lib/stage_cache: Add save/get raw storage
Leverage the stage_cache mechanism to store a non-specific type of data. This is not interesting when the location for the cache is in cbmem. However it will be more useful when an external location is used, e.g. when the cache is in TSEG, locked from user modification. Change-Id: Iaf0b25ebe14c176bbd24fc8942f902f627ca8e6f Signed-off-by: Marshall Dawson <marshalldawson3rd@gmail.com> Reviewed-on: https://review.coreboot.org/23518 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
ac1cd44525
commit
8d6e0e0a72
|
@ -61,6 +61,7 @@
|
|||
#define CBMEM_ID_SMM_SAVE_SPACE 0x07e9acee
|
||||
#define CBMEM_ID_STAGEx_META 0x57a9e000
|
||||
#define CBMEM_ID_STAGEx_CACHE 0x57a9e100
|
||||
#define CBMEM_ID_STAGEx_RAW 0x57a9e200
|
||||
#define CBMEM_ID_STORAGE_DATA 0x53746f72
|
||||
#define CBMEM_ID_TCPA_LOG 0x54435041
|
||||
#define CBMEM_ID_TIMESTAMP 0x54494d45
|
||||
|
|
|
@ -20,14 +20,24 @@
|
|||
#include <stdint.h>
|
||||
#include <program_loading.h>
|
||||
|
||||
/* Types of stages that may be stored in stage cache */
|
||||
enum {
|
||||
STAGE_RAMSTAGE,
|
||||
STAGE_REFCODE,
|
||||
STAGE_POSTCAR,
|
||||
};
|
||||
|
||||
/* Types of raw data that may be stored in stage cache */
|
||||
enum {
|
||||
STAGE_S3_DATA,
|
||||
};
|
||||
|
||||
/* Cache the loaded stage provided according to the parameters. */
|
||||
void stage_cache_add(int stage_id, const struct prog *stage);
|
||||
/* Cache non-specific data or code. */
|
||||
void stage_cache_add_raw(int stage_id, const void *base, const size_t size);
|
||||
/* Get a pointer to cached raw data and its size. */
|
||||
void stage_cache_get_raw(int stage_id, void **base, size_t *size);
|
||||
/* Load the cached stage at given location returning the stage entry point. */
|
||||
void stage_cache_load_stage(int stage_id, struct prog *stage);
|
||||
/* Fill in parameters for the external stage cache, if utilized. */
|
||||
|
|
|
@ -45,6 +45,35 @@ void stage_cache_add(int stage_id, const struct prog *stage)
|
|||
memcpy(c, prog_start(stage), prog_size(stage));
|
||||
}
|
||||
|
||||
void stage_cache_add_raw(int stage_id, const void *base, const size_t size)
|
||||
{
|
||||
void *c;
|
||||
|
||||
c = cbmem_add(CBMEM_ID_STAGEx_RAW + stage_id, size);
|
||||
if (c == NULL) {
|
||||
printk(BIOS_DEBUG, "Error: Can't add %x raw data to cbmem\n",
|
||||
CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
return;
|
||||
}
|
||||
|
||||
memcpy(c, base, size);
|
||||
}
|
||||
|
||||
void stage_cache_get_raw(int stage_id, void **base, size_t *size)
|
||||
{
|
||||
const struct cbmem_entry *e;
|
||||
|
||||
e = cbmem_entry_find(CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
if (e == NULL) {
|
||||
printk(BIOS_ERR, "Error: Can't find raw %x data in cbmem\n",
|
||||
CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
return;
|
||||
}
|
||||
|
||||
*base = cbmem_entry_start(e);
|
||||
*size = cbmem_entry_size(e);
|
||||
}
|
||||
|
||||
void stage_cache_load_stage(int stage_id, struct prog *stage)
|
||||
{
|
||||
struct stage_cache *meta;
|
||||
|
|
|
@ -93,6 +93,47 @@ void stage_cache_add(int stage_id, const struct prog *stage)
|
|||
memcpy(c, prog_start(stage), prog_size(stage));
|
||||
}
|
||||
|
||||
void stage_cache_add_raw(int stage_id, const void *base, const size_t size)
|
||||
{
|
||||
struct imd *imd;
|
||||
const struct imd_entry *e;
|
||||
void *c;
|
||||
|
||||
imd = imd_get();
|
||||
e = imd_entry_add(imd, CBMEM_ID_STAGEx_RAW + stage_id, size);
|
||||
if (e == NULL) {
|
||||
printk(BIOS_DEBUG, "Error: Can't add %x raw data to imd\n",
|
||||
CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
return;
|
||||
}
|
||||
|
||||
c = imd_entry_at(imd, e);
|
||||
if (c == NULL) {
|
||||
printk(BIOS_DEBUG, "Error: Can't get %x raw entry in imd\n",
|
||||
CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
return;
|
||||
}
|
||||
|
||||
memcpy(c, base, size);
|
||||
}
|
||||
|
||||
void stage_cache_get_raw(int stage_id, void **base, size_t *size)
|
||||
{
|
||||
struct imd *imd;
|
||||
const struct imd_entry *e;
|
||||
|
||||
imd = imd_get();
|
||||
e = imd_entry_find(imd, CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
if (e == NULL) {
|
||||
printk(BIOS_DEBUG, "Error: Can't find %x raw data to imd\n",
|
||||
CBMEM_ID_STAGEx_RAW + stage_id);
|
||||
return;
|
||||
}
|
||||
|
||||
*base = imd_entry_at(imd, e);
|
||||
*size = imd_entry_size(imd, e);
|
||||
}
|
||||
|
||||
void stage_cache_load_stage(int stage_id, struct prog *stage)
|
||||
{
|
||||
struct imd *imd;
|
||||
|
|
Loading…
Reference in New Issue