This patch makes 'cpm_uart_of_init' be able to parses SMC serial device node in 
DTS

Signed-off-by: Mark Zhan <[EMAIL PROTECTED]>
---
  arch/powerpc/sysdev/fsl_soc.c |   37 ++++++++++++++++++++-----------------
  1 file changed, 20 insertions(+), 17 deletions(-)

Index: linux-powerpc-2.6.x/arch/powerpc/sysdev/fsl_soc.c
===================================================================
--- linux-powerpc-2.6.x.orig/arch/powerpc/sysdev/fsl_soc.c      2007-07-16 
15:52:17.000000000 +0800
+++ linux-powerpc-2.6.x/arch/powerpc/sysdev/fsl_soc.c   2007-07-16 
16:59:31.000000000 +0800
@@ -757,8 +757,8 @@

  arch_initcall(fs_enet_of_init);

-static const char scc_regs[] = "regs";
-static const char scc_pram[] = "pram";
+static const char cpm_uart_regs[] = "regs";
+static const char cpm_uart_pram[] = "pram";

  static int __init cpm_uart_of_init(void)
  {
@@ -775,6 +775,7 @@
                const int *id;
                const char *model;

+               cpm_uart_dev = NULL;
                memset(r, 0, sizeof(r));
                memset(&cpm_uart_data, 0, sizeof(cpm_uart_data));

@@ -782,31 +783,35 @@
                if (ret)
                        goto err;

-               r[0].name = scc_regs;
+               r[0].name = cpm_uart_regs;

                ret = of_address_to_resource(np, 1, &r[1]);
                if (ret)
                        goto err;
-               r[1].name = scc_pram;
+               r[1].name = cpm_uart_pram;

                of_irq_to_resource(np, 0, &r[2]);

-               cpm_uart_dev =
-                   platform_device_register_simple("fsl-cpm-scc:uart", i, 
&r[0], 3);
-
-               if (IS_ERR(cpm_uart_dev)) {
-                       ret = PTR_ERR(cpm_uart_dev);
-                       goto err;
-               }
-
                id = of_get_property(np, "device-id", NULL);
                cpm_uart_data.fs_no = *id;

                model = of_get_property(np, "model", NULL);
                strcpy(cpm_uart_data.fs_type, model);

-               cpm_uart_data.uart_clk = ppc_proc_freq;
+               if (strstr(model, "SMC")) {
+                       cpm_uart_dev = 
platform_device_register_simple("fsl-cpm-smc:uart",
+                                                       i, &r[0], 3);
+               } else if (strstr(model, "SCC")) {
+                       cpm_uart_dev = 
platform_device_register_simple("fsl-cpm-scc:uart",
+                                                       i, &r[0], 3);
+               }

+               if (IS_ERR(cpm_uart_dev)) {
+                       ret = PTR_ERR(cpm_uart_dev);
+                       goto err;
+               }
+
+               cpm_uart_data.uart_clk = ppc_proc_freq;
                cpm_uart_data.tx_num_fifo = 4;
                cpm_uart_data.tx_buf_size = 32;
                cpm_uart_data.rx_num_fifo = 4;
@@ -816,10 +821,8 @@
                cpm_uart_data.clk_tx = *((u32 *)of_get_property(np,
                                                "tx-clock", NULL));

-               ret =
-                   platform_device_add_data(cpm_uart_dev, &cpm_uart_data,
-                                            sizeof(struct
-                                                   fs_uart_platform_info));
+               ret = platform_device_add_data(cpm_uart_dev, &cpm_uart_data,
+                                       sizeof(struct fs_uart_platform_info));
                if (ret)
                        goto unreg;
        }
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to