diff options
author | Heiko Schocher <hs@denx.de> | 2014-06-22 06:33:29 +0200 |
---|---|---|
committer | Tom Rini <trini@ti.com> | 2014-06-23 09:11:30 -0400 |
commit | b047d671dbf60beab9822349f794a0152b97ac31 (patch) | |
tree | 8c4d06f914a0f0c04d287d8e9561b0a76973561f /lib/fdtdec_common.c | |
parent | 39b6d07fd7e692736cdb05a000b1c84ab43de4fb (diff) | |
download | u-boot-imx-b047d671dbf60beab9822349f794a0152b97ac31.zip u-boot-imx-b047d671dbf60beab9822349f794a0152b97ac31.tar.gz u-boot-imx-b047d671dbf60beab9822349f794a0152b97ac31.tar.bz2 |
lib, fdt: move fdtdec_get_int() out of lib/fdtdec.c
move fdtdec_get_int() out of lib/fdtdec.c into lib/fdtdec_common.c
as this function is also used, if CONFIG_OF_CONTROL is not
used. Poped up on the ids8313 board using signed FIT images,
and activating CONFIG_SYS_GENERIC_BOARD. Without this patch
it shows on boot:
No valid FDT found - please append one to U-Boot binary, use u-boot-dtb.bin or define CONFIG_OF_EMBED. For sandbox, use -d <file.dtb>
With this patch, it boots again with CONFIG_SYS_GENERIC_BOARD
enabled.
Signed-off-by: Heiko Schocher <hs@denx.de>
Acked-by: Simon Glass <sjg@chromium.org>
Cc: Tom Rini <trini@ti.com>
Diffstat (limited to 'lib/fdtdec_common.c')
-rw-r--r-- | lib/fdtdec_common.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/lib/fdtdec_common.c b/lib/fdtdec_common.c new file mode 100644 index 0000000..757931a --- /dev/null +++ b/lib/fdtdec_common.c @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2014 + * Heiko Schocher, DENX Software Engineering, hs@denx.de. + * + * Based on lib/fdtdec.c: + * Copyright (c) 2011 The Chromium OS Authors. + * + * SPDX-License-Identifier: GPL-2.0+ + */ + +#ifndef USE_HOSTCC +#include <common.h> +#include <libfdt.h> +#include <fdtdec.h> +#else +#include "libfdt.h" +#include "fdt_support.h" + +#define debug(...) +#endif + +int fdtdec_get_int(const void *blob, int node, const char *prop_name, + int default_val) +{ + const int *cell; + int len; + + debug("%s: %s: ", __func__, prop_name); + cell = fdt_getprop(blob, node, prop_name, &len); + if (cell && len >= sizeof(int)) { + int val = fdt32_to_cpu(cell[0]); + + debug("%#x (%d)\n", val, val); + return val; + } + debug("(not found)\n"); + return default_val; +} |