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:
Marshall Dawson 2018-01-30 15:33:23 -07:00 committed by Martin Roth
parent ac1cd44525
commit 8d6e0e0a72
4 changed files with 81 additions and 0 deletions

View File

@ -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

View File

@ -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. */

View File

@ -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;

View File

@ -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;