blob: 596fc5325ca5877940eb739fe96a66b64600321a [file] [log] [blame]
Uwe Hermannba290d12009-06-17 12:07:12 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2009 Uwe Hermann <uwe@hermann-uwe.de>
5 * Copyright (C) 2009 Carl-Daniel Hailfinger
Stefan Tauner4a038652013-07-17 09:28:00 +00006 * Copyright (C) 2011-2013 Stefan Tauner
Uwe Hermannba290d12009-06-17 12:07:12 +00007 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
Uwe Hermannba290d12009-06-17 12:07:12 +000017 */
18
Carl-Daniel Hailfinger831e8f42010-05-30 22:24:40 +000019#include <stdio.h>
Uwe Hermannba290d12009-06-17 12:07:12 +000020#include <string.h>
21#include <stdlib.h>
Nico Huber519be662018-12-23 20:03:35 +010022#include <stddef.h>
Uwe Hermannba290d12009-06-17 12:07:12 +000023#include "flash.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000024#include "programmer.h"
Uwe Hermannba290d12009-06-17 12:07:12 +000025
Stefan Tauner1181ee22014-06-01 02:13:23 +000026static const char *test_state_to_text(enum test_state test_state)
27{
28 switch (test_state) {
29 case OK: return "OK";
30 case BAD: return "Not working";
31 case NA: return "N/A";
32 case DEP: return "Config-dependent";
33 case NT:
34 default: return "Untested";
35 }
36}
37
Niklas Söderlundede2fa42012-10-23 13:06:46 +000038static int print_supported_chips(void)
Uwe Hermannba290d12009-06-17 12:07:12 +000039{
Stefan Tauner29e5d312011-09-12 22:55:01 +000040 const char *delim = "/";
41 const int mintoklen = 5;
42 const int border = 2;
43 int i, chipcount = 0;
Stefan Tauner7bcacb12011-05-26 01:35:19 +000044 int maxvendorlen = strlen("Vendor") + 1;
45 int maxchiplen = strlen("Device") + 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +000046 int maxtypelen = strlen("Type") + 1;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000047 const struct flashchip *chip;
Stefan Tauner00155492011-06-26 20:45:35 +000048 char *s;
Stefan Tauner4a038652013-07-17 09:28:00 +000049 char *ven, *dev;
50 char *tmpven, *tmpdev, *tmpven_save, *tmpdev_save;
Stefan Tauner29e5d312011-09-12 22:55:01 +000051 int tmpvenlen, tmpdevlen, curvenlen, curdevlen;
Uwe Hermannba290d12009-06-17 12:07:12 +000052
Stefan Tauner29e5d312011-09-12 22:55:01 +000053 /* calculate maximum column widths and by iterating over all chips */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000054 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +000055 /* Ignore generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000056 if (!strncmp(chip->vendor, "Unknown", 7) ||
57 !strncmp(chip->vendor, "Programmer", 10) ||
58 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +000059 continue;
Uwe Hermannba290d12009-06-17 12:07:12 +000060 chipcount++;
Stefan Tauner29e5d312011-09-12 22:55:01 +000061
62 /* Find maximum vendor length (respecting line splitting). */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000063 tmpven = (char *)chip->vendor;
Stefan Tauner29e5d312011-09-12 22:55:01 +000064 do {
65 /* and take minimum token lengths into account */
66 tmpvenlen = 0;
67 do {
68 tmpvenlen += strcspn(tmpven, delim);
69 /* skip to the address after the first token */
70 tmpven += tmpvenlen;
71 if (tmpven[0] == '\0')
72 break;
73 tmpven++;
74 } while (tmpvenlen < mintoklen);
75 maxvendorlen = max(maxvendorlen, tmpvenlen);
76 if (tmpven[0] == '\0')
77 break;
78 } while (1);
79
80 /* same for device name */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000081 tmpdev = (char *)chip->name;
Stefan Tauner29e5d312011-09-12 22:55:01 +000082 do {
83 tmpdevlen = 0;
84 do {
85 tmpdevlen += strcspn(tmpdev, delim);
86 tmpdev += tmpdevlen;
87 if (tmpdev[0] == '\0')
88 break;
89 tmpdev++;
90 } while (tmpdevlen < mintoklen);
91 maxchiplen = max(maxchiplen, tmpdevlen);
92 if (tmpdev[0] == '\0')
93 break;
94 } while (1);
95
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000096 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +000097 maxtypelen = max(maxtypelen, strlen(s));
98 free(s);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000099 }
Stefan Tauner29e5d312011-09-12 22:55:01 +0000100 maxvendorlen += border;
101 maxchiplen += border;
102 maxtypelen += border;
Uwe Hermannba290d12009-06-17 12:07:12 +0000103
Stefan Tauner12589362011-06-25 17:36:25 +0000104 msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
105 msg_ginfo("Vendor");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000106 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000107 msg_ginfo(" ");
108 msg_ginfo("Device");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000109 for (i = strlen("Device"); i < maxchiplen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000110 msg_ginfo(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000111
Stefan Tauner29e5d312011-09-12 22:55:01 +0000112 msg_ginfo("Test");
113 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000114 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000115 msg_ginfo("Known");
116 for (i = 0; i < border; i++)
117 msg_ginfo(" ");
Stefan Tauner0554ca52013-07-25 22:54:25 +0000118 msg_ginfo(" Size ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000119 for (i = 0; i < border; i++)
120 msg_ginfo(" ");
121
122 msg_ginfo("Type");
123 for (i = strlen("Type"); i < maxtypelen; i++)
124 msg_ginfo(" ");
125 msg_gdbg("Voltage");
126 msg_ginfo("\n");
127
128 for (i = 0; i < maxvendorlen + maxchiplen; i++)
129 msg_ginfo(" ");
130 msg_ginfo("OK ");
131 for (i = 0; i < border; i++)
132 msg_ginfo(" ");
133 msg_ginfo("Broken");
134 for (i = 0; i < border; i++)
135 msg_ginfo(" ");
Stefan Tauner0554ca52013-07-25 22:54:25 +0000136 msg_ginfo("[kB] ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000137 for (i = 0; i < border + maxtypelen; i++)
138 msg_ginfo(" ");
139 msg_gdbg("range [V]");
140 msg_ginfo("\n\n");
Stefan Tauner5c316f92015-02-08 21:57:52 +0000141 msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE, - = N/A)\n\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000142
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000143 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +0000144 /* Don't print generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000145 if (!strncmp(chip->vendor, "Unknown", 7) ||
146 !strncmp(chip->vendor, "Programmer", 10) ||
147 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +0000148 continue;
149
Stefan Tauner29e5d312011-09-12 22:55:01 +0000150 /* support for multiline vendor names:
151 * - make a copy of the original vendor name
152 * - use strok to put the first token in tmpven
153 * - keep track of the length of all tokens on the current line
154 * for ' '-padding in curvenlen
155 * - check if additional tokens should be printed on the current
156 * line
157 * - after all other values are printed print the surplus tokens
158 * on fresh lines
159 */
Stefan Tauner4a038652013-07-17 09:28:00 +0000160 ven = malloc(strlen(chip->vendor) + 1);
161 if (ven == NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000162 msg_gerr("Out of memory!\n");
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000163 return 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000164 }
Stefan Tauner4a038652013-07-17 09:28:00 +0000165 strcpy(ven, chip->vendor);
Uwe Hermannba290d12009-06-17 12:07:12 +0000166
Stefan Tauner4a038652013-07-17 09:28:00 +0000167 tmpven = strtok_r(ven, delim, &tmpven_save);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000168 msg_ginfo("%s", tmpven);
169 curvenlen = strlen(tmpven);
Stefan Tauner4a038652013-07-17 09:28:00 +0000170 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000171 msg_ginfo("%s", delim);
172 curvenlen++;
173 tmpvenlen = strlen(tmpven);
174 if (tmpvenlen >= mintoklen)
175 break; /* big enough to be on its own line */
176 msg_ginfo("%s", tmpven);
177 curvenlen += tmpvenlen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000178 }
179
Stefan Tauner29e5d312011-09-12 22:55:01 +0000180 for (i = curvenlen; i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000181 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000182
183 /* support for multiline device names as above */
Stefan Tauner4a038652013-07-17 09:28:00 +0000184 dev = malloc(strlen(chip->name) + 1);
185 if (dev == NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000186 msg_gerr("Out of memory!\n");
Jacob Garber4a7970b2019-08-12 14:31:46 -0600187 free(ven);
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000188 return 1;
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000189 }
Stefan Tauner4a038652013-07-17 09:28:00 +0000190 strcpy(dev, chip->name);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000191
Stefan Tauner4a038652013-07-17 09:28:00 +0000192 tmpdev = strtok_r(dev, delim, &tmpdev_save);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000193 msg_ginfo("%s", tmpdev);
194 curdevlen = strlen(tmpdev);
Stefan Tauner4a038652013-07-17 09:28:00 +0000195 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000196 msg_ginfo("%s", delim);
197 curdevlen++;
198 tmpdevlen = strlen(tmpdev);
199 if (tmpdevlen >= mintoklen)
200 break; /* big enough to be on its own line */
201 msg_ginfo("%s", tmpdev);
202 curdevlen += tmpdevlen;
203 }
204
205 for (i = curdevlen; i < maxchiplen; i++)
206 msg_ginfo(" ");
207
Stefan Tauner6455dff2014-05-26 00:36:24 +0000208 if (chip->tested.probe == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000209 msg_ginfo("P");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000210 else if (chip->tested.probe == NA)
211 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000212 else
213 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000214 if (chip->tested.read == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000215 msg_ginfo("R");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000216 else if (chip->tested.read == NA)
217 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000218 else
219 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000220 if (chip->tested.erase == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000221 msg_ginfo("E");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000222 else if (chip->tested.erase == NA)
223 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000224 else
225 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000226 if (chip->tested.write == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000227 msg_ginfo("W");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000228 else if (chip->tested.write == NA)
229 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000230 else
231 msg_ginfo(" ");
232 for (i = 0; i < border; i++)
233 msg_ginfo(" ");
234
Stefan Tauner6455dff2014-05-26 00:36:24 +0000235 if (chip->tested.probe == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000236 msg_ginfo("P");
237 else
238 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000239 if (chip->tested.read == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000240 msg_ginfo("R");
241 else
242 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000243 if (chip->tested.erase == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000244 msg_ginfo("E");
245 else
246 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000247 if (chip->tested.write == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000248 msg_ginfo("W");
249 else
250 msg_ginfo(" ");
251 for (i = 0; i < border + 1; i++)
252 msg_ginfo(" ");
253
Stefan Tauner0554ca52013-07-25 22:54:25 +0000254 msg_ginfo("%6d", chip->total_size);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000255 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000256 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000257
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000258 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000259 msg_ginfo("%s", s);
260 for (i = strlen(s); i < maxtypelen; i++)
261 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000262 free(s);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000263
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000264 if (chip->voltage.min == 0 && chip->voltage.max == 0)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000265 msg_gdbg("no info");
266 else
267 msg_gdbg("%0.02f;%0.02f",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000268 chip->voltage.min/(double)1000,
269 chip->voltage.max/(double)1000);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000270
271 /* print surplus vendor and device name tokens */
272 while (tmpven != NULL || tmpdev != NULL) {
273 msg_ginfo("\n");
274 if (tmpven != NULL){
275 msg_ginfo("%s", tmpven);
276 curvenlen = strlen(tmpven);
Stefan Tauner4a038652013-07-17 09:28:00 +0000277 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000278 msg_ginfo("%s", delim);
279 curvenlen++;
280 tmpvenlen = strlen(tmpven);
281 /* big enough to be on its own line */
282 if (tmpvenlen >= mintoklen)
283 break;
284 msg_ginfo("%s", tmpven);
285 curvenlen += tmpvenlen;
286 }
287 } else
288 curvenlen = 0;
289
290 for (i = curvenlen; i < maxvendorlen; i++)
291 msg_ginfo(" ");
292
293 if (tmpdev != NULL){
294 msg_ginfo("%s", tmpdev);
295 curdevlen = strlen(tmpdev);
Stefan Tauner4a038652013-07-17 09:28:00 +0000296 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000297 msg_ginfo("%s", delim);
298 curdevlen++;
299 tmpdevlen = strlen(tmpdev);
300 /* big enough to be on its own line */
301 if (tmpdevlen >= mintoklen)
302 break;
303 msg_ginfo("%s", tmpdev);
304 curdevlen += tmpdevlen;
305 }
306 }
307 }
308 msg_ginfo("\n");
Stefan Tauner4a038652013-07-17 09:28:00 +0000309 free(ven);
310 free(dev);
Uwe Hermannba290d12009-06-17 12:07:12 +0000311 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000312
313 return 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000314}
315
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000316#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000317static void print_supported_chipsets(void)
Uwe Hermannba290d12009-06-17 12:07:12 +0000318{
Nico Huber519be662018-12-23 20:03:35 +0100319 unsigned int i, chipsetcount = 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000320 const struct penable *c = chipset_enables;
Nico Huber519be662018-12-23 20:03:35 +0100321 size_t maxvendorlen = strlen("Vendor") + 1;
322 size_t maxchipsetlen = strlen("Chipset") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000323
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000324 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Uwe Hermannba290d12009-06-17 12:07:12 +0000325 chipsetcount++;
Nico Huber519be662018-12-23 20:03:35 +0100326 maxvendorlen = MAX(maxvendorlen, strlen(c->vendor_name));
327 maxchipsetlen = MAX(maxchipsetlen, strlen(c->device_name));
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000328 }
329 maxvendorlen++;
330 maxchipsetlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000331
Nico Huber519be662018-12-23 20:03:35 +0100332 msg_ginfo("Supported chipsets (total: %u):\n\n", chipsetcount);
Uwe Hermannba290d12009-06-17 12:07:12 +0000333
Stefan Tauner12589362011-06-25 17:36:25 +0000334 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000335 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000336 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000337
Stefan Tauner12589362011-06-25 17:36:25 +0000338 msg_ginfo("Chipset");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000339 for (i = strlen("Chipset"); i < maxchipsetlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000340 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000341
Stefan Tauner428ba2b2014-06-02 00:34:58 +0000342 msg_ginfo("PCI IDs Status\n\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000343
344 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000345 msg_ginfo("%s", c->vendor_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000346 for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000347 msg_ginfo(" ");
348 msg_ginfo("%s", c->device_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000349 for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000350 msg_ginfo(" ");
Stefan Tauner428ba2b2014-06-02 00:34:58 +0000351 msg_ginfo("%04x:%04x %s\n", c->vendor_id, c->device_id,
352 test_state_to_text(c->status));
Uwe Hermannba290d12009-06-17 12:07:12 +0000353 }
354}
355
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000356static void print_supported_boards_helper(const struct board_info *boards,
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000357 const char *devicetype)
Uwe Hermannba290d12009-06-17 12:07:12 +0000358{
Nico Huber519be662018-12-23 20:03:35 +0100359 unsigned int i;
Stefan Tauner2c20b282012-07-28 19:35:26 +0000360 unsigned int boardcount_good = 0, boardcount_bad = 0, boardcount_nt = 0;
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000361 const struct board_match *e = board_matches;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000362 const struct board_info *b = boards;
Nico Huber519be662018-12-23 20:03:35 +0100363 size_t maxvendorlen = strlen("Vendor") + 1;
364 size_t maxboardlen = strlen("Board") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000365
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000366 for (b = boards; b->vendor != NULL; b++) {
367 maxvendorlen = max(maxvendorlen, strlen(b->vendor));
368 maxboardlen = max(maxboardlen, strlen(b->name));
Stefan Tauner2c20b282012-07-28 19:35:26 +0000369 if (b->working == OK)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000370 boardcount_good++;
Stefan Tauner2c20b282012-07-28 19:35:26 +0000371 else if (b->working == NT)
372 boardcount_nt++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000373 else
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000374 boardcount_bad++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000375 }
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000376 maxvendorlen++;
377 maxboardlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000378
Stefan Tauner2c20b282012-07-28 19:35:26 +0000379 msg_ginfo("%d known %s (good: %d, untested: %d, bad: %d):\n\n",
380 boardcount_good + boardcount_nt + boardcount_bad,
381 devicetype, boardcount_good, boardcount_nt, boardcount_bad);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000382
Stefan Tauner12589362011-06-25 17:36:25 +0000383 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000384 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000385 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000386
Stefan Tauner12589362011-06-25 17:36:25 +0000387 msg_ginfo("Board");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000388 for (i = strlen("Board"); i < maxboardlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000389 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000390
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000391 msg_ginfo("Status Required value for\n");
392 for (i = 0; i < maxvendorlen + maxboardlen + strlen("Status "); i++)
393 msg_ginfo(" ");
394 msg_ginfo("-p internal:mainboard=\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000395
396 for (b = boards; b->vendor != NULL; b++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000397 msg_ginfo("%s", b->vendor);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000398 for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000399 msg_ginfo(" ");
400 msg_ginfo("%s", b->name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000401 for (i = 0; i < maxboardlen - strlen(b->name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000402 msg_ginfo(" ");
Stefan Reinauerf94d9ce2014-04-26 16:11:07 +0000403
Edward O'Callaghan61e16e52019-11-17 14:29:33 +1100404 msg_pinfo(test_state_to_text(b->working));
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000405
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000406 for (e = board_matches; e->vendor_name != NULL; e++) {
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000407 if (strcmp(e->vendor_name, b->vendor)
408 || strcmp(e->board_name, b->name))
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000409 continue;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000410 if (e->lb_vendor == NULL)
Stefan Tauner12589362011-06-25 17:36:25 +0000411 msg_ginfo("(autodetected)");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000412 else
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000413 msg_ginfo("%s:%s", e->lb_vendor,
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000414 e->lb_part);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000415 }
Stefan Tauner12589362011-06-25 17:36:25 +0000416 msg_ginfo("\n");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000417 }
Uwe Hermannba290d12009-06-17 12:07:12 +0000418}
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000419#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000420
Jacob Garberbeeb8bc2019-06-21 15:24:17 -0600421static void print_supported_devs(const struct programmer_entry prog, const char *const type)
Stefan Tauneraf358d62012-12-27 18:40:26 +0000422{
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000423 const struct dev_entry *const devs = prog.devs.dev;
424 msg_ginfo("\nSupported %s devices for the %s programmer:\n", type, prog.name);
Stefan Tauner1181ee22014-06-01 02:13:23 +0000425 unsigned int maxvendorlen = strlen("Vendor") + 1;
426 unsigned int maxdevlen = strlen("Device") + 1;
427
428 unsigned int i;
Stefan Tauneraf358d62012-12-27 18:40:26 +0000429 for (i = 0; devs[i].vendor_name != NULL; i++) {
Stefan Tauner1181ee22014-06-01 02:13:23 +0000430 maxvendorlen = max(maxvendorlen, strlen(devs[i].vendor_name));
431 maxdevlen = max(maxdevlen, strlen(devs[i].device_name));
432 }
433 maxvendorlen++;
434 maxdevlen++;
435
436 msg_ginfo("Vendor");
437 for (i = strlen("Vendor"); i < maxvendorlen; i++)
438 msg_ginfo(" ");
439
440 msg_ginfo("Device");
441 for (i = strlen("Device"); i < maxdevlen; i++)
442 msg_ginfo(" ");
443
444 msg_ginfo(" %s IDs Status\n", type);
445
446 for (i = 0; devs[i].vendor_name != NULL; i++) {
447 msg_ginfo("%s", devs[i].vendor_name);
448 unsigned int j;
449 for (j = strlen(devs[i].vendor_name); j < maxvendorlen; j++)
450 msg_ginfo(" ");
451 msg_ginfo("%s", devs[i].device_name);
452 for (j = strlen(devs[i].device_name); j < maxdevlen; j++)
453 msg_ginfo(" ");
454
455 msg_pinfo(" %04x:%04x %s\n", devs[i].vendor_id, devs[i].device_id,
456 test_state_to_text(devs[i].status));
Stefan Tauneraf358d62012-12-27 18:40:26 +0000457 }
458}
459
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000460int print_supported(void)
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000461{
Stefan Tauneraf358d62012-12-27 18:40:26 +0000462 unsigned int i;
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000463 if (print_supported_chips())
464 return 1;
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000465
Stefan Tauner12589362011-06-25 17:36:25 +0000466 msg_ginfo("\nSupported programmers:\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000467 list_programmers_linebreak(0, 80, 0);
Stefan Taunerb226cb12012-11-24 18:59:39 +0000468 msg_ginfo("\n");
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000469#if CONFIG_INTERNAL == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000470 msg_ginfo("\nSupported devices for the %s programmer:\n\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000471 programmer_table[PROGRAMMER_INTERNAL].name);
472 print_supported_chipsets();
Stefan Tauner12589362011-06-25 17:36:25 +0000473 msg_ginfo("\n");
Stefan Tauner74dc73f2015-03-01 22:04:38 +0000474 print_supported_boards_helper(boards_known, "mainboards");
Stefan Tauner12589362011-06-25 17:36:25 +0000475 msg_ginfo("\n");
Stefan Tauner74dc73f2015-03-01 22:04:38 +0000476 print_supported_boards_helper(laptops_known, "mobile devices");
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000477#endif
Stefan Tauneraf358d62012-12-27 18:40:26 +0000478 for (i = 0; i < PROGRAMMER_INVALID; i++) {
479 const struct programmer_entry prog = programmer_table[i];
480 switch (prog.type) {
481 case USB:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000482 print_supported_devs(prog, "USB");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000483 break;
Stefan Tauneraf358d62012-12-27 18:40:26 +0000484 case PCI:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000485 print_supported_devs(prog, "PCI");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000486 break;
Stefan Tauneraf358d62012-12-27 18:40:26 +0000487 case OTHER:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000488 if (prog.devs.note != NULL) {
489 msg_ginfo("\nSupported devices for the %s programmer:\n", prog.name);
490 msg_ginfo("%s", prog.devs.note);
491 }
Stefan Tauneraf358d62012-12-27 18:40:26 +0000492 break;
493 default:
494 msg_gerr("\n%s: %s: Uninitialized programmer type! Please report a bug at "
495 "flashrom@flashrom.org\n", __func__, prog.name);
496 break;
497 }
498 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000499 return 0;
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000500}
501
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000502#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger4146ced2010-06-07 11:10:43 +0000503
504#ifdef CONFIG_PRINT_WIKI
505#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
506#else
507#define B(vendor, name, status, url, note) { vendor, name, status }
508#endif
509
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000510/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000511const struct board_info boards_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000512#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +0000513 B("A-Trend", "ATC-6220", OK, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
514 B("abit", "A-S78H", OK, NULL, NULL),
515 B("abit", "AN-M2", OK, NULL, NULL),
516 B("abit", "AV8", OK, NULL, NULL),
517 B("abit", "AX8", OK, NULL, NULL),
Stefan Tauner2c5b65e2013-10-26 17:02:03 +0000518 B("abit", "BF6", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000519 B("abit", "BM6", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000520 B("abit", "BX6 2.0", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000521 B("abit", "Fatal1ty F-I90HD", OK, NULL, NULL),
522 B("abit", "IC7", OK, NULL, NULL),
523 B("abit", "IP35", OK, NULL, NULL),
524 B("abit", "IP35 Pro", OK, NULL, NULL),
525 B("abit", "IS-10", BAD, NULL, "Reported by deejkuba@aol.com to flashrom@coreboot.org, no public archive. Missing board enable and/or M50FW040 unlocking. May work now."),
526 B("abit", "KN8 Ultra", OK, NULL, NULL),
Stefan Tauner74dc73f2015-03-01 22:04:38 +0000527 B("abit", "KN9 Ultra", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000528 B("abit", "NF-M2 nView", OK, NULL, NULL),
529 B("abit", "NF-M2S", OK, NULL, NULL),
530 B("abit", "NF7-S", OK, NULL, NULL),
531 B("abit", "VA6", OK, NULL, NULL),
532 B("abit", "VT6X4", OK, NULL, NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000533 B("Acer", "V75-M", OK, NULL, "This is an OEM board used by IBM in e.g. Aptiva 2170-G"),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000534 B("Acer", "EM61SM/EM61PM", OK, NULL, "Used in Acer Aspire T180 and E380. Seems to be an OEM variant of abit's NF-M2S."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000535 B("Acorp", "6A815EPD", OK, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000536 B("Acorp", "6M810C", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000537 B("ADLINK", "Express-HR", OK, "http://www.adlinktech.com/PD/web/PD_detail.php?pid=1012", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000538 B("Advantech", "PCM-5820", OK, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
539 B("agami", "Aruma", OK, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
540 B("Albatron", "PM266A Pro", OK, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
Stefan Taunere34e3e82013-01-01 00:06:51 +0000541 B("Alienware", "Aurora-R2", BAD, NULL, "Mainboard model is 0RV30W. Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000542 B("AOpen", "i945GMx-VFX", OK, NULL, "This is (also?) an OEM board from FSC (used in e.g. ESPRIMO Q5010 with designation D2544-B1)."),
Stefan Tauner5c316f92015-02-08 21:57:52 +0000543 B("AOpen", "UK79G-1394", OK, "http://global.aopen.com/products_detail.aspx?auno=9", "Used in EZ18 barebones"),
544 B("AOpen", "vKM400Am-S", OK, "http://global.aopen.com/products_detail.aspx?Auno=824", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000545 B("Artec Group","DBE61", OK, "http://wiki.thincan.org/DBE61", NULL),
546 B("Artec Group","DBE62", OK, "http://wiki.thincan.org/DBE62", NULL),
547 B("ASI", "MB-5BLMP", OK, "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III thin client."),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000548 B("ASRock", "4CoreDual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=4CoreDual-VSTA", "W39V040FB"),
549 B("ASRock", "775Dual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=775Dual-VSTA", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000550 B("ASRock", "775i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
551 B("ASRock", "880G Pro3", OK, "http://www.asrock.com/mb/overview.asp?Model=880G%20Pro3", NULL),
552 B("ASRock", "890GX Extreme3", OK, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
553 B("ASRock", "939A785GMH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000554 B("ASRock", "960GM-GS3 FX", OK, "http://www.asrock.com/mb/overview.asp?Model=960GM-GS3%20FX", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000555 B("ASRock", "A330GC", OK, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
556 B("ASRock", "A770CrossFire", OK, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000557 B("ASRock", "A780FullHD", OK, "http://www.asrock.com/mb/overview.asp?Model=A780FullHD", "While flashrom is working correctly, there might be problems with the firmware images themselves. Please see https://flashrom.org/pipermail/flashrom/2012-July/009600.html for details."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000558 B("ASRock", "ALiveNF6G-DVI", OK, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
559 B("ASRock", "AM2NF6G-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000560 B("ASRock", "AMCP7AION-HT", OK, "http://www.asrock.com/nettop/NVIDIA/ION%20330HT/", "Used in ION 330HT(-BD) barebones."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000561 B("ASRock", "ConRoeXFire-eSATA2", OK, "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000562 B("ASRock", "E350M1/USB3", OK, "http://www.asrock.com/mb/overview.asp?model=e350m1/usb3", "Vendor firmware writes to flash at shutdown. This probably corrupts the flash in case you write coreboot while running the vendor firmware. Simply updating the vendor firmware should be fine."),
Stefan Tauner0be072c2016-03-13 15:16:30 +0000563 B("ASRock", "Fatal1ty 970 Performance", OK, "http://www.asrock.com/mb/overview.asp?Model=Fatal1ty%20970%20Performance", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000564 B("ASRock", "Fatal1ty Z77 Performance", BAD, "http://www.asrock.com/mb/overview.asp?Model=Fatal1ty%20Z77%20Performance", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000565 B("ASRock", "G31M-GS", OK, "http://www.asrock.com/mb/overview.asp?Model=G31M-GS", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000566 B("ASRock", "G31M-S rev 2.0", OK, "http://www.asrock.com/mb/overview.asp?model=G31M-S", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000567 B("ASRock", "G41M-VS3", OK, "http://www.asrock.com/mb/overview.asp?Model=G41M-VS3", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000568 B("ASRock", "H61M-ITX", BAD, "http://www.asrock.com/mb/overview.asp?Model=H61M-ITX", "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
569 B("ASRock", "H67M", BAD, "http://www.asrock.com/mb/overview.asp?Model=H67M", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Wei Hu31402ee2014-05-16 21:39:33 +0000570 B("ASRock", "IMB-180-H", OK, "http://www.asrock.com/ipc/overview.asp?Model=IMB-A180-H", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000571 B("ASRock", "K7S41", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
572 B("ASRock", "K7S41GX", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000573 B("ASRock", "K7VT4A+", BAD, "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip found, probably due to flash translation. https://flashrom.org/pipermail/flashrom/2009-August/000393.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000574 B("ASRock", "K8S8X", OK, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
575 B("ASRock", "M3A790GXH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
576 B("ASRock", "N61P-S", OK, "http://www.asrock.com/mb/overview.asp?Model=N61P-S", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000577 B("ASRock", "N68C-S UCC", OK, "http://www.asrock.com/mb/overview.asp?Model=N68C-S%20UCC", NULL),
Stefan Tauner0be072c2016-03-13 15:16:30 +0000578 B("ASRock", "P4i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65G", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000579 B("ASRock", "P4i65GV", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000580 B("ASRock", "Z68 Extreme4", BAD, "http://www.asrock.com/mb/overview.asp?Model=Z68%20Extreme4", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200581 B("ASUS", "A7N8X Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
582 B("ASUS", "A7N8X-E Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
583 B("ASUS", "A7N8X-VM/400", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000584 B("ASUS", "A7V133", OK, NULL, NULL),
585 B("ASUS", "A7V333", OK, NULL, NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200586 B("ASUS", "A7V400-MX", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
587 B("ASUS", "A7V600-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
588 B("ASUS", "A7V8X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
589 B("ASUS", "A7V8X-MX", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
590 B("ASUS", "A7V8X-MX SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
591 B("ASUS", "A7V8X-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000592 B("ASUS", "A8M2N-LA (NodusM3-GL8E)", OK, "http://h10010.www1.hp.com/ewfrf/wc/document?docname=c00757531&cc=us&dlc=en&lc=en", "This is an OEM board from HP, the HP name is NodusM3-GL8E."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200593 B("ASUS", "A8N-E", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000594 B("ASUS", "A8N-LA (Nagami-GL8E)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?lc=en&cc=us&docname=c00647121&dlc=en", "This is an OEM board from HP, the HP name is Nagami-GL8E."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200595 B("ASUS", "A8N-SLI", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
Jonathan Kollaschc8190002012-09-04 03:55:04 +0000596 B("ASUS", "A8N-SLI Deluxe", NT, NULL, "Should work out of the box since r1593."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200597 B("ASUS", "A8N-SLI Premium", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/", NULL),
598 B("ASUS", "A8N-VM", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
599 B("ASUS", "A8N-VM CSM", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000600 B("ASUS", "A8NE-FM/S", OK, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200601 B("ASUS", "A8V Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
602 B("ASUS", "A8V-E Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
603 B("ASUS", "A8V-E SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
604 B("ASUS", "C60M1-I", OK, "https://www.asus.com/Motherboards/C60M1I/", "The MAC address of the onboard network card is stored in flash."),
605 B("ASUS", "Crosshair II Formula", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/", NULL),
606 B("ASUS", "Crosshair IV Extreme", OK, "https://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000607 B("ASUS", "CUSL2-C", OK, NULL, "The image provided by ASUS is only 256 kB big and has to be written to the upper 256 kB of the 512 kB chip."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200608 B("ASUS", "DSAN-DX", NT, "https://www.asus.com/Server_Workstation/Server_Motherboards/DSANDX/", NULL),
609 B("ASUS", "E35M1-I DELUXE", OK, "https://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/", NULL),
610 B("ASUS", "F1A75-V PRO", OK, "https://www.asus.com/Motherboard/F1A75V_PRO/", NULL),
Stefan Tauner6697f712014-08-06 15:09:15 +0000611 B("ASUS", "F2A85-M", DEP, "https://www.asus.com/Motherboards/F2A85M/", "UEFI builds v6404 and above disable access to some parts of the flash, cf. http://www.coreboot.org/ASUS_F2A85-M#UEFI_builds_that_allow_flash_chip_access"),
Paul Menzel0373ce32017-10-04 13:14:13 +0200612 B("ASUS", "K8N", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
613 B("ASUS", "K8V", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
614 B("ASUS", "K8V SE Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/", NULL),
615 B("ASUS", "K8V-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
616 B("ASUS", "K8V-X SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
617 B("ASUS", "KFSN4-DRE/SAS", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/", NULL),
618 B("ASUS", "M2A-MX", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
619 B("ASUS", "M2A-VM (HDMI)", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
620 B("ASUS", "M2N32-SLI Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/", NULL),
621 B("ASUS", "M2N68-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M2N68VM/", NULL),
622 B("ASUS", "M2NBP-VM CSM", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
623 B("ASUS", "M2N-E", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NE/", "If the machine doesn't come up again after flashing, try resetting the NVRAM(CMOS). The MAC address of the onboard network card will change to the value stored in the new image, so backup the old address first. See https://flashrom.org/pipermail/flashrom/2009-November/000879.html"),
624 B("ASUS", "M2N-E SLI", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
625 B("ASUS", "M2N-MX SE Plus", OK, "https://www.asus.com/Motherboards/M2NMX_SE_Plus/", NULL),
626 B("ASUS", "M2NPV-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
627 B("ASUS", "M2N-SLI Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
628 B("ASUS", "M2V", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
629 B("ASUS", "M2V-MX", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
630 B("ASUS", "M3A", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
631 B("ASUS", "M3A76-CM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
632 B("ASUS", "M3A78-EH", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EH/", NULL),
633 B("ASUS", "M3A78-EM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
634 B("ASUS", "M3N78 PRO", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3N78_PRO/", NULL),
635 B("ASUS", "M3N78-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
636 B("ASUS", "M3N-H/HDMI", OK, "https://www.asus.com/Motherboards/M3NHHDMI//", NULL),
637 B("ASUS", "M4A785TD-M EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
638 B("ASUS", "M4A785TD-V EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
639 B("ASUS", "M4A785T-M", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TM/", NULL),
640 B("ASUS", "M4A78-EM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
641 B("ASUS", "M4A78LT-M LE", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
642 B("ASUS", "M4A79T Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
643 B("ASUS", "M4A87TD/USB3", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
644 B("ASUS", "M4A89GTD PRO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
645 B("ASUS", "M4N68T V2", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4N68T_V2/", NULL),
646 B("ASUS", "M4N78 PRO", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
647 B("ASUS", "M4N78 SE", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_SE/", NULL),
648 B("ASUS", "M5A78L-M LX", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/M5A78LM_LX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see https://flashrom.org/pipermail/flashrom/2012-May/009200.html"),
649 B("ASUS", "M5A97 (rev. 1.0)", OK, "https://www.asus.com/Motherboard/M5A97/", NULL),
650 B("ASUS", "M5A99X EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
651 B("ASUS", "Maximus IV Extreme", BAD, "https://www.asus.com/Motherboards/Intel_Socket_1155/Maximus_IV_Extreme/", "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunereb582572012-09-21 12:52:50 +0000652 B("ASUS", "MEW-AM", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000653 B("ASUS", "MEW-VM", BAD, "http://www.elhvb.com/mboards/OEM/HP/manual/ASUS%20MEW-VM.htm", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
654 B("ASUS", "OPLX-M", NT, NULL, "Untested board enable."),
Stefan Taunereb582572012-09-21 12:52:50 +0000655 B("ASUS", "P2B", OK, NULL, NULL),
656 B("ASUS", "P2B-D", OK, NULL, NULL),
657 B("ASUS", "P2B-DS", OK, NULL, NULL),
658 B("ASUS", "P2B-F", OK, NULL, NULL),
659 B("ASUS", "P2B-LS", OK, NULL, NULL),
660 B("ASUS", "P2B-N", OK, NULL, NULL),
661 B("ASUS", "P2E-M", OK, NULL, NULL),
662 B("ASUS", "P2L97-S", OK, NULL, NULL),
663 B("ASUS", "P3B-F", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
664 B("ASUS", "P4B266", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000665 B("ASUS", "P4B266-LM", OK, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000666 B("ASUS", "P4B533-E", OK, NULL, NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200667 B("ASUS", "P4C800-E Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000668 B("ASUS", "P4GV-LA (Guppy)", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478", NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200669 B("ASUS", "P4P800", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
670 B("ASUS", "P4P800-E Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/", NULL),
671 B("ASUS", "P4P800-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
672 B("ASUS", "P4P800-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800X/", NULL),
Miklós Mártonde77ad42019-08-06 22:43:19 +0200673 B("ASUS", "P4P800SE", OK, "https://www.asus.com/supportonly/P4P800 SE/", NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200674 B("ASUS", "P4PE-X/TE", NT, "https://www.asus.com/999/html/events/mb/socket478/p4pe-x-te/overview.htm", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000675 B("ASUS", "P4S533-X", OK, NULL, NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200676 B("ASUS", "P4S800-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000677 B("ASUS", "P4SC-E", OK, NULL, "Part of ASUS Terminator P4 533 barebone system"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000678 B("ASUS", "P4SD-LA", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000679 B("ASUS", "P5A", OK, NULL, NULL),
680 B("ASUS", "P5B", OK, NULL, NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200681 B("ASUS", "P5B-Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000682 B("ASUS", "P5B-VM", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000683 B("ASUS", "P5BV-M", BAD, NULL, "Reported by Bernhard M. Wiedemann <bernhard@uml12d.zq1.de> to flashrom@coreboot.org, no public archive. Missing board enable and/or SST49LF008A unlocking. May work now."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200684 B("ASUS", "P5BV-R", OK, "https://www.asus.com/Server_Workstation/Servers/RS120E5PA2/", "Used in RS120-E5/PA2 servers."),
685 B("ASUS", "P5GC-MX/1333", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/", NULL),
686 B("ASUS", "P5GD1 Pro", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000687 B("ASUS", "P5GD1-VM/S", OK, NULL, "This is an OEM board from FSC. Although flashrom supports it and can probably not distinguish it from the P5GD1-VM, please note that the P5GD1-VM BIOS does not support the FSC variants completely."),
688 B("ASUS", "P5GD1(-VM)", NT, NULL, "Untested board enable."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200689 B("ASUS", "P5GD2 Premium", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/", NULL),
690 B("ASUS", "P5GD2-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD2X/", NULL),
691 B("ASUS", "P5GDC Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/", NULL),
692 B("ASUS", "P5GDC-V Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000693 B("ASUS", "P5GD2/C variants", NT, NULL, "Untested board enable."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200694 B("ASUS", "P5K SE", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5K_SE/", NULL),
695 B("ASUS", "P5K-V", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
696 B("ASUS", "P5K-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
697 B("ASUS", "P5KC", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000698 B("ASUS", "P5KPL-AM IN/GB", OK, "http://support.asus.com/download.aspx?SLanguage=en&m=P5KPL-AM+IN%2fGB&os=29", NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +0200699 B("ASUS", "P5KPL-CM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
700 B("ASUS", "P5KPL-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KPLVM/", "Found in V3-P5G31."),
701 B("ASUS", "P5L-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
702 B("ASUS", "P5L-VM 1394", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/", NULL),
Stefan Tauner6697f712014-08-06 15:09:15 +0000703 B("ASUS", "P5LD2", OK, NULL, NULL),
Dima Veselov9d8f53d2014-07-14 18:04:15 +0000704 B("ASUS", "P5LD2-MQ", OK, "http://support.asus.com/download.aspx?SLanguage=en&p=8&s=12&m=Vintage-PH2&os=&hashedid=n/a", "Found in ASUS Vintage-PH2 barebones."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200705 B("ASUS", "P5LD2-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM/", NULL),
706 B("ASUS", "P5LD2-VM DH", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM_DH/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000707 B("ASUS", "P5LP-LE (Lithium-UL8E)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00379616&tmp_task=prodinfoCategory&cc=us&dlc=en&lc=en&product=1159887", "This is an OEM board from HP."),
708 B("ASUS", "P5LP-LE (Epson OEM)", OK, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
709 B("ASUS", "P5LP-LE", NT, NULL, "This designation is used for OEM boards from HP, Epson and maybe others. The HP names vary and not all of them have been tested yet. Please report any success or failure, thanks."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200710 B("ASUS", "P5N-D", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
711 B("ASUS", "P5N-E SLI", NT, "https://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Untested board enable."),
712 B("ASUS", "P5N32-E SLI", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/", NULL),
713 B("ASUS", "P5N7A-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
714 B("ASUS", "P5ND2-SLI Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/", NULL),
715 B("ASUS", "P5PE-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
716 B("ASUS", "P5QPL-AM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
717 B("ASUS", "P5VD1-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
718 B("ASUS", "P5VD2-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5VD2MX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see https://flashrom.org/pipermail/flashrom/2012-March/009014.html"),
719 B("ASUS", "P6T SE", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
720 B("ASUS", "P6T Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/", NULL),
721 B("ASUS", "P6T Deluxe V2", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/", NULL),
722 B("ASUS", "P7H57D-V EVO", OK, "https://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000723 B("ASUS", "P7H55-M LX", BAD, NULL, "flashrom works correctly, but GbE LAN is nonworking (probably due to a missing/bogus MAC address; see https://flashrom.org/pipermail/flashrom/2011-July/007432.html and http://ubuntuforums.org/showthread.php?t=1534389 for a possible workaround)"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000724 B("ASUS", "P8B-E/4L", BAD, NULL, "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
725 B("ASUS", "P8B WS", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000726 B("ASUS", "P8B75-M LE", BAD, NULL, "Probing works (2x 8192 kB via hwseq), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000727 B("ASUS", "P8H61 PRO", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
728 B("ASUS", "P8H61-M LE/USB3", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000729 B("ASUS", "P8H67-M PRO", BAD, NULL, "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."), // some firmware versions apparently are not locked, see report by Marek Zakrzewski
Paul Menzel0373ce32017-10-04 13:14:13 +0200730 B("ASUS", "P8H77-I", OK, "https://www.asus.com/Motherboards/P8H77I/", NULL),
731 B("ASUS", "P8H77-M", OK, "https://www.asus.com/Motherboards/P8H77M/", NULL),
732 B("ASUS", "P8H77-V LE", OK, "https://www.asus.com/Motherboards/P8H77V_LE/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000733 B("ASUS", "P8P67 (rev. 3.1)", BAD, NULL, "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000734 B("ASUS", "P8P67 LE (B2)", OK, NULL, NULL),
735 B("ASUS", "P8P67 LE (B3)", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200736 B("ASUS", "P8P67 PRO (rev. 3.0)", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8P67_PRO/", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000737 B("ASUS", "P8P67-M PRO", BAD, NULL, "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200738 B("ASUS", "P8Z68-V", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000739 B("ASUS", "P8Z68-V LE", BAD, NULL, "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000740 B("ASUS", "P8Z68-V PRO", BAD, NULL, "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200741 B("ASUS", "P8Z68-V PRO/GEN3", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V_PROGEN3/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
742 B("ASUS", "RAMPAGE III GENE", OK, "https://www.asus.com/Motherboards/RAMPAGE_III_GENE/", "The MAC address of the onboard network card is stored in flash."),
743 B("ASUS", "SABERTOOTH 990FX", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX/", NULL),
744 B("ASUS", "SABERTOOTH 990FX R2.0", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX_R20/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000745 B("ASUS", "TUSL2-C", NT, "http://support.asus.com/download.aspx?SLanguage=en&p=1&s=4&m=TUSL2-C&os=&hashedid=n/a", "Untested board enable."),
Paul Menzel0373ce32017-10-04 13:14:13 +0200746 B("ASUS", "Z8NA-D6C", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/", NULL),
747 B("ASUS", "Z8PE-D12", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000748 B("Attro", "G5G100-P", OK, "http://www.attro.com/motherboard/G5G100-P.htm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000749 B("Bachmann", "OT200", OK, "http://www.bachmann.info/produkte/bedien-und-beobachtungsgeraete/operator-terminals/", NULL),
750 B("BCOM", "WinNET100", OK, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
751 B("Bifferos", "Bifferboard", OK, "http://bifferos.co.uk/", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000752 B("Biostar", "H61MGC", BAD, NULL, "Probing works (Eon EN25Q32(A/B), 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000753 B("Biostar", "H61MU3", BAD, NULL, "Probing works (Eon EN25Q32(A/B), 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
754 B("Biostar", "M6TBA", BAD, "ftp://ftp.biostar-usa.com/manuals/M6TBA/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Stefan Taunereb582572012-09-21 12:52:50 +0000755 B("Biostar", "M7NCD Pro", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=260", NULL),
Stefan Taunerb6304c12012-08-09 23:25:27 +0000756 B("Biostar", "M7VIQ", NT, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000757 B("Biostar", "N61PB-M2S", OK, NULL, NULL),
758 B("Biostar", "N68S3+", OK, NULL, NULL),
759 B("Biostar", "P4M80-M4", OK, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000760 B("Biostar", "TA780G M2+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=344", NULL),
761 B("Biostar", "TA790GX A3+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=395", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000762 B("Boser", "HS-6637", BAD, "http://www.boser.com.tw/manual/HS-62376637v3.4.pdf", "Reported by Mark Robinson <mark@zl2tod.net> to flashrom@coreboot.org, no public archive. Missing board enable and/or F29C51002T unlocking. May work now."),
763 B("Congatec", "conga-X852", OK, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
764 B("Dell", "Inspiron 580", BAD, "http://support.dell.com/support/edocs/systems/insp580/en/index.htm", "Probing works (Macronix MX25L6405, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000765 B("Dell", "OptiPlex 7010", BAD, NULL, "Mainboard model is 0KRC95. Probing works (Hardware Sequencing 4 + 8MB), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000766 B("Dell", "OptiPlex GX1", OK, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
767 B("Dell", "PowerEdge 1850", OK, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000768 B("Dell", "PowerEdge C6220", BAD, NULL, "Mainboard model is 0HYFFG. Probing works (Macronix MX25L6405, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked (and there are even overlapping PRs)."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000769 B("Dell", "Vostro 460", BAD, "http://support.dell.com/support/edocs/systems/vos460/en/index.htm", "Mainboard model is 0Y2MRG. Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
770 B("DFI", "855GME-MGF", BAD, "http://www.dfi.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?action=e&downloadType=&windowstate=normal&mode=view&downloadFlag=false&itemId=433", "Probably needs a board enable. http://www.coreboot.org/pipermail/coreboot/2009-May/048549.html"),
Tadas Slotkus3dcdc032012-08-25 03:53:12 +0000771 B("DFI", "AD77", NT, NULL, "Untested board enable."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000772 B("DFI", "Blood-Iron P35 T2RL", OK, "http://lp.lanparty.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?itemId=516&downloadFlag=false&action=1", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000773 B("Elitegroup", "848P-A7", OK, NULL, NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000774 B("Elitegroup", "GeForce6100PM-M2 (V3.0)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000775 B("Elitegroup", "GeForce6100SM-M", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000776 B("Elitegroup", "GeForce7050M-M (V2.0)", OK, "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=865&MenuID=20&LanID=0", NULL),
Stefan Tauner74dc73f2015-03-01 22:04:38 +0000777 B("Elitegroup", "GF7050VT-M", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000778 B("Elitegroup", "GF7100PVT-M3 (V1.0)", OK, NULL, NULL),
779 B("Elitegroup", "GF8200A", OK, NULL, NULL),
780 B("Elitegroup", "K7S5A", OK, NULL, NULL),
781 B("Elitegroup", "K7S6A", OK, NULL, NULL),
782 B("Elitegroup", "K7SEM (V1.0A)", OK, NULL, NULL),
783 B("Elitegroup", "K7VTA3", OK, NULL, NULL),
784 B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000785 B("Elitegroup", "P4VXMS (V1.0A)", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000786 B("Elitegroup", "P6BAP-A+ (V2.2)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000787 B("Elitegroup", "P6IWP-Fe", OK, NULL, NULL),
788 B("Elitegroup", "P6VAP-A+", OK, NULL, NULL),
789 B("Elitegroup", "RS485M-M", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000790 B("Emerson", "ATCA-7360", OK, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000791 B("EPoX", "EP-3PTA", BAD, NULL, "Missing board enable (W83627HF/F/HG/G), see https://flashrom.org/pipermail/flashrom/2012-April/009043.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000792 B("EPoX", "EP-8K5A2", OK, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
793 B("EPoX", "EP-8NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
794 B("EPoX", "EP-8RDA3+", OK, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
795 B("EPoX", "EP-9NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
796 B("EPoX", "EP-BX3", OK, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000797 B("EVGA", "122-CK-NF68", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000798 B("EVGA", "132-CK-NF78", OK, "http://www.evga.com/articles/385.asp", NULL),
799 B("EVGA", "270-WS-W555-A2 (Classified SR-2)", OK, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
800 B("FIC", "VA-502", BAD, "ftp://ftp.fic.com.tw/motherboard/manual/socket7/va-502/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. Seems the PCI subsystem IDs are identical with the Tekram P6Pro-A5. May work now."),
Stefan Taunereb582572012-09-21 12:52:50 +0000801 B("Foxconn", "6150K8MD-8EKRSH", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000157", NULL),
802 B("Foxconn", "A6VMX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000346", NULL),
803 B("Foxconn", "P4M800P7MA-RS2", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000138", NULL),
Stefan Taunerd7d423b2012-10-20 09:13:16 +0000804 B("Foxconn", "P55MX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=motherboard&U=en-us0000474", "Needs the MFG jumper to be set correctly before flashing to enable the Flash Descriptor Override Strap."),
Stefan Taunereb582572012-09-21 12:52:50 +0000805 B("Foxconn", "Q45M", BAD, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000587", "Probing works (Hardware sequencing, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000806 B("Freetech", "P6F91i", OK, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
Stefan Tauner74dc73f2015-03-01 22:04:38 +0000807 B("Fujitsu", "D2724-A1x", OK, NULL, "Used in ESPRIMO E5625."),
808 B("Fujitsu", "D3041-A1x", OK, NULL, "Used in ESPRIMO P2560, contains an Atmel AT26DF081A."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000809 B("Fujitsu-Siemens", "CELSIUS W410", BAD, "ftp://ftp.ts.fujitsu.com/pub/mainboard-oem-sales/Products/Mainboards/Industrial&ExtendedLifetime/D3061&D3062/", "Mainboard model is D3062-A1. Probing works (Macronix MX25L6405, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000810 B("Fujitsu-Siemens", "ESPRIMO P5915", OK, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/professionalpc/ESPRIMO/P/EsprimoP5915-6.htm", "Mainboard model is D2312-A2."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000811 B("GIGABYTE", "GA-2761GXDK", OK, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
812 B("GIGABYTE", "GA-6BXC", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
813 B("GIGABYTE", "GA-6BXDU", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
814 B("GIGABYTE", "GA-6IEM", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
815 B("GIGABYTE", "GA-6VXE7+", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
816 B("GIGABYTE", "GA-6ZMA", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000817 B("GIGABYTE", "GA-770TA-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
818 B("GIGABYTE", "GA-7DXR", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
819 B("GIGABYTE", "GA-7VT600", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
820 B("GIGABYTE", "GA-7ZM", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1366", "Works fine if you remove jumper JP9 on the board and disable the flash protection BIOS option."),
821 B("GIGABYTE", "GA-880GMA-USB3 (rev. 3.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
822 B("GIGABYTE", "GA-8I945GZME-RH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
823 B("GIGABYTE", "GA-8IP775", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
824 B("GIGABYTE", "GA-8IRML", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
825 B("GIGABYTE", "GA-8PE667 Ultra 2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000826 B("GIGABYTE", "GA-8S648", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1674", NULL),
Stefan Tauner7fbbbb82014-11-30 22:31:12 +0000827 B("GIGABYTE", "GA-8SIMLFS 2.0", OK, NULL, "This is an OEM board used by Fujitsu."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000828 B("GIGABYTE", "GA-8SIMLH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000829 B("GIGABYTE", "GA-945GCM-S2 (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2466", NULL),
830 B("GIGABYTE", "GA-945GM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2331", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000831 B("GIGABYTE", "GA-945PL-S3P (rev. 6.6)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
832 B("GIGABYTE", "GA-965GM-S2 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
833 B("GIGABYTE", "GA-965P-DS4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000834 B("GIGABYTE", "GA-965P-S3 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2321", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000835 B("GIGABYTE", "GA-970A-D3P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4642", NULL),
Stefan Tauner5c316f92015-02-08 21:57:52 +0000836 B("GIGABYTE", "GA-970A-UD3P (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=5194", "Primary flash chip is a Macronix MX25L3206E."),
837 B("GIGABYTE", "GA-990FXA-UD3 (rev. 4.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4672", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000838 B("GIGABYTE", "GA-A75M-UD2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3928", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000839 B("GIGABYTE", "GA-B85M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4567", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000840 B("GIGABYTE", "GA-EG43M-S2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2878", NULL),
841 B("GIGABYTE", "GA-EP31-DS3L (rev. 1.0, 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000842 B("GIGABYTE", "GA-EP35-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000843 B("GIGABYTE", "GA-EX58-UD4P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000844 B("GIGABYTE", "GA-G33M-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2557", NULL),
845 B("GIGABYTE", "GA-G33M-S2L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2692", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000846 B("GIGABYTE", "GA-G41MT-S2PT", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3960", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000847 B("GIGABYTE", "GA-H55M-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3509", "8 MB (ME) + 1 MB (BIOS) flash chips - hardware sequencing required."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000848 B("GIGABYTE", "GA-H61M-D2-B3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3773", NULL),
849 B("GIGABYTE", "GA-H61M-D2H-USB3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4004", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000850 B("GIGABYTE", "GA-H77-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4141", "Does only work with -p internal:ich_spi_mode=hwseq due to an evil twin of MX25L6405 and ICH SPI lockdown."),
Stefan Tauner5c316f92015-02-08 21:57:52 +0000851 B("GIGABYTE", "GA-H77-DS3H (rev. 1.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4318", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000852 B("GIGABYTE", "GA-H77M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4388", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000853 B("GIGABYTE", "GA-J1900N-D3V", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4918", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000854 B("GIGABYTE", "GA-K8N51GMF-9", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000855 B("GIGABYTE", "GA-K8N51GMF", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
856 B("GIGABYTE", "GA-K8N-SLI", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000857 B("GIGABYTE", "GA-K8NS", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1784", NULL),
858 B("GIGABYTE", "GA-M56S-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2607", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000859 B("GIGABYTE", "GA-M57SLI-S4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
860 B("GIGABYTE", "GA-M61P-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
861 B("GIGABYTE", "GA-M720-US3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
862 B("GIGABYTE", "GA-MA69VM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
863 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
864 B("GIGABYTE", "GA-MA770-UD3 (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
865 B("GIGABYTE", "GA-MA770T-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
866 B("GIGABYTE", "GA-MA780G-UD3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000867 B("GIGABYTE", "GA-MA785GMT-UD2H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000868 B("GIGABYTE", "GA-MA78G-DS3H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
869 B("GIGABYTE", "GA-MA78GM-S2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2758", NULL), /* TODO: Rev. 1.BAD, 1.OK, or 2.x? */
870 B("GIGABYTE", "GA-MA78GPM-DS2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
871 B("GIGABYTE", "GA-MA790FX-DQ6", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
872 B("GIGABYTE", "GA-MA790GP-DS4H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
873 B("GIGABYTE", "GA-MA790XT-UD4P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000874 B("GIGABYTE", "GA-P31-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2615", NULL),
875 B("GIGABYTE", "GA-P31-S3G", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2676", NULL),
Stefan Tauner5c316f92015-02-08 21:57:52 +0000876 B("GIGABYTE", "GA-P55-USB3 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3440", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000877 B("GIGABYTE", "GA-P55A-UD4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000878 B("GIGABYTE", "GA-P55A-UD7" , OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3324", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000879 B("GIGABYTE", "GA-P67A-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000880 B("GIGABYTE", "GA-X58A-UD3R (rev. 2.0)", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000881 B("GIGABYTE", "GA-X58A-UD7 (rev. 2.0)", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000882 B("GIGABYTE", "GA-X79-UD5", OK, NULL, NULL),
883 B("GIGABYTE", "GA-X79-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4050", "Contains a Macronix MX25L6406E."),
884 B("GIGABYTE", "GA-X79-UP4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4288", NULL),
885 B("GIGABYTE", "GA-Z68MA-D2H-B3 (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3975", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000886 B("GIGABYTE", "GA-Z68MX-UD2H-B (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
887 B("GIGABYTE", "GA-Z68XP-UD3 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3892", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000888 B("GIGABYTE", "GA-Z77MX-D3H", BAD, "http://www.gigabyte.com/products/product-page.aspx?pid=4145", "Uses MX25L6436E and requires a small patch (but works flawlessly with that)."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000889 B("GIGABYTE", "GA-Z87-HD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4489", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000890 B("HP", "8100 Elite CMT PC (304Bh)", BAD, NULL, "SPI lock down, PR, read-only descriptor, locked ME region."),
891 B("HP", "e-Vectra P2706T", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000892 B("HP", "Evans-GL6 (Pegatron IPMEL-AE)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?cc=us&lc=en&dlc=en&docname=c01925513", "Found in HP Pavilion Slimline s5220f."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000893 B("HP", "ProLiant DL145 G3", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00816835&lang=en&cc=us&taskId=101&prodSeriesId=3219755&prodTypeId=15351", NULL),
894 B("HP", "ProLiant DL165 G6", OK, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
895 B("HP", "ProLiant N40L", OK, NULL, NULL),
896 B("HP", "Puffer2-UL8E", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
897 B("HP", "dc7800", BAD, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF06a/12454-12454-64287-321860-3328898-3459241.html?dnr=1", "ICH9DO with SPI lock down, BIOS lock, PR, read-only descriptor, locked ME region."),
898 B("HP", "Vectra VL400", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
899 B("HP", "Vectra VL420 SFF", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
900 B("HP", "xw4400 (0A68h)", BAD, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00775230", "ICH7 with SPI lock down, BIOS lock, flash block detection (SST25VF080B); see http://paste.flashrom.org/view.php?id=686"),
Stefan Tauner4c723152016-01-14 22:47:55 +0000901 B("HP", "xw6400", BAD, NULL, "No chip found, see https://flashrom.org/pipermail/flashrom/2012-March/009006.html"),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000902 B("HP", "xw9300", BAD, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodTypeId=12454&prodSeriesId=459226", "Missing board enable, see https://flashrom.org/pipermail/flashrom/2012-March/008885.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000903 B("HP", "xw9400", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=3211286&prodTypeId=12454", "Boot block is write protected unless the solder points next to F2 are shorted."),
Stefan Tauner4c723152016-01-14 22:47:55 +0000904 B("HP", "Z400 Workstation (0AE4h)", BAD, NULL, "ICH10R with BIOS lock enable and a protected range PRBAD, see https://flashrom.org/pipermail/flashrom/2012-June/009350.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000905 B("IBASE", "MB899", OK, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
906 B("IBM", "x3455", OK, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
907 B("IEI", "PICOe-9452", OK, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
908 B("Intel", "D201GLY", OK, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000909 B("Intel", "D2700MUD", BAD, "http://www.intel.com/cd/products/services/emea/eng/motherboards/desktop/D2700MUD/", "SMM protection enabled"),
Stefan Tauner4c723152016-01-14 22:47:55 +0000910 B("Intel", "D425KT", BAD, "http://www.intel.com/content/www/us/en/motherboards/desktop-motherboards/desktop-board-d425kt.html", "NM10 with SPI lock down, BIOS lock, see https://flashrom.org/pipermail/flashrom/2012-January/008600.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000911 B("Intel", "D865GLC", BAD, NULL, "ICH5 with BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000912 B("Intel", "D945GCNL", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000913 B("Intel", "DG45ID", BAD, "http://www.intel.com/products/desktop/motherboards/dg45id/dg45id-overview.htm", "Probing works (Winbond W25x32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
914 B("Intel", "DQ965GF", BAD, NULL, "Probing enables Hardware Sequencing (behind that hides a SST SST25VF016B, 2048 kB). Parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked (and the platform data region seems to be bogus)."),
915 B("Intel", "DG965OT", BAD, NULL, "Probing enables Hardware Sequencing (behind that hides a SST SST25VF080B, 1024 kB). Parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked (and the platform data region seems to be bogus)."),
Stefan Tauner4c723152016-01-14 22:47:55 +0000916 B("Intel", "DH61AG ", BAD, NULL, "H61 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2012-June/009417.html"),
917 B("Intel", "DH67CF", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2011-September/007789.html"),
918 B("Intel", "DH67CL", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2012-November/010112.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000919 B("Intel", "DN2800MT (Marshalltown)", BAD, NULL, "BIOS locked via BIOS_CNTL."),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000920 B("Intel", "DQ45CB", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000921 B("Intel", "DQ77MK", BAD, NULL, "Q77 with BIOS lock enable and locked ME region, see http://paste.flashrom.org/view.php?id=1603"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000922 B("Intel", "EP80759", OK, NULL, NULL),
923 B("Intel", "Foxhollow", OK, NULL, "Intel reference board."),
924 B("Intel", "Greencity", OK, NULL, "Intel reference board."),
925 B("Intel", "SE440BX-2", BAD, "http://downloadcenter.intel.com/SearchResult.aspx?lang=eng&ProductFamily=Desktop+Boards&ProductLine=Discontinued+Motherboards&ProductProduct=Intel%C2%AE+SE440BX-2+Motherboard", "Probably won't work, see http://www.coreboot.org/pipermail/flashrom/2010-July/003952.html"),
926 B("IWILL", "DK8-HTX", OK, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
927 B("Jetway", "J-7BXAN", OK, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
928 B("Jetway", "J7F4K1G5D-PB", OK, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
929 B("Kontron", "986LCD-M", OK, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
930 B("Lanner", "EM-8510C", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000931 B("Lenovo", "Tilapia CRB", OK, NULL, "Used in ThinkCentre M75e."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000932 B("Lex", "CV700A", OK, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
933 B("Mitac", "6513WU", OK, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
934 B("MSC", "Q7-TCTC", OK, "http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html", NULL),
935 B("MSI", "MS-6153", OK, "http://www.msi.com/product/mb/MS-6153.html", NULL),
936 B("MSI", "MS-6156", OK, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
937 B("MSI", "MS-6163 (MS-6163 Pro)",OK, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
938 B("MSI", "MS-6178", BAD, "http://www.msi.com/product/mb/MS-6178.html", "Immediately powers off if you try to hot-plug the chip. However, this does '''not''' happen if you use coreboot. Owned by Uwe Hermann <uwe@hermann-uwe.de>."),
939 B("MSI", "MS-6330 (K7T Turbo)", OK, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
940 B("MSI", "MS-6391 (845 Pro4)", OK, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
941 B("MSI", "MS-6561 (745 Ultra)", OK, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
942 B("MSI", "MS-6566 (845 Ultra-C)",OK, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
943 B("MSI", "MS-6570 (K7N2)", OK, "http://www.msi.com/product/mb/K7N2.html", NULL),
944 B("MSI", "MS-6577 (Xenon)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?product=90390&lc=en&cc=us&dlc=en&docname=bph07843", "This is an OEM board from HP, the HP name is Xenon."),
945 B("MSI", "MS-6590 (KT4 Ultra)", OK, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000946 //B("MSI", "MS-6702E (K8T Neo2-F/FIR)",OK, "http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL), This was wrongly attributed to the MS-7094 board enable.
947 B("MSI", "MS-6704 (845PE Max2 PCB 1.0)", OK, "http://www.msi.com/product/mb/845PE-Max2.html", "Write protection must be disabled in the BIOS setup."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000948 B("MSI", "MS-6712 (KT4V)", OK, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
949 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", OK, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
950 B("MSI", "MS-7005 (651M-L)", OK, "http://www.msi.com/product/mb/651M-L.html", NULL),
951 B("MSI", "MS-7025 (K8N Neo2 Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
Stefan Tauner33366a02012-09-15 15:51:09 +0000952 B("MSI", "MS-7030 (K8N Neo Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo-Platinum.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000953 B("MSI", "MS-7046", OK, "http://www.heimir.de/ms7046/", NULL),
954 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", OK, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
955 B("MSI", "MS-7065", OK, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000956 B("MSI", "MS-7094 (K8T Neo2-F V2.0)",OK, "http://www.msi.com/product/mb/K8T_Neo2F_V2.0.html", NULL),
957 B("MSI", "MS-7125 (K8N Neo4(-F/-FI/-FX/Platinum))", OK, "http://www.msi.com/product/mb/K8N_Neo4_Platinum_PCB_1.0.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000958 B("MSI", "MS-7135 (K8N Neo3)", OK, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
959 B("MSI", "MS-7142 (K8MM-V)", OK, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
960 B("MSI", "MS-7168 (Orion)", OK, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
961 B("MSI", "MS-7207 (K8NGM2-L)", OK, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
962 B("MSI", "MS-7211 (PM8M3-V)", OK, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
963 B("MSI", "MS-7236 (945PL Neo3)", OK, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
964 B("MSI", "MS-7250 (K9N SLI (rev 2.1))", OK, "http://www.msi.com/product/mb/K9N--SLI.html", NULL),
965 B("MSI", "MS-7253 (K9VGM-V)", OK, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
966 B("MSI", "MS-7255 (P4M890M)", OK, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
967 B("MSI", "MS-7260 (K9N Neo PCB 1.0)", BAD, "http://www.msi.com/product/mb/K9N-Neo--PCB-1-0-.html", "Interestingly flashrom does not work when the vendor BIOS is booted, but it ''does'' work flawlessly when the machine is booted with coreboot. Owned by Uwe Hermann <uwe@hermann-uwe.de>."),
Stefan Taunereb582572012-09-21 12:52:50 +0000968 B("MSI", "MS-7309 (K9N6SGM-V)", BAD, "http://www.msi.com/product/mb/K9N6SGM-V---K9N6PGM-FI---K9N6PGM-F.html", "Uses Fintek F71882F/F71883F/F71887 SPI-to-LPC translation."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000969 B("MSI", "MS-7309 (K9N6PGM2-V2)", OK, "http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
970 B("MSI", "MS-7312 (K9MM-V)", OK, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000971 B("MSI", "MS-7336", OK, NULL, "Some non-essential DMI data (e.g. serial numbers) is overwritten when using flashrom. This is an OEM board used by HP (e.g. dx2300 Microtower)."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000972 B("MSI", "MS-7345 (P35 Neo2-FIR)", OK, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
Elyes HAOUASac01baa2018-05-28 16:52:21 +0200973 B("MSI", "MS-7357 (G33M)", OK, "http://www.msi.com/product/mb/G33M.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000974 B("MSI", "MS-7368 (K9AG Neo2-Digital)", OK, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
975 B("MSI", "MS-7369 (K9N Neo V2)", OK, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
976 B("MSI", "MS-7376 (K9A2 Platinum V1)", OK, "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000977 B("MSI", "MS-7379 (G31M)", OK, "http://www.msi.com/product/mb/G31M.html", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000978 B("MSI", "MS-7399 1.1 (Persian)", OK, "http://acersupport.com/acerpanam/desktop/0000/Acer/AspireM5640/AspireM5640sp2.shtml", "This is an OEM board used by Acer in e.g. Aspire M5640/M3640."),
Stefan Tauner6697f712014-08-06 15:09:15 +0000979 B("MSI", "MS-7502", OK, NULL, "This is an OEM board used by Medion in e.g. Medion MD8833."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000980 B("MSI", "MS-7522 (MSI X58 Pro-E)", OK, "http://www.msi.com/product/mb/X58_ProE.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000981 B("MSI", "MS-7529 (G31M3-L(S) V2)", OK, "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000982 B("MSI", "MS-7529 (G31TM-P21)", OK, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000983 B("MSI", "MS-7548 (Aspen-GL8E)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c01635688&lc=en&cc=us&dlc=en", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000984 B("MSI", "MS-7551 (KA780G)", OK, "http://www.msi.com/product/mb/KA780G.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000985 B("MSI", "MS-7596 (785GM-E51)", OK, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000986 B("MSI", "MS-7597 (GF615M-P33)", BAD, NULL, "Missing board enable/SIO support (Fintek F71889), see https://flashrom.org/pipermail/flashrom/2012-March/008956.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000987 B("MSI", "MS-7599 (870-C45)", OK, "http://www.msi.com/product/mb/870-C45.html", NULL),
988 B("MSI", "MS-7613 (Iona-GL8E)", BAD, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c02014355&lc=en&cc=dk&dlc=en&product=4348478", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
989 B("MSI", "MS-7635 (H55M-ED55)", BAD, "http://www.msi.com/product/mb/H55M-ED55.html", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
990 B("MSI", "MS-7640 (890FXA-GD70)",OK, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
991 B("MSI", "MS-7642 (890GXM-G65)", OK, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
Stefan Tauner4c723152016-01-14 22:47:55 +0000992 B("MSI", "MS-7676 (H67MA-ED55(B3))", OK, "http://www.msi.com/product/mb/H67MA-ED55--B3-.html", "Seems to work fine basically, but user reported (hopefully unrelated) buggy behavior of the board after a firmware upgrade. See https://flashrom.org/pipermail/flashrom/2012-January/008547.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000993 B("MSI", "MS-7676 (Z68MA-G45 (B3))", OK, "http://www.msi.com/product/mb/Z68MA-G45--B3-.html", NULL),
994 B("MSI", "MS-7696 (A75MA-G55)", OK, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
995 B("MSI", "MS-7698 (E350IA-E45)", OK, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000996 B("MSI", "MS-7740 (H61MA-E35(B3))", OK, "http://www.msi.com/product/mb/H61MA-E35--B3-.html", NULL),
997 B("MSI", "MS-7756 (H77MA-G43)", OK, "http://www.msi.com/product/mb/H77MA-G43.html", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +0000998 B("MSI", "MS-7760 (X79A-GD45 (8D))", OK, "http://www.msi.com/product/mb/X79A-GD45-8D.html", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000999 B("MSI", "MS-7808 (B75MA-E33)", OK, "http://www.msi.com/product/mb/B75MA-E33.html", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001000 B("MSI", "MS-7816 (H87-G43)", OK, "http://www.msi.com/product/mb/H87-G43.html", NULL),
Stefan Tauner5c316f92015-02-08 21:57:52 +00001001 B("MSI", "MS-7817 (H81M-E33)", OK, "http://www.msi.com/product/mb/H81ME33.html", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001002 B("MSI", "MS-9830 (IM-945GSE-A, A9830IMS)", OK, "http://www.msi.com/product/ipc/IM-945GSE-A.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001003 B("NEC", "PowerMate 2000", OK, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
1004 B("Nokia", "IP530", OK, NULL, NULL),
1005 B("Palit", "N61S", OK, NULL, NULL),
1006 B("PCCHIPS ", "M598LMR (V9.0)", OK, NULL, NULL),
1007 B("PCCHIPS ", "M863G (V5.1A)", OK, "http://www.pcchips.com.tw/PCCWebSite/Products/ProductsDetail.aspx?CategoryID=1&DetailID=343&DetailName=Feature&MenuID=1&LanID=0", NULL),
1008 B("PC Engines", "Alix.1c", OK, "http://pcengines.ch/alix1c.htm", NULL),
1009 B("PC Engines", "Alix.2c2", OK, "http://pcengines.ch/alix2c2.htm", NULL),
1010 B("PC Engines", "Alix.2c3", OK, "http://pcengines.ch/alix2c3.htm", NULL),
1011 B("PC Engines", "Alix.2d3", OK, "http://pcengines.ch/alix2d3.htm", NULL),
1012 B("PC Engines", "Alix.3c3", OK, "http://pcengines.ch/alix3c3.htm", NULL),
1013 B("PC Engines", "Alix.3d3", OK, "http://pcengines.ch/alix3d3.htm", NULL),
1014 B("PC Engines", "Alix.6f2", OK, "http://pcengines.ch/alix6f2.htm", NULL),
Wei Hu31402ee2014-05-16 21:39:33 +00001015 B("PC Engines", "APU", OK, "http://pcengines.ch/apu.htm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001016 B("PC Engines", "WRAP.2E", OK, "http://pcengines.ch/wrap2e1.htm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001017 B("PCWARE", "APM80-D3", OK, "http://www.pcwarebr.com.br/produtos_mb_apm80-d3.php", "Probably manufactured by ASUS"),
1018 B("Pegatron", "IPP7A-CP", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001019 B("Portwell", "PEB-4700VLA", OK, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
1020 B("RCA", "RM4100", OK, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
1021 B("Samsung", "Polaris 32", OK, NULL, NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001022 B("SAPPHIRE", "IPC-E350M1", OK, "http://www.sapphiretech.com/presentation/product/?pid=1034&lid=1", NULL),
Stefan Tauner6697f712014-08-06 15:09:15 +00001023 B("Shuttle", "AB61", OK, "http://www.shuttle.eu/_archive/older/de/ab61.htm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001024 B("Shuttle", "AK31", OK, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
1025 B("Shuttle", "AK38N", OK, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
1026 B("Shuttle", "AV11V30", OK, NULL, NULL),
1027 B("Shuttle", "AV18E2", OK, "http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001028 B("Shuttle", "FB61", OK, "http://www.shuttle.eu/_archive/older/en/fb61.htm#mainboardfb6", "Used in SB61G2 systems."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001029 B("Shuttle", "FD37", OK, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
1030 B("Shuttle", "FH67", OK, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
1031 B("Shuttle", "FN25", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +00001032 B("Shuttle", "FN78S", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn78sh7/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001033 B("Shuttle", "X50/X50(B)", OK, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
1034 B("Soyo", "SY-5VD", BAD, "http://www.soyo.com/content/Downloads/163/&c=80&p=464&l=English", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
1035 B("Soyo", "SY-6BA+ III", OK, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
1036 B("Soyo", "SY-7VCA", OK, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
1037 B("Sun", "Blade x6250", OK, "http://www.sun.com/servers/blades/x6250/", NULL),
1038 B("Sun", "Fire x4150", BAD, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
1039 B("Sun", "Fire x4200", BAD, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
1040 B("Sun", "Fire x4540", BAD, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
1041 B("Sun", "Fire x4600", BAD, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
1042 B("Sun", "Ultra 40 M2", OK, "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001043 B("Supermicro", "A1SAi-2550F", OK, "http://www.supermicro.com/products/motherboard/Atom/X10/A1SAi-2550F.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001044 B("Supermicro", "H8QC8", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001045 B("Supermicro", "H8QME-2", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron8000/MCP55/H8QME-2.cfm", NULL),
1046 B("Supermicro", "X10SLM-F", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C220/X10SLM-F.cfm", "Probing works (Winbond W25Q128, 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked; SMM protection enabled."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001047 B("Supermicro", "X5DP8-G2", OK, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
1048 B("Supermicro", "X7DBT-INF", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001049 B("Supermicro", "X7DWT", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5400/X7DWT.cfm", "Used in Dell C6100 servers."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001050 B("Supermicro", "X7SPA-H(F)", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H", NULL),
1051 B("Supermicro", "X7SPE-HF-D525", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPE-HF-D525.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001052 B("Supermicro", "X8DT3", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001053 B("Supermicro", "X8DT6-F", OK, "http://www.supermicro.nl/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=Y", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001054 B("Supermicro", "X8DTE-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=N", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001055 B("Supermicro", "X8DTG-D", OK, "http://www.supermicro.com/products/motherboard/qpi/5500/x8dtg-df.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001056 B("Supermicro", "X8DTH-6F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
1057 B("Supermicro", "X8DTT-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
1058 B("Supermicro", "X8DTT-HIBQF", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm", NULL),
1059 B("Supermicro", "X8DTU-6TF+", BAD, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU_.cfm?TYP=SAS&LAN=10", "Probing works (Atmel AT25DF321A, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
1060 B("Supermicro", "X8DTU-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001061 B("Supermicro", "X8SAX", OK, "http://www.supermicro.com/products/motherboard/xeon3000/x58/x8sax.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001062 B("Supermicro", "X8SIE(-F)", BAD, "http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIE.cfm?IPMI=N&TYP=LN2", "Requires unlocking the ME although the registers are set up correctly by the descriptor/BIOS already (tested with swseq and hwseq)."),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001063 B("Supermicro", "X8SIL-F", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIL.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001064 B("Supermicro", "X8STi", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
1065 B("Supermicro", "X9DR3-F", BAD, "http://www.supermicro.com/products/motherboard/xeon/c600/x9dr3-f.cfm", "Probing works (Numonyx N25Q128 (supported by SFDP only atm), 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001066 B("Supermicro", "X9DRD-7LN4F", BAD, "http://www.supermicro.com/products/motherboard/xeon/c600/x9drd-7ln4f.cfm", "Probing works (Numonyx N25Q128 (supported by SFDP only atm), 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001067 B("Supermicro", "X9DRT-HF+", BAD, NULL, "Probing works (Numonyx N25Q128 (supported by SFDP only atm), 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked; SMM protection enabled."),
1068 B("Supermicro", "X9DRW", BAD, NULL, "Probing works (Numonyx N25Q128 (supported by SFDP only atm), 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunereb582572012-09-21 12:52:50 +00001069 B("Supermicro", "X9QRi-F+", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C600/X9QRi-F_.cfm", "Probing works (Macronix MX25L12805, 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked; SMM protection enabled."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001070 B("Supermicro", "X9SCA-F", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCA-F.cfm", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001071 B("Supermicro", "X9SCE-F", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCE-F.cfm", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001072 B("Supermicro", "X9SCL", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCL.cfm", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001073 B("Supermicro", "X9SCM-F", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCM-F.cfm", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001074 B("T-Online", "S-100", OK, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
1075 B("Tekram", "P6Pro-A5", OK, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
1076 B("Termtek", "TK-3370 (Rev:2.5B)", OK, NULL, NULL),
1077 B("Thomson", "IP1000", OK, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
1078 B("TriGem", "Anaheim-3", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml", NULL),
1079 B("TriGem", "Lomita", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
1080 B("Tyan", "S1846 (Tsunami ATX)", OK, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
1081 B("Tyan", "S2466 (Tiger MPX)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
1082 B("Tyan", "S2498 (Tomcat K7M)", OK, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
1083 B("Tyan", "S2723 (Tiger i7501)", OK, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
1084 B("Tyan", "S2875 (Tiger K8W)", OK, "http://www.tyan.com/archive/products/html/tigerk8w.html", NULL),
1085 B("Tyan", "S2881 (Thunder K8SR)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
1086 B("Tyan", "S2882-D (Thunder K8SD Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
1087 B("Tyan", "S2882 (Thunder K8S Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
1088 B("Tyan", "S2891 (Thunder K8SRE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
1089 B("Tyan", "S2892 (Thunder K8SE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
1090 B("Tyan", "S2895 (Thunder K8WE)", OK, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
1091 B("Tyan", "S2912 (Thunder n3600R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
1092 B("Tyan", "S2915-E (Thunder n6650W)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
1093 B("Tyan", "S2915 (Thunder n6650W)", OK, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
1094 B("Tyan", "S2933 (Thunder n3600S)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
1095 B("Tyan", "S3095 (Tomcat i945GM)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
1096 B("Tyan", "S3992 (Thunder h2000M)", OK, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001097 B("Tyan", "S4882 (Thunder K8QS Pro)", OK, "http://www.tyan.com/archive/products/html/thunderk8qspro.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001098 B("Tyan", "S5180 (Toledo i965R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
1099 B("Tyan", "S5191 (Toledo i3000R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
1100 B("Tyan", "S5197 (Toledo i3010W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
1101 B("Tyan", "S5211-1U (Toledo i3200R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
1102 B("Tyan", "S5211 (Toledo i3210W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
1103 B("Tyan", "S5220 (Toledo q35T)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
1104 B("Tyan", "S5375-1U (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
1105 B("Tyan", "S5375 (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
1106 B("Tyan", "S5376 (Tempest i5100W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
1107 B("Tyan", "S5377 (Tempest i5100T)", OK, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
1108 B("Tyan", "S5382 (Tempest i5000PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
1109 B("Tyan", "S5397 (Tempest i5400PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001110 B("Tyan", "S7066 (S7066WGM3NR)", BAD, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=790&SKU=600000330", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunereb582572012-09-21 12:52:50 +00001111 B("VIA", "EITX-3000", OK, "http://www.viaembedded.com/en/products/boards/810/1/EITX-3000.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001112 B("VIA", "EPIA M/MII/...", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=202", NULL), /* EPIA-MII link for now */
1113 B("VIA", "EPIA SP", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
1114 B("VIA", "EPIA-CN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
1115 B("VIA", "EPIA EK", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
1116 B("VIA", "EPIA-EX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
1117 B("VIA", "EPIA-LN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
1118 B("VIA", "EPIA-M700", OK, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
1119 B("VIA", "EPIA-N/NL", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=221", NULL), /* EPIA-N link for now */
1120 B("VIA", "EPIA-NX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
1121 B("VIA", "NAB74X0", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
1122 B("VIA", "pc2500e", OK, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
1123 B("VIA", "PC3500G", OK, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
1124 B("VIA", "VB700X", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
1125 B("ZOTAC", "Fusion-ITX WiFi (FUSION350-A-E)", OK, NULL, NULL),
1126 B("ZOTAC", "GeForce 8200", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +00001127 B("ZOTAC", "H61-ITX WiFi (H61ITX-A-E)", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001128 B("ZOTAC", "H67-ITX WiFi (H67ITX-C-E)", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner6697f712014-08-06 15:09:15 +00001129 B("ZOTAC", "IONITX-A-E", OK, NULL, NULL),
1130 B("ZOTAC", "IONITX-F-E", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001131 B("ZOTAC", "nForce 630i Supreme (N73U-Supreme)", OK, NULL, NULL),
1132 B("ZOTAC", "ZBOX AD02 (PLUS)", OK, NULL, NULL),
1133 B("ZOTAC", "ZBOX HD-ID11", OK, NULL, NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001134#endif
Peter Lemenkov4adf8a62010-06-01 10:13:17 +00001135
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +00001136 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001137};
1138
1139/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +00001140const struct board_info laptops_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001141#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +00001142 B("Acer", "Aspire 1520", OK, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
1143 B("Acer", "Aspire One", BAD, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
1144 B("ASUS", "A8Jm", OK, NULL, NULL),
Paul Menzel0373ce32017-10-04 13:14:13 +02001145 B("ASUS", "Eee PC 701 4G", BAD, "https://www.asus.com/Eee/Eee_PC/Eee_PC_4G/", "It seems the chip (25X40) is behind some SPI flash translation layer (likely in the EC, the ENE KB3310)."),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001146 B("ASUS", "M6Ne", NT, NULL, "Untested board enable."),
1147 B("ASUS", "U38N", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001148 B("Clevo", "P150HM", BAD, "http://www.clevo.com.tw/en/products/prodinfo_2.asp?productid=307", "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001149 B("Dell", "Latitude D630", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001150 B("Dell", "Inspiron 1420", OK, NULL, NULL),
1151 B("Dell", "Latitude CPi A366XT", BAD, "http://www.coreboot.org/Dell_Latitude_CPi_A366XT", "The laptop immediately powers off if you try to hot-swap the chip. It's not yet tested if write/erase would work on this laptop."),
Stefan Tauner4c723152016-01-14 22:47:55 +00001152 B("Dell", "Vostro 3700", BAD, NULL, "Locked ME, see https://flashrom.org/pipermail/flashrom/2012-May/009197.html."),
1153 B("Dell", "Latitude E6520", BAD, NULL, "Locked ME, see https://flashrom.org/pipermail/flashrom/2012-June/009420.html."),
Stefan Tauner6697f712014-08-06 15:09:15 +00001154 B("Elitegroup", "A928", OK, NULL, "Bootsector is locked and needs to be skipped with a layout file (writeable address range is 00000000:0003bfff)."),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001155 B("Fujitsu", "Amilo Xi 3650", OK, NULL, NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001156 B("HP/Compaq", "EliteBook 8560p", BAD, NULL, "SPI lock down, SMM protection, PR in BIOS region, read-only descriptor, locked ME region."),
Stefan Tauner4c723152016-01-14 22:47:55 +00001157 B("HP/Compaq", "nx9005", BAD, "http://h18000.www1.hp.com/products/quickspecs/11602_na/11602_na.HTML", "Shuts down when probing for a chip. https://flashrom.org/pipermail/flashrom/2010-May/003321.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001158 B("HP/Compaq", "nx9010", BAD, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?lang=en&cc=us&objectID=c00348514", "Hangs upon '''flashrom -V''' (needs hard power-cycle then)."),
Stefan Tauner6697f712014-08-06 15:09:15 +00001159 B("IBM/Lenovo", "ThinkPad T40p", BAD, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
Stefan Tauner6697f712014-08-06 15:09:15 +00001160 B("IBM/Lenovo", "ThinkPad T410s", BAD, "http://www.thinkwiki.org/wiki/Category:T410s", "Probing works (Winbond W25X64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs) and ME is locked. Also, a Protected Range is locking the top range of the BIOS region (presumably the boot block)."),
Stefan Tauner23e10b82016-01-23 16:16:49 +00001161 B("IBM/Lenovo", "ThinkPad T420", BAD, "http://www.thinkwiki.org/wiki/Category:T420", "Probing works (Macronix MX25L6405, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs) and ME is locked. Also, a Protected Range is locking the top range of the BIOS region (presumably the boot block)."),
Stefan Tauner6697f712014-08-06 15:09:15 +00001162 B("IBM/Lenovo", "ThinkPad X1", BAD, "http://www.thinkwiki.org/wiki/Category:X1", "Probing works (ST M25PX64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs) and ME is locked. Also, a Protected Range is locking the top range of the BIOS region (presumably the boot block)."),
Stefan Tauner5c316f92015-02-08 21:57:52 +00001163 B("IBM/Lenovo", "ThinkPad T530", DEP, "http://www.thinkwiki.org/wiki/Category:T530", "Works fine but only with coreboot (due to locked regions and additional PR restrictions)."),
Stefan Tauner6697f712014-08-06 15:09:15 +00001164 B("IBM/Lenovo", "ThinkPad 240", BAD, "http://www.stanford.edu/~bresnan//tp240.html", "Seems to (partially) work at first, but one block/sector cannot be written which then leaves you with a bricked laptop. Maybe this can be investigated and fixed in software later."),
1165 B("IBM/Lenovo", "3000 V100 TF05Cxx", OK, "http://www5.pc.ibm.com/europe/products.nsf/products?openagent&brand=Lenovo3000Notebook&series=Lenovo+3000+V+Series#viewallmodelstop", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001166 //B("MSI", "GT60-2OD", OK, "http://www.msi.com/product/nb/GT60_2OD.html", NULL), requires layout patches
Stefan Tauner74dc73f2015-03-01 22:04:38 +00001167 B("Teclast", "X98 Air 3G", OK, NULL, NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001168#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001169
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +00001170 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001171};
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +00001172#endif