// SPDX-License-Identifier: GPL-2.0+ /* * Bootmethod for sandbox testing * * Copyright 2021 Google LLC * Written by Simon Glass */ #define LOG_CATEGORY UCLASS_BOOTSTD #include #include #include #include #include static int sandbox_check(struct udevice *dev, struct bootflow_iter *iter) { return 0; } static int sandbox_read_bootflow(struct udevice *dev, struct bootflow *bflow) { /* pretend we are ready */ bflow->state = BOOTFLOWST_READY; return 0; } static int sandbox_read_file(struct udevice *dev, struct bootflow *bflow, const char *file_path, ulong addr, ulong *sizep) { return -ENOSYS; } static int sandbox_boot(struct udevice *dev, struct bootflow *bflow) { /* always fail: see bootflow_iter_disable() */ return -ENOTSUPP; } static int sandbox_bootmeth_bind(struct udevice *dev) { struct bootmeth_uc_plat *plat = dev_get_uclass_plat(dev); plat->desc = "Sandbox boot for testing"; return 0; } static struct bootmeth_ops sandbox_bootmeth_ops = { .check = sandbox_check, .read_bootflow = sandbox_read_bootflow, .read_file = sandbox_read_file, .boot = sandbox_boot, }; static const struct udevice_id sandbox_bootmeth_ids[] = { { .compatible = "u-boot,sandbox-extlinux" }, { } }; U_BOOT_DRIVER(bootmeth_sandbox) = { .name = "bootmeth_sandbox", .id = UCLASS_BOOTMETH, .of_match = sandbox_bootmeth_ids, .ops = &sandbox_bootmeth_ops, .bind = sandbox_bootmeth_bind, };