1 /* ifdtool - dump Intel Firmware Descriptor information */
2 /* SPDX-License-Identifier: GPL-2.0-only */
6 #define IFDTOOL_VERSION "1.2"
13 /* port from flashrom */
19 CHIPSET_POULSBO
, /* SCH U* */
20 CHIPSET_TUNNEL_CREEK
, /* Atom E6xx */
21 CHIPSET_CENTERTON
, /* Atom S1220 S1240 S1260 */
27 CHIPSET_5_SERIES_IBEX_PEAK
,
28 CHIPSET_6_SERIES_COUGAR_POINT
,
29 CHIPSET_7_SERIES_PANTHER_POINT
,
30 CHIPSET_8_SERIES_LYNX_POINT
,
31 CHIPSET_BAYTRAIL
, /* Actually all with Silvermont architecture:
32 * Bay Trail, Avoton/Rangeley
34 CHIPSET_8_SERIES_LYNX_POINT_LP
,
35 CHIPSET_8_SERIES_WELLSBURG
,
36 CHIPSET_9_SERIES_WILDCAT_POINT
,
37 CHIPSET_9_SERIES_WILDCAT_POINT_LP
,
38 CHIPSET_N_J_SERIES_APOLLO_LAKE
, /* Apollo Lake: N3xxx, J3xxx */
39 CHIPSET_N_J_SERIES_GEMINI_LAKE
, /* Gemini Lake: N5xxx, J5xxx, N4xxx, J4xxx */
40 CHIPSET_N_SERIES_JASPER_LAKE
, /* Jasper Lake: N6xxx, N51xx, N45xx */
41 CHIPSET_x6000_SERIES_ELKHART_LAKE
, /* Elkhart Lake: x6000 */
42 CHIPSET_100_200_SERIES_SUNRISE_POINT
, /* 6th-7th gen Core i/o (LP) variants */
43 CHIPSET_300_SERIES_CANNON_POINT
, /* 8th-9th gen Core i/o (LP) variants */
44 CHIPSET_400_SERIES_ICE_POINT
, /* 10th gen Core i/o (LP) variants */
45 CHIPSET_500_600_SERIES_TIGER_ALDER_POINT
, /* 11th-12th gen Core i/o (LP)
47 CHIPSET_C620_SERIES_LEWISBURG
,
67 #define LAYOUT_LINELEN 80
70 SPI_FREQUENCY_20MHZ
= 0,
71 SPI_FREQUENCY_33MHZ
= 1,
72 SPI_FREQUENCY_48MHZ
= 2,
73 SPI_FREQUENCY_50MHZ_30MHZ
= 4,
74 SPI_FREQUENCY_17MHZ
= 6,
77 enum spi_frequency_500_series
{
78 SPI_FREQUENCY_100MHZ
= 0,
79 SPI_FREQUENCY_50MHZ
= 1,
80 SPI_FREQUENCY_500SERIES_33MHZ
= 3,
81 SPI_FREQUENCY_25MHZ
= 4,
82 SPI_FREQUENCY_14MHZ
= 6,
86 ESPI_FREQUENCY_20MHZ
= 0,
87 ESPI_FREQUENCY_24MHZ
= 1,
88 ESPI_FREQUENCY_30MHZ
= 2,
89 ESPI_FREQUENCY_48MHZ
= 3,
90 ESPI_FREQUENCY_60MHZ
= 4,
91 ESPI_FREQUENCY_17MHZ
= 6,
94 enum espi_frequency_500_series
{
95 ESPI_FREQUENCY_500SERIES_20MHZ
= 0,
96 ESPI_FREQUENCY_500SERIES_24MHZ
= 1,
97 ESPI_FREQUENCY_500SERIES_25MHZ
= 2,
98 ESPI_FREQUENCY_500SERIES_48MHZ
= 3,
99 ESPI_FREQUENCY_500SERIES_60MHZ
= 4,
102 enum component_density
{
103 COMPONENT_DENSITY_512KB
= 0,
104 COMPONENT_DENSITY_1MB
= 1,
105 COMPONENT_DENSITY_2MB
= 2,
106 COMPONENT_DENSITY_4MB
= 3,
107 COMPONENT_DENSITY_8MB
= 4,
108 COMPONENT_DENSITY_16MB
= 5,
109 COMPONENT_DENSITY_32MB
= 6,
110 COMPONENT_DENSITY_64MB
= 7,
111 COMPONENT_DENSITY_UNUSED
= 0xf
120 uint32_t flmap3
; // Exist for 500 series onwards
121 } __attribute__((packed
)) fdbar_t
;
124 #define MAX_REGIONS 16
125 #define MAX_REGIONS_OLD 5
144 uint32_t flreg
[MAX_REGIONS
];
145 } __attribute__((packed
)) frba_t
;
152 } __attribute__((packed
)) fcba_t
;
155 #define MAX_PCHSTRP 1024
158 uint32_t pchstrp
[MAX_PCHSTRP
];
159 } __attribute__((packed
)) fpsba_t
;
162 * WR / RD bits start at different locations within the flmstr regs, but
163 * otherwise have identical meaning.
165 #define FLMSTR_WR_SHIFT_V1 24
166 #define FLMSTR_WR_SHIFT_V2 20
167 #define FLMSTR_RD_SHIFT_V1 16
168 #define FLMSTR_RD_SHIFT_V2 8
178 } __attribute__((packed
)) fmba_t
;
183 } __attribute__((packed
)) fmsba_t
;
192 // Actual number of entries specified in vtl
193 /* FIXME: Rationale for the limit of 8.
194 * AFAICT it's 127, cf. flashrom's ich_descriptors_tool). */
199 int base
, limit
, size
;
205 const char *filename
;
206 const char *fmapname
;