blob: efd834d7e36325dabac1bd1e78a89b519ff670d8 [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.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
Carl-Daniel Hailfinger831e8f42010-05-30 22:24:40 +000023#include <stdio.h>
Uwe Hermannba290d12009-06-17 12:07:12 +000024#include <string.h>
25#include <stdlib.h>
26#include "flash.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000027#include "programmer.h"
Uwe Hermannba290d12009-06-17 12:07:12 +000028
Stefan Tauner4a038652013-07-17 09:28:00 +000029/* FIXME: Find a better solution for MinGW. Maybe wrap strtok_s (C11) below if it becomes available */
30#ifdef __MINGW32__
31static char* strtok_r(char *str, const char *delim, char **nextp)
32{
33 if (str == NULL)
34 str = *nextp;
35
36 str += strspn(str, delim); /* Skip leading delimiters */
37 if (*str == '\0')
38 return NULL;
39
40 char *ret = str;
41 str += strcspn(str, delim); /* Find end of token */
42 if (*str != '\0')
43 *str++ = '\0';
44
45 *nextp = str;
46 return ret;
47}
48#endif
49
Stefan Tauner1181ee22014-06-01 02:13:23 +000050static const char *test_state_to_text(enum test_state test_state)
51{
52 switch (test_state) {
53 case OK: return "OK";
54 case BAD: return "Not working";
55 case NA: return "N/A";
56 case DEP: return "Config-dependent";
57 case NT:
58 default: return "Untested";
59 }
60}
61
Uwe Hermannba290d12009-06-17 12:07:12 +000062/*
63 * Return a string corresponding to the bustype parameter.
Stefan Tauner00155492011-06-26 20:45:35 +000064 * Memory is obtained with malloc() and must be freed with free() by the caller.
Uwe Hermannba290d12009-06-17 12:07:12 +000065 */
66char *flashbuses_to_text(enum chipbustype bustype)
67{
68 char *ret = calloc(1, 1);
Uwe Hermannba290d12009-06-17 12:07:12 +000069 /*
70 * FIXME: Once all chipsets and flash chips have been updated, NONSPI
71 * will cease to exist and should be eliminated here as well.
72 */
Carl-Daniel Hailfinger532c7172011-11-04 21:35:26 +000073 if (bustype == BUS_NONSPI) {
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +000074 ret = strcat_realloc(ret, "Non-SPI, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000075 } else {
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000076 if (bustype & BUS_PARALLEL)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000077 ret = strcat_realloc(ret, "Parallel, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000078 if (bustype & BUS_LPC)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000079 ret = strcat_realloc(ret, "LPC, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000080 if (bustype & BUS_FWH)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000081 ret = strcat_realloc(ret, "FWH, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000082 if (bustype & BUS_SPI)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000083 ret = strcat_realloc(ret, "SPI, ");
Carl-Daniel Hailfinger532c7172011-11-04 21:35:26 +000084 if (bustype & BUS_PROG)
85 ret = strcat_realloc(ret, "Programmer-specific, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000086 if (bustype == BUS_NONE)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000087 ret = strcat_realloc(ret, "None, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000088 }
89 /* Kill last comma. */
Stefan Tauner355cbfd2011-05-28 02:37:14 +000090 ret[strlen(ret) - 2] = '\0';
Uwe Hermannba290d12009-06-17 12:07:12 +000091 ret = realloc(ret, strlen(ret) + 1);
92 return ret;
93}
94
Niklas Söderlundede2fa42012-10-23 13:06:46 +000095static int print_supported_chips(void)
Uwe Hermannba290d12009-06-17 12:07:12 +000096{
Stefan Tauner29e5d312011-09-12 22:55:01 +000097 const char *delim = "/";
98 const int mintoklen = 5;
99 const int border = 2;
100 int i, chipcount = 0;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000101 int maxvendorlen = strlen("Vendor") + 1;
102 int maxchiplen = strlen("Device") + 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000103 int maxtypelen = strlen("Type") + 1;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000104 const struct flashchip *chip;
Stefan Tauner00155492011-06-26 20:45:35 +0000105 char *s;
Stefan Tauner4a038652013-07-17 09:28:00 +0000106 char *ven, *dev;
107 char *tmpven, *tmpdev, *tmpven_save, *tmpdev_save;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000108 int tmpvenlen, tmpdevlen, curvenlen, curdevlen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000109
Stefan Tauner29e5d312011-09-12 22:55:01 +0000110 /* calculate maximum column widths and by iterating over all chips */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000111 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +0000112 /* Ignore generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000113 if (!strncmp(chip->vendor, "Unknown", 7) ||
114 !strncmp(chip->vendor, "Programmer", 10) ||
115 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +0000116 continue;
Uwe Hermannba290d12009-06-17 12:07:12 +0000117 chipcount++;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000118
119 /* Find maximum vendor length (respecting line splitting). */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000120 tmpven = (char *)chip->vendor;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000121 do {
122 /* and take minimum token lengths into account */
123 tmpvenlen = 0;
124 do {
125 tmpvenlen += strcspn(tmpven, delim);
126 /* skip to the address after the first token */
127 tmpven += tmpvenlen;
128 if (tmpven[0] == '\0')
129 break;
130 tmpven++;
131 } while (tmpvenlen < mintoklen);
132 maxvendorlen = max(maxvendorlen, tmpvenlen);
133 if (tmpven[0] == '\0')
134 break;
135 } while (1);
136
137 /* same for device name */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000138 tmpdev = (char *)chip->name;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000139 do {
140 tmpdevlen = 0;
141 do {
142 tmpdevlen += strcspn(tmpdev, delim);
143 tmpdev += tmpdevlen;
144 if (tmpdev[0] == '\0')
145 break;
146 tmpdev++;
147 } while (tmpdevlen < mintoklen);
148 maxchiplen = max(maxchiplen, tmpdevlen);
149 if (tmpdev[0] == '\0')
150 break;
151 } while (1);
152
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000153 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000154 maxtypelen = max(maxtypelen, strlen(s));
155 free(s);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000156 }
Stefan Tauner29e5d312011-09-12 22:55:01 +0000157 maxvendorlen += border;
158 maxchiplen += border;
159 maxtypelen += border;
Uwe Hermannba290d12009-06-17 12:07:12 +0000160
Stefan Tauner12589362011-06-25 17:36:25 +0000161 msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
162 msg_ginfo("Vendor");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000163 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000164 msg_ginfo(" ");
165 msg_ginfo("Device");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000166 for (i = strlen("Device"); i < maxchiplen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000167 msg_ginfo(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000168
Stefan Tauner29e5d312011-09-12 22:55:01 +0000169 msg_ginfo("Test");
170 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000171 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000172 msg_ginfo("Known");
173 for (i = 0; i < border; i++)
174 msg_ginfo(" ");
Stefan Tauner0554ca52013-07-25 22:54:25 +0000175 msg_ginfo(" Size ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000176 for (i = 0; i < border; i++)
177 msg_ginfo(" ");
178
179 msg_ginfo("Type");
180 for (i = strlen("Type"); i < maxtypelen; i++)
181 msg_ginfo(" ");
182 msg_gdbg("Voltage");
183 msg_ginfo("\n");
184
185 for (i = 0; i < maxvendorlen + maxchiplen; i++)
186 msg_ginfo(" ");
187 msg_ginfo("OK ");
188 for (i = 0; i < border; i++)
189 msg_ginfo(" ");
190 msg_ginfo("Broken");
191 for (i = 0; i < border; i++)
192 msg_ginfo(" ");
Stefan Tauner0554ca52013-07-25 22:54:25 +0000193 msg_ginfo("[kB] ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000194 for (i = 0; i < border + maxtypelen; i++)
195 msg_ginfo(" ");
196 msg_gdbg("range [V]");
197 msg_ginfo("\n\n");
Stefan Tauner12589362011-06-25 17:36:25 +0000198 msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE)\n\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000199
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000200 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +0000201 /* Don't print generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000202 if (!strncmp(chip->vendor, "Unknown", 7) ||
203 !strncmp(chip->vendor, "Programmer", 10) ||
204 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +0000205 continue;
206
Stefan Tauner29e5d312011-09-12 22:55:01 +0000207 /* support for multiline vendor names:
208 * - make a copy of the original vendor name
209 * - use strok to put the first token in tmpven
210 * - keep track of the length of all tokens on the current line
211 * for ' '-padding in curvenlen
212 * - check if additional tokens should be printed on the current
213 * line
214 * - after all other values are printed print the surplus tokens
215 * on fresh lines
216 */
Stefan Tauner4a038652013-07-17 09:28:00 +0000217 ven = malloc(strlen(chip->vendor) + 1);
218 if (ven == NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000219 msg_gerr("Out of memory!\n");
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000220 return 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000221 }
Stefan Tauner4a038652013-07-17 09:28:00 +0000222 strcpy(ven, chip->vendor);
Uwe Hermannba290d12009-06-17 12:07:12 +0000223
Stefan Tauner4a038652013-07-17 09:28:00 +0000224 tmpven = strtok_r(ven, delim, &tmpven_save);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000225 msg_ginfo("%s", tmpven);
226 curvenlen = strlen(tmpven);
Stefan Tauner4a038652013-07-17 09:28:00 +0000227 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000228 msg_ginfo("%s", delim);
229 curvenlen++;
230 tmpvenlen = strlen(tmpven);
231 if (tmpvenlen >= mintoklen)
232 break; /* big enough to be on its own line */
233 msg_ginfo("%s", tmpven);
234 curvenlen += tmpvenlen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000235 }
236
Stefan Tauner29e5d312011-09-12 22:55:01 +0000237 for (i = curvenlen; i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000238 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000239
240 /* support for multiline device names as above */
Stefan Tauner4a038652013-07-17 09:28:00 +0000241 dev = malloc(strlen(chip->name) + 1);
242 if (dev == NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000243 msg_gerr("Out of memory!\n");
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000244 return 1;
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000245 }
Stefan Tauner4a038652013-07-17 09:28:00 +0000246 strcpy(dev, chip->name);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000247
Stefan Tauner4a038652013-07-17 09:28:00 +0000248 tmpdev = strtok_r(dev, delim, &tmpdev_save);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000249 msg_ginfo("%s", tmpdev);
250 curdevlen = strlen(tmpdev);
Stefan Tauner4a038652013-07-17 09:28:00 +0000251 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000252 msg_ginfo("%s", delim);
253 curdevlen++;
254 tmpdevlen = strlen(tmpdev);
255 if (tmpdevlen >= mintoklen)
256 break; /* big enough to be on its own line */
257 msg_ginfo("%s", tmpdev);
258 curdevlen += tmpdevlen;
259 }
260
261 for (i = curdevlen; i < maxchiplen; i++)
262 msg_ginfo(" ");
263
Stefan Tauner6455dff2014-05-26 00:36:24 +0000264 if (chip->tested.probe == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000265 msg_ginfo("P");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000266 else if (chip->tested.probe == NA)
267 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000268 else
269 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000270 if (chip->tested.read == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000271 msg_ginfo("R");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000272 else if (chip->tested.read == NA)
273 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000274 else
275 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000276 if (chip->tested.erase == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000277 msg_ginfo("E");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000278 else if (chip->tested.erase == NA)
279 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000280 else
281 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000282 if (chip->tested.write == OK)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000283 msg_ginfo("W");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000284 else if (chip->tested.write == NA)
285 msg_ginfo("-");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000286 else
287 msg_ginfo(" ");
288 for (i = 0; i < border; i++)
289 msg_ginfo(" ");
290
Stefan Tauner6455dff2014-05-26 00:36:24 +0000291 if (chip->tested.probe == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000292 msg_ginfo("P");
293 else
294 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000295 if (chip->tested.read == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000296 msg_ginfo("R");
297 else
298 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000299 if (chip->tested.erase == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000300 msg_ginfo("E");
301 else
302 msg_ginfo(" ");
Stefan Tauner6455dff2014-05-26 00:36:24 +0000303 if (chip->tested.write == BAD)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000304 msg_ginfo("W");
305 else
306 msg_ginfo(" ");
307 for (i = 0; i < border + 1; i++)
308 msg_ginfo(" ");
309
Stefan Tauner0554ca52013-07-25 22:54:25 +0000310 msg_ginfo("%6d", chip->total_size);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000311 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000312 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000313
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000314 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000315 msg_ginfo("%s", s);
316 for (i = strlen(s); i < maxtypelen; i++)
317 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000318 free(s);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000319
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000320 if (chip->voltage.min == 0 && chip->voltage.max == 0)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000321 msg_gdbg("no info");
322 else
323 msg_gdbg("%0.02f;%0.02f",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000324 chip->voltage.min/(double)1000,
325 chip->voltage.max/(double)1000);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000326
327 /* print surplus vendor and device name tokens */
328 while (tmpven != NULL || tmpdev != NULL) {
329 msg_ginfo("\n");
330 if (tmpven != NULL){
331 msg_ginfo("%s", tmpven);
332 curvenlen = strlen(tmpven);
Stefan Tauner4a038652013-07-17 09:28:00 +0000333 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000334 msg_ginfo("%s", delim);
335 curvenlen++;
336 tmpvenlen = strlen(tmpven);
337 /* big enough to be on its own line */
338 if (tmpvenlen >= mintoklen)
339 break;
340 msg_ginfo("%s", tmpven);
341 curvenlen += tmpvenlen;
342 }
343 } else
344 curvenlen = 0;
345
346 for (i = curvenlen; i < maxvendorlen; i++)
347 msg_ginfo(" ");
348
349 if (tmpdev != NULL){
350 msg_ginfo("%s", tmpdev);
351 curdevlen = strlen(tmpdev);
Stefan Tauner4a038652013-07-17 09:28:00 +0000352 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
Stefan Tauner29e5d312011-09-12 22:55:01 +0000353 msg_ginfo("%s", delim);
354 curdevlen++;
355 tmpdevlen = strlen(tmpdev);
356 /* big enough to be on its own line */
357 if (tmpdevlen >= mintoklen)
358 break;
359 msg_ginfo("%s", tmpdev);
360 curdevlen += tmpdevlen;
361 }
362 }
363 }
364 msg_ginfo("\n");
Stefan Tauner4a038652013-07-17 09:28:00 +0000365 free(ven);
366 free(dev);
Uwe Hermannba290d12009-06-17 12:07:12 +0000367 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000368
369 return 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000370}
371
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000372#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000373static void print_supported_chipsets(void)
Uwe Hermannba290d12009-06-17 12:07:12 +0000374{
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000375 int i, chipsetcount = 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000376 const struct penable *c = chipset_enables;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000377 int maxvendorlen = strlen("Vendor") + 1;
378 int maxchipsetlen = strlen("Chipset") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000379
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000380 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Uwe Hermannba290d12009-06-17 12:07:12 +0000381 chipsetcount++;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000382 maxvendorlen = max(maxvendorlen, strlen(c->vendor_name));
383 maxchipsetlen = max(maxchipsetlen, strlen(c->device_name));
384 }
385 maxvendorlen++;
386 maxchipsetlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000387
Stefan Tauner12589362011-06-25 17:36:25 +0000388 msg_ginfo("Supported chipsets (total: %d):\n\n", chipsetcount);
Uwe Hermannba290d12009-06-17 12:07:12 +0000389
Stefan Tauner12589362011-06-25 17:36:25 +0000390 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000391 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000392 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000393
Stefan Tauner12589362011-06-25 17:36:25 +0000394 msg_ginfo("Chipset");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000395 for (i = strlen("Chipset"); i < maxchipsetlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000396 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000397
Stefan Tauner428ba2b2014-06-02 00:34:58 +0000398 msg_ginfo("PCI IDs Status\n\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000399
400 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000401 msg_ginfo("%s", c->vendor_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000402 for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000403 msg_ginfo(" ");
404 msg_ginfo("%s", c->device_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000405 for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000406 msg_ginfo(" ");
Stefan Tauner428ba2b2014-06-02 00:34:58 +0000407 msg_ginfo("%04x:%04x %s\n", c->vendor_id, c->device_id,
408 test_state_to_text(c->status));
Uwe Hermannba290d12009-06-17 12:07:12 +0000409 }
410}
411
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000412static void print_supported_boards_helper(const struct board_info *boards,
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000413 const char *devicetype)
Uwe Hermannba290d12009-06-17 12:07:12 +0000414{
Stefan Tauner2c20b282012-07-28 19:35:26 +0000415 int i;
416 unsigned int boardcount_good = 0, boardcount_bad = 0, boardcount_nt = 0;
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000417 const struct board_match *e = board_matches;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000418 const struct board_info *b = boards;
419 int maxvendorlen = strlen("Vendor") + 1;
420 int maxboardlen = strlen("Board") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000421
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000422 for (b = boards; b->vendor != NULL; b++) {
423 maxvendorlen = max(maxvendorlen, strlen(b->vendor));
424 maxboardlen = max(maxboardlen, strlen(b->name));
Stefan Tauner2c20b282012-07-28 19:35:26 +0000425 if (b->working == OK)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000426 boardcount_good++;
Stefan Tauner2c20b282012-07-28 19:35:26 +0000427 else if (b->working == NT)
428 boardcount_nt++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000429 else
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000430 boardcount_bad++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000431 }
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000432 maxvendorlen++;
433 maxboardlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000434
Stefan Tauner2c20b282012-07-28 19:35:26 +0000435 msg_ginfo("%d known %s (good: %d, untested: %d, bad: %d):\n\n",
436 boardcount_good + boardcount_nt + boardcount_bad,
437 devicetype, boardcount_good, boardcount_nt, boardcount_bad);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000438
Stefan Tauner12589362011-06-25 17:36:25 +0000439 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000440 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000441 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000442
Stefan Tauner12589362011-06-25 17:36:25 +0000443 msg_ginfo("Board");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000444 for (i = strlen("Board"); i < maxboardlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000445 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000446
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000447 msg_ginfo("Status Required value for\n");
448 for (i = 0; i < maxvendorlen + maxboardlen + strlen("Status "); i++)
449 msg_ginfo(" ");
450 msg_ginfo("-p internal:mainboard=\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000451
452 for (b = boards; b->vendor != NULL; b++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000453 msg_ginfo("%s", b->vendor);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000454 for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000455 msg_ginfo(" ");
456 msg_ginfo("%s", b->name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000457 for (i = 0; i < maxboardlen - strlen(b->name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000458 msg_ginfo(" ");
Stefan Reinauerf94d9ce2014-04-26 16:11:07 +0000459
460 if (b->working == OK)
461 msg_ginfo("OK ");
462 else if (b->working == NT)
463 msg_ginfo("NT ");
464 else
465 msg_ginfo("BAD ");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000466
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000467 for (e = board_matches; e->vendor_name != NULL; e++) {
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000468 if (strcmp(e->vendor_name, b->vendor)
469 || strcmp(e->board_name, b->name))
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000470 continue;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000471 if (e->lb_vendor == NULL)
Stefan Tauner12589362011-06-25 17:36:25 +0000472 msg_ginfo("(autodetected)");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000473 else
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000474 msg_ginfo("%s:%s", e->lb_vendor,
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000475 e->lb_part);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000476 }
Stefan Tauner12589362011-06-25 17:36:25 +0000477 msg_ginfo("\n");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000478 }
Uwe Hermannba290d12009-06-17 12:07:12 +0000479}
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000480#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000481
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000482void print_supported_devs(const struct programmer_entry prog, const char *const type)
Stefan Tauneraf358d62012-12-27 18:40:26 +0000483{
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000484 const struct dev_entry *const devs = prog.devs.dev;
485 msg_ginfo("\nSupported %s devices for the %s programmer:\n", type, prog.name);
Stefan Tauner1181ee22014-06-01 02:13:23 +0000486 unsigned int maxvendorlen = strlen("Vendor") + 1;
487 unsigned int maxdevlen = strlen("Device") + 1;
488
489 unsigned int i;
Stefan Tauneraf358d62012-12-27 18:40:26 +0000490 for (i = 0; devs[i].vendor_name != NULL; i++) {
Stefan Tauner1181ee22014-06-01 02:13:23 +0000491 maxvendorlen = max(maxvendorlen, strlen(devs[i].vendor_name));
492 maxdevlen = max(maxdevlen, strlen(devs[i].device_name));
493 }
494 maxvendorlen++;
495 maxdevlen++;
496
497 msg_ginfo("Vendor");
498 for (i = strlen("Vendor"); i < maxvendorlen; i++)
499 msg_ginfo(" ");
500
501 msg_ginfo("Device");
502 for (i = strlen("Device"); i < maxdevlen; i++)
503 msg_ginfo(" ");
504
505 msg_ginfo(" %s IDs Status\n", type);
506
507 for (i = 0; devs[i].vendor_name != NULL; i++) {
508 msg_ginfo("%s", devs[i].vendor_name);
509 unsigned int j;
510 for (j = strlen(devs[i].vendor_name); j < maxvendorlen; j++)
511 msg_ginfo(" ");
512 msg_ginfo("%s", devs[i].device_name);
513 for (j = strlen(devs[i].device_name); j < maxdevlen; j++)
514 msg_ginfo(" ");
515
516 msg_pinfo(" %04x:%04x %s\n", devs[i].vendor_id, devs[i].device_id,
517 test_state_to_text(devs[i].status));
Stefan Tauneraf358d62012-12-27 18:40:26 +0000518 }
519}
520
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000521int print_supported(void)
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000522{
Stefan Tauneraf358d62012-12-27 18:40:26 +0000523 unsigned int i;
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000524 if (print_supported_chips())
525 return 1;
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000526
Stefan Tauner12589362011-06-25 17:36:25 +0000527 msg_ginfo("\nSupported programmers:\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000528 list_programmers_linebreak(0, 80, 0);
Stefan Taunerb226cb12012-11-24 18:59:39 +0000529 msg_ginfo("\n");
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000530#if CONFIG_INTERNAL == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000531 msg_ginfo("\nSupported devices for the %s programmer:\n\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000532 programmer_table[PROGRAMMER_INTERNAL].name);
533 print_supported_chipsets();
Stefan Tauner12589362011-06-25 17:36:25 +0000534 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000535 print_supported_boards_helper(boards_known, "boards");
Stefan Tauner12589362011-06-25 17:36:25 +0000536 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000537 print_supported_boards_helper(laptops_known, "laptops");
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000538#endif
Stefan Tauneraf358d62012-12-27 18:40:26 +0000539 for (i = 0; i < PROGRAMMER_INVALID; i++) {
540 const struct programmer_entry prog = programmer_table[i];
541 switch (prog.type) {
542 case USB:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000543 print_supported_devs(prog, "USB");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000544 break;
545#if NEED_PCI == 1
546 case PCI:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000547 print_supported_devs(prog, "PCI");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000548 break;
Adam Jurkowski516f9322009-12-14 03:07:31 +0000549#endif
Stefan Tauneraf358d62012-12-27 18:40:26 +0000550 case OTHER:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000551 if (prog.devs.note != NULL) {
552 msg_ginfo("\nSupported devices for the %s programmer:\n", prog.name);
553 msg_ginfo("%s", prog.devs.note);
554 }
Stefan Tauneraf358d62012-12-27 18:40:26 +0000555 break;
556 default:
557 msg_gerr("\n%s: %s: Uninitialized programmer type! Please report a bug at "
558 "flashrom@flashrom.org\n", __func__, prog.name);
559 break;
560 }
561 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000562 return 0;
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000563}
564
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000565#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger4146ced2010-06-07 11:10:43 +0000566
567#ifdef CONFIG_PRINT_WIKI
568#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
569#else
570#define B(vendor, name, status, url, note) { vendor, name, status }
571#endif
572
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000573/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000574const struct board_info boards_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000575#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +0000576 B("A-Trend", "ATC-6220", OK, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
577 B("abit", "A-S78H", OK, NULL, NULL),
578 B("abit", "AN-M2", OK, NULL, NULL),
579 B("abit", "AV8", OK, NULL, NULL),
580 B("abit", "AX8", OK, NULL, NULL),
Stefan Tauner2c5b65e2013-10-26 17:02:03 +0000581 B("abit", "BF6", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000582 B("abit", "BM6", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000583 B("abit", "BX6 2.0", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000584 B("abit", "Fatal1ty F-I90HD", OK, NULL, NULL),
585 B("abit", "IC7", OK, NULL, NULL),
586 B("abit", "IP35", OK, NULL, NULL),
587 B("abit", "IP35 Pro", OK, NULL, NULL),
588 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."),
589 B("abit", "KN8 Ultra", OK, NULL, NULL),
590 B("abit", "NF-M2 nView", OK, NULL, NULL),
591 B("abit", "NF-M2S", OK, NULL, NULL),
592 B("abit", "NF7-S", OK, NULL, NULL),
593 B("abit", "VA6", OK, NULL, NULL),
594 B("abit", "VT6X4", OK, NULL, NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000595 B("Acer", "V75-M", OK, NULL, "This is an OEM board used by IBM in e.g. Aptiva 2170-G"),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000596 B("Acer", "EM61SM/EM61PM", OK, NULL, "Used in Acer Aspire T180."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000597 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 +0000598 B("Acorp", "6M810C", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000599 B("ADLINK", "Express-HR", OK, "http://www.adlinktech.com/PD/web/PD_detail.php?pid=1012", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000600 B("Advantech", "PCM-5820", OK, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
601 B("agami", "Aruma", OK, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
602 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 +0000603 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 +0000604 B("AOpen", "i945GMx-VFX", OK, NULL, "This is (also?) an OEM board from FSC (used in e.g. ESPRIMO Q5010 with designation D2544-B1)."),
605 B("AOpen", "vKM400Am-S", OK, "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
606 B("Artec Group","DBE61", OK, "http://wiki.thincan.org/DBE61", NULL),
607 B("Artec Group","DBE62", OK, "http://wiki.thincan.org/DBE62", NULL),
608 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 +0000609 B("ASRock", "4CoreDual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=4CoreDual-VSTA", "W39V040FB"),
610 B("ASRock", "775Dual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=775Dual-VSTA", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000611 B("ASRock", "775i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
612 B("ASRock", "880G Pro3", OK, "http://www.asrock.com/mb/overview.asp?Model=880G%20Pro3", NULL),
613 B("ASRock", "890GX Extreme3", OK, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
614 B("ASRock", "939A785GMH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000615 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 +0000616 B("ASRock", "A330GC", OK, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
617 B("ASRock", "A770CrossFire", OK, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
618 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 http://www.flashrom.org/pipermail/flashrom/2012-July/009600.html for details."),
619 B("ASRock", "ALiveNF6G-DVI", OK, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
620 B("ASRock", "AM2NF6G-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
621 B("ASRock", "ConRoeXFire-eSATA2", OK, "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000622 B("ASRock", "E350M1/USB3", OK, "http://www.asrock.com/mb/overview.asp?model=e350m1/usb3", NULL),
623 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."),
624 B("ASRock", "G31M-S rev 2.0", OK, "http://www.asrock.com/mb/overview.asp?model=G31M-S", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000625 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."),
626 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 +0000627 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 +0000628 B("ASRock", "K7S41", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
629 B("ASRock", "K7S41GX", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
630 B("ASRock", "K7VT4A+", BAD, "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip found, probably due to flash translation. http://www.flashrom.org/pipermail/flashrom/2009-August/000393.html"),
631 B("ASRock", "K8S8X", OK, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
632 B("ASRock", "M3A790GXH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
633 B("ASRock", "N61P-S", OK, "http://www.asrock.com/mb/overview.asp?Model=N61P-S", NULL),
634 B("ASRock", "P4i65GV", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000635 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000636 B("ASUS", "A7N8X Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
637 B("ASUS", "A7N8X-E Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
638 B("ASUS", "A7N8X-VM/400", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000639 B("ASUS", "A7V133", OK, NULL, NULL),
640 B("ASUS", "A7V333", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000641 B("ASUS", "A7V400-MX", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
642 B("ASUS", "A7V600-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
643 B("ASUS", "A7V8X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
644 B("ASUS", "A7V8X-MX", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
645 B("ASUS", "A7V8X-MX SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
646 B("ASUS", "A7V8X-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
647 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."),
648 B("ASUS", "A8N-E", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
649 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."),
650 B("ASUS", "A8N-SLI", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
Jonathan Kollaschc8190002012-09-04 03:55:04 +0000651 B("ASUS", "A8N-SLI Deluxe", NT, NULL, "Should work out of the box since r1593."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000652 B("ASUS", "A8N-SLI Premium", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/", NULL),
653 B("ASUS", "A8N-VM", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
654 B("ASUS", "A8N-VM CSM", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
655 B("ASUS", "A8NE-FM/S", OK, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
656 B("ASUS", "A8V Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
657 B("ASUS", "A8V-E Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
658 B("ASUS", "A8V-E SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000659 B("ASUS", "C60M1-I", OK, "http://www.asus.com/Motherboards/C60M1I/", "The MAC address of the onboard network card is stored in flash."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000660 B("ASUS", "Crosshair II Formula", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/", NULL),
661 B("ASUS", "Crosshair IV Extreme", OK, "http://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/", NULL),
Stefan Tauner98546c92012-11-05 12:20:29 +0000662 B("ASUS", "DSAN-DX", NT, "http://www.asus.com/Server_Workstation/Server_Motherboards/DSANDX/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000663 B("ASUS", "E35M1-I DELUXE", OK, "http://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000664 B("ASUS", "F1A75-V PRO", OK, "http://www.asus.com/Motherboard/F1A75V_PRO/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000665 B("ASUS", "K8N", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
666 B("ASUS", "K8V", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
667 B("ASUS", "K8V SE Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/", NULL),
668 B("ASUS", "K8V-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
669 B("ASUS", "K8V-X SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
670 B("ASUS", "KFSN4-DRE/SAS", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/", NULL),
671 B("ASUS", "M2A-MX", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
672 B("ASUS", "M2A-VM (HDMI)", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
673 B("ASUS", "M2N32-SLI Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/", NULL),
674 B("ASUS", "M2N68-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M2N68VM/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000675 B("ASUS", "M2NBP-VM CSM", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000676 B("ASUS", "M2N-E", OK, "http://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 http://www.flashrom.org/pipermail/flashrom/2009-November/000879.html"),
677 B("ASUS", "M2N-E SLI", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000678 B("ASUS", "M2NPV-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000679 B("ASUS", "M2N-SLI Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000680 B("ASUS", "M2V", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
681 B("ASUS", "M2V-MX", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
682 B("ASUS", "M3A", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
683 B("ASUS", "M3A76-CM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000684 B("ASUS", "M3A78-EH", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EH/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000685 B("ASUS", "M3A78-EM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
686 B("ASUS", "M3N78 PRO", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78_PRO/", NULL),
687 B("ASUS", "M3N78-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000688 B("ASUS", "M3N-H/HDMI", OK, "http://www.asus.com/Motherboards/M3NHHDMI//", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000689 B("ASUS", "M4A785TD-M EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
690 B("ASUS", "M4A785TD-V EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000691 B("ASUS", "M4A785T-M", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TM/", NULL),
692 B("ASUS", "M4A78-EM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000693 B("ASUS", "M4A78LT-M LE", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
694 B("ASUS", "M4A79T Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
695 B("ASUS", "M4A87TD/USB3", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
696 B("ASUS", "M4A89GTD PRO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
697 B("ASUS", "M4N68T V2", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4N68T_V2/", NULL),
698 B("ASUS", "M4N78 PRO", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
699 B("ASUS", "M5A78L-M LX", OK, "http://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 http://www.flashrom.org/pipermail/flashrom/2012-May/009200.html"),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000700 B("ASUS", "M5A97 (rev. 1.0)", OK, "http://www.asus.com/Motherboard/M5A97/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000701 B("ASUS", "M5A99X EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
702 B("ASUS", "Maximus IV Extreme", BAD, "http://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 +0000703 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 +0000704 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."),
705 B("ASUS", "OPLX-M", NT, NULL, "Untested board enable."),
Stefan Taunereb582572012-09-21 12:52:50 +0000706 B("ASUS", "P2B", OK, NULL, NULL),
707 B("ASUS", "P2B-D", OK, NULL, NULL),
708 B("ASUS", "P2B-DS", OK, NULL, NULL),
709 B("ASUS", "P2B-F", OK, NULL, NULL),
710 B("ASUS", "P2B-LS", OK, NULL, NULL),
711 B("ASUS", "P2B-N", OK, NULL, NULL),
712 B("ASUS", "P2E-M", OK, NULL, NULL),
713 B("ASUS", "P2L97-S", OK, NULL, NULL),
714 B("ASUS", "P3B-F", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
715 B("ASUS", "P4B266", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000716 B("ASUS", "P4B266-LM", OK, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000717 B("ASUS", "P4B533-E", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000718 B("ASUS", "P4C800-E Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/", NULL),
719 B("ASUS", "P4GV-LA (Guppy)", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478", NULL),
720 B("ASUS", "P4P800", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
721 B("ASUS", "P4P800-E Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/", NULL),
722 B("ASUS", "P4P800-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000723 B("ASUS", "P4P800-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800X/", NULL),
Stefan Taunerd3b98fb2013-03-04 01:41:56 +0000724 B("ASUS", "P4PE-X/TE", NT, "http://www.asus.com/999/html/events/mb/socket478/p4pe-x-te/overview.htm", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000725 B("ASUS", "P4S533-X", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000726 B("ASUS", "P4S800-MX", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000727 B("ASUS", "P4SC-E", OK, NULL, "Part of ASUS Terminator P4 533 barebone system"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000728 B("ASUS", "P4SD-LA", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000729 B("ASUS", "P5A", OK, NULL, NULL),
730 B("ASUS", "P5B", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000731 B("ASUS", "P5B-Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000732 B("ASUS", "P5B-VM", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000733 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000734 B("ASUS", "P5BV-R", OK, "http://www.asus.com/Server_Workstation/Servers/RS120E5PA2/", "Used in RS120-E5/PA2 servers."),
735 B("ASUS", "P5GC-MX/1333", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/", NULL),
736 B("ASUS", "P5GD1 Pro", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
737 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."),
738 B("ASUS", "P5GD1(-VM)", NT, NULL, "Untested board enable."),
739 B("ASUS", "P5GD2 Premium", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/", NULL),
740 B("ASUS", "P5GD2-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2X/", NULL),
741 B("ASUS", "P5GDC Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/", NULL),
742 B("ASUS", "P5GDC-V Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/", NULL),
743 B("ASUS", "P5GD2/C variants", NT, NULL, "Untested board enable."),
744 B("ASUS", "P5K-V", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
745 B("ASUS", "P5K-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
746 B("ASUS", "P5KC", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
Stefan Tauner352e50b2013-02-22 15:58:45 +0000747 B("ASUS", "P5KPL-AM IN/GB", OK, "http://support.asus.com/download.aspx?SLanguage=en&m=P5KPL-AM+IN%2fGB&os=29", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000748 B("ASUS", "P5KPL-CM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
749 B("ASUS", "P5L-MX", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
750 B("ASUS", "P5L-VM 1394", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/", NULL),
751 B("ASUS", "P5LD2", NT, NULL, "Untested board enable."),
Idwer Vollering4d0cde12012-09-07 08:27:46 +0000752 B("ASUS", "P5LD2-VM", NT, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM/", "Untested board enable."),
Stefan Tauner309dd2c2013-11-21 15:59:52 +0000753 B("ASUS", "P5LD2-VM DH", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM_DH/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000754 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."),
755 B("ASUS", "P5LP-LE (Epson OEM)", OK, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
756 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000757 B("ASUS", "P5N-D", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
758 B("ASUS", "P5N-E SLI", NT, "http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Untested board enable."),
759 B("ASUS", "P5N32-E SLI", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/", NULL),
760 B("ASUS", "P5N7A-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
761 B("ASUS", "P5ND2-SLI Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/", NULL),
762 B("ASUS", "P5PE-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
763 B("ASUS", "P5QPL-AM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
764 B("ASUS", "P5VD1-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
765 B("ASUS", "P5VD2-MX", OK, "http://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 http://www.flashrom.org/pipermail/flashrom/2012-March/009014.html"),
766 B("ASUS", "P6T SE", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
767 B("ASUS", "P6T Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/", NULL),
768 B("ASUS", "P6T Deluxe V2", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/", NULL),
769 B("ASUS", "P7H57D-V EVO", OK, "http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
770 B("ASUS", "P7H55-M LX", BAD, NULL, "flashrom works correctly, but GbE LAN is nonworking (probably due to a missing/bogus MAC address; see http://www.flashrom.org/pipermail/flashrom/2011-July/007432.html and http://ubuntuforums.org/showthread.php?t=1534389 for a possible workaround)"),
771 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."),
772 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 +0000773 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 +0000774 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."),
775 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 +0000776 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
Stefan Tauner0554ca52013-07-25 22:54:25 +0000777 B("ASUS", "P8H77-I", OK, "http://www.asus.com/Motherboards/P8H77I/", NULL),
778 B("ASUS", "P8H77-M", OK, "http://www.asus.com/Motherboards/P8H77M/", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000779 B("ASUS", "P8H77-V LE", OK, "http://www.asus.com/Motherboards/P8H77V_LE/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000780 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 +0000781 B("ASUS", "P8P67 LE (B2)", OK, NULL, NULL),
782 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000783 B("ASUS", "P8P67 PRO (rev. 3.0)", OK, "http://www.asus.com/Motherboards/Intel_Socket_1155/P8P67_PRO/", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000784 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000785 B("ASUS", "P8Z68-V", OK, "http://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 +0000786 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 +0000787 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."),
788 B("ASUS", "P8Z68-V PRO/GEN3", OK, "http://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V_PROGEN3/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
789 B("ASUS", "SABERTOOTH 990FX", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX/", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000790 B("ASUS", "SABERTOOTH 990FX R2.0", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX_R20/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000791 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."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000792 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."),
793 B("ASUS", "Z8NA-D6C", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/", NULL),
794 B("ASUS", "Z8PE-D12", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000795 B("Attro", "G5G100-P", OK, "http://www.attro.com/motherboard/G5G100-P.htm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000796 B("Bachmann", "OT200", OK, "http://www.bachmann.info/produkte/bedien-und-beobachtungsgeraete/operator-terminals/", NULL),
797 B("BCOM", "WinNET100", OK, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
798 B("Bifferos", "Bifferboard", OK, "http://bifferos.co.uk/", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000799 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 +0000800 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."),
801 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 +0000802 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 +0000803 B("Biostar", "M7VIQ", NT, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000804 B("Biostar", "N61PB-M2S", OK, NULL, NULL),
805 B("Biostar", "N68S3+", OK, NULL, NULL),
806 B("Biostar", "P4M80-M4", OK, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000807 B("Biostar", "TA780G M2+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=344", NULL),
808 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 +0000809 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."),
810 B("Congatec", "conga-X852", OK, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
811 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 +0000812 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 +0000813 B("Dell", "OptiPlex GX1", OK, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
814 B("Dell", "PowerEdge 1850", OK, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000815 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 +0000816 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."),
817 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 +0000818 B("DFI", "AD77", NT, NULL, "Untested board enable."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000819 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 +0000820 B("Elitegroup", "848P-A7", OK, NULL, NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +0000821 B("Elitegroup", "GeForce6100PM-M2 (V3.0)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000822 B("Elitegroup", "GeForce6100SM-M", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000823 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 Taunereb582572012-09-21 12:52:50 +0000824 B("Elitegroup", "GF7100PVT-M3 (V1.0)", OK, NULL, NULL),
825 B("Elitegroup", "GF8200A", OK, NULL, NULL),
826 B("Elitegroup", "K7S5A", OK, NULL, NULL),
827 B("Elitegroup", "K7S6A", OK, NULL, NULL),
828 B("Elitegroup", "K7SEM (V1.0A)", OK, NULL, NULL),
829 B("Elitegroup", "K7VTA3", OK, NULL, NULL),
830 B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000831 B("Elitegroup", "P4VXMS (V1.0A)", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000832 B("Elitegroup", "P6BAP-A+ (V2.2)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000833 B("Elitegroup", "P6IWP-Fe", OK, NULL, NULL),
834 B("Elitegroup", "P6VAP-A+", OK, NULL, NULL),
835 B("Elitegroup", "RS485M-M", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000836 B("Emerson", "ATCA-7360", OK, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
837 B("EPoX", "EP-3PTA", BAD, NULL, "Missing board enable (W83627HF/F/HG/G), see http://www.flashrom.org/pipermail/flashrom/2012-April/009043.html"),
838 B("EPoX", "EP-8K5A2", OK, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
839 B("EPoX", "EP-8NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
840 B("EPoX", "EP-8RDA3+", OK, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
841 B("EPoX", "EP-9NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
842 B("EPoX", "EP-BX3", OK, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000843 B("EVGA", "122-CK-NF68", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000844 B("EVGA", "132-CK-NF78", OK, "http://www.evga.com/articles/385.asp", NULL),
845 B("EVGA", "270-WS-W555-A2 (Classified SR-2)", OK, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
846 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 +0000847 B("Foxconn", "6150K8MD-8EKRSH", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000157", NULL),
848 B("Foxconn", "A6VMX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000346", NULL),
849 B("Foxconn", "P4M800P7MA-RS2", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000138", NULL),
Stefan Taunerd7d423b2012-10-20 09:13:16 +0000850 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 +0000851 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 +0000852 B("Freetech", "P6F91i", OK, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
853 B("Fujitsu", "D3041-A1", OK, NULL, "Used in ESPRIMO P2560, contains an Atmel AT26DF081A."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000854 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 +0000855 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 +0000856 B("GIGABYTE", "GA-2761GXDK", OK, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
857 B("GIGABYTE", "GA-6BXC", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
858 B("GIGABYTE", "GA-6BXDU", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
859 B("GIGABYTE", "GA-6IEM", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
860 B("GIGABYTE", "GA-6VXE7+", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
861 B("GIGABYTE", "GA-6ZMA", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000862 B("GIGABYTE", "GA-770TA-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
863 B("GIGABYTE", "GA-7DXR", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
864 B("GIGABYTE", "GA-7VT600", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
865 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."),
866 B("GIGABYTE", "GA-880GMA-USB3 (rev. 3.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
867 B("GIGABYTE", "GA-8I945GZME-RH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
868 B("GIGABYTE", "GA-8IP775", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
869 B("GIGABYTE", "GA-8IRML", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
870 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 +0000871 B("GIGABYTE", "GA-8S648", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1674", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000872 B("GIGABYTE", "GA-8SIMLH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
873 B("GIGABYTE", "GA-945PL-S3P (rev. 6.6)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
874 B("GIGABYTE", "GA-965GM-S2 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
875 B("GIGABYTE", "GA-965P-DS4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000876 B("GIGABYTE", "GA-970A-D3P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4642", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000877 B("GIGABYTE", "GA-A75M-UD2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3928", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000878 B("GIGABYTE", "GA-B85M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4567", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000879 B("GIGABYTE", "GA-EP31-DS3L (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
880 B("GIGABYTE", "GA-EP35-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000881 B("GIGABYTE", "GA-EX58-UD4P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000882 B("GIGABYTE", "GA-G41MT-S2PT", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3960", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000883 B("GIGABYTE", "GA-H61M-D2-B3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3773", NULL),
884 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 +0000885 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 Tauner352e50b2013-02-22 15:58:45 +0000886 B("GIGABYTE", "GA-H77M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4388", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000887 B("GIGABYTE", "GA-K8N51GMF-9", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000888 B("GIGABYTE", "GA-K8N51GMF", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
889 B("GIGABYTE", "GA-K8N-SLI", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000890 B("GIGABYTE", "GA-K8NS Pro-939", NT, "http://www.gigabyte.com/products/product-page.aspx?pid=1875", "Untested board enable."),
891 B("GIGABYTE", "GA-M57SLI-S4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
892 B("GIGABYTE", "GA-M61P-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
893 B("GIGABYTE", "GA-M720-US3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
894 B("GIGABYTE", "GA-MA69VM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
895 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
896 B("GIGABYTE", "GA-MA770-UD3 (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
897 B("GIGABYTE", "GA-MA770T-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
898 B("GIGABYTE", "GA-MA780G-UD3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000899 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 +0000900 B("GIGABYTE", "GA-MA78G-DS3H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
901 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? */
902 B("GIGABYTE", "GA-MA78GPM-DS2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
903 B("GIGABYTE", "GA-MA790FX-DQ6", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
904 B("GIGABYTE", "GA-MA790GP-DS4H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
905 B("GIGABYTE", "GA-MA790XT-UD4P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
906 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 +0000907 B("GIGABYTE", "GA-P55A-UD7" , OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3324", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000908 B("GIGABYTE", "GA-P67A-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000909 B("GIGABYTE", "GA-X58A-UD3R (rev. 2.0)", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000910 B("GIGABYTE", "GA-X58A-UD7 (rev. 2.0)", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000911 B("GIGABYTE", "GA-X79-UD5", OK, NULL, NULL),
912 B("GIGABYTE", "GA-X79-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4050", "Contains a Macronix MX25L6406E."),
913 B("GIGABYTE", "GA-X79-UP4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4288", NULL),
914 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 +0000915 B("GIGABYTE", "GA-Z68MX-UD2H-B (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
916 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 +0000917 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 +0000918 B("GIGABYTE", "GA-Z87-HD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4489", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000919 B("HP", "8100 Elite CMT PC (304Bh)", BAD, NULL, "SPI lock down, PR, read-only descriptor, locked ME region."),
920 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 +0000921 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 +0000922 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),
923 B("HP", "ProLiant DL165 G6", OK, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
924 B("HP", "ProLiant N40L", OK, NULL, NULL),
925 B("HP", "Puffer2-UL8E", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
926 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."),
927 B("HP", "Vectra VL400", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
928 B("HP", "Vectra VL420 SFF", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
929 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"),
930 B("HP", "xw6400", BAD, NULL, "No chip found, see http://www.flashrom.org/pipermail/flashrom/2012-March/009006.html"),
931 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 http://www.flashrom.org/pipermail/flashrom/2012-February/008862.html"),
932 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."),
933 B("HP", "Z400 Workstation (0AE4h)", BAD, NULL, "ICH10R with BIOS lock enable and a protected range PRBAD, see http://www.flashrom.org/pipermail/flashrom/2012-June/009350.html"),
934 B("IBASE", "MB899", OK, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
935 B("IBM", "x3455", OK, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
936 B("IEI", "PICOe-9452", OK, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
937 B("Intel", "D201GLY", OK, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000938 B("Intel", "D2700MUD", BAD, "http://www.intel.com/cd/products/services/emea/eng/motherboards/desktop/D2700MUD/", "SMM protection enabled"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000939 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 http://www.flashrom.org/pipermail/flashrom/2012-January/008600.html"),
940 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 +0000941 B("Intel", "D945GCNL", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000942 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."),
943 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)."),
944 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)."),
945 B("Intel", "DH61AG ", BAD, NULL, "H61 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2012-June/009417.html"),
946 B("Intel", "DH67CF", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
Stefan Taunere34e3e82013-01-01 00:06:51 +0000947 B("Intel", "DH67CL", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2012-November/010112.html"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000948 B("Intel", "DN2800MT (Marshalltown)", BAD, NULL, "BIOS locked via BIOS_CNTL."),
Stefan Taunerdbac46c2013-08-13 22:10:41 +0000949 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 +0000950 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 +0000951 B("Intel", "EP80759", OK, NULL, NULL),
952 B("Intel", "Foxhollow", OK, NULL, "Intel reference board."),
953 B("Intel", "Greencity", OK, NULL, "Intel reference board."),
954 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"),
955 B("IWILL", "DK8-HTX", OK, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
956 B("Jetway", "J-7BXAN", OK, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
957 B("Jetway", "J7F4K1G5D-PB", OK, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
958 B("Kontron", "986LCD-M", OK, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
959 B("Lanner", "EM-8510C", OK, NULL, NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000960 B("Lenovo", "Tilapia CRB", OK, NULL, "Used in ThinkCentre M75e."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000961 B("Lex", "CV700A", OK, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
962 B("Mitac", "6513WU", OK, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
963 B("MSC", "Q7-TCTC", OK, "http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html", NULL),
964 B("MSI", "MS-6153", OK, "http://www.msi.com/product/mb/MS-6153.html", NULL),
965 B("MSI", "MS-6156", OK, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
966 B("MSI", "MS-6163 (MS-6163 Pro)",OK, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
967 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>."),
968 B("MSI", "MS-6330 (K7T Turbo)", OK, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
969 B("MSI", "MS-6391 (845 Pro4)", OK, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
970 B("MSI", "MS-6561 (745 Ultra)", OK, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
971 B("MSI", "MS-6566 (845 Ultra-C)",OK, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
972 B("MSI", "MS-6570 (K7N2)", OK, "http://www.msi.com/product/mb/K7N2.html", NULL),
973 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."),
974 B("MSI", "MS-6590 (KT4 Ultra)", OK, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000975 //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.
976 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 +0000977 B("MSI", "MS-6712 (KT4V)", OK, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
978 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", OK, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
979 B("MSI", "MS-7005 (651M-L)", OK, "http://www.msi.com/product/mb/651M-L.html", NULL),
980 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 +0000981 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 +0000982 B("MSI", "MS-7046", OK, "http://www.heimir.de/ms7046/", NULL),
983 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", OK, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
984 B("MSI", "MS-7065", OK, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +0000985 B("MSI", "MS-7094 (K8T Neo2-F V2.0)",OK, "http://www.msi.com/product/mb/K8T_Neo2F_V2.0.html", NULL),
986 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 +0000987 B("MSI", "MS-7135 (K8N Neo3)", OK, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
988 B("MSI", "MS-7142 (K8MM-V)", OK, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
989 B("MSI", "MS-7168 (Orion)", OK, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
990 B("MSI", "MS-7207 (K8NGM2-L)", OK, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
991 B("MSI", "MS-7211 (PM8M3-V)", OK, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
992 B("MSI", "MS-7236 (945PL Neo3)", OK, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
993 B("MSI", "MS-7250 (K9N SLI (rev 2.1))", OK, "http://www.msi.com/product/mb/K9N--SLI.html", NULL),
994 B("MSI", "MS-7253 (K9VGM-V)", OK, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
995 B("MSI", "MS-7255 (P4M890M)", OK, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
996 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 +0000997 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 +0000998 B("MSI", "MS-7309 (K9N6PGM2-V2)", OK, "http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
999 B("MSI", "MS-7312 (K9MM-V)", OK, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
1000 B("MSI", "MS-7345 (P35 Neo2-FIR)", OK, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001001 B("MSI", "MS-7357 (G33M)", OK, "http://www.msi.com/product/mb/G33M.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001002 B("MSI", "MS-7368 (K9AG Neo2-Digital)", OK, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
1003 B("MSI", "MS-7369 (K9N Neo V2)", OK, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
1004 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 +00001005 B("MSI", "MS-7379 (G31M)", OK, "http://www.msi.com/product/mb/G31M.html", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001006 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."),
1007 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 +00001008 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 +00001009 B("MSI", "MS-7529 (G31TM-P21)", OK, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001010 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 +00001011 B("MSI", "MS-7551 (KA780G)", OK, "http://www.msi.com/product/mb/KA780G.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001012 B("MSI", "MS-7596 (785GM-E51)", OK, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
1013 B("MSI", "MS-7597 (GF615M-P33)", BAD, NULL, "Missing board enable/SIO support (Fintek F71889), see http://www.flashrom.org/pipermail/flashrom/2012-March/008956.html"),
1014 B("MSI", "MS-7599 (870-C45)", OK, "http://www.msi.com/product/mb/870-C45.html", NULL),
1015 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."),
1016 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."),
1017 B("MSI", "MS-7640 (890FXA-GD70)",OK, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
1018 B("MSI", "MS-7642 (890GXM-G65)", OK, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
1019 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 http://www.flashrom.org/pipermail/flashrom/2012-January/008547.html"),
1020 B("MSI", "MS-7676 (Z68MA-G45 (B3))", OK, "http://www.msi.com/product/mb/Z68MA-G45--B3-.html", NULL),
1021 B("MSI", "MS-7696 (A75MA-G55)", OK, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
1022 B("MSI", "MS-7698 (E350IA-E45)", OK, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001023 B("MSI", "MS-7740 (H61MA-E35(B3))", OK, "http://www.msi.com/product/mb/H61MA-E35--B3-.html", NULL),
1024 B("MSI", "MS-7756 (H77MA-G43)", OK, "http://www.msi.com/product/mb/H77MA-G43.html", NULL),
1025 B("MSI", "MS-7808 (B75MA-E33)", OK, "http://www.msi.com/product/mb/B75MA-E33.html", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001026 B("MSI", "MS-7816 (H87-G43)", OK, "http://www.msi.com/product/mb/H87-G43.html", NULL),
1027 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 +00001028 B("NEC", "PowerMate 2000", OK, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
1029 B("Nokia", "IP530", OK, NULL, NULL),
1030 B("Palit", "N61S", OK, NULL, NULL),
1031 B("PCCHIPS ", "M598LMR (V9.0)", OK, NULL, NULL),
1032 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),
1033 B("PC Engines", "Alix.1c", OK, "http://pcengines.ch/alix1c.htm", NULL),
1034 B("PC Engines", "Alix.2c2", OK, "http://pcengines.ch/alix2c2.htm", NULL),
1035 B("PC Engines", "Alix.2c3", OK, "http://pcengines.ch/alix2c3.htm", NULL),
1036 B("PC Engines", "Alix.2d3", OK, "http://pcengines.ch/alix2d3.htm", NULL),
1037 B("PC Engines", "Alix.3c3", OK, "http://pcengines.ch/alix3c3.htm", NULL),
1038 B("PC Engines", "Alix.3d3", OK, "http://pcengines.ch/alix3d3.htm", NULL),
1039 B("PC Engines", "Alix.6f2", OK, "http://pcengines.ch/alix6f2.htm", NULL),
Wei Hu31402ee2014-05-16 21:39:33 +00001040 B("PC Engines", "APU", OK, "http://pcengines.ch/apu.htm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001041 B("PC Engines", "WRAP.2E", OK, "http://pcengines.ch/wrap2e1.htm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001042 B("PCWARE", "APM80-D3", OK, "http://www.pcwarebr.com.br/produtos_mb_apm80-d3.php", "Probably manufactured by ASUS"),
1043 B("Pegatron", "IPP7A-CP", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001044 B("Portwell", "PEB-4700VLA", OK, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
1045 B("RCA", "RM4100", OK, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
1046 B("Samsung", "Polaris 32", OK, NULL, NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001047 B("SAPPHIRE", "IPC-E350M1", OK, "http://www.sapphiretech.com/presentation/product/?pid=1034&lid=1", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001048 B("Shuttle", "AK31", OK, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
1049 B("Shuttle", "AK38N", OK, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
1050 B("Shuttle", "AV11V30", OK, NULL, NULL),
1051 B("Shuttle", "AV18E2", OK, "http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001052 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 +00001053 B("Shuttle", "FD37", OK, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
1054 B("Shuttle", "FH67", OK, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
1055 B("Shuttle", "FN25", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +00001056 B("Shuttle", "FN78S", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn78sh7/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001057 B("Shuttle", "X50/X50(B)", OK, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
1058 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."),
1059 B("Soyo", "SY-6BA+ III", OK, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
1060 B("Soyo", "SY-7VCA", OK, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
1061 B("Sun", "Blade x6250", OK, "http://www.sun.com/servers/blades/x6250/", NULL),
1062 B("Sun", "Fire x4150", BAD, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
1063 B("Sun", "Fire x4200", BAD, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
1064 B("Sun", "Fire x4540", BAD, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
1065 B("Sun", "Fire x4600", BAD, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
1066 B("Sun", "Ultra 40 M2", OK, "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html", NULL),
1067 B("Supermicro", "H8QC8", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001068 B("Supermicro", "H8QME-2", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron8000/MCP55/H8QME-2.cfm", NULL),
1069 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 +00001070 B("Supermicro", "X5DP8-G2", OK, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
1071 B("Supermicro", "X7DBT-INF", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001072 B("Supermicro", "X7SPA-H(F)", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H", NULL),
1073 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 +00001074 B("Supermicro", "X8DT3", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
Stefan Taunerc2eec2c2014-05-03 21:33:01 +00001075 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 +00001076 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 +00001077 B("Supermicro", "X8DTG-D", OK, "http://www.supermicro.com/products/motherboard/qpi/5500/x8dtg-df.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001078 B("Supermicro", "X8DTH-6F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
1079 B("Supermicro", "X8DTT-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
1080 B("Supermicro", "X8DTT-HIBQF", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm", NULL),
1081 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."),
1082 B("Supermicro", "X8DTU-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001083 B("Supermicro", "X8SAX", OK, "http://www.supermicro.com/products/motherboard/xeon3000/x58/x8sax.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001084 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 +00001085 B("Supermicro", "X8SIL-F", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIL.cfm", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001086 B("Supermicro", "X8STi", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
1087 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 +00001088 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 +00001089 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."),
1090 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 +00001091 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 +00001092 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 +00001093 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 +00001094 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 +00001095 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 +00001096 B("T-Online", "S-100", OK, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
1097 B("Tekram", "P6Pro-A5", OK, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
1098 B("Termtek", "TK-3370 (Rev:2.5B)", OK, NULL, NULL),
1099 B("Thomson", "IP1000", OK, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
1100 B("TriGem", "Anaheim-3", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml", NULL),
1101 B("TriGem", "Lomita", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
1102 B("Tyan", "S1846 (Tsunami ATX)", OK, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
1103 B("Tyan", "S2466 (Tiger MPX)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
1104 B("Tyan", "S2498 (Tomcat K7M)", OK, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
1105 B("Tyan", "S2723 (Tiger i7501)", OK, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
1106 B("Tyan", "S2875 (Tiger K8W)", OK, "http://www.tyan.com/archive/products/html/tigerk8w.html", NULL),
1107 B("Tyan", "S2881 (Thunder K8SR)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
1108 B("Tyan", "S2882-D (Thunder K8SD Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
1109 B("Tyan", "S2882 (Thunder K8S Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
1110 B("Tyan", "S2891 (Thunder K8SRE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
1111 B("Tyan", "S2892 (Thunder K8SE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
1112 B("Tyan", "S2895 (Thunder K8WE)", OK, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
1113 B("Tyan", "S2912 (Thunder n3600R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
1114 B("Tyan", "S2915-E (Thunder n6650W)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
1115 B("Tyan", "S2915 (Thunder n6650W)", OK, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
1116 B("Tyan", "S2933 (Thunder n3600S)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
1117 B("Tyan", "S3095 (Tomcat i945GM)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
1118 B("Tyan", "S3992 (Thunder h2000M)", OK, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001119 B("Tyan", "S4882 (Thunder K8QS Pro)", OK, "http://www.tyan.com/archive/products/html/thunderk8qspro.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001120 B("Tyan", "S5180 (Toledo i965R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
1121 B("Tyan", "S5191 (Toledo i3000R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
1122 B("Tyan", "S5197 (Toledo i3010W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
1123 B("Tyan", "S5211-1U (Toledo i3200R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
1124 B("Tyan", "S5211 (Toledo i3210W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
1125 B("Tyan", "S5220 (Toledo q35T)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
1126 B("Tyan", "S5375-1U (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
1127 B("Tyan", "S5375 (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
1128 B("Tyan", "S5376 (Tempest i5100W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
1129 B("Tyan", "S5377 (Tempest i5100T)", OK, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
1130 B("Tyan", "S5382 (Tempest i5000PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
1131 B("Tyan", "S5397 (Tempest i5400PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
Stefan Tauner0554ca52013-07-25 22:54:25 +00001132 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 +00001133 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 +00001134 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 */
1135 B("VIA", "EPIA SP", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
1136 B("VIA", "EPIA-CN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
1137 B("VIA", "EPIA EK", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
1138 B("VIA", "EPIA-EX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
1139 B("VIA", "EPIA-LN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
1140 B("VIA", "EPIA-M700", OK, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
1141 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 */
1142 B("VIA", "EPIA-NX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
1143 B("VIA", "NAB74X0", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
1144 B("VIA", "pc2500e", OK, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
1145 B("VIA", "PC3500G", OK, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
1146 B("VIA", "VB700X", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
1147 B("ZOTAC", "Fusion-ITX WiFi (FUSION350-A-E)", OK, NULL, NULL),
1148 B("ZOTAC", "GeForce 8200", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +00001149 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 +00001150 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 Taunerc2eec2c2014-05-03 21:33:01 +00001151 B("ZOTAC", "IONITX-A", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001152 B("ZOTAC", "nForce 630i Supreme (N73U-Supreme)", OK, NULL, NULL),
1153 B("ZOTAC", "ZBOX AD02 (PLUS)", OK, NULL, NULL),
1154 B("ZOTAC", "ZBOX HD-ID11", OK, NULL, NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001155#endif
Peter Lemenkov4adf8a62010-06-01 10:13:17 +00001156
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +00001157 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001158};
1159
1160/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +00001161const struct board_info laptops_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001162#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +00001163 B("Acer", "Aspire 1520", OK, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
1164 B("Acer", "Aspire One", BAD, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
1165 B("ASUS", "A8Jm", OK, NULL, NULL),
Stefan Taunerdbac46c2013-08-13 22:10:41 +00001166 B("ASUS", "Eee PC 701 4G", BAD, "http://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 Tauner2c20b282012-07-28 19:35:26 +00001167 B("ASUS", "M6Ne", NT, "http://www.asus.com/Notebooks/Versatile_Performance/M6NNe/", "Untested board enable."),
1168 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."),
1169 B("Dell", "Inspiron 1420", OK, NULL, NULL),
1170 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."),
1171 B("Dell", "Vostro 3700", BAD, NULL, "Locked ME, see http://www.flashrom.org/pipermail/flashrom/2012-May/009197.html."),
1172 B("Dell", "Latitude E6520", BAD, NULL, "Locked ME, see http://www.flashrom.org/pipermail/flashrom/2012-June/009420.html."),
Stefan Taunere34e3e82013-01-01 00:06:51 +00001173 B("Elitegroup", "A928", OK, NULL, "Bootsector is locked and needs to be skipped with a layout file (writeable address range is 00000000:0003bfff"),
1174 B("HP/Compaq", "EliteBook 8560p", BAD, NULL, "SPI lock down, SMM protection, PR in BIOS region, read-only descriptor, locked ME region."),
Stefan Tauner2c20b282012-07-28 19:35:26 +00001175 B("HP/Compaq", "nx9005", BAD, "http://h18000.www1.hp.com/products/quickspecs/11602_na/11602_na.HTML", "Shuts down when probing for a chip. http://www.flashrom.org/pipermail/flashrom/2010-May/003321.html"),
1176 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)."),
1177 B("IBM/Lenovo", "Thinkpad T40p", BAD, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
1178 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)."),
1179 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)."),
1180 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)."),
1181 B("IBM/Lenovo", "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."),
1182 B("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 +00001183 //B("MSI", "GT60-2OD", OK, "http://www.msi.com/product/nb/GT60_2OD.html", NULL), requires layout patches
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001184#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001185
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +00001186 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001187};
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +00001188#endif