blob: b29cf7dd9eab3dec1ccf52ba4d3c300017d5e7dc [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>
6#include <cpu/x86/msr.h>
Usha Pe1508762019-11-28 10:21:02 +05307#include <cpu/x86/name.h>
Andrey Petrova00e1042017-06-05 13:22:59 -07008#include <device/pci.h>
9#include <device/pci_ids.h>
Subrata Banikb3585b92018-01-08 13:57:43 +053010#include <intelblocks/mp_init.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070011#include <soc/bootblock.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070012#include <soc/pch.h>
13#include <soc/pci_devs.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070014
15#define BIOS_SIGN_ID 0x8B
16
17static struct {
18 u32 cpuid;
19 const char *name;
20} cpu_table[] = {
21 { CPUID_CANNONLAKE_A0, "Cannonlake A0" },
22 { CPUID_CANNONLAKE_B0, "Cannonlake B0" },
23 { CPUID_CANNONLAKE_C0, "Cannonlake C0" },
Lijian Zhaoe9872282018-01-21 21:05:54 -080024 { CPUID_CANNONLAKE_D0, "Cannonlake D0" },
Subrata Banikd8663e02020-02-03 10:51:01 +053025 { CPUID_KABYLAKE_Y0, "Coffeelake D0" },
Subrata Banikd1dfba42019-02-21 17:01:21 +053026 { CPUID_WHISKEYLAKE_V0, "Whiskeylake V0" },
27 { CPUID_WHISKEYLAKE_W0, "Whiskeylake W0" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080028 { CPUID_COFFEELAKE_U0, "Coffeelake U0 (6+2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020029 { CPUID_COFFEELAKE_B0, "Coffeelake B0" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080030 { CPUID_COFFEELAKE_P0, "Coffeelake P0" },
31 { CPUID_COFFEELAKE_R0, "Coffeelake R0" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053032 { CPUID_COMETLAKE_U_A0, "Cometlake-U A0 (6+2)" },
33 { CPUID_COMETLAKE_U_K0_S0, "Cometlake-U K0/S0 (6+2)/(4+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080034 { CPUID_COMETLAKE_H_S_6_2_G0, "Cometlake-H/S G0 (6+2)" },
35 { CPUID_COMETLAKE_H_S_6_2_G1, "Cometlake-H/S G1 (6+2)" },
Ronak Kanabar128bb2a2019-01-29 19:52:53 +053036 { CPUID_COMETLAKE_H_S_10_2_P0, "Cometlake-H/S P0 (10+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080037 { CPUID_COMETLAKE_H_S_10_2_Q0_P1, "Cometlake-H/S Q0/P1 (10+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070038};
39
40static struct {
41 u16 mchid;
42 const char *name;
43} mch_table[] = {
44 { PCI_DEVICE_ID_INTEL_CNL_ID_U, "Cannonlake-U" },
45 { PCI_DEVICE_ID_INTEL_CNL_ID_Y, "Cannonlake-Y" },
Subrata Banikab9f64d2019-02-22 13:25:04 +053046 { PCI_DEVICE_ID_INTEL_CFL_ID_U, "Coffeelake U (4+3e)" },
Christian Walterccac15a2019-08-13 09:55:37 +020047 { PCI_DEVICE_ID_INTEL_CFL_ID_U_2, "Coffeelake U (2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080048 { PCI_DEVICE_ID_INTEL_WHL_ID_W_4, "Whiskeylake W (4+2)" },
49 { PCI_DEVICE_ID_INTEL_WHL_ID_W_2, "Whiskeylake W (2+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080050 { PCI_DEVICE_ID_INTEL_CFL_ID_H, "Coffeelake-H" },
Christian Walterccac15a2019-08-13 09:55:37 +020051 { PCI_DEVICE_ID_INTEL_CFL_ID_H_4, "Coffeelake-H (4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080052 { PCI_DEVICE_ID_INTEL_CFL_ID_H_8, "Coffeelake-H (8+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080053 { PCI_DEVICE_ID_INTEL_CFL_ID_S, "Coffeelake-S" },
Christian Walterccac15a2019-08-13 09:55:37 +020054 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_2, "Coffeelake-S DT(2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020055 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_4, "Coffeelake-S DT(4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080056 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_8, "Coffeelake-S DT(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020057 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_4, "Coffeelake-S WS(4+2)" },
58 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_6, "Coffeelake-S WS(6+2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080059 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_8, "Coffeelake-S WS(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020060 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_4, "Coffeelake-S S(4)" },
61 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_6, "Coffeelake-S S(6)" },
62 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_8, "Coffeelake-S S(8)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053063 { PCI_DEVICE_ID_INTEL_CML_ULT, "CometLake-U (4+2)" },
Subrata Banikba8af582019-02-27 15:00:55 +053064 { PCI_DEVICE_ID_INTEL_CML_ULT_2_2, "CometLake-U (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053065 { PCI_DEVICE_ID_INTEL_CML_ULT_6_2, "CometLake-U (6+2)" },
66 { PCI_DEVICE_ID_INTEL_CML_ULX, "CometLake-ULX (4+2)" },
67 { PCI_DEVICE_ID_INTEL_CML_S, "CometLake-S (6+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080068 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_P0P1_6_2, "CometLake-S G0/G1/P0/P1 (6+2)" },
69 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_8_2, "CometLake-S P0/P1 (8+2)" },
70 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_10_2, "CometLake-S P0/P1 (10+2)" },
Gaggery Tsai39e1f442020-01-08 15:22:13 -080071 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_4, "CometLake-S G0/G1 (4+2)" },
72 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_2, "CometLake-S G0/G1 (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053073 { PCI_DEVICE_ID_INTEL_CML_H, "CometLake-H (6+2)" },
Jamie Chen6bb9aaf2019-12-20 19:30:33 +080074 { PCI_DEVICE_ID_INTEL_CML_H_4_2, "CometLake-H (4+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053075 { PCI_DEVICE_ID_INTEL_CML_H_8_2, "CometLake-H (8+2)" },
Andrey Petrova00e1042017-06-05 13:22:59 -070076};
77
78static struct {
Subrata Banikec10fbb2017-12-07 11:48:48 +053079 u16 lpcid;
80 const char *name;
81} pch_table[] = {
82 { PCI_DEVICE_ID_INTEL_CNL_BASE_U_LPC, "Cannonlake-U Base" },
83 { PCI_DEVICE_ID_INTEL_CNL_U_PREMIUM_LPC, "Cannonlake-U Premium" },
84 { PCI_DEVICE_ID_INTEL_CNL_Y_PREMIUM_LPC, "Cannonlake-Y Premium" },
Felix Singerd298ffe2019-07-28 13:27:11 +020085 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H310, "Cannonlake-H H310" },
86 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H370, "Cannonlake-H H370" },
87 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Z390, "Cannonlake-H Z390" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080088 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Q370, "Cannonlake-H Q370" },
Felix Singerd298ffe2019-07-28 13:27:11 +020089 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_B360, "Cannonlake-H B360" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080090 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C246, "Cannonlake-H C246" },
Felix Singerd298ffe2019-07-28 13:27:11 +020091 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C242, "Cannonlake-H C242" },
92 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_QM370, "Cannonlake-H QM370" },
93 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_HM370, "Cannonlake-H HM370" },
Nico Huber129bc4c2019-05-14 13:17:28 +020094 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_CM246, "Cannonlake-H CM246" },
Ronak Kanabarda7ffb482019-02-05 01:51:13 +053095 { PCI_DEVICE_ID_INTEL_CMP_SUPER_U_LPC, "Cometlake-U Super" },
96 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_Y_LPC, "Cometlake-Y Premium" },
97 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_U_LPC, "Cometlake-U Premium" },
98 { PCI_DEVICE_ID_INTEL_CMP_BASE_U_LPC, "Cometlake-U Base" },
99 { PCI_DEVICE_ID_INTEL_CMP_SUPER_Y_LPC, "Cometlake-Y Super" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800100 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_HM470, "Cometlake-H HM470" },
101 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_WM490, "Cometlake-H WM490" },
102 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_QM480, "Cometlake-H QM480" },
103 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_W480, "Cometlake-H W480" },
104 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_H470, "Cometlake-H H470" },
105 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_Z490, "Cometlake-H Z490" },
106 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_Q470, "Cometlake-H Q470" },
Subrata Banikec10fbb2017-12-07 11:48:48 +0530107};
108
109static struct {
Andrey Petrova00e1042017-06-05 13:22:59 -0700110 u16 igdid;
111 const char *name;
112} igd_table[] = {
113 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_1, "Cannonlake ULX GT2" },
114 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_2, "Cannonlake ULX GT1.5" },
115 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_3, "Cannonlake ULX GT1" },
116 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_4, "Cannonlake ULX GT0.5" },
117 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_1, "Cannonlake ULT GT2" },
118 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_2, "Cannonlake ULT GT1.5" },
119 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_3, "Cannonlake ULT GT1" },
120 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_4, "Cannonlake ULT GT0.5" },
Subrata Banikd1dfba42019-02-21 17:01:21 +0530121 { PCI_DEVICE_ID_INTEL_CFL_GT2_ULT, "Coffeelake ULT GT2" },
Lijian Zhao395f1e32019-04-14 12:27:02 -0700122 { PCI_DEVICE_ID_INTEL_WHL_GT1_ULT_1, "Whiskeylake ULT GT1" },
123 { PCI_DEVICE_ID_INTEL_WHL_GT2_ULT_1, "Whiskeylake ULT GT2" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +0800124 { PCI_DEVICE_ID_INTEL_CFL_H_GT2, "Coffeelake-H GT2" },
Nico Huberff3c9642019-05-14 13:18:05 +0200125 { PCI_DEVICE_ID_INTEL_CFL_H_XEON_GT2, "Coffeelake-H Xeon GT2" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +0800126 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_1, "Coffeelake-S GT2" },
127 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_2, "Coffeelake-S GT2" },
128 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_3, "Coffeelake-S GT2" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200129 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_4, "Coffeelake-S GT2" },
Christian Walter19b963c2019-12-09 15:07:13 +0100130 { PCI_DEVICE_ID_INTEL_CFL_U_GT2, "Coffeelake-U GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530131 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_1, "CometLake ULT GT1" },
132 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_2, "CometLake ULT GT1" },
133 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_1, "CometLake ULT GT2" },
134 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_2, "CometLake ULT GT2" },
135 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_3, "CometLake ULT GT1" },
136 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_4, "CometLake ULT GT1" },
137 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_3, "CometLake ULT GT2" },
138 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_4, "CometLake ULT GT2" },
Meera Ravindranath970f1a42019-08-27 16:16:56 +0530139 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_5, "CometLake ULT GT2" },
140 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_6, "CometLake ULT GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530141 { PCI_DEVICE_ID_INTEL_CML_GT1_ULX_1, "CometLake ULX GT1" },
142 { PCI_DEVICE_ID_INTEL_CML_GT2_ULX_1, "CometLake ULX GT2" },
143 { PCI_DEVICE_ID_INTEL_CML_GT1_S_1, "CometLake S GT1" },
144 { PCI_DEVICE_ID_INTEL_CML_GT1_S_2, "CometLake S GT1" },
145 { PCI_DEVICE_ID_INTEL_CML_GT2_S_1, "CometLake S GT2" },
146 { PCI_DEVICE_ID_INTEL_CML_GT2_S_2, "CometLake S GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800147 { PCI_DEVICE_ID_INTEL_CML_GT2_S_G0, "CometLake S GT2 G0" },
148 { PCI_DEVICE_ID_INTEL_CML_GT2_S_P0, "CometLake S GT2 P0" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530149 { PCI_DEVICE_ID_INTEL_CML_GT1_H_1, "CometLake H GT1" },
150 { PCI_DEVICE_ID_INTEL_CML_GT1_H_2, "CometLake H GT1" },
151 { PCI_DEVICE_ID_INTEL_CML_GT2_H_1, "CometLake H GT2" },
152 { PCI_DEVICE_ID_INTEL_CML_GT2_H_2, "CometLake H GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800153 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R0, "CometLake H GT2 R0" },
154 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R1, "CometLake H GT2 R1" },
155
Andrey Petrova00e1042017-06-05 13:22:59 -0700156};
157
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200158static uint8_t get_dev_revision(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530159{
160 return pci_read_config8(dev, PCI_REVISION_ID);
161}
162
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200163static uint16_t get_dev_id(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530164{
165 return pci_read_config16(dev, PCI_DEVICE_ID);
166}
167
Andrey Petrova00e1042017-06-05 13:22:59 -0700168static void report_cpu_info(void)
169{
Usha Pe1508762019-11-28 10:21:02 +0530170 u32 i, cpu_id, cpu_feature_flag;
171 char cpu_name[49];
Andrey Petrova00e1042017-06-05 13:22:59 -0700172 int vt, txt, aes;
173 msr_t microcode_ver;
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);
Andrey Petrova00e1042017-06-05 13:22:59 -0700178
179 microcode_ver.lo = 0;
180 microcode_ver.hi = 0;
181 wrmsr(BIOS_SIGN_ID, microcode_ver);
Subrata Banik53b08c32018-12-10 14:11:35 +0530182 cpu_id = cpu_get_cpuid();
Andrey Petrova00e1042017-06-05 13:22:59 -0700183 microcode_ver = rdmsr(BIOS_SIGN_ID);
184
185 /* Look for string to match the name */
186 for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
Subrata Banik53b08c32018-12-10 14:11:35 +0530187 if (cpu_table[i].cpuid == cpu_id) {
Andrey Petrova00e1042017-06-05 13:22:59 -0700188 cpu_type = cpu_table[i].name;
189 break;
190 }
191 }
192
193 printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
194 printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
Subrata Banik53b08c32018-12-10 14:11:35 +0530195 cpu_id, cpu_type, microcode_ver.hi);
Andrey Petrova00e1042017-06-05 13:22:59 -0700196
Subrata Banik53b08c32018-12-10 14:11:35 +0530197 cpu_feature_flag = cpu_get_feature_flags_ecx();
198 aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
199 txt = (cpu_feature_flag & CPUID_SMX) ? 1 : 0;
200 vt = (cpu_feature_flag & CPUID_VMX) ? 1 : 0;
Andrey Petrova00e1042017-06-05 13:22:59 -0700201 printk(BIOS_DEBUG,
202 "CPU: AES %ssupported, TXT %ssupported, VT %ssupported\n",
203 mode[aes], mode[txt], mode[vt]);
204}
205
206static void report_mch_info(void)
207{
208 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200209 pci_devfn_t dev = SA_DEV_ROOT;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530210 uint16_t mchid = get_dev_id(dev);
211 uint8_t mch_revision = get_dev_revision(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700212 const char *mch_type = "Unknown";
213
214 for (i = 0; i < ARRAY_SIZE(mch_table); i++) {
215 if (mch_table[i].mchid == mchid) {
216 mch_type = mch_table[i].name;
217 break;
218 }
219 }
220
221 printk(BIOS_DEBUG, "MCH: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530222 mchid, mch_revision, mch_type);
223}
224
225static void report_pch_info(void)
226{
227 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200228 pci_devfn_t dev = PCH_DEV_LPC;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530229 uint16_t lpcid = get_dev_id(dev);
230 const char *pch_type = "Unknown";
231
232 for (i = 0; i < ARRAY_SIZE(pch_table); i++) {
233 if (pch_table[i].lpcid == lpcid) {
234 pch_type = pch_table[i].name;
235 break;
236 }
237 }
238 printk(BIOS_DEBUG, "PCH: device id %04x (rev %02x) is %s\n",
239 lpcid, get_dev_revision(dev), pch_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700240}
241
242static void report_igd_info(void)
243{
244 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200245 pci_devfn_t dev = SA_DEV_IGD;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530246 uint16_t igdid = get_dev_id(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700247 const char *igd_type = "Unknown";
248
249 for (i = 0; i < ARRAY_SIZE(igd_table); i++) {
250 if (igd_table[i].igdid == igdid) {
251 igd_type = igd_table[i].name;
252 break;
253 }
254 }
255 printk(BIOS_DEBUG, "IGD: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530256 igdid, get_dev_revision(dev), igd_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700257}
258
259void report_platform_info(void)
260{
261 report_cpu_info();
262 report_mch_info();
Subrata Banikec10fbb2017-12-07 11:48:48 +0530263 report_pch_info();
Andrey Petrova00e1042017-06-05 13:22:59 -0700264 report_igd_info();
265}