coreboot
coreboot is an Open Source project aimed at replacing the proprietary BIOS found in most computers.
report_platform.c
Go to the documentation of this file.
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 
3 /*
4  * This file is created based on Intel Alder Lake Platform Stepping and IDs
5  * Document number: 619362, 619501
6  * Chapter number: 2, 14
7  */
8 
9 #include <arch/cpu.h>
10 #include <device/pci_ops.h>
11 #include <commonlib/helpers.h>
12 #include <console/console.h>
13 #include <cpu/intel/cpu_ids.h>
14 #include <cpu/intel/microcode.h>
15 #include <cpu/x86/msr.h>
16 #include <cpu/x86/name.h>
17 #include <device/pci.h>
18 #include <device/pci_ids.h>
19 #include <soc/bootblock.h>
20 #include <soc/pci_devs.h>
21 
22 static struct {
24  const char *name;
25 } cpu_table[] = {
26  { CPUID_ALDERLAKE_J0, "Alderlake J0 Platform" },
27  { CPUID_ALDERLAKE_K0, "Alderlake K0 Platform" },
28  { CPUID_ALDERLAKE_L0, "Alderlake L0 Platform" },
29  { CPUID_ALDERLAKE_Q0, "Alderlake Q0 Platform" },
30  { CPUID_ALDERLAKE_R0, "Alderlake R0 Platform" },
31  { CPUID_ALDERLAKE_N_A0, "Alderlake-N Platform" },
32 };
33 
34 static struct {
36  const char *name;
37 } mch_table[] = {
38  { PCI_DID_INTEL_ADL_P_ID_1, "Alderlake-P" },
39  { PCI_DID_INTEL_ADL_P_ID_3, "Alderlake-P" },
40  { PCI_DID_INTEL_ADL_P_ID_4, "Alderlake-P" },
41  { PCI_DID_INTEL_ADL_P_ID_5, "Alderlake-P" },
42  { PCI_DID_INTEL_ADL_P_ID_6, "Alderlake-P" },
43  { PCI_DID_INTEL_ADL_P_ID_7, "Alderlake-P" },
44  { PCI_DID_INTEL_ADL_P_ID_8, "Alderlake-P" },
45  { PCI_DID_INTEL_ADL_P_ID_9, "Alderlake-P" },
46  { PCI_DID_INTEL_ADL_P_ID_10, "Alderlake-P" },
47  { PCI_DID_INTEL_ADL_M_ID_1, "Alderlake-M" },
48  { PCI_DID_INTEL_ADL_M_ID_2, "Alderlake-M" },
49  { PCI_DID_INTEL_ADL_N_ID_1, "Alderlake-N" },
50  { PCI_DID_INTEL_ADL_N_ID_2, "Alderlake-N" },
51  { PCI_DID_INTEL_ADL_N_ID_3, "Alderlake-N" },
52  { PCI_DID_INTEL_ADL_N_ID_4, "Alderlake-N" },
53 
54 };
55 
56 static struct {
58  const char *name;
59 } pch_table[] = {
60  { PCI_DID_INTEL_ADP_P_ESPI_0, "Alderlake-P SKU" },
61  { PCI_DID_INTEL_ADP_P_ESPI_1, "Alderlake-P SKU" },
62  { PCI_DID_INTEL_ADP_P_ESPI_2, "Alderlake-P SKU" },
63  { PCI_DID_INTEL_ADP_P_ESPI_3, "Alderlake-P SKU" },
64  { PCI_DID_INTEL_ADP_P_ESPI_4, "Alderlake-P SKU" },
65  { PCI_DID_INTEL_ADP_P_ESPI_5, "Alderlake-P SKU" },
66  { PCI_DID_INTEL_ADP_P_ESPI_6, "Alderlake-P SKU" },
67  { PCI_DID_INTEL_ADP_P_ESPI_7, "Alderlake-P SKU" },
68  { PCI_DID_INTEL_ADP_P_ESPI_8, "Alderlake-P SKU" },
69  { PCI_DID_INTEL_ADP_P_ESPI_9, "Alderlake-P SKU" },
70  { PCI_DID_INTEL_ADP_P_ESPI_10, "Alderlake-P SKU" },
71  { PCI_DID_INTEL_ADP_P_ESPI_11, "Alderlake-P SKU" },
72  { PCI_DID_INTEL_ADP_P_ESPI_12, "Alderlake-P SKU" },
73  { PCI_DID_INTEL_ADP_P_ESPI_13, "Alderlake-P SKU" },
74  { PCI_DID_INTEL_ADP_P_ESPI_14, "Alderlake-P SKU" },
75  { PCI_DID_INTEL_ADP_P_ESPI_15, "Alderlake-P SKU" },
76  { PCI_DID_INTEL_ADP_P_ESPI_16, "Alderlake-P SKU" },
77  { PCI_DID_INTEL_ADP_P_ESPI_17, "Alderlake-P SKU" },
78  { PCI_DID_INTEL_ADP_P_ESPI_18, "Alderlake-P SKU" },
79  { PCI_DID_INTEL_ADP_P_ESPI_19, "Alderlake-P SKU" },
80  { PCI_DID_INTEL_ADP_P_ESPI_20, "Alderlake-P SKU" },
81  { PCI_DID_INTEL_ADP_P_ESPI_21, "Alderlake-P SKU" },
82  { PCI_DID_INTEL_ADP_P_ESPI_22, "Alderlake-P SKU" },
83  { PCI_DID_INTEL_ADP_P_ESPI_23, "Alderlake-P SKU" },
84  { PCI_DID_INTEL_ADP_P_ESPI_24, "Alderlake-P SKU" },
85  { PCI_DID_INTEL_ADP_P_ESPI_25, "Alderlake-P SKU" },
86  { PCI_DID_INTEL_ADP_P_ESPI_26, "Alderlake-P SKU" },
87  { PCI_DID_INTEL_ADP_P_ESPI_27, "Alderlake-P SKU" },
88  { PCI_DID_INTEL_ADP_P_ESPI_28, "Alderlake-P SKU" },
89  { PCI_DID_INTEL_ADP_P_ESPI_29, "Alderlake-P SKU" },
90  { PCI_DID_INTEL_ADP_P_ESPI_30, "Alderlake-P SKU" },
91  { PCI_DID_INTEL_ADP_P_ESPI_31, "Alderlake-P SKU" },
92  { PCI_DID_INTEL_ADP_P_ESPI_32, "Alderlake-P SKU" },
93  { PCI_DID_INTEL_ADP_P_ESPI_33, "Alderlake-P SKU" },
94  { PCI_DID_INTEL_ADP_M_ESPI_32, "Alderlake-M SKU" },
95  { PCI_DID_INTEL_ADP_M_N_ESPI_1, "Alderlake-N SKU" },
96  { PCI_DID_INTEL_ADP_M_N_ESPI_2, "Alderlake-N SKU" },
97 };
98 
99 static struct {
101  const char *name;
102 } igd_table[] = {
103  { PCI_DID_INTEL_ADL_GT0, "Alderlake GT0" },
104  { PCI_DID_INTEL_ADL_GT1, "Alderlake GT1" },
105  { PCI_DID_INTEL_ADL_GT1_1, "Alderlake GT1" },
106  { PCI_DID_INTEL_ADL_GT1_2, "Alderlake GT1" },
107  { PCI_DID_INTEL_ADL_GT1_3, "Alderlake GT1" },
108  { PCI_DID_INTEL_ADL_GT1_4, "Alderlake GT1" },
109  { PCI_DID_INTEL_ADL_GT1_5, "Alderlake GT1" },
110  { PCI_DID_INTEL_ADL_GT1_6, "Alderlake GT1" },
111  { PCI_DID_INTEL_ADL_GT1_7, "Alderlake GT1" },
112  { PCI_DID_INTEL_ADL_GT1_8, "Alderlake GT1" },
113  { PCI_DID_INTEL_ADL_GT1_9, "Alderlake GT1" },
114  { PCI_DID_INTEL_ADL_P_GT2, "Alderlake P GT2" },
115  { PCI_DID_INTEL_ADL_P_GT2_1, "Alderlake P GT2" },
116  { PCI_DID_INTEL_ADL_P_GT2_2, "Alderlake P GT2" },
117  { PCI_DID_INTEL_ADL_P_GT2_3, "Alderlake P GT2" },
118  { PCI_DID_INTEL_ADL_P_GT2_4, "Alderlake P GT2" },
119  { PCI_DID_INTEL_ADL_P_GT2_5, "Alderlake P GT2" },
120  { PCI_DID_INTEL_ADL_P_GT2_6, "Alderlake P GT2" },
121  { PCI_DID_INTEL_ADL_P_GT2_7, "Alderlake P GT2" },
122  { PCI_DID_INTEL_ADL_P_GT2_8, "Alderlake P GT2" },
123  { PCI_DID_INTEL_ADL_P_GT2_9, "Alderlake P GT2" },
124  { PCI_DID_INTEL_ADL_M_GT1, "Alderlake M GT1" },
125  { PCI_DID_INTEL_ADL_M_GT2, "Alderlake M GT2" },
126  { PCI_DID_INTEL_ADL_M_GT3, "Alderlake M GT3" },
127  { PCI_DID_INTEL_ADL_N_GT1, "Alderlake N GT1" },
128  { PCI_DID_INTEL_ADL_N_GT2, "Alderlake N GT2" },
129  { PCI_DID_INTEL_ADL_N_GT3, "Alderlake N GT3" },
130 };
131 
133 {
134  return pci_read_config8(dev, PCI_REVISION_ID);
135 }
136 
137 static inline uint16_t get_dev_id(pci_devfn_t dev)
138 {
139  return pci_read_config16(dev, PCI_DEVICE_ID);
140 }
141 
142 static void report_cache_info(void)
143 {
144  int cache_level = CACHE_L3;
145  struct cpu_cache_info info;
146 
148  return;
149 
150  printk(BIOS_INFO, "Cache: Level %d: ", cache_level);
151  printk(BIOS_INFO, "Associativity = %zd Partitions = %zd Line Size = %zd Sets = %zd\n",
152  info.num_ways, info.physical_partitions, info.line_size, info.num_sets);
153 
154  printk(BIOS_INFO, "Cache size = %zu MiB\n", get_cache_size(&info)/MiB);
155 }
156 
157 static void report_cpu_info(void)
158 {
159  u32 i, cpu_id, cpu_feature_flag;
160  char cpu_name[49];
161  int vt, txt, aes;
162  static const char *const mode[] = {"NOT ", ""};
163  const char *cpu_type = "Unknown";
164 
165  fill_processor_name(cpu_name);
166  cpu_id = cpu_get_cpuid();
167 
168  /* Look for string to match the name */
169  for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
170  if (cpu_table[i].cpuid == cpu_id) {
171  cpu_type = cpu_table[i].name;
172  break;
173  }
174  }
175 
176  printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
177  printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
179 
180  cpu_feature_flag = cpu_get_feature_flags_ecx();
181  aes = !!(cpu_feature_flag & CPUID_AES);
182  txt = !!(cpu_feature_flag & CPUID_SMX);
183  vt = !!(cpu_feature_flag & CPUID_VMX);
185  "CPU: AES %ssupported, TXT %ssupported, VT %ssupported\n",
186  mode[aes], mode[txt], mode[vt]);
187 
189 }
190 
191 static void report_mch_info(void)
192 {
193  int i;
195  const char *mch_type = "Unknown";
196 
197  for (i = 0; i < ARRAY_SIZE(mch_table); i++) {
198  if (mch_table[i].mchid == mchid) {
199  mch_type = mch_table[i].name;
200  break;
201  }
202  }
203 
204  printk(BIOS_DEBUG, "MCH: device id %04x (rev %02x) is %s\n",
205  mchid, get_dev_revision(SA_DEV_ROOT), mch_type);
206 }
207 
208 static void report_pch_info(void)
209 {
210  int i;
212  uint16_t espiid = get_dev_id(dev);
213  const char *pch_type = "Unknown";
214 
215  for (i = 0; i < ARRAY_SIZE(pch_table); i++) {
216  if (pch_table[i].espiid == espiid) {
217  pch_type = pch_table[i].name;
218  break;
219  }
220  }
221  printk(BIOS_DEBUG, "PCH: device id %04x (rev %02x) is %s\n",
223 }
224 
225 static void report_igd_info(void)
226 {
227  int i;
228  pci_devfn_t dev = SA_DEV_IGD;
229  uint16_t igdid = get_dev_id(dev);
230  const char *igd_type = "Unknown";
231 
232  for (i = 0; i < ARRAY_SIZE(igd_table); i++) {
233  if (igd_table[i].igdid == igdid) {
234  igd_type = igd_table[i].name;
235  break;
236  }
237  }
238  printk(BIOS_DEBUG, "IGD: device id %04x (rev %02x) is %s\n",
239  igdid, get_dev_revision(dev), igd_type);
240 }
241 
243 {
244  report_cpu_info();
245  report_mch_info();
246  report_pch_info();
247  report_igd_info();
248 }
cache_level
Definition: cpu.h:339
@ CACHE_L3
Definition: cpu.h:343
cpu_type
Definition: cpu.h:347
#define ARRAY_SIZE(a)
Definition: helpers.h:12
#define MiB
Definition: helpers.h:76
#define printk(level,...)
Definition: stdlib.h:16
uint32_t cpu_get_feature_flags_ecx(void)
Definition: cpu_common.c:72
size_t get_cache_size(const struct cpu_cache_info *info)
Definition: cpu_common.c:183
bool fill_cpu_cache_info(uint8_t level, struct cpu_cache_info *info)
Definition: cpu_common.c:191
uint32_t cpu_get_cpuid(void)
Definition: cpu_common.c:63
#define CPUID_ALDERLAKE_K0
Definition: cpu_ids.h:56
#define CPUID_ALDERLAKE_J0
Definition: cpu_ids.h:54
#define CPUID_ALDERLAKE_R0
Definition: cpu_ids.h:58
#define CPUID_ALDERLAKE_N_A0
Definition: cpu_ids.h:59
#define CPUID_ALDERLAKE_L0
Definition: cpu_ids.h:57
#define CPUID_ALDERLAKE_Q0
Definition: cpu_ids.h:55
static struct smmstore_params_info info
Definition: ramstage.c:12
#define CPUID_AES
Definition: msr.h:28
#define CPUID_VMX
Definition: msr.h:24
#define CPUID_SMX
Definition: msr.h:25
static __always_inline u16 pci_read_config16(const struct device *dev, u16 reg)
Definition: pci_ops.h:52
static __always_inline u8 pci_read_config8(const struct device *dev, u16 reg)
Definition: pci_ops.h:46
#define BIOS_INFO
BIOS_INFO - Expected events.
Definition: loglevel.h:113
#define BIOS_DEBUG
BIOS_DEBUG - Verbose output.
Definition: loglevel.h:128
uint32_t get_current_microcode_rev(void)
Definition: microcode.c:112
void fill_processor_name(char *processor_name)
Definition: name.c:8
void report_platform_info(void)
#define PCI_DEVICE_ID
Definition: pci_def.h:9
#define PCI_REVISION_ID
Definition: pci_def.h:41
#define PCI_DID_INTEL_ADL_P_ID_7
Definition: pci_ids.h:4069
#define PCI_DID_INTEL_ADP_P_ESPI_10
Definition: pci_ids.h:2989
#define PCI_DID_INTEL_ADL_P_GT2_5
Definition: pci_ids.h:3947
#define PCI_DID_INTEL_ADL_N_GT1
Definition: pci_ids.h:3956
#define PCI_DID_INTEL_ADP_P_ESPI_22
Definition: pci_ids.h:3001
#define PCI_DID_INTEL_ADL_GT1_6
Definition: pci_ids.h:3938
#define PCI_DID_INTEL_ADP_P_ESPI_25
Definition: pci_ids.h:3004
#define PCI_DID_INTEL_ADL_GT1_8
Definition: pci_ids.h:3940
#define PCI_DID_INTEL_ADL_GT1_3
Definition: pci_ids.h:3935
#define PCI_DID_INTEL_ADL_P_GT2_2
Definition: pci_ids.h:3944
#define PCI_DID_INTEL_ADL_GT1_5
Definition: pci_ids.h:3937
#define PCI_DID_INTEL_ADL_M_GT1
Definition: pci_ids.h:3953
#define PCI_DID_INTEL_ADP_P_ESPI_9
Definition: pci_ids.h:2988
#define PCI_DID_INTEL_ADP_P_ESPI_11
Definition: pci_ids.h:2990
#define PCI_DID_INTEL_ADP_P_ESPI_27
Definition: pci_ids.h:3006
#define PCI_DID_INTEL_ADP_M_ESPI_32
Definition: pci_ids.h:3077
#define PCI_DID_INTEL_ADP_P_ESPI_30
Definition: pci_ids.h:3009
#define PCI_DID_INTEL_ADL_N_ID_2
Definition: pci_ids.h:4076
#define PCI_DID_INTEL_ADL_P_ID_4
Definition: pci_ids.h:4066
#define PCI_DID_INTEL_ADP_P_ESPI_32
Definition: pci_ids.h:3011
#define PCI_DID_INTEL_ADL_P_ID_3
Definition: pci_ids.h:4065
#define PCI_DID_INTEL_ADL_P_GT2
Definition: pci_ids.h:3942
#define PCI_DID_INTEL_ADL_P_GT2_7
Definition: pci_ids.h:3949
#define PCI_DID_INTEL_ADL_P_GT2_3
Definition: pci_ids.h:3945
#define PCI_DID_INTEL_ADL_P_GT2_8
Definition: pci_ids.h:3950
#define PCI_DID_INTEL_ADL_P_ID_5
Definition: pci_ids.h:4067
#define PCI_DID_INTEL_ADL_P_GT2_1
Definition: pci_ids.h:3943
#define PCI_DID_INTEL_ADP_P_ESPI_17
Definition: pci_ids.h:2996
#define PCI_DID_INTEL_ADP_P_ESPI_0
Definition: pci_ids.h:2979
#define PCI_DID_INTEL_ADP_P_ESPI_33
Definition: pci_ids.h:3012
#define PCI_DID_INTEL_ADL_GT1_4
Definition: pci_ids.h:3936
#define PCI_DID_INTEL_ADL_N_ID_4
Definition: pci_ids.h:4078
#define PCI_DID_INTEL_ADP_P_ESPI_8
Definition: pci_ids.h:2987
#define PCI_DID_INTEL_ADP_M_N_ESPI_2
Definition: pci_ids.h:3047
#define PCI_DID_INTEL_ADP_P_ESPI_16
Definition: pci_ids.h:2995
#define PCI_DID_INTEL_ADL_GT1_9
Definition: pci_ids.h:3941
#define PCI_DID_INTEL_ADL_M_GT2
Definition: pci_ids.h:3954
#define PCI_DID_INTEL_ADP_P_ESPI_13
Definition: pci_ids.h:2992
#define PCI_DID_INTEL_ADP_P_ESPI_23
Definition: pci_ids.h:3002
#define PCI_DID_INTEL_ADP_P_ESPI_1
Definition: pci_ids.h:2980
#define PCI_DID_INTEL_ADP_P_ESPI_7
Definition: pci_ids.h:2986
#define PCI_DID_INTEL_ADP_P_ESPI_31
Definition: pci_ids.h:3010
#define PCI_DID_INTEL_ADP_P_ESPI_28
Definition: pci_ids.h:3007
#define PCI_DID_INTEL_ADL_P_GT2_4
Definition: pci_ids.h:3946
#define PCI_DID_INTEL_ADL_P_ID_10
Definition: pci_ids.h:4072
#define PCI_DID_INTEL_ADL_N_GT2
Definition: pci_ids.h:3957
#define PCI_DID_INTEL_ADP_P_ESPI_6
Definition: pci_ids.h:2985
#define PCI_DID_INTEL_ADP_M_N_ESPI_1
Definition: pci_ids.h:3046
#define PCI_DID_INTEL_ADL_P_ID_6
Definition: pci_ids.h:4068
#define PCI_DID_INTEL_ADL_P_ID_9
Definition: pci_ids.h:4071
#define PCI_DID_INTEL_ADL_P_GT2_6
Definition: pci_ids.h:3948
#define PCI_DID_INTEL_ADP_P_ESPI_18
Definition: pci_ids.h:2997
#define PCI_DID_INTEL_ADL_P_GT2_9
Definition: pci_ids.h:3951
#define PCI_DID_INTEL_ADP_P_ESPI_12
Definition: pci_ids.h:2991
#define PCI_DID_INTEL_ADL_N_ID_1
Definition: pci_ids.h:4075
#define PCI_DID_INTEL_ADP_P_ESPI_5
Definition: pci_ids.h:2984
#define PCI_DID_INTEL_ADL_GT1_7
Definition: pci_ids.h:3939
#define PCI_DID_INTEL_ADL_GT1_1
Definition: pci_ids.h:3933
#define PCI_DID_INTEL_ADL_M_ID_1
Definition: pci_ids.h:4073
#define PCI_DID_INTEL_ADP_P_ESPI_21
Definition: pci_ids.h:3000
#define PCI_DID_INTEL_ADL_GT1
Definition: pci_ids.h:3932
#define PCI_DID_INTEL_ADL_P_ID_1
Definition: pci_ids.h:4064
#define PCI_DID_INTEL_ADP_P_ESPI_14
Definition: pci_ids.h:2993
#define PCI_DID_INTEL_ADL_GT0
Definition: pci_ids.h:3931
#define PCI_DID_INTEL_ADP_P_ESPI_20
Definition: pci_ids.h:2999
#define PCI_DID_INTEL_ADP_P_ESPI_2
Definition: pci_ids.h:2981
#define PCI_DID_INTEL_ADL_P_ID_8
Definition: pci_ids.h:4070
#define PCI_DID_INTEL_ADP_P_ESPI_3
Definition: pci_ids.h:2982
#define PCI_DID_INTEL_ADL_M_GT3
Definition: pci_ids.h:3955
#define PCI_DID_INTEL_ADP_P_ESPI_26
Definition: pci_ids.h:3005
#define PCI_DID_INTEL_ADL_N_GT3
Definition: pci_ids.h:3958
#define PCI_DID_INTEL_ADP_P_ESPI_24
Definition: pci_ids.h:3003
#define PCI_DID_INTEL_ADP_P_ESPI_15
Definition: pci_ids.h:2994
#define PCI_DID_INTEL_ADP_P_ESPI_29
Definition: pci_ids.h:3008
#define PCI_DID_INTEL_ADL_GT1_2
Definition: pci_ids.h:3934
#define PCI_DID_INTEL_ADP_P_ESPI_19
Definition: pci_ids.h:2998
#define PCI_DID_INTEL_ADL_N_ID_3
Definition: pci_ids.h:4077
#define PCI_DID_INTEL_ADL_M_ID_2
Definition: pci_ids.h:4074
#define PCI_DID_INTEL_ADP_P_ESPI_4
Definition: pci_ids.h:2983
u32 pci_devfn_t
Definition: pci_type.h:8
u16 mchid
static struct @448 mch_table[]
static void report_igd_info(void)
static struct @450 igd_table[]
static void report_mch_info(void)
static void report_cache_info(void)
static uint16_t get_dev_id(pci_devfn_t dev)
static void report_pch_info(void)
static struct @449 pch_table[]
u16 igdid
const char * name
u32 cpuid
static struct @447 cpu_table[]
static void report_cpu_info(void)
static uint8_t get_dev_revision(pci_devfn_t dev)
u16 espiid
unsigned int cpu_id
Definition: chip.h:47
#define PCH_DEV_ESPI
Definition: pci_devs.h:223
#define SA_DEV_IGD
Definition: pci_devs.h:33
u16 pch_type(void)
Definition: pch.c:20
#define SA_DEV_ROOT
Definition: pci_devs.h:26
unsigned short uint16_t
Definition: stdint.h:11
uint32_t u32
Definition: stdint.h:51
uint16_t u16
Definition: stdint.h:48
unsigned char uint8_t
Definition: stdint.h:8