216 lines
6.2 KiB
C
216 lines
6.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/* Copyright (c) 2018, The Linux Foundation. All rights reserved. */
|
|
|
|
#ifndef _DT_BINDINGS_POWER_QCOM_RPMPD_H
|
|
#define _DT_BINDINGS_POWER_QCOM_RPMPD_H
|
|
|
|
#include <dt-bindings/power/qcom,rpmhpd.h>
|
|
|
|
/* Generic RPM Power Domain Indexes */
|
|
#define RPMPD_VDDCX 0
|
|
#define RPMPD_VDDCX_AO 1
|
|
/* VFC and VFL are mutually exclusive and can not be present on the same platform */
|
|
#define RPMPD_VDDCX_VFC 2
|
|
#define RPMPD_VDDCX_VFL 2
|
|
#define RPMPD_VDDMX 3
|
|
#define RPMPD_VDDMX_AO 4
|
|
#define RPMPD_VDDMX_VFL 5
|
|
#define RPMPD_SSCCX 6
|
|
#define RPMPD_SSCCX_VFL 7
|
|
#define RPMPD_SSCMX 8
|
|
#define RPMPD_SSCMX_VFL 9
|
|
|
|
/*
|
|
* Platform-specific power domain bindings. Don't add new entries here, use
|
|
* RPMPD_* above.
|
|
*/
|
|
|
|
/* MDM9607 Power Domains */
|
|
#define MDM9607_VDDCX RPMPD_VDDCX
|
|
#define MDM9607_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MDM9607_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define MDM9607_VDDMX RPMPD_VDDMX
|
|
#define MDM9607_VDDMX_AO RPMPD_VDDMX_AO
|
|
#define MDM9607_VDDMX_VFL RPMPD_VDDMX_VFL
|
|
|
|
/* MSM8226 Power Domain Indexes */
|
|
#define MSM8226_VDDCX RPMPD_VDDCX
|
|
#define MSM8226_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MSM8226_VDDCX_VFC RPMPD_VDDCX_VFC
|
|
|
|
/* MSM8939 Power Domains */
|
|
#define MSM8939_VDDMDCX 0
|
|
#define MSM8939_VDDMDCX_AO 1
|
|
#define MSM8939_VDDMDCX_VFC 2
|
|
#define MSM8939_VDDCX 3
|
|
#define MSM8939_VDDCX_AO 4
|
|
#define MSM8939_VDDCX_VFC 5
|
|
#define MSM8939_VDDMX 6
|
|
#define MSM8939_VDDMX_AO 7
|
|
|
|
/* MSM8916 Power Domain Indexes */
|
|
#define MSM8916_VDDCX RPMPD_VDDCX
|
|
#define MSM8916_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MSM8916_VDDCX_VFC RPMPD_VDDCX_VFC
|
|
#define MSM8916_VDDMX RPMPD_VDDMX
|
|
#define MSM8916_VDDMX_AO RPMPD_VDDMX_AO
|
|
|
|
/* MSM8909 Power Domain Indexes */
|
|
#define MSM8909_VDDCX MSM8916_VDDCX
|
|
#define MSM8909_VDDCX_AO MSM8916_VDDCX_AO
|
|
#define MSM8909_VDDCX_VFC MSM8916_VDDCX_VFC
|
|
#define MSM8909_VDDMX MSM8916_VDDMX
|
|
#define MSM8909_VDDMX_AO MSM8916_VDDMX_AO
|
|
|
|
/* MSM8917 Power Domain Indexes */
|
|
#define MSM8917_VDDCX RPMPD_VDDCX
|
|
#define MSM8917_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MSM8917_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define MSM8917_VDDMX RPMPD_VDDMX
|
|
#define MSM8917_VDDMX_AO RPMPD_VDDMX_AO
|
|
|
|
/* MSM8937 Power Domain Indexes */
|
|
#define MSM8937_VDDCX MSM8917_VDDCX
|
|
#define MSM8937_VDDCX_AO MSM8917_VDDCX_AO
|
|
#define MSM8937_VDDCX_VFL MSM8917_VDDCX_VFL
|
|
#define MSM8937_VDDMX MSM8917_VDDMX
|
|
#define MSM8937_VDDMX_AO MSM8917_VDDMX_AO
|
|
|
|
/* QM215 Power Domain Indexes */
|
|
#define QM215_VDDCX MSM8917_VDDCX
|
|
#define QM215_VDDCX_AO MSM8917_VDDCX_AO
|
|
#define QM215_VDDCX_VFL MSM8917_VDDCX_VFL
|
|
#define QM215_VDDMX MSM8917_VDDMX
|
|
#define QM215_VDDMX_AO MSM8917_VDDMX_AO
|
|
|
|
/* MSM8953 Power Domain Indexes */
|
|
#define MSM8953_VDDMD 0
|
|
#define MSM8953_VDDMD_AO 1
|
|
#define MSM8953_VDDCX 2
|
|
#define MSM8953_VDDCX_AO 3
|
|
#define MSM8953_VDDCX_VFL 4
|
|
#define MSM8953_VDDMX 5
|
|
#define MSM8953_VDDMX_AO 6
|
|
|
|
/* MSM8974 Power Domain Indexes */
|
|
#define MSM8974_VDDCX 0
|
|
#define MSM8974_VDDCX_AO 1
|
|
#define MSM8974_VDDCX_VFC 2
|
|
#define MSM8974_VDDGFX 3
|
|
#define MSM8974_VDDGFX_VFC 4
|
|
|
|
/* MSM8976 Power Domain Indexes */
|
|
#define MSM8976_VDDCX RPMPD_VDDCX
|
|
#define MSM8976_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MSM8976_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define MSM8976_VDDMX RPMPD_VDDMX
|
|
#define MSM8976_VDDMX_AO RPMPD_VDDMX_AO
|
|
#define MSM8976_VDDMX_VFL RPMPD_VDDMX_VFL
|
|
|
|
/* MSM8994 Power Domain Indexes */
|
|
#define MSM8994_VDDCX 0
|
|
#define MSM8994_VDDCX_AO 1
|
|
#define MSM8994_VDDCX_VFC 2
|
|
#define MSM8994_VDDMX 3
|
|
#define MSM8994_VDDMX_AO 4
|
|
#define MSM8994_VDDGFX 5
|
|
#define MSM8994_VDDGFX_VFC 6
|
|
|
|
/* MSM8996 Power Domain Indexes */
|
|
#define MSM8996_VDDCX 0
|
|
#define MSM8996_VDDCX_AO 1
|
|
#define MSM8996_VDDCX_VFC 2
|
|
#define MSM8996_VDDMX 3
|
|
#define MSM8996_VDDMX_AO 4
|
|
#define MSM8996_VDDSSCX 5
|
|
#define MSM8996_VDDSSCX_VFC 6
|
|
|
|
/* MSM8998 Power Domain Indexes */
|
|
#define MSM8998_VDDCX RPMPD_VDDCX
|
|
#define MSM8998_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define MSM8998_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define MSM8998_VDDMX RPMPD_VDDMX
|
|
#define MSM8998_VDDMX_AO RPMPD_VDDMX_AO
|
|
#define MSM8998_VDDMX_VFL RPMPD_VDDMX_VFL
|
|
#define MSM8998_SSCCX RPMPD_SSCCX
|
|
#define MSM8998_SSCCX_VFL RPMPD_SSCCX_VFL
|
|
#define MSM8998_SSCMX RPMPD_SSCMX
|
|
#define MSM8998_SSCMX_VFL RPMPD_SSCMX_VFL
|
|
|
|
/* QCM2290 Power Domains */
|
|
#define QCM2290_VDDCX 0
|
|
#define QCM2290_VDDCX_AO 1
|
|
#define QCM2290_VDDCX_VFL 2
|
|
#define QCM2290_VDDMX 3
|
|
#define QCM2290_VDDMX_AO 4
|
|
#define QCM2290_VDDMX_VFL 5
|
|
#define QCM2290_VDD_LPI_CX 6
|
|
#define QCM2290_VDD_LPI_MX 7
|
|
|
|
/* QCS404 Power Domains */
|
|
#define QCS404_VDDMX 0
|
|
#define QCS404_VDDMX_AO 1
|
|
#define QCS404_VDDMX_VFL 2
|
|
#define QCS404_LPICX 3
|
|
#define QCS404_LPICX_VFL 4
|
|
#define QCS404_LPIMX 5
|
|
#define QCS404_LPIMX_VFL 6
|
|
|
|
/* SDM660 Power Domains */
|
|
#define SDM660_VDDCX RPMPD_VDDCX
|
|
#define SDM660_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define SDM660_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define SDM660_VDDMX RPMPD_VDDMX
|
|
#define SDM660_VDDMX_AO RPMPD_VDDMX_AO
|
|
#define SDM660_VDDMX_VFL RPMPD_VDDMX_VFL
|
|
#define SDM660_SSCCX RPMPD_SSCCX
|
|
#define SDM660_SSCCX_VFL RPMPD_SSCCX_VFL
|
|
#define SDM660_SSCMX RPMPD_SSCMX
|
|
#define SDM660_SSCMX_VFL RPMPD_SSCMX_VFL
|
|
|
|
/* SM6115 Power Domains */
|
|
#define SM6115_VDDCX 0
|
|
#define SM6115_VDDCX_AO 1
|
|
#define SM6115_VDDCX_VFL 2
|
|
#define SM6115_VDDMX 3
|
|
#define SM6115_VDDMX_AO 4
|
|
#define SM6115_VDDMX_VFL 5
|
|
#define SM6115_VDD_LPI_CX 6
|
|
#define SM6115_VDD_LPI_MX 7
|
|
|
|
/* SM6125 Power Domains */
|
|
#define SM6125_VDDCX RPMPD_VDDCX
|
|
#define SM6125_VDDCX_AO RPMPD_VDDCX_AO
|
|
#define SM6125_VDDCX_VFL RPMPD_VDDCX_VFL
|
|
#define SM6125_VDDMX RPMPD_VDDMX
|
|
#define SM6125_VDDMX_AO RPMPD_VDDMX_AO
|
|
#define SM6125_VDDMX_VFL RPMPD_VDDMX_VFL
|
|
|
|
/* SM6375 Power Domain Indexes */
|
|
#define SM6375_VDDCX 0
|
|
#define SM6375_VDDCX_AO 1
|
|
#define SM6375_VDDCX_VFL 2
|
|
#define SM6375_VDDMX 3
|
|
#define SM6375_VDDMX_AO 4
|
|
#define SM6375_VDDMX_VFL 5
|
|
#define SM6375_VDDGX 6
|
|
#define SM6375_VDDGX_AO 7
|
|
#define SM6375_VDD_LPI_CX 8
|
|
#define SM6375_VDD_LPI_MX 9
|
|
|
|
/* RPM SMD Power Domain performance levels */
|
|
#define RPM_SMD_LEVEL_RETENTION 16
|
|
#define RPM_SMD_LEVEL_RETENTION_PLUS 32
|
|
#define RPM_SMD_LEVEL_MIN_SVS 48
|
|
#define RPM_SMD_LEVEL_LOW_SVS 64
|
|
#define RPM_SMD_LEVEL_SVS 128
|
|
#define RPM_SMD_LEVEL_SVS_PLUS 192
|
|
#define RPM_SMD_LEVEL_NOM 256
|
|
#define RPM_SMD_LEVEL_NOM_PLUS 320
|
|
#define RPM_SMD_LEVEL_TURBO 384
|
|
#define RPM_SMD_LEVEL_TURBO_NO_CPR 416
|
|
#define RPM_SMD_LEVEL_TURBO_HIGH 448
|
|
#define RPM_SMD_LEVEL_BINNING 512
|
|
|
|
#endif
|