Patrick Georgi | ea063cb | 2020-05-08 19:28:13 +0200 | [diff] [blame] | 1 | /* inteltool - dump all registers on an Intel CPU + chipset based system */ |
Patrick Georgi | 7333a11 | 2020-05-08 20:48:04 +0200 | [diff] [blame] | 2 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 3 | |
Nico Huber | 99b02a1 | 2017-04-05 17:39:57 +0200 | [diff] [blame] | 4 | #ifndef INTELTOOL_H |
| 5 | #define INTELTOOL_H 1 |
| 6 | |
Michael Niewöhner | 10d5221 | 2020-03-13 19:08:21 +0100 | [diff] [blame] | 7 | #include <arch/mmio.h> |
Nico Huber | af83db2 | 2017-04-05 17:30:20 +0200 | [diff] [blame] | 8 | #include <commonlib/helpers.h> |
| 9 | |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 10 | #include <stdint.h> |
Stefan Reinauer | f7f2f25 | 2009-09-01 09:52:14 +0000 | [diff] [blame] | 11 | |
Fabian Groffen | 6e04d85 | 2023-03-10 18:14:11 +0100 | [diff] [blame] | 12 | #if defined(__linux__) |
Stefan Reinauer | 1162f25 | 2008-12-04 15:18:20 +0000 | [diff] [blame] | 13 | #include <sys/io.h> |
Stefan Reinauer | f7f2f25 | 2009-09-01 09:52:14 +0000 | [diff] [blame] | 14 | #endif |
| 15 | #if (defined(__MACH__) && defined(__APPLE__)) |
Paul Menzel | a8843de | 2017-06-05 12:33:23 +0200 | [diff] [blame] | 16 | /* DirectHW is available here: https://www.coreboot.org/DirectHW */ |
Stefan Reinauer | f7f2f25 | 2009-09-01 09:52:14 +0000 | [diff] [blame] | 17 | #define __DARWIN__ |
Stefan Reinauer | cff573d | 2011-03-18 22:08:39 +0000 | [diff] [blame] | 18 | #include <DirectHW/DirectHW.h> |
Stefan Reinauer | 1162f25 | 2008-12-04 15:18:20 +0000 | [diff] [blame] | 19 | #endif |
Andrey Korolyov | 046d217 | 2016-01-05 19:59:06 +0300 | [diff] [blame] | 20 | #ifdef __NetBSD__ |
| 21 | #include <pciutils/pci.h> |
| 22 | #else |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 23 | #include <pci/pci.h> |
Andrey Korolyov | 046d217 | 2016-01-05 19:59:06 +0300 | [diff] [blame] | 24 | #endif |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 25 | |
Idwer Vollering | 3f91d81 | 2010-10-24 13:50:13 +0000 | [diff] [blame] | 26 | /* This #include is needed for freebsd_{rd,wr}msr. */ |
| 27 | #if defined(__FreeBSD__) |
| 28 | #include <machine/cpufunc.h> |
| 29 | #endif |
| 30 | |
Andrey Korolyov | 046d217 | 2016-01-05 19:59:06 +0300 | [diff] [blame] | 31 | #ifdef __NetBSD__ |
| 32 | static inline uint8_t inb(unsigned port) |
| 33 | { |
| 34 | uint8_t data; |
| 35 | __asm volatile("inb %w1,%0" : "=a" (data) : "d" (port)); |
| 36 | return data; |
| 37 | } |
| 38 | static inline uint16_t inw(unsigned port) |
| 39 | { |
Elyes HAOUAS | 9450150 | 2016-10-19 17:59:10 +0200 | [diff] [blame] | 40 | uint16_t data; |
| 41 | __asm volatile("inw %w1,%0": "=a" (data) : "d" (port)); |
| 42 | return data; |
Andrey Korolyov | 046d217 | 2016-01-05 19:59:06 +0300 | [diff] [blame] | 43 | } |
| 44 | static inline uint32_t inl(unsigned port) |
| 45 | { |
| 46 | uint32_t data; |
| 47 | __asm volatile("inl %w1,%0": "=a" (data) : "d" (port)); |
| 48 | return data; |
| 49 | } |
| 50 | #endif |
| 51 | |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 52 | #define INTELTOOL_VERSION "1.0" |
| 53 | |
| 54 | /* Tested chipsets: */ |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 55 | #define PCI_VENDOR_ID_INTEL 0x8086 |
| 56 | #define PCI_DEVICE_ID_INTEL_ICH 0x2410 |
| 57 | #define PCI_DEVICE_ID_INTEL_ICH0 0x2420 |
| 58 | #define PCI_DEVICE_ID_INTEL_ICH2 0x2440 |
| 59 | #define PCI_DEVICE_ID_INTEL_ICH4 0x24c0 |
| 60 | #define PCI_DEVICE_ID_INTEL_ICH4M 0x24cc |
Idwer Vollering | 312fc96 | 2010-12-17 22:34:58 +0000 | [diff] [blame] | 61 | #define PCI_DEVICE_ID_INTEL_ICH5 0x24d0 |
Pat Erley | ca3548e | 2010-04-21 06:23:19 +0000 | [diff] [blame] | 62 | #define PCI_DEVICE_ID_INTEL_ICH6 0x2640 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 63 | #define PCI_DEVICE_ID_INTEL_ICH7DH 0x27b0 |
| 64 | #define PCI_DEVICE_ID_INTEL_ICH7 0x27b8 |
| 65 | #define PCI_DEVICE_ID_INTEL_ICH7M 0x27b9 |
| 66 | #define PCI_DEVICE_ID_INTEL_ICH7MDH 0x27bd |
Corey Osgood | f366ce0 | 2010-08-17 08:33:44 +0000 | [diff] [blame] | 67 | #define PCI_DEVICE_ID_INTEL_NM10 0x27bc |
| 68 | #define PCI_DEVICE_ID_INTEL_ICH8 0x2810 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 69 | #define PCI_DEVICE_ID_INTEL_ICH8M 0x2815 |
Lubomir Rintel | 2a13bad | 2015-03-01 10:14:15 +0100 | [diff] [blame] | 70 | #define PCI_DEVICE_ID_INTEL_ICH8ME 0x2811 |
Anton Kochkov | da0b456 | 2010-05-30 12:33:12 +0000 | [diff] [blame] | 71 | #define PCI_DEVICE_ID_INTEL_ICH9DH 0x2912 |
| 72 | #define PCI_DEVICE_ID_INTEL_ICH9DO 0x2914 |
| 73 | #define PCI_DEVICE_ID_INTEL_ICH9R 0x2916 |
| 74 | #define PCI_DEVICE_ID_INTEL_ICH9 0x2918 |
| 75 | #define PCI_DEVICE_ID_INTEL_ICH9M 0x2919 |
| 76 | #define PCI_DEVICE_ID_INTEL_ICH9ME 0x2917 |
Idwer Vollering | 66dcda9 | 2020-07-09 14:16:39 +0200 | [diff] [blame] | 77 | #define PCI_DEVICE_ID_INTEL_ICH10DO 0x3a14 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 78 | #define PCI_DEVICE_ID_INTEL_ICH10R 0x3a16 |
Angel Pons | 65adc70 | 2021-11-14 15:34:02 +0100 | [diff] [blame] | 79 | #define PCI_DEVICE_ID_INTEL_ICH10 0x3a18 |
| 80 | #define PCI_DEVICE_ID_INTEL_ICH10D 0x3a1a |
Stefan Tauner | 088f569 | 2013-05-28 11:30:25 +0200 | [diff] [blame] | 81 | #define PCI_DEVICE_ID_INTEL_3400_DESKTOP 0x3b00 |
| 82 | #define PCI_DEVICE_ID_INTEL_3400_MOBILE 0x3b01 |
| 83 | #define PCI_DEVICE_ID_INTEL_P55 0x3b02 |
| 84 | #define PCI_DEVICE_ID_INTEL_PM55 0x3b03 |
| 85 | #define PCI_DEVICE_ID_INTEL_H55 0x3b06 |
| 86 | #define PCI_DEVICE_ID_INTEL_QM57 0x3b07 |
| 87 | #define PCI_DEVICE_ID_INTEL_H57 0x3b08 |
| 88 | #define PCI_DEVICE_ID_INTEL_HM55 0x3b09 |
| 89 | #define PCI_DEVICE_ID_INTEL_Q57 0x3b0a |
| 90 | #define PCI_DEVICE_ID_INTEL_HM57 0x3b0b |
| 91 | #define PCI_DEVICE_ID_INTEL_3400_MOBILE_SFF 0x3b0d |
| 92 | #define PCI_DEVICE_ID_INTEL_B55_A 0x3b0e |
| 93 | #define PCI_DEVICE_ID_INTEL_QS57 0x3b0f |
| 94 | #define PCI_DEVICE_ID_INTEL_3400 0x3b12 |
| 95 | #define PCI_DEVICE_ID_INTEL_3420 0x3b14 |
| 96 | #define PCI_DEVICE_ID_INTEL_3450 0x3b16 |
| 97 | #define PCI_DEVICE_ID_INTEL_B55_B 0x3b1e |
Stefan Reinauer | 74cd5698 | 2010-06-01 10:04:28 +0000 | [diff] [blame] | 98 | #define PCI_DEVICE_ID_INTEL_SCH_POULSBO_LPC 0x8119 |
Johanna Schander | d756c27 | 2019-12-29 14:31:01 +0100 | [diff] [blame] | 99 | #define PCI_DEVICE_ID_INTEL_ICELAKE_LP_U 0x3482 |
Nico Huber | 76d6049 | 2013-03-29 17:57:15 +0100 | [diff] [blame] | 100 | #define PCI_DEVICE_ID_INTEL_Z68 0x1c44 |
| 101 | #define PCI_DEVICE_ID_INTEL_P67 0x1c46 |
| 102 | #define PCI_DEVICE_ID_INTEL_UM67 0x1c47 |
| 103 | #define PCI_DEVICE_ID_INTEL_HM65 0x1c49 |
| 104 | #define PCI_DEVICE_ID_INTEL_H67 0x1c4a |
| 105 | #define PCI_DEVICE_ID_INTEL_HM67 0x1c4b |
| 106 | #define PCI_DEVICE_ID_INTEL_Q65 0x1c4c |
| 107 | #define PCI_DEVICE_ID_INTEL_QS67 0x1c4d |
| 108 | #define PCI_DEVICE_ID_INTEL_Q67 0x1c4e |
| 109 | #define PCI_DEVICE_ID_INTEL_QM67 0x1c4f |
| 110 | #define PCI_DEVICE_ID_INTEL_B65 0x1c50 |
| 111 | #define PCI_DEVICE_ID_INTEL_C202 0x1c52 |
| 112 | #define PCI_DEVICE_ID_INTEL_C204 0x1c54 |
| 113 | #define PCI_DEVICE_ID_INTEL_C206 0x1c56 |
| 114 | #define PCI_DEVICE_ID_INTEL_H61 0x1c5c |
| 115 | #define PCI_DEVICE_ID_INTEL_Z77 0x1e44 |
| 116 | #define PCI_DEVICE_ID_INTEL_Z75 0x1e46 |
| 117 | #define PCI_DEVICE_ID_INTEL_Q77 0x1e47 |
| 118 | #define PCI_DEVICE_ID_INTEL_Q75 0x1e48 |
| 119 | #define PCI_DEVICE_ID_INTEL_B75 0x1e49 |
| 120 | #define PCI_DEVICE_ID_INTEL_H77 0x1e4a |
| 121 | #define PCI_DEVICE_ID_INTEL_C216 0x1e53 |
| 122 | #define PCI_DEVICE_ID_INTEL_QM77 0x1e55 |
| 123 | #define PCI_DEVICE_ID_INTEL_QS77 0x1e56 |
| 124 | #define PCI_DEVICE_ID_INTEL_HM77 0x1e57 |
| 125 | #define PCI_DEVICE_ID_INTEL_UM77 0x1e58 |
| 126 | #define PCI_DEVICE_ID_INTEL_HM76 0x1e59 |
| 127 | #define PCI_DEVICE_ID_INTEL_HM75 0x1e5d |
| 128 | #define PCI_DEVICE_ID_INTEL_HM70 0x1e5e |
| 129 | #define PCI_DEVICE_ID_INTEL_NM70 0x1e5f |
Dennis Wassenberg | ae6685f | 2014-10-30 10:30:40 +0100 | [diff] [blame] | 130 | #define PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_FULL 0x9c41 |
| 131 | #define PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_PREM 0x9c43 |
| 132 | #define PCI_DEVICE_ID_INTEL_LYNXPOINT_LP_BASE 0x9c45 |
Youness Alaoui | 1244a51 | 2017-04-13 13:22:33 -0400 | [diff] [blame] | 133 | #define PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP_PREM 0x9cc3 |
Matthew Garrett | 2bf28e5 | 2018-07-23 21:09:47 -0700 | [diff] [blame] | 134 | #define PCI_DEVICE_ID_INTEL_WILDCATPOINT_LP 0x9cc5 |
| 135 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_SATA 0xa102 |
| 136 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_P2SB 0xa120 |
| 137 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_PRE 0xa141 |
| 138 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_SATA 0x9d03 |
Felix Singer | 0a7543d | 2019-02-19 23:49:11 +0100 | [diff] [blame] | 139 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_PRE 0x9d41 |
| 140 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_BASE_SKL 0x9d43 |
| 141 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_Y_PREM_SKL 0x9d46 |
| 142 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_PREM_SKL 0x9d48 |
| 143 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_BASE_KBL 0x9d53 |
| 144 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_Y_PREM_KBL 0x9d56 |
| 145 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_PREM_KBL 0x9d58 |
Matthew Garrett | 2bf28e5 | 2018-07-23 21:09:47 -0700 | [diff] [blame] | 146 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_IHDCP_BASE 0x9d50 |
| 147 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_U_IHDCP_PREM 0x9d4e |
| 148 | #define PCI_DEVICE_ID_INTEL_SUNRISEPOINT_LP_Y_IHDCP_PREM 0x9d4b |
Matt DeVillier | 3c78445 | 2019-06-11 23:23:46 -0500 | [diff] [blame] | 149 | #define PCI_DEVICE_ID_INTEL_CANNONPOINT_LP_U_PREM 0x9d84 |
Matt DeVillier | 62e883d | 2020-08-08 11:17:31 -0500 | [diff] [blame] | 150 | #define PCI_DEVICE_ID_INTEL_COMETPOINT_LP_U_PREM 0x0284 |
| 151 | #define PCI_DEVICE_ID_INTEL_COMETPOINT_LP_U_BASE 0x0285 |
Michał Żygowski | 8ac40f3 | 2021-07-09 16:00:16 +0200 | [diff] [blame] | 152 | #define PCI_DEVICE_ID_INTEL_TIGERPOINT_U_SUPER 0xa081 |
| 153 | #define PCI_DEVICE_ID_INTEL_TIGERPOINT_U_PREM 0xa082 |
| 154 | #define PCI_DEVICE_ID_INTEL_TIGERPOINT_U_BASE 0xa083 |
| 155 | #define PCI_DEVICE_ID_INTEL_TIGERPOINT_Y_SUPER 0xa086 |
| 156 | #define PCI_DEVICE_ID_INTEL_TIGERPOINT_Y_PREM 0xa087 |
Maximilian Schander | cb2d21d | 2017-10-28 14:45:48 +0200 | [diff] [blame] | 157 | #define PCI_DEVICE_ID_INTEL_H110 0xa143 |
| 158 | #define PCI_DEVICE_ID_INTEL_H170 0xa144 |
| 159 | #define PCI_DEVICE_ID_INTEL_Z170 0xa145 |
| 160 | #define PCI_DEVICE_ID_INTEL_Q170 0xa146 |
| 161 | #define PCI_DEVICE_ID_INTEL_Q150 0xa147 |
| 162 | #define PCI_DEVICE_ID_INTEL_B150 0xa148 |
| 163 | #define PCI_DEVICE_ID_INTEL_C236 0xa149 |
| 164 | #define PCI_DEVICE_ID_INTEL_C232 0xa14a |
| 165 | #define PCI_DEVICE_ID_INTEL_QM170 0xa14d |
| 166 | #define PCI_DEVICE_ID_INTEL_HM170 0xa14e |
Nico Huber | ed9c9ce | 2017-03-30 17:45:36 +0200 | [diff] [blame] | 167 | #define PCI_DEVICE_ID_INTEL_CM236 0xa150 |
Maximilian Schander | cb2d21d | 2017-10-28 14:45:48 +0200 | [diff] [blame] | 168 | #define PCI_DEVICE_ID_INTEL_HM175 0xa152 |
| 169 | #define PCI_DEVICE_ID_INTEL_QM175 0xa153 |
| 170 | #define PCI_DEVICE_ID_INTEL_CM238 0xa154 |
Thomas Heijligen | 725369f | 2019-02-19 10:51:34 +0000 | [diff] [blame] | 171 | |
Maxim Polyakov | ec32e61 | 2019-08-16 19:15:12 +0300 | [diff] [blame] | 172 | #define PCI_DEVICE_ID_INTEL_C621 0xa1c1 |
| 173 | #define PCI_DEVICE_ID_INTEL_C622 0xa1c2 |
| 174 | #define PCI_DEVICE_ID_INTEL_C624 0xa1c3 |
| 175 | #define PCI_DEVICE_ID_INTEL_C625 0xa1c4 |
| 176 | #define PCI_DEVICE_ID_INTEL_C626 0xa1c5 |
| 177 | #define PCI_DEVICE_ID_INTEL_C627 0xa1c6 |
| 178 | #define PCI_DEVICE_ID_INTEL_C628 0xa1c7 |
| 179 | #define PCI_DEVICE_ID_INTEL_C629 0xa1ca |
Maxim Polyakov | de7092b | 2020-07-17 00:19:41 +0300 | [diff] [blame] | 180 | #define PCI_DEVICE_ID_INTEL_C621A 0xa1cb |
| 181 | #define PCI_DEVICE_ID_INTEL_C627A 0xa1cc |
| 182 | #define PCI_DEVICE_ID_INTEL_C629A 0xa1cd |
Maxim Polyakov | ec32e61 | 2019-08-16 19:15:12 +0300 | [diff] [blame] | 183 | #define PCI_DEVICE_ID_INTEL_C624_SUPER 0xa242 |
| 184 | #define PCI_DEVICE_ID_INTEL_C627_SUPER_1 0xa243 |
| 185 | #define PCI_DEVICE_ID_INTEL_C621_SUPER 0xa244 |
| 186 | #define PCI_DEVICE_ID_INTEL_C627_SUPER_2 0xa245 |
| 187 | #define PCI_DEVICE_ID_INTEL_C628_SUPER 0xa246 |
Maxim Polyakov | de7092b | 2020-07-17 00:19:41 +0300 | [diff] [blame] | 188 | #define PCI_DEVICE_ID_INTEL_C621A_SUPER 0xa24a |
| 189 | #define PCI_DEVICE_ID_INTEL_C627A_SUPER 0xa24b |
| 190 | #define PCI_DEVICE_ID_INTEL_C629A_SUPER 0xa24c |
Maxim Polyakov | ec32e61 | 2019-08-16 19:15:12 +0300 | [diff] [blame] | 191 | |
Jonathan Zhang | 4caa05e | 2021-05-03 14:06:22 -0700 | [diff] [blame] | 192 | #define PCI_DEVICE_ID_INTEL_EBG 0x1b81 |
| 193 | |
Timofey Komarov | 6c80082 | 2021-06-25 12:07:32 +0300 | [diff] [blame] | 194 | #define PCI_DEVICE_ID_INTEL_H270 0xa2c4 |
| 195 | #define PCI_DEVICE_ID_INTEL_Z270 0xa2c5 |
| 196 | #define PCI_DEVICE_ID_INTEL_Q270 0xa2c6 |
| 197 | #define PCI_DEVICE_ID_INTEL_Q250 0xa2c7 |
| 198 | #define PCI_DEVICE_ID_INTEL_B250 0xa2c8 |
| 199 | #define PCI_DEVICE_ID_INTEL_Z370 0xa2c9 |
| 200 | #define PCI_DEVICE_ID_INTEL_H310C 0xa2ca |
| 201 | #define PCI_DEVICE_ID_INTEL_X299 0xa2d2 |
| 202 | |
Thomas Heijligen | 725369f | 2019-02-19 10:51:34 +0000 | [diff] [blame] | 203 | #define PCI_DEVICE_ID_INTEL_H310 0xa303 |
| 204 | #define PCI_DEVICE_ID_INTEL_H370 0xa304 |
| 205 | #define PCI_DEVICE_ID_INTEL_Z390 0xa305 |
| 206 | #define PCI_DEVICE_ID_INTEL_Q370 0xa306 |
| 207 | #define PCI_DEVICE_ID_INTEL_B360 0xa308 |
| 208 | #define PCI_DEVICE_ID_INTEL_C246 0xa309 |
| 209 | #define PCI_DEVICE_ID_INTEL_C242 0xa30a |
| 210 | #define PCI_DEVICE_ID_INTEL_QM370 0xa30c |
| 211 | #define PCI_DEVICE_ID_INTEL_HM370 0xa30d |
| 212 | #define PCI_DEVICE_ID_INTEL_CM246 0xa30e |
| 213 | |
Michał Żygowski | 8ac40f3 | 2021-07-09 16:00:16 +0200 | [diff] [blame] | 214 | #define PCI_DEVICE_ID_INTEL_Q570 0x4384 |
| 215 | #define PCI_DEVICE_ID_INTEL_Z590 0x4385 |
| 216 | #define PCI_DEVICE_ID_INTEL_H570 0x4386 |
| 217 | #define PCI_DEVICE_ID_INTEL_B560 0x4387 |
| 218 | #define PCI_DEVICE_ID_INTEL_H510 0x4388 |
| 219 | #define PCI_DEVICE_ID_INTEL_WM590 0x4389 |
| 220 | #define PCI_DEVICE_ID_INTEL_QM580 0x438a |
| 221 | #define PCI_DEVICE_ID_INTEL_HM570 0x438b |
| 222 | #define PCI_DEVICE_ID_INTEL_C252 0x438c |
| 223 | #define PCI_DEVICE_ID_INTEL_C256 0x438d |
| 224 | #define PCI_DEVICE_ID_INTEL_W580 0x438f |
| 225 | |
Maximilian Brune | 8d1051f | 2022-08-08 12:55:57 +0200 | [diff] [blame] | 226 | #define PCI_DEVICE_ID_INTEL_H610E 0x7a92 |
| 227 | #define PCI_DEVICE_ID_INTEL_Q670E 0x7a91 |
| 228 | #define PCI_DEVICE_ID_INTEL_R680E 0x7a90 |
Michał Kopeć | 2d8edeb | 2022-04-05 10:40:03 +0200 | [diff] [blame] | 229 | #define PCI_DEVICE_ID_INTEL_H610 0x7a87 |
| 230 | #define PCI_DEVICE_ID_INTEL_B660 0x7a86 |
| 231 | #define PCI_DEVICE_ID_INTEL_H670 0x7a85 |
| 232 | #define PCI_DEVICE_ID_INTEL_Q670 0x7a83 |
| 233 | #define PCI_DEVICE_ID_INTEL_Z690 0x7a84 |
| 234 | #define PCI_DEVICE_ID_INTEL_W680 0x7a88 |
| 235 | #define PCI_DEVICE_ID_INTEL_W685 0x7a8a |
| 236 | #define PCI_DEVICE_ID_INTEL_WM690 0x7a8d |
| 237 | #define PCI_DEVICE_ID_INTEL_HM670 0x7a8c |
| 238 | #define PCI_DEVICE_ID_INTEL_WM790 0x7a0d |
| 239 | #define PCI_DEVICE_ID_INTEL_HM770 0x7a0c |
| 240 | |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 241 | #define PCI_DEVICE_ID_INTEL_82810 0x7120 |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 242 | #define PCI_DEVICE_ID_INTEL_82810_DC 0x7122 |
| 243 | #define PCI_DEVICE_ID_INTEL_82810E_DC 0x7124 |
Stefan Reinauer | 0484481 | 2010-02-22 11:26:06 +0000 | [diff] [blame] | 244 | #define PCI_DEVICE_ID_INTEL_82830M 0x3575 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 245 | #define PCI_DEVICE_ID_INTEL_82845 0x1a30 |
Idwer Vollering | 312fc96 | 2010-12-17 22:34:58 +0000 | [diff] [blame] | 246 | #define PCI_DEVICE_ID_INTEL_82865 0x2570 |
Pat Erley | ca3548e | 2010-04-21 06:23:19 +0000 | [diff] [blame] | 247 | #define PCI_DEVICE_ID_INTEL_82915 0x2580 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 248 | #define PCI_DEVICE_ID_INTEL_82945P 0x2770 |
| 249 | #define PCI_DEVICE_ID_INTEL_82945GM 0x27a0 |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 250 | #define PCI_DEVICE_ID_INTEL_82945GSE 0x27ac |
Stefan Tauner | 1a00cf0 | 2012-10-13 06:23:52 +0200 | [diff] [blame] | 251 | #define PCI_DEVICE_ID_INTEL_82946 0x2970 |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 252 | #define PCI_DEVICE_ID_INTEL_82965PM 0x2a00 |
| 253 | #define PCI_DEVICE_ID_INTEL_82Q965 0x2990 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 254 | #define PCI_DEVICE_ID_INTEL_82975X 0x277c |
Loïc Grenié | 8429de7 | 2009-11-02 15:01:49 +0000 | [diff] [blame] | 255 | #define PCI_DEVICE_ID_INTEL_82Q35 0x29b0 |
| 256 | #define PCI_DEVICE_ID_INTEL_82G33 0x29c0 |
| 257 | #define PCI_DEVICE_ID_INTEL_82Q33 0x29d0 |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 258 | #define PCI_DEVICE_ID_INTEL_82X38 0x29e0 |
Ruud Schramp | bb41f50 | 2011-04-04 07:53:19 +0200 | [diff] [blame] | 259 | #define PCI_DEVICE_ID_INTEL_32X0 0x29f0 |
Damien Zammit | 9c98664 | 2015-08-17 21:04:41 +1000 | [diff] [blame] | 260 | #define PCI_DEVICE_ID_INTEL_82XX4X 0x2a40 |
| 261 | #define PCI_DEVICE_ID_INTEL_82Q45 0x2e10 |
| 262 | #define PCI_DEVICE_ID_INTEL_82G45 0x2e20 |
| 263 | #define PCI_DEVICE_ID_INTEL_82G41 0x2e30 |
| 264 | #define PCI_DEVICE_ID_INTEL_82B43 0x2e40 |
| 265 | #define PCI_DEVICE_ID_INTEL_82B43_2 0x2e90 |
| 266 | |
qeed | b775a62 | 2018-06-19 19:52:19 -0400 | [diff] [blame] | 267 | #define PCI_DEVICE_ID_INTEL_C8_MOBILE 0x8c41 |
| 268 | #define PCI_DEVICE_ID_INTEL_C8_DESKTOP 0x8c42 |
| 269 | #define PCI_DEVICE_ID_INTEL_Z87 0x8c44 |
| 270 | #define PCI_DEVICE_ID_INTEL_Z85 0x8c46 |
| 271 | #define PCI_DEVICE_ID_INTEL_HM86 0x8c49 |
| 272 | #define PCI_DEVICE_ID_INTEL_H87 0x8c4a |
| 273 | #define PCI_DEVICE_ID_INTEL_HM87 0x8c4b |
| 274 | #define PCI_DEVICE_ID_INTEL_Q85 0x8c4c |
| 275 | #define PCI_DEVICE_ID_INTEL_Q87 0x8c4e |
| 276 | #define PCI_DEVICE_ID_INTEL_QM87 0x8c4f |
| 277 | #define PCI_DEVICE_ID_INTEL_B85 0x8c50 |
| 278 | #define PCI_DEVICE_ID_INTEL_C222 0x8c52 |
| 279 | #define PCI_DEVICE_ID_INTEL_C224 0x8c54 |
| 280 | #define PCI_DEVICE_ID_INTEL_C226 0x8c56 |
| 281 | #define PCI_DEVICE_ID_INTEL_H81 0x8c5c |
| 282 | |
Angel Pons | aa4cd73 | 2022-10-07 00:18:04 +0200 | [diff] [blame] | 283 | #define PCI_DEVICE_ID_INTEL_C9_MOBILE 0x8cc1 |
| 284 | #define PCI_DEVICE_ID_INTEL_C9_DESKTOP 0x8cc2 |
| 285 | #define PCI_DEVICE_ID_INTEL_HM97 0x8cc3 |
| 286 | #define PCI_DEVICE_ID_INTEL_Z97 0x8cc4 |
| 287 | #define PCI_DEVICE_ID_INTEL_H97 0x8cc6 |
| 288 | |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 289 | #define PCI_DEVICE_ID_INTEL_82X58 0x3405 |
| 290 | #define PCI_DEVICE_ID_INTEL_SCH_POULSBO 0x8100 |
| 291 | #define PCI_DEVICE_ID_INTEL_ATOM_DXXX 0xa000 |
Sven Schnelle | 54a5aed | 2011-10-30 13:30:36 +0100 | [diff] [blame] | 292 | #define PCI_DEVICE_ID_INTEL_I63XX 0x2670 |
Sven Schnelle | 4b7b320 | 2012-01-08 15:27:18 +0100 | [diff] [blame] | 293 | |
Sven Schnelle | 56dfc7c | 2012-07-05 22:53:57 +0200 | [diff] [blame] | 294 | #define PCI_DEVICE_ID_INTEL_I5000X 0x25c0 |
| 295 | #define PCI_DEVICE_ID_INTEL_I5000Z 0x25d0 |
| 296 | #define PCI_DEVICE_ID_INTEL_I5000V 0x25d4 |
Sven Schnelle | 4b7b320 | 2012-01-08 15:27:18 +0100 | [diff] [blame] | 297 | #define PCI_DEVICE_ID_INTEL_I5000P 0x25d8 |
| 298 | |
Kacper Stojek | fb9110b | 2022-08-17 10:28:20 +0200 | [diff] [blame] | 299 | #define PCI_DEVICE_ID_INTEL_ADL_P 0x5182 |
| 300 | #define PCI_DEVICE_ID_INTEL_ADL_M 0x5187 |
| 301 | #define PCI_DEVICE_ID_INTEL_RPL_P 0x519d |
| 302 | |
Kacper Stojek | 76d2b66 | 2022-10-17 14:30:24 +0200 | [diff] [blame] | 303 | #define PCI_DEVICE_ID_INTEL_EHL 0x4b00 |
Karol Zmyslowski | b2f5a22 | 2023-03-10 19:44:04 +0100 | [diff] [blame] | 304 | #define PCI_DEVICE_ID_INTEL_JSL 0x4d87 |
Kacper Stojek | 76d2b66 | 2022-10-17 14:30:24 +0200 | [diff] [blame] | 305 | |
Corey Osgood | 23d98c7 | 2010-07-29 19:25:31 +0000 | [diff] [blame] | 306 | /* untested, but almost identical to D-series */ |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 307 | #define PCI_DEVICE_ID_INTEL_ATOM_NXXX 0xa010 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 308 | |
| 309 | #define PCI_DEVICE_ID_INTEL_82443LX 0x7180 |
Maciej Pijanka | 90d1740 | 2009-09-30 17:05:46 +0000 | [diff] [blame] | 310 | /* 82443BX has a different device ID if AGP is disabled (hardware-wise). */ |
| 311 | #define PCI_DEVICE_ID_INTEL_82443BX 0x7190 |
| 312 | #define PCI_DEVICE_ID_INTEL_82443BX_NO_AGP 0x7192 |
| 313 | |
| 314 | /* 82371AB/EB/MB use the same device ID value. */ |
| 315 | #define PCI_DEVICE_ID_INTEL_82371XX 0x7110 |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 316 | |
Martin Roth | 51dde6f | 2014-12-07 22:11:54 -0700 | [diff] [blame] | 317 | /* Bay Trail */ |
| 318 | #define PCI_DEVICE_ID_INTEL_BAYTRAIL 0x0f00 /* SOC Transaction Router */ |
| 319 | #define PCI_DEVICE_ID_INTEL_BAYTRAIL_LPC 0x0f1c |
| 320 | #define PCI_DEVICE_ID_INTEL_BAYTRAIL_GFX 0x0f31 |
| 321 | #define CPUID_BAYTRAIL 0x30670 |
| 322 | |
Nico Huber | 94473af | 2018-11-20 12:10:29 +0100 | [diff] [blame] | 323 | #define PCI_DEVICE_ID_INTEL_APL_LPC 0x5ae8 |
Thomas Heijligen | da02719 | 2019-01-12 19:20:50 +0100 | [diff] [blame] | 324 | #define PCI_DEVICE_ID_INTEL_DNV_LPC 0x19dc |
Sean Rhodes | 645dde7 | 2021-10-22 09:31:22 +0100 | [diff] [blame] | 325 | #define PCI_DEVICE_ID_INTEL_GLK_LPC 0x31E8 |
Nico Huber | 94473af | 2018-11-20 12:10:29 +0100 | [diff] [blame] | 326 | |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 327 | /* Intel starts counting these generations with the integration of the DRAM controller */ |
Stefan Tauner | dbc6fcd | 2013-06-20 18:05:06 +0200 | [diff] [blame] | 328 | #define PCI_DEVICE_ID_INTEL_CORE_0TH_GEN 0xd132 /* Nehalem */ |
Stefan Tauner | 04c0600 | 2012-10-13 02:19:30 +0200 | [diff] [blame] | 329 | #define PCI_DEVICE_ID_INTEL_CORE_1ST_GEN 0x0044 /* Westmere */ |
Felix Held | 0cc8f29 | 2014-11-05 03:18:44 +0100 | [diff] [blame] | 330 | #define PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_D 0x0100 /* Sandy Bridge (Desktop) */ |
| 331 | #define PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_M 0x0104 /* Sandy Bridge (Mobile) */ |
Felix Held | fac95e3 | 2014-11-09 00:11:28 +0100 | [diff] [blame] | 332 | #define PCI_DEVICE_ID_INTEL_CORE_2ND_GEN_E3 0x0108 /* Sandy Bridge (Xeon E3) */ |
| 333 | #define PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_D 0x0150 /* Ivy Bridge (Desktop) */ |
| 334 | #define PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_M 0x0154 /* Ivy Bridge (Mobile) */ |
| 335 | #define PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_E3 0x0158 /* Ivy Bridge (Xeon E3 v2) */ |
| 336 | #define PCI_DEVICE_ID_INTEL_CORE_3RD_GEN_015c 0x015c /* Ivy Bridge (?) */ |
| 337 | #define PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_D 0x0c00 /* Haswell (Desktop) */ |
| 338 | #define PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_M 0x0c04 /* Haswell (Mobile) */ |
| 339 | #define PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_E3 0x0c08 /* Haswell (Xeon E3 v3) */ |
Dennis Wassenberg | ae6685f | 2014-10-30 10:30:40 +0100 | [diff] [blame] | 340 | #define PCI_DEVICE_ID_INTEL_CORE_4TH_GEN_U 0x0a04 /* Haswell-ULT */ |
Matt DeVillier | 5b667df | 2015-05-14 21:58:33 -0500 | [diff] [blame] | 341 | #define PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_U 0x1604 /* Broadwell-ULT */ |
Angel Pons | f007ab7 | 2022-10-07 00:25:33 +0200 | [diff] [blame] | 342 | #define PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_D 0x1610 /* Broadwell (Desktop) */ |
| 343 | #define PCI_DEVICE_ID_INTEL_CORE_5TH_GEN_M 0x1614 /* Broadwell (Mobile) */ |
Nico Huber | 54fe32f | 2017-10-03 16:03:07 +0200 | [diff] [blame] | 344 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D2 0x190f /* Skylake (Desktop) */ |
Michael Niewöhner | 0d1366d | 2020-03-14 22:39:30 +0100 | [diff] [blame] | 345 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_U 0x1904 /* Skylake (Mobile) */ |
| 346 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_Y 0x190c /* Skylake (Mobile) */ |
Maximilian Schander | cb2d21d | 2017-10-28 14:45:48 +0200 | [diff] [blame] | 347 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_M 0x1910 /* Skylake (Mobile) */ |
Christoph Pomaska | 48ac29e | 2018-01-01 01:48:21 +0100 | [diff] [blame] | 348 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_WST 0x1918 /* Skylake (Workstation) */ |
| 349 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_D 0x191f /* Skylake (Desktop) */ |
Maxim Polyakov | 1317689 | 2019-08-27 18:20:08 +0300 | [diff] [blame] | 350 | #define PCI_DEVICE_ID_INTEL_CORE_6TH_GEN_E 0x2020 /* Skylake-E (Server) */ |
Matthew Garrett | 2bf28e5 | 2018-07-23 21:09:47 -0700 | [diff] [blame] | 351 | #define PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U 0x5904 /* Kabylake (Mobile) */ |
| 352 | #define PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_Y 0x590C /* Kabylake (Mobile) */ |
| 353 | #define PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_U_Q 0x5914 /* Kabylake (Mobile) */ |
Christian Walter | 9a8c5e7 | 2019-05-06 17:50:57 +0200 | [diff] [blame] | 354 | #define PCI_DEVICE_ID_INTEL_CORE_7TH_GEN_E3 0x5918 /* Kabylake Xeon E3 */ |
Matt DeVillier | 3c78445 | 2019-06-11 23:23:46 -0500 | [diff] [blame] | 355 | #define PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_1 0x3ed0 /* Coffeelake (Mobile) */ |
| 356 | #define PCI_DEVICE_ID_INTEL_CORE_8TH_GEN_U_2 0x3e34 /* Whiskeylake (Mobile) */ |
Johanna Schander | d756c27 | 2019-12-29 14:31:01 +0100 | [diff] [blame] | 357 | #define PCI_DEVICE_ID_INTEL_CORE_10TH_GEN_U 0x8a12 /* Icelake U */ |
Matt DeVillier | 62e883d | 2020-08-08 11:17:31 -0500 | [diff] [blame] | 358 | #define PCI_DEVICE_ID_INTEL_CORE_CML_U1 0x9b51 /* Cometlake U (Mobile) */ |
| 359 | #define PCI_DEVICE_ID_INTEL_CORE_CML_U2 0x9b61 /* Cometlake U (Mobile) */ |
| 360 | #define PCI_DEVICE_ID_INTEL_CORE_CML_U3 0x9b71 /* Cometlake U (Mobile) */ |
Michał Żygowski | 8ac40f3 | 2021-07-09 16:00:16 +0200 | [diff] [blame] | 361 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_U_2 0x9a04 /* Tigerlake UP3 2 Cores */ |
| 362 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_U_4 0x9a14 /* Tigerlake UP3 4 Cores */ |
| 363 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_Y_2 0x9a02 /* Tigerlake UP4 2 Cores */ |
| 364 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_Y_4 0x9a12 /* Tigerlake UP4 4 Cores */ |
| 365 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_H_4 0x9a16 /* Tigerlake H 4 Cores */ |
| 366 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_H_6 0x9a26 /* Tigerlake H 6 Cores */ |
| 367 | #define PCI_DEVICE_ID_INTEL_CORE_TGL_ID_H_8 0x9a36 /* Tigerlake H 8 Cores */ |
Stefan Reinauer | 91893ee | 2020-10-23 01:40:41 +0000 | [diff] [blame] | 368 | #define PCI_DEVICE_ID_INTEL_HEWITTLAKE 0x6f00 /* Hewitt Lake */ |
Jonathan Zhang | b18e194 | 2021-05-03 13:12:23 -0700 | [diff] [blame] | 369 | #define PCI_DEVICE_ID_INTEL_SAPPHIRERAPIDS_SP 0x09a2 /* Sapphire Rapids SP */ |
Michał Kopeć | 2d8edeb | 2022-04-05 10:40:03 +0200 | [diff] [blame] | 370 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_S_8_8 0x4660 /* Alderlake S LGA 8+8 */ |
| 371 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_S_8_4 0x4668 /* Alderlake S LGA 8+4 */ |
| 372 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_S_6_4 0x4648 /* Alderlake S LGA 6+4 */ |
| 373 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_S_8_0 0x4670 /* Alderlake S LGA 8+0 */ |
| 374 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_S_6_0 0x4650 /* Alderlake S LGA 6+0 */ |
| 375 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_HX_8_8 0x4637 /* Alderlake HX 8+8 */ |
| 376 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_HX_6_8 0x463B /* Alderlake HX 6+8 */ |
| 377 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_HX_4_8 0x4623 /* Alderlake HX 4+8 */ |
Kacper Stojek | fb9110b | 2022-08-17 10:28:20 +0200 | [diff] [blame] | 378 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_P_6_8 0x4641 /* Alderlake P 6+8 */ |
| 379 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_P_4_8 0x4621 /* Alderlake P 4+8 */ |
| 380 | #define PCI_DEVICE_ID_INTEL_CORE_ADL_ID_P_2_8 0x4601 /* Alderlake P 2+8 */ |
Anton Kochkov | c7fc442 | 2012-07-21 06:36:47 +0400 | [diff] [blame] | 381 | |
Patrick Rudolph | 2d26a36 | 2017-11-07 19:51:21 +0100 | [diff] [blame] | 382 | /* Intel GPUs */ |
| 383 | #define PCI_DEVICE_ID_INTEL_G35_EXPRESS 0x2982 |
| 384 | #define PCI_DEVICE_ID_INTEL_G35_EXPRESS_1 0x2983 |
| 385 | #define PCI_DEVICE_ID_INTEL_965_EXPRESS 0x2a02 |
| 386 | #define PCI_DEVICE_ID_INTEL_965_EXPRESS_1 0x2a03 |
| 387 | #define PCI_DEVICE_ID_INTEL_965_EXPRESS_2 0x2a12 |
| 388 | #define PCI_DEVICE_ID_INTEL_965_EXPRESS_3 0x2a13 |
| 389 | #define PCI_DEVICE_ID_INTEL_4_SERIES 0x2a42 |
| 390 | #define PCI_DEVICE_ID_INTEL_4_SERIES_1 0x2a43 |
| 391 | #define PCI_DEVICE_ID_INTEL_G45 0x2e22 |
| 392 | #define PCI_DEVICE_ID_INTEL_G45_1 0x2e23 |
| 393 | #define PCI_DEVICE_ID_INTEL_Q45 0x2e12 |
| 394 | #define PCI_DEVICE_ID_INTEL_Q45_1 0x2e13 |
| 395 | #define PCI_DEVICE_ID_INTEL_G41 0x2e32 |
| 396 | #define PCI_DEVICE_ID_INTEL_G41_1 0x2e33 |
| 397 | #define PCI_DEVICE_ID_INTEL_B43 0x2e42 |
| 398 | #define PCI_DEVICE_ID_INTEL_B43_1 0x2e43 |
| 399 | #define PCI_DEVICE_ID_INTEL_B43_2 0x2e92 |
| 400 | #define PCI_DEVICE_ID_INTEL_B43_3 0x2e93 |
| 401 | #define PCI_DEVICE_ID_INTEL_HD_GRAPHICS 0x0046 |
| 402 | #define PCI_DEVICE_ID_INTEL_HD_GRAPHICS_1 0x0042 |
| 403 | #define PCI_DEVICE_ID_INTEL_HD_GRAPHICS_2 0x0106 |
| 404 | #define PCI_DEVICE_ID_INTEL_HD_2000 0x0102 |
| 405 | #define PCI_DEVICE_ID_INTEL_HD_2000_1 0x0106 |
| 406 | #define PCI_DEVICE_ID_INTEL_HD_3000 0x0116 |
| 407 | #define PCI_DEVICE_ID_INTEL_HD_3000_1 0x0112 |
| 408 | #define PCI_DEVICE_ID_INTEL_HD_3000_2 0x0116 |
| 409 | #define PCI_DEVICE_ID_INTEL_HD_3000_3 0x0122 |
| 410 | #define PCI_DEVICE_ID_INTEL_HD_3000_4 0x0126 |
| 411 | #define PCI_DEVICE_ID_INTEL_HD_3000_5 0x0116 |
| 412 | #define PCI_DEVICE_ID_INTEL_HD_2500 0x0152 |
| 413 | #define PCI_DEVICE_ID_INTEL_HD_2500_1 0x0156 |
| 414 | #define PCI_DEVICE_ID_INTEL_HD_2500_2 0x015A |
| 415 | #define PCI_DEVICE_ID_INTEL_HD_4000 0x0162 |
| 416 | #define PCI_DEVICE_ID_INTEL_HD_4000_1 0x0166 |
| 417 | #define PCI_DEVICE_ID_INTEL_HD_4000_2 0x016A |
| 418 | #define PCI_DEVICE_ID_INTEL_HD_4600 0x0412 |
| 419 | #define PCI_DEVICE_ID_INTEL_HD_4600_1 0x0416 |
Sellerie | 409a5dc | 2019-07-26 15:09:18 +0200 | [diff] [blame] | 420 | #define PCI_DEVICE_ID_INTEL_HD_4400 0x041E |
Arashk Mahshidfar | e607ddc | 2022-05-20 11:20:21 +0430 | [diff] [blame] | 421 | #define PCI_DEVICE_ID_INTEL_HD_4400_1 0x0A16 |
Patrick Rudolph | 2d26a36 | 2017-11-07 19:51:21 +0100 | [diff] [blame] | 422 | #define PCI_DEVICE_ID_INTEL_HD_5000 0x0422 |
| 423 | #define PCI_DEVICE_ID_INTEL_HD_5000_1 0x0426 |
| 424 | #define PCI_DEVICE_ID_INTEL_HD_5000_2 0x042A |
Felix Singer | 24b000a | 2019-01-02 14:44:54 +0100 | [diff] [blame] | 425 | #define PCI_DEVICE_ID_INTEL_HD_510 0x1902 |
| 426 | #define PCI_DEVICE_ID_INTEL_HD_515 0x191E |
| 427 | #define PCI_DEVICE_ID_INTEL_HD_520 0x1916 |
| 428 | #define PCI_DEVICE_ID_INTEL_HD_530_1 0x191B |
| 429 | #define PCI_DEVICE_ID_INTEL_HD_530_2 0x1912 |
| 430 | #define PCI_DEVICE_ID_INTEL_UHD_615_1 0x591C |
| 431 | #define PCI_DEVICE_ID_INTEL_UHD_615_2 0x591E |
| 432 | #define PCI_DEVICE_ID_INTEL_UHD_617 0x87C0 |
| 433 | #define PCI_DEVICE_ID_INTEL_UHD_620_1 0x5917 |
| 434 | #define PCI_DEVICE_ID_INTEL_UHD_620_2 0x3EA0 |
| 435 | #define PCI_DEVICE_ID_INTEL_UHD_620_3 0x5916 |
| 436 | #define PCI_DEVICE_ID_INTEL_UHD_630_1 0x3E92 |
| 437 | #define PCI_DEVICE_ID_INTEL_UHD_630_2 0x3E9B |
| 438 | #define PCI_DEVICE_ID_INTEL_UHD_630_3 0x3E91 |
| 439 | #define PCI_DEVICE_ID_INTEL_UHD_630_4 0x5912 |
| 440 | #define PCI_DEVICE_ID_INTEL_UHD_630_5 0x591B |
| 441 | #define PCI_DEVICE_ID_INTEL_UHD_630_6 0x5902 |
| 442 | #define PCI_DEVICE_ID_INTEL_UHD_630_7 0x3E98 |
| 443 | #define PCI_DEVICE_ID_INTEL_UHD_640 0x5926 |
| 444 | #define PCI_DEVICE_ID_INTEL_IRIS_540 0x1926 |
| 445 | #define PCI_DEVICE_ID_INTEL_IRIS_550 0x1927 |
| 446 | #define PCI_DEVICE_ID_INTEL_IRIS_PRO_580 0x193B |
| 447 | #define PCI_DEVICE_ID_INTEL_IRIS_PLUS_650 0x5927 |
| 448 | #define PCI_DEVICE_ID_INTEL_IRIS_PLUS_655 0x3EA5 |
Johanna Schander | d756c27 | 2019-12-29 14:31:01 +0100 | [diff] [blame] | 449 | #define PCI_DEVICE_ID_INTEL_IRIS_PLUS_G7 0x8A52 |
Matt DeVillier | 62e883d | 2020-08-08 11:17:31 -0500 | [diff] [blame] | 450 | #define PCI_DEVICE_ID_INTEL_UHD_GRAPHICS 0x9b41 |
Michał Żygowski | 8ac40f3 | 2021-07-09 16:00:16 +0200 | [diff] [blame] | 451 | #define PCI_DEVICE_ID_INTEL_TGL_GT2_Y 0x9A40 |
| 452 | #define PCI_DEVICE_ID_INTEL_TGL_GT2_UY 0x9A49 |
| 453 | #define PCI_DEVICE_ID_INTEL_TGL_GT1 0x9A60 |
| 454 | #define PCI_DEVICE_ID_INTEL_TGL_GT1_2 0x9A68 |
| 455 | #define PCI_DEVICE_ID_INTEL_TGL_GT2_ULT_1 0x9A78 |
| 456 | #define PCI_DEVICE_ID_INTEL_TGL_GT2_ULT_2 0x9A70 |
Michał Kopeć | 2d8edeb | 2022-04-05 10:40:03 +0200 | [diff] [blame] | 457 | #define PCI_DEVICE_ID_INTEL_ADL_S_GT1 0x4680 |
| 458 | #define PCI_DEVICE_ID_INTEL_ADL_S_GT1_2 0x4682 |
| 459 | #define PCI_DEVICE_ID_INTEL_ADL_S_GT1_3 0x4690 |
| 460 | #define PCI_DEVICE_ID_INTEL_ADL_S_GT1_4 0x4692 |
Patrick Rudolph | 2d26a36 | 2017-11-07 19:51:21 +0100 | [diff] [blame] | 461 | |
Idwer Vollering | 3f91d81 | 2010-10-24 13:50:13 +0000 | [diff] [blame] | 462 | #if !defined(__DARWIN__) && !defined(__FreeBSD__) |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 463 | typedef struct { uint32_t hi, lo; } msr_t; |
Stefan Reinauer | 1162f25 | 2008-12-04 15:18:20 +0000 | [diff] [blame] | 464 | #endif |
Idwer Vollering | 3f91d81 | 2010-10-24 13:50:13 +0000 | [diff] [blame] | 465 | #if defined (__FreeBSD__) |
| 466 | /* FreeBSD already has conflicting definitions for wrmsr/rdmsr. */ |
| 467 | #undef rdmsr |
| 468 | #undef wrmsr |
| 469 | #define rdmsr freebsd_rdmsr |
| 470 | #define wrmsr freebsd_wrmsr |
| 471 | typedef struct { uint32_t hi, lo; } msr_t; |
Idwer Vollering | 3f91d81 | 2010-10-24 13:50:13 +0000 | [diff] [blame] | 472 | #endif |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 473 | typedef struct { uint16_t addr; int size; char *name; } io_register_t; |
Pratik Prajapati | 91664d4 | 2017-07-24 13:53:26 -0700 | [diff] [blame] | 474 | typedef struct { |
| 475 | uint32_t eax; |
| 476 | uint32_t ebx; |
| 477 | uint32_t ecx; |
| 478 | uint32_t edx; |
| 479 | } cpuid_result_t; |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 480 | |
Stefan Reinauer | cff573d | 2011-03-18 22:08:39 +0000 | [diff] [blame] | 481 | void *map_physical(uint64_t phys_addr, size_t len); |
Stefan Reinauer | f7f2f25 | 2009-09-01 09:52:14 +0000 | [diff] [blame] | 482 | void unmap_physical(void *virt_addr, size_t len); |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 483 | |
| 484 | unsigned int cpuid(unsigned int op); |
Maxim Polyakov | d8163ed | 2019-10-09 18:35:23 +0300 | [diff] [blame] | 485 | int print_intel_msrs(unsigned int range_start, unsigned int range_end); |
Vladimir Serbinenko | fb69a69 | 2015-10-10 13:20:32 +0200 | [diff] [blame] | 486 | int print_mchbar(struct pci_dev *nb, struct pci_access *pacc, const char *dump_spd_file); |
Tobias Diedrich | 3645e61 | 2010-11-27 14:44:19 +0000 | [diff] [blame] | 487 | int print_pmbase(struct pci_dev *sb, struct pci_access *pacc); |
Michael Niewöhner | 9952e72 | 2020-03-13 22:22:26 +0100 | [diff] [blame] | 488 | int print_lpc(struct pci_dev *sb, struct pci_access *pacc); |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 489 | int print_rcba(struct pci_dev *sb); |
Iru Cai | ab5cac2 | 2019-07-14 23:04:05 +0800 | [diff] [blame] | 490 | void print_iobp(struct pci_dev *sb, volatile uint8_t *rcba); |
Nico Huber | 09dcbf0 | 2013-04-01 15:08:04 +0200 | [diff] [blame] | 491 | int print_gpios(struct pci_dev *sb, int show_all, int show_diffs); |
Johanna Schander | e32ded8 | 2020-01-29 10:08:17 +0100 | [diff] [blame] | 492 | const struct gpio_community *const *get_gpio_communities(struct pci_dev *const sb, |
| 493 | size_t* community_count, |
| 494 | size_t* pad_stepping); |
Nico Huber | 1898023 | 2017-04-07 12:26:07 +0200 | [diff] [blame] | 495 | void print_gpio_groups(struct pci_dev *sb); |
Stefan Reinauer | 2319027 | 2008-08-20 13:41:24 +0000 | [diff] [blame] | 496 | int print_epbar(struct pci_dev *nb); |
| 497 | int print_dmibar(struct pci_dev *nb); |
| 498 | int print_pciexbar(struct pci_dev *nb); |
Sven Schnelle | 4b7b320 | 2012-01-08 15:27:18 +0100 | [diff] [blame] | 499 | int print_ambs(struct pci_dev *nb, struct pci_access *pacc); |
Alexander Couzens | aa3dd5d | 2015-01-03 02:52:10 +0100 | [diff] [blame] | 500 | int print_spi(struct pci_dev *sb); |
Vladimir Serbinenko | 188aec0 | 2015-05-20 14:04:41 +0200 | [diff] [blame] | 501 | int print_gfx(struct pci_dev *gfx); |
Iru Cai | 904538b | 2016-06-08 22:39:22 +0800 | [diff] [blame] | 502 | int print_ahci(struct pci_dev *ahci); |
Pratik Prajapati | 91664d4 | 2017-07-24 13:53:26 -0700 | [diff] [blame] | 503 | int print_sgx(void); |
Pratik Prajapati | 1e67816 | 2020-09-03 11:28:19 -0700 | [diff] [blame] | 504 | void print_tme(void); |
Pratikkumar Prajapati | c262b44 | 2022-12-19 09:52:34 -0800 | [diff] [blame] | 505 | void print_keylocker(void); |
Vladimir Serbinenko | fb69a69 | 2015-10-10 13:20:32 +0200 | [diff] [blame] | 506 | void ivybridge_dump_timings(const char *dump_spd_file); |
Nico Huber | 99b02a1 | 2017-04-05 17:39:57 +0200 | [diff] [blame] | 507 | |
| 508 | #endif |