blob: 578cbbf9771f2719f33dcff5690555b3f250f5ba [file] [log] [blame]
Angel Ponsf5627e82020-04-05 15:46:52 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Andrey Petrova00e1042017-06-05 13:22:59 -07002
3#include <arch/cpu.h>
Kyösti Mälkkif1b58b72019-03-01 13:43:02 +02004#include <device/pci_ops.h>
Andrey Petrova00e1042017-06-05 13:22:59 -07005#include <console/console.h>
Subrata Banik3b5a47b2021-07-16 13:39:32 +05306#include <cpu/intel/cpu_ids.h>
Subrata Banikb7db12b2020-08-04 18:01:27 +05307#include <cpu/intel/microcode.h>
Andrey Petrova00e1042017-06-05 13:22:59 -07008#include <cpu/x86/msr.h>
Usha Pe1508762019-11-28 10:21:02 +05309#include <cpu/x86/name.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070010#include <device/pci.h>
11#include <device/pci_ids.h>
12#include <soc/bootblock.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070013#include <soc/pch.h>
14#include <soc/pci_devs.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070015
Andrey Petrova00e1042017-06-05 13:22:59 -070016static struct {
17 u32 cpuid;
18 const char *name;
19} cpu_table[] = {
20 { CPUID_CANNONLAKE_A0, "Cannonlake A0" },
21 { CPUID_CANNONLAKE_B0, "Cannonlake B0" },
22 { CPUID_CANNONLAKE_C0, "Cannonlake C0" },
Lijian Zhaoe9872282018-01-21 21:05:54 -080023 { CPUID_CANNONLAKE_D0, "Cannonlake D0" },
Subrata Banikd8663e02020-02-03 10:51:01 +053024 { CPUID_KABYLAKE_Y0, "Coffeelake D0" },
Subrata Banikd1dfba42019-02-21 17:01:21 +053025 { CPUID_WHISKEYLAKE_V0, "Whiskeylake V0" },
26 { CPUID_WHISKEYLAKE_W0, "Whiskeylake W0" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080027 { CPUID_COFFEELAKE_U0, "Coffeelake U0 (6+2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020028 { CPUID_COFFEELAKE_B0, "Coffeelake B0" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080029 { CPUID_COFFEELAKE_P0, "Coffeelake P0" },
30 { CPUID_COFFEELAKE_R0, "Coffeelake R0" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053031 { CPUID_COMETLAKE_U_A0, "Cometlake-U A0 (6+2)" },
32 { CPUID_COMETLAKE_U_K0_S0, "Cometlake-U K0/S0 (6+2)/(4+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080033 { CPUID_COMETLAKE_H_S_6_2_G0, "Cometlake-H/S G0 (6+2)" },
34 { CPUID_COMETLAKE_H_S_6_2_G1, "Cometlake-H/S G1 (6+2)" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053035 { CPUID_COMETLAKE_H_S_10_2_P0, "Cometlake-H/S P0 (10+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080036 { CPUID_COMETLAKE_H_S_10_2_Q0_P1, "Cometlake-H/S Q0/P1 (10+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070037};
38
39static struct {
40 u16 mchid;
41 const char *name;
42} mch_table[] = {
Felix Singer43b7f412022-03-07 04:34:52 +010043 { PCI_DID_INTEL_CNL_ID_U, "Cannonlake-U" },
44 { PCI_DID_INTEL_CNL_ID_Y, "Cannonlake-Y" },
45 { PCI_DID_INTEL_CFL_ID_U, "Coffeelake U (4+3e)" },
46 { PCI_DID_INTEL_CFL_ID_U_2, "Coffeelake U (2)" },
47 { PCI_DID_INTEL_WHL_ID_W_4, "Whiskeylake W (4+2)" },
48 { PCI_DID_INTEL_WHL_ID_W_2, "Whiskeylake W (2+2)" },
49 { PCI_DID_INTEL_CFL_ID_H, "Coffeelake-H" },
50 { PCI_DID_INTEL_CFL_ID_H_4, "Coffeelake-H (4)" },
51 { PCI_DID_INTEL_CFL_ID_H_8, "Coffeelake-H (8+2)" },
52 { PCI_DID_INTEL_CFL_ID_S, "Coffeelake-S" },
53 { PCI_DID_INTEL_CFL_ID_S_DT_2, "Coffeelake-S DT(2)" },
54 { PCI_DID_INTEL_CFL_ID_S_DT_4, "Coffeelake-S DT(4)" },
55 { PCI_DID_INTEL_CFL_ID_S_DT_8, "Coffeelake-S DT(8+2)" },
56 { PCI_DID_INTEL_CFL_ID_S_WS_4, "Coffeelake-S WS(4+2)" },
57 { PCI_DID_INTEL_CFL_ID_S_WS_6, "Coffeelake-S WS(6+2)" },
58 { PCI_DID_INTEL_CFL_ID_S_WS_8, "Coffeelake-S WS(8+2)" },
59 { PCI_DID_INTEL_CFL_ID_S_S_4, "Coffeelake-S S(4)" },
60 { PCI_DID_INTEL_CFL_ID_S_S_6, "Coffeelake-S S(6)" },
61 { PCI_DID_INTEL_CFL_ID_S_S_8, "Coffeelake-S S(8)" },
62 { PCI_DID_INTEL_CML_ULT, "CometLake-U (4+2)" },
63 { PCI_DID_INTEL_CML_ULT_2_2, "CometLake-U (2+2)" },
64 { PCI_DID_INTEL_CML_ULT_6_2, "CometLake-U (6+2)" },
65 { PCI_DID_INTEL_CML_ULX, "CometLake-ULX (4+2)" },
66 { PCI_DID_INTEL_CML_S, "CometLake-S (6+2)" },
67 { PCI_DID_INTEL_CML_S_G0G1_P0P1_6_2, "CometLake-S G0/G1/P0/P1 (6+2)" },
68 { PCI_DID_INTEL_CML_S_P0P1_8_2, "CometLake-S P0/P1 (8+2)" },
69 { PCI_DID_INTEL_CML_S_P0P1_10_2, "CometLake-S P0/P1 (10+2)" },
70 { PCI_DID_INTEL_CML_S_G0G1_4, "CometLake-S G0/G1 (4+2)" },
71 { PCI_DID_INTEL_CML_S_G0G1_2, "CometLake-S G0/G1 (2+2)" },
72 { PCI_DID_INTEL_CML_H, "CometLake-H (6+2)" },
73 { PCI_DID_INTEL_CML_H_4_2, "CometLake-H (4+2)" },
74 { PCI_DID_INTEL_CML_H_8_2, "CometLake-H (8+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070075};
76
77static struct {
Subrata Banikec10fbb2017-12-07 11:48:48 +053078 u16 lpcid;
79 const char *name;
80} pch_table[] = {
Felix Singer43b7f412022-03-07 04:34:52 +010081 { PCI_DID_INTEL_CNL_BASE_U_LPC, "Cannonlake-U Base" },
82 { PCI_DID_INTEL_CNL_U_PREMIUM_LPC, "Cannonlake-U Premium" },
83 { PCI_DID_INTEL_CNL_Y_PREMIUM_LPC, "Cannonlake-Y Premium" },
84 { PCI_DID_INTEL_CNP_H_LPC_H310, "Cannonlake-H H310" },
85 { PCI_DID_INTEL_CNP_H_LPC_H370, "Cannonlake-H H370" },
86 { PCI_DID_INTEL_CNP_H_LPC_Z390, "Cannonlake-H Z390" },
87 { PCI_DID_INTEL_CNP_H_LPC_Q370, "Cannonlake-H Q370" },
88 { PCI_DID_INTEL_CNP_H_LPC_B360, "Cannonlake-H B360" },
89 { PCI_DID_INTEL_CNP_H_LPC_C246, "Cannonlake-H C246" },
90 { PCI_DID_INTEL_CNP_H_LPC_C242, "Cannonlake-H C242" },
91 { PCI_DID_INTEL_CNP_H_LPC_QM370, "Cannonlake-H QM370" },
92 { PCI_DID_INTEL_CNP_H_LPC_HM370, "Cannonlake-H HM370" },
93 { PCI_DID_INTEL_CNP_H_LPC_CM246, "Cannonlake-H CM246" },
94 { PCI_DID_INTEL_CMP_SUPER_U_LPC, "Cometlake-U Super" },
95 { PCI_DID_INTEL_CMP_PREMIUM_Y_LPC, "Cometlake-Y Premium" },
96 { PCI_DID_INTEL_CMP_PREMIUM_U_LPC, "Cometlake-U Premium" },
97 { PCI_DID_INTEL_CMP_BASE_U_LPC, "Cometlake-U Base" },
98 { PCI_DID_INTEL_CMP_SUPER_Y_LPC, "Cometlake-Y Super" },
99 { PCI_DID_INTEL_CMP_H_LPC_HM470, "Cometlake-H HM470" },
100 { PCI_DID_INTEL_CMP_H_LPC_WM490, "Cometlake-H WM490" },
101 { PCI_DID_INTEL_CMP_H_LPC_QM480, "Cometlake-H QM480" },
102 { PCI_DID_INTEL_CMP_H_LPC_W480, "Cometlake-H W480" },
103 { PCI_DID_INTEL_CMP_H_LPC_H470, "Cometlake-H H470" },
104 { PCI_DID_INTEL_CMP_H_LPC_Z490, "Cometlake-H Z490" },
105 { PCI_DID_INTEL_CMP_H_LPC_Q470, "Cometlake-H Q470" },
Subrata Banikec10fbb2017-12-07 11:48:48 +0530106};
107
108static struct {
Andrey Petrova00e1042017-06-05 13:22:59 -0700109 u16 igdid;
110 const char *name;
111} igd_table[] = {
Felix Singer43b7f412022-03-07 04:34:52 +0100112 { PCI_DID_INTEL_CNL_GT2_ULX_1, "Cannonlake ULX GT2" },
113 { PCI_DID_INTEL_CNL_GT2_ULX_2, "Cannonlake ULX GT1.5" },
114 { PCI_DID_INTEL_CNL_GT2_ULX_3, "Cannonlake ULX GT1" },
115 { PCI_DID_INTEL_CNL_GT2_ULX_4, "Cannonlake ULX GT0.5" },
116 { PCI_DID_INTEL_CNL_GT2_ULT_1, "Cannonlake ULT GT2" },
117 { PCI_DID_INTEL_CNL_GT2_ULT_2, "Cannonlake ULT GT1.5" },
118 { PCI_DID_INTEL_CNL_GT2_ULT_3, "Cannonlake ULT GT1" },
119 { PCI_DID_INTEL_CNL_GT2_ULT_4, "Cannonlake ULT GT0.5" },
120 { PCI_DID_INTEL_CFL_GT2_ULT, "Coffeelake ULT GT2" },
121 { PCI_DID_INTEL_WHL_GT1_ULT_1, "Whiskeylake ULT GT1" },
122 { PCI_DID_INTEL_WHL_GT2_ULT_1, "Whiskeylake ULT GT2" },
123 { PCI_DID_INTEL_CFL_H_GT2, "Coffeelake-H GT2" },
124 { PCI_DID_INTEL_CFL_H_XEON_GT2, "Coffeelake-H Xeon GT2" },
125 { PCI_DID_INTEL_CFL_S_GT1_1, "Coffeelake-S GT1" },
126 { PCI_DID_INTEL_CFL_S_GT1_2, "Coffeelake-S GT1" },
127 { PCI_DID_INTEL_CFL_S_GT2_1, "Coffeelake-S GT2" },
128 { PCI_DID_INTEL_CFL_S_GT2_2, "Coffeelake-S GT2" },
129 { PCI_DID_INTEL_CFL_S_GT2_3, "Coffeelake-S GT2" },
130 { PCI_DID_INTEL_CFL_S_GT2_4, "Coffeelake-S GT2" },
131 { PCI_DID_INTEL_CFL_S_GT2_5, "Coffeelake-S GT2" },
132 { PCI_DID_INTEL_CML_GT1_ULT_1, "CometLake ULT GT1" },
133 { PCI_DID_INTEL_CML_GT1_ULT_2, "CometLake ULT GT1" },
134 { PCI_DID_INTEL_CML_GT2_ULT_1, "CometLake ULT GT2" },
135 { PCI_DID_INTEL_CML_GT2_ULT_2, "CometLake ULT GT2" },
136 { PCI_DID_INTEL_CML_GT1_ULT_3, "CometLake ULT GT1" },
137 { PCI_DID_INTEL_CML_GT1_ULT_4, "CometLake ULT GT1" },
138 { PCI_DID_INTEL_CML_GT2_ULT_3, "CometLake ULT GT2" },
139 { PCI_DID_INTEL_CML_GT2_ULT_4, "CometLake ULT GT2" },
140 { PCI_DID_INTEL_CML_GT2_ULT_5, "CometLake ULT GT2" },
141 { PCI_DID_INTEL_CML_GT2_ULT_6, "CometLake ULT GT2" },
142 { PCI_DID_INTEL_CML_GT1_ULX_1, "CometLake ULX GT1" },
143 { PCI_DID_INTEL_CML_GT2_ULX_1, "CometLake ULX GT2" },
144 { PCI_DID_INTEL_CML_GT1_S_1, "CometLake S GT1" },
145 { PCI_DID_INTEL_CML_GT1_S_2, "CometLake S GT1" },
146 { PCI_DID_INTEL_CML_GT2_S_1, "CometLake S GT2" },
147 { PCI_DID_INTEL_CML_GT2_S_2, "CometLake S GT2" },
148 { PCI_DID_INTEL_CML_GT2_S_G0, "CometLake S GT2 G0" },
149 { PCI_DID_INTEL_CML_GT2_S_P0, "CometLake S GT2 P0" },
150 { PCI_DID_INTEL_CML_GT1_H_1, "CometLake H GT1" },
151 { PCI_DID_INTEL_CML_GT1_H_2, "CometLake H GT1" },
152 { PCI_DID_INTEL_CML_GT2_H_1, "CometLake H GT2" },
153 { PCI_DID_INTEL_CML_GT2_H_2, "CometLake H GT2" },
154 { PCI_DID_INTEL_CML_GT2_H_R0, "CometLake H GT2 R0" },
155 { PCI_DID_INTEL_CML_GT2_H_R1, "CometLake H GT2 R1" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800156
Andrey Petrova00e1042017-06-05 13:22:59 -0700157};
158
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200159static uint8_t get_dev_revision(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530160{
161 return pci_read_config8(dev, PCI_REVISION_ID);
162}
163
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200164static uint16_t get_dev_id(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530165{
166 return pci_read_config16(dev, PCI_DEVICE_ID);
167}
168
Andrey Petrova00e1042017-06-05 13:22:59 -0700169static void report_cpu_info(void)
170{
Usha Pe1508762019-11-28 10:21:02 +0530171 u32 i, cpu_id, cpu_feature_flag;
172 char cpu_name[49];
Andrey Petrova00e1042017-06-05 13:22:59 -0700173 int vt, txt, aes;
Elyes HAOUAS39303d52018-07-08 12:40:45 +0200174 static const char *const mode[] = {"NOT ", ""};
Andrey Petrova00e1042017-06-05 13:22:59 -0700175 const char *cpu_type = "Unknown";
176
Usha Pe1508762019-11-28 10:21:02 +0530177 fill_processor_name(cpu_name);
Subrata Banik53b08c32018-12-10 14:11:35 +0530178 cpu_id = cpu_get_cpuid();
Andrey Petrova00e1042017-06-05 13:22:59 -0700179
180 /* Look for string to match the name */
181 for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
Subrata Banik53b08c32018-12-10 14:11:35 +0530182 if (cpu_table[i].cpuid == cpu_id) {
Andrey Petrova00e1042017-06-05 13:22:59 -0700183 cpu_type = cpu_table[i].name;
184 break;
185 }
186 }
187
188 printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
189 printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
Subrata Banikb7db12b2020-08-04 18:01:27 +0530190 cpu_id, cpu_type, get_current_microcode_rev());
Andrey Petrova00e1042017-06-05 13:22:59 -0700191
Subrata Banik53b08c32018-12-10 14:11:35 +0530192 cpu_feature_flag = cpu_get_feature_flags_ecx();
193 aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
194 txt = (cpu_feature_flag & CPUID_SMX) ? 1 : 0;
195 vt = (cpu_feature_flag & CPUID_VMX) ? 1 : 0;
Andrey Petrova00e1042017-06-05 13:22:59 -0700196 printk(BIOS_DEBUG,
197 "CPU: AES %ssupported, TXT %ssupported, VT %ssupported\n",
198 mode[aes], mode[txt], mode[vt]);
199}
200
201static void report_mch_info(void)
202{
203 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200204 pci_devfn_t dev = SA_DEV_ROOT;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530205 uint16_t mchid = get_dev_id(dev);
206 uint8_t mch_revision = get_dev_revision(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700207 const char *mch_type = "Unknown";
208
209 for (i = 0; i < ARRAY_SIZE(mch_table); i++) {
210 if (mch_table[i].mchid == mchid) {
211 mch_type = mch_table[i].name;
212 break;
213 }
214 }
215
216 printk(BIOS_DEBUG, "MCH: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530217 mchid, mch_revision, mch_type);
218}
219
220static void report_pch_info(void)
221{
222 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200223 pci_devfn_t dev = PCH_DEV_LPC;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530224 uint16_t lpcid = get_dev_id(dev);
225 const char *pch_type = "Unknown";
226
227 for (i = 0; i < ARRAY_SIZE(pch_table); i++) {
228 if (pch_table[i].lpcid == lpcid) {
229 pch_type = pch_table[i].name;
230 break;
231 }
232 }
233 printk(BIOS_DEBUG, "PCH: device id %04x (rev %02x) is %s\n",
234 lpcid, get_dev_revision(dev), pch_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700235}
236
237static void report_igd_info(void)
238{
239 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200240 pci_devfn_t dev = SA_DEV_IGD;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530241 uint16_t igdid = get_dev_id(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700242 const char *igd_type = "Unknown";
243
244 for (i = 0; i < ARRAY_SIZE(igd_table); i++) {
245 if (igd_table[i].igdid == igdid) {
246 igd_type = igd_table[i].name;
247 break;
248 }
249 }
250 printk(BIOS_DEBUG, "IGD: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530251 igdid, get_dev_revision(dev), igd_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700252}
253
254void report_platform_info(void)
255{
256 report_cpu_info();
257 report_mch_info();
Subrata Banikec10fbb2017-12-07 11:48:48 +0530258 report_pch_info();
Andrey Petrova00e1042017-06-05 13:22:59 -0700259 report_igd_info();
260}