[PATCH v3 1/2] dm: core: ofnode: Add ofnode_read_bootscript_address()
Simon Glass
sjg at chromium.org
Mon Jul 31 19:08:07 CEST 2023
On Mon, 31 Jul 2023 at 05:33, Michal Simek <michal.simek at amd.com> wrote:
>
> ofnode_read_bootscript_address() reads bootscript address from
> /options/u-boot DT node. bootscr-address or bootscr-ram-offset properties
> are read and values are filled. bootscr-address has higher priority than
> bootscr-ram-offset and the only one should be described in DT.
>
> Also add test to cover this new function.
>
> Signed-off-by: Michal Simek <michal.simek at amd.com>
>
> ---
>
> Changes in v3:
> - new patch in this series
>
> arch/sandbox/dts/test.dts | 7 +++++++
> drivers/core/ofnode.c | 25 +++++++++++++++++++++++++
> include/dm/ofnode.h | 25 +++++++++++++++++++++++++
> test/dm/ofnode.c | 14 ++++++++++++++
> 4 files changed, 71 insertions(+)
Reviewed-by: Simon Glass <sjg at chromium.org>
nits below
>
> diff --git a/arch/sandbox/dts/test.dts b/arch/sandbox/dts/test.dts
> index b5509eee8cfe..94b00b80429b 100644
> --- a/arch/sandbox/dts/test.dts
> +++ b/arch/sandbox/dts/test.dts
> @@ -79,6 +79,13 @@
> };
> };
>
> + options {
> + u-boot {
> + compatible = "u-boot,config";
> + bootscr-ram-offset = /bits/ 64 <0x12345678>;
> + };
> + };
> +
> bootstd {
> bootph-verify;
> compatible = "u-boot,boot-std";
> diff --git a/drivers/core/ofnode.c b/drivers/core/ofnode.c
> index 8df16e56af5c..d94f0300c30a 100644
> --- a/drivers/core/ofnode.c
> +++ b/drivers/core/ofnode.c
> @@ -1563,6 +1563,31 @@ const char *ofnode_conf_read_str(const char *prop_name)
> return ofnode_read_string(node, prop_name);
> }
>
> +int ofnode_read_bootscript_address(u64 *bootscr_address, u64 *bootscr_offset)
> +{
> + int ret;
> + ofnode uboot;
> +
> + *bootscr_address = 0;
> + *bootscr_offset = 0;
> +
> + uboot = ofnode_path("/options/u-boot");
> + if (!ofnode_valid(uboot)) {
> + printf("%s: Missing /u-boot node\n", __func__);
> + return -EINVAL;
> + }
> +
> + ret = ofnode_read_u64(uboot, "bootscr-address", bootscr_address);
> + if (ret) {
> + ret = ofnode_read_u64(uboot, "bootscr-ram-offset",
> + bootscr_offset);
> + if (ret)
> + return -EINVAL;
> + }
> +
> + return 0;
> +}
> +
> ofnode ofnode_get_phy_node(ofnode node)
> {
> /* DT node properties that reference a PHY node */
> diff --git a/include/dm/ofnode.h b/include/dm/ofnode.h
> index 0f38b3e736de..a297236112ed 100644
> --- a/include/dm/ofnode.h
> +++ b/include/dm/ofnode.h
> @@ -1500,6 +1500,26 @@ int ofnode_conf_read_int(const char *prop_name, int default_val);
> */
> const char *ofnode_conf_read_str(const char *prop_name);
>
> +/**
> + * ofnode_read_bootscript_address() - Read bootscr-address or bootscr-ram-offset
> + *
> + * @bootscr_address: pointer to 64bit address where bootscr-address property value
> + * is stored
> + * @bootscr_offset: pointer to 64bit offset address where bootscr-ram-offset
> + * property value is stored
> + *
> + * This reads a bootscr-address or bootscr-ram-offset property from
> + * the /options/u-boot/ node of the devicetree. bootscr-address holds the full
> + * address of the boot script file. bootscr-ram-offset holds the boot script
> + * file offset from the start of the ram base address. When bootscr-address is
> + * defined, bootscr-ram-offset property is ignored.
> + *
> + * This only works with the control FDT.
> + *
> + * Return: 0 if OK, -EINVAL if property is not found.
> + */
> +int ofnode_read_bootscript_address(u64 *bootscr_address, u64 *bootscr_offset);
> +
> #else /* CONFIG_DM */
> static inline bool ofnode_conf_read_bool(const char *prop_name)
> {
> @@ -1516,6 +1536,11 @@ static inline const char *ofnode_conf_read_str(const char *prop_name)
> return NULL;
> }
>
> +int ofnode_read_bootscript_address(u64 *bootscr_address, u64 *bootscr_offset)
> +{
> + return -EINVAL;
> +}
> +
> #endif /* CONFIG_DM */
>
> /**
> diff --git a/test/dm/ofnode.c b/test/dm/ofnode.c
> index 6fbebc7da085..0aef68465ec7 100644
> --- a/test/dm/ofnode.c
> +++ b/test/dm/ofnode.c
> @@ -583,6 +583,20 @@ static int dm_test_ofnode_conf(struct unit_test_state *uts)
> }
> DM_TEST(dm_test_ofnode_conf, 0);
>
> +static int dm_test_ofnode_options(struct unit_test_state *uts)
> +{
> + u64 bootscr_address;
> + u64 bootscr_offset;
> +
> + ut_assert(!ofnode_read_bootscript_address(&bootscr_address,
> + &bootscr_offset));
ut_assertok(ofnode...)
> + ut_assert(bootscr_address == 0);
ut_asserteq_64(0, bootscr_address);
> + ut_assert(bootscr_offset == 0x12345678);
ut_asserteq_64(0x12345678, bootscr_address);
> +
> + return 0;
> +}
> +DM_TEST(dm_test_ofnode_options, 0);
> +
> static int dm_test_ofnode_for_each_compatible_node(struct unit_test_state *uts)
> {
> const char compatible[] = "denx,u-boot-fdt-test";
> --
> 2.36.1
>
Regards,
Simon
More information about the U-Boot
mailing list