Hello Michael, On 9/6/19 3:20 PM, Michael Tretter wrote: > Add a new command "of_overlay" for applying device tree overlays, > because it does not really fit into any other device tree related > command and would create a mess with the command options. > > Signed-off-by: Michael Tretter <m.tretter@xxxxxxxxxxxxxx> > > --- > Changelog: > > v1->v2: none > --- > commands/Kconfig | 12 ++++++ > commands/Makefile | 1 + > commands/of_overlay.c | 89 +++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 102 insertions(+) > create mode 100644 commands/of_overlay.c > > diff --git a/commands/Kconfig b/commands/Kconfig > index 039fd7d1ac..01d82031ad 100644 > --- a/commands/Kconfig > +++ b/commands/Kconfig > @@ -2088,6 +2088,18 @@ config CMD_OF_FIXUP_STATUS > Register a fixup to enable or disable a device tree node. > Nodes are enabled on default. Disabled with -d. > > +config CMD_OF_OVERLAY > + tristate > + select OFTREE This should depend or select OF_OVERLAY, otherwise: ./commands/of_overlay.c:60: undefined reference to `firmware_load_overlay' Cheers Ahmad > + prompt "of_overlay" > + help > + of_overlay - register device tree overlay as fixup > + > + Usage: of_overlay [-S path] FILE > + > + Options: > + -S path load firmware using this search path > + > config CMD_OFTREE > tristate > select OFTREE > diff --git a/commands/Makefile b/commands/Makefile > index e69fb5046f..62ad9ce2b2 100644 > --- a/commands/Makefile > +++ b/commands/Makefile > @@ -78,6 +78,7 @@ obj-$(CONFIG_CMD_OF_NODE) += of_node.o > obj-$(CONFIG_CMD_OF_DUMP) += of_dump.o > obj-$(CONFIG_CMD_OF_DISPLAY_TIMINGS) += of_display_timings.o > obj-$(CONFIG_CMD_OF_FIXUP_STATUS) += of_fixup_status.o > +obj-$(CONFIG_CMD_OF_OVERLAY) += of_overlay.o > obj-$(CONFIG_CMD_MAGICVAR) += magicvar.o > obj-$(CONFIG_CMD_IOMEM) += iomemport.o > obj-$(CONFIG_CMD_LINUX_EXEC) += linux_exec.o > diff --git a/commands/of_overlay.c b/commands/of_overlay.c > new file mode 100644 > index 0000000000..f929443bfe > --- /dev/null > +++ b/commands/of_overlay.c > @@ -0,0 +1,89 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * Copyright (c) 2019 Michael Tretter <m.tretter@xxxxxxxxxxxxxx>, Pengutronix > + * > + * See file CREDITS for list of people who contributed to this > + * project. > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License version 2 > + * as published by the Free Software Foundation. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + */ > + > +#include <command.h> > +#include <common.h> > +#include <environment.h> > +#include <fdt.h> > +#include <firmware.h> > +#include <fs.h> > +#include <getopt.h> > +#include <libfile.h> > +#include <of.h> > + > +static int do_of_overlay(int argc, char *argv[]) > +{ > + int opt, ret; > + struct fdt_header *fdt; > + struct device_node *overlay; > + const char *search_path = NULL; > + > + while ((opt = getopt(argc, argv, "S:")) > 0) { > + switch (opt) { > + case 'S': > + search_path = optarg; > + break; > + default: > + return COMMAND_ERROR_USAGE; > + } > + } > + > + if (argc != optind + 1) > + return COMMAND_ERROR_USAGE; > + > + fdt = read_file(argv[optind], NULL); > + if (!fdt) { > + printf("cannot read %s\n", argv[optind]); > + return 1; > + } > + > + overlay = of_unflatten_dtb(fdt); > + free(fdt); > + if (IS_ERR(overlay)) > + return PTR_ERR(overlay); > + > + if (search_path) { > + ret = firmware_load_overlay(overlay, search_path); > + if (ret) > + goto err; > + } > + > + ret = of_register_overlay(overlay); > + if (ret) { > + printf("cannot apply oftree overlay: %s\n", strerror(-ret)); > + goto err; > + } > + > + return 0; > + > +err: > + of_delete_node(overlay); > + return ret; > +} > + > +BAREBOX_CMD_HELP_START(of_overlay) > +BAREBOX_CMD_HELP_TEXT("Options:") > +BAREBOX_CMD_HELP_OPT("-S path", "load firmware using this search path") > +BAREBOX_CMD_HELP_END > + > +BAREBOX_CMD_START(of_overlay) > + .cmd = do_of_overlay, > + BAREBOX_CMD_DESC("register device tree overlay as fixup") > + BAREBOX_CMD_OPTS("[-S path] FILE") > + BAREBOX_CMD_GROUP(CMD_GRP_MISC) > + BAREBOX_CMD_HELP(cmd_of_overlay_help) > +BAREBOX_CMD_END > -- Pengutronix e.K. | | Industrial Linux Solutions | http://www.pengutronix.de/ | Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 | _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox