blob: 87b4be7844889aa1cb8cde894cb5c47da6daec6a [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 Banikb7db12b2020-08-04 18:01:27 +05306#include <cpu/intel/microcode.h>
Andrey Petrova00e1042017-06-05 13:22:59 -07007#include <cpu/x86/msr.h>
Usha Pe1508762019-11-28 10:21:02 +05308#include <cpu/x86/name.h>
Andrey Petrova00e1042017-06-05 13:22:59 -07009#include <device/pci.h>
10#include <device/pci_ids.h>
Subrata Banikb3585b92018-01-08 13:57:43 +053011#include <intelblocks/mp_init.h>
Andrey Petrova00e1042017-06-05 13:22:59 -070012#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[] = {
43 { PCI_DEVICE_ID_INTEL_CNL_ID_U, "Cannonlake-U" },
44 { PCI_DEVICE_ID_INTEL_CNL_ID_Y, "Cannonlake-Y" },
Subrata Banikab9f64d2019-02-22 13:25:04 +053045 { PCI_DEVICE_ID_INTEL_CFL_ID_U, "Coffeelake U (4+3e)" },
Christian Walterccac15a2019-08-13 09:55:37 +020046 { PCI_DEVICE_ID_INTEL_CFL_ID_U_2, "Coffeelake U (2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080047 { PCI_DEVICE_ID_INTEL_WHL_ID_W_4, "Whiskeylake W (4+2)" },
48 { PCI_DEVICE_ID_INTEL_WHL_ID_W_2, "Whiskeylake W (2+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080049 { PCI_DEVICE_ID_INTEL_CFL_ID_H, "Coffeelake-H" },
Christian Walterccac15a2019-08-13 09:55:37 +020050 { PCI_DEVICE_ID_INTEL_CFL_ID_H_4, "Coffeelake-H (4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080051 { PCI_DEVICE_ID_INTEL_CFL_ID_H_8, "Coffeelake-H (8+2)" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080052 { PCI_DEVICE_ID_INTEL_CFL_ID_S, "Coffeelake-S" },
Christian Walterccac15a2019-08-13 09:55:37 +020053 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_2, "Coffeelake-S DT(2)" },
Felix Singerd298ffe2019-07-28 13:27:11 +020054 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_4, "Coffeelake-S DT(4)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080055 { PCI_DEVICE_ID_INTEL_CFL_ID_S_DT_8, "Coffeelake-S DT(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020056 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_4, "Coffeelake-S WS(4+2)" },
57 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_6, "Coffeelake-S WS(6+2)" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080058 { PCI_DEVICE_ID_INTEL_CFL_ID_S_WS_8, "Coffeelake-S WS(8+2)" },
Christian Walterccac15a2019-08-13 09:55:37 +020059 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_4, "Coffeelake-S S(4)" },
60 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_6, "Coffeelake-S S(6)" },
61 { PCI_DEVICE_ID_INTEL_CFL_ID_S_S_8, "Coffeelake-S S(8)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053062 { PCI_DEVICE_ID_INTEL_CML_ULT, "CometLake-U (4+2)" },
Subrata Banikba8af582019-02-27 15:00:55 +053063 { PCI_DEVICE_ID_INTEL_CML_ULT_2_2, "CometLake-U (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053064 { PCI_DEVICE_ID_INTEL_CML_ULT_6_2, "CometLake-U (6+2)" },
65 { PCI_DEVICE_ID_INTEL_CML_ULX, "CometLake-ULX (4+2)" },
66 { PCI_DEVICE_ID_INTEL_CML_S, "CometLake-S (6+2)" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080067 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_P0P1_6_2, "CometLake-S G0/G1/P0/P1 (6+2)" },
68 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_8_2, "CometLake-S P0/P1 (8+2)" },
69 { PCI_DEVICE_ID_INTEL_CML_S_P0P1_10_2, "CometLake-S P0/P1 (10+2)" },
Gaggery Tsai39e1f442020-01-08 15:22:13 -080070 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_4, "CometLake-S G0/G1 (4+2)" },
71 { PCI_DEVICE_ID_INTEL_CML_S_G0G1_2, "CometLake-S G0/G1 (2+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053072 { PCI_DEVICE_ID_INTEL_CML_H, "CometLake-H (6+2)" },
Jamie Chen6bb9aaf2019-12-20 19:30:33 +080073 { PCI_DEVICE_ID_INTEL_CML_H_4_2, "CometLake-H (4+2)" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +053074 { PCI_DEVICE_ID_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[] = {
81 { PCI_DEVICE_ID_INTEL_CNL_BASE_U_LPC, "Cannonlake-U Base" },
82 { PCI_DEVICE_ID_INTEL_CNL_U_PREMIUM_LPC, "Cannonlake-U Premium" },
83 { PCI_DEVICE_ID_INTEL_CNL_Y_PREMIUM_LPC, "Cannonlake-Y Premium" },
Felix Singerd298ffe2019-07-28 13:27:11 +020084 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H310, "Cannonlake-H H310" },
85 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_H370, "Cannonlake-H H370" },
86 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Z390, "Cannonlake-H Z390" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +080087 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_Q370, "Cannonlake-H Q370" },
Felix Singerd298ffe2019-07-28 13:27:11 +020088 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_B360, "Cannonlake-H B360" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +080089 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C246, "Cannonlake-H C246" },
Felix Singerd298ffe2019-07-28 13:27:11 +020090 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_C242, "Cannonlake-H C242" },
91 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_QM370, "Cannonlake-H QM370" },
92 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_HM370, "Cannonlake-H HM370" },
Nico Huber129bc4c2019-05-14 13:17:28 +020093 { PCI_DEVICE_ID_INTEL_CNP_H_LPC_CM246, "Cannonlake-H CM246" },
Ronak Kanabarda7ffb482019-02-05 01:51:13 +053094 { PCI_DEVICE_ID_INTEL_CMP_SUPER_U_LPC, "Cometlake-U Super" },
95 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_Y_LPC, "Cometlake-Y Premium" },
96 { PCI_DEVICE_ID_INTEL_CMP_PREMIUM_U_LPC, "Cometlake-U Premium" },
97 { PCI_DEVICE_ID_INTEL_CMP_BASE_U_LPC, "Cometlake-U Base" },
98 { PCI_DEVICE_ID_INTEL_CMP_SUPER_Y_LPC, "Cometlake-Y Super" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -080099 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_HM470, "Cometlake-H HM470" },
100 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_WM490, "Cometlake-H WM490" },
101 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_QM480, "Cometlake-H QM480" },
102 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_W480, "Cometlake-H W480" },
103 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_H470, "Cometlake-H H470" },
104 { PCI_DEVICE_ID_INTEL_CMP_H_LPC_Z490, "Cometlake-H Z490" },
105 { PCI_DEVICE_ID_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[] = {
112 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_1, "Cannonlake ULX GT2" },
113 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_2, "Cannonlake ULX GT1.5" },
114 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_3, "Cannonlake ULX GT1" },
115 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULX_4, "Cannonlake ULX GT0.5" },
116 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_1, "Cannonlake ULT GT2" },
117 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_2, "Cannonlake ULT GT1.5" },
118 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_3, "Cannonlake ULT GT1" },
119 { PCI_DEVICE_ID_INTEL_CNL_GT2_ULT_4, "Cannonlake ULT GT0.5" },
Subrata Banikd1dfba42019-02-21 17:01:21 +0530120 { PCI_DEVICE_ID_INTEL_CFL_GT2_ULT, "Coffeelake ULT GT2" },
Lijian Zhao395f1e32019-04-14 12:27:02 -0700121 { PCI_DEVICE_ID_INTEL_WHL_GT1_ULT_1, "Whiskeylake ULT GT1" },
122 { PCI_DEVICE_ID_INTEL_WHL_GT2_ULT_1, "Whiskeylake ULT GT2" },
praveen hodagatta praneshe26c4a42018-09-20 03:49:45 +0800123 { PCI_DEVICE_ID_INTEL_CFL_H_GT2, "Coffeelake-H GT2" },
Nico Huberff3c9642019-05-14 13:18:05 +0200124 { PCI_DEVICE_ID_INTEL_CFL_H_XEON_GT2, "Coffeelake-H Xeon GT2" },
Lean Sheng Tan38c3ff72019-05-27 13:06:35 +0800125 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_1, "Coffeelake-S GT2" },
126 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_2, "Coffeelake-S GT2" },
127 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_3, "Coffeelake-S GT2" },
Felix Singerd298ffe2019-07-28 13:27:11 +0200128 { PCI_DEVICE_ID_INTEL_CFL_S_GT2_4, "Coffeelake-S GT2" },
Christian Walter19b963c2019-12-09 15:07:13 +0100129 { PCI_DEVICE_ID_INTEL_CFL_U_GT2, "Coffeelake-U GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530130 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_1, "CometLake ULT GT1" },
131 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_2, "CometLake ULT GT1" },
132 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_1, "CometLake ULT GT2" },
133 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_2, "CometLake ULT GT2" },
134 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_3, "CometLake ULT GT1" },
135 { PCI_DEVICE_ID_INTEL_CML_GT1_ULT_4, "CometLake ULT GT1" },
136 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_3, "CometLake ULT GT2" },
137 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_4, "CometLake ULT GT2" },
Meera Ravindranath970f1a42019-08-27 16:16:56 +0530138 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_5, "CometLake ULT GT2" },
139 { PCI_DEVICE_ID_INTEL_CML_GT2_ULT_6, "CometLake ULT GT2" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530140 { PCI_DEVICE_ID_INTEL_CML_GT1_ULX_1, "CometLake ULX GT1" },
141 { PCI_DEVICE_ID_INTEL_CML_GT2_ULX_1, "CometLake ULX GT2" },
142 { PCI_DEVICE_ID_INTEL_CML_GT1_S_1, "CometLake S GT1" },
143 { PCI_DEVICE_ID_INTEL_CML_GT1_S_2, "CometLake S GT1" },
144 { PCI_DEVICE_ID_INTEL_CML_GT2_S_1, "CometLake S GT2" },
145 { PCI_DEVICE_ID_INTEL_CML_GT2_S_2, "CometLake S GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800146 { PCI_DEVICE_ID_INTEL_CML_GT2_S_G0, "CometLake S GT2 G0" },
147 { PCI_DEVICE_ID_INTEL_CML_GT2_S_P0, "CometLake S GT2 P0" },
Ronak Kanabarf606a2f2019-02-04 16:06:50 +0530148 { PCI_DEVICE_ID_INTEL_CML_GT1_H_1, "CometLake H GT1" },
149 { PCI_DEVICE_ID_INTEL_CML_GT1_H_2, "CometLake H GT1" },
150 { PCI_DEVICE_ID_INTEL_CML_GT2_H_1, "CometLake H GT2" },
151 { PCI_DEVICE_ID_INTEL_CML_GT2_H_2, "CometLake H GT2" },
Gaggery Tsaifdcc9ab2019-11-04 20:49:10 -0800152 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R0, "CometLake H GT2 R0" },
153 { PCI_DEVICE_ID_INTEL_CML_GT2_H_R1, "CometLake H GT2 R1" },
154
Andrey Petrova00e1042017-06-05 13:22:59 -0700155};
156
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200157static uint8_t get_dev_revision(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530158{
159 return pci_read_config8(dev, PCI_REVISION_ID);
160}
161
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200162static uint16_t get_dev_id(pci_devfn_t dev)
Subrata Banikec10fbb2017-12-07 11:48:48 +0530163{
164 return pci_read_config16(dev, PCI_DEVICE_ID);
165}
166
Andrey Petrova00e1042017-06-05 13:22:59 -0700167static void report_cpu_info(void)
168{
Usha Pe1508762019-11-28 10:21:02 +0530169 u32 i, cpu_id, cpu_feature_flag;
170 char cpu_name[49];
Andrey Petrova00e1042017-06-05 13:22:59 -0700171 int vt, txt, aes;
Elyes HAOUAS39303d52018-07-08 12:40:45 +0200172 static const char *const mode[] = {"NOT ", ""};
Andrey Petrova00e1042017-06-05 13:22:59 -0700173 const char *cpu_type = "Unknown";
174
Usha Pe1508762019-11-28 10:21:02 +0530175 fill_processor_name(cpu_name);
Subrata Banik53b08c32018-12-10 14:11:35 +0530176 cpu_id = cpu_get_cpuid();
Andrey Petrova00e1042017-06-05 13:22:59 -0700177
178 /* Look for string to match the name */
179 for (i = 0; i < ARRAY_SIZE(cpu_table); i++) {
Subrata Banik53b08c32018-12-10 14:11:35 +0530180 if (cpu_table[i].cpuid == cpu_id) {
Andrey Petrova00e1042017-06-05 13:22:59 -0700181 cpu_type = cpu_table[i].name;
182 break;
183 }
184 }
185
186 printk(BIOS_DEBUG, "CPU: %s\n", cpu_name);
187 printk(BIOS_DEBUG, "CPU: ID %x, %s, ucode: %08x\n",
Subrata Banikb7db12b2020-08-04 18:01:27 +0530188 cpu_id, cpu_type, get_current_microcode_rev());
Andrey Petrova00e1042017-06-05 13:22:59 -0700189
Subrata Banik53b08c32018-12-10 14:11:35 +0530190 cpu_feature_flag = cpu_get_feature_flags_ecx();
191 aes = (cpu_feature_flag & CPUID_AES) ? 1 : 0;
192 txt = (cpu_feature_flag & CPUID_SMX) ? 1 : 0;
193 vt = (cpu_feature_flag & CPUID_VMX) ? 1 : 0;
Andrey Petrova00e1042017-06-05 13:22:59 -0700194 printk(BIOS_DEBUG,
195 "CPU: AES %ssupported, TXT %ssupported, VT %ssupported\n",
196 mode[aes], mode[txt], mode[vt]);
197}
198
199static void report_mch_info(void)
200{
201 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200202 pci_devfn_t dev = SA_DEV_ROOT;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530203 uint16_t mchid = get_dev_id(dev);
204 uint8_t mch_revision = get_dev_revision(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700205 const char *mch_type = "Unknown";
206
207 for (i = 0; i < ARRAY_SIZE(mch_table); i++) {
208 if (mch_table[i].mchid == mchid) {
209 mch_type = mch_table[i].name;
210 break;
211 }
212 }
213
214 printk(BIOS_DEBUG, "MCH: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530215 mchid, mch_revision, mch_type);
216}
217
218static void report_pch_info(void)
219{
220 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200221 pci_devfn_t dev = PCH_DEV_LPC;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530222 uint16_t lpcid = get_dev_id(dev);
223 const char *pch_type = "Unknown";
224
225 for (i = 0; i < ARRAY_SIZE(pch_table); i++) {
226 if (pch_table[i].lpcid == lpcid) {
227 pch_type = pch_table[i].name;
228 break;
229 }
230 }
231 printk(BIOS_DEBUG, "PCH: device id %04x (rev %02x) is %s\n",
232 lpcid, get_dev_revision(dev), pch_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700233}
234
235static void report_igd_info(void)
236{
237 int i;
Elyes HAOUASc8a649c2018-06-10 23:36:44 +0200238 pci_devfn_t dev = SA_DEV_IGD;
Subrata Banikec10fbb2017-12-07 11:48:48 +0530239 uint16_t igdid = get_dev_id(dev);
Andrey Petrova00e1042017-06-05 13:22:59 -0700240 const char *igd_type = "Unknown";
241
242 for (i = 0; i < ARRAY_SIZE(igd_table); i++) {
243 if (igd_table[i].igdid == igdid) {
244 igd_type = igd_table[i].name;
245 break;
246 }
247 }
248 printk(BIOS_DEBUG, "IGD: device id %04x (rev %02x) is %s\n",
Subrata Banikec10fbb2017-12-07 11:48:48 +0530249 igdid, get_dev_revision(dev), igd_type);
Andrey Petrova00e1042017-06-05 13:22:59 -0700250}
251
252void report_platform_info(void)
253{
254 report_cpu_info();
255 report_mch_info();
Subrata Banikec10fbb2017-12-07 11:48:48 +0530256 report_pch_info();
Andrey Petrova00e1042017-06-05 13:22:59 -0700257 report_igd_info();
258}