Option API
The option API around the set_option(const char *name, void *val)
and
get_option(void *dest, const char *name)
functions deprecated in favor
of a type-safe API.
Historically, options were stored in RTC battery-backed CMOS RAM inside the chipset on PC platforms. Nowadays, options can also be stored in the same flash chip as the boot firmware or through some BMC interface.
The new type-safe option framework can be used by calling
enum cb_err set_uint_option(const char *name, unsigned int value)
and
unsigned int get_uint_option(const char *name, const unsigned int fallback)
.
The default setting is OPTION_BACKEND_NONE
, which disables any runtime
configurable options. If supported by a mainboard, the USE_OPTION_TABLE
and USE_MAINBOARD_SPECIFIC_OPTION_BACKEND
choices are visible, and can
be selected to enable runtime configurability.
Mainboard-specific option backend
Mainboards with a mainboard-specific (vendor-defined) method to access
options can select HAVE_MAINBOARD_SPECIFIC_OPTION_BACKEND
to provide
implementations of the option API accessors. To allow choosing between
multiple option backends, the mainboard-specific implementation should
only be built when USE_MAINBOARD_SPECIFIC_OPTION_BACKEND
is selected.
Where possible, using a generic, mainboard-independent mechanism should be preferred over reinventing the wheel in mainboard-specific code. The mainboard-specific approach should only be used when the option storage mechanism has to satisfy externally-imposed, vendor-defined constraints.