dm: core: Add dev_get_addr_ptr() to return a pointer to the reg address
authorStefan Roese <sr@denx.de>
Thu, 21 Apr 2016 05:11:34 +0000 (07:11 +0200)
committerHeiko Schocher <hs@denx.de>
Mon, 25 Apr 2016 05:30:16 +0000 (07:30 +0200)
On some platforms (e.g. x86), the return value of dev_get_addr() can't
be assigned to a pointer type variable directly. As there might be a
difference between the size of fdt_addr_t and the pointer type. On
x86 for example, "fdt_addr_t" is 64bit but "void *" only 32bit. So
assigning the register base directly in dev_get_addr() results in this
compilation warning:
  warning: cast to pointer from integer of different size

This patch introduces the new function dev_get_addr_ptr() that
returns a pointer to the 'reg' address that can be used by drivers
in this case.

Signed-off-by: Stefan Roese <sr@denx.de>
Reviewed-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
drivers/core/device.c
include/dm/device.h

index 269087a084cf6edbf1637de12602b5773c79e394..1322991d6c7b6e0599679518543da7c5cdb7c5ad 100644 (file)
@@ -673,6 +673,11 @@ fdt_addr_t dev_get_addr(struct udevice *dev)
        return dev_get_addr_index(dev, 0);
 }
 
+void *dev_get_addr_ptr(struct udevice *dev)
+{
+       return (void *)(uintptr_t)dev_get_addr_index(dev, 0);
+}
+
 bool device_has_children(struct udevice *dev)
 {
        return !list_empty(&dev->child_head);
index dad7591dfacb10c8231fa7867eaa9df6607ac388..8970fc015c7eb1158644110338d8e6f181181d1d 100644 (file)
@@ -453,6 +453,16 @@ int device_find_next_child(struct udevice **devp);
  */
 fdt_addr_t dev_get_addr(struct udevice *dev);
 
+/**
+ * dev_get_addr_ptr() - Return pointer to the address of the reg property
+ *                      of a device
+ *
+ * @dev: Pointer to a device
+ *
+ * @return Pointer to addr, or NULL if there is no such property
+ */
+void *dev_get_addr_ptr(struct udevice *dev);
+
 /**
  * dev_get_addr_index() - Get the indexed reg property of a device
  *