| /* 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 |