mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-02-17 22:49:02 +00:00
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>
This commit is contained in:
parent
39b6d07fd7
commit
b047d671db
4 changed files with 41 additions and 36 deletions
|
@ -23,6 +23,8 @@ obj-$(CONFIG_USB_TTY) += circbuf.o
|
|||
obj-y += crc7.o
|
||||
obj-y += crc8.o
|
||||
obj-y += crc16.o
|
||||
obj-$(CONFIG_FIT) += fdtdec_common.o
|
||||
obj-$(CONFIG_OF_CONTROL) += fdtdec_common.o
|
||||
obj-$(CONFIG_OF_CONTROL) += fdtdec.o
|
||||
obj-$(CONFIG_TEST_FDTDEC) += fdtdec_test.o
|
||||
obj-$(CONFIG_GZIP) += gunzip.o
|
||||
|
|
36
lib/fdtdec.c
36
lib/fdtdec.c
|
@ -111,24 +111,6 @@ fdt_addr_t fdtdec_get_addr(const void *blob, int node,
|
|||
return fdtdec_get_addr_size(blob, node, prop_name, NULL);
|
||||
}
|
||||
|
||||
s32 fdtdec_get_int(const void *blob, int node, const char *prop_name,
|
||||
s32 default_val)
|
||||
{
|
||||
const s32 *cell;
|
||||
int len;
|
||||
|
||||
debug("%s: %s: ", __func__, prop_name);
|
||||
cell = fdt_getprop(blob, node, prop_name, &len);
|
||||
if (cell && len >= sizeof(s32)) {
|
||||
s32 val = fdt32_to_cpu(cell[0]);
|
||||
|
||||
debug("%#x (%d)\n", val, val);
|
||||
return val;
|
||||
}
|
||||
debug("(not found)\n");
|
||||
return default_val;
|
||||
}
|
||||
|
||||
uint64_t fdtdec_get_uint64(const void *blob, int node, const char *prop_name,
|
||||
uint64_t default_val)
|
||||
{
|
||||
|
@ -648,22 +630,4 @@ int fdtdec_read_fmap_entry(const void *blob, int node, const char *name,
|
|||
|
||||
return 0;
|
||||
}
|
||||
#else
|
||||
#include "libfdt.h"
|
||||
#include "fdt_support.h"
|
||||
|
||||
int fdtdec_get_int(const void *blob, int node, const char *prop_name,
|
||||
int default_val)
|
||||
{
|
||||
const int *cell;
|
||||
int len;
|
||||
|
||||
cell = fdt_getprop_w((void *)blob, node, prop_name, &len);
|
||||
if (cell && len >= sizeof(int)) {
|
||||
int val = fdt32_to_cpu(cell[0]);
|
||||
|
||||
return val;
|
||||
}
|
||||
return default_val;
|
||||
}
|
||||
#endif
|
||||
|
|
38
lib/fdtdec_common.c
Normal file
38
lib/fdtdec_common.c
Normal file
|
@ -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;
|
||||
}
|
|
@ -69,6 +69,7 @@ dumpimage-mkimage-objs := aisimage.o \
|
|||
common/bootm.o \
|
||||
lib/crc32.o \
|
||||
default_image.o \
|
||||
lib/fdtdec_common.o \
|
||||
lib/fdtdec.o \
|
||||
fit_common.o \
|
||||
fit_image.o \
|
||||
|
|
Loading…
Add table
Reference in a new issue