6db4831e98
Android 14
82 lines
1.8 KiB
C
82 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2019 MediaTek Inc.
|
|
*/
|
|
|
|
#ifndef __HELIO_DVFSRC_V6781_H
|
|
#define __HELIO_DVFSRC_V6781_H
|
|
|
|
#include <mach/upmu_hw.h>
|
|
|
|
#if defined(CONFIG_MTK_DVFSRC_MT6781_PRETEST)
|
|
#define PMIC_VCORE_ADDR PMIC_RG_BUCK_VCORE_VOSEL
|
|
#define VCORE_BASE_UV 400000
|
|
#define VCORE_STEP_UV 6250
|
|
#else
|
|
#define PMIC_VCORE_ADDR PMIC_RG_BUCK_VCORE_VOSEL
|
|
#define VCORE_BASE_UV 500000
|
|
#define VCORE_STEP_UV 6250
|
|
#endif
|
|
|
|
#define PMIC_VSRAM_OTHERS_ADDR PMIC_RG_LDO_VSRAM_OTHERS_VOSEL
|
|
#define VSRAM_BASE_UV 500000
|
|
#define VSRAM_STEP_UV 6250
|
|
|
|
/* PMIC */
|
|
#define __vcore_pmic_to_uv(pmic) \
|
|
(((pmic) * VCORE_STEP_UV) + VCORE_BASE_UV)
|
|
|
|
#define __vcore_uv_to_pmic(uv) /* pmic >= uv */ \
|
|
((((uv) - VCORE_BASE_UV) + (VCORE_STEP_UV - 1)) / VCORE_STEP_UV)
|
|
|
|
/* VSRAM_OTHERS */
|
|
#define vsram_pmic_to_uv(pmic) \
|
|
(((pmic) * VSRAM_STEP_UV) + VSRAM_BASE_UV)
|
|
|
|
#define vsram_uv_to_pmic(uv) /* pmic >= uv */ \
|
|
((((uv) - VSRAM_BASE_UV) + (VSRAM_STEP_UV - 1)) / VSRAM_STEP_UV)
|
|
|
|
|
|
enum met_src_index {
|
|
SRC_MD2SPM_IDX = 0,
|
|
DDR_OPP_IDX,
|
|
DDR_SW_REQ1_SPM_IDX,
|
|
DDR_SW_REQ2_CM_IDX,
|
|
DDR_SW_REQ3_PMQOS_IDX,
|
|
#if defined(CONFIG_MTK_DVFSRC_MT6781_PRETEST)
|
|
DDR_SW_REQ4_MD_IDX,
|
|
DDR_SW_REQ8_MCUSYS_IDX,
|
|
#endif
|
|
DDR_QOS_BW_IDX,
|
|
DDR_EMI_TOTAL_IDX,
|
|
DDR_HRT_BW_IDX,
|
|
DDR_HIFI_IDX,
|
|
DDR_HIFI_LATENCY_IDX,
|
|
DDR_MD_LATENCY_IDX,
|
|
DDR_MD_DDR_IDX,
|
|
DDR_MD_SRCLK_IDX,
|
|
VCORE_OPP_IDX,
|
|
VCORE_SW_REQ3_PMQOS_IDX,
|
|
VCORE_SCP_IDX,
|
|
VCORE_HIFI_IDX,
|
|
SRC_SCP_REQ_IDX,
|
|
SRC_PMQOS_TATOL_IDX,
|
|
SRC_PMQOS_BW0_IDX,
|
|
SRC_PMQOS_BW1_IDX,
|
|
SRC_PMQOS_BW2_IDX,
|
|
SRC_PMQOS_BW3_IDX,
|
|
SRC_PMQOS_BW4_IDX,
|
|
SRC_TOTAL_EMI_BW_IDX,
|
|
SRC_HRT_MD_BW_IDX,
|
|
SRC_HRT_DISP_BW_IDX,
|
|
SRC_HRT_ISP_BW_IDX,
|
|
SRC_MD_SCENARIO_IDX,
|
|
SRC_HIFI_SCENARIO_IDX,
|
|
SRC_MD_EMI_LATENCY_IDX,
|
|
SRC_MAX
|
|
};
|
|
extern u32 dvfsrc_ct_mode(void);
|
|
extern u32 dvfsrc_vcore_mode(void);
|
|
#endif /* __HELIO_DVFSRC_V6781_H */
|
|
|