unplugged-kernel/drivers/misc/mediatek/dcm/mt6761_dcm_autogen.c

1005 lines
27 KiB
C

// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#include <linux/io.h>
#include <mt6761_dcm_internal.h>
#include <mt6761_dcm_autogen.h>
#include <mtk_dcm.h>
/* Below from DCM autogen. */
#define INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_MASK ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x1 << 3) | \
(0x1 << 4) | \
(0x1f << 5) | \
(0x1 << 20) | \
(0x1 << 21) | \
(0x1 << 22) | \
(0x1 << 23) | \
(0x1 << 30))
#define INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_ON ((0x1 << 0) | \
(0x1 << 1) | \
(0x0 << 2) | \
(0x0 << 3) | \
(0x0 << 4) | \
(0x10 << 5) | \
(0x1 << 20) | \
(0x1 << 21) | \
(0x1 << 22) | \
(0x1 << 23) | \
(0x1 << 30))
#define INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_OFF ((0x0 << 0) | \
(0x0 << 1) | \
(0x0 << 2) | \
(0x0 << 3) | \
(0x0 << 4) | \
(0x10 << 5) | \
(0x0 << 20) | \
(0x1 << 21) | \
(0x1 << 22) | \
(0x0 << 23) | \
(0x0 << 30))
static void infracfg_ao_infra_dcm_rg_sfsel_set(unsigned int val)
{
reg_write(INFRA_BUS_DCM_CTRL,
(reg_read(INFRA_BUS_DCM_CTRL) &
~(0x1f << 10)) |
(val & 0x1f) << 10);
}
bool dcm_infracfg_ao_dcm_infrabus_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(INFRA_BUS_DCM_CTRL) &
INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_MASK) ==
(unsigned int) INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_ON);
return ret;
}
void dcm_infracfg_ao_dcm_infrabus_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'infracfg_ao_dcm_infrabus_group'" */
infracfg_ao_infra_dcm_rg_sfsel_set(0x1);
reg_write(INFRA_BUS_DCM_CTRL,
(reg_read(INFRA_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'infracfg_ao_dcm_infrabus_group'" */
infracfg_ao_infra_dcm_rg_sfsel_set(0x1);
reg_write(INFRA_BUS_DCM_CTRL,
(reg_read(INFRA_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_INFRABUS_GROUP_REG0_OFF);
}
}
#define INFRACFG_AO_DCM_MEM_GROUP_REG0_MASK ((0x1 << 0) | \
(0x1 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x7f << 9) | \
(0x1f << 16) | \
(0x1f << 21) | \
(0x1 << 26) | \
(0x1 << 27) | \
(0x1 << 28) | \
(0x1 << 29) | \
(0x1 << 31))
#define INFRACFG_AO_DCM_MEM_GROUP_REG1_MASK ((0x1 << 0) | \
(0x1 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x1f << 16) | \
(0x1f << 21) | \
(0x1 << 26))
#define INFRACFG_AO_DCM_MEM_GROUP_REG0_ON ((0x0 << 0) | \
(0x0 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x0 << 9) | \
(0x0 << 16) | \
(0x1f << 21) | \
(0x0 << 26) | \
(0x1 << 27) | \
(0x0 << 28) | \
(0x0 << 29) | \
(0x0 << 31))
#define INFRACFG_AO_DCM_MEM_GROUP_REG1_ON ((0x0 << 0) | \
(0x0 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x0 << 16) | \
(0x1f << 21) | \
(0x0 << 26))
#define INFRACFG_AO_DCM_MEM_GROUP_REG0_OFF ((0x0 << 0) | \
(0x0 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x0 << 9) | \
(0x0 << 16) | \
(0x1f << 21) | \
(0x0 << 26) | \
(0x1 << 27) | \
(0x0 << 28) | \
(0x0 << 29) | \
(0x0 << 31))
#define INFRACFG_AO_DCM_MEM_GROUP_REG1_OFF ((0x0 << 0) | \
(0x0 << 6) | \
(0x1 << 7) | \
(0x1 << 8) | \
(0x0 << 16) | \
(0x1f << 21) | \
(0x0 << 26))
bool dcm_infracfg_ao_dcm_mem_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(MEM_DCM_CTRL) &
INFRACFG_AO_DCM_MEM_GROUP_REG0_MASK) ==
(unsigned int) INFRACFG_AO_DCM_MEM_GROUP_REG0_ON);
ret &= ((reg_read(DFS_MEM_DCM_CTRL) &
INFRACFG_AO_DCM_MEM_GROUP_REG1_MASK) ==
(unsigned int) INFRACFG_AO_DCM_MEM_GROUP_REG1_ON);
return ret;
}
void dcm_infracfg_ao_dcm_mem_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'infracfg_ao_dcm_mem_group'" */
reg_write(MEM_DCM_CTRL,
(reg_read(MEM_DCM_CTRL) &
~INFRACFG_AO_DCM_MEM_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_MEM_GROUP_REG0_ON);
reg_write(DFS_MEM_DCM_CTRL,
(reg_read(DFS_MEM_DCM_CTRL) &
~INFRACFG_AO_DCM_MEM_GROUP_REG1_MASK) |
INFRACFG_AO_DCM_MEM_GROUP_REG1_ON);
} else {
/* TINFO = "Turn OFF DCM 'infracfg_ao_dcm_mem_group'" */
reg_write(MEM_DCM_CTRL,
(reg_read(MEM_DCM_CTRL) &
~INFRACFG_AO_DCM_MEM_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_MEM_GROUP_REG0_OFF);
reg_write(DFS_MEM_DCM_CTRL,
(reg_read(DFS_MEM_DCM_CTRL) &
~INFRACFG_AO_DCM_MEM_GROUP_REG1_MASK) |
INFRACFG_AO_DCM_MEM_GROUP_REG1_OFF);
}
}
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_MASK ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 3) | \
(0x1 << 4) | \
(0x1f << 5) | \
(0x1f << 15) | \
(0x1 << 20) | \
(0x1 << 21) | \
(0x1 << 22) | \
(0x1f << 23) | \
(0x1 << 28) | \
(0x1 << 29))
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_MASK ((0xf << 0))
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_ON ((0x1 << 0) | \
(0x1 << 1) | \
(0x0 << 3) | \
(0x0 << 4) | \
(0x1f << 5) | \
(0x1f << 15) | \
(0x1 << 20) | \
(0x1 << 21) | \
(0x1 << 22) | \
(0x0 << 23) | \
(0x1 << 28) | \
(0x1 << 29))
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_ON ((0x0 << 0))
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_OFF ((0x0 << 0) | \
(0x0 << 1) | \
(0x0 << 3) | \
(0x0 << 4) | \
(0x1f << 5) | \
(0x0 << 15) | \
(0x0 << 20) | \
(0x0 << 21) | \
(0x0 << 22) | \
(0x0 << 23) | \
(0x0 << 28) | \
(0x0 << 29))
#define INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_OFF ((0xf << 0))
static void infracfg_ao_peri_dcm_rg_sfsel_set(unsigned int val)
{
reg_write(PERI_BUS_DCM_CTRL,
(reg_read(PERI_BUS_DCM_CTRL) &
~(0x1f << 10)) |
(val & 0x1f) << 10);
}
bool dcm_infracfg_ao_dcm_peribus_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(PERI_BUS_DCM_CTRL) &
INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_MASK) ==
(unsigned int) INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_ON);
ret &= ((reg_read(P2P_RX_CLK_ON) &
INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_MASK) ==
(unsigned int) INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_ON);
return ret;
}
void dcm_infracfg_ao_dcm_peribus_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'infracfg_ao_dcm_peribus_group'" */
infracfg_ao_peri_dcm_rg_sfsel_set(0x0);
reg_write(PERI_BUS_DCM_CTRL,
(reg_read(PERI_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_ON);
reg_write(P2P_RX_CLK_ON,
(reg_read(P2P_RX_CLK_ON) &
~INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_MASK) |
INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_ON);
} else {
/* TINFO = "Turn OFF DCM 'infracfg_ao_dcm_peribus_group'" */
infracfg_ao_peri_dcm_rg_sfsel_set(0x0);
reg_write(PERI_BUS_DCM_CTRL,
(reg_read(PERI_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_PERIBUS_GROUP_REG0_OFF);
reg_write(P2P_RX_CLK_ON,
(reg_read(P2P_RX_CLK_ON) &
~INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_MASK) |
INFRACFG_AO_DCM_PERIBUS_GROUP_REG1_OFF);
}
}
#define INFRACFG_AO_DCM_SSUSB_GROUP_REG0_MASK ((0x1 << 31))
#define INFRACFG_AO_DCM_SSUSB_GROUP_REG0_ON ((0x1 << 31))
#define INFRACFG_AO_DCM_SSUSB_GROUP_REG0_OFF ((0x0 << 31))
bool dcm_infracfg_ao_dcm_ssusb_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(PERI_BUS_DCM_CTRL) &
INFRACFG_AO_DCM_SSUSB_GROUP_REG0_MASK) ==
(unsigned int) INFRACFG_AO_DCM_SSUSB_GROUP_REG0_ON);
return ret;
}
void dcm_infracfg_ao_dcm_ssusb_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'infracfg_ao_dcm_ssusb_group'" */
reg_write(PERI_BUS_DCM_CTRL,
(reg_read(PERI_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_SSUSB_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_SSUSB_GROUP_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'infracfg_ao_dcm_ssusb_group'" */
reg_write(PERI_BUS_DCM_CTRL,
(reg_read(PERI_BUS_DCM_CTRL) &
~INFRACFG_AO_DCM_SSUSB_GROUP_REG0_MASK) |
INFRACFG_AO_DCM_SSUSB_GROUP_REG0_OFF);
}
}
#define MP0_CPUCFG_MP0_RGU_DCM_REG0_MASK ((0x1 << 0))
#define MP0_CPUCFG_MP0_RGU_DCM_REG0_ON ((0x1 << 0))
#define MP0_CPUCFG_MP0_RGU_DCM_REG0_OFF ((0x0 << 0))
bool dcm_mp0_cpucfg_mp0_rgu_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(MP0_CPUCFG_MP0_RGU_DCM_CONFIG) &
MP0_CPUCFG_MP0_RGU_DCM_REG0_MASK) ==
(unsigned int) MP0_CPUCFG_MP0_RGU_DCM_REG0_ON);
return ret;
}
void dcm_mp0_cpucfg_mp0_rgu_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mp0_cpucfg_mp0_rgu_dcm'" */
reg_write(MP0_CPUCFG_MP0_RGU_DCM_CONFIG,
(reg_read(MP0_CPUCFG_MP0_RGU_DCM_CONFIG) &
~MP0_CPUCFG_MP0_RGU_DCM_REG0_MASK) |
MP0_CPUCFG_MP0_RGU_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mp0_cpucfg_mp0_rgu_dcm'" */
reg_write(MP0_CPUCFG_MP0_RGU_DCM_CONFIG,
(reg_read(MP0_CPUCFG_MP0_RGU_DCM_CONFIG) &
~MP0_CPUCFG_MP0_RGU_DCM_REG0_MASK) |
MP0_CPUCFG_MP0_RGU_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_ADB400_DCM_REG0_MASK ((0x1 << 0) | \
(0x1 << 2) | \
(0x1 << 6))
#define MCU_MISCCFG_ADB400_DCM_REG0_ON ((0x1 << 0) | \
(0x1 << 2) | \
(0x1 << 6))
#define MCU_MISCCFG_ADB400_DCM_REG0_OFF ((0x0 << 0) | \
(0x0 << 2) | \
(0x0 << 6))
bool dcm_mcu_misccfg_adb400_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(CCI_ADB400_DCM_CONFIG) &
MCU_MISCCFG_ADB400_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_ADB400_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_adb400_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_adb400_dcm'" */
reg_write(CCI_ADB400_DCM_CONFIG,
(reg_read(CCI_ADB400_DCM_CONFIG) &
~MCU_MISCCFG_ADB400_DCM_REG0_MASK) |
MCU_MISCCFG_ADB400_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_adb400_dcm'" */
reg_write(CCI_ADB400_DCM_CONFIG,
(reg_read(CCI_ADB400_DCM_CONFIG) &
~MCU_MISCCFG_ADB400_DCM_REG0_MASK) |
MCU_MISCCFG_ADB400_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_MASK ((0x1 << 11))
#define MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_ON ((0x1 << 11))
#define MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_OFF ((0x0 << 11))
bool dcm_mcu_misccfg_bus_arm_pll_divider_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(BUS_PLL_DIVIDER_CFG) &
MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_bus_arm_pll_divider_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON 'mcu_misccfg_bus_arm_pll_divider_dcm'" */
reg_write(BUS_PLL_DIVIDER_CFG,
(reg_read(BUS_PLL_DIVIDER_CFG) &
~MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF 'mcu_misccfg_bus_arm_pll_divider_dcm'" */
reg_write(BUS_PLL_DIVIDER_CFG,
(reg_read(BUS_PLL_DIVIDER_CFG) &
~MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_ARM_PLL_DIVIDER_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_BUS_CLOCK_DCM_REG0_MASK ((0x1 << 8))
#define MCU_MISCCFG_BUS_CLOCK_DCM_REG0_ON ((0x1 << 8))
#define MCU_MISCCFG_BUS_CLOCK_DCM_REG0_OFF ((0x0 << 8))
bool dcm_mcu_misccfg_bus_clock_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(CCI_CLK_CTRL) &
MCU_MISCCFG_BUS_CLOCK_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_BUS_CLOCK_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_bus_clock_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_bus_clock_dcm'" */
reg_write(CCI_CLK_CTRL,
(reg_read(CCI_CLK_CTRL) &
~MCU_MISCCFG_BUS_CLOCK_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_CLOCK_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_bus_clock_dcm'" */
reg_write(CCI_CLK_CTRL,
(reg_read(CCI_CLK_CTRL) &
~MCU_MISCCFG_BUS_CLOCK_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_CLOCK_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_BUS_FABRIC_DCM_REG0_MASK ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x1 << 3) | \
(0x1 << 4) | \
(0x1 << 5) | \
(0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 18) | \
(0x1 << 21))
#define MCU_MISCCFG_BUS_FABRIC_DCM_REG0_ON ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x1 << 3) | \
(0x1 << 4) | \
(0x1 << 5) | \
(0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 18) | \
(0x1 << 21))
#define MCU_MISCCFG_BUS_FABRIC_DCM_REG0_OFF ((0x0 << 0) | \
(0x0 << 1) | \
(0x0 << 2) | \
(0x0 << 3) | \
(0x0 << 4) | \
(0x0 << 5) | \
(0x0 << 8) | \
(0x0 << 9) | \
(0x0 << 10) | \
(0x0 << 11) | \
(0x0 << 12) | \
(0x0 << 18) | \
(0x0 << 21))
bool dcm_mcu_misccfg_bus_fabric_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(BUS_FABRIC_DCM_CTRL) &
MCU_MISCCFG_BUS_FABRIC_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_BUS_FABRIC_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_bus_fabric_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_bus_fabric_dcm'" */
reg_write(BUS_FABRIC_DCM_CTRL,
(reg_read(BUS_FABRIC_DCM_CTRL) &
~MCU_MISCCFG_BUS_FABRIC_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_FABRIC_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_bus_fabric_dcm'" */
reg_write(BUS_FABRIC_DCM_CTRL,
(reg_read(BUS_FABRIC_DCM_CTRL) &
~MCU_MISCCFG_BUS_FABRIC_DCM_REG0_MASK) |
MCU_MISCCFG_BUS_FABRIC_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_GIC_SYNC_DCM_REG0_MASK ((0x1 << 0))
#define MCU_MISCCFG_GIC_SYNC_DCM_REG0_ON ((0x1 << 0))
#define MCU_MISCCFG_GIC_SYNC_DCM_REG0_OFF ((0x0 << 0))
bool dcm_mcu_misccfg_gic_sync_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(MP_GIC_RGU_SYNC_DCM) &
MCU_MISCCFG_GIC_SYNC_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_GIC_SYNC_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_gic_sync_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_gic_sync_dcm'" */
reg_write(MP_GIC_RGU_SYNC_DCM,
(reg_read(MP_GIC_RGU_SYNC_DCM) &
~MCU_MISCCFG_GIC_SYNC_DCM_REG0_MASK) |
MCU_MISCCFG_GIC_SYNC_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_gic_sync_dcm'" */
reg_write(MP_GIC_RGU_SYNC_DCM,
(reg_read(MP_GIC_RGU_SYNC_DCM) &
~MCU_MISCCFG_GIC_SYNC_DCM_REG0_MASK) |
MCU_MISCCFG_GIC_SYNC_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_L2_SHARED_DCM_REG0_MASK ((0x1 << 0))
#define MCU_MISCCFG_L2_SHARED_DCM_REG0_ON ((0x1 << 0))
#define MCU_MISCCFG_L2_SHARED_DCM_REG0_OFF ((0x0 << 0))
bool dcm_mcu_misccfg_l2_shared_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(L2C_SRAM_CTRL) &
MCU_MISCCFG_L2_SHARED_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_L2_SHARED_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_l2_shared_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_l2_shared_dcm'" */
reg_write(L2C_SRAM_CTRL,
(reg_read(L2C_SRAM_CTRL) &
~MCU_MISCCFG_L2_SHARED_DCM_REG0_MASK) |
MCU_MISCCFG_L2_SHARED_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_l2_shared_dcm'" */
reg_write(L2C_SRAM_CTRL,
(reg_read(L2C_SRAM_CTRL) &
~MCU_MISCCFG_L2_SHARED_DCM_REG0_MASK) |
MCU_MISCCFG_L2_SHARED_DCM_REG0_OFF);
}
}
#define MCU_MISCCFG_MCU_MISC_DCM_REG0_MASK ((0x1 << 0))
#define MCU_MISCCFG_MCU_MISC_DCM_REG0_ON ((0x1 << 0))
#define MCU_MISCCFG_MCU_MISC_DCM_REG0_OFF ((0x0 << 0))
bool dcm_mcu_misccfg_mcu_misc_dcm_is_on(void)
{
bool ret = true;
ret &= ((reg_read(MCU_MISC_DCM_CTRL) &
MCU_MISCCFG_MCU_MISC_DCM_REG0_MASK) ==
(unsigned int) MCU_MISCCFG_MCU_MISC_DCM_REG0_ON);
return ret;
}
void dcm_mcu_misccfg_mcu_misc_dcm(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'mcu_misccfg_mcu_misc_dcm'" */
reg_write(MCU_MISC_DCM_CTRL,
(reg_read(MCU_MISC_DCM_CTRL) &
~MCU_MISCCFG_MCU_MISC_DCM_REG0_MASK) |
MCU_MISCCFG_MCU_MISC_DCM_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'mcu_misccfg_mcu_misc_dcm'" */
reg_write(MCU_MISC_DCM_CTRL,
(reg_read(MCU_MISC_DCM_CTRL) &
~MCU_MISCCFG_MCU_MISC_DCM_REG0_MASK) |
MCU_MISCCFG_MCU_MISC_DCM_REG0_OFF);
}
}
#define DRAMC_CH0_TOP0_DDRPHY_REG0_MASK ((0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 13) | \
(0x1 << 14) | \
(0x1 << 15) | \
(0x1 << 16) | \
(0x1 << 17) | \
(0x1 << 19))
#define DRAMC_CH0_TOP0_DDRPHY_REG1_MASK ((0x1 << 6) | \
(0x1 << 7) | \
(0x1 << 26))
#define DRAMC_CH0_TOP0_DDRPHY_REG2_MASK ((0x1 << 26) | \
(0x1 << 27))
#define DRAMC_CH0_TOP0_DDRPHY_REG0_ON ((0x0 << 8) | \
(0x0 << 9) | \
(0x0 << 10) | \
(0x0 << 11) | \
(0x0 << 12) | \
(0x0 << 13) | \
(0x0 << 14) | \
(0x0 << 15) | \
(0x0 << 16) | \
(0x0 << 17) | \
(0x0 << 19))
#define DRAMC_CH0_TOP0_DDRPHY_REG1_ON ((0x0 << 6) | \
(0x0 << 7) | \
(0x0 << 26))
#define DRAMC_CH0_TOP0_DDRPHY_REG2_ON ((0x0 << 26) | \
(0x0 << 27))
#define DRAMC_CH0_TOP0_DDRPHY_REG0_OFF ((0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 13) | \
(0x1 << 14) | \
(0x1 << 15) | \
(0x1 << 16) | \
(0x1 << 17) | \
(0x1 << 19))
#define DRAMC_CH0_TOP0_DDRPHY_REG1_OFF ((0x1 << 6) | \
(0x1 << 7) | \
(0x0 << 26))
#define DRAMC_CH0_TOP0_DDRPHY_REG2_OFF ((0x1 << 26) | \
(0x1 << 27))
static void dramc_ch0_top0_rg_mem_dcm_idle_fsel_set(unsigned int val)
{
reg_write(DRAMC_CH0_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL2) &
~(0x1f << 21)) |
(val & 0x1f) << 21);
}
bool dcm_dramc_ch0_top0_ddrphy_is_on(void)
{
bool ret = true;
ret &= ((reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL0) &
DRAMC_CH0_TOP0_DDRPHY_REG0_MASK) ==
(unsigned int) DRAMC_CH0_TOP0_DDRPHY_REG0_ON);
ret &= ((reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL2) &
DRAMC_CH0_TOP0_DDRPHY_REG1_MASK) ==
(unsigned int) DRAMC_CH0_TOP0_DDRPHY_REG1_ON);
ret &= ((reg_read(DRAMC_CH0_TOP0_MISC_CTRL3) &
DRAMC_CH0_TOP0_DDRPHY_REG2_MASK) ==
(unsigned int) DRAMC_CH0_TOP0_DDRPHY_REG2_ON);
return ret;
}
void dcm_dramc_ch0_top0_ddrphy(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'dramc_ch0_top0_ddrphy'" */
dramc_ch0_top0_rg_mem_dcm_idle_fsel_set(0x8);
reg_write(DRAMC_CH0_TOP0_MISC_CG_CTRL0,
(reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL0) &
~DRAMC_CH0_TOP0_DDRPHY_REG0_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG0_ON);
reg_write(DRAMC_CH0_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL2) &
~DRAMC_CH0_TOP0_DDRPHY_REG1_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG1_ON);
reg_write(DRAMC_CH0_TOP0_MISC_CTRL3,
(reg_read(DRAMC_CH0_TOP0_MISC_CTRL3) &
~DRAMC_CH0_TOP0_DDRPHY_REG2_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG2_ON);
} else {
/* TINFO = "Turn OFF DCM 'dramc_ch0_top0_ddrphy'" */
dramc_ch0_top0_rg_mem_dcm_idle_fsel_set(0x0);
reg_write(DRAMC_CH0_TOP0_MISC_CG_CTRL0,
(reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL0) &
~DRAMC_CH0_TOP0_DDRPHY_REG0_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG0_OFF);
reg_write(DRAMC_CH0_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH0_TOP0_MISC_CG_CTRL2) &
~DRAMC_CH0_TOP0_DDRPHY_REG1_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG1_OFF);
reg_write(DRAMC_CH0_TOP0_MISC_CTRL3,
(reg_read(DRAMC_CH0_TOP0_MISC_CTRL3) &
~DRAMC_CH0_TOP0_DDRPHY_REG2_MASK) |
DRAMC_CH0_TOP0_DDRPHY_REG2_OFF);
}
}
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_MASK ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x1 << 26) | \
(0x1 << 30) | \
(0x1 << 31))
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_MASK ((0x1 << 31))
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_ON ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x0 << 26) | \
(0x1 << 30) | \
(0x1 << 31))
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_ON ((0x1 << 31))
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_OFF ((0x0 << 0) | \
(0x0 << 1) | \
(0x0 << 2) | \
(0x1 << 26) | \
(0x0 << 30) | \
(0x0 << 31))
#define DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_OFF ((0x0 << 31))
bool dcm_dramc_ch0_top1_dcm_dramc_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(DRAMC_CH0_TOP1_DRAMC_PD_CTRL) &
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_MASK) ==
(unsigned int) DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_ON);
ret &= ((reg_read(DRAMC_CH0_TOP1_CLKAR) &
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_MASK) ==
(unsigned int) DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_ON);
return ret;
}
void dcm_dramc_ch0_top1_dcm_dramc_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'dramc_ch0_top1_dcm_dramc_group'" */
reg_write(DRAMC_CH0_TOP1_DRAMC_PD_CTRL,
(reg_read(DRAMC_CH0_TOP1_DRAMC_PD_CTRL) &
~DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_MASK) |
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_ON);
reg_write(DRAMC_CH0_TOP1_CLKAR,
(reg_read(DRAMC_CH0_TOP1_CLKAR) &
~DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_MASK) |
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_ON);
} else {
/* TINFO = "Turn OFF DCM 'dramc_ch0_top1_dcm_dramc_group'" */
reg_write(DRAMC_CH0_TOP1_DRAMC_PD_CTRL,
(reg_read(DRAMC_CH0_TOP1_DRAMC_PD_CTRL) &
~DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_MASK) |
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG0_OFF);
reg_write(DRAMC_CH0_TOP1_CLKAR,
(reg_read(DRAMC_CH0_TOP1_CLKAR) &
~DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_MASK) |
DRAMC_CH0_TOP1_DCM_DRAMC_GROUP_REG1_OFF);
}
}
#define CHN0_EMI_DCM_EMI_GROUP_REG0_MASK ((0xff << 24))
#define CHN0_EMI_DCM_EMI_GROUP_REG0_ON ((0x0 << 24))
#define CHN0_EMI_DCM_EMI_GROUP_REG0_OFF ((0xff << 24))
bool dcm_chn0_emi_dcm_emi_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(CHN0_EMI_CHN_EMI_CONB) &
CHN0_EMI_DCM_EMI_GROUP_REG0_MASK) ==
(unsigned int) CHN0_EMI_DCM_EMI_GROUP_REG0_ON);
return ret;
}
void dcm_chn0_emi_dcm_emi_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'chn0_emi_dcm_emi_group'" */
reg_write(CHN0_EMI_CHN_EMI_CONB,
(reg_read(CHN0_EMI_CHN_EMI_CONB) &
~CHN0_EMI_DCM_EMI_GROUP_REG0_MASK) |
CHN0_EMI_DCM_EMI_GROUP_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'chn0_emi_dcm_emi_group'" */
reg_write(CHN0_EMI_CHN_EMI_CONB,
(reg_read(CHN0_EMI_CHN_EMI_CONB) &
~CHN0_EMI_DCM_EMI_GROUP_REG0_MASK) |
CHN0_EMI_DCM_EMI_GROUP_REG0_OFF);
}
}
#define DRAMC_CH1_TOP0_DDRPHY_REG0_MASK ((0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 13) | \
(0x1 << 14) | \
(0x1 << 15) | \
(0x1 << 16) | \
(0x1 << 17) | \
(0x1 << 19))
#define DRAMC_CH1_TOP0_DDRPHY_REG1_MASK ((0x1 << 6) | \
(0x1 << 7) | \
(0x1 << 26))
#define DRAMC_CH1_TOP0_DDRPHY_REG2_MASK ((0x1 << 26) | \
(0x1 << 27))
#define DRAMC_CH1_TOP0_DDRPHY_REG0_ON ((0x0 << 8) | \
(0x0 << 9) | \
(0x0 << 10) | \
(0x0 << 11) | \
(0x0 << 12) | \
(0x0 << 13) | \
(0x0 << 14) | \
(0x0 << 15) | \
(0x0 << 16) | \
(0x0 << 17) | \
(0x0 << 19))
#define DRAMC_CH1_TOP0_DDRPHY_REG1_ON ((0x0 << 6) | \
(0x0 << 7) | \
(0x0 << 26))
#define DRAMC_CH1_TOP0_DDRPHY_REG2_ON ((0x0 << 26) | \
(0x0 << 27))
#define DRAMC_CH1_TOP0_DDRPHY_REG0_OFF ((0x1 << 8) | \
(0x1 << 9) | \
(0x1 << 10) | \
(0x1 << 11) | \
(0x1 << 12) | \
(0x1 << 13) | \
(0x1 << 14) | \
(0x1 << 15) | \
(0x1 << 16) | \
(0x1 << 17) | \
(0x1 << 19))
#define DRAMC_CH1_TOP0_DDRPHY_REG1_OFF ((0x1 << 6) | \
(0x1 << 7) | \
(0x0 << 26))
#define DRAMC_CH1_TOP0_DDRPHY_REG2_OFF ((0x1 << 26) | \
(0x1 << 27))
static void dramc_ch1_top0_rg_mem_dcm_idle_fsel_set(unsigned int val)
{
reg_write(DRAMC_CH1_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL2) &
~(0x1f << 21)) |
(val & 0x1f) << 21);
}
bool dcm_dramc_ch1_top0_ddrphy_is_on(void)
{
bool ret = true;
ret &= ((reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL0) &
DRAMC_CH1_TOP0_DDRPHY_REG0_MASK) ==
(unsigned int) DRAMC_CH1_TOP0_DDRPHY_REG0_ON);
ret &= ((reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL2) &
DRAMC_CH1_TOP0_DDRPHY_REG1_MASK) ==
(unsigned int) DRAMC_CH1_TOP0_DDRPHY_REG1_ON);
ret &= ((reg_read(DRAMC_CH1_TOP0_MISC_CTRL3) &
DRAMC_CH1_TOP0_DDRPHY_REG2_MASK) ==
(unsigned int) DRAMC_CH1_TOP0_DDRPHY_REG2_ON);
return ret;
}
void dcm_dramc_ch1_top0_ddrphy(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'dramc_ch1_top0_ddrphy'" */
dramc_ch1_top0_rg_mem_dcm_idle_fsel_set(0x8);
reg_write(DRAMC_CH1_TOP0_MISC_CG_CTRL0,
(reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL0) &
~DRAMC_CH1_TOP0_DDRPHY_REG0_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG0_ON);
reg_write(DRAMC_CH1_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL2) &
~DRAMC_CH1_TOP0_DDRPHY_REG1_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG1_ON);
reg_write(DRAMC_CH1_TOP0_MISC_CTRL3,
(reg_read(DRAMC_CH1_TOP0_MISC_CTRL3) &
~DRAMC_CH1_TOP0_DDRPHY_REG2_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG2_ON);
} else {
/* TINFO = "Turn OFF DCM 'dramc_ch1_top0_ddrphy'" */
dramc_ch1_top0_rg_mem_dcm_idle_fsel_set(0x0);
reg_write(DRAMC_CH1_TOP0_MISC_CG_CTRL0,
(reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL0) &
~DRAMC_CH1_TOP0_DDRPHY_REG0_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG0_OFF);
reg_write(DRAMC_CH1_TOP0_MISC_CG_CTRL2,
(reg_read(DRAMC_CH1_TOP0_MISC_CG_CTRL2) &
~DRAMC_CH1_TOP0_DDRPHY_REG1_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG1_OFF);
reg_write(DRAMC_CH1_TOP0_MISC_CTRL3,
(reg_read(DRAMC_CH1_TOP0_MISC_CTRL3) &
~DRAMC_CH1_TOP0_DDRPHY_REG2_MASK) |
DRAMC_CH1_TOP0_DDRPHY_REG2_OFF);
}
}
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_MASK ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x1 << 26) | \
(0x1 << 30) | \
(0x1 << 31))
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_MASK ((0x1 << 31))
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_ON ((0x1 << 0) | \
(0x1 << 1) | \
(0x1 << 2) | \
(0x0 << 26) | \
(0x1 << 30) | \
(0x1 << 31))
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_ON ((0x1 << 31))
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_OFF ((0x0 << 0) | \
(0x0 << 1) | \
(0x0 << 2) | \
(0x1 << 26) | \
(0x0 << 30) | \
(0x0 << 31))
#define DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_OFF ((0x0 << 31))
bool dcm_dramc_ch1_top1_dcm_dramc_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(DRAMC_CH1_TOP1_DRAMC_PD_CTRL) &
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_MASK) ==
(unsigned int) DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_ON);
ret &= ((reg_read(DRAMC_CH1_TOP1_CLKAR) &
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_MASK) ==
(unsigned int) DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_ON);
return ret;
}
void dcm_dramc_ch1_top1_dcm_dramc_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'dramc_ch1_top1_dcm_dramc_group'" */
reg_write(DRAMC_CH1_TOP1_DRAMC_PD_CTRL,
(reg_read(DRAMC_CH1_TOP1_DRAMC_PD_CTRL) &
~DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_MASK) |
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_ON);
reg_write(DRAMC_CH1_TOP1_CLKAR,
(reg_read(DRAMC_CH1_TOP1_CLKAR) &
~DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_MASK) |
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_ON);
} else {
/* TINFO = "Turn OFF DCM 'dramc_ch1_top1_dcm_dramc_group'" */
reg_write(DRAMC_CH1_TOP1_DRAMC_PD_CTRL,
(reg_read(DRAMC_CH1_TOP1_DRAMC_PD_CTRL) &
~DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_MASK) |
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG0_OFF);
reg_write(DRAMC_CH1_TOP1_CLKAR,
(reg_read(DRAMC_CH1_TOP1_CLKAR) &
~DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_MASK) |
DRAMC_CH1_TOP1_DCM_DRAMC_GROUP_REG1_OFF);
}
}
#define CHN1_EMI_DCM_EMI_GROUP_REG0_MASK ((0xff << 24))
#define CHN1_EMI_DCM_EMI_GROUP_REG0_ON ((0x0 << 24))
#define CHN1_EMI_DCM_EMI_GROUP_REG0_OFF ((0xff << 24))
bool dcm_chn1_emi_dcm_emi_group_is_on(void)
{
bool ret = true;
ret &= ((reg_read(CHN1_EMI_CHN_EMI_CONB) &
CHN1_EMI_DCM_EMI_GROUP_REG0_MASK) ==
(unsigned int) CHN1_EMI_DCM_EMI_GROUP_REG0_ON);
return ret;
}
void dcm_chn1_emi_dcm_emi_group(int on)
{
if (on) {
/* TINFO = "Turn ON DCM 'chn1_emi_dcm_emi_group'" */
reg_write(CHN1_EMI_CHN_EMI_CONB,
(reg_read(CHN1_EMI_CHN_EMI_CONB) &
~CHN1_EMI_DCM_EMI_GROUP_REG0_MASK) |
CHN1_EMI_DCM_EMI_GROUP_REG0_ON);
} else {
/* TINFO = "Turn OFF DCM 'chn1_emi_dcm_emi_group'" */
reg_write(CHN1_EMI_CHN_EMI_CONB,
(reg_read(CHN1_EMI_CHN_EMI_CONB) &
~CHN1_EMI_DCM_EMI_GROUP_REG0_MASK) |
CHN1_EMI_DCM_EMI_GROUP_REG0_OFF);
}
}