Merge git://git.denx.de/u-boot-dm
[platform/kernel/u-boot.git] / drivers / core / util.c
index e01dd06..2e232d5 100644 (file)
@@ -5,8 +5,11 @@
  */
 
 #include <common.h>
+#include <dm/util.h>
+#include <libfdt.h>
 #include <vsprintf.h>
 
+#ifdef CONFIG_DM_WARN
 void dm_warn(const char *fmt, ...)
 {
        va_list args;
@@ -15,7 +18,9 @@ void dm_warn(const char *fmt, ...)
        vprintf(fmt, args);
        va_end(args);
 }
+#endif
 
+#ifdef DEBUG
 void dm_dbg(const char *fmt, ...)
 {
        va_list args;
@@ -24,6 +29,7 @@ void dm_dbg(const char *fmt, ...)
        vprintf(fmt, args);
        va_end(args);
 }
+#endif
 
 int list_count_items(struct list_head *head)
 {
@@ -35,3 +41,27 @@ int list_count_items(struct list_head *head)
 
        return count;
 }
+
+bool dm_fdt_pre_reloc(const void *blob, int offset)
+{
+       if (fdt_getprop(blob, offset, "u-boot,dm-pre-reloc", NULL))
+               return true;
+
+#ifdef CONFIG_TPL_BUILD
+       if (fdt_getprop(blob, offset, "u-boot,dm-tpl", NULL))
+               return true;
+#elif defined(CONFIG_SPL_BUILD)
+       if (fdt_getprop(blob, offset, "u-boot,dm-spl", NULL))
+               return true;
+#else
+       /*
+        * In regular builds individual spl and tpl handling both
+        * count as handled pre-relocation for later second init.
+        */
+       if (fdt_getprop(blob, offset, "u-boot,dm-spl", NULL) ||
+           fdt_getprop(blob, offset, "u-boot,dm-tpl", NULL))
+               return true;
+#endif
+
+       return false;
+}