Julius Werner has submitted this change. ( https://review.coreboot.org/c/coreboot/+/59492 )
Change subject: libpayload: Add boot_device_read() function ......................................................................
libpayload: Add boot_device_read() function
This patch adds a new way of implementing flash access for libpayload. Until now all reads had to be performed using cbfs_media, which is obsolete. From now on all reads should be performed using boot_device_read().
This patch also provides a default implementation of boot_device_read() for x86 architecture.
Change-Id: I1babd2a8414ed9de3ca49903fcb4f036997b5ff3 Signed-off-by: Jakub Czapiga jacz@semihalf.com Reviewed-on: https://review.coreboot.org/c/coreboot/+/59492 Tested-by: build bot (Jenkins) no-reply@coreboot.org Reviewed-by: Julius Werner jwerner@chromium.org --- A payloads/libpayload/arch/x86/boot_media.c A payloads/libpayload/include/boot_device.h 2 files changed, 39 insertions(+), 0 deletions(-)
Approvals: build bot (Jenkins): Verified Julius Werner: Looks good to me, approved
diff --git a/payloads/libpayload/arch/x86/boot_media.c b/payloads/libpayload/arch/x86/boot_media.c new file mode 100644 index 0000000..ce02832 --- /dev/null +++ b/payloads/libpayload/arch/x86/boot_media.c @@ -0,0 +1,17 @@ +/* SPDX-License-Identifier: BSD-3-Clause */ + +#include <boot_device.h> +#include <commonlib/bsd/cb_err.h> +#include <stddef.h> +#include <string.h> +#include <sysinfo.h> + +__attribute__((weak)) ssize_t boot_device_read(void *buf, size_t offset, size_t size) +{ + /* Memory-mapping usually only works for the top 16MB. */ + if (!lib_sysinfo.boot_media_size || lib_sysinfo.boot_media_size - offset > 16 * MiB) + return CB_ERR_ARG; + void *ptr = (void *)(uintptr_t)(0 - lib_sysinfo.boot_media_size + offset); + memcpy(buf, ptr, size); + return size; +} diff --git a/payloads/libpayload/include/boot_device.h b/payloads/libpayload/include/boot_device.h new file mode 100644 index 0000000..a946545 --- /dev/null +++ b/payloads/libpayload/include/boot_device.h @@ -0,0 +1,22 @@ +/* SPDX-License-Identifier: BSD-3-Clause */ + +#ifndef _BOOT_DEVICE_H +#define _BOOT_DEVICE_H + +#include <stddef.h> + +/** + * This is a boot device access function, which is used by libpayload to read data from + * the flash memory (or other boot device). It has to be implemented by payloads that want + * to use FMAP or libcbfs. + * + * @param buf The output buffer to which the data should be written to. + * @param offset Absolute offset in bytes of the requested boot device memory area. Not aligned. + * @param size Size in bytes of the requested boot device memory area. Not aligned. + * + * @returns Number of bytes returned to the buffer, or negative value on error. Typically should + * be equal to the `size`, and not aligned forcefully. + */ +ssize_t boot_device_read(void *buf, size_t offset, size_t size); + +#endif /* _BOOT_DEVICE_H */
6 is the latest approved patch-set. No files were changed between the latest approved patch-set and the submitted one.