diff options
author | Manuel Lauss <mano@roarinelk.homelinux.net> | 2008-12-21 03:26:21 -0500 |
---|---|---|
committer | Ralf Baechle <ralf@linux-mips.org> | 2009-01-11 04:57:26 -0500 |
commit | 074cf656700ddd1d2bd7f815f78e785418beb898 (patch) | |
tree | af55e5f9d36775df851924303e44fdde7cff8654 /arch/mips/alchemy/common | |
parent | 1820ec1d2b993f3ec00169e881504aa4541a9bf7 (diff) |
MIPS: Alchemy: remove cpu_table.
Remove the cpu_table:
- move detection of whether c0_config[OD] is read-only and should be set
to fix various chip errata to au1000 headers.
- move detection of write-only sys_cpupll to au1000 headers.
- remove the BCLK switching code: Activation of this features should be
left to the boards using the chips since it also affects external devices
tied to BCLK, and only the board designers know whether it is safe to
enable.
Signed-off-by: Manuel Lauss <mano@roarinelk.homelinux.net>
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
delete mode 100644 arch/mips/alchemy/common/cputable.c
Diffstat (limited to 'arch/mips/alchemy/common')
-rw-r--r-- | arch/mips/alchemy/common/Makefile | 2 | ||||
-rw-r--r-- | arch/mips/alchemy/common/cputable.c | 52 | ||||
-rw-r--r-- | arch/mips/alchemy/common/setup.c | 26 | ||||
-rw-r--r-- | arch/mips/alchemy/common/time.c | 4 |
4 files changed, 4 insertions, 80 deletions
diff --git a/arch/mips/alchemy/common/Makefile b/arch/mips/alchemy/common/Makefile index 28b8aebb35e..d50d4764eaf 100644 --- a/arch/mips/alchemy/common/Makefile +++ b/arch/mips/alchemy/common/Makefile | |||
@@ -7,7 +7,7 @@ | |||
7 | 7 | ||
8 | obj-y += prom.o irq.o puts.o time.o reset.o \ | 8 | obj-y += prom.o irq.o puts.o time.o reset.o \ |
9 | clocks.o platform.o power.o setup.o \ | 9 | clocks.o platform.o power.o setup.o \ |
10 | sleeper.o cputable.o dma.o dbdma.o gpio.o | 10 | sleeper.o dma.o dbdma.o gpio.o |
11 | 11 | ||
12 | obj-$(CONFIG_PCI) += pci.o | 12 | obj-$(CONFIG_PCI) += pci.o |
13 | 13 | ||
diff --git a/arch/mips/alchemy/common/cputable.c b/arch/mips/alchemy/common/cputable.c deleted file mode 100644 index ba6430bc2d0..00000000000 --- a/arch/mips/alchemy/common/cputable.c +++ /dev/null | |||
@@ -1,52 +0,0 @@ | |||
1 | /* | ||
2 | * arch/mips/au1000/common/cputable.c | ||
3 | * | ||
4 | * Copyright (C) 2004 Dan Malek (dan@embeddededge.com) | ||
5 | * Copied from PowerPC and updated for Alchemy Au1xxx processors. | ||
6 | * | ||
7 | * Copyright (C) 2001 Ben. Herrenschmidt (benh@kernel.crashing.org) | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or | ||
10 | * modify it under the terms of the GNU General Public License | ||
11 | * as published by the Free Software Foundation; either version | ||
12 | * 2 of the License, or (at your option) any later version. | ||
13 | */ | ||
14 | |||
15 | #include <asm/mach-au1x00/au1000.h> | ||
16 | |||
17 | struct cpu_spec *cur_cpu_spec[NR_CPUS]; | ||
18 | |||
19 | /* With some thought, we can probably use the mask to reduce the | ||
20 | * size of the table. | ||
21 | */ | ||
22 | struct cpu_spec cpu_specs[] = { | ||
23 | { 0xffffffff, 0x00030100, "Au1000 DA", 1, 0, 1 }, | ||
24 | { 0xffffffff, 0x00030201, "Au1000 HA", 1, 0, 1 }, | ||
25 | { 0xffffffff, 0x00030202, "Au1000 HB", 1, 0, 1 }, | ||
26 | { 0xffffffff, 0x00030203, "Au1000 HC", 1, 1, 0 }, | ||
27 | { 0xffffffff, 0x00030204, "Au1000 HD", 1, 1, 0 }, | ||
28 | { 0xffffffff, 0x01030200, "Au1500 AB", 1, 1, 0 }, | ||
29 | { 0xffffffff, 0x01030201, "Au1500 AC", 0, 1, 0 }, | ||
30 | { 0xffffffff, 0x01030202, "Au1500 AD", 0, 1, 0 }, | ||
31 | { 0xffffffff, 0x02030200, "Au1100 AB", 1, 1, 0 }, | ||
32 | { 0xffffffff, 0x02030201, "Au1100 BA", 1, 1, 0 }, | ||
33 | { 0xffffffff, 0x02030202, "Au1100 BC", 1, 1, 0 }, | ||
34 | { 0xffffffff, 0x02030203, "Au1100 BD", 0, 1, 0 }, | ||
35 | { 0xffffffff, 0x02030204, "Au1100 BE", 0, 1, 0 }, | ||
36 | { 0xffffffff, 0x03030200, "Au1550 AA", 0, 1, 0 }, | ||
37 | { 0xffffffff, 0x04030200, "Au1200 AB", 0, 0, 0 }, | ||
38 | { 0xffffffff, 0x04030201, "Au1200 AC", 1, 0, 0 }, | ||
39 | { 0x00000000, 0x00000000, "Unknown Au1xxx", 1, 0, 0 } | ||
40 | }; | ||
41 | |||
42 | void set_cpuspec(void) | ||
43 | { | ||
44 | struct cpu_spec *sp; | ||
45 | u32 prid; | ||
46 | |||
47 | prid = read_c0_prid(); | ||
48 | sp = cpu_specs; | ||
49 | while ((prid & sp->prid_mask) != sp->prid_value) | ||
50 | sp++; | ||
51 | cur_cpu_spec[0] = sp; | ||
52 | } | ||
diff --git a/arch/mips/alchemy/common/setup.c b/arch/mips/alchemy/common/setup.c index 9889ec3ba4c..4d42be811e7 100644 --- a/arch/mips/alchemy/common/setup.c +++ b/arch/mips/alchemy/common/setup.c | |||
@@ -44,37 +44,13 @@ extern void set_cpuspec(void); | |||
44 | 44 | ||
45 | void __init plat_mem_setup(void) | 45 | void __init plat_mem_setup(void) |
46 | { | 46 | { |
47 | struct cpu_spec *sp; | ||
48 | unsigned long prid, cpufreq, bclk; | ||
49 | |||
50 | set_cpuspec(); | ||
51 | sp = cur_cpu_spec[0]; | ||
52 | |||
53 | _machine_restart = au1000_restart; | 47 | _machine_restart = au1000_restart; |
54 | _machine_halt = au1000_halt; | 48 | _machine_halt = au1000_halt; |
55 | pm_power_off = au1000_power_off; | 49 | pm_power_off = au1000_power_off; |
56 | 50 | ||
57 | board_setup(); /* board specific setup */ | 51 | board_setup(); /* board specific setup */ |
58 | 52 | ||
59 | prid = read_c0_prid(); | 53 | if (au1xxx_cpu_needs_config_od()) |
60 | if (sp->cpu_pll_wo) | ||
61 | #ifdef CONFIG_SOC_AU1000_FREQUENCY | ||
62 | cpufreq = CONFIG_SOC_AU1000_FREQUENCY / 1000000; | ||
63 | #else | ||
64 | cpufreq = 396; | ||
65 | #endif | ||
66 | else | ||
67 | cpufreq = (au_readl(SYS_CPUPLL) & 0x3F) * 12; | ||
68 | printk(KERN_INFO "(PRID %08lx) @ %ld MHz\n", prid, cpufreq); | ||
69 | |||
70 | if (sp->cpu_bclk) { | ||
71 | /* Enable BCLK switching */ | ||
72 | bclk = au_readl(SYS_POWERCTRL); | ||
73 | au_writel(bclk | 0x60, SYS_POWERCTRL); | ||
74 | printk(KERN_INFO "BCLK switching enabled!\n"); | ||
75 | } | ||
76 | |||
77 | if (sp->cpu_od) | ||
78 | /* Various early Au1xx0 errata corrected by this */ | 54 | /* Various early Au1xx0 errata corrected by this */ |
79 | set_c0_config(1 << 19); /* Set Config[OD] */ | 55 | set_c0_config(1 << 19); /* Set Config[OD] */ |
80 | else | 56 | else |
diff --git a/arch/mips/alchemy/common/time.c b/arch/mips/alchemy/common/time.c index 68d714258e9..15185708ad8 100644 --- a/arch/mips/alchemy/common/time.c +++ b/arch/mips/alchemy/common/time.c | |||
@@ -198,7 +198,7 @@ unsigned long calc_clock(void) | |||
198 | * silicon versions of Au1000 are not sold by AMD, we don't bend | 198 | * silicon versions of Au1000 are not sold by AMD, we don't bend |
199 | * over backwards trying to determine the frequency. | 199 | * over backwards trying to determine the frequency. |
200 | */ | 200 | */ |
201 | if (cur_cpu_spec[0]->cpu_pll_wo) | 201 | if (au1xxx_cpu_has_pll_wo()) |
202 | #ifdef CONFIG_SOC_AU1000_FREQUENCY | 202 | #ifdef CONFIG_SOC_AU1000_FREQUENCY |
203 | cpu_speed = CONFIG_SOC_AU1000_FREQUENCY; | 203 | cpu_speed = CONFIG_SOC_AU1000_FREQUENCY; |
204 | #else | 204 | #else |
@@ -221,7 +221,7 @@ void __init plat_time_init(void) | |||
221 | 221 | ||
222 | est_freq += 5000; /* round */ | 222 | est_freq += 5000; /* round */ |
223 | est_freq -= est_freq%10000; | 223 | est_freq -= est_freq%10000; |
224 | printk(KERN_INFO "CPU frequency %u.%02u MHz\n", | 224 | printk(KERN_INFO "(PRId %08x) @ %u.%02u MHz\n", read_c0_prid(), |
225 | est_freq / 1000000, ((est_freq % 1000000) * 100) / 1000000); | 225 | est_freq / 1000000, ((est_freq % 1000000) * 100) / 1000000); |
226 | set_au1x00_speed(est_freq); | 226 | set_au1x00_speed(est_freq); |
227 | 227 | ||