1 /* SPDX-License-Identifier: GPL-2.0-or-later */
4 #include <soc/ramstage.h>
7 union eeprom_dimm_layout
{
10 char manufacturer
[50];
12 uint8_t controller_id
;
13 uint8_t data_width_bits
;
14 uint8_t bus_width_bits
;
15 uint32_t capacity_mib
;
16 uint32_t max_tdp_milliwatts
;
21 _Static_assert(sizeof(union eeprom_dimm_layout
) == 0x80,
22 "union eeprom_dimm_layout has invalid size!");
24 struct __packed eeprom_board_layout
{
30 uint32_t cpu_max_non_turbo_frequency
;
32 union eeprom_dimm_layout dimm
[4];
34 uint8_t raw_layout
[617];
38 _Static_assert(sizeof(struct eeprom_board_layout
) == (617 + sizeof(uint32_t)),
39 "struct eeprom_board_layout has invalid size!");
41 struct __packed eeprom_reset_cause_regs
{
42 uint32_t gblrst_cause0
;
43 uint32_t gblrst_cause1
;
47 struct __packed eeprom_board_settings
{
52 uint8_t primary_video
;
53 uint8_t deep_sx_enabled
;
55 uint8_t usb_powered_in_s5
;
56 uint8_t power_state_after_g3
;
57 uint8_t blue_rear_vref
;
58 uint8_t front_panel_audio
;
59 uint8_t pxe_boot_capability
;
60 uint8_t pink_rear_vref
;
62 uint8_t boot_menu_disabled
;
64 uint8_t raw_settings
[12];
69 PRIMARY_VIDEO_ASPEED
= 0,
70 PRIMARY_VIDEO_INTEL
= 1,
73 _Static_assert(sizeof(struct eeprom_board_settings
) == (12 + sizeof(uint32_t)),
74 "struct eeprom_board_settings has invalid size!");
76 struct __packed eeprom_bmc_settings
{
79 uint8_t efp3_displayport
;
82 #define HERMES_SN_PN_LENGTH 32
84 /* The EEPROM on address 0x57 has the following vendor defined layout: */
85 struct __packed eeprom_layout
{
87 uint8_t raw_fspm_upd
[0x600];
91 uint8_t raw_fsps_upd
[0xc00];
95 uint8_t raw_board_layout
[0x400];
96 struct eeprom_board_layout board_layout
;
98 char system_serial_number
[HERMES_SN_PN_LENGTH
];
99 char board_serial_number
[HERMES_SN_PN_LENGTH
];
100 uint8_t boot_order
[0x200];
101 char board_part_number
[HERMES_SN_PN_LENGTH
];
102 char product_part_number
[HERMES_SN_PN_LENGTH
];
104 struct eeprom_reset_cause_regs reset_cause_regs
;
105 uint8_t raw_reset_cause_registers
[0x80];
107 uint8_t unused
[0x600];
109 uint8_t raw_board_settings
[0xf8];
110 struct eeprom_board_settings board_settings
;
113 uint8_t raw_bmc_settings
[0x8];
114 struct eeprom_bmc_settings bmc_settings
;
118 _Static_assert(sizeof(FSPM_UPD
) <= 0x600, "FSPM_UPD too big");
119 _Static_assert(sizeof(FSPS_UPD
) <= 0xc00, "FSPS_UPD too big");
120 _Static_assert(sizeof(struct eeprom_layout
) == 0x2000, "EEPROM layout size mismatch");
122 bool eeprom_read_buffer(void *blob
, size_t read_offset
, size_t size
);
123 int check_signature(const size_t offset
, const uint64_t signature
);
124 struct eeprom_board_settings
*get_board_settings(void);
125 struct eeprom_bmc_settings
*get_bmc_settings(void);
126 const char *eeprom_read_serial(size_t offset
, const char *fallback
);
127 uint8_t get_bmc_hsi(void);
128 void report_eeprom_error(const size_t off
);
129 bool eeprom_write_byte(const uint8_t data
, const uint16_t write_offset
);
130 bool write_board_settings(const struct eeprom_board_layout
*new_layout
);
132 #define READ_EEPROM(section_type, section_name, dest, opt_name) \
134 typeof(dest->opt_name) __tmp; \
135 size_t __off = offsetof(struct eeprom_layout, section_name); \
136 bool ret = eeprom_read_buffer(&__tmp, \
137 __off + offsetof(section_type, opt_name), \
140 report_eeprom_error(__off + offsetof(section_type, opt_name)); \
142 dest->opt_name = __tmp; \
146 #define READ_EEPROM_FSP_M(dest, opt_name) READ_EEPROM(FSPM_UPD, raw_fspm_upd, dest, opt_name)
147 #define READ_EEPROM_FSP_S(dest, opt_name) READ_EEPROM(FSPS_UPD, raw_fsps_upd, dest, opt_name)