blob: ef37ca72642eb406e9aff218cd8cee067d77f6ef [file] [log] [blame]
Patrick Georgiea063cb2020-05-08 19:28:13 +02001/* ifdtool - dump Intel Firmware Descriptor information */
Patrick Georgi7333a112020-05-08 20:48:04 +02002/* SPDX-License-Identifier: GPL-2.0-only */
Stefan Reinauer1c795ad12011-10-14 12:49:41 -07003
4#include <stdint.h>
Bill XIEb3e15a22017-09-07 18:34:50 +08005#include <stdbool.h>
Duncan Laurie1f7fd722015-06-22 11:14:48 -07006#define IFDTOOL_VERSION "1.2"
7
8enum ifd_version {
9 IFD_VERSION_1,
Patrick Rudolph16598742022-10-21 15:13:43 +020010 IFD_VERSION_1_5,
Duncan Laurie1f7fd722015-06-22 11:14:48 -070011 IFD_VERSION_2,
12};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -070013
Bill XIEb3e15a22017-09-07 18:34:50 +080014/* port from flashrom */
15enum ich_chipset {
16 CHIPSET_ICH_UNKNOWN,
Bill XIEb3e15a22017-09-07 18:34:50 +080017 CHIPSET_ICH8,
18 CHIPSET_ICH9,
19 CHIPSET_ICH10,
Subrata Banik89db2252020-08-26 14:49:17 +053020 CHIPSET_PCH_UNKNOWN,
Bill XIEb3e15a22017-09-07 18:34:50 +080021 CHIPSET_5_SERIES_IBEX_PEAK,
22 CHIPSET_6_SERIES_COUGAR_POINT,
23 CHIPSET_7_SERIES_PANTHER_POINT,
24 CHIPSET_8_SERIES_LYNX_POINT,
25 CHIPSET_BAYTRAIL, /* Actually all with Silvermont architecture:
26 * Bay Trail, Avoton/Rangeley
27 */
28 CHIPSET_8_SERIES_LYNX_POINT_LP,
29 CHIPSET_8_SERIES_WELLSBURG,
30 CHIPSET_9_SERIES_WILDCAT_POINT,
31 CHIPSET_9_SERIES_WILDCAT_POINT_LP,
Subrata Banik8c082e52021-06-10 23:02:29 +053032 CHIPSET_N_J_SERIES_APOLLO_LAKE, /* Apollo Lake: N3xxx, J3xxx */
33 CHIPSET_N_J_SERIES_GEMINI_LAKE, /* Gemini Lake: N5xxx, J5xxx, N4xxx, J4xxx */
34 CHIPSET_N_SERIES_JASPER_LAKE, /* Jasper Lake: N6xxx, N51xx, N45xx */
35 CHIPSET_x6000_SERIES_ELKHART_LAKE, /* Elkhart Lake: x6000 */
Subrata Banik89db2252020-08-26 14:49:17 +053036 CHIPSET_100_200_SERIES_SUNRISE_POINT, /* 6th-7th gen Core i/o (LP) variants */
Subrata Banik8c082e52021-06-10 23:02:29 +053037 CHIPSET_300_SERIES_CANNON_POINT, /* 8th-9th gen Core i/o (LP) variants */
38 CHIPSET_400_SERIES_ICE_POINT, /* 10th gen Core i/o (LP) variants */
Subrata Banika5f47812020-09-29 11:43:01 +053039 CHIPSET_500_600_SERIES_TIGER_ALDER_POINT, /* 11th-12th gen Core i/o (LP)
40 * variants onwards */
Subrata Banik9cd85d02023-05-24 23:18:49 +053041 CHIPSET_800_SERIES_METEOR_LAKE, /* 14th gen Core i/o (LP) variants onwards */
Subrata Banik6fc8bd92024-06-20 13:32:56 +053042 CHIPSET_900_SERIES_PANTHER_LAKE, /* 16th gen Core i/o (LP) variants onwards */
Bill XIEb3e15a22017-09-07 18:34:50 +080043 CHIPSET_C620_SERIES_LEWISBURG,
Jeff Dalyabd4b962022-01-06 00:52:30 -050044 CHIPSET_DENVERTON,
Bill XIEb3e15a22017-09-07 18:34:50 +080045};
46
Andrey Petrov96ecb772016-10-31 19:31:54 -070047enum platform {
Furquan Shaikhc0257dd2018-05-02 23:29:04 -070048 PLATFORM_APL,
49 PLATFORM_CNL,
Johnny Line273a022021-06-22 11:26:46 +080050 PLATFORM_LBG,
Lean Sheng Tan0faba3c2021-06-09 07:52:24 -070051 PLATFORM_EHL,
Furquan Shaikhc0257dd2018-05-02 23:29:04 -070052 PLATFORM_GLK,
Aamir Bohra1018be22018-06-29 15:08:50 +053053 PLATFORM_ICL,
rkanabard64b0462019-08-30 11:40:08 +053054 PLATFORM_JSL,
Furquan Shaikh088b6e82018-03-21 10:42:37 -070055 PLATFORM_SKLKBL,
Ravi Sarawadi7d9d63b2019-10-22 13:45:36 -070056 PLATFORM_TGL,
Subrata Banik46f80732020-03-14 15:01:42 +053057 PLATFORM_ADL,
Wonkyu Kim3922aa52022-02-02 15:19:05 -080058 PLATFORM_IFD2,
Jeff Dalyabd4b962022-01-06 00:52:30 -050059 PLATFORM_DNV,
Subrata Banikca82e612022-01-20 18:51:21 +053060 PLATFORM_MTL,
Subrata Banik6fc8bd92024-06-20 13:32:56 +053061 PLATFORM_PTL,
Patrick Rudolph16598742022-10-21 15:13:43 +020062 PLATFORM_WBG
Andrey Petrov96ecb772016-10-31 19:31:54 -070063};
64
Chris Douglass03ce0142014-02-26 13:30:13 -050065#define LAYOUT_LINELEN 80
66
Stefan Reinauer1c795ad12011-10-14 12:49:41 -070067enum spi_frequency {
68 SPI_FREQUENCY_20MHZ = 0,
69 SPI_FREQUENCY_33MHZ = 1,
Duncan Laurie1f7fd722015-06-22 11:14:48 -070070 SPI_FREQUENCY_48MHZ = 2,
71 SPI_FREQUENCY_50MHZ_30MHZ = 4,
72 SPI_FREQUENCY_17MHZ = 6,
Stefan Reinauer1c795ad12011-10-14 12:49:41 -070073};
74
Subrata Banikd16ef4d2020-08-26 15:53:00 +053075enum spi_frequency_500_series {
76 SPI_FREQUENCY_100MHZ = 0,
77 SPI_FREQUENCY_50MHZ = 1,
78 SPI_FREQUENCY_500SERIES_33MHZ = 3,
79 SPI_FREQUENCY_25MHZ = 4,
80 SPI_FREQUENCY_14MHZ = 6,
81};
82
Subrata Banike5d39922020-08-26 16:01:42 +053083enum espi_frequency {
84 ESPI_FREQUENCY_20MHZ = 0,
85 ESPI_FREQUENCY_24MHZ = 1,
86 ESPI_FREQUENCY_30MHZ = 2,
87 ESPI_FREQUENCY_48MHZ = 3,
88 ESPI_FREQUENCY_60MHZ = 4,
89 ESPI_FREQUENCY_17MHZ = 6,
90};
91
92enum espi_frequency_500_series {
93 ESPI_FREQUENCY_500SERIES_20MHZ = 0,
94 ESPI_FREQUENCY_500SERIES_24MHZ = 1,
95 ESPI_FREQUENCY_500SERIES_25MHZ = 2,
96 ESPI_FREQUENCY_500SERIES_48MHZ = 3,
97 ESPI_FREQUENCY_500SERIES_60MHZ = 4,
98};
99
Subrata Banik9cd85d02023-05-24 23:18:49 +0530100enum espi_frequency_800_series {
101 ESPI_FREQUENCY_800SERIES_20MHZ = 0,
102 ESPI_FREQUENCY_800SERIES_25MHZ = 1,
103 ESPI_FREQUENCY_800SERIES_33MHZ = 2,
104 ESPI_FREQUENCY_800SERIES_50MHZ = 4,
105};
106
Stefan Reinauer1b1309f2012-05-11 15:53:43 -0700107enum component_density {
108 COMPONENT_DENSITY_512KB = 0,
109 COMPONENT_DENSITY_1MB = 1,
110 COMPONENT_DENSITY_2MB = 2,
111 COMPONENT_DENSITY_4MB = 3,
112 COMPONENT_DENSITY_8MB = 4,
113 COMPONENT_DENSITY_16MB = 5,
Duncan Laurie1f7fd722015-06-22 11:14:48 -0700114 COMPONENT_DENSITY_32MB = 6,
115 COMPONENT_DENSITY_64MB = 7,
116 COMPONENT_DENSITY_UNUSED = 0xf
Stefan Reinauer1b1309f2012-05-11 15:53:43 -0700117};
118
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700119// flash descriptor
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100120struct __packed fdbar {
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700121 uint32_t flvalsig;
122 uint32_t flmap0;
123 uint32_t flmap1;
124 uint32_t flmap2;
Subrata Banikbd2da5a2020-08-26 15:43:51 +0530125 uint32_t flmap3; // Exist for 500 series onwards
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100126};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700127
128// regions
Jeff Daly3623eca2022-01-05 23:51:40 -0500129#define MAX_REGIONS 16
Duncan Laurie1f7fd722015-06-22 11:14:48 -0700130#define MAX_REGIONS_OLD 5
Bill XIE4651d452017-09-12 11:54:48 +0800131
Duncan Laurie7775d672019-06-06 13:39:26 -0700132enum flash_regions {
133 REGION_DESC,
134 REGION_BIOS,
135 REGION_ME,
136 REGION_GBE,
137 REGION_PDR,
Jeff Daly3623eca2022-01-05 23:51:40 -0500138 REGION_DEV_EXP1,
139 REGION_BIOS2,
Duncan Laurie7775d672019-06-06 13:39:26 -0700140 REGION_EC = 8,
Jeff Daly3623eca2022-01-05 23:51:40 -0500141 REGION_DEV_EXP2,
142 REGION_IE,
143 REGION_10GB_0,
144 REGION_10GB_1,
145 REGION_PTT = 15,
Duncan Laurie7775d672019-06-06 13:39:26 -0700146};
147
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100148struct __packed frba {
Bill XIE4651d452017-09-12 11:54:48 +0800149 uint32_t flreg[MAX_REGIONS];
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100150};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700151
152// component section
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100153struct __packed fcba {
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700154 uint32_t flcomp;
155 uint32_t flill;
156 uint32_t flpb;
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100157};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700158
159// pch strap
Patrick Rudolph802cbee2020-05-25 12:18:11 +0200160#define MAX_PCHSTRP 1024
Bill XIE4651d452017-09-12 11:54:48 +0800161
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100162struct __packed fpsba {
Bill XIE4651d452017-09-12 11:54:48 +0800163 uint32_t pchstrp[MAX_PCHSTRP];
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100164};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700165
Shawn Nematbakhshd2cb1182015-09-10 19:07:13 -0700166/*
167 * WR / RD bits start at different locations within the flmstr regs, but
168 * otherwise have identical meaning.
169 */
170#define FLMSTR_WR_SHIFT_V1 24
171#define FLMSTR_WR_SHIFT_V2 20
172#define FLMSTR_RD_SHIFT_V1 16
173#define FLMSTR_RD_SHIFT_V2 8
174
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700175// master
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100176struct __packed fmba {
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700177 uint32_t flmstr1;
178 uint32_t flmstr2;
179 uint32_t flmstr3;
Duncan Laurie1f7fd722015-06-22 11:14:48 -0700180 uint32_t flmstr4;
181 uint32_t flmstr5;
Jeff Dalyabd4b962022-01-06 00:52:30 -0500182 uint32_t flmstr6;
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100183};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700184
185// processor strap
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100186struct __packed fmsba {
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700187 uint32_t data[8];
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100188};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700189
Stefan Reinauer4a17d292012-09-27 12:42:15 -0700190// ME VSCC
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100191struct vscc {
Stefan Reinauer4a17d292012-09-27 12:42:15 -0700192 uint32_t jid;
193 uint32_t vscc;
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100194};
Stefan Reinauer1c795ad12011-10-14 12:49:41 -0700195
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100196struct vtba {
Stefan Reinauer4a17d292012-09-27 12:42:15 -0700197 // Actual number of entries specified in vtl
Stefan Tauner0d226142018-08-05 18:56:53 +0200198 /* FIXME: Rationale for the limit of 8.
199 * AFAICT it's 127, cf. flashrom's ich_descriptors_tool). */
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100200 struct vscc entry[8];
201};
Stefan Reinauer4a17d292012-09-27 12:42:15 -0700202
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100203struct region {
Maximilian Brune347596a2023-03-05 20:55:32 +0100204 int base, limit, size, type;
Maximilian Bruneab0e6802023-03-05 04:34:40 +0100205};
Chris Douglass03ce0142014-02-26 13:30:13 -0500206
207struct region_name {
Bill XIEfa5f9942017-09-12 11:22:29 +0800208 const char *pretty;
209 const char *terse;
Bill XIE1bf65062017-09-12 11:31:37 +0800210 const char *filename;
Mathew Kingc7ddc992019-08-08 14:59:25 -0600211 const char *fmapname;
Chris Douglass03ce0142014-02-26 13:30:13 -0500212};
Subrata Banik5fe22972024-01-30 00:31:08 +0530213
214struct cse_fpt {
215 const char signature[4];
216 uint32_t count;
217 uint8_t header_version;
218 uint8_t entry_version;
219 uint8_t length;
220 uint8_t crc;
221 uint8_t reserved[20];
222};
223
224struct cse_fpt_sub_part {
225 const char signature[4];
226 uint32_t reserved_1;
227 uint32_t offset;
228 uint32_t length;
229 uint8_t reserved_2[12];
230 uint32_t flags;
231};