[PATCH 07/14] ARM: AM43XX: Add functions to save/restore am43xx control registers

2018-04-11 Thread Keerthy
From: Tero Kristo 

These registers are part of the wkup domain and are lost during RTC only
suspend and also hibernation, so storing/restoring their state is
necessary.

Signed-off-by: Tero Kristo 
Signed-off-by: Keerthy 
---
 arch/arm/mach-omap2/control.c | 94 +--
 arch/arm/mach-omap2/control.h | 15 ++-
 2 files changed, 105 insertions(+), 4 deletions(-)

diff --git a/arch/arm/mach-omap2/control.c b/arch/arm/mach-omap2/control.c
index d92aa9a..d094ae3 100644
--- a/arch/arm/mach-omap2/control.c
+++ b/arch/arm/mach-omap2/control.c
@@ -622,7 +622,8 @@ void __init omap3_ctrl_init(void)
 
 #endif /* CONFIG_ARCH_OMAP3 && CONFIG_PM */
 
-#if defined(CONFIG_SOC_AM33XX) && defined(CONFIG_PM)
+#if defined(CONFIG_PM)
+#if defined(CONFIG_SOC_AM33XX) || defined(CONFIG_SOC_AM43XX)
 static unsigned long am33xx_control_reg_offsets[] = {
AM33XX_CONTROL_SYSCONFIG_OFFSET,
AM33XX_CONTROL_STATUS_OFFSET,
@@ -674,7 +675,65 @@ void __init omap3_ctrl_init(void)
AM33XX_CONTROL_RESET_ISO_OFFSET,
 };
 
-static u32 am33xx_control_vals[ARRAY_SIZE(am33xx_control_reg_offsets)];
+static unsigned long am43xx_control_reg_offsets[] = {
+   AM33XX_CONTROL_SYSCONFIG_OFFSET,
+   AM33XX_CONTROL_STATUS_OFFSET,
+   AM43XX_CONTROL_MPU_L2_CTRL_OFFSET,
+   AM33XX_CONTROL_CORE_SLDO_CTRL_OFFSET,
+   AM33XX_CONTROL_MPU_SLDO_CTRL_OFFSET,
+   AM33XX_CONTROL_CLK32KDIVRATIO_CTRL_OFFSET,
+   AM33XX_CONTROL_BANDGAP_CTRL_OFFSET,
+   AM33XX_CONTROL_BANDGAP_TRIM_OFFSET,
+   AM33XX_CONTROL_PLL_CLKINPULOW_CTRL_OFFSET,
+   AM33XX_CONTROL_MOSC_CTRL_OFFSET,
+   AM33XX_CONTROL_DEEPSLEEP_CTRL_OFFSET,
+   AM43XX_CONTROL_DISPLAY_PLL_SEL_OFFSET,
+   AM33XX_CONTROL_INIT_PRIORITY_0_OFFSET,
+   AM33XX_CONTROL_INIT_PRIORITY_1_OFFSET,
+   AM33XX_CONTROL_TPTC_CFG_OFFSET,
+   AM33XX_CONTROL_USB_CTRL0_OFFSET,
+   AM33XX_CONTROL_USB_CTRL1_OFFSET,
+   AM43XX_CONTROL_USB_CTRL2_OFFSET,
+   AM43XX_CONTROL_GMII_SEL_OFFSET,
+   AM43XX_CONTROL_MPUSS_CTRL_OFFSET,
+   AM43XX_CONTROL_TIMER_CASCADE_CTRL_OFFSET,
+   AM43XX_CONTROL_PWMSS_CTRL_OFFSET,
+   AM33XX_CONTROL_MREQPRIO_0_OFFSET,
+   AM33XX_CONTROL_MREQPRIO_1_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP1_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP2_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP3_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP4_OFFSET,
+   AM33XX_CONTROL_SMRT_CTRL_OFFSET,
+   AM33XX_CONTROL_MPUSS_HW_DEBUG_SEL_OFFSET,
+   AM43XX_CONTROL_CQDETECT_STS_OFFSET,
+   AM43XX_CONTROL_CQDETECT_STS2_OFFSET,
+   AM43XX_CONTROL_VTP_CTRL_OFFSET,
+   AM33XX_CONTROL_VREF_CTRL_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_0_3_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_4_7_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_8_11_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_12_15_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_16_19_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_20_23_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_24_27_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_28_31_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_32_35_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_36_39_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_40_43_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_44_47_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_48_51_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_52_55_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_56_59_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_60_63_OFFSET,
+   AM33XX_CONTROL_TIMER_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_ECAP_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_ADC_EVT_CAPT_OFFSET,
+   AM43XX_CONTROL_ADC1_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_RESET_ISO_OFFSET,
+};
+
+static u32 am33xx_control_vals[ARRAY_SIZE(am43xx_control_reg_offsets)];
 
 /**
  * am33xx_control_save_context - Save the wakeup domain registers
@@ -703,7 +762,36 @@ void am33xx_control_restore_context(void)
omap_ctrl_writel(am33xx_control_vals[i],
 am33xx_control_reg_offsets[i]);
 }
-#endif /* CONFIG_SOC_AM33XX && CONFIG_PM */
+
+/**
+ * am43xx_control_save_context - Save the wakeup domain registers
+ *
+ * Save the wkup domain registers
+ */
+void am43xx_control_save_context(void)
+{
+   int i;
+
+   for (i = 0; i < ARRAY_SIZE(am43xx_control_reg_offsets); i++)
+   am33xx_control_vals[i] =
+   omap_ctrl_readl(am43xx_control_reg_offsets[i]);
+}
+
+/**
+ * am43xx_control_restore_context - Restore the wakeup domain registers
+ *
+ * Restore the wkup domain registers
+ */
+void am43xx_control_restore_context(void)
+{
+   int i;
+
+   for (i = 0; i < ARRAY_SIZE(am43xx_control_reg_offsets); i++)
+   omap_ctrl_writel(am33xx_control_vals[i],
+am43xx_control_reg_offsets[i]);
+}
+#endif /* CONFIG_PM */
+#endif /* CONFIG_SOC_AM33XX || CONFIG_SOC_AM43XX */
 
 struct 

[PATCH 07/14] ARM: AM43XX: Add functions to save/restore am43xx control registers

2018-04-11 Thread Keerthy
From: Tero Kristo 

These registers are part of the wkup domain and are lost during RTC only
suspend and also hibernation, so storing/restoring their state is
necessary.

Signed-off-by: Tero Kristo 
Signed-off-by: Keerthy 
---
 arch/arm/mach-omap2/control.c | 94 +--
 arch/arm/mach-omap2/control.h | 15 ++-
 2 files changed, 105 insertions(+), 4 deletions(-)

diff --git a/arch/arm/mach-omap2/control.c b/arch/arm/mach-omap2/control.c
index d92aa9a..d094ae3 100644
--- a/arch/arm/mach-omap2/control.c
+++ b/arch/arm/mach-omap2/control.c
@@ -622,7 +622,8 @@ void __init omap3_ctrl_init(void)
 
 #endif /* CONFIG_ARCH_OMAP3 && CONFIG_PM */
 
-#if defined(CONFIG_SOC_AM33XX) && defined(CONFIG_PM)
+#if defined(CONFIG_PM)
+#if defined(CONFIG_SOC_AM33XX) || defined(CONFIG_SOC_AM43XX)
 static unsigned long am33xx_control_reg_offsets[] = {
AM33XX_CONTROL_SYSCONFIG_OFFSET,
AM33XX_CONTROL_STATUS_OFFSET,
@@ -674,7 +675,65 @@ void __init omap3_ctrl_init(void)
AM33XX_CONTROL_RESET_ISO_OFFSET,
 };
 
-static u32 am33xx_control_vals[ARRAY_SIZE(am33xx_control_reg_offsets)];
+static unsigned long am43xx_control_reg_offsets[] = {
+   AM33XX_CONTROL_SYSCONFIG_OFFSET,
+   AM33XX_CONTROL_STATUS_OFFSET,
+   AM43XX_CONTROL_MPU_L2_CTRL_OFFSET,
+   AM33XX_CONTROL_CORE_SLDO_CTRL_OFFSET,
+   AM33XX_CONTROL_MPU_SLDO_CTRL_OFFSET,
+   AM33XX_CONTROL_CLK32KDIVRATIO_CTRL_OFFSET,
+   AM33XX_CONTROL_BANDGAP_CTRL_OFFSET,
+   AM33XX_CONTROL_BANDGAP_TRIM_OFFSET,
+   AM33XX_CONTROL_PLL_CLKINPULOW_CTRL_OFFSET,
+   AM33XX_CONTROL_MOSC_CTRL_OFFSET,
+   AM33XX_CONTROL_DEEPSLEEP_CTRL_OFFSET,
+   AM43XX_CONTROL_DISPLAY_PLL_SEL_OFFSET,
+   AM33XX_CONTROL_INIT_PRIORITY_0_OFFSET,
+   AM33XX_CONTROL_INIT_PRIORITY_1_OFFSET,
+   AM33XX_CONTROL_TPTC_CFG_OFFSET,
+   AM33XX_CONTROL_USB_CTRL0_OFFSET,
+   AM33XX_CONTROL_USB_CTRL1_OFFSET,
+   AM43XX_CONTROL_USB_CTRL2_OFFSET,
+   AM43XX_CONTROL_GMII_SEL_OFFSET,
+   AM43XX_CONTROL_MPUSS_CTRL_OFFSET,
+   AM43XX_CONTROL_TIMER_CASCADE_CTRL_OFFSET,
+   AM43XX_CONTROL_PWMSS_CTRL_OFFSET,
+   AM33XX_CONTROL_MREQPRIO_0_OFFSET,
+   AM33XX_CONTROL_MREQPRIO_1_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP1_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP2_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP3_OFFSET,
+   AM33XX_CONTROL_HW_EVENT_SEL_GRP4_OFFSET,
+   AM33XX_CONTROL_SMRT_CTRL_OFFSET,
+   AM33XX_CONTROL_MPUSS_HW_DEBUG_SEL_OFFSET,
+   AM43XX_CONTROL_CQDETECT_STS_OFFSET,
+   AM43XX_CONTROL_CQDETECT_STS2_OFFSET,
+   AM43XX_CONTROL_VTP_CTRL_OFFSET,
+   AM33XX_CONTROL_VREF_CTRL_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_0_3_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_4_7_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_8_11_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_12_15_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_16_19_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_20_23_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_24_27_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_28_31_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_32_35_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_36_39_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_40_43_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_44_47_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_48_51_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_52_55_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_56_59_OFFSET,
+   AM33XX_CONTROL_TPCC_EVT_MUX_60_63_OFFSET,
+   AM33XX_CONTROL_TIMER_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_ECAP_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_ADC_EVT_CAPT_OFFSET,
+   AM43XX_CONTROL_ADC1_EVT_CAPT_OFFSET,
+   AM33XX_CONTROL_RESET_ISO_OFFSET,
+};
+
+static u32 am33xx_control_vals[ARRAY_SIZE(am43xx_control_reg_offsets)];
 
 /**
  * am33xx_control_save_context - Save the wakeup domain registers
@@ -703,7 +762,36 @@ void am33xx_control_restore_context(void)
omap_ctrl_writel(am33xx_control_vals[i],
 am33xx_control_reg_offsets[i]);
 }
-#endif /* CONFIG_SOC_AM33XX && CONFIG_PM */
+
+/**
+ * am43xx_control_save_context - Save the wakeup domain registers
+ *
+ * Save the wkup domain registers
+ */
+void am43xx_control_save_context(void)
+{
+   int i;
+
+   for (i = 0; i < ARRAY_SIZE(am43xx_control_reg_offsets); i++)
+   am33xx_control_vals[i] =
+   omap_ctrl_readl(am43xx_control_reg_offsets[i]);
+}
+
+/**
+ * am43xx_control_restore_context - Restore the wakeup domain registers
+ *
+ * Restore the wkup domain registers
+ */
+void am43xx_control_restore_context(void)
+{
+   int i;
+
+   for (i = 0; i < ARRAY_SIZE(am43xx_control_reg_offsets); i++)
+   omap_ctrl_writel(am33xx_control_vals[i],
+am43xx_control_reg_offsets[i]);
+}
+#endif /* CONFIG_PM */
+#endif /* CONFIG_SOC_AM33XX || CONFIG_SOC_AM43XX */
 
 struct control_init_data {
int index;
diff --git