Commit dbd6fefb authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Krzysztof Kozlowski

ARM: samsung: make pm-debug platform independent

The pm-debug code is one of the few things shared between
s3c24xx/s3c64xx and the newer s5pv210. In order to make s5pv210
independent of plat-samsung, change the common bits of this code to no
longer reference the s3c specific bits.

In particular, all the CPU checks need to be moved out of the common
code into platform specific files.
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Link: https://lore.kernel.org/r/20200806182059.2431-12-krzk@kernel.orgSigned-off-by: default avatarKrzysztof Kozlowski <krzk@kernel.org>
parent 1e574a66
...@@ -77,11 +77,6 @@ static inline void s3c_pm_arch_show_resume_irqs(void) ...@@ -77,11 +77,6 @@ static inline void s3c_pm_arch_show_resume_irqs(void)
s3c_irqwake_eintmask); s3c_irqwake_eintmask);
} }
static inline void s3c_pm_arch_update_uart(void __iomem *regs,
struct pm_uart_save *save)
{
}
static inline void s3c_pm_restored_gpios(void) { } static inline void s3c_pm_restored_gpios(void) { }
static inline void samsung_pm_saved_gpios(void) { } static inline void samsung_pm_saved_gpios(void) { }
......
...@@ -65,48 +65,6 @@ static inline void s3c_pm_arch_show_resume_irqs(void) ...@@ -65,48 +65,6 @@ static inline void s3c_pm_arch_show_resume_irqs(void)
#define s3c_irqwake_intallow 0 #define s3c_irqwake_intallow 0
#endif #endif
static inline void s3c_pm_arch_update_uart(void __iomem *regs,
struct pm_uart_save *save)
{
u32 ucon = __raw_readl(regs + S3C2410_UCON);
u32 ucon_clk = ucon & S3C6400_UCON_CLKMASK;
u32 save_clk = save->ucon & S3C6400_UCON_CLKMASK;
u32 new_ucon;
u32 delta;
/* S3C64XX UART blocks only support level interrupts, so ensure that
* when we restore unused UART blocks we force the level interrupt
* settigs. */
save->ucon |= S3C2410_UCON_TXILEVEL | S3C2410_UCON_RXILEVEL;
/* We have a constraint on changing the clock type of the UART
* between UCLKx and PCLK, so ensure that when we restore UCON
* that the CLK field is correctly modified if the bootloader
* has changed anything.
*/
if (ucon_clk != save_clk) {
new_ucon = save->ucon;
delta = ucon_clk ^ save_clk;
/* change from UCLKx => wrong PCLK,
* either UCLK can be tested for by a bit-test
* with UCLK0 */
if (ucon_clk & S3C6400_UCON_UCLK0 &&
!(save_clk & S3C6400_UCON_UCLK0) &&
delta & S3C6400_UCON_PCLK2) {
new_ucon &= ~S3C6400_UCON_UCLK0;
} else if (delta == S3C6400_UCON_PCLK2) {
/* as an precaution, don't change from
* PCLK2 => PCLK or vice-versa */
new_ucon ^= S3C6400_UCON_PCLK2;
}
S3C_PMDBG("ucon change %04x => %04x (save=%04x)\n",
ucon, new_ucon, save->ucon);
save->ucon = new_ucon;
}
}
static inline void s3c_pm_restored_gpios(void) static inline void s3c_pm_restored_gpios(void)
{ {
/* ensure sleep mode has been cleared from the system */ /* ensure sleep mode has been cleared from the system */
......
...@@ -305,6 +305,56 @@ static void s3c64xx_pm_prepare(void) ...@@ -305,6 +305,56 @@ static void s3c64xx_pm_prepare(void)
__raw_writel(__raw_readl(S3C64XX_WAKEUP_STAT), S3C64XX_WAKEUP_STAT); __raw_writel(__raw_readl(S3C64XX_WAKEUP_STAT), S3C64XX_WAKEUP_STAT);
} }
#ifdef CONFIG_SAMSUNG_PM_DEBUG
void s3c_pm_arch_update_uart(void __iomem *regs, struct pm_uart_save *save)
{
u32 ucon;
u32 ucon_clk
u32 save_clk;
u32 new_ucon;
u32 delta;
if (!soc_is_s3c64xx())
return;
ucon = __raw_readl(regs + S3C2410_UCON);
ucon_clk = ucon & S3C6400_UCON_CLKMASK;
sav_clk = save->ucon & S3C6400_UCON_CLKMASK;
/* S3C64XX UART blocks only support level interrupts, so ensure that
* when we restore unused UART blocks we force the level interrupt
* settigs. */
save->ucon |= S3C2410_UCON_TXILEVEL | S3C2410_UCON_RXILEVEL;
/* We have a constraint on changing the clock type of the UART
* between UCLKx and PCLK, so ensure that when we restore UCON
* that the CLK field is correctly modified if the bootloader
* has changed anything.
*/
if (ucon_clk != save_clk) {
new_ucon = save->ucon;
delta = ucon_clk ^ save_clk;
/* change from UCLKx => wrong PCLK,
* either UCLK can be tested for by a bit-test
* with UCLK0 */
if (ucon_clk & S3C6400_UCON_UCLK0 &&
!(save_clk & S3C6400_UCON_UCLK0) &&
delta & S3C6400_UCON_PCLK2) {
new_ucon &= ~S3C6400_UCON_UCLK0;
} else if (delta == S3C6400_UCON_PCLK2) {
/* as an precaution, don't change from
* PCLK2 => PCLK or vice-versa */
new_ucon ^= S3C6400_UCON_PCLK2;
}
S3C_PMDBG("ucon change %04x => %04x (save=%04x)\n",
ucon, new_ucon, save->ucon);
save->ucon = new_ucon;
}
}
#endif
int __init s3c64xx_pm_init(void) int __init s3c64xx_pm_init(void)
{ {
int i; int i;
......
...@@ -111,7 +111,7 @@ static int s5pv210_suspend_enter(suspend_state_t state) ...@@ -111,7 +111,7 @@ static int s5pv210_suspend_enter(suspend_state_t state)
return -EINVAL; return -EINVAL;
} }
s3c_pm_save_uarts(); s3c_pm_save_uarts(false);
s5pv210_pm_prepare(); s5pv210_pm_prepare();
flush_cache_all(); flush_cache_all();
s3c_pm_check_store(); s3c_pm_check_store();
...@@ -120,7 +120,7 @@ static int s5pv210_suspend_enter(suspend_state_t state) ...@@ -120,7 +120,7 @@ static int s5pv210_suspend_enter(suspend_state_t state)
if (ret) if (ret)
return ret; return ret;
s3c_pm_restore_uarts(); s3c_pm_restore_uarts(false);
S3C_PMDBG("%s: wakeup stat: %08x\n", __func__, S3C_PMDBG("%s: wakeup stat: %08x\n", __func__,
__raw_readl(S5P_WAKEUP_STAT)); __raw_readl(S5P_WAKEUP_STAT));
......
...@@ -71,13 +71,24 @@ extern void s3c_pm_dbg(const char *msg, ...); ...@@ -71,13 +71,24 @@ extern void s3c_pm_dbg(const char *msg, ...);
#define S3C_PMDBG(fmt...) s3c_pm_dbg(fmt) #define S3C_PMDBG(fmt...) s3c_pm_dbg(fmt)
extern void s3c_pm_save_uarts(void); extern void s3c_pm_save_uarts(bool is_s3c24xx);
extern void s3c_pm_restore_uarts(void); extern void s3c_pm_restore_uarts(bool is_s3c24xx);
#ifdef CONFIG_ARCH_S3C64XX
extern void s3c_pm_arch_update_uart(void __iomem *regs,
struct pm_uart_save *save);
#else
static inline void
s3c_pm_arch_update_uart(void __iomem *regs, struct pm_uart_save *save)
{
}
#endif
#else #else
#define S3C_PMDBG(fmt...) pr_debug(fmt) #define S3C_PMDBG(fmt...) pr_debug(fmt)
static inline void s3c_pm_save_uarts(void) { } static inline void s3c_pm_save_uarts(bool is_s3c24xx) { }
static inline void s3c_pm_restore_uarts(void) { } static inline void s3c_pm_restore_uarts(bool is_s3c24xx) { }
#endif #endif
/* suspend memory checking */ /* suspend memory checking */
......
...@@ -18,14 +18,6 @@ ...@@ -18,14 +18,6 @@
#include <plat/cpu.h> #include <plat/cpu.h>
#include <plat/pm-common.h> #include <plat/pm-common.h>
#ifdef CONFIG_SAMSUNG_ATAGS
#include <plat/pm.h>
#include <mach/pm-core.h>
#else
static inline void s3c_pm_arch_update_uart(void __iomem *regs,
struct pm_uart_save *save) {}
#endif
static struct pm_uart_save uart_save; static struct pm_uart_save uart_save;
extern void printascii(const char *); extern void printascii(const char *);
...@@ -52,7 +44,7 @@ static inline void __iomem *s3c_pm_uart_base(void) ...@@ -52,7 +44,7 @@ static inline void __iomem *s3c_pm_uart_base(void)
return (void __iomem *)vaddr; return (void __iomem *)vaddr;
} }
void s3c_pm_save_uarts(void) void s3c_pm_save_uarts(bool is_s3c2410)
{ {
void __iomem *regs = s3c_pm_uart_base(); void __iomem *regs = s3c_pm_uart_base();
struct pm_uart_save *save = &uart_save; struct pm_uart_save *save = &uart_save;
...@@ -63,14 +55,14 @@ void s3c_pm_save_uarts(void) ...@@ -63,14 +55,14 @@ void s3c_pm_save_uarts(void)
save->umcon = __raw_readl(regs + S3C2410_UMCON); save->umcon = __raw_readl(regs + S3C2410_UMCON);
save->ubrdiv = __raw_readl(regs + S3C2410_UBRDIV); save->ubrdiv = __raw_readl(regs + S3C2410_UBRDIV);
if (!soc_is_s3c2410()) if (!is_s3c2410)
save->udivslot = __raw_readl(regs + S3C2443_DIVSLOT); save->udivslot = __raw_readl(regs + S3C2443_DIVSLOT);
S3C_PMDBG("UART[%p]: ULCON=%04x, UCON=%04x, UFCON=%04x, UBRDIV=%04x\n", S3C_PMDBG("UART[%p]: ULCON=%04x, UCON=%04x, UFCON=%04x, UBRDIV=%04x\n",
regs, save->ulcon, save->ucon, save->ufcon, save->ubrdiv); regs, save->ulcon, save->ucon, save->ufcon, save->ubrdiv);
} }
void s3c_pm_restore_uarts(void) void s3c_pm_restore_uarts(bool is_s3c2410)
{ {
void __iomem *regs = s3c_pm_uart_base(); void __iomem *regs = s3c_pm_uart_base();
struct pm_uart_save *save = &uart_save; struct pm_uart_save *save = &uart_save;
...@@ -83,6 +75,6 @@ void s3c_pm_restore_uarts(void) ...@@ -83,6 +75,6 @@ void s3c_pm_restore_uarts(void)
__raw_writel(save->umcon, regs + S3C2410_UMCON); __raw_writel(save->umcon, regs + S3C2410_UMCON);
__raw_writel(save->ubrdiv, regs + S3C2410_UBRDIV); __raw_writel(save->ubrdiv, regs + S3C2410_UBRDIV);
if (!soc_is_s3c2410()) if (!is_s3c2410)
__raw_writel(save->udivslot, regs + S3C2443_DIVSLOT); __raw_writel(save->udivslot, regs + S3C2443_DIVSLOT);
} }
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include <asm/irq.h> #include <asm/irq.h>
#include <plat/cpu.h>
#include <plat/pm.h> #include <plat/pm.h>
#include <mach/pm-core.h> #include <mach/pm-core.h>
...@@ -99,7 +100,7 @@ static int s3c_pm_enter(suspend_state_t state) ...@@ -99,7 +100,7 @@ static int s3c_pm_enter(suspend_state_t state)
samsung_pm_saved_gpios(); samsung_pm_saved_gpios();
} }
s3c_pm_save_uarts(); s3c_pm_save_uarts(soc_is_s3c2410());
s3c_pm_save_core(); s3c_pm_save_core();
/* set the irq configuration for wake */ /* set the irq configuration for wake */
...@@ -136,7 +137,7 @@ static int s3c_pm_enter(suspend_state_t state) ...@@ -136,7 +137,7 @@ static int s3c_pm_enter(suspend_state_t state)
/* restore the system state */ /* restore the system state */
s3c_pm_restore_core(); s3c_pm_restore_core();
s3c_pm_restore_uarts(); s3c_pm_restore_uarts(soc_is_s3c2410());
if (!of_have_populated_dt()) { if (!of_have_populated_dt()) {
samsung_pm_restore_gpios(); samsung_pm_restore_gpios();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment