powerpc/82xx: rename and update mgcoge board support
authorHolger Brunck <holger.brunck@keymile.com>
Thu, 10 Mar 2011 11:52:45 +0000 (12:52 +0100)
committerKumar Gala <galak@kernel.crashing.org>
Tue, 15 Mar 2011 15:06:37 +0000 (10:06 -0500)
The mgcoge board from keymile is now base for some other
similar boards. Therefore the board specific name mgcoge
was renamed to a generic name km82xx. Additionally some
enhancements were made:
- rework partition table in dts file
- add cpm2_pio_c gpio controller in dts file
- update defconfig
- add pin description for SCC1
- add pin description and configuration for USB

Signed-off-by: Holger Brunck <holger.brunck@keymile.com>
Acked-by: Heiko Schocher <hs@denx.de>
CC: Benjamin Herrenschmidt <benh@kernel.crashing.org>
CC: Heiko Schocher <hs@denx.de>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
arch/powerpc/boot/dts/mgcoge.dts
arch/powerpc/configs/mgcoge_defconfig
arch/powerpc/platforms/82xx/Makefile
arch/powerpc/platforms/82xx/km82xx.c [new file with mode: 0644]
arch/powerpc/platforms/82xx/mgcoge.c [deleted file]

index 0ce96644176da3758b00b1ba1a5ecc34ac156879..1360d2f69024ea976389ccaa129079a4376217f2 100644 (file)
@@ -13,7 +13,7 @@
 /dts-v1/;
 / {
        model = "MGCOGE";
-       compatible = "keymile,mgcoge";
+       compatible = "keymile,km82xx";
        #address-cells = <1>;
        #size-cells = <1>;
 
                reg = <0xf0010100 0x40>;
 
                ranges = <0 0 0xfe000000 0x00400000
-                         5 0 0x50000000 0x20000000
-                       >; /* Filled in by U-Boot */
+                         1 0 0x30000000 0x00010000
+                         2 0 0x40000000 0x00010000
+                         5 0 0x50000000 0x04000000
+                       >;
 
                flash@0,0 {
                        compatible = "cfi-flash";
                        device-width = <1>;
                        partition@0 {
                                label = "u-boot";
-                               reg = <0 0x40000>;
+                               reg = <0x00000 0xC0000>;
                        };
-                       partition@40000 {
+                       partition@1 {
                                label = "env";
-                               reg = <0x40000 0x20000>;
+                               reg = <0xC0000 0x20000>;
                        };
-                       partition@60000 {
-                               label = "kernel";
-                               reg = <0x60000 0x220000>;
+                       partition@2 {
+                               label = "envred";
+                               reg = <0xE0000 0x20000>;
                        };
-                       partition@280000 {
-                               label = "dtb";
-                               reg = <0x280000 0x20000>;
+                       partition@3 {
+                               label = "free";
+                               reg = <0x100000 0x300000>;
                        };
                };
 
                flash@5,0 {
                        compatible = "cfi-flash";
-                       reg = <5 0x0 0x2000000>;
+                       reg = <5 0x00000000 0x02000000
+                              5 0x02000000 0x02000000>;
                        #address-cells = <1>;
                        #size-cells = <1>;
                        bank-width = <2>;
-                       device-width = <2>;
-                       partition@0 {
-                               label = "ramdisk";
-                               reg = <0 0x7a0000>;
-                       };
-                       partition@7a0000 {
-                               label = "user";
-                               reg = <0x7a0000 0x1860000>;
+                       partition@app { /* 64 MBytes */
+                               label = "ubi0";
+                               reg = <0x00000000 0x04000000>;
                        };
                };
        };
                        };
                };
 
+               cpm2_pio_c: gpio-controller@10d40 {
+                       #gpio-cells = <2>;
+                       compatible = "fsl,cpm2-pario-bank";
+                       reg = <0x10d40 0x14>;
+                       gpio-controller;
+               };
+
                PIC: interrupt-controller@10c00 {
                        #interrupt-cells = <2>;
                        interrupt-controller;
index 39518e91822f4fb2ac32bdbd753823330df1e898..6cb588a7d425cb8e1a66a67545ac413514bcff6e 100644 (file)
@@ -1,4 +1,5 @@
 CONFIG_SYSVIPC=y
+CONFIG_SPARSE_IRQ=y
 CONFIG_IKCONFIG=y
 CONFIG_IKCONFIG_PROC=y
 CONFIG_LOG_BUF_SHIFT=14
@@ -10,7 +11,6 @@ CONFIG_SLAB=y
 CONFIG_PPC_82xx=y
 CONFIG_MGCOGE=y
 CONFIG_BINFMT_MISC=y
-CONFIG_SPARSE_IRQ=y
 # CONFIG_SECCOMP is not set
 CONFIG_NET=y
 CONFIG_PACKET=y
@@ -30,7 +30,6 @@ CONFIG_MTD=y
 CONFIG_MTD_CONCAT=y
 CONFIG_MTD_PARTITIONS=y
 CONFIG_MTD_CMDLINE_PARTS=y
-CONFIG_MTD_OF_PARTS=y
 CONFIG_MTD_CHAR=y
 CONFIG_MTD_BLKDEVS=y
 CONFIG_MTD_CFI=y
@@ -43,7 +42,6 @@ CONFIG_MTD_PHYSMAP_OF=y
 CONFIG_PROC_DEVICETREE=y
 CONFIG_BLK_DEV_LOOP=y
 CONFIG_BLK_DEV_RAM=y
-# CONFIG_MISC_DEVICES is not set
 # CONFIG_MACINTOSH_DRIVERS is not set
 CONFIG_NETDEVICES=y
 CONFIG_FIXED_PHY=y
@@ -67,7 +65,6 @@ CONFIG_EXT2_FS=y
 CONFIG_EXT3_FS=y
 # CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
 # CONFIG_EXT3_FS_XATTR is not set
-CONFIG_INOTIFY=y
 CONFIG_AUTOFS4_FS=y
 CONFIG_PROC_KCORE=y
 CONFIG_TMPFS=y
@@ -88,13 +85,9 @@ CONFIG_DEBUG_FS=y
 CONFIG_DEBUG_KERNEL=y
 # CONFIG_SCHED_DEBUG is not set
 CONFIG_DEBUG_INFO=y
-# CONFIG_RCU_CPU_STALL_DETECTOR is not set
 CONFIG_SYSCTL_SYSCALL_CHECK=y
 CONFIG_BDI_SWITCH=y
-CONFIG_CRYPTO_CBC=y
 CONFIG_CRYPTO_ECB=y
 CONFIG_CRYPTO_PCBC=y
-CONFIG_CRYPTO_MD5=y
-CONFIG_CRYPTO_DES=y
 # CONFIG_CRYPTO_ANSI_CPRNG is not set
 # CONFIG_CRYPTO_HW is not set
index d982793f4dbd111b0535436ee39deb06c1cb40ca..455fe21e37c431ae64e8779de86a817ec8cfb0d8 100644 (file)
@@ -6,4 +6,4 @@ obj-$(CONFIG_CPM2) += pq2.o
 obj-$(CONFIG_PQ2_ADS_PCI_PIC) += pq2ads-pci-pic.o
 obj-$(CONFIG_PQ2FADS) += pq2fads.o
 obj-$(CONFIG_EP8248E) += ep8248e.o
-obj-$(CONFIG_MGCOGE) += mgcoge.o
+obj-$(CONFIG_MGCOGE) += km82xx.o
diff --git a/arch/powerpc/platforms/82xx/km82xx.c b/arch/powerpc/platforms/82xx/km82xx.c
new file mode 100644 (file)
index 0000000..428c5e0
--- /dev/null
@@ -0,0 +1,206 @@
+/*
+ * Keymile km82xx support
+ * Copyright 2008-2011 DENX Software Engineering GmbH
+ * Author: Heiko Schocher <hs@denx.de>
+ *
+ * based on code from:
+ * Copyright 2007 Freescale Semiconductor, Inc.
+ * Author: Scott Wood <scottwood@freescale.com>
+ *
+ * This program is free software; you can redistribute  it and/or modify it
+ * under  the terms of  the GNU General  Public License as published by the
+ * Free Software Foundation;  either version 2 of the  License, or (at your
+ * option) any later version.
+ */
+
+#include <linux/init.h>
+#include <linux/interrupt.h>
+#include <linux/fsl_devices.h>
+#include <linux/of_platform.h>
+
+#include <asm/io.h>
+#include <asm/cpm2.h>
+#include <asm/udbg.h>
+#include <asm/machdep.h>
+#include <asm/time.h>
+#include <asm/mpc8260.h>
+#include <asm/prom.h>
+
+#include <sysdev/fsl_soc.h>
+#include <sysdev/cpm2_pic.h>
+
+#include "pq2.h"
+
+static void __init km82xx_pic_init(void)
+{
+       struct device_node *np = of_find_compatible_node(NULL, NULL,
+                                                       "fsl,pq2-pic");
+       if (!np) {
+               printk(KERN_ERR "PIC init: can not find cpm-pic node\n");
+               return;
+       }
+
+       cpm2_pic_init(np);
+       of_node_put(np);
+}
+
+struct cpm_pin {
+       int port, pin, flags;
+};
+
+static __initdata struct cpm_pin km82xx_pins[] = {
+
+       /* SMC2 */
+       {0, 8, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {0, 9, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+
+       /* SCC1 */
+       {2, 21, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2, 15, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {3, 31, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {3, 30, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
+
+       /* SCC4 */
+       {2, 25, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2, 24, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2,  9, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2,  8, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {3, 22, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {3, 21, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+
+       /* FCC1 */
+       {0, 14, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {0, 15, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {0, 16, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {0, 17, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {0, 18, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {0, 19, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {0, 20, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {0, 21, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {0, 26, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
+       {0, 27, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
+       {0, 28, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
+       {0, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
+       {0, 30, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
+       {0, 31, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
+
+       {2, 22, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2, 23, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+
+       /* FCC2 */
+       {1, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 20, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 21, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 22, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {1, 23, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {1, 24, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {1, 25, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+       {1, 26, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 27, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 28, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
+       {1, 30, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {1, 31, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
+
+       {2, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+       {2, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
+
+       /* MDC */
+       {0, 13, CPM_PIN_OUTPUT | CPM_PIN_GPIO},
+
+#if defined(CONFIG_I2C_CPM)
+       /* I2C */
+       {3, 14, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_OPENDRAIN},
+       {3, 15, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_OPENDRAIN},
+#endif
+
+       /* USB */
+       {0, 10, CPM_PIN_OUTPUT | CPM_PIN_GPIO},    /* FULL_SPEED */
+       {0, 11, CPM_PIN_OUTPUT | CPM_PIN_GPIO},    /*/SLAVE */
+       {2, 10, CPM_PIN_INPUT  | CPM_PIN_PRIMARY}, /* RXN */
+       {2, 11, CPM_PIN_INPUT  | CPM_PIN_PRIMARY}, /* RXP */
+       {2, 20, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, /* /OE */
+       {2, 27, CPM_PIN_INPUT  | CPM_PIN_PRIMARY}, /* RXCLK */
+       {3, 23, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, /* TXP */
+       {3, 24, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, /* TXN */
+       {3, 25, CPM_PIN_INPUT  | CPM_PIN_PRIMARY}, /* RXD */
+};
+
+static void __init init_ioports(void)
+{
+       int i;
+
+       for (i = 0; i < ARRAY_SIZE(km82xx_pins); i++) {
+               const struct cpm_pin *pin = &km82xx_pins[i];
+               cpm2_set_pin(pin->port, pin->pin, pin->flags);
+       }
+
+       cpm2_smc_clk_setup(CPM_CLK_SMC2, CPM_BRG8);
+       cpm2_clk_setup(CPM_CLK_SCC1, CPM_CLK11, CPM_CLK_RX);
+       cpm2_clk_setup(CPM_CLK_SCC1, CPM_CLK11, CPM_CLK_TX);
+       cpm2_clk_setup(CPM_CLK_SCC3, CPM_CLK5, CPM_CLK_RTX);
+       cpm2_clk_setup(CPM_CLK_SCC4, CPM_CLK7, CPM_CLK_RX);
+       cpm2_clk_setup(CPM_CLK_SCC4, CPM_CLK8, CPM_CLK_TX);
+       cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK10, CPM_CLK_RX);
+       cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK9,  CPM_CLK_TX);
+       cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK13, CPM_CLK_RX);
+       cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK14, CPM_CLK_TX);
+
+       /* Force USB FULL SPEED bit to '1' */
+       setbits32(&cpm2_immr->im_ioport.iop_pdata, 1 << (31 - 10));
+       /* clear USB_SLAVE */
+       clrbits32(&cpm2_immr->im_ioport.iop_pdata, 1 << (31 - 11));
+}
+
+static void __init km82xx_setup_arch(void)
+{
+       if (ppc_md.progress)
+               ppc_md.progress("km82xx_setup_arch()", 0);
+
+       cpm2_reset();
+
+       /* When this is set, snooping CPM DMA from RAM causes
+        * machine checks.  See erratum SIU18.
+        */
+       clrbits32(&cpm2_immr->im_siu_conf.siu_82xx.sc_bcr, MPC82XX_BCR_PLDP);
+
+       init_ioports();
+
+       if (ppc_md.progress)
+               ppc_md.progress("km82xx_setup_arch(), finish", 0);
+}
+
+static  __initdata struct of_device_id of_bus_ids[] = {
+       { .compatible = "simple-bus", },
+       {},
+};
+
+static int __init declare_of_platform_devices(void)
+{
+       of_platform_bus_probe(NULL, of_bus_ids, NULL);
+
+       return 0;
+}
+machine_device_initcall(km82xx, declare_of_platform_devices);
+
+/*
+ * Called very early, device-tree isn't unflattened
+ */
+static int __init km82xx_probe(void)
+{
+       unsigned long root = of_get_flat_dt_root();
+       return of_flat_dt_is_compatible(root, "keymile,km82xx");
+}
+
+define_machine(km82xx)
+{
+       .name = "Keymile km82xx",
+       .probe = km82xx_probe,
+       .setup_arch = km82xx_setup_arch,
+       .init_IRQ = km82xx_pic_init,
+       .get_irq = cpm2_get_irq,
+       .calibrate_decr = generic_calibrate_decr,
+       .restart = pq2_restart,
+       .progress = udbg_progress,
+};
diff --git a/arch/powerpc/platforms/82xx/mgcoge.c b/arch/powerpc/platforms/82xx/mgcoge.c
deleted file mode 100644 (file)
index 7a5de9e..0000000
+++ /dev/null
@@ -1,180 +0,0 @@
-/*
- * Keymile mgcoge support
- * Copyright 2008 DENX Software Engineering GmbH
- * Author: Heiko Schocher <hs@denx.de>
- *
- * based on code from:
- * Copyright 2007 Freescale Semiconductor, Inc.
- * Author: Scott Wood <scottwood@freescale.com>
- *
- * This program is free software; you can redistribute  it and/or modify it
- * under  the terms of  the GNU General  Public License as published by the
- * Free Software Foundation;  either version 2 of the  License, or (at your
- * option) any later version.
- */
-
-#include <linux/init.h>
-#include <linux/interrupt.h>
-#include <linux/fsl_devices.h>
-#include <linux/of_platform.h>
-
-#include <asm/io.h>
-#include <asm/cpm2.h>
-#include <asm/udbg.h>
-#include <asm/machdep.h>
-#include <asm/time.h>
-#include <asm/mpc8260.h>
-#include <asm/prom.h>
-
-#include <sysdev/fsl_soc.h>
-#include <sysdev/cpm2_pic.h>
-
-#include "pq2.h"
-
-static void __init mgcoge_pic_init(void)
-{
-       struct device_node *np = of_find_compatible_node(NULL, NULL, "fsl,pq2-pic");
-       if (!np) {
-               printk(KERN_ERR "PIC init: can not find cpm-pic node\n");
-               return;
-       }
-
-       cpm2_pic_init(np);
-       of_node_put(np);
-}
-
-struct cpm_pin {
-       int port, pin, flags;
-};
-
-static __initdata struct cpm_pin mgcoge_pins[] = {
-
-       /* SMC2 */
-       {0, 8, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {0, 9, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-
-       /* SCC4 */
-       {2, 25, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {2, 24, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {2,  9, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {2,  8, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {3, 22, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {3, 21, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-
-       /* FCC1 */
-       {0, 14, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {0, 15, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {0, 16, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {0, 17, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {0, 18, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {0, 19, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {0, 20, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {0, 21, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {0, 26, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
-       {0, 27, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
-       {0, 28, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
-       {0, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
-       {0, 30, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
-       {0, 31, CPM_PIN_INPUT | CPM_PIN_SECONDARY},
-
-       {2, 22, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {2, 23, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-
-       /* FCC2 */
-       {1, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 20, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 21, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 22, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {1, 23, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {1, 24, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {1, 25, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-       {1, 26, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 27, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 28, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY},
-       {1, 30, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {1, 31, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY},
-
-       {2, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-       {2, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY},
-
-       /* MDC */
-       {0, 13, CPM_PIN_OUTPUT | CPM_PIN_GPIO},
-
-#if defined(CONFIG_I2C_CPM)
-       /* I2C */
-       {3, 14, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_OPENDRAIN},
-       {3, 15, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_OPENDRAIN},
-#endif
-};
-
-static void __init init_ioports(void)
-{
-       int i;
-
-       for (i = 0; i < ARRAY_SIZE(mgcoge_pins); i++) {
-               const struct cpm_pin *pin = &mgcoge_pins[i];
-               cpm2_set_pin(pin->port, pin->pin, pin->flags);
-       }
-
-       cpm2_smc_clk_setup(CPM_CLK_SMC2, CPM_BRG8);
-       cpm2_clk_setup(CPM_CLK_SCC4, CPM_CLK7, CPM_CLK_RX);
-       cpm2_clk_setup(CPM_CLK_SCC4, CPM_CLK8, CPM_CLK_TX);
-       cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK10, CPM_CLK_RX);
-       cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK9,  CPM_CLK_TX);
-       cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK13, CPM_CLK_RX);
-       cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK14, CPM_CLK_TX);
-}
-
-static void __init mgcoge_setup_arch(void)
-{
-       if (ppc_md.progress)
-               ppc_md.progress("mgcoge_setup_arch()", 0);
-
-       cpm2_reset();
-
-       /* When this is set, snooping CPM DMA from RAM causes
-        * machine checks.  See erratum SIU18.
-        */
-       clrbits32(&cpm2_immr->im_siu_conf.siu_82xx.sc_bcr, MPC82XX_BCR_PLDP);
-
-       init_ioports();
-
-       if (ppc_md.progress)
-               ppc_md.progress("mgcoge_setup_arch(), finish", 0);
-}
-
-static  __initdata struct of_device_id of_bus_ids[] = {
-       { .compatible = "simple-bus", },
-       {},
-};
-
-static int __init declare_of_platform_devices(void)
-{
-       of_platform_bus_probe(NULL, of_bus_ids, NULL);
-
-       return 0;
-}
-machine_device_initcall(mgcoge, declare_of_platform_devices);
-
-/*
- * Called very early, device-tree isn't unflattened
- */
-static int __init mgcoge_probe(void)
-{
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "keymile,mgcoge");
-}
-
-define_machine(mgcoge)
-{
-       .name = "Keymile MGCOGE",
-       .probe = mgcoge_probe,
-       .setup_arch = mgcoge_setup_arch,
-       .init_IRQ = mgcoge_pic_init,
-       .get_irq = cpm2_get_irq,
-       .calibrate_decr = generic_calibrate_decr,
-       .restart = pq2_restart,
-       .progress = udbg_progress,
-};