1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2024-12-25 13:35:31 +02:00

[atheros] add missing CONFIG_GPIO_LEDS related ifdefs

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10835 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
juhosg 2008-04-14 17:23:07 +00:00
parent 41696be697
commit a426ecf827
2 changed files with 26 additions and 22 deletions

View File

@ -192,7 +192,7 @@ static struct platform_device ar5312_gpio_leds = {
static char __init *ar5312_flash_limit(void) static char __init *ar5312_flash_limit(void)
{ {
u32 ctl; u32 ctl;
/* /*
* Configure flash bank 0. * Configure flash bank 0.
* Assume 8M window size. Flash will be aliased if it's smaller * Assume 8M window size. Flash will be aliased if it's smaller
*/ */
@ -205,7 +205,7 @@ static char __init *ar5312_flash_limit(void)
(sysRegRead(AR531X_FLASHCTL0) & FLASHCTL_MW); (sysRegRead(AR531X_FLASHCTL0) & FLASHCTL_MW);
sysRegWrite(AR531X_FLASHCTL0, ctl); sysRegWrite(AR531X_FLASHCTL0, ctl);
/* Disable other flash banks */ /* Disable other flash banks */
sysRegWrite(AR531X_FLASHCTL1, sysRegWrite(AR531X_FLASHCTL1,
sysRegRead(AR531X_FLASHCTL1) & ~(FLASHCTL_E | FLASHCTL_AC)); sysRegRead(AR531X_FLASHCTL1) & ~(FLASHCTL_E | FLASHCTL_AC));
@ -219,7 +219,7 @@ static char __init *ar5312_flash_limit(void)
static struct ar531x_config __init *init_wmac(int unit) static struct ar531x_config __init *init_wmac(int unit)
{ {
struct ar531x_config *config; struct ar531x_config *config;
config = (struct ar531x_config *) kzalloc(sizeof(struct ar531x_config), GFP_KERNEL); config = (struct ar531x_config *) kzalloc(sizeof(struct ar531x_config), GFP_KERNEL);
config->board = board_config; config->board = board_config;
config->radio = radio_config; config->radio = radio_config;
@ -228,7 +228,7 @@ static struct ar531x_config __init *init_wmac(int unit)
return config; return config;
} }
int __init ar5312_init_devices(void) int __init ar5312_init_devices(void)
{ {
struct ar531x_boarddata *bcfg; struct ar531x_boarddata *bcfg;
@ -243,13 +243,13 @@ int __init ar5312_init_devices(void)
ar531x_find_config(ar5312_flash_limit()); ar531x_find_config(ar5312_flash_limit());
bcfg = (struct ar531x_boarddata *) board_config; bcfg = (struct ar531x_boarddata *) board_config;
/* /*
* Chip IDs and hardware detection for some Atheros * Chip IDs and hardware detection for some Atheros
* models are really broken! * models are really broken!
* *
* Atheros uses a disabled WMAC0 and Silicon ID of AR5312 * Atheros uses a disabled WMAC0 and Silicon ID of AR5312
* as indication for AR2312, which is otherwise * as indication for AR2312, which is otherwise
* indistinguishable from the real AR5312. * indistinguishable from the real AR5312.
*/ */
if (radio_config) { if (radio_config) {
@ -262,11 +262,11 @@ int __init ar5312_init_devices(void)
/* AR2313 has CPU minor rev. 10 */ /* AR2313 has CPU minor rev. 10 */
if ((current_cpu_data.processor_id & 0xff) == 0x0a) if ((current_cpu_data.processor_id & 0xff) == 0x0a)
mips_machtype = MACH_ATHEROS_AR2313; mips_machtype = MACH_ATHEROS_AR2313;
/* AR2312 shares the same Silicon ID as AR5312 */ /* AR2312 shares the same Silicon ID as AR5312 */
else if (bcfg->config & BD_ISCASPER) else if (bcfg->config & BD_ISCASPER)
mips_machtype = MACH_ATHEROS_AR2312; mips_machtype = MACH_ATHEROS_AR2312;
/* Everything else is probably AR5312 or compatible */ /* Everything else is probably AR5312 or compatible */
else else
mips_machtype = MACH_ATHEROS_AR5312; mips_machtype = MACH_ATHEROS_AR5312;
@ -288,8 +288,10 @@ int __init ar5312_init_devices(void)
ar5312_devs[dev++] = &ar5312_physmap_flash; ar5312_devs[dev++] = &ar5312_physmap_flash;
#ifdef CONFIG_LEDS_GPIO
ar5312_leds[0].gpio = bcfg->sysLedGpio; ar5312_leds[0].gpio = bcfg->sysLedGpio;
ar5312_devs[dev++] = &ar5312_gpio_leds; ar5312_devs[dev++] = &ar5312_gpio_leds;
#endif
if (!memcmp(bcfg->enet0Mac, "\xff\xff\xff\xff\xff\xff", 6)) if (!memcmp(bcfg->enet0Mac, "\xff\xff\xff\xff\xff\xff", 6))
memcpy(bcfg->enet0Mac, bcfg->enet1Mac, 6); memcpy(bcfg->enet0Mac, bcfg->enet1Mac, 6);
@ -363,7 +365,7 @@ static int __initdata CLOCKCTL1_PREDIVIDE_TABLE[4] = {
5 5
}; };
static unsigned int __init ar5312_cpu_frequency(void) static unsigned int __init ar5312_cpu_frequency(void)
{ {
unsigned int result; unsigned int result;
@ -391,7 +393,7 @@ static unsigned int __init ar5312_cpu_frequency(void)
multiplier_shift = AR5312_CLOCKCTL1_MULTIPLIER_SHIFT; multiplier_shift = AR5312_CLOCKCTL1_MULTIPLIER_SHIFT;
doubler_mask = AR5312_CLOCKCTL1_DOUBLER_MASK; doubler_mask = AR5312_CLOCKCTL1_DOUBLER_MASK;
} }
/* /*
* Clocking is derived from a fixed 40MHz input clock. * Clocking is derived from a fixed 40MHz input clock.
* *
@ -400,9 +402,9 @@ static unsigned int __init ar5312_cpu_frequency(void)
* flash, Timer, Watchdog Timer) * flash, Timer, Watchdog Timer)
* *
* cntFreq = cpuFreq / 2 (use for CPU count/compare) * cntFreq = cpuFreq / 2 (use for CPU count/compare)
* *
* So, for example, with a PLL multiplier of 5, we have * So, for example, with a PLL multiplier of 5, we have
* *
* cpuFreq = 200MHz * cpuFreq = 200MHz
* sysFreq = 50MHz * sysFreq = 50MHz
* cntFreq = 100MHz * cntFreq = 100MHz
@ -414,7 +416,7 @@ static unsigned int __init ar5312_cpu_frequency(void)
preDivideSelect = (clockCtl1 & predivide_mask) >> predivide_shift; preDivideSelect = (clockCtl1 & predivide_mask) >> predivide_shift;
preDivisor = CLOCKCTL1_PREDIVIDE_TABLE[preDivideSelect]; preDivisor = CLOCKCTL1_PREDIVIDE_TABLE[preDivideSelect];
multiplier = (clockCtl1 & multiplier_mask) >> multiplier_shift; multiplier = (clockCtl1 & multiplier_mask) >> multiplier_shift;
if (clockCtl1 & doubler_mask) { if (clockCtl1 & doubler_mask) {
multiplier = multiplier << 1; multiplier = multiplier << 1;
} }
@ -446,7 +448,7 @@ void __init ar5312_prom_init(void)
+ (bank1AC ? (1 << (bank1AC+1)) : 0); + (bank1AC ? (1 << (bank1AC+1)) : 0);
memsize <<= 20; memsize <<= 20;
add_memory_region(0, memsize, BOOT_MEM_RAM); add_memory_region(0, memsize, BOOT_MEM_RAM);
/* Initialize it to AR5312 for now. Real detection will be done /* Initialize it to AR5312 for now. Real detection will be done
* in ar5312_init_devices() */ * in ar5312_init_devices() */
mips_machtype = MACH_ATHEROS_AR5312; mips_machtype = MACH_ATHEROS_AR5312;

View File

@ -150,7 +150,7 @@ static __u8 spiflash_probe(void)
(1 << 4) | SPI_CTL_START; (1 << 4) | SPI_CTL_START;
spiflash_regwrite32(SPI_FLASH_CTL, reg); spiflash_regwrite32(SPI_FLASH_CTL, reg);
do { do {
reg = spiflash_regread32(SPI_FLASH_CTL); reg = spiflash_regread32(SPI_FLASH_CTL);
} while (reg & SPI_CTL_BUSY); } while (reg & SPI_CTL_BUSY);
@ -236,17 +236,19 @@ int __init ar5315_init_devices(void)
config->radio = radio_config; config->radio = radio_config;
config->unit = 0; config->unit = 0;
config->tag = (u_int16_t) (sysRegRead(AR5315_SREV) & AR5315_REV_CHIP); config->tag = (u_int16_t) (sysRegRead(AR5315_SREV) & AR5315_REV_CHIP);
ar5315_eth_data.board_config = board_config; ar5315_eth_data.board_config = board_config;
ar5315_eth_data.macaddr = bcfg->enet0Mac; ar5315_eth_data.macaddr = bcfg->enet0Mac;
ar5315_wmac.dev.platform_data = config; ar5315_wmac.dev.platform_data = config;
ar5315_leds[0].gpio = bcfg->sysLedGpio;
ar5315_devs[dev++] = &ar5315_eth; ar5315_devs[dev++] = &ar5315_eth;
ar5315_devs[dev++] = &ar5315_wmac; ar5315_devs[dev++] = &ar5315_wmac;
ar5315_devs[dev++] = &ar5315_spiflash; ar5315_devs[dev++] = &ar5315_spiflash;
#ifdef CONFIG_LEDS_GPIO
ar5315_leds[0].gpio = bcfg->sysLedGpio;
ar5315_devs[dev++] = &ar5315_gpio_leds; ar5315_devs[dev++] = &ar5315_gpio_leds;
#endif
return platform_add_devices(ar5315_devs, dev); return platform_add_devices(ar5315_devs, dev);
} }
@ -269,7 +271,7 @@ static void ar5315_restart(char *command)
/* reset the system */ /* reset the system */
sysRegWrite(AR5315_COLD_RESET,AR5317_RESET_SYSTEM); sysRegWrite(AR5315_COLD_RESET,AR5317_RESET_SYSTEM);
/* /*
* Cold reset does not work on the AR2315/6, use the GPIO reset bits a workaround. * Cold reset does not work on the AR2315/6, use the GPIO reset bits a workaround.
*/ */
gpio_direction_output(AR5315_RESET_GPIO, 0); gpio_direction_output(AR5315_RESET_GPIO, 0);
@ -326,11 +328,11 @@ ar5315_sys_clk(unsigned int clockCtl)
clkDiv = 1; clkDiv = 1;
break; break;
} }
cpuDiv = (clockCtl & CPUCLK_CLK_DIV_M) >> CPUCLK_CLK_DIV_S; cpuDiv = (clockCtl & CPUCLK_CLK_DIV_M) >> CPUCLK_CLK_DIV_S;
cpuDiv = cpuDiv * 2 ?: 1; cpuDiv = cpuDiv * 2 ?: 1;
return (pllcOut/(clkDiv * cpuDiv)); return (pllcOut/(clkDiv * cpuDiv));
} }
static inline unsigned int ar5315_cpu_frequency(void) static inline unsigned int ar5315_cpu_frequency(void)
{ {
return ar5315_sys_clk(sysRegRead(AR5315_CPUCLK)); return ar5315_sys_clk(sysRegRead(AR5315_CPUCLK));