Files
u-boot/boot/extension-uclass.c
Kory Maincent (TI.com) 2d12958ee7 boot: Remove legacy extension board support
Remove the legacy extension board implementation now that all boards
have been converted to use the new UCLASS-based framework. This
eliminates lines of legacy code while preserving functionality
through the modern driver model approach.

Update the bootstd tests, due to the removal of extension hunter.

Signed-off-by: Kory Maincent (TI.com) <kory.maincent@bootlin.com>
2025-11-03 10:02:39 -06:00

152 lines
3.1 KiB
C

// SPDX-License-Identifier: GPL-2.0+
/*
* (C) Copyright 2025 Köry Maincent <kory.maincent@bootlin.com>
*/
#include <alist.h>
#include <command.h>
#include <env.h>
#include <extension_board.h>
#include <fdt_support.h>
#include <malloc.h>
#include <mapmem.h>
#include <dm/device-internal.h>
#include <dm/lists.h>
#include <dm/uclass.h>
struct alist *extension_get_list(void)
{
struct udevice *dev;
if (uclass_first_device_err(UCLASS_EXTENSION, &dev))
return NULL;
return dev_get_priv(dev);
}
int extension_probe(struct udevice *dev)
{
struct alist *extension_list = dev_get_priv(dev);
alist_init_struct(extension_list, struct extension);
return 0;
}
int extension_remove(struct udevice *dev)
{
struct alist *extension_list = dev_get_priv(dev);
alist_uninit(extension_list);
return 0;
}
int extension_scan(void)
{
struct alist *extension_list = extension_get_list();
const struct extension_ops *ops;
struct udevice *dev;
int ret;
ret = uclass_first_device_err(UCLASS_EXTENSION, &dev);
if (ret)
return ret;
if (!extension_list)
return -ENODEV;
ops = extension_get_ops(dev);
alist_empty(extension_list);
return ops->scan(dev, extension_list);
}
static int _extension_apply(const struct extension *extension)
{
ulong extrasize, overlay_addr;
struct fdt_header *blob;
char *overlay_cmd;
int ret;
if (!working_fdt) {
printf("No FDT memory address configured. Please configure\n"
"the FDT address via \"fdt addr <address>\" command.\n");
return -EINVAL;
}
overlay_cmd = env_get("extension_overlay_cmd");
if (!overlay_cmd) {
printf("Environment extension_overlay_cmd is missing\n");
return -EINVAL;
}
overlay_addr = env_get_hex("extension_overlay_addr", 0);
if (!overlay_addr) {
printf("Environment extension_overlay_addr is missing\n");
return -EINVAL;
}
env_set("extension_overlay_name", extension->overlay);
ret = run_command(overlay_cmd, 0);
if (ret)
return ret;
extrasize = env_get_hex("filesize", 0);
if (!extrasize)
return -EINVAL;
fdt_shrink_to_minimum(working_fdt, extrasize);
blob = map_sysmem(overlay_addr, 0);
if (!fdt_valid(&blob)) {
printf("Invalid overlay devicetree %s\n", extension->overlay);
return -EINVAL;
}
/* Apply method prints messages on error */
ret = fdt_overlay_apply_verbose(working_fdt, blob);
if (ret)
printf("Failed to apply overlay %s\n", extension->overlay);
return ret;
}
int extension_apply(int extension_num)
{
struct alist *extension_list = extension_get_list();
const struct extension *extension;
if (!extension_list)
return -ENOENT;
extension = alist_get(extension_list, extension_num,
struct extension);
if (!extension) {
printf("Wrong extension number\n");
return -EINVAL;
}
return _extension_apply(extension);
}
int extension_apply_all(void)
{
struct alist *extension_list = extension_get_list();
const struct extension *extension;
int ret;
if (!extension_list)
return -ENOENT;
alist_for_each(extension, extension_list) {
ret = _extension_apply(extension);
if (ret)
return ret;
}
return 0;
}
UCLASS_DRIVER(extension) = {
.name = "extension",
.id = UCLASS_EXTENSION,
};