qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [RFC PATCH V1 10/14] xilinx_ethlite: Added fdt generic plat


From: Peter A. G. Crosthwaite
Subject: [Qemu-devel] [RFC PATCH V1 10/14] xilinx_ethlite: Added fdt generic platform support
Date: Thu, 25 Aug 2011 16:41:16 +1000

Signed-off-by: Peter A. G. Crosthwaite <address@hidden>
---
 hw/xilinx_ethlite.c |   39 ++++++++++++++++++++++++++++++++++++++-
 1 files changed, 38 insertions(+), 1 deletions(-)

diff --git a/hw/xilinx_ethlite.c b/hw/xilinx_ethlite.c
index f35ba84..c06b015 100644
--- a/hw/xilinx_ethlite.c
+++ b/hw/xilinx_ethlite.c
@@ -221,9 +221,11 @@ static int xilinx_ethlite_init(SysBusDevice *dev)
     return 0;
 }
 
+#define QDEV_NAME "xilinx,ethlite"
+
 static SysBusDeviceInfo xilinx_ethlite_info = {
     .init = xilinx_ethlite_init,
-    .qdev.name  = "xilinx,ethlite",
+    .qdev.name  = QDEV_NAME,
     .qdev.size  = sizeof(struct xlx_ethlite),
     .qdev.props = (Property[]) {
         DEFINE_PROP_UINT32("txpingpong", struct xlx_ethlite, c_tx_pingpong, 1),
@@ -239,3 +241,38 @@ static void xilinx_ethlite_register(void)
 }
 
 device_init(xilinx_ethlite_register)
+
+#ifdef CONFIG_FDT
+
+#include "fdt_generic_qdev.h"
+
+static FDTQDevPropMapping *
+xilinx_ethlite_fdt_qdev_map(char *node_path, FDTMachineInfo *fdti)
+{
+    FDTQDevPropMapping *ret = g_malloc0(sizeof(*ret) * 3);
+    struct FDTQDevPropMapping sprops [] = {
+        {
+            .name = "txpingpong",
+            .src.u32 = qemu_devtree_getprop(fdti->fdt, NULL, node_path,
+                                        "xlnx,tx-ping-pong", 0, 0)
+        },{
+            .name = "rxpingpong",
+            .src.u32 = qemu_devtree_getprop(fdti->fdt, NULL, node_path,
+                                        "xlnx,rx-ping-pong", 0, 0)
+        },{
+           .name = NULL
+        }
+    };
+    return memcpy(ret, sprops, sizeof(*ret) * 3);
+}
+
+FDTQDevOps xilinx_ethlite_fdt_qdev_ops = {
+    .dev_name = QDEV_NAME,
+    .is_nic = 1,
+    .map = xilinx_ethlite_fdt_qdev_map,
+};
+
+fdt_qdev_register_compatibility(&xilinx_ethlite_fdt_qdev_ops,
+    "xlnx,xps-ethernetlite-1.00.a");
+
+#endif /*CONFIG_FDT */
-- 
1.7.3.2




reply via email to

[Prev in Thread] Current Thread [Next in Thread]