/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (C) 2026 MediaTek Inc. All Rights Reserved. * Author: Bo-Chen Chen */ #ifndef __MT6359_H_ #define __MT6359_H_ #define MT6359_REGULATOR_DRIVER "mt6359_regulator" enum { MT6359_ID_VS1 = 0, MT6359_ID_VGPU11, MT6359_ID_VMODEM, MT6359_ID_VPU, MT6359_ID_VCORE, MT6359_ID_VS2, MT6359_ID_VPA, MT6359_ID_VPROC2, MT6359_ID_VPROC1, MT6359_ID_VCORE_SSHUB, MT6359_ID_VGPU11_SSHUB = MT6359_ID_VCORE_SSHUB, MT6359_ID_VAUD18 = 10, MT6359_ID_VSIM1, MT6359_ID_VIBR, MT6359_ID_VRF12, MT6359_ID_VUSB, MT6359_ID_VSRAM_PROC2, MT6359_ID_VIO18, MT6359_ID_VCAMIO, MT6359_ID_VCN18, MT6359_ID_VFE28, MT6359_ID_VCN13, MT6359_ID_VCN33_1_BT, MT6359_ID_VCN33_1_WIFI, MT6359_ID_VAUX18, MT6359_ID_VSRAM_OTHERS, MT6359_ID_VEFUSE, MT6359_ID_VXO22, MT6359_ID_VRFCK, MT6359_ID_VBIF28, MT6359_ID_VIO28, MT6359_ID_VEMC, MT6359_ID_VCN33_2_BT, MT6359_ID_VCN33_2_WIFI, MT6359_ID_VA12, MT6359_ID_VA09, MT6359_ID_VRF18, MT6359_ID_VSRAM_MD, MT6359_ID_VUFS, MT6359_ID_VM18, MT6359_ID_VBBCK, MT6359_ID_VSRAM_PROC1, MT6359_ID_VSIM2, MT6359_ID_VSRAM_OTHERS_SSHUB, MT6359_ID_RG_MAX, }; /* PMIC Registers */ #define MT6359_BUCK_VPU_CON0 0x1488 #define MT6359_BUCK_VPU_DBG1 0x14a8 #define MT6359_BUCK_VPU_ELR0 0x14ac #define MT6359_BUCK_VCORE_CON0 0x1508 #define MT6359_BUCK_VCORE_DBG1 0x1528 #define MT6359_BUCK_VGPU11_CON0 0x1588 #define MT6359_BUCK_VGPU11_DBG1 0x15a8 #define MT6359_BUCK_VMODEM_CON0 0x1688 #define MT6359_BUCK_VMODEM_DBG1 0x16a8 #define MT6359_BUCK_VMODEM_ELR0 0x16ae #define MT6359_BUCK_VPROC1_CON0 0x1708 #define MT6359_BUCK_VPROC1_DBG1 0x1728 #define MT6359_BUCK_VPROC1_ELR0 0x172e #define MT6359_BUCK_VPROC2_CON0 0x1788 #define MT6359_BUCK_VPROC2_DBG1 0x17a8 #define MT6359_BUCK_VPROC2_ELR0 0x17b2 #define MT6359_BUCK_VS1_CON0 0x1808 #define MT6359_BUCK_VS1_DBG1 0x1828 #define MT6359_BUCK_VS1_ELR0 0x1834 #define MT6359_BUCK_VS2_CON0 0x1888 #define MT6359_BUCK_VS2_DBG1 0x18a8 #define MT6359_BUCK_VS2_ELR0 0x18b4 #define MT6359_BUCK_VPA_CON0 0x1908 #define MT6359_BUCK_VPA_CON1 0x190e #define MT6359_BUCK_VPA_DBG1 0x1916 #define MT6359_VGPUVCORE_ANA_CON2 0x198e #define MT6359_VGPUVCORE_ANA_CON13 0x19a4 #define MT6359_VPROC1_ANA_CON3 0x19b2 #define MT6359_VPROC2_ANA_CON3 0x1a0e #define MT6359_VMODEM_ANA_CON3 0x1a1a #define MT6359_VPU_ANA_CON3 0x1a26 #define MT6359_VS1_ANA_CON0 0x1a2c #define MT6359_VS2_ANA_CON0 0x1a34 #define MT6359_VPA_ANA_CON0 0x1a3c #define MT6359_RG_BUCK_VPU_EN_ADDR MT6359_BUCK_VPU_CON0 #define MT6359_RG_BUCK_VPU_LP_ADDR MT6359_BUCK_VPU_CON0 #define MT6359_RG_BUCK_VPU_LP_SHIFT 1 #define MT6359_DA_VPU_EN_ADDR MT6359_BUCK_VPU_DBG1 #define MT6359_RG_BUCK_VPU_VOSEL_ADDR MT6359_BUCK_VPU_ELR0 #define MT6359_RG_BUCK_VPU_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VPU_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VCORE_EN_ADDR MT6359_BUCK_VCORE_CON0 #define MT6359_RG_BUCK_VCORE_LP_ADDR MT6359_BUCK_VCORE_CON0 #define MT6359_RG_BUCK_VCORE_LP_SHIFT 1 #define MT6359_DA_VCORE_EN_ADDR MT6359_BUCK_VCORE_DBG1 #define MT6359_RG_BUCK_VCORE_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VCORE_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VGPU11_EN_ADDR MT6359_BUCK_VGPU11_CON0 #define MT6359_RG_BUCK_VGPU11_LP_ADDR MT6359_BUCK_VGPU11_CON0 #define MT6359_RG_BUCK_VGPU11_LP_SHIFT 1 #define MT6359_DA_VGPU11_EN_ADDR MT6359_BUCK_VGPU11_DBG1 #define MT6359_RG_BUCK_VGPU11_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VGPU11_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VMODEM_EN_ADDR MT6359_BUCK_VMODEM_CON0 #define MT6359_RG_BUCK_VMODEM_LP_ADDR MT6359_BUCK_VMODEM_CON0 #define MT6359_RG_BUCK_VMODEM_LP_SHIFT 1 #define MT6359_DA_VMODEM_EN_ADDR MT6359_BUCK_VMODEM_DBG1 #define MT6359_RG_BUCK_VMODEM_VOSEL_ADDR MT6359_BUCK_VMODEM_ELR0 #define MT6359_RG_BUCK_VMODEM_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VMODEM_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VPROC1_EN_ADDR MT6359_BUCK_VPROC1_CON0 #define MT6359_RG_BUCK_VPROC1_LP_ADDR MT6359_BUCK_VPROC1_CON0 #define MT6359_RG_BUCK_VPROC1_LP_SHIFT 1 #define MT6359_DA_VPROC1_EN_ADDR MT6359_BUCK_VPROC1_DBG1 #define MT6359_RG_BUCK_VPROC1_VOSEL_ADDR MT6359_BUCK_VPROC1_ELR0 #define MT6359_RG_BUCK_VPROC1_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VPROC1_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VPROC2_EN_ADDR MT6359_BUCK_VPROC2_CON0 #define MT6359_RG_BUCK_VPROC2_LP_ADDR MT6359_BUCK_VPROC2_CON0 #define MT6359_RG_BUCK_VPROC2_LP_SHIFT 1 #define MT6359_DA_VPROC2_EN_ADDR MT6359_BUCK_VPROC2_DBG1 #define MT6359_RG_BUCK_VPROC2_VOSEL_ADDR MT6359_BUCK_VPROC2_ELR0 #define MT6359_RG_BUCK_VPROC2_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VPROC2_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VS1_EN_ADDR MT6359_BUCK_VS1_CON0 #define MT6359_RG_BUCK_VS1_LP_ADDR MT6359_BUCK_VS1_CON0 #define MT6359_RG_BUCK_VS1_LP_SHIFT 1 #define MT6359_DA_VS1_EN_ADDR MT6359_BUCK_VS1_DBG1 #define MT6359_RG_BUCK_VS1_VOSEL_ADDR MT6359_BUCK_VS1_ELR0 #define MT6359_RG_BUCK_VS1_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VS1_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VS2_EN_ADDR MT6359_BUCK_VS2_CON0 #define MT6359_RG_BUCK_VS2_LP_ADDR MT6359_BUCK_VS2_CON0 #define MT6359_RG_BUCK_VS2_LP_SHIFT 1 #define MT6359_DA_VS2_EN_ADDR MT6359_BUCK_VS2_DBG1 #define MT6359_RG_BUCK_VS2_VOSEL_ADDR MT6359_BUCK_VS2_ELR0 #define MT6359_RG_BUCK_VS2_VOSEL_MASK 0x7F #define MT6359_RG_BUCK_VS2_VOSEL_SHIFT 0 #define MT6359_RG_BUCK_VPA_EN_ADDR MT6359_BUCK_VPA_CON0 #define MT6359_RG_BUCK_VPA_LP_ADDR MT6359_BUCK_VPA_CON0 #define MT6359_RG_BUCK_VPA_LP_SHIFT 1 #define MT6359_RG_BUCK_VPA_VOSEL_ADDR MT6359_BUCK_VPA_CON1 #define MT6359_RG_BUCK_VPA_VOSEL_MASK 0x3F #define MT6359_RG_BUCK_VPA_VOSEL_SHIFT 0 #define MT6359_DA_VPA_EN_ADDR MT6359_BUCK_VPA_DBG1 #define MT6359_RG_VGPU11_FCCM_ADDR MT6359_VGPUVCORE_ANA_CON2 #define MT6359_RG_VGPU11_FCCM_SHIFT 9 #define MT6359_RG_VCORE_FCCM_ADDR MT6359_VGPUVCORE_ANA_CON13 #define MT6359_RG_VCORE_FCCM_SHIFT 5 #define MT6359_RG_VPROC1_FCCM_ADDR MT6359_VPROC1_ANA_CON3 #define MT6359_RG_VPROC1_FCCM_SHIFT 1 #define MT6359_RG_VPROC2_FCCM_ADDR MT6359_VPROC2_ANA_CON3 #define MT6359_RG_VPROC2_FCCM_SHIFT 1 #define MT6359_RG_VMODEM_FCCM_ADDR MT6359_VMODEM_ANA_CON3 #define MT6359_RG_VMODEM_FCCM_SHIFT 1 #define MT6359_RG_VPU_FCCM_ADDR MT6359_VPU_ANA_CON3 #define MT6359_RG_VPU_FCCM_SHIFT 1 #define MT6359_RG_VS1_FPWM_ADDR MT6359_VS1_ANA_CON0 #define MT6359_RG_VS1_FPWM_SHIFT 3 #define MT6359_RG_VS2_FPWM_ADDR MT6359_VS2_ANA_CON0 #define MT6359_RG_VS2_FPWM_SHIFT 3 #define MT6359_RG_VPA_MODESET_ADDR MT6359_VPA_ANA_CON0 #define MT6359_RG_VPA_MODESET_SHIFT 1 #define MT6359_RG_LDO_VSRAM_PROC1_VOSEL_MASK 0x7F #define MT6359_RG_LDO_VSRAM_PROC1_VOSEL_SHIFT 0 #define MT6359_RG_LDO_VSRAM_PROC2_VOSEL_MASK 0x7F #define MT6359_RG_LDO_VSRAM_PROC2_VOSEL_SHIFT 0 #define MT6359_RG_LDO_VSRAM_OTHERS_VOSEL_MASK 0x7F #define MT6359_RG_LDO_VSRAM_OTHERS_VOSEL_SHIFT 0 #define MT6359_RG_LDO_VSRAM_MD_VOSEL_MASK 0x7F #define MT6359_RG_LDO_VSRAM_MD_VOSEL_SHIFT 0 #define MT6359_RG_LDO_VCN33_1_EN_0_SHIFT 0 #define MT6359_RG_LDO_VCN33_2_EN_1_SHIFT 15 #define MT6359_RG_LDO_VSRAM_OTHERS_SSHUB_VOSEL_MASK 0x7F #define MT6359_RG_LDO_VSRAM_OTHERS_SSHUB_VOSEL_SHIFT 1 #define MT6359_RG_VCN33_1_VOSEL_MASK 0xF #define MT6359_RG_VCN33_1_VOSEL_SHIFT 8 #define MT6359_RG_VCN33_2_VOSEL_MASK 0xF #define MT6359_RG_VCN33_2_VOSEL_SHIFT 8 #define MT6359_RG_VSIM1_VOSEL_MASK 0xF #define MT6359_RG_VSIM1_VOSEL_SHIFT 8 #define MT6359_RG_VSIM2_VOSEL_MASK 0xF #define MT6359_RG_VSIM2_VOSEL_SHIFT 8 #define MT6359_RG_VIO28_VOSEL_MASK 0xF #define MT6359_RG_VIO28_VOSEL_SHIFT 8 #define MT6359_RG_VIBR_VOSEL_MASK 0xF #define MT6359_RG_VIBR_VOSEL_SHIFT 8 #define MT6359_RG_VRF18_VOSEL_MASK 0xF #define MT6359_RG_VRF18_VOSEL_SHIFT 8 #define MT6359_RG_VEFUSE_VOSEL_MASK 0xF #define MT6359_RG_VEFUSE_VOSEL_SHIFT 8 #define MT6359_RG_VCAMIO_VOSEL_MASK 0xF #define MT6359_RG_VCAMIO_VOSEL_SHIFT 8 #define MT6359_RG_VIO18_VOSEL_MASK 0xF #define MT6359_RG_VIO18_VOSEL_SHIFT 8 #define MT6359_RG_VM18_VOSEL_MASK 0xF #define MT6359_RG_VM18_VOSEL_SHIFT 8 #define MT6359_RG_VUFS_VOSEL_MASK 0xF #define MT6359_RG_VUFS_VOSEL_SHIFT 8 #define MT6359_RG_VRF12_VOSEL_MASK 0xF #define MT6359_RG_VRF12_VOSEL_SHIFT 8 #define MT6359_RG_VCN13_VOSEL_MASK 0xF #define MT6359_RG_VCN13_VOSEL_SHIFT 8 #define MT6359_RG_VA09_VOSEL_MASK 0xF #define MT6359_RG_VA09_VOSEL_SHIFT 8 #define MT6359_RG_VA12_VOSEL_MASK 0xF #define MT6359_RG_VA12_VOSEL_SHIFT 8 #define MT6359_RG_VXO22_VOSEL_MASK 0xF #define MT6359_RG_VXO22_VOSEL_SHIFT 8 #define MT6359_RG_VRFCK_VOSEL_MASK 0xF #define MT6359_RG_VRFCK_VOSEL_SHIFT 8 #endif