diff options
author | Jakub Czapiga <jacz@semihalf.com> | 2021-11-12 11:31:21 +0000 |
---|---|---|
committer | Julius Werner <jwerner@chromium.org> | 2021-12-10 17:56:34 +0000 |
commit | f7d6eb2fef3b4afca5c165af0b936612e01b1c2e (patch) | |
tree | b5fac874b447d4d83f57cc102293c696d975f652 /payloads/libpayload/arch | |
parent | 48fbf2f21d261d5f4331e881bf03c52526f766cd (diff) |
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>
Diffstat (limited to 'payloads/libpayload/arch')
-rw-r--r-- | payloads/libpayload/arch/x86/boot_media.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/payloads/libpayload/arch/x86/boot_media.c b/payloads/libpayload/arch/x86/boot_media.c new file mode 100644 index 0000000000..ce0283273d --- /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; +} |