soc/intel/xeon_sp/util: Enhance lock_pam0123
[coreboot2.git] / Documentation / drivers / smmstore.md
blob70827477df79ef6115a75b83591340e05771854c
1 # SMM based flash storage driver
3 This documents the API exposed by the x86 system management based
4 storage driver.
6 ## SMMSTORE
8 SMMSTORE is a [SMM] mediated driver to read from, write to and erase a
9 predefined region in flash. It can be enabled by setting
10 `CONFIG_SMMSTORE=y` in menuconfig.
12 This can be used by the OS or the payload to implement persistent
13 storage to hold for instance configuration data, without needing
14 to implement a (platform specific) storage driver in the payload
15 itself.
17 The API provides append-only semantics for key/value pairs.
19 ## API
21 ### Storage region
23 By default SMMSTORE will operate on a separate FMAP region called
24 `SMMSTORE`. The default generated FMAP will include such a region.
25 On systems with a locked FMAP, e.g. in an existing vboot setup
26 with a locked RO region, the option exists to add a cbfsfile
27 called `smm_store` in the `RW_LEGACY` (if CHROMEOS) or in the
28 `COREBOOT` FMAP regions. It is recommended for new builds using
29 a handcrafted FMD that intend to make use of SMMSTORE to include a
30 sufficiently large `SMMSTORE` FMAP region. It is recommended to
31 align the `SMMSTORE` region to 64KiB for the largest flash erase
32 op compatibility.
34 When a default generated FMAP is used the size of the FMAP region
35 is equal to `CONFIG_SMMSTORE_SIZE`. UEFI payloads expect at least
36 64KiB. Given that the current implementation lacks a way to rewrite
37 key-value pairs at least a multiple of this is recommended.
39 ### generating the SMI
41 SMMSTORE is called via an SMI, which is generated via a write to the
42 IO port defined in the smi_cmd entry of the FADT ACPI table. `%al`
43 contains `APM_CNT_SMMSTORE=0xed` and is written to the smi_cmd IO
44 port. `%ah` contains the SMMSTORE command. `%ebx` contains the
45 parameter buffer to the SMMSTORE command.
47 ### Return values
49 If a command succeeds, SMMSTORE will return with
50 `SMMSTORE_RET_SUCCESS=0` on `%eax`. On failure SMMSTORE will return
51 `SMMSTORE_RET_FAILURE=1`. For unsupported SMMSTORE commands
52 `SMMSTORE_REG_UNSUPPORTED=2` is returned.
54 **NOTE1**: The caller **must** check the return value and should make
55 no assumption on the returned data if `%eax` does not contain
56 `SMMSTORE_RET_SUCCESS`.
58 **NOTE2**: If the SMI returns without changing `%ax` assume that the
59 SMMSTORE feature is not installed.
61 ### Calling arguments
63 SMMSTORE supports 3 subcommands that are passed via `%ah`, the additional
64 calling arguments are passed via `%ebx`.
66 **NOTE**: The size of the struct entries are in the native word size of
67 smihandler. This means 32 bits in almost all cases.
70 #### - SMMSTORE_CMD_CLEAR = 1
72 This clears the `SMMSTORE` storage region. The argument in `%ebx` is
73 unused.
75 #### - SMMSTORE_CMD_READ = 2
77 The additional parameter buffer `%ebx` contains a pointer to
78 the following struct:
80 ```C
81 struct smmstore_params_read {
82         void *buf;
83         ssize_t bufsize;
85 ```
87 INPUT:
88 - `buf`: is a pointer to where the data needs to be read
89 - `bufsize`: is the size of the buffer
91 OUTPUT:
92 - `buf`
93 - `bufsize`: returns the amount of data that has actually been read.
95 #### - SMMSTORE_CMD_APPEND = 3
97 SMMSTORE takes a key-value approach to appending data. key-value pairs
98 are never updated, they are always appended. It is up to the caller to
99 walk through the key-value pairs after reading SMMSTORE to find the
100 latest one.
102 The additional parameter buffer `%ebx` contains a pointer to
103 the following struct:
105 ```C
106 struct smmstore_params_append {
107         void *key;
108         size_t keysize;
109         void *val;
110         size_t valsize;
114 INPUT:
115 - `key`: pointer to the key data
116 - `keysize`: size of the key data
117 - `val`: pointer to the value data
118 - `valsize`: size of the value data
120 #### Security
122 Pointers provided by the payload or OS are checked to not overlap with the SMM.
123 That protects the SMM handler from being manipulated.
125 *However there's no validation done on the source or destination pointing to
126 DRAM. A malicious application that is able to issue SMIs could extract arbitrary
127 data or modify the currently running kernel.*
129 ## External links
131 * [A Tour Beyond BIOS Implementing UEFI Authenticated Variables in SMM with EDKI](https://software.intel.com/sites/default/files/managed/cf/ea/a_tour_beyond_bios_implementing_uefi_authenticated_variables_in_smm_with_edkii.pdf)
132 Note, this differs significantly from coreboot's implementation.
134 [SMM]: ../security/smm.md