MIPS: Alchemy: introduce helpers to access SYS register block.

This patch changes all absolute SYS_XY registers to offsets from the
SYS block base, prefixes them with AU1000 to avoid silent failures due
to changed addresses, and introduces helper functions to read/write
them.

No functional changes, comparing assembly of a few select functions shows
no differences.

Signed-off-by: Manuel Lauss <manuel.lauss@gmail.com>
Cc: Linux-MIPS <linux-mips@linux-mips.org>
Patchwork: https://patchwork.linux-mips.org/patch/7464/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
This commit is contained in:
Manuel Lauss 2014-07-23 16:36:24 +02:00 committed by Ralf Baechle
parent 2ef1bb9911
commit 1d09de7dc7
17 changed files with 152 additions and 159 deletions

View File

@ -85,10 +85,10 @@ void __init board_setup(void)
#endif /* IS_ENABLED(CONFIG_USB_OHCI_HCD) */ #endif /* IS_ENABLED(CONFIG_USB_OHCI_HCD) */
/* Initialize sys_pinfunc */ /* Initialize sys_pinfunc */
au_writel(SYS_PF_NI2, SYS_PINFUNC); alchemy_wrsys(SYS_PF_NI2, AU1000_SYS_PINFUNC);
/* Initialize GPIO */ /* Initialize GPIO */
au_writel(~0, KSEG1ADDR(AU1000_SYS_PHYS_ADDR) + SYS_TRIOUTCLR); alchemy_wrsys(~0, AU1000_SYS_TRIOUTCLR);
alchemy_gpio_direction_output(0, 0); /* Disable M66EN (PCI 66MHz) */ alchemy_gpio_direction_output(0, 0); /* Disable M66EN (PCI 66MHz) */
alchemy_gpio_direction_output(3, 1); /* Disable PCI CLKRUN# */ alchemy_gpio_direction_output(3, 1); /* Disable PCI CLKRUN# */
alchemy_gpio_direction_output(1, 1); /* Enable EXT_IO3 */ alchemy_gpio_direction_output(1, 1); /* Enable EXT_IO3 */

View File

@ -87,9 +87,9 @@ void __init board_setup(void)
alchemy_gpio2_enable(); alchemy_gpio2_enable();
/* Set multiple use pins (UART3/GPIO) to UART (it's used as UART too) */ /* Set multiple use pins (UART3/GPIO) to UART (it's used as UART too) */
pin_func = au_readl(SYS_PINFUNC) & ~SYS_PF_UR3; pin_func = alchemy_rdsys(AU1000_SYS_PINFUNC) & ~SYS_PF_UR3;
pin_func |= SYS_PF_UR3; pin_func |= SYS_PF_UR3;
au_writel(pin_func, SYS_PINFUNC); alchemy_wrsys(pin_func, AU1000_SYS_PINFUNC);
/* Enable UART */ /* Enable UART */
alchemy_uart_enable(AU1000_UART3_PHYS_ADDR); alchemy_uart_enable(AU1000_UART3_PHYS_ADDR);

View File

@ -91,13 +91,13 @@ unsigned long au1xxx_calc_clock(void)
if (au1xxx_cpu_has_pll_wo()) if (au1xxx_cpu_has_pll_wo())
cpu_speed = 396000000; cpu_speed = 396000000;
else else
cpu_speed = (au_readl(SYS_CPUPLL) & 0x0000003f) * AU1000_SRC_CLK; cpu_speed = (alchemy_rdsys(AU1000_SYS_CPUPLL) & 0x3f) * AU1000_SRC_CLK;
/* On Alchemy CPU:counter ratio is 1:1 */ /* On Alchemy CPU:counter ratio is 1:1 */
mips_hpt_frequency = cpu_speed; mips_hpt_frequency = cpu_speed;
/* Equation: Baudrate = CPU / (SD * 2 * CLKDIV * 16) */ /* Equation: Baudrate = CPU / (SD * 2 * CLKDIV * 16) */
set_au1x00_uart_baud_base(cpu_speed / (2 * ((int)(au_readl(SYS_POWERCTRL) set_au1x00_uart_baud_base(cpu_speed / (2 *
& 0x03) + 2) * 16)); ((alchemy_rdsys(AU1000_SYS_POWERCTRL) & 0x03) + 2) * 16));
set_au1x00_speed(cpu_speed); set_au1x00_speed(cpu_speed);

View File

@ -389,13 +389,12 @@ static int au1x_ic1_setwake(struct irq_data *d, unsigned int on)
return -EINVAL; return -EINVAL;
local_irq_save(flags); local_irq_save(flags);
wakemsk = __raw_readl((void __iomem *)SYS_WAKEMSK); wakemsk = alchemy_rdsys(AU1000_SYS_WAKEMSK);
if (on) if (on)
wakemsk |= 1 << bit; wakemsk |= 1 << bit;
else else
wakemsk &= ~(1 << bit); wakemsk &= ~(1 << bit);
__raw_writel(wakemsk, (void __iomem *)SYS_WAKEMSK); alchemy_wrsys(wakemsk, AU1000_SYS_WAKEMSK);
wmb();
local_irq_restore(flags); local_irq_restore(flags);
return 0; return 0;

View File

@ -420,7 +420,7 @@ static void __init alchemy_setup_macs(int ctype)
memcpy(au1xxx_eth1_platform_data.mac, ethaddr, 6); memcpy(au1xxx_eth1_platform_data.mac, ethaddr, 6);
/* Register second MAC if enabled in pinfunc */ /* Register second MAC if enabled in pinfunc */
if (!(au_readl(SYS_PINFUNC) & (u32)SYS_PF_NI2)) { if (!(alchemy_rdsys(AU1000_SYS_PINFUNC) & SYS_PF_NI2)) {
ret = platform_device_register(&au1xxx_eth1_device); ret = platform_device_register(&au1xxx_eth1_device);
if (ret) if (ret)
printk(KERN_INFO "Alchemy: failed to register MAC1\n"); printk(KERN_INFO "Alchemy: failed to register MAC1\n");

View File

@ -54,14 +54,14 @@ static unsigned int sleep_static_memctlr[4][3];
static void save_core_regs(void) static void save_core_regs(void)
{ {
/* Clocks and PLLs. */ /* Clocks and PLLs. */
sleep_sys_clocks[0] = au_readl(SYS_FREQCTRL0); sleep_sys_clocks[0] = alchemy_rdsys(AU1000_SYS_FREQCTRL0);
sleep_sys_clocks[1] = au_readl(SYS_FREQCTRL1); sleep_sys_clocks[1] = alchemy_rdsys(AU1000_SYS_FREQCTRL1);
sleep_sys_clocks[2] = au_readl(SYS_CLKSRC); sleep_sys_clocks[2] = alchemy_rdsys(AU1000_SYS_CLKSRC);
sleep_sys_clocks[3] = au_readl(SYS_CPUPLL); sleep_sys_clocks[3] = alchemy_rdsys(AU1000_SYS_CPUPLL);
sleep_sys_clocks[4] = au_readl(SYS_AUXPLL); sleep_sys_clocks[4] = alchemy_rdsys(AU1000_SYS_AUXPLL);
/* pin mux config */ /* pin mux config */
sleep_sys_pinfunc = au_readl(SYS_PINFUNC); sleep_sys_pinfunc = alchemy_rdsys(AU1000_SYS_PINFUNC);
/* Save the static memory controller configuration. */ /* Save the static memory controller configuration. */
sleep_static_memctlr[0][0] = au_readl(MEM_STCFG0); sleep_static_memctlr[0][0] = au_readl(MEM_STCFG0);
@ -85,16 +85,14 @@ static void restore_core_regs(void)
* one of those Au1000 with a write-only PLL, where we dont * one of those Au1000 with a write-only PLL, where we dont
* have a valid value) * have a valid value)
*/ */
au_writel(sleep_sys_clocks[0], SYS_FREQCTRL0); alchemy_wrsys(sleep_sys_clocks[0], AU1000_SYS_FREQCTRL0);
au_writel(sleep_sys_clocks[1], SYS_FREQCTRL1); alchemy_wrsys(sleep_sys_clocks[1], AU1000_SYS_FREQCTRL1);
au_writel(sleep_sys_clocks[2], SYS_CLKSRC); alchemy_wrsys(sleep_sys_clocks[2], AU1000_SYS_CLKSRC);
au_writel(sleep_sys_clocks[4], SYS_AUXPLL); alchemy_wrsys(sleep_sys_clocks[4], AU1000_SYS_AUXPLL);
if (!au1xxx_cpu_has_pll_wo()) if (!au1xxx_cpu_has_pll_wo())
au_writel(sleep_sys_clocks[3], SYS_CPUPLL); alchemy_wrsys(sleep_sys_clocks[3], AU1000_SYS_CPUPLL);
au_sync();
au_writel(sleep_sys_pinfunc, SYS_PINFUNC); alchemy_wrsys(sleep_sys_pinfunc, AU1000_SYS_PINFUNC);
au_sync();
/* Restore the static memory controller configuration. */ /* Restore the static memory controller configuration. */
au_writel(sleep_static_memctlr[0][0], MEM_STCFG0); au_writel(sleep_static_memctlr[0][0], MEM_STCFG0);

View File

@ -46,7 +46,7 @@
static cycle_t au1x_counter1_read(struct clocksource *cs) static cycle_t au1x_counter1_read(struct clocksource *cs)
{ {
return au_readl(SYS_RTCREAD); return alchemy_rdsys(AU1000_SYS_RTCREAD);
} }
static struct clocksource au1x_counter1_clocksource = { static struct clocksource au1x_counter1_clocksource = {
@ -60,12 +60,11 @@ static struct clocksource au1x_counter1_clocksource = {
static int au1x_rtcmatch2_set_next_event(unsigned long delta, static int au1x_rtcmatch2_set_next_event(unsigned long delta,
struct clock_event_device *cd) struct clock_event_device *cd)
{ {
delta += au_readl(SYS_RTCREAD); delta += alchemy_rdsys(AU1000_SYS_RTCREAD);
/* wait for register access */ /* wait for register access */
while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_M21) while (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_M21)
; ;
au_writel(delta, SYS_RTCMATCH2); alchemy_wrsys(delta, AU1000_SYS_RTCMATCH2);
au_sync();
return 0; return 0;
} }
@ -112,31 +111,29 @@ static int __init alchemy_time_init(unsigned int m2int)
* (the 32S bit seems to be stuck set to 1 once a single clock- * (the 32S bit seems to be stuck set to 1 once a single clock-
* edge is detected, hence the timeouts). * edge is detected, hence the timeouts).
*/ */
if (CNTR_OK != (au_readl(SYS_COUNTER_CNTRL) & CNTR_OK)) if (CNTR_OK != (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & CNTR_OK))
goto cntr_err; goto cntr_err;
/* /*
* setup counter 1 (RTC) to tick at full speed * setup counter 1 (RTC) to tick at full speed
*/ */
t = 0xffffff; t = 0xffffff;
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_T1S) && --t) while ((alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_T1S) && --t)
asm volatile ("nop"); asm volatile ("nop");
if (!t) if (!t)
goto cntr_err; goto cntr_err;
au_writel(0, SYS_RTCTRIM); /* 32.768 kHz */ alchemy_wrsys(0, AU1000_SYS_RTCTRIM); /* 32.768 kHz */
au_sync();
t = 0xffffff; t = 0xffffff;
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && --t) while ((alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_C1S) && --t)
asm volatile ("nop"); asm volatile ("nop");
if (!t) if (!t)
goto cntr_err; goto cntr_err;
au_writel(0, SYS_RTCWRITE); alchemy_wrsys(0, AU1000_SYS_RTCWRITE);
au_sync();
t = 0xffffff; t = 0xffffff;
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && --t) while ((alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_C1S) && --t)
asm volatile ("nop"); asm volatile ("nop");
if (!t) if (!t)
goto cntr_err; goto cntr_err;

View File

@ -518,10 +518,9 @@ int __init db1000_dev_setup(void)
gpio_direction_input(20); /* sd1 cd# */ gpio_direction_input(20); /* sd1 cd# */
/* spi_gpio on SSI0 pins */ /* spi_gpio on SSI0 pins */
pfc = __raw_readl((void __iomem *)SYS_PINFUNC); pfc = alchemy_rdsys(AU1000_SYS_PINFUNC);
pfc |= (1 << 0); /* SSI0 pins as GPIOs */ pfc |= (1 << 0); /* SSI0 pins as GPIOs */
__raw_writel(pfc, (void __iomem *)SYS_PINFUNC); alchemy_wrsys(pfc, AU1000_SYS_PINFUNC);
wmb();
spi_register_board_info(db1100_spi_info, spi_register_board_info(db1100_spi_info,
ARRAY_SIZE(db1100_spi_info)); ARRAY_SIZE(db1100_spi_info));

View File

@ -150,12 +150,11 @@ int __init db1200_board_setup(void)
(whoami >> 4) & 0xf, (whoami >> 8) & 0xf, whoami & 0xf); (whoami >> 4) & 0xf, (whoami >> 8) & 0xf, whoami & 0xf);
/* SMBus/SPI on PSC0, Audio on PSC1 */ /* SMBus/SPI on PSC0, Audio on PSC1 */
pfc = __raw_readl((void __iomem *)SYS_PINFUNC); pfc = alchemy_rdsys(AU1000_SYS_PINFUNC);
pfc &= ~(SYS_PINFUNC_P0A | SYS_PINFUNC_P0B); pfc &= ~(SYS_PINFUNC_P0A | SYS_PINFUNC_P0B);
pfc &= ~(SYS_PINFUNC_P1A | SYS_PINFUNC_P1B | SYS_PINFUNC_FS3); pfc &= ~(SYS_PINFUNC_P1A | SYS_PINFUNC_P1B | SYS_PINFUNC_FS3);
pfc |= SYS_PINFUNC_P1C; /* SPI is configured later */ pfc |= SYS_PINFUNC_P1C; /* SPI is configured later */
__raw_writel(pfc, (void __iomem *)SYS_PINFUNC); alchemy_wrsys(pfc, AU1000_SYS_PINFUNC);
wmb();
/* Clock configurations: PSC0: ~50MHz via Clkgen0, derived from /* Clock configurations: PSC0: ~50MHz via Clkgen0, derived from
* CPU clock; all other clock generators off/unused. * CPU clock; all other clock generators off/unused.
@ -166,16 +165,13 @@ int __init db1200_board_setup(void)
div = ((div >> 1) - 1) & 0xff; div = ((div >> 1) - 1) & 0xff;
freq0 = div << SYS_FC_FRDIV0_BIT; freq0 = div << SYS_FC_FRDIV0_BIT;
__raw_writel(freq0, (void __iomem *)SYS_FREQCTRL0); alchemy_wrsys(freq0, AU1000_SYS_FREQCTRL0);
wmb();
freq0 |= SYS_FC_FE0; /* enable F0 */ freq0 |= SYS_FC_FE0; /* enable F0 */
__raw_writel(freq0, (void __iomem *)SYS_FREQCTRL0); alchemy_wrsys(freq0, AU1000_SYS_FREQCTRL0);
wmb();
/* psc0_intclk comes 1:1 from F0 */ /* psc0_intclk comes 1:1 from F0 */
clksrc = SYS_CS_MUX_FQ0 << SYS_CS_ME0_BIT; clksrc = SYS_CS_MUX_FQ0 << SYS_CS_ME0_BIT;
__raw_writel(clksrc, (void __iomem *)SYS_CLKSRC); alchemy_wrsys(clksrc, AU1000_SYS_CLKSRC);
wmb();
return 0; return 0;
} }
@ -886,7 +882,7 @@ int __init db1200_dev_setup(void)
* As a result, in SPI mode, OTG simply won't work (PSC0 uses * As a result, in SPI mode, OTG simply won't work (PSC0 uses
* it as an input pin which is pulled high on the boards). * it as an input pin which is pulled high on the boards).
*/ */
pfc = __raw_readl((void __iomem *)SYS_PINFUNC) & ~SYS_PINFUNC_P0A; pfc = alchemy_rdsys(AU1000_SYS_PINFUNC) & ~SYS_PINFUNC_P0A;
/* switch off OTG VBUS supply */ /* switch off OTG VBUS supply */
gpio_request(215, "otg-vbus"); gpio_request(215, "otg-vbus");
@ -912,8 +908,7 @@ int __init db1200_dev_setup(void)
printk(KERN_INFO " S6.8 ON : PSC0 mode SPI\n"); printk(KERN_INFO " S6.8 ON : PSC0 mode SPI\n");
printk(KERN_INFO " OTG port VBUS supply disabled\n"); printk(KERN_INFO " OTG port VBUS supply disabled\n");
} }
__raw_writel(pfc, (void __iomem *)SYS_PINFUNC); alchemy_wrsys(pfc, AU1000_SYS_PINFUNC);
wmb();
/* Audio: DIP7 selects I2S(0)/AC97(1), but need I2C for I2S! /* Audio: DIP7 selects I2S(0)/AC97(1), but need I2C for I2S!
* so: DIP7=1 || DIP8=0 => AC97, DIP7=0 && DIP8=1 => I2S * so: DIP7=1 || DIP8=0 => AC97, DIP7=0 && DIP8=1 => I2S

View File

@ -31,16 +31,16 @@
static void __init db1550_hw_setup(void) static void __init db1550_hw_setup(void)
{ {
void __iomem *base; void __iomem *base;
unsigned long v;
/* complete SPI setup: link psc0_intclk to a 48MHz source, /* complete SPI setup: link psc0_intclk to a 48MHz source,
* and assign GPIO16 to PSC0_SYNC1 (SPI cs# line) as well as PSC1_SYNC * and assign GPIO16 to PSC0_SYNC1 (SPI cs# line) as well as PSC1_SYNC
* for AC97 on PB1550. * for AC97 on PB1550.
*/ */
base = (void __iomem *)SYS_CLKSRC; v = alchemy_rdsys(AU1000_SYS_CLKSRC);
__raw_writel(__raw_readl(base) | 0x000001e0, base); alchemy_wrsys(v | 0x000001e0, AU1000_SYS_CLKSRC);
base = (void __iomem *)SYS_PINFUNC; v = alchemy_rdsys(AU1000_SYS_PINFUNC);
__raw_writel(__raw_readl(base) | 1 | SYS_PF_PSC1_S1, base); alchemy_wrsys(v | 1 | SYS_PF_PSC1_S1, AU1000_SYS_PINFUNC);
wmb();
/* reset the AC97 codec now, the reset time in the psc-ac97 driver /* reset the AC97 codec now, the reset time in the psc-ac97 driver
* is apparently too short although it's ridiculous as it is. * is apparently too short although it's ridiculous as it is.

View File

@ -45,23 +45,20 @@ static int db1x_pm_enter(suspend_state_t state)
alchemy_gpio1_input_enable(); alchemy_gpio1_input_enable();
/* clear and setup wake cause and source */ /* clear and setup wake cause and source */
au_writel(0, SYS_WAKEMSK); alchemy_wrsys(0, AU1000_SYS_WAKEMSK);
au_sync(); alchemy_wrsys(0, AU1000_SYS_WAKESRC);
au_writel(0, SYS_WAKESRC);
au_sync();
au_writel(db1x_pm_wakemsk, SYS_WAKEMSK); alchemy_wrsys(db1x_pm_wakemsk, AU1000_SYS_WAKEMSK);
au_sync();
/* setup 1Hz-timer-based wakeup: wait for reg access */ /* setup 1Hz-timer-based wakeup: wait for reg access */
while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_M20) while (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_M20)
asm volatile ("nop"); asm volatile ("nop");
au_writel(au_readl(SYS_TOYREAD) + db1x_pm_sleep_secs, SYS_TOYMATCH2); alchemy_wrsys(alchemy_rdsys(AU1000_SYS_TOYREAD) + db1x_pm_sleep_secs,
au_sync(); AU1000_SYS_TOYMATCH2);
/* wait for value to really hit the register */ /* wait for value to really hit the register */
while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_M20) while (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_M20)
asm volatile ("nop"); asm volatile ("nop");
/* ...and now the sandman can come! */ /* ...and now the sandman can come! */
@ -102,12 +99,10 @@ static void db1x_pm_end(void)
/* read and store wakeup source, the clear the register. To /* read and store wakeup source, the clear the register. To
* be able to clear it, WAKEMSK must be cleared first. * be able to clear it, WAKEMSK must be cleared first.
*/ */
db1x_pm_last_wakesrc = au_readl(SYS_WAKESRC); db1x_pm_last_wakesrc = alchemy_rdsys(AU1000_SYS_WAKESRC);
au_writel(0, SYS_WAKEMSK);
au_writel(0, SYS_WAKESRC);
au_sync();
alchemy_wrsys(0, AU1000_SYS_WAKEMSK);
alchemy_wrsys(0, AU1000_SYS_WAKESRC);
} }
static const struct platform_suspend_ops db1x_pm_ops = { static const struct platform_suspend_ops db1x_pm_ops = {
@ -242,17 +237,13 @@ static int __init pm_init(void)
* for confirmation since there's plenty of time from here to * for confirmation since there's plenty of time from here to
* the next suspend cycle. * the next suspend cycle.
*/ */
if (au_readl(SYS_TOYTRIM) != 32767) { if (alchemy_rdsys(AU1000_SYS_TOYTRIM) != 32767)
au_writel(32767, SYS_TOYTRIM); alchemy_wrsys(32767, AU1000_SYS_TOYTRIM);
au_sync();
}
db1x_pm_last_wakesrc = au_readl(SYS_WAKESRC); db1x_pm_last_wakesrc = alchemy_rdsys(AU1000_SYS_WAKESRC);
au_writel(0, SYS_WAKESRC); alchemy_wrsys(0, AU1000_SYS_WAKESRC);
au_sync(); alchemy_wrsys(0, AU1000_SYS_WAKEMSK);
au_writel(0, SYS_WAKEMSK);
au_sync();
suspend_set_ops(&db1x_pm_ops); suspend_set_ops(&db1x_pm_ops);

View File

@ -335,8 +335,7 @@
/* Programmable Counters 0 and 1 */ /* Programmable Counters 0 and 1 */
#define SYS_BASE 0xB1900000 #define AU1000_SYS_CNTRCTRL 0x14
#define SYS_COUNTER_CNTRL (SYS_BASE + 0x14)
# define SYS_CNTRL_E1S (1 << 23) # define SYS_CNTRL_E1S (1 << 23)
# define SYS_CNTRL_T1S (1 << 20) # define SYS_CNTRL_T1S (1 << 20)
# define SYS_CNTRL_M21 (1 << 19) # define SYS_CNTRL_M21 (1 << 19)
@ -358,24 +357,24 @@
# define SYS_CNTRL_C0S (1 << 0) # define SYS_CNTRL_C0S (1 << 0)
/* Programmable Counter 0 Registers */ /* Programmable Counter 0 Registers */
#define SYS_TOYTRIM (SYS_BASE + 0) #define AU1000_SYS_TOYTRIM 0x00
#define SYS_TOYWRITE (SYS_BASE + 4) #define AU1000_SYS_TOYWRITE 0x04
#define SYS_TOYMATCH0 (SYS_BASE + 8) #define AU1000_SYS_TOYMATCH0 0x08
#define SYS_TOYMATCH1 (SYS_BASE + 0xC) #define AU1000_SYS_TOYMATCH1 0x0c
#define SYS_TOYMATCH2 (SYS_BASE + 0x10) #define AU1000_SYS_TOYMATCH2 0x10
#define SYS_TOYREAD (SYS_BASE + 0x40) #define AU1000_SYS_TOYREAD 0x40
/* Programmable Counter 1 Registers */ /* Programmable Counter 1 Registers */
#define SYS_RTCTRIM (SYS_BASE + 0x44) #define AU1000_SYS_RTCTRIM 0x44
#define SYS_RTCWRITE (SYS_BASE + 0x48) #define AU1000_SYS_RTCWRITE 0x48
#define SYS_RTCMATCH0 (SYS_BASE + 0x4C) #define AU1000_SYS_RTCMATCH0 0x4c
#define SYS_RTCMATCH1 (SYS_BASE + 0x50) #define AU1000_SYS_RTCMATCH1 0x50
#define SYS_RTCMATCH2 (SYS_BASE + 0x54) #define AU1000_SYS_RTCMATCH2 0x54
#define SYS_RTCREAD (SYS_BASE + 0x58) #define AU1000_SYS_RTCREAD 0x58
/* GPIO */ /* GPIO */
#define SYS_PINFUNC 0xB190002C #define AU1000_SYS_PINFUNC 0x2C
# define SYS_PF_USB (1 << 15) /* 2nd USB device/host */ # define SYS_PF_USB (1 << 15) /* 2nd USB device/host */
# define SYS_PF_U3 (1 << 14) /* GPIO23/U3TXD */ # define SYS_PF_U3 (1 << 14) /* GPIO23/U3TXD */
# define SYS_PF_U2 (1 << 13) /* GPIO22/U2TXD */ # define SYS_PF_U2 (1 << 13) /* GPIO22/U2TXD */
@ -445,21 +444,21 @@
#define SYS_PINFUNC_S1B (1 << 2) #define SYS_PINFUNC_S1B (1 << 2)
/* Power Management */ /* Power Management */
#define SYS_SCRATCH0 0xB1900018 #define AU1000_SYS_SCRATCH0 0x18
#define SYS_SCRATCH1 0xB190001C #define AU1000_SYS_SCRATCH1 0x1c
#define SYS_WAKEMSK 0xB1900034 #define AU1000_SYS_WAKEMSK 0x34
#define SYS_ENDIAN 0xB1900038 #define AU1000_SYS_ENDIAN 0x38
#define SYS_POWERCTRL 0xB190003C #define AU1000_SYS_POWERCTRL 0x3c
#define SYS_WAKESRC 0xB190005C #define AU1000_SYS_WAKESRC 0x5c
#define SYS_SLPPWR 0xB1900078 #define AU1000_SYS_SLPPWR 0x78
#define SYS_SLEEP 0xB190007C #define AU1000_SYS_SLEEP 0x7c
#define SYS_WAKEMSK_D2 (1 << 9) #define SYS_WAKEMSK_D2 (1 << 9)
#define SYS_WAKEMSK_M2 (1 << 8) #define SYS_WAKEMSK_M2 (1 << 8)
#define SYS_WAKEMSK_GPIO(x) (1 << (x)) #define SYS_WAKEMSK_GPIO(x) (1 << (x))
/* Clock Controller */ /* Clock Controller */
#define SYS_FREQCTRL0 0xB1900020 #define AU1000_SYS_FREQCTRL0 0x20
# define SYS_FC_FRDIV2_BIT 22 # define SYS_FC_FRDIV2_BIT 22
# define SYS_FC_FRDIV2_MASK (0xff << SYS_FC_FRDIV2_BIT) # define SYS_FC_FRDIV2_MASK (0xff << SYS_FC_FRDIV2_BIT)
# define SYS_FC_FE2 (1 << 21) # define SYS_FC_FE2 (1 << 21)
@ -472,7 +471,7 @@
# define SYS_FC_FRDIV0_MASK (0xff << SYS_FC_FRDIV0_BIT) # define SYS_FC_FRDIV0_MASK (0xff << SYS_FC_FRDIV0_BIT)
# define SYS_FC_FE0 (1 << 1) # define SYS_FC_FE0 (1 << 1)
# define SYS_FC_FS0 (1 << 0) # define SYS_FC_FS0 (1 << 0)
#define SYS_FREQCTRL1 0xB1900024 #define AU1000_SYS_FREQCTRL1 0x24
# define SYS_FC_FRDIV5_BIT 22 # define SYS_FC_FRDIV5_BIT 22
# define SYS_FC_FRDIV5_MASK (0xff << SYS_FC_FRDIV5_BIT) # define SYS_FC_FRDIV5_MASK (0xff << SYS_FC_FRDIV5_BIT)
# define SYS_FC_FE5 (1 << 21) # define SYS_FC_FE5 (1 << 21)
@ -485,7 +484,7 @@
# define SYS_FC_FRDIV3_MASK (0xff << SYS_FC_FRDIV3_BIT) # define SYS_FC_FRDIV3_MASK (0xff << SYS_FC_FRDIV3_BIT)
# define SYS_FC_FE3 (1 << 1) # define SYS_FC_FE3 (1 << 1)
# define SYS_FC_FS3 (1 << 0) # define SYS_FC_FS3 (1 << 0)
#define SYS_CLKSRC 0xB1900028 #define AU1000_SYS_CLKSRC 0x28
# define SYS_CS_ME1_BIT 27 # define SYS_CS_ME1_BIT 27
# define SYS_CS_ME1_MASK (0x7 << SYS_CS_ME1_BIT) # define SYS_CS_ME1_MASK (0x7 << SYS_CS_ME1_BIT)
# define SYS_CS_DE1 (1 << 26) # define SYS_CS_DE1 (1 << 26)
@ -525,8 +524,12 @@
# define SYS_CS_MUX_FQ3 0x5 # define SYS_CS_MUX_FQ3 0x5
# define SYS_CS_MUX_FQ4 0x6 # define SYS_CS_MUX_FQ4 0x6
# define SYS_CS_MUX_FQ5 0x7 # define SYS_CS_MUX_FQ5 0x7
#define SYS_CPUPLL 0xB1900060
#define SYS_AUXPLL 0xB1900064 #define AU1000_SYS_CPUPLL 0x60
#define AU1000_SYS_AUXPLL 0x64
/**********************************************************************/
/* The PCI chip selects are outside the 32bit space, and since we can't /* The PCI chip selects are outside the 32bit space, and since we can't
@ -694,6 +697,22 @@ static inline u32 au_readl(unsigned long reg)
return *(volatile u32 *)reg; return *(volatile u32 *)reg;
} }
/* helpers to access the SYS_* registers */
static inline unsigned long alchemy_rdsys(int regofs)
{
void __iomem *b = (void __iomem *)KSEG1ADDR(AU1000_SYS_PHYS_ADDR);
return __raw_readl(b + regofs);
}
static inline void alchemy_wrsys(unsigned long v, int regofs)
{
void __iomem *b = (void __iomem *)KSEG1ADDR(AU1000_SYS_PHYS_ADDR);
__raw_writel(v, b + regofs);
wmb(); /* drain writebuffer */
}
/* Early Au1000 have a write-only SYS_CPUPLL register. */ /* Early Au1000 have a write-only SYS_CPUPLL register. */
static inline int au1xxx_cpu_has_pll_wo(void) static inline int au1xxx_cpu_has_pll_wo(void)
{ {

View File

@ -25,20 +25,20 @@
#define MAKE_IRQ(intc, off) (AU1000_INTC##intc##_INT_BASE + (off)) #define MAKE_IRQ(intc, off) (AU1000_INTC##intc##_INT_BASE + (off))
/* GPIO1 registers within SYS_ area */ /* GPIO1 registers within SYS_ area */
#define SYS_TRIOUTRD 0x100 #define AU1000_SYS_TRIOUTRD 0x100
#define SYS_TRIOUTCLR 0x100 #define AU1000_SYS_TRIOUTCLR 0x100
#define SYS_OUTPUTRD 0x108 #define AU1000_SYS_OUTPUTRD 0x108
#define SYS_OUTPUTSET 0x108 #define AU1000_SYS_OUTPUTSET 0x108
#define SYS_OUTPUTCLR 0x10C #define AU1000_SYS_OUTPUTCLR 0x10C
#define SYS_PINSTATERD 0x110 #define AU1000_SYS_PINSTATERD 0x110
#define SYS_PININPUTEN 0x110 #define AU1000_SYS_PININPUTEN 0x110
/* register offsets within GPIO2 block */ /* register offsets within GPIO2 block */
#define GPIO2_DIR 0x00 #define AU1000_GPIO2_DIR 0x00
#define GPIO2_OUTPUT 0x08 #define AU1000_GPIO2_OUTPUT 0x08
#define GPIO2_PINSTATE 0x0C #define AU1000_GPIO2_PINSTATE 0x0C
#define GPIO2_INTENABLE 0x10 #define AU1000_GPIO2_INTENABLE 0x10
#define GPIO2_ENABLE 0x14 #define AU1000_GPIO2_ENABLE 0x14
struct gpio; struct gpio;
@ -217,26 +217,21 @@ static inline int au1200_irq_to_gpio(int irq)
*/ */
static inline void alchemy_gpio1_set_value(int gpio, int v) static inline void alchemy_gpio1_set_value(int gpio, int v)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1000_SYS_PHYS_ADDR);
unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE); unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE);
unsigned long r = v ? SYS_OUTPUTSET : SYS_OUTPUTCLR; unsigned long r = v ? AU1000_SYS_OUTPUTSET : AU1000_SYS_OUTPUTCLR;
__raw_writel(mask, base + r); alchemy_wrsys(mask, r);
wmb();
} }
static inline int alchemy_gpio1_get_value(int gpio) static inline int alchemy_gpio1_get_value(int gpio)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1000_SYS_PHYS_ADDR);
unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE); unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE);
return __raw_readl(base + SYS_PINSTATERD) & mask; return alchemy_rdsys(AU1000_SYS_PINSTATERD) & mask;
} }
static inline int alchemy_gpio1_direction_input(int gpio) static inline int alchemy_gpio1_direction_input(int gpio)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1000_SYS_PHYS_ADDR);
unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE); unsigned long mask = 1 << (gpio - ALCHEMY_GPIO1_BASE);
__raw_writel(mask, base + SYS_TRIOUTCLR); alchemy_wrsys(mask, AU1000_SYS_TRIOUTCLR);
wmb();
return 0; return 0;
} }
@ -279,13 +274,13 @@ static inline void __alchemy_gpio2_mod_dir(int gpio, int to_out)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
unsigned long mask = 1 << (gpio - ALCHEMY_GPIO2_BASE); unsigned long mask = 1 << (gpio - ALCHEMY_GPIO2_BASE);
unsigned long d = __raw_readl(base + GPIO2_DIR); unsigned long d = __raw_readl(base + AU1000_GPIO2_DIR);
if (to_out) if (to_out)
d |= mask; d |= mask;
else else
d &= ~mask; d &= ~mask;
__raw_writel(d, base + GPIO2_DIR); __raw_writel(d, base + AU1000_GPIO2_DIR);
wmb(); wmb();
} }
@ -294,14 +289,15 @@ static inline void alchemy_gpio2_set_value(int gpio, int v)
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
unsigned long mask; unsigned long mask;
mask = ((v) ? 0x00010001 : 0x00010000) << (gpio - ALCHEMY_GPIO2_BASE); mask = ((v) ? 0x00010001 : 0x00010000) << (gpio - ALCHEMY_GPIO2_BASE);
__raw_writel(mask, base + GPIO2_OUTPUT); __raw_writel(mask, base + AU1000_GPIO2_OUTPUT);
wmb(); wmb();
} }
static inline int alchemy_gpio2_get_value(int gpio) static inline int alchemy_gpio2_get_value(int gpio)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
return __raw_readl(base + GPIO2_PINSTATE) & (1 << (gpio - ALCHEMY_GPIO2_BASE)); return __raw_readl(base + AU1000_GPIO2_PINSTATE) &
(1 << (gpio - ALCHEMY_GPIO2_BASE));
} }
static inline int alchemy_gpio2_direction_input(int gpio) static inline int alchemy_gpio2_direction_input(int gpio)
@ -352,12 +348,12 @@ static inline int alchemy_gpio2_to_irq(int gpio)
static inline void __alchemy_gpio2_mod_int(int gpio2, int en) static inline void __alchemy_gpio2_mod_int(int gpio2, int en)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
unsigned long r = __raw_readl(base + GPIO2_INTENABLE); unsigned long r = __raw_readl(base + AU1000_GPIO2_INTENABLE);
if (en) if (en)
r |= 1 << gpio2; r |= 1 << gpio2;
else else
r &= ~(1 << gpio2); r &= ~(1 << gpio2);
__raw_writel(r, base + GPIO2_INTENABLE); __raw_writel(r, base + AU1000_GPIO2_INTENABLE);
wmb(); wmb();
} }
@ -434,9 +430,9 @@ static inline void alchemy_gpio2_disable_int(int gpio2)
static inline void alchemy_gpio2_enable(void) static inline void alchemy_gpio2_enable(void)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
__raw_writel(3, base + GPIO2_ENABLE); /* reset, clock enabled */ __raw_writel(3, base + AU1000_GPIO2_ENABLE); /* reset, clock enabled */
wmb(); wmb();
__raw_writel(1, base + GPIO2_ENABLE); /* clock enabled */ __raw_writel(1, base + AU1000_GPIO2_ENABLE); /* clock enabled */
wmb(); wmb();
} }
@ -448,7 +444,7 @@ static inline void alchemy_gpio2_enable(void)
static inline void alchemy_gpio2_disable(void) static inline void alchemy_gpio2_disable(void)
{ {
void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR); void __iomem *base = (void __iomem *)KSEG1ADDR(AU1500_GPIO2_PHYS_ADDR);
__raw_writel(2, base + GPIO2_ENABLE); /* reset, clock disabled */ __raw_writel(2, base + AU1000_GPIO2_ENABLE); /* reset, clock disabled */
wmb(); wmb();
} }

View File

@ -602,7 +602,7 @@ static void au1xmmc_set_clock(struct au1xmmc_host *host, int rate)
/* From databook: /* From databook:
* divisor = ((((cpuclock / sbus_divisor) / 2) / mmcclock) / 2) - 1 * divisor = ((((cpuclock / sbus_divisor) / 2) / mmcclock) / 2) - 1
*/ */
pbus /= ((au_readl(SYS_POWERCTRL) & 0x3) + 2); pbus /= ((alchemy_rdsys(AU1000_SYS_POWERCTRL) & 0x3) + 2);
pbus /= 2; pbus /= 2;
divisor = ((pbus / rate) / 2) - 1; divisor = ((pbus / rate) / 2) - 1;

View File

@ -32,7 +32,7 @@ static int au1xtoy_rtc_read_time(struct device *dev, struct rtc_time *tm)
{ {
unsigned long t; unsigned long t;
t = au_readl(SYS_TOYREAD); t = alchemy_rdsys(AU1000_SYS_TOYREAD);
rtc_time_to_tm(t, tm); rtc_time_to_tm(t, tm);
@ -45,13 +45,12 @@ static int au1xtoy_rtc_set_time(struct device *dev, struct rtc_time *tm)
rtc_tm_to_time(tm, &t); rtc_tm_to_time(tm, &t);
au_writel(t, SYS_TOYWRITE); alchemy_wrsys(t, AU1000_SYS_TOYWRITE);
au_sync();
/* wait for the pending register write to succeed. This can /* wait for the pending register write to succeed. This can
* take up to 6 seconds... * take up to 6 seconds...
*/ */
while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C0S) while (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_C0S)
msleep(1); msleep(1);
return 0; return 0;
@ -68,7 +67,7 @@ static int au1xtoy_rtc_probe(struct platform_device *pdev)
unsigned long t; unsigned long t;
int ret; int ret;
t = au_readl(SYS_COUNTER_CNTRL); t = alchemy_rdsys(AU1000_SYS_CNTRCTRL);
if (!(t & CNTR_OK)) { if (!(t & CNTR_OK)) {
dev_err(&pdev->dev, "counters not working; aborting.\n"); dev_err(&pdev->dev, "counters not working; aborting.\n");
ret = -ENODEV; ret = -ENODEV;
@ -78,10 +77,10 @@ static int au1xtoy_rtc_probe(struct platform_device *pdev)
ret = -ETIMEDOUT; ret = -ETIMEDOUT;
/* set counter0 tickrate to 1Hz if necessary */ /* set counter0 tickrate to 1Hz if necessary */
if (au_readl(SYS_TOYTRIM) != 32767) { if (alchemy_rdsys(AU1000_SYS_TOYTRIM) != 32767) {
/* wait until hardware gives access to TRIM register */ /* wait until hardware gives access to TRIM register */
t = 0x00100000; t = 0x00100000;
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_T0S) && --t) while ((alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_T0S) && --t)
msleep(1); msleep(1);
if (!t) { if (!t) {
@ -93,12 +92,11 @@ static int au1xtoy_rtc_probe(struct platform_device *pdev)
} }
/* set 1Hz TOY tick rate */ /* set 1Hz TOY tick rate */
au_writel(32767, SYS_TOYTRIM); alchemy_wrsys(32767, AU1000_SYS_TOYTRIM);
au_sync();
} }
/* wait until the hardware allows writes to the counter reg */ /* wait until the hardware allows writes to the counter reg */
while (au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C0S) while (alchemy_rdsys(AU1000_SYS_CNTRCTRL) & SYS_CNTRL_C0S)
msleep(1); msleep(1);
rtcdev = devm_rtc_device_register(&pdev->dev, "rtc-au1xxx", rtcdev = devm_rtc_device_register(&pdev->dev, "rtc-au1xxx",

View File

@ -507,8 +507,9 @@ static int au1100fb_drv_probe(struct platform_device *dev)
print_dbg("phys=0x%08x, size=%dK", fbdev->fb_phys, fbdev->fb_len / 1024); print_dbg("phys=0x%08x, size=%dK", fbdev->fb_phys, fbdev->fb_len / 1024);
/* Setup LCD clock to AUX (48 MHz) */ /* Setup LCD clock to AUX (48 MHz) */
sys_clksrc = au_readl(SYS_CLKSRC) & ~(SYS_CS_ML_MASK | SYS_CS_DL | SYS_CS_CL); sys_clksrc = alchemy_rdsys(AU1000_SYS_CLKSRC);
au_writel((sys_clksrc | (1 << SYS_CS_ML_BIT)), SYS_CLKSRC); sys_clksrc &= ~(SYS_CS_ML_MASK | SYS_CS_DL | SYS_CS_CL);
alchemy_wrsys((sys_clksrc | (1 << SYS_CS_ML_BIT)), AU1000_SYS_CLKSRC);
/* load the panel info into the var struct */ /* load the panel info into the var struct */
au1100fb_var.bits_per_pixel = fbdev->panel->bpp; au1100fb_var.bits_per_pixel = fbdev->panel->bpp;
@ -591,13 +592,13 @@ int au1100fb_drv_suspend(struct platform_device *dev, pm_message_t state)
return 0; return 0;
/* Save the clock source state */ /* Save the clock source state */
sys_clksrc = au_readl(SYS_CLKSRC); sys_clksrc = alchemy_rdsys(AU1000_SYS_CLKSRC);
/* Blank the LCD */ /* Blank the LCD */
au1100fb_fb_blank(VESA_POWERDOWN, &fbdev->info); au1100fb_fb_blank(VESA_POWERDOWN, &fbdev->info);
/* Stop LCD clocking */ /* Stop LCD clocking */
au_writel(sys_clksrc & ~SYS_CS_ML_MASK, SYS_CLKSRC); alchemy_wrsys(sys_clksrc & ~SYS_CS_ML_MASK, AU1000_SYS_CLKSRC);
memcpy(&fbregs, fbdev->regs, sizeof(struct au1100fb_regs)); memcpy(&fbregs, fbdev->regs, sizeof(struct au1100fb_regs));
@ -614,7 +615,7 @@ int au1100fb_drv_resume(struct platform_device *dev)
memcpy(fbdev->regs, &fbregs, sizeof(struct au1100fb_regs)); memcpy(fbdev->regs, &fbregs, sizeof(struct au1100fb_regs));
/* Restart LCD clocking */ /* Restart LCD clocking */
au_writel(sys_clksrc, SYS_CLKSRC); alchemy_wrsys(sys_clksrc, AU1000_SYS_CLKSRC);
/* Unblank the LCD */ /* Unblank the LCD */
au1100fb_fb_blank(VESA_NO_BLANKING, &fbdev->info); au1100fb_fb_blank(VESA_NO_BLANKING, &fbdev->info);

View File

@ -830,10 +830,10 @@ static void au1200_setpanel(struct panel_settings *newpanel,
if (!(panel->mode_clkcontrol & LCD_CLKCONTROL_EXT)) if (!(panel->mode_clkcontrol & LCD_CLKCONTROL_EXT))
{ {
uint32 sys_clksrc; uint32 sys_clksrc;
au_writel(panel->mode_auxpll, SYS_AUXPLL); alchemy_wrsys(panel->mode_auxpll, AU1000_SYS_AUXPLL);
sys_clksrc = au_readl(SYS_CLKSRC) & ~0x0000001f; sys_clksrc = alchemy_rdsys(AU1000_SYS_CLKSRC) & ~0x0000001f;
sys_clksrc |= panel->mode_toyclksrc; sys_clksrc |= panel->mode_toyclksrc;
au_writel(sys_clksrc, SYS_CLKSRC); alchemy_wrsys(sys_clksrc, AU1000_SYS_CLKSRC);
} }
/* /*