aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/platforms/52xx/lite5200.c
diff options
context:
space:
mode:
authorGrant Likely <grant.likely@secretlab.ca>2007-10-09 16:45:28 -0400
committerGrant Likely <grant.likely@secretlab.ca>2007-10-10 12:22:04 -0400
commit4de3b992a6880828943f1b5849e1e7153fe4185c (patch)
treef020001483d877540a17297c9d9b3bfb6d9582fd /arch/powerpc/platforms/52xx/lite5200.c
parent9fe2e7969d5e5af7dbd2086f2e18f4ebc585490d (diff)
[POWERPC] MPC5200: Don't make firmware fixups into common code
The Lite5200 u-boot image doesn't entirely configure the processor correctly and so Linux needs to fixup the cpu setup in setup_arch. Fixing the CPU setup is good, but making it into common code is not a good idea. New board ports should be encouraged not to take the lead of the lite5200 and instead get their firmware to setup the CPU the right way. Signed-off-by: Grant Likely <grant.likely@secretlab.ca> Signed-off-by: Sylvain Munaut <tnt@246tnt.com>
Diffstat (limited to 'arch/powerpc/platforms/52xx/lite5200.c')
-rw-r--r--arch/powerpc/platforms/52xx/lite5200.c59
1 files changed, 49 insertions, 10 deletions
diff --git a/arch/powerpc/platforms/52xx/lite5200.c b/arch/powerpc/platforms/52xx/lite5200.c
index 7fa0ec8d91c..0caa3d955c3 100644
--- a/arch/powerpc/platforms/52xx/lite5200.c
+++ b/arch/powerpc/platforms/52xx/lite5200.c
@@ -30,19 +30,56 @@
30 * 30 *
31 */ 31 */
32 32
33/*
34 * Fix clock configuration.
35 *
36 * Firmware is supposed to be responsible for this. If you are creating a
37 * new board port, do *NOT* duplicate this code. Fix your boot firmware
38 * to set it correctly in the first place
39 */
40static void __init
41lite5200_fix_clock_config(void)
42{
43 struct mpc52xx_cdm __iomem *cdm;
44
45 /* Map zones */
46 cdm = mpc52xx_find_and_map("mpc5200-cdm");
47 if (!cdm) {
48 printk(KERN_ERR "%s() failed; expect abnormal behaviour\n",
49 __FUNCTION__);
50 return;
51 }
52
53 /* Use internal 48 Mhz */
54 out_8(&cdm->ext_48mhz_en, 0x00);
55 out_8(&cdm->fd_enable, 0x01);
56 if (in_be32(&cdm->rstcfg) & 0x40) /* Assumes 33Mhz clock */
57 out_be16(&cdm->fd_counters, 0x0001);
58 else
59 out_be16(&cdm->fd_counters, 0x5555);
60
61 /* Unmap the regs */
62 iounmap(cdm);
63}
64
65/*
66 * Fix setting of port_config register.
67 *
68 * Firmware is supposed to be responsible for this. If you are creating a
69 * new board port, do *NOT* duplicate this code. Fix your boot firmware
70 * to set it correctly in the first place
71 */
33static void __init 72static void __init
34lite5200_setup_cpu(void) 73lite5200_fix_port_config(void)
35{ 74{
36 struct mpc52xx_gpio __iomem *gpio; 75 struct mpc52xx_gpio __iomem *gpio;
37 u32 port_config; 76 u32 port_config;
38 77
39 /* Map zones */
40 gpio = mpc52xx_find_and_map("mpc5200-gpio"); 78 gpio = mpc52xx_find_and_map("mpc5200-gpio");
41 if (!gpio) { 79 if (!gpio) {
42 printk(KERN_ERR __FILE__ ": " 80 printk(KERN_ERR "%s() failed. expect abnormal behavior\n",
43 "Error while mapping GPIO register for port config. " 81 __FUNCTION__);
44 "Expect some abnormal behavior\n"); 82 return;
45 goto error;
46 } 83 }
47 84
48 /* Set port config */ 85 /* Set port config */
@@ -61,7 +98,6 @@ lite5200_setup_cpu(void)
61 out_be32(&gpio->port_config, port_config); 98 out_be32(&gpio->port_config, port_config);
62 99
63 /* Unmap zone */ 100 /* Unmap zone */
64error:
65 iounmap(gpio); 101 iounmap(gpio);
66} 102}
67 103
@@ -100,9 +136,12 @@ static void __init lite5200_setup_arch(void)
100 if (ppc_md.progress) 136 if (ppc_md.progress)
101 ppc_md.progress("lite5200_setup_arch()", 0); 137 ppc_md.progress("lite5200_setup_arch()", 0);
102 138
103 /* CPU & Port mux setup */ 139 /* Fix things that firmware should have done. */
104 mpc52xx_setup_cpu(); /* Generic */ 140 lite5200_fix_clock_config();
105 lite5200_setup_cpu(); /* Platorm specific */ 141 lite5200_fix_port_config();
142
143 /* Some mpc5200 & mpc5200b related configuration */
144 mpc5200_setup_xlb_arbiter();
106 145
107#ifdef CONFIG_PM 146#ifdef CONFIG_PM
108 mpc52xx_suspend.board_suspend_prepare = lite5200_suspend_prepare; 147 mpc52xx_suspend.board_suspend_prepare = lite5200_suspend_prepare;