blob: b89c3b41476ad7c05fd4ddcd18be37c873421201 [file] [log] [blame]
Andrey Petrova00e1042017-06-05 13:22:59 -07001/*
2 * This file is part of the coreboot project.
3 *
4 * Copyright (C) 2014 Google Inc.
Subrata Banikb3585b92018-01-08 13:57:43 +05305 * Copyright (C) 2015-2018 Intel Corporation.
Andrey Petrova00e1042017-06-05 13:22:59 -07006 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; version 2 of the License.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 */
16
17#include <arch/cpu.h>
Kyösti Mälkkif1b58b72019-03-01 13:43:02 +020018#include <device/pci_ops.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070019#include <console/console.h>
20#include <cpu/x86/msr.h>
Usha Pe1508762019-11-28 10:21:02 +053021#include <cpu/x86/name.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070022#include <device/pci.h>
23#include <device/pci_ids.h>
Subrata Banikb3585b92018-01-08 13:57:43 +053024#include <intelblocks/mp_init.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070025#include <soc/bootblock.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070026#include <soc/pch.h>
27#include <soc/pci_devs.h>
28#include <string.h>
29
30#define BIOS_SIGN_ID 0x8B
31
32static struct {
33 u32 cpuid;
34 const char *name;
35} cpu_table[] = {
36 { CPUID_CANNONLAKE_A0, "Cannonlake A0" },
37 { CPUID_CANNONLAKE_B0, "Cannonlake B0" },
38 { CPUID_CANNONLAKE_C0, "Cannonlake C0" },
Lijian Zhaoe9872282018-01-21 21:05:54 -080039 { CPUID_CANNONLAKE_D0, "Cannonlake D0" },
Subrata Banikd8663e02020-02-03 10:51:01 +053040 { CPUID_KABYLAKE_Y0, "Coffeelake D0" },
Subrata Banikd1dfba42019-02-21 17:01:21 +053041 { CPUID_WHISKEYLAKE_V0, "Whiskeylake V0" },
42 { CPUID_WHISKEYLAKE_W0, "Whiskeylake W0" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080043 { CPUID_COFFEELAKE_U0, "Coffeelake U0 (6+2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020044 { CPUID_COFFEELAKE_B0, "Coffeelake B0" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080045 { CPUID_COFFEELAKE_P0, "Coffeelake P0" },
46 { CPUID_COFFEELAKE_R0, "Coffeelake R0" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053047 { CPUID_COMETLAKE_U_A0, "Cometlake-U A0 (6+2)" },
48 { CPUID_COMETLAKE_U_K0_S0, "Cometlake-U K0/S0 (6+2)/(4+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080049 { CPUID_COMETLAKE_H_S_6_2_G0, "Cometlake-H/S G0 (6+2)" },
50 { CPUID_COMETLAKE_H_S_6_2_G1, "Cometlake-H/S G1 (6+2)" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053051 { CPUID_COMETLAKE_H_S_10_2_P0, "Cometlake-H/S P0 (10+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080052 { CPUID_COMETLAKE_H_S_10_2_Q0_P1, "Cometlake-H/S Q0/P1 (10+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070053};
54
55static struct {
56 u16 mchid;
57 const char *name;
58} mch_table[] = {
59 { PCI_DEVICE_ID_INTEL_CNL_ID_U, "Cannonlake-U" },
60 { PCI_DEVICE_ID_INTEL_CNL_ID_Y, "Cannonlake-Y" },
Subrata Banikab9f64d2019-02-22 13:25:04 +053061 { PCI_DEVICE_ID_INTEL_CFL_ID_U, "Coffeelake U (4+3e)" },
Christian Walterccac15a2019-08-13 09:55:37 +020062 { PCI_DEVICE_ID_INTEL_CFL_ID_U_2, "Coffeelake U (2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080063 { PCI_DEVICE_ID_INTEL_WHL_ID_W_4, "Whiskeylake W (4+2)" },
64 { PCI_DEVICE_ID_INTEL_WHL_ID_W_2, "Whiskeylake W (2+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080065 { PCI_DEVICE_ID_INTEL_CFL_ID_H, "Coffeelake-H" },
Christian Walterccac15a2019-08-13 09:55:37 +020066 { PCI_DEVICE_ID_INTEL_CFL_ID_H_4, "Coffeelake-H (4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080067 { PCI_DEVICE_ID_INTEL_CFL_ID_H_8, "Coffeelake-H (8+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080068 { PCI_DEVICE_ID_INTEL_CFL_ID_S, "Coffeelake-S" },
Christian Walterccac15a2019-08-13 09:55:37 +020069 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_2, "Coffeelake-S DT(2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020070 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_4, "Coffeelake-S DT(4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080071 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_8, "Coffeelake-S DT(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020072 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_4, "Coffeelake-S WS(4+2)" },
73 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_6, "Coffeelake-S WS(6+2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080074 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_8, "Coffeelake-S WS(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020075 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_4, "Coffeelake-S S(4)" },
76 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_6, "Coffeelake-S S(6)" },
77 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_8, "Coffeelake-S S(8)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053078 { PCI_DEVICE_ID_INTEL_CML_ULT, "CometLake-U (4+2)" },
Subrata Banikba8af582019-02-27 15:00:55 +053079 { PCI_DEVICE_ID_INTEL_CML_ULT_2_2, "CometLake-U (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053080 { PCI_DEVICE_ID_INTEL_CML_ULT_6_2, "CometLake-U (6+2)" },
81 { PCI_DEVICE_ID_INTEL_CML_ULX, "CometLake-ULX (4+2)" },
82 { PCI_DEVICE_ID_INTEL_CML_S, "CometLake-S (6+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080083 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_P0P1_6_2, "CometLake-S G0/G1/P0/P1 (6+2)" },
84 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_8_2, "CometLake-S P0/P1 (8+2)" },
85 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_10_2, "CometLake-S P0/P1 (10+2)" },
Gaggery Tsai39e1f442020-01-08 15:22:13 -080086 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_4, "CometLake-S G0/G1 (4+2)" },
87 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_2, "CometLake-S G0/G1 (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053088 { PCI_DEVICE_ID_INTEL_CML_H, "CometLake-H (6+2)" },
Jamie Chen6bb9aaf2019-12-20 19:30:33 +080089 { PCI_DEVICE_ID_INTEL_CML_H_4_2, "CometLake-H (4+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053090 { PCI_DEVICE_ID_INTEL_CML_H_8_2, "CometLake-H (8+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070091};
92
93static struct {
Subrata Banikec10fbb2017-12-07 11:48:48 +053094 u16 lpcid;
95 const char *name;
96} pch_table[] = {
97 { PCI_DEVICE_ID_INTEL_CNL_BASE_U_LPC, "Cannonlake-U Base" },
98 { PCI_DEVICE_ID_INTEL_CNL_U_PREMIUM_LPC, "Cannonlake-U Premium" },
99 { PCI_DEVICE_ID_INTEL_CNL_Y_PREMIUM_LPC, "Cannonlake-Y Premium" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200100 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H310, "Cannonlake-H H310" },
101 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H370, "Cannonlake-H H370" },
102 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Z390, "Cannonlake-H Z390" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +0800103 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Q370, "Cannonlake-H Q370" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200104 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_B360, "Cannonlake-H B360" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +0800105 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C246, "Cannonlake-H C246" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200106 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C242, "Cannonlake-H C242" },
107 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_QM370, "Cannonlake-H QM370" },
108 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_HM370, "Cannonlake-H HM370" },
Nico Huber129bc4c2019-05-14 13:17:28 +0200109 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_CM246, "Cannonlake-H CM246" },
Ronak Kanabarda7ffb482019-02-05 01:51:13 +0530110 { PCI_DEVICE_ID_INTEL_CMP_SUPER_U_LPC, "Cometlake-U Super" },
111 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_Y_LPC, "Cometlake-Y Premium" },
112 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_U_LPC, "Cometlake-U Premium" },
113 { PCI_DEVICE_ID_INTEL_CMP_BASE_U_LPC, "Cometlake-U Base" },
114 { PCI_DEVICE_ID_INTEL_CMP_SUPER_Y_LPC, "Cometlake-Y Super" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800115 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_HM470, "Cometlake-H HM470" },
116 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_WM490, "Cometlake-H WM490" },
117 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_QM480, "Cometlake-H QM480" },
118 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_W480, "Cometlake-H W480" },
119 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_H470, "Cometlake-H H470" },
120 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_Z490, "Cometlake-H Z490" },
121 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_Q470, "Cometlake-H Q470" },
Subrata Banikec10fbb2017-12-07 11:48:48 +0530122};
123
124static struct {
Andrey Petrova00e1042017-06-05 13:22:59 -0700125 u16 igdid;
126 const char *name;
127} igd_table[] = {
128 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_1, "Cannonlake ULX GT2" },
129 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_2, "Cannonlake ULX GT1.5" },
130 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_3, "Cannonlake ULX GT1" },
131 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_4, "Cannonlake ULX GT0.5" },
132 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_1, "Cannonlake ULT GT2" },
133 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_2, "Cannonlake ULT GT1.5" },
134 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_3, "Cannonlake ULT GT1" },
135 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_4, "Cannonlake ULT GT0.5" },
Subrata Banikd1dfba42019-02-21 17:01:21 +0530136 { PCI_DEVICE_ID_INTEL_CFL_GT2_ULT, "Coffeelake ULT GT2" },
Lijian Zhao395f1e32019-04-14 12:27:02 -0700137 { PCI_DEVICE_ID_INTEL_WHL_GT1_ULT_1, "Whiskeylake ULT GT1" },
138 { PCI_DEVICE_ID_INTEL_WHL_GT2_ULT_1, "Whiskeylake ULT GT2" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +0800139 { PCI_DEVICE_ID_INTEL_CFL_H_GT2, "Coffeelake-H GT2" },
Nico Huberff3c9642019-05-14 13:18:05 +0200140 { PCI_DEVICE_ID_INTEL_CFL_H_XEON_GT2, "Coffeelake-H Xeon GT2" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +0800141 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_1, "Coffeelake-S GT2" },
142 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_2, "Coffeelake-S GT2" },
143 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_3, "Coffeelake-S GT2" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200144 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_4, "Coffeelake-S GT2" },
Christian Walter19b963c2019-12-09 15:07:13 +0100145 { PCI_DEVICE_ID_INTEL_CFL_U_GT2, "Coffeelake-U GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530146 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_1, "CometLake ULT GT1" },
147 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_2, "CometLake ULT GT1" },
148 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_1, "CometLake ULT GT2" },
149 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_2, "CometLake ULT GT2" },
150 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_3, "CometLake ULT GT1" },
151 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_4, "CometLake ULT GT1" },
152 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_3, "CometLake ULT GT2" },
153 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_4, "CometLake ULT GT2" },
Meera Ravindranath970f1a42019-08-27 16:16:56 +0530154 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_5, "CometLake ULT GT2" },
155 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_6, "CometLake ULT GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530156 { PCI_DEVICE_ID_INTEL_CML_GT1_ULX_1, "CometLake ULX GT1" },
157 { PCI_DEVICE_ID_INTEL_CML_GT2_ULX_1, "CometLake ULX GT2" },
158 { PCI_DEVICE_ID_INTEL_CML_GT1_S_1, "CometLake S GT1" },
159 { PCI_DEVICE_ID_INTEL_CML_GT1_S_2, "CometLake S GT1" },
160 { PCI_DEVICE_ID_INTEL_CML_GT2_S_1, "CometLake S GT2" },
161 { PCI_DEVICE_ID_INTEL_CML_GT2_S_2, "CometLake S GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800162 { PCI_DEVICE_ID_INTEL_CML_GT2_S_G0, "CometLake S GT2 G0" },
163 { PCI_DEVICE_ID_INTEL_CML_GT2_S_P0, "CometLake S GT2 P0" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530164 { PCI_DEVICE_ID_INTEL_CML_GT1_H_1, "CometLake H GT1" },
165 { PCI_DEVICE_ID_INTEL_CML_GT1_H_2, "CometLake H GT1" },
166 { PCI_DEVICE_ID_INTEL_CML_GT2_H_1, "CometLake H GT2" },
167 { PCI_DEVICE_ID_INTEL_CML_GT2_H_2, "CometLake H GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800168 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R0, "CometLake H GT2 R0" },
169 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R1, "CometLake H GT2 R1" },
170
Andrey Petrova00e1042017-06-05 13:22:59 -0700171};
172
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200173static uint8_t get_dev_revision(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530174{
175 return pci_read_config8(dev, PCI_REVISION_ID);
176}
177
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200178static uint16_t get_dev_id(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530179{
180 return pci_read_config16(dev, PCI_DEVICE_ID);
181}
182
Andrey Petrova00e1042017-06-05 13:22:59 -0700183static void report_cpu_info(void)
184{
Usha Pe1508762019-11-28 10:21:02 +0530185 u32 i, cpu_id, cpu_feature_flag;
186 char cpu_name[49];
Andrey Petrova00e1042017-06-05 13:22:59 -0700187 int vt, txt, aes;
188 msr_t microcode_ver;
Elyes HAOUAS39303d52018-07-08 12:40:45 +0200189 static const char *const mode[] = {"NOT ", ""};
Andrey Petrova00e1042017-06-05 13:22:59 -0700190 const char *cpu_type = "Unknown";
191
Usha Pe1508762019-11-28 10:21:02 +0530192 fill_processor_name(cpu_name);
Andrey Petrova00e1042017-06-05 13:22:59 -0700193
194 microcode_ver.lo = 0;
195 microcode_ver.hi = 0;
196 wrmsr(BIOS_SIGN_ID, microcode_ver);
Subrata Banik53b08c32018-12-10 14:11:35 +0530197 cpu_id = cpu_get_cpuid();
Andrey Petrova00e1042017-06-05 13:22:59 -0700198 microcode_ver = rdmsr(BIOS_SIGN_ID);
199
200 /* Look for string to match the name */
201 for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
Subrata Banik53b08c32018-12-10 14:11:35 +0530202 if (cpu_table[i].cpuid == cpu_id) {
Andrey Petrova00e1042017-06-05 13:22:59 -0700203 cpu_type = cpu_table[i].name;
204 break;
205 }
206 }
207
208 printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
209 printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
Subrata Banik53b08c32018-12-10 14:11:35 +0530210 cpu_id, cpu_type, microcode_ver.hi);
Andrey Petrova00e1042017-06-05 13:22:59 -0700211
Subrata Banik53b08c32018-12-10 14:11:35 +0530212 cpu_feature_flag = cpu_get_feature_flags_ecx();
213 aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
214 txt = (cpu_feature_flag & CPUID_SMX) ? 1 : 0;
215 vt = (cpu_feature_flag & CPUID_VMX) ? 1 : 0;
Andrey Petrova00e1042017-06-05 13:22:59 -0700216 printk(BIOS_DEBUG,
217 "CPU: AES %ssupported, TXT %ssupported, VT %ssupported\n",
218 mode[aes], mode[txt], mode[vt]);
219}
220
221static void report_mch_info(void)
222{
223 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200224 pci_devfn_t dev = SA_DEV_ROOT;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530225 uint16_t mchid = get_dev_id(dev);
226 uint8_t mch_revision = get_dev_revision(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700227 const char *mch_type = "Unknown";
228
229 for (i = 0; i < ARRAY_SIZE(mch_table); i++) {
230 if (mch_table[i].mchid == mchid) {
231 mch_type = mch_table[i].name;
232 break;
233 }
234 }
235
236 printk(BIOS_DEBUG, "MCH: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530237 mchid, mch_revision, mch_type);
238}
239
240static void report_pch_info(void)
241{
242 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200243 pci_devfn_t dev = PCH_DEV_LPC;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530244 uint16_t lpcid = get_dev_id(dev);
245 const char *pch_type = "Unknown";
246
247 for (i = 0; i < ARRAY_SIZE(pch_table); i++) {
248 if (pch_table[i].lpcid == lpcid) {
249 pch_type = pch_table[i].name;
250 break;
251 }
252 }
253 printk(BIOS_DEBUG, "PCH: device id %04x (rev %02x) is %s\n",
254 lpcid, get_dev_revision(dev), pch_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700255}
256
257static void report_igd_info(void)
258{
259 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200260 pci_devfn_t dev = SA_DEV_IGD;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530261 uint16_t igdid = get_dev_id(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700262 const char *igd_type = "Unknown";
263
264 for (i = 0; i < ARRAY_SIZE(igd_table); i++) {
265 if (igd_table[i].igdid == igdid) {
266 igd_type = igd_table[i].name;
267 break;
268 }
269 }
270 printk(BIOS_DEBUG, "IGD: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530271 igdid, get_dev_revision(dev), igd_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700272}
273
274void report_platform_info(void)
275{
276 report_cpu_info();
277 report_mch_info();
Subrata Banikec10fbb2017-12-07 11:48:48 +0530278 report_pch_info();
Andrey Petrova00e1042017-06-05 13:22:59 -0700279 report_igd_info();
280}