lib/reg_script: Allow multiple independent handlers
Remove the platform_bus_table routine and replace it with a link time table. This allows the handlers to be spread across multiple modules without any one module knowing about all of the handlers. Establish number ranges for both the SOC and mainboard. TEST=Build and run on Galileo Gen2 Change-Id: I0823d443d3352f31ba7fa20845bbf550b585c86f Signed-off-by: Lee Leahy <leroy.p.leahy@intel.com> Reviewed-on: https://review.coreboot.org/14554 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins)
This commit is contained in:
parent
6bcbe5749b
commit
efcee9fadd
4 changed files with 23 additions and 34 deletions
|
@ -60,7 +60,9 @@ enum {
|
||||||
|
|
||||||
/* Insert other platform independent values above this comment */
|
/* Insert other platform independent values above this comment */
|
||||||
|
|
||||||
REG_SCRIPT_TYPE_PLATFORM_BASE = 0x10000
|
REG_SCRIPT_TYPE_PLATFORM_BASE = 0x10000,
|
||||||
|
REG_SCRIPT_TYPE_SOC_BASE = REG_SCRIPT_TYPE_PLATFORM_BASE,
|
||||||
|
REG_SCRIPT_TYPE_MAINBOARD_BASE = 0x20000
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -92,17 +94,17 @@ struct reg_script_context {
|
||||||
const struct reg_script *step;
|
const struct reg_script *step;
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
struct reg_script_bus_entry {
|
struct reg_script_bus_entry {
|
||||||
int type;
|
uint32_t type;
|
||||||
uint64_t (*reg_script_read)(struct reg_script_context *ctx);
|
uint64_t (*reg_script_read)(struct reg_script_context *ctx);
|
||||||
void (*reg_script_write)(struct reg_script_context *ctx);
|
void (*reg_script_write)(struct reg_script_context *ctx);
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Get the address and length of the platform bus table */
|
#define REG_SCRIPT_TABLE_ATTRIBUTE __attribute__ ((used,section (".rsbe_init")))
|
||||||
const struct reg_script_bus_entry *platform_bus_table(size_t *table_entries);
|
|
||||||
|
|
||||||
#endif /* __PRE_RAM */
|
#define REG_SCRIPT_BUS_ENTRY(bus_entry_) \
|
||||||
|
const struct reg_script_bus_entry *rsbe_ ## bus_entry_ \
|
||||||
|
REG_SCRIPT_TABLE_ATTRIBUTE = &bus_entry_;
|
||||||
|
|
||||||
/* Internal helper Macros. */
|
/* Internal helper Macros. */
|
||||||
|
|
||||||
|
|
|
@ -43,6 +43,11 @@
|
||||||
_cbmem_init_hooks = .;
|
_cbmem_init_hooks = .;
|
||||||
KEEP(*(.rodata.cbmem_init_hooks));
|
KEEP(*(.rodata.cbmem_init_hooks));
|
||||||
_ecbmem_init_hooks = .;
|
_ecbmem_init_hooks = .;
|
||||||
|
|
||||||
|
. = ALIGN(ARCH_POINTER_ALIGN_SIZE);
|
||||||
|
_rsbe_init_begin = .;
|
||||||
|
KEEP(*(.rsbe_init));
|
||||||
|
_ersbe_init_begin = .;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ENV_RAMSTAGE
|
#if ENV_RAMSTAGE
|
||||||
|
|
|
@ -393,35 +393,27 @@ static void reg_script_write_msr(struct reg_script_context *ctx)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
/* Default routine provided for systems without platform specific busses */
|
|
||||||
const struct reg_script_bus_entry *__attribute__((weak))
|
|
||||||
platform_bus_table(size_t *table_entries)
|
|
||||||
{
|
|
||||||
/* No platform bus type table supplied */
|
|
||||||
*table_entries = 0;
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Locate the structure containing the platform specific bus access routines */
|
/* Locate the structure containing the platform specific bus access routines */
|
||||||
static const struct reg_script_bus_entry
|
static const struct reg_script_bus_entry
|
||||||
*find_bus(const struct reg_script *step)
|
*find_bus(const struct reg_script *step)
|
||||||
{
|
{
|
||||||
const struct reg_script_bus_entry *bus;
|
extern const struct reg_script_bus_entry *_rsbe_init_begin[];
|
||||||
|
extern const struct reg_script_bus_entry *_ersbe_init_begin[];
|
||||||
|
const struct reg_script_bus_entry * const * bus;
|
||||||
size_t table_entries;
|
size_t table_entries;
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
/* Locate the platform specific bus */
|
/* Locate the platform specific bus */
|
||||||
bus = platform_bus_table(&table_entries);
|
bus = _rsbe_init_begin;
|
||||||
|
table_entries = &_ersbe_init_begin[0] - &_rsbe_init_begin[0];
|
||||||
for (i = 0; i < table_entries; i++) {
|
for (i = 0; i < table_entries; i++) {
|
||||||
if (bus[i].type == step->type)
|
if (bus[i]->type == step->type)
|
||||||
return &bus[i];
|
return bus[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Bus not found */
|
/* Bus not found */
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
static uint64_t reg_script_read(struct reg_script_context *ctx)
|
static uint64_t reg_script_read(struct reg_script_context *ctx)
|
||||||
{
|
{
|
||||||
|
@ -443,7 +435,6 @@ static uint64_t reg_script_read(struct reg_script_context *ctx)
|
||||||
return reg_script_read_iosf(ctx);
|
return reg_script_read_iosf(ctx);
|
||||||
#endif /* HAS_IOSF */
|
#endif /* HAS_IOSF */
|
||||||
default:
|
default:
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
{
|
{
|
||||||
const struct reg_script_bus_entry *bus;
|
const struct reg_script_bus_entry *bus;
|
||||||
|
|
||||||
|
@ -452,7 +443,6 @@ static uint64_t reg_script_read(struct reg_script_context *ctx)
|
||||||
if (NULL != bus)
|
if (NULL != bus)
|
||||||
return bus->reg_script_read(ctx);
|
return bus->reg_script_read(ctx);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
printk(BIOS_ERR,
|
printk(BIOS_ERR,
|
||||||
"Unsupported read type (0x%x) for this device!\n",
|
"Unsupported read type (0x%x) for this device!\n",
|
||||||
step->type);
|
step->type);
|
||||||
|
@ -487,7 +477,6 @@ static void reg_script_write(struct reg_script_context *ctx)
|
||||||
break;
|
break;
|
||||||
#endif /* HAS_IOSF */
|
#endif /* HAS_IOSF */
|
||||||
default:
|
default:
|
||||||
#ifndef __PRE_RAM__
|
|
||||||
{
|
{
|
||||||
const struct reg_script_bus_entry *bus;
|
const struct reg_script_bus_entry *bus;
|
||||||
|
|
||||||
|
@ -498,7 +487,6 @@ static void reg_script_write(struct reg_script_context *ctx)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
printk(BIOS_ERR,
|
printk(BIOS_ERR,
|
||||||
"Unsupported write type (0x%x) for this device!\n",
|
"Unsupported write type (0x%x) for this device!\n",
|
||||||
step->type);
|
step->type);
|
||||||
|
|
|
@ -190,16 +190,10 @@ void reg_script_write_iosf(struct reg_script_context *ctx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct reg_script_bus_entry reg_script_bus_table[] = {
|
static const struct reg_script_bus_entry reg_script_bus_table = {
|
||||||
{REG_SCRIPT_TYPE_IOSF, reg_script_read_iosf, reg_script_write_iosf}
|
REG_SCRIPT_TYPE_IOSF, reg_script_read_iosf, reg_script_write_iosf
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct reg_script_bus_entry *platform_bus_table(size_t *table_entries)
|
REG_SCRIPT_BUS_ENTRY(reg_script_bus_table);
|
||||||
{
|
|
||||||
/* Return the table size and address */
|
|
||||||
*table_entries = sizeof(reg_script_bus_table)
|
|
||||||
/ sizeof(reg_script_bus_table[0]);
|
|
||||||
return ®_script_bus_table[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* ENV_RAMSTAGE */
|
#endif /* ENV_RAMSTAGE */
|
||||||
|
|
Loading…
Reference in a new issue