summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Czapiga <jacz@semihalf.com>2021-11-12 11:31:21 +0000
committerJulius Werner <jwerner@chromium.org>2021-12-10 17:56:34 +0000
commitf7d6eb2fef3b4afca5c165af0b936612e01b1c2e (patch)
treeb5fac874b447d4d83f57cc102293c696d975f652
parent48fbf2f21d261d5f4331e881bf03c52526f766cd (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>
-rw-r--r--payloads/libpayload/arch/x86/boot_media.c17
-rw-r--r--payloads/libpayload/include/boot_device.h22
2 files changed, 39 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;
+}
diff --git a/payloads/libpayload/include/boot_device.h b/payloads/libpayload/include/boot_device.h
new file mode 100644
index 0000000000..a946545792
--- /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 */