From: John Jacques <john.jacq...@lsi.com>

In some cases, the differences between simulation, emulation,
and hardware are important. This patch updates the device trees
to indicate the correct name and the arch/arm/mach-axxia code
to use it.

Signed-off-by: John Jacques <john.jacq...@lsi.com>
---
 arch/arm/boot/dts/axm55xxemu.dts    |   25 +---
 arch/arm/boot/dts/axm55xxemu7.dts   |  217 +++++++++++++++++++++++++++++++++++
 arch/arm/boot/dts/axm55xxsim.dts    |    2 +-
 arch/arm/boot/dts/axm55xxsim16.dts  |    2 +-
 arch/arm/mach-axxia/axxia.c         |    3 +-
 arch/arm/mach-axxia/ddr_retention.c |   33 ++++--
 6 files changed, 247 insertions(+), 35 deletions(-)
 create mode 100644 arch/arm/boot/dts/axm55xxemu7.dts

diff --git a/arch/arm/boot/dts/axm55xxemu.dts b/arch/arm/boot/dts/axm55xxemu.dts
index 1b22b33..93222c1 100644
--- a/arch/arm/boot/dts/axm55xxemu.dts
+++ b/arch/arm/boot/dts/axm55xxemu.dts
@@ -24,7 +24,7 @@
 
 / {
        model = "AXM5516";
-       compatible = "arm", "lsi,axm5516";
+       compatible = "arm", "lsi,axm5516-emu";
        interrupt-parent = <&gic>;
        #address-cells = <2>;
        #size-cells = <2>;
@@ -68,29 +68,6 @@
                        reg = <3>;
                         cpu-release-addr = <0>; // Fixed by the boot loader
                };
-
-               /*
-               cpu@4 {
-                       device_type = "cpu";
-                       compatible = "arm,cortex-a15";
-                       reg = <4>;
-                        cpu-release-addr = <0>; // Fixed by the boot loader
-               };
-
-               cpu@5 {
-                       device_type = "cpu";
-                       compatible = "arm,cortex-a15";
-                       reg = <5>;
-                        cpu-release-addr = <0>; // Fixed by the boot loader
-               };
-
-               cpu@6 {
-                       device_type = "cpu";
-                       compatible = "arm,cortex-a15";
-                       reg = <6>;
-                        cpu-release-addr = <0>; // Fixed by the boot loader
-               };
-               */
        };
 
        clocks {
diff --git a/arch/arm/boot/dts/axm55xxemu7.dts 
b/arch/arm/boot/dts/axm55xxemu7.dts
new file mode 100644
index 0000000..6da4393
--- /dev/null
+++ b/arch/arm/boot/dts/axm55xxemu7.dts
@@ -0,0 +1,217 @@
+/*
+ * arch/arm/boot/dts/axm55xxemu7.dts
+ *
+ * Copyright (C) 2012 LSI
+ *
+ * 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.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+/dts-v1/;
+
+/memreserve/ 0x00000000 0x00400000;
+
+/ {
+       model = "AXM5516";
+       compatible = "arm", "lsi,axm5516-emu";
+       interrupt-parent = <&gic>;
+       #address-cells = <2>;
+       #size-cells = <2>;
+
+       chosen { };
+
+       aliases {
+               serial0   = &axxia_serial0;
+               timer     = &axxia_timers;
+               ethernet0 = &axxia_femac0;
+       };
+
+       cpus {
+               #address-cells = <1>;
+               #size-cells = <0>;
+
+               cpu@0 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <0>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@1 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <1>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@2 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <2>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@3 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <3>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@4 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <4>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@5 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <5>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+
+               cpu@6 {
+                       device_type = "cpu";
+                       compatible = "arm,cortex-a15";
+                       reg = <6>;
+                        cpu-release-addr = <0>; // Fixed by the boot loader
+               };
+       };
+
+       clocks {
+               #address-cells = <1>;
+               #size-cells = <0>;
+
+               cpu {
+                       frequency = <0>; /* Filled in by the boot loader. */
+               };
+
+               peripheral {
+                       frequency = <0>; /* Filled in by the boot loader. */
+               };
+
+               emmc {
+                       frequency = <0>; /* Filled in by the boot loader. */
+               };
+       };
+
+       memory@00000000 {
+               device_type = "memory";
+               reg = <0 0x00000000 0 0x10000000>;
+       };
+
+       gic: interrupt-controller@2001001000 {
+               compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic";
+               #interrupt-cells = <3>;
+               #address-cells = <0>;
+               interrupt-controller;
+               reg = <0x20 0x01001000 0 0x1000>,  /* gic dist base */
+                     <0x20 0x01002000 0 0x100>,   /* gic cpu base */
+                     <0x20 0x10030000 0 0x100>,   /* axm IPI mask reg base */
+                     <0x20 0x10040000 0 0x20000>; /* axm IPI send reg base */
+       };
+
+       timer {
+               compatible = "arm,armv7-timer";
+               interrupts = <1 13 0xf08>,
+                            <1 14 0xf08>;
+       };
+
+
+       gpdma@2020140000 {
+               compatible = "lsi,dma32";
+               reg = <0x20 0x20140000 0x00 0x1000>;
+               interrupts = <0 60 4>, /* busy */
+                            <0 61 4>; /* error */
+
+               channel0 {
+                       interrupts = <0 62 4>;
+               };
+
+               channel1 {
+                       interrupts = <0 63 4>;
+               };
+       };
+
+       gpdma@2020141000 {
+               status = "disabled";
+               compatible = "lsi,dma32";
+               reg = <0x20 0x20141000 0x00 0x1000>;
+               interrupts = <0 64 4>, /* busy */
+                            <0 65 4>; /* error */
+
+               channel0 {
+                       interrupts = <0 66 4>;
+               };
+
+               channel1 {
+                       interrupts = <0 67 4>;
+               };
+       };
+
+       gpreg@2010094000  {
+               compatible = "lsi,gpreg";
+               reg = <0x20 0x10094000 0 0x1000>;
+       };
+
+        axxia_femac0: femac@0x2010120000 {
+                compatible = "lsi,acp-femac";
+               device_type = "network";
+               reg = <0x20 0x10120000 0 0x1000>,
+                     <0x20 0x10121000 0 0x1000>,
+                     <0x20 0x10122000 0 0x1000>;
+               interrupts = <0 2 4>,
+                            <0 3 4>,
+                            <0 4 4>;
+               mdio-reg = <0x20 0x10090000 0 0x1000>;
+               mdio-clock = <0>;
+               phy-address = <0x3>;
+               ad-value = <0x61>;
+               mac-address = [00 00 00 00 00 00];
+       };
+
+        amba {
+               compatible = "arm,amba-bus";
+               #address-cells = <2>;
+               #size-cells = <2>;
+               ranges;
+
+               axxia_serial0: uart@2010080000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x20 0x10080000 0x00 0x1000>;
+                       interrupts = <0 56 4>;
+               };
+
+               axxia_timers: timer@2010091000 {
+                       compatible = "arm,sp804", "arm,primecell";
+                       reg = <0x20 0x10091000 0 0x1000>;
+                       interrupts = <0 46 4>,
+                                    <0 47 4>,
+                                    <0 48 4>,
+                                    <0 49 4>,
+                                    <0 50 4>,
+                                    <0 51 4>,
+                                    <0 52 4>,
+                                    <0 53 4>;
+               };
+       };
+};
+
+/*
+  Local Variables:
+  mode: C
+  End:
+*/
diff --git a/arch/arm/boot/dts/axm55xxsim.dts b/arch/arm/boot/dts/axm55xxsim.dts
index 5620dcb..b20b09a 100644
--- a/arch/arm/boot/dts/axm55xxsim.dts
+++ b/arch/arm/boot/dts/axm55xxsim.dts
@@ -1,5 +1,5 @@
 /*
- * arch/arm/boot/dts/axm-sim.dts
+ * arch/arm/boot/dts/axm55xxsim.dts
  *
  * Copyright (C) 2012 LSI
  *
diff --git a/arch/arm/boot/dts/axm55xxsim16.dts 
b/arch/arm/boot/dts/axm55xxsim16.dts
index 0b6277a..0ce2ff4 100644
--- a/arch/arm/boot/dts/axm55xxsim16.dts
+++ b/arch/arm/boot/dts/axm55xxsim16.dts
@@ -1,5 +1,5 @@
 /*
- * arch/arm/boot/dts/axm-sim.dts
+ * arch/arm/boot/dts/axm55xxsim16.dts
  *
  * Copyright (C) 2012 LSI
  *
diff --git a/arch/arm/mach-axxia/axxia.c b/arch/arm/mach-axxia/axxia.c
index 526ec98..af85305 100644
--- a/arch/arm/mach-axxia/axxia.c
+++ b/arch/arm/mach-axxia/axxia.c
@@ -58,8 +58,9 @@
 extern void axxia_ddr_retention_init(void);
 
 static const char *axxia_dt_match[] __initconst = {
-       "lsi,axm5516",
        "lsi,axm5516-sim",
+       "lsi,axm5516-emu",
+       "lsi,axm5516",
        NULL
 };
 
diff --git a/arch/arm/mach-axxia/ddr_retention.c 
b/arch/arm/mach-axxia/ddr_retention.c
index a17f970..7e4687d 100644
--- a/arch/arm/mach-axxia/ddr_retention.c
+++ b/arch/arm/mach-axxia/ddr_retention.c
@@ -34,6 +34,7 @@
 static void __iomem *nca;
 static void __iomem *apb;
 static void __iomem *dickens;
+static int ddr_retention_enabled;
 
 unsigned long ncp_caal_regions_acp55xx[] = {
        NCP_REGION_ID(0x0b, 0x05),      /* SPPV2   */
@@ -253,6 +254,11 @@ initiate_retention_reset(void)
        unsigned long value;
        unsigned long delay;
 
+       if (0 == ddr_retention_enabled) {
+               pr_info("DDR Retention Reset is Not Enabled\n");
+               return;
+       }
+
        if (NULL == nca || NULL == apb || NULL == dickens)
                BUG();
 
@@ -330,15 +336,26 @@ static const struct file_operations proc_ops = {
 void
 axxia_ddr_retention_init(void)
 {
-       if (!of_find_compatible_node(NULL, NULL, "lsi,axm5516"))
-               return;
+       /*
+         Only available on ASIC systems.
+       */
 
-       if (!proc_create(PROC_PATH, S_IWUSR, NULL, &proc_ops)) {
-               pr_err("Failed to register DDR retention proc interface\n");
-               return;
+       if (of_find_compatible_node(NULL, NULL, "lsi,axm5516")) {
+               /* Create /proc entry. */
+               if (!proc_create("driver/axxia_ddr_retention_reset",
+                                S_IWUSR, NULL,
+                                &proc_ops)) {
+                       pr_info("Failed to register DDR retention proc 
entry\n");
+               } else {
+                       apb = ioremap(0x2010000000, 0x40000);
+                       nca = ioremap(0x002020100000ULL, 0x20000);
+                       dickens = ioremap(0x2000000000, 0x1000000);
+                       ddr_retention_enabled = 1;
+                       pr_info("DDR Retention Reset Initialized\n");
+               }
+       } else {
+               pr_info("DDR Retention Reset is Not Available\n");
        }
 
-       apb = ioremap(0x2010000000, 0x40000);
-       nca = ioremap(0x002020100000ULL, 0x20000);
-       dickens = ioremap(0x2000000000, 0x1000000);
+       return;
 }
-- 
1.7.9.5

-- 
_______________________________________________
linux-yocto mailing list
linux-yocto@yoctoproject.org
https://lists.yoctoproject.org/listinfo/linux-yocto

Reply via email to