blob: feca45ecd3beb3c251f1386640505fd809b8cb1b [file] [log] [blame]
uwe884cc8b2009-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
Edward O'Callaghane121af72019-11-14 22:34:07 +11006 * Copyright (C) 2011-2013 Stefan Tauner
uwe884cc8b2009-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.
uwe884cc8b2009-06-17 12:07:12 +000017 */
18
hailfingera83a5fe2010-05-30 22:24:40 +000019#include <stdio.h>
uwe884cc8b2009-06-17 12:07:12 +000020#include <string.h>
21#include <stdlib.h>
Edward O'Callaghane121af72019-11-14 22:34:07 +110022#include <stddef.h>
uwe884cc8b2009-06-17 12:07:12 +000023#include "flash.h"
hailfinger428f6852010-07-27 22:41:39 +000024#include "programmer.h"
uwe884cc8b2009-06-17 12:07:12 +000025
Edward O'Callaghane121af72019-11-14 22:34:07 +110026static const char *test_state_to_text(enum test_state test_state)
27{
28 switch (test_state) {
29 case OK: return "OK";
30 case BAD: return "Not working";
31 case NA: return "N/A";
32 case DEP: return "Config-dependent";
33 case NT:
34 default: return "Untested";
35 }
36}
37
Edward O'Callaghan723c12c2020-08-01 22:42:00 +100038static int print_supported_chips(void)
uwe884cc8b2009-06-17 12:07:12 +000039{
stefanctcf8fd612011-09-12 22:55:01 +000040 const char *delim = "/";
41 const int mintoklen = 5;
42 const int border = 2;
43 int i, chipcount = 0;
stefanct6d836ba2011-05-26 01:35:19 +000044 int maxvendorlen = strlen("Vendor") + 1;
45 int maxchiplen = strlen("Device") + 1;
stefanctcf8fd612011-09-12 22:55:01 +000046 int maxtypelen = strlen("Type") + 1;
Edward O'Callaghan723c12c2020-08-01 22:42:00 +100047 const struct flashchip *chip;
stefanct588b6d22011-06-26 20:45:35 +000048 char *s;
Edward O'Callaghanab4993a2019-11-09 21:36:17 +110049 char *ven, *dev;
50 char *tmpven, *tmpdev, *tmpven_save, *tmpdev_save;
stefanctcf8fd612011-09-12 22:55:01 +000051 int tmpvenlen, tmpdevlen, curvenlen, curdevlen;
uwe884cc8b2009-06-17 12:07:12 +000052
stefanctcf8fd612011-09-12 22:55:01 +000053 /* calculate maximum column widths and by iterating over all chips */
Edward O'Callaghan723c12c2020-08-01 22:42:00 +100054 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner0fd31b62016-08-04 17:11:25 -070055 /* Ignore generic entries. */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +110056 if (!strncmp(chip->vendor, "Unknown", 7) ||
57 !strncmp(chip->vendor, "Programmer", 10) ||
58 !strncmp(chip->name, "unknown", 7))
uwe884cc8b2009-06-17 12:07:12 +000059 continue;
uwe884cc8b2009-06-17 12:07:12 +000060 chipcount++;
stefanctcf8fd612011-09-12 22:55:01 +000061
62 /* Find maximum vendor length (respecting line splitting). */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +110063 tmpven = (char *)chip->vendor;
stefanctcf8fd612011-09-12 22:55:01 +000064 do {
65 /* and take minimum token lengths into account */
66 tmpvenlen = 0;
67 do {
68 tmpvenlen += strcspn(tmpven, delim);
69 /* skip to the address after the first token */
70 tmpven += tmpvenlen;
71 if (tmpven[0] == '\0')
72 break;
73 tmpven++;
74 } while (tmpvenlen < mintoklen);
75 maxvendorlen = max(maxvendorlen, tmpvenlen);
76 if (tmpven[0] == '\0')
77 break;
78 } while (1);
79
80 /* same for device name */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +110081 tmpdev = (char *)chip->name;
stefanctcf8fd612011-09-12 22:55:01 +000082 do {
83 tmpdevlen = 0;
84 do {
85 tmpdevlen += strcspn(tmpdev, delim);
86 tmpdev += tmpdevlen;
87 if (tmpdev[0] == '\0')
88 break;
89 tmpdev++;
90 } while (tmpdevlen < mintoklen);
91 maxchiplen = max(maxchiplen, tmpdevlen);
92 if (tmpdev[0] == '\0')
93 break;
94 } while (1);
95
Edward O'Callaghanab4993a2019-11-09 21:36:17 +110096 s = flashbuses_to_text(chip->bustype);
stefanctcf8fd612011-09-12 22:55:01 +000097 maxtypelen = max(maxtypelen, strlen(s));
98 free(s);
hailfingere4c80422010-07-17 23:21:12 +000099 }
stefanctcf8fd612011-09-12 22:55:01 +0000100 maxvendorlen += border;
101 maxchiplen += border;
102 maxtypelen += border;
uwe884cc8b2009-06-17 12:07:12 +0000103
stefancte94ab342011-06-25 17:36:25 +0000104 msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
105 msg_ginfo("Vendor");
hailfingere4c80422010-07-17 23:21:12 +0000106 for (i = strlen("Vendor"); i < maxvendorlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000107 msg_ginfo(" ");
108 msg_ginfo("Device");
hailfingere4c80422010-07-17 23:21:12 +0000109 for (i = strlen("Device"); i < maxchiplen; i++)
stefancte94ab342011-06-25 17:36:25 +0000110 msg_ginfo(" ");
uwe884cc8b2009-06-17 12:07:12 +0000111
stefanctcf8fd612011-09-12 22:55:01 +0000112 msg_ginfo("Test");
113 for (i = 0; i < border; i++)
stefancte94ab342011-06-25 17:36:25 +0000114 msg_ginfo(" ");
stefanctcf8fd612011-09-12 22:55:01 +0000115 msg_ginfo("Known");
116 for (i = 0; i < border; i++)
117 msg_ginfo(" ");
Edward O'Callaghane121af72019-11-14 22:34:07 +1100118 msg_ginfo(" Size ");
stefanctcf8fd612011-09-12 22:55:01 +0000119 for (i = 0; i < border; i++)
120 msg_ginfo(" ");
121
122 msg_ginfo("Type");
123 for (i = strlen("Type"); i < maxtypelen; i++)
124 msg_ginfo(" ");
125 msg_gdbg("Voltage");
126 msg_ginfo("\n");
127
128 for (i = 0; i < maxvendorlen + maxchiplen; i++)
129 msg_ginfo(" ");
130 msg_ginfo("OK ");
131 for (i = 0; i < border; i++)
132 msg_ginfo(" ");
133 msg_ginfo("Broken");
134 for (i = 0; i < border; i++)
135 msg_ginfo(" ");
Edward O'Callaghane121af72019-11-14 22:34:07 +1100136 msg_ginfo("[kB] ");
stefanctcf8fd612011-09-12 22:55:01 +0000137 for (i = 0; i < border + maxtypelen; i++)
138 msg_ginfo(" ");
139 msg_gdbg("range [V]");
140 msg_ginfo("\n\n");
Edward O'Callaghane121af72019-11-14 22:34:07 +1100141 msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE, - = N/A)\n\n");
uwe884cc8b2009-06-17 12:07:12 +0000142
Edward O'Callaghan723c12c2020-08-01 22:42:00 +1000143 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner0fd31b62016-08-04 17:11:25 -0700144 /* Don't print generic entries. */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100145 if (!strncmp(chip->vendor, "Unknown", 7) ||
146 !strncmp(chip->vendor, "Programmer", 10) ||
147 !strncmp(chip->name, "unknown", 7))
uwe884cc8b2009-06-17 12:07:12 +0000148 continue;
149
stefanctcf8fd612011-09-12 22:55:01 +0000150 /* support for multiline vendor names:
151 * - make a copy of the original vendor name
152 * - use strok to put the first token in tmpven
153 * - keep track of the length of all tokens on the current line
154 * for ' '-padding in curvenlen
155 * - check if additional tokens should be printed on the current
156 * line
157 * - after all other values are printed print the surplus tokens
158 * on fresh lines
159 */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100160 ven = malloc(strlen(chip->vendor) + 1);
161 if (ven == NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000162 msg_gerr("Out of memory!\n");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100163 return 1;
stefanctcf8fd612011-09-12 22:55:01 +0000164 }
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100165 strcpy(ven, chip->vendor);
uwe884cc8b2009-06-17 12:07:12 +0000166
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100167 tmpven = strtok_r(ven, delim, &tmpven_save);
stefanctcf8fd612011-09-12 22:55:01 +0000168 msg_ginfo("%s", tmpven);
169 curvenlen = strlen(tmpven);
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100170 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000171 msg_ginfo("%s", delim);
172 curvenlen++;
173 tmpvenlen = strlen(tmpven);
174 if (tmpvenlen >= mintoklen)
175 break; /* big enough to be on its own line */
176 msg_ginfo("%s", tmpven);
177 curvenlen += tmpvenlen;
uwe884cc8b2009-06-17 12:07:12 +0000178 }
179
stefanctcf8fd612011-09-12 22:55:01 +0000180 for (i = curvenlen; i < maxvendorlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000181 msg_ginfo(" ");
stefanctcf8fd612011-09-12 22:55:01 +0000182
183 /* support for multiline device names as above */
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100184 dev = malloc(strlen(chip->name) + 1);
185 if (dev == NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000186 msg_gerr("Out of memory!\n");
Edward O'Callaghan95f1e532020-04-23 14:02:25 +1000187 free(ven);
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100188 return 1;
hailfingere4c80422010-07-17 23:21:12 +0000189 }
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100190 strcpy(dev, chip->name);
stefanctcf8fd612011-09-12 22:55:01 +0000191
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100192 tmpdev = strtok_r(dev, delim, &tmpdev_save);
stefanctcf8fd612011-09-12 22:55:01 +0000193 msg_ginfo("%s", tmpdev);
194 curdevlen = strlen(tmpdev);
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100195 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000196 msg_ginfo("%s", delim);
197 curdevlen++;
198 tmpdevlen = strlen(tmpdev);
199 if (tmpdevlen >= mintoklen)
200 break; /* big enough to be on its own line */
201 msg_ginfo("%s", tmpdev);
202 curdevlen += tmpdevlen;
203 }
204
205 for (i = curdevlen; i < maxchiplen; i++)
206 msg_ginfo(" ");
207
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100208 if (chip->tested.probe == OK)
stefanctcf8fd612011-09-12 22:55:01 +0000209 msg_ginfo("P");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100210 else if (chip->tested.probe == NA)
211 msg_ginfo("-");
stefanctcf8fd612011-09-12 22:55:01 +0000212 else
213 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100214 if (chip->tested.read == OK)
stefanctcf8fd612011-09-12 22:55:01 +0000215 msg_ginfo("R");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100216 else if (chip->tested.read == NA)
217 msg_ginfo("-");
stefanctcf8fd612011-09-12 22:55:01 +0000218 else
219 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100220 if (chip->tested.erase == OK)
stefanctcf8fd612011-09-12 22:55:01 +0000221 msg_ginfo("E");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100222 else if (chip->tested.erase == NA)
223 msg_ginfo("-");
stefanctcf8fd612011-09-12 22:55:01 +0000224 else
225 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100226 if (chip->tested.write == OK)
stefanctcf8fd612011-09-12 22:55:01 +0000227 msg_ginfo("W");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100228 else if (chip->tested.write == NA)
229 msg_ginfo("-");
stefanctcf8fd612011-09-12 22:55:01 +0000230 else
231 msg_ginfo(" ");
232 for (i = 0; i < border; i++)
233 msg_ginfo(" ");
234
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100235 if (chip->tested.probe == BAD)
stefanctcf8fd612011-09-12 22:55:01 +0000236 msg_ginfo("P");
237 else
238 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100239 if (chip->tested.read == BAD)
stefanctcf8fd612011-09-12 22:55:01 +0000240 msg_ginfo("R");
241 else
242 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100243 if (chip->tested.erase == BAD)
stefanctcf8fd612011-09-12 22:55:01 +0000244 msg_ginfo("E");
245 else
246 msg_ginfo(" ");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100247 if (chip->tested.write == BAD)
stefanctcf8fd612011-09-12 22:55:01 +0000248 msg_ginfo("W");
249 else
250 msg_ginfo(" ");
251 for (i = 0; i < border + 1; i++)
252 msg_ginfo(" ");
253
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100254 msg_ginfo("%6d", chip->total_size);
stefanctcf8fd612011-09-12 22:55:01 +0000255 for (i = 0; i < border; i++)
stefancte94ab342011-06-25 17:36:25 +0000256 msg_ginfo(" ");
stefanct588b6d22011-06-26 20:45:35 +0000257
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100258 s = flashbuses_to_text(chip->bustype);
stefanctcf8fd612011-09-12 22:55:01 +0000259 msg_ginfo("%s", s);
260 for (i = strlen(s); i < maxtypelen; i++)
261 msg_ginfo(" ");
stefanct588b6d22011-06-26 20:45:35 +0000262 free(s);
stefanctcf8fd612011-09-12 22:55:01 +0000263
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100264 if (chip->voltage.min == 0 && chip->voltage.max == 0)
stefanctcf8fd612011-09-12 22:55:01 +0000265 msg_gdbg("no info");
266 else
267 msg_gdbg("%0.02f;%0.02f",
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100268 chip->voltage.min/(double)1000,
269 chip->voltage.max/(double)1000);
stefanctcf8fd612011-09-12 22:55:01 +0000270
271 /* print surplus vendor and device name tokens */
272 while (tmpven != NULL || tmpdev != NULL) {
273 msg_ginfo("\n");
274 if (tmpven != NULL){
275 msg_ginfo("%s", tmpven);
276 curvenlen = strlen(tmpven);
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100277 while ((tmpven = strtok_r(NULL, delim, &tmpven_save)) != NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000278 msg_ginfo("%s", delim);
279 curvenlen++;
280 tmpvenlen = strlen(tmpven);
281 /* big enough to be on its own line */
282 if (tmpvenlen >= mintoklen)
283 break;
284 msg_ginfo("%s", tmpven);
285 curvenlen += tmpvenlen;
286 }
287 } else
288 curvenlen = 0;
289
290 for (i = curvenlen; i < maxvendorlen; i++)
291 msg_ginfo(" ");
292
293 if (tmpdev != NULL){
294 msg_ginfo("%s", tmpdev);
295 curdevlen = strlen(tmpdev);
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100296 while ((tmpdev = strtok_r(NULL, delim, &tmpdev_save)) != NULL) {
stefanctcf8fd612011-09-12 22:55:01 +0000297 msg_ginfo("%s", delim);
298 curdevlen++;
299 tmpdevlen = strlen(tmpdev);
300 /* big enough to be on its own line */
301 if (tmpdevlen >= mintoklen)
302 break;
303 msg_ginfo("%s", tmpdev);
304 curdevlen += tmpdevlen;
305 }
306 }
307 }
308 msg_ginfo("\n");
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100309 free(ven);
310 free(dev);
uwe884cc8b2009-06-17 12:07:12 +0000311 }
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100312
313 return 0;
uwe884cc8b2009-06-17 12:07:12 +0000314}
315
hailfinger90c7d542010-05-31 15:27:27 +0000316#if CONFIG_INTERNAL == 1
hailfinger1ff33dc2010-07-03 11:02:10 +0000317static void print_supported_chipsets(void)
uwe884cc8b2009-06-17 12:07:12 +0000318{
Edward O'Callaghana66d68a2019-11-10 02:02:46 +1100319 unsigned int i, chipsetcount = 0;
uwe884cc8b2009-06-17 12:07:12 +0000320 const struct penable *c = chipset_enables;
Edward O'Callaghane121af72019-11-14 22:34:07 +1100321 size_t maxvendorlen = strlen("Vendor") + 1;
322 size_t maxchipsetlen = strlen("Chipset") + 1;
uwe884cc8b2009-06-17 12:07:12 +0000323
stefanct6d836ba2011-05-26 01:35:19 +0000324 for (c = chipset_enables; c->vendor_name != NULL; c++) {
uwe884cc8b2009-06-17 12:07:12 +0000325 chipsetcount++;
Edward O'Callaghane121af72019-11-14 22:34:07 +1100326 maxvendorlen = MAX(maxvendorlen, strlen(c->vendor_name));
327 maxchipsetlen = MAX(maxchipsetlen, strlen(c->device_name));
stefanct6d836ba2011-05-26 01:35:19 +0000328 }
329 maxvendorlen++;
330 maxchipsetlen++;
uwe884cc8b2009-06-17 12:07:12 +0000331
Edward O'Callaghane121af72019-11-14 22:34:07 +1100332 msg_ginfo("Supported chipsets (total: %u):\n\n", chipsetcount);
uwe884cc8b2009-06-17 12:07:12 +0000333
stefancte94ab342011-06-25 17:36:25 +0000334 msg_ginfo("Vendor");
stefanct6d836ba2011-05-26 01:35:19 +0000335 for (i = strlen("Vendor"); i < maxvendorlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000336 msg_ginfo(" ");
stefanct6d836ba2011-05-26 01:35:19 +0000337
stefancte94ab342011-06-25 17:36:25 +0000338 msg_ginfo("Chipset");
stefanct6d836ba2011-05-26 01:35:19 +0000339 for (i = strlen("Chipset"); i < maxchipsetlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000340 msg_ginfo(" ");
stefanct6d836ba2011-05-26 01:35:19 +0000341
Edward O'Callaghane121af72019-11-14 22:34:07 +1100342 msg_ginfo("PCI IDs Status\n\n");
stefanct6d836ba2011-05-26 01:35:19 +0000343
344 for (c = chipset_enables; c->vendor_name != NULL; c++) {
stefancte94ab342011-06-25 17:36:25 +0000345 msg_ginfo("%s", c->vendor_name);
stefanct6d836ba2011-05-26 01:35:19 +0000346 for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
stefancte94ab342011-06-25 17:36:25 +0000347 msg_ginfo(" ");
348 msg_ginfo("%s", c->device_name);
stefanct6d836ba2011-05-26 01:35:19 +0000349 for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
stefancte94ab342011-06-25 17:36:25 +0000350 msg_ginfo(" ");
Edward O'Callaghane121af72019-11-14 22:34:07 +1100351 msg_ginfo("%04x:%04x %s\n", c->vendor_id, c->device_id,
352 test_state_to_text(c->status));
uwe884cc8b2009-06-17 12:07:12 +0000353 }
354}
355
hailfinger1ff33dc2010-07-03 11:02:10 +0000356static void print_supported_boards_helper(const struct board_info *boards,
uwef35eeec2010-06-01 10:13:17 +0000357 const char *devicetype)
uwe884cc8b2009-06-17 12:07:12 +0000358{
Edward O'Callaghane121af72019-11-14 22:34:07 +1100359 unsigned int i;
360 unsigned int boardcount_good = 0, boardcount_bad = 0, boardcount_nt = 0;
hailfinger4640bdb2011-08-31 16:19:50 +0000361 const struct board_match *e = board_matches;
stefanct6d836ba2011-05-26 01:35:19 +0000362 const struct board_info *b = boards;
Edward O'Callaghane121af72019-11-14 22:34:07 +1100363 size_t maxvendorlen = strlen("Vendor") + 1;
364 size_t maxboardlen = strlen("Board") + 1;
uwe884cc8b2009-06-17 12:07:12 +0000365
stefanct6d836ba2011-05-26 01:35:19 +0000366 for (b = boards; b->vendor != NULL; b++) {
367 maxvendorlen = max(maxvendorlen, strlen(b->vendor));
368 maxboardlen = max(maxboardlen, strlen(b->name));
Edward O'Callaghane121af72019-11-14 22:34:07 +1100369 if (b->working == OK)
uwef35eeec2010-06-01 10:13:17 +0000370 boardcount_good++;
Edward O'Callaghane121af72019-11-14 22:34:07 +1100371 else if (b->working == NT)
372 boardcount_nt++;
uwe884cc8b2009-06-17 12:07:12 +0000373 else
uwef35eeec2010-06-01 10:13:17 +0000374 boardcount_bad++;
uwe884cc8b2009-06-17 12:07:12 +0000375 }
stefanct6d836ba2011-05-26 01:35:19 +0000376 maxvendorlen++;
377 maxboardlen++;
uwe884cc8b2009-06-17 12:07:12 +0000378
Edward O'Callaghane121af72019-11-14 22:34:07 +1100379 msg_ginfo("%d known %s (good: %d, untested: %d, bad: %d):\n\n",
380 boardcount_good + boardcount_nt + boardcount_bad,
381 devicetype, boardcount_good, boardcount_nt, boardcount_bad);
uwef35eeec2010-06-01 10:13:17 +0000382
stefancte94ab342011-06-25 17:36:25 +0000383 msg_ginfo("Vendor");
stefanct6d836ba2011-05-26 01:35:19 +0000384 for (i = strlen("Vendor"); i < maxvendorlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000385 msg_ginfo(" ");
stefanct6d836ba2011-05-26 01:35:19 +0000386
stefancte94ab342011-06-25 17:36:25 +0000387 msg_ginfo("Board");
stefanct6d836ba2011-05-26 01:35:19 +0000388 for (i = strlen("Board"); i < maxboardlen; i++)
stefancte94ab342011-06-25 17:36:25 +0000389 msg_ginfo(" ");
stefanct6d836ba2011-05-26 01:35:19 +0000390
Carl-Daniel Hailfingere5ec66e2016-08-03 16:10:19 -0700391 msg_ginfo("Status Required value for\n");
392 for (i = 0; i < maxvendorlen + maxboardlen + strlen("Status "); i++)
393 msg_ginfo(" ");
394 msg_ginfo("-p internal:mainboard=\n");
stefanct6d836ba2011-05-26 01:35:19 +0000395
396 for (b = boards; b->vendor != NULL; b++) {
stefancte94ab342011-06-25 17:36:25 +0000397 msg_ginfo("%s", b->vendor);
stefanct6d836ba2011-05-26 01:35:19 +0000398 for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
stefancte94ab342011-06-25 17:36:25 +0000399 msg_ginfo(" ");
400 msg_ginfo("%s", b->name);
stefanct6d836ba2011-05-26 01:35:19 +0000401 for (i = 0; i < maxboardlen - strlen(b->name); i++)
stefancte94ab342011-06-25 17:36:25 +0000402 msg_ginfo(" ");
Edward O'Callaghane121af72019-11-14 22:34:07 +1100403
404 switch (b->working) {
405 case OK: msg_ginfo("OK "); break;
406 case NT: msg_ginfo("NT "); break;
407 case DEP: msg_ginfo("DEP "); break;
408 case NA: msg_ginfo("N/A "); break;
409 case BAD:
410 default: msg_ginfo("BAD "); break;
411 }
uwef35eeec2010-06-01 10:13:17 +0000412
hailfinger4640bdb2011-08-31 16:19:50 +0000413 for (e = board_matches; e->vendor_name != NULL; e++) {
stefanct6d836ba2011-05-26 01:35:19 +0000414 if (strcmp(e->vendor_name, b->vendor)
415 || strcmp(e->board_name, b->name))
uwef35eeec2010-06-01 10:13:17 +0000416 continue;
stefanct6d836ba2011-05-26 01:35:19 +0000417 if (e->lb_vendor == NULL)
stefancte94ab342011-06-25 17:36:25 +0000418 msg_ginfo("(autodetected)");
uwef35eeec2010-06-01 10:13:17 +0000419 else
Carl-Daniel Hailfingere5ec66e2016-08-03 16:10:19 -0700420 msg_ginfo("%s:%s", e->lb_vendor,
stefanct6d836ba2011-05-26 01:35:19 +0000421 e->lb_part);
uwef35eeec2010-06-01 10:13:17 +0000422 }
stefancte94ab342011-06-25 17:36:25 +0000423 msg_ginfo("\n");
uwef35eeec2010-06-01 10:13:17 +0000424 }
uwe884cc8b2009-06-17 12:07:12 +0000425}
hailfinger80422e22009-12-13 22:28:00 +0000426#endif
uwec0751f42009-10-06 13:00:00 +0000427
Edward O'Callaghana66d68a2019-11-10 02:02:46 +1100428static void print_supported_devs(const struct programmer_entry prog, const char *const type)
429{
430 const struct dev_entry *const devs = prog.devs.dev;
431 msg_ginfo("\nSupported %s devices for the %s programmer:\n", type, prog.name);
432 unsigned int maxvendorlen = strlen("Vendor") + 1;
433 unsigned int maxdevlen = strlen("Device") + 1;
434
435 unsigned int i;
436 for (i = 0; devs[i].vendor_name != NULL; i++) {
437 maxvendorlen = max(maxvendorlen, strlen(devs[i].vendor_name));
438 maxdevlen = max(maxdevlen, strlen(devs[i].device_name));
439 }
440 maxvendorlen++;
441 maxdevlen++;
442
443 msg_ginfo("Vendor");
444 for (i = strlen("Vendor"); i < maxvendorlen; i++)
445 msg_ginfo(" ");
446
447 msg_ginfo("Device");
448 for (i = strlen("Device"); i < maxdevlen; i++)
449 msg_ginfo(" ");
450
451 msg_ginfo(" %s IDs Status\n", type);
452
453 for (i = 0; devs[i].vendor_name != NULL; i++) {
454 msg_ginfo("%s", devs[i].vendor_name);
455 unsigned int j;
456 for (j = strlen(devs[i].vendor_name); j < maxvendorlen; j++)
457 msg_ginfo(" ");
458 msg_ginfo("%s", devs[i].device_name);
459 for (j = strlen(devs[i].device_name); j < maxdevlen; j++)
460 msg_ginfo(" ");
461
462 msg_pinfo(" %04x:%04x %s\n", devs[i].vendor_id, devs[i].device_id,
463 test_state_to_text(devs[i].status));
464 }
465}
466
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100467int print_supported(void)
hailfingera50d60e2009-11-17 09:57:34 +0000468{
Edward O'Callaghana66d68a2019-11-10 02:02:46 +1100469 unsigned int i;
Edward O'Callaghan723c12c2020-08-01 22:42:00 +1000470 if (print_supported_chips())
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100471 return 1;
hailfingerf79d1712010-10-06 23:48:34 +0000472
stefancte94ab342011-06-25 17:36:25 +0000473 msg_ginfo("\nSupported programmers:\n");
hailfingerf79d1712010-10-06 23:48:34 +0000474 list_programmers_linebreak(0, 80, 0);
Edward O'Callaghane121af72019-11-14 22:34:07 +1100475 msg_ginfo("\n");
hailfinger90c7d542010-05-31 15:27:27 +0000476#if CONFIG_INTERNAL == 1
stefancte94ab342011-06-25 17:36:25 +0000477 msg_ginfo("\nSupported devices for the %s programmer:\n\n",
hailfingerf79d1712010-10-06 23:48:34 +0000478 programmer_table[PROGRAMMER_INTERNAL].name);
479 print_supported_chipsets();
stefancte94ab342011-06-25 17:36:25 +0000480 msg_ginfo("\n");
Edward O'Callaghan95f1e532020-04-23 14:02:25 +1000481 print_supported_boards_helper(boards_known, "mainboards");
stefancte94ab342011-06-25 17:36:25 +0000482 msg_ginfo("\n");
Edward O'Callaghana66d68a2019-11-10 02:02:46 +1100483 print_supported_boards_helper(laptops_known, "mobile devices");
hailfinger80422e22009-12-13 22:28:00 +0000484#endif
Edward O'Callaghana66d68a2019-11-10 02:02:46 +1100485 for (i = 0; i < PROGRAMMER_INVALID; i++) {
486 const struct programmer_entry prog = programmer_table[i];
487 switch (prog.type) {
488 case USB:
489 print_supported_devs(prog, "USB");
490 break;
491 case PCI:
492 print_supported_devs(prog, "PCI");
493 break;
494 case OTHER:
495 if (prog.devs.note != NULL) {
496 msg_ginfo("\nSupported devices for the %s programmer:\n", prog.name);
497 msg_ginfo("%s", prog.devs.note);
498 }
499 break;
500 default:
501 msg_gerr("\n%s: %s: Uninitialized programmer type! Please report a bug at "
502 "flashrom@flashrom.org\n", __func__, prog.name);
503 break;
504 }
505 }
Edward O'Callaghanab4993a2019-11-09 21:36:17 +1100506 return 0;
hailfingera50d60e2009-11-17 09:57:34 +0000507}
508
hailfinger90c7d542010-05-31 15:27:27 +0000509#if CONFIG_INTERNAL == 1
hailfingera635fff2010-06-07 11:10:43 +0000510
511#ifdef CONFIG_PRINT_WIKI
512#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
513#else
514#define B(vendor, name, status, url, note) { vendor, name, status }
515#endif
516
uwec0751f42009-10-06 13:00:00 +0000517/* Please keep this list alphabetically ordered by vendor/board. */
uwef35eeec2010-06-01 10:13:17 +0000518const struct board_info boards_known[] = {
hailfinger324a9cc2010-05-26 01:45:41 +0000519#if defined(__i386__) || defined(__x86_64__)
Edward O'Callaghanb30f7622019-11-11 14:27:26 +1100520 B("A-Trend", "ATC-6220", OK, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
521 B("abit", "A-S78H", OK, NULL, NULL),
522 B("abit", "AN-M2", OK, NULL, NULL),
523 B("abit", "AV8", OK, NULL, NULL),
524 B("abit", "AX8", OK, NULL, NULL),
525 B("abit", "BF6", OK, NULL, NULL),
526 B("abit", "BM6", OK, NULL, NULL),
527 B("abit", "BX6 2.0", OK, NULL, NULL),
528 B("abit", "Fatal1ty F-I90HD", OK, NULL, NULL),
529 B("abit", "IC7", OK, NULL, NULL),
530 B("abit", "IP35", OK, NULL, NULL),
531 B("abit", "IP35 Pro", OK, NULL, NULL),
532 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."),
533 B("abit", "KN8 Ultra", OK, NULL, NULL),
534 B("abit", "KN9 Ultra", OK, NULL, NULL),
535 B("abit", "NF-M2 nView", OK, NULL, NULL),
536 B("abit", "NF-M2S", OK, NULL, NULL),
537 B("abit", "NF7-S", OK, NULL, NULL),
538 B("abit", "VA6", OK, NULL, NULL),
539 B("abit", "VT6X4", OK, NULL, NULL),
540 B("Acer", "V75-M", OK, NULL, "This is an OEM board used by IBM in e.g. Aptiva 2170-G"),
541 B("Acer", "EM61SM/EM61PM", OK, NULL, "Used in Acer Aspire T180 and E380. Seems to be an OEM variant of abit's NF-M2S."),
542 B("Acorp", "6A815EPD", OK, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
543 B("Acorp", "6M810C", OK, NULL, NULL),
544 B("ADLINK", "Express-HR", OK, "http://www.adlinktech.com/PD/web/PD_detail.php?pid=1012", NULL),
545 B("Advantech", "PCM-5820", OK, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
546 B("agami", "Aruma", OK, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
547 B("Albatron", "PM266A Pro", OK, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
548 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."),
549 B("AOpen", "i945GMx-VFX", OK, NULL, "This is (also?) an OEM board from FSC (used in e.g. ESPRIMO Q5010 with designation D2544-B1)."),
550 B("AOpen", "UK79G-1394", OK, "http://global.aopen.com/products_detail.aspx?auno=9", "Used in EZ18 barebones"),
551 B("AOpen", "vKM400Am-S", OK, "http://global.aopen.com/products_detail.aspx?Auno=824", NULL),
552 B("Artec Group","DBE61", OK, "http://wiki.thincan.org/DBE61", NULL),
553 B("Artec Group","DBE62", OK, "http://wiki.thincan.org/DBE62", NULL),
554 B("ASI", "MB-5BLMP", OK, "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III thin client."),
555 B("ASRock", "4CoreDual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=4CoreDual-VSTA", "W39V040FB"),
556 B("ASRock", "775Dual-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=775Dual-VSTA", NULL),
557 B("ASRock", "775i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
558 B("ASRock", "880G Pro3", OK, "http://www.asrock.com/mb/overview.asp?Model=880G%20Pro3", NULL),
559 B("ASRock", "890GX Extreme3", OK, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
560 B("ASRock", "939A785GMH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
561 B("ASRock", "960GM-GS3 FX", OK, "http://www.asrock.com/mb/overview.asp?Model=960GM-GS3%20FX", NULL),
562 B("ASRock", "A330GC", OK, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
563 B("ASRock", "A770CrossFire", OK, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
564 B("ASRock", "A780FullHD", OK, "http://www.asrock.com/mb/overview.asp?Model=A780FullHD", "While flashrom is working correctly, there might be problems with the firmware images themselves. Please see https://flashrom.org/pipermail/flashrom/2012-July/009600.html for details."),
565 B("ASRock", "ALiveNF6G-DVI", OK, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
566 B("ASRock", "AM2NF6G-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
567 B("ASRock", "AMCP7AION-HT", OK, "http://www.asrock.com/nettop/NVIDIA/ION%20330HT/", "Used in ION 330HT(-BD) barebones."),
568 B("ASRock", "ConRoeXFire-eSATA2", OK, "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2", NULL),
569 B("ASRock", "E350M1/USB3", OK, "http://www.asrock.com/mb/overview.asp?model=e350m1/usb3", "Vendor firmware writes to flash at shutdown. This probably corrupts the flash in case you write coreboot while running the vendor firmware. Simply updating the vendor firmware should be fine."),
570 B("ASRock", "Fatal1ty 970 Performance", OK, "http://www.asrock.com/mb/overview.asp?Model=Fatal1ty%20970%20Performance", "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
571 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."),
572 B("ASRock", "G31M-GS", OK, "http://www.asrock.com/mb/overview.asp?Model=G31M-GS", NULL),
573 B("ASRock", "G31M-S rev 2.0", OK, "http://www.asrock.com/mb/overview.asp?model=G31M-S", NULL),
574 B("ASRock", "G41M-VS3", OK, "http://www.asrock.com/mb/overview.asp?Model=G41M-VS3", NULL),
575 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."),
576 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."),
577 B("ASRock", "IMB-180-H", OK, "http://www.asrock.com/ipc/overview.asp?Model=IMB-A180-H", NULL),
578 B("ASRock", "K7S41", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
579 B("ASRock", "K7S41GX", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
580 B("ASRock", "K7VT4A+", BAD, "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip found, probably due to flash translation. https://flashrom.org/pipermail/flashrom/2009-August/000393.html"),
581 B("ASRock", "K8S8X", OK, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
582 B("ASRock", "M3A790GXH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
583 B("ASRock", "N61P-S", OK, "http://www.asrock.com/mb/overview.asp?Model=N61P-S", NULL),
584 B("ASRock", "N68C-S UCC", OK, "http://www.asrock.com/mb/overview.asp?Model=N68C-S%20UCC", NULL),
585 B("ASRock", "P4i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65G", NULL),
586 B("ASRock", "P4i65GV", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
587 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."),
588 B("ASUS", "A7N8X Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
589 B("ASUS", "A7N8X-E Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
590 B("ASUS", "A7N8X-VM/400", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
591 B("ASUS", "A7V133", OK, NULL, NULL),
592 B("ASUS", "A7V333", OK, NULL, NULL),
593 B("ASUS", "A7V400-MX", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
594 B("ASUS", "A7V600-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
595 B("ASUS", "A7V8X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
596 B("ASUS", "A7V8X-MX", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
597 B("ASUS", "A7V8X-MX SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
598 B("ASUS", "A7V8X-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
599 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."),
600 B("ASUS", "A8N-E", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
601 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."),
602 B("ASUS", "A8N-SLI", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
603 B("ASUS", "A8N-SLI Deluxe", NT, NULL, "Should work out of the box since r1593."),
604 B("ASUS", "A8N-SLI Premium", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/", NULL),
605 B("ASUS", "A8N-VM", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
606 B("ASUS", "A8N-VM CSM", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
607 B("ASUS", "A8NE-FM/S", OK, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
608 B("ASUS", "A8V Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
609 B("ASUS", "A8V-E Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
610 B("ASUS", "A8V-E SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
611 B("ASUS", "C60M1-I", OK, "https://www.asus.com/Motherboards/C60M1I/", "The MAC address of the onboard network card is stored in flash."),
612 B("ASUS", "Crosshair II Formula", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/", NULL),
613 B("ASUS", "Crosshair IV Extreme", OK, "https://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/", NULL),
614 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."),
615 B("ASUS", "DSAN-DX", NT, "https://www.asus.com/Server_Workstation/Server_Motherboards/DSANDX/", NULL),
616 B("ASUS", "E35M1-I DELUXE", OK, "https://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/", NULL),
617 B("ASUS", "F1A75-V PRO", OK, "https://www.asus.com/Motherboard/F1A75V_PRO/", NULL),
618 B("ASUS", "F2A85-M", DEP, "https://www.asus.com/Motherboards/F2A85M/", "UEFI builds v6404 and above disable access to some parts of the flash, cf. http://www.coreboot.org/ASUS_F2A85-M#UEFI_builds_that_allow_flash_chip_access"),
619 B("ASUS", "K8N", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
620 B("ASUS", "K8V", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
621 B("ASUS", "K8V SE Deluxe", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/", NULL),
622 B("ASUS", "K8V-X", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
623 B("ASUS", "K8V-X SE", OK, "https://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
624 B("ASUS", "KFSN4-DRE/SAS", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/", NULL),
625 B("ASUS", "M2A-MX", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
626 B("ASUS", "M2A-VM (HDMI)", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
627 B("ASUS", "M2N32-SLI Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/", NULL),
628 B("ASUS", "M2N68-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M2N68VM/", NULL),
629 B("ASUS", "M2NBP-VM CSM", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
630 B("ASUS", "M2N-E", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NE/", "If the machine doesn't come up again after flashing, try resetting the NVRAM(CMOS). The MAC address of the onboard network card will change to the value stored in the new image, so backup the old address first. See https://flashrom.org/pipermail/flashrom/2009-November/000879.html"),
631 B("ASUS", "M2N-E SLI", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
632 B("ASUS", "M2N-MX SE Plus", OK, "https://www.asus.com/Motherboards/M2NMX_SE_Plus/", NULL),
633 B("ASUS", "M2NPV-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
634 B("ASUS", "M2N-SLI Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
635 B("ASUS", "M2V", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
636 B("ASUS", "M2V-MX", OK, "https://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
637 B("ASUS", "M3A", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
638 B("ASUS", "M3A76-CM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
639 B("ASUS", "M3A78-EH", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EH/", NULL),
640 B("ASUS", "M3A78-EM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
641 B("ASUS", "M3N78 PRO", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3N78_PRO/", NULL),
642 B("ASUS", "M3N78-VM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
643 B("ASUS", "M3N-H/HDMI", OK, "https://www.asus.com/Motherboards/M3NHHDMI//", NULL),
644 B("ASUS", "M4A785TD-M EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
645 B("ASUS", "M4A785TD-V EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
646 B("ASUS", "M4A785T-M", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A785TM/", NULL),
647 B("ASUS", "M4A78-EM", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
648 B("ASUS", "M4A78LT-M LE", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
649 B("ASUS", "M4A79T Deluxe", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
650 B("ASUS", "M4A87TD/USB3", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
651 B("ASUS", "M4A89GTD PRO", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
652 B("ASUS", "M4N68T V2", OK, "https://www.asus.com/Motherboards/AMD_AM3/M4N68T_V2/", NULL),
653 B("ASUS", "M4N78 PRO", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
654 B("ASUS", "M4N78 SE", OK, "https://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_SE/", NULL),
655 B("ASUS", "M5A78L-M LX", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/M5A78LM_LX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see https://flashrom.org/pipermail/flashrom/2012-May/009200.html"),
656 B("ASUS", "M5A97 (rev. 1.0)", OK, "https://www.asus.com/Motherboard/M5A97/", NULL),
657 B("ASUS", "M5A99X EVO", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
658 B("ASUS", "Maximus IV Extreme", BAD, "https://www.asus.com/Motherboards/Intel_Socket_1155/Maximus_IV_Extreme/", "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
659 B("ASUS", "MEW-AM", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
660 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."),
661 B("ASUS", "OPLX-M", NT, NULL, "Untested board enable."),
662 B("ASUS", "P2B", OK, NULL, NULL),
663 B("ASUS", "P2B-D", OK, NULL, NULL),
664 B("ASUS", "P2B-DS", OK, NULL, NULL),
665 B("ASUS", "P2B-F", OK, NULL, NULL),
666 B("ASUS", "P2B-LS", OK, NULL, NULL),
667 B("ASUS", "P2B-N", OK, NULL, NULL),
668 B("ASUS", "P2E-M", OK, NULL, NULL),
669 B("ASUS", "P2L97-S", OK, NULL, NULL),
Edward O'Callaghan80f8e572020-08-02 00:16:54 +1000670 B("ASUS", "P3B-F", OK, NULL, "Owned by Uwe Hermann <uwe@hermann-uwe.de>."),
Edward O'Callaghanb30f7622019-11-11 14:27:26 +1100671 B("ASUS", "P4B266", OK, NULL, NULL),
672 B("ASUS", "P4B266-LM", OK, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
673 B("ASUS", "P4B533-E", OK, NULL, NULL),
674 B("ASUS", "P4C800-E Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/", NULL),
675 B("ASUS", "P4GV-LA (Guppy)", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478", NULL),
676 B("ASUS", "P4P800", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
677 B("ASUS", "P4P800-E Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/", NULL),
678 B("ASUS", "P4P800-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
679 B("ASUS", "P4P800-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4P800X/", NULL),
Edward O'Callaghan95f1e532020-04-23 14:02:25 +1000680 B("ASUS", "P4P800SE", OK, "https://www.asus.com/supportonly/P4P800 SE/", NULL),
Edward O'Callaghanb30f7622019-11-11 14:27:26 +1100681 B("ASUS", "P4PE-X/TE", NT, "https://www.asus.com/999/html/events/mb/socket478/p4pe-x-te/overview.htm", NULL),
682 B("ASUS", "P4S533-X", OK, NULL, NULL),
683 B("ASUS", "P4S800-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
684 B("ASUS", "P4SC-E", OK, NULL, "Part of ASUS Terminator P4 533 barebone system"),
685 B("ASUS", "P4SD-LA", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
686 B("ASUS", "P5A", OK, NULL, NULL),
687 B("ASUS", "P5B", OK, NULL, NULL),
688 B("ASUS", "P5B-Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/", NULL),
689 B("ASUS", "P5B-VM", OK, NULL, NULL),
690 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."),
691 B("ASUS", "P5BV-R", OK, "https://www.asus.com/Server_Workstation/Servers/RS120E5PA2/", "Used in RS120-E5/PA2 servers."),
692 B("ASUS", "P5GC-MX/1333", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/", NULL),
693 B("ASUS", "P5GD1 Pro", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
694 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."),
695 B("ASUS", "P5GD1(-VM)", NT, NULL, "Untested board enable."),
696 B("ASUS", "P5GD2 Premium", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/", NULL),
697 B("ASUS", "P5GD2-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GD2X/", NULL),
698 B("ASUS", "P5GDC Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/", NULL),
699 B("ASUS", "P5GDC-V Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/", NULL),
700 B("ASUS", "P5GD2/C variants", NT, NULL, "Untested board enable."),
701 B("ASUS", "P5K SE", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5K_SE/", NULL),
702 B("ASUS", "P5K-V", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
703 B("ASUS", "P5K-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
704 B("ASUS", "P5KC", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
705 B("ASUS", "P5KPL-AM IN/GB", OK, "http://support.asus.com/download.aspx?SLanguage=en&m=P5KPL-AM+IN%2fGB&os=29", NULL),
706 B("ASUS", "P5KPL-CM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
707 B("ASUS", "P5KPL-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5KPLVM/", "Found in V3-P5G31."),
708 B("ASUS", "P5L-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
709 B("ASUS", "P5L-VM 1394", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/", NULL),
710 B("ASUS", "P5LD2", OK, NULL, NULL),
711 B("ASUS", "P5LD2-MQ", OK, "http://support.asus.com/download.aspx?SLanguage=en&p=8&s=12&m=Vintage-PH2&os=&hashedid=n/a", "Found in ASUS Vintage-PH2 barebones."),
712 B("ASUS", "P5LD2-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM/", NULL),
713 B("ASUS", "P5LD2-VM DH", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM_DH/", NULL),
714 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."),
715 B("ASUS", "P5LP-LE (Epson OEM)", OK, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
716 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."),
717 B("ASUS", "P5N-D", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
718 B("ASUS", "P5N-E SLI", NT, "https://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Untested board enable."),
719 B("ASUS", "P5N32-E SLI", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/", NULL),
720 B("ASUS", "P5N7A-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
721 B("ASUS", "P5ND2-SLI Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/", NULL),
722 B("ASUS", "P5PE-VM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
723 B("ASUS", "P5QPL-AM", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
724 B("ASUS", "P5VD1-X", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
725 B("ASUS", "P5VD2-MX", OK, "https://www.asus.com/Motherboards/Intel_Socket_775/P5VD2MX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see https://flashrom.org/pipermail/flashrom/2012-March/009014.html"),
726 B("ASUS", "P6T SE", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
727 B("ASUS", "P6T Deluxe", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/", NULL),
728 B("ASUS", "P6T Deluxe V2", OK, "https://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/", NULL),
729 B("ASUS", "P7H57D-V EVO", OK, "https://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
730 B("ASUS", "P7H55-M LX", BAD, NULL, "flashrom works correctly, but GbE LAN is nonworking (probably due to a missing/bogus MAC address; see https://flashrom.org/pipermail/flashrom/2011-July/007432.html and http://ubuntuforums.org/showthread.php?t=1534389 for a possible workaround)"),
731 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."),
732 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."),
733 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."),
734 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."),
735 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."),
736 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
737 B("ASUS", "P8H77-I", OK, "https://www.asus.com/Motherboards/P8H77I/", NULL),
738 B("ASUS", "P8H77-M", OK, "https://www.asus.com/Motherboards/P8H77M/", NULL),
739 B("ASUS", "P8H77-V LE", OK, "https://www.asus.com/Motherboards/P8H77V_LE/", NULL),
740 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."),
741 B("ASUS", "P8P67 LE (B2)", OK, NULL, NULL),
742 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."),
743 B("ASUS", "P8P67 PRO (rev. 3.0)", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8P67_PRO/", NULL),
744 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."),
745 B("ASUS", "P8Z68-V", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
746 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."),
747 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."),
748 B("ASUS", "P8Z68-V PRO/GEN3", OK, "https://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V_PROGEN3/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
749 B("ASUS", "RAMPAGE III GENE", OK, "https://www.asus.com/Motherboards/RAMPAGE_III_GENE/", "The MAC address of the onboard network card is stored in flash."),
750 B("ASUS", "SABERTOOTH 990FX", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX/", NULL),
751 B("ASUS", "SABERTOOTH 990FX R2.0", OK, "https://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX_R20/", NULL),
752 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."),
753 B("ASUS", "Z8NA-D6C", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/", NULL),
754 B("ASUS", "Z8PE-D12", OK, "https://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/", NULL),
755 B("Attro", "G5G100-P", OK, "http://www.attro.com/motherboard/G5G100-P.htm", NULL),
756 B("Bachmann", "OT200", OK, "http://www.bachmann.info/produkte/bedien-und-beobachtungsgeraete/operator-terminals/", NULL),
757 B("BCOM", "WinNET100", OK, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
758 B("Bifferos", "Bifferboard", OK, "http://bifferos.co.uk/", NULL),
759 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."),
760 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."),
761 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."),
762 B("Biostar", "M7NCD Pro", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=260", NULL),
763 B("Biostar", "M7VIQ", NT, NULL, NULL),
764 B("Biostar", "N61PB-M2S", OK, NULL, NULL),
765 B("Biostar", "N68S3+", OK, NULL, NULL),
766 B("Biostar", "P4M80-M4", OK, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
767 B("Biostar", "TA780G M2+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=344", NULL),
768 B("Biostar", "TA790GX A3+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=395", NULL),
769 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."),
770 B("Congatec", "conga-X852", OK, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
771 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."),
772 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."),
773 B("Dell", "OptiPlex GX1", OK, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
774 B("Dell", "PowerEdge 1850", OK, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
775 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)."),
776 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."),
777 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"),
778 B("DFI", "AD77", NT, NULL, "Untested board enable."),
779 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),
780 B("Elitegroup", "848P-A7", OK, NULL, NULL),
781 B("Elitegroup", "GeForce6100PM-M2 (V3.0)", OK, NULL, NULL),
782 B("Elitegroup", "GeForce6100SM-M", OK, NULL, NULL),
783 B("Elitegroup", "GeForce7050M-M (V2.0)", OK, "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=865&MenuID=20&LanID=0", NULL),
784 B("Elitegroup", "GF7050VT-M", OK, NULL, NULL),
785 B("Elitegroup", "GF7100PVT-M3 (V1.0)", OK, NULL, NULL),
786 B("Elitegroup", "GF8200A", OK, NULL, NULL),
787 B("Elitegroup", "K7S5A", OK, NULL, NULL),
788 B("Elitegroup", "K7S6A", OK, NULL, NULL),
789 B("Elitegroup", "K7SEM (V1.0A)", OK, NULL, NULL),
790 B("Elitegroup", "K7VTA3", OK, NULL, NULL),
791 B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)", OK, NULL, NULL),
792 B("Elitegroup", "P4VXMS (V1.0A)", OK, NULL, NULL),
793 B("Elitegroup", "P6BAP-A+ (V2.2)", OK, NULL, NULL),
794 B("Elitegroup", "P6IWP-Fe", OK, NULL, NULL),
795 B("Elitegroup", "P6VAP-A+", OK, NULL, NULL),
796 B("Elitegroup", "RS485M-M", OK, NULL, NULL),
797 B("Emerson", "ATCA-7360", OK, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
798 B("EPoX", "EP-3PTA", BAD, NULL, "Missing board enable (W83627HF/F/HG/G), see https://flashrom.org/pipermail/flashrom/2012-April/009043.html"),
799 B("EPoX", "EP-8K5A2", OK, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
800 B("EPoX", "EP-8NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
801 B("EPoX", "EP-8RDA3+", OK, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
802 B("EPoX", "EP-9NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
803 B("EPoX", "EP-BX3", OK, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
804 B("EVGA", "122-CK-NF68", OK, NULL, NULL),
805 B("EVGA", "132-CK-NF78", OK, "http://www.evga.com/articles/385.asp", NULL),
806 B("EVGA", "270-WS-W555-A2 (Classified SR-2)", OK, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
807 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."),
808 B("Foxconn", "6150K8MD-8EKRSH", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000157", NULL),
809 B("Foxconn", "A6VMX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000346", NULL),
810 B("Foxconn", "P4M800P7MA-RS2", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000138", NULL),
811 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."),
812 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."),
813 B("Freetech", "P6F91i", OK, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
814 B("Fujitsu", "D2724-A1x", OK, NULL, "Used in ESPRIMO E5625."),
815 B("Fujitsu", "D3041-A1x", OK, NULL, "Used in ESPRIMO P2560, contains an Atmel AT26DF081A."),
816 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."),
817 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."),
818 B("GIGABYTE", "GA-2761GXDK", OK, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
819 B("GIGABYTE", "GA-6BXC", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
820 B("GIGABYTE", "GA-6BXDU", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
821 B("GIGABYTE", "GA-6IEM", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
822 B("GIGABYTE", "GA-6VXE7+", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
823 B("GIGABYTE", "GA-6ZMA", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
824 B("GIGABYTE", "GA-770TA-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
825 B("GIGABYTE", "GA-7DXR", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
826 B("GIGABYTE", "GA-7VT600", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
827 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."),
828 B("GIGABYTE", "GA-880GMA-USB3 (rev. 3.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
829 B("GIGABYTE", "GA-8I945GZME-RH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
830 B("GIGABYTE", "GA-8IP775", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
831 B("GIGABYTE", "GA-8IRML", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
832 B("GIGABYTE", "GA-8PE667 Ultra 2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
833 B("GIGABYTE", "GA-8S648", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1674", NULL),
834 B("GIGABYTE", "GA-8SIMLFS 2.0", OK, NULL, "This is an OEM board used by Fujitsu."),
835 B("GIGABYTE", "GA-8SIMLH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
836 B("GIGABYTE", "GA-945GCM-S2 (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2466", NULL),
837 B("GIGABYTE", "GA-945GM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2331", NULL),
838 B("GIGABYTE", "GA-945PL-S3P (rev. 6.6)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
839 B("GIGABYTE", "GA-965GM-S2 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
840 B("GIGABYTE", "GA-965P-DS4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
841 B("GIGABYTE", "GA-965P-S3 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2321", NULL),
842 B("GIGABYTE", "GA-970A-D3P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4642", NULL),
843 B("GIGABYTE", "GA-970A-UD3P (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=5194", "Primary flash chip is a Macronix MX25L3206E."),
844 B("GIGABYTE", "GA-990FXA-UD3 (rev. 4.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4672", NULL),
845 B("GIGABYTE", "GA-A75M-UD2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3928", NULL),
846 B("GIGABYTE", "GA-B85M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4567", NULL),
847 B("GIGABYTE", "GA-EG43M-S2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2878", NULL),
848 B("GIGABYTE", "GA-EP31-DS3L (rev. 1.0, 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
849 B("GIGABYTE", "GA-EP35-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
850 B("GIGABYTE", "GA-EX58-UD4P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
851 B("GIGABYTE", "GA-G33M-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2557", NULL),
852 B("GIGABYTE", "GA-G33M-S2L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2692", NULL),
853 B("GIGABYTE", "GA-G41MT-S2PT", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3960", NULL),
854 B("GIGABYTE", "GA-H55M-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3509", "8 MB (ME) + 1 MB (BIOS) flash chips - hardware sequencing required."),
855 B("GIGABYTE", "GA-H61M-D2-B3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3773", NULL),
856 B("GIGABYTE", "GA-H61M-D2H-USB3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4004", NULL),
857 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."),
858 B("GIGABYTE", "GA-H77-DS3H (rev. 1.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4318", NULL),
859 B("GIGABYTE", "GA-H77M-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4388", NULL),
860 B("GIGABYTE", "GA-J1900N-D3V", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4918", NULL),
861 B("GIGABYTE", "GA-K8N51GMF-9", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
862 B("GIGABYTE", "GA-K8N51GMF", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
863 B("GIGABYTE", "GA-K8N-SLI", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
864 B("GIGABYTE", "GA-K8NS", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1784", NULL),
865 B("GIGABYTE", "GA-M56S-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2607", NULL),
866 B("GIGABYTE", "GA-M57SLI-S4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
867 B("GIGABYTE", "GA-M61P-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
868 B("GIGABYTE", "GA-M720-US3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
869 B("GIGABYTE", "GA-MA69VM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
870 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
871 B("GIGABYTE", "GA-MA770-UD3 (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
872 B("GIGABYTE", "GA-MA770T-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
873 B("GIGABYTE", "GA-MA780G-UD3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
874 B("GIGABYTE", "GA-MA785GMT-UD2H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
875 B("GIGABYTE", "GA-MA78G-DS3H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
876 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? */
877 B("GIGABYTE", "GA-MA78GPM-DS2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
878 B("GIGABYTE", "GA-MA790FX-DQ6", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
879 B("GIGABYTE", "GA-MA790GP-DS4H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
880 B("GIGABYTE", "GA-MA790XT-UD4P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
881 B("GIGABYTE", "GA-P31-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2615", NULL),
882 B("GIGABYTE", "GA-P31-S3G", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2676", NULL),
883 B("GIGABYTE", "GA-P55-USB3 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3440", NULL),
884 B("GIGABYTE", "GA-P55A-UD4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
885 B("GIGABYTE", "GA-P55A-UD7" , OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3324", NULL),
886 B("GIGABYTE", "GA-P67A-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
887 B("GIGABYTE", "GA-X58A-UD3R (rev. 2.0)", OK, NULL, NULL),
888 B("GIGABYTE", "GA-X58A-UD7 (rev. 2.0)", OK, NULL, NULL),
889 B("GIGABYTE", "GA-X79-UD5", OK, NULL, NULL),
890 B("GIGABYTE", "GA-X79-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4050", "Contains a Macronix MX25L6406E."),
891 B("GIGABYTE", "GA-X79-UP4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4288", NULL),
892 B("GIGABYTE", "GA-Z68MA-D2H-B3 (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3975", NULL),
893 B("GIGABYTE", "GA-Z68MX-UD2H-B (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
894 B("GIGABYTE", "GA-Z68XP-UD3 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3892", NULL),
895 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)."),
896 B("GIGABYTE", "GA-Z87-HD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4489", NULL),
897 B("HP", "8100 Elite CMT PC (304Bh)", BAD, NULL, "SPI lock down, PR, read-only descriptor, locked ME region."),
898 B("HP", "e-Vectra P2706T", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454", NULL),
899 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."),
900 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),
901 B("HP", "ProLiant DL165 G6", OK, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
902 B("HP", "ProLiant N40L", OK, NULL, NULL),
903 B("HP", "Puffer2-UL8E", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
904 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."),
905 B("HP", "Vectra VL400", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
906 B("HP", "Vectra VL420 SFF", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
907 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"),
908 B("HP", "xw6400", BAD, NULL, "No chip found, see https://flashrom.org/pipermail/flashrom/2012-March/009006.html"),
909 B("HP", "xw9300", BAD, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodTypeId=12454&prodSeriesId=459226", "Missing board enable, see https://flashrom.org/pipermail/flashrom/2012-March/008885.html"),
910 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."),
911 B("HP", "Z400 Workstation (0AE4h)", BAD, NULL, "ICH10R with BIOS lock enable and a protected range PRBAD, see https://flashrom.org/pipermail/flashrom/2012-June/009350.html"),
912 B("IBASE", "MB899", OK, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
913 B("IBM", "x3455", OK, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
914 B("IEI", "PICOe-9452", OK, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
915 B("Intel", "D201GLY", OK, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
916 B("Intel", "D2700MUD", BAD, "http://www.intel.com/cd/products/services/emea/eng/motherboards/desktop/D2700MUD/", "SMM protection enabled"),
917 B("Intel", "D425KT", BAD, "http://www.intel.com/content/www/us/en/motherboards/desktop-motherboards/desktop-board-d425kt.html", "NM10 with SPI lock down, BIOS lock, see https://flashrom.org/pipermail/flashrom/2012-January/008600.html"),
918 B("Intel", "D865GLC", BAD, NULL, "ICH5 with BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
919 B("Intel", "D945GCNL", OK, NULL, NULL),
920 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."),
921 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)."),
922 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)."),
923 B("Intel", "DH61AG ", BAD, NULL, "H61 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2012-June/009417.html"),
924 B("Intel", "DH67CF", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2011-September/007789.html"),
925 B("Intel", "DH67CL", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see https://flashrom.org/pipermail/flashrom/2012-November/010112.html"),
926 B("Intel", "DN2800MT (Marshalltown)", BAD, NULL, "BIOS locked via BIOS_CNTL."),
927 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."),
928 B("Intel", "DQ77MK", BAD, NULL, "Q77 with BIOS lock enable and locked ME region, see http://paste.flashrom.org/view.php?id=1603"),
929 B("Intel", "EP80759", OK, NULL, NULL),
930 B("Intel", "Foxhollow", OK, NULL, "Intel reference board."),
931 B("Intel", "Greencity", OK, NULL, "Intel reference board."),
932 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"),
933 B("IWILL", "DK8-HTX", OK, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
934 B("Jetway", "J-7BXAN", OK, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
935 B("Jetway", "J7F4K1G5D-PB", OK, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
936 B("Kontron", "986LCD-M", OK, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
937 B("Lanner", "EM-8510C", OK, NULL, NULL),
938 B("Lenovo", "Tilapia CRB", OK, NULL, "Used in ThinkCentre M75e."),
939 B("Lex", "CV700A", OK, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
940 B("Mitac", "6513WU", OK, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
941 B("MSC", "Q7-TCTC", OK, "http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html", NULL),
942 B("MSI", "MS-6153", OK, "http://www.msi.com/product/mb/MS-6153.html", NULL),
943 B("MSI", "MS-6156", OK, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
944 B("MSI", "MS-6163 (MS-6163 Pro)",OK, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
945 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>."),
946 B("MSI", "MS-6330 (K7T Turbo)", OK, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
947 B("MSI", "MS-6391 (845 Pro4)", OK, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
948 B("MSI", "MS-6561 (745 Ultra)", OK, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
949 B("MSI", "MS-6566 (845 Ultra-C)",OK, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
950 B("MSI", "MS-6570 (K7N2)", OK, "http://www.msi.com/product/mb/K7N2.html", NULL),
951 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."),
952 B("MSI", "MS-6590 (KT4 Ultra)", OK, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
953 //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.
954 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."),
955 B("MSI", "MS-6712 (KT4V)", OK, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
956 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", OK, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
957 B("MSI", "MS-7005 (651M-L)", OK, "http://www.msi.com/product/mb/651M-L.html", NULL),
958 B("MSI", "MS-7025 (K8N Neo2 Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
959 B("MSI", "MS-7030 (K8N Neo Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo-Platinum.html", NULL),
960 B("MSI", "MS-7046", OK, "http://www.heimir.de/ms7046/", NULL),
961 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", OK, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
962 B("MSI", "MS-7065", OK, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
963 B("MSI", "MS-7094 (K8T Neo2-F V2.0)",OK, "http://www.msi.com/product/mb/K8T_Neo2F_V2.0.html", NULL),
964 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),
965 B("MSI", "MS-7135 (K8N Neo3)", OK, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
966 B("MSI", "MS-7142 (K8MM-V)", OK, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
967 B("MSI", "MS-7168 (Orion)", OK, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
968 B("MSI", "MS-7207 (K8NGM2-L)", OK, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
969 B("MSI", "MS-7211 (PM8M3-V)", OK, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
970 B("MSI", "MS-7236 (945PL Neo3)", OK, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
971 B("MSI", "MS-7250 (K9N SLI (rev 2.1))", OK, "http://www.msi.com/product/mb/K9N--SLI.html", NULL),
972 B("MSI", "MS-7253 (K9VGM-V)", OK, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
973 B("MSI", "MS-7255 (P4M890M)", OK, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
974 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>."),
975 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."),
976 B("MSI", "MS-7309 (K9N6PGM2-V2)", OK, "http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
977 B("MSI", "MS-7312 (K9MM-V)", OK, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
978 B("MSI", "MS-7336", OK, NULL, "Some non-essential DMI data (e.g. serial numbers) is overwritten when using flashrom. This is an OEM board used by HP (e.g. dx2300 Microtower)."),
979 B("MSI", "MS-7345 (P35 Neo2-FIR)", OK, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
980 B("MSI", "MS-7357 (G33M)", OK, "http://www.msi.com/product/mb/G33M.html", NULL),
981 B("MSI", "MS-7368 (K9AG Neo2-Digital)", OK, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
982 B("MSI", "MS-7369 (K9N Neo V2)", OK, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
983 B("MSI", "MS-7376 (K9A2 Platinum V1)", OK, "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
984 B("MSI", "MS-7379 (G31M)", OK, "http://www.msi.com/product/mb/G31M.html", NULL),
985 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."),
986 B("MSI", "MS-7502", OK, NULL, "This is an OEM board used by Medion in e.g. Medion MD8833."),
987 B("MSI", "MS-7522 (MSI X58 Pro-E)", OK, "http://www.msi.com/product/mb/X58_ProE.html", NULL),
988 B("MSI", "MS-7529 (G31M3-L(S) V2)", OK, "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
989 B("MSI", "MS-7529 (G31TM-P21)", OK, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
990 B("MSI", "MS-7548 (Aspen-GL8E)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c01635688&lc=en&cc=us&dlc=en", NULL),
991 B("MSI", "MS-7551 (KA780G)", OK, "http://www.msi.com/product/mb/KA780G.html", NULL),
992 B("MSI", "MS-7596 (785GM-E51)", OK, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
993 B("MSI", "MS-7597 (GF615M-P33)", BAD, NULL, "Missing board enable/SIO support (Fintek F71889), see https://flashrom.org/pipermail/flashrom/2012-March/008956.html"),
994 B("MSI", "MS-7599 (870-C45)", OK, "http://www.msi.com/product/mb/870-C45.html", NULL),
995 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."),
996 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."),
997 B("MSI", "MS-7640 (890FXA-GD70)",OK, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
998 B("MSI", "MS-7642 (890GXM-G65)", OK, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
999 B("MSI", "MS-7676 (H67MA-ED55(B3))", OK, "http://www.msi.com/product/mb/H67MA-ED55--B3-.html", "Seems to work fine basically, but user reported (hopefully unrelated) buggy behavior of the board after a firmware upgrade. See https://flashrom.org/pipermail/flashrom/2012-January/008547.html"),
1000 B("MSI", "MS-7676 (Z68MA-G45 (B3))", OK, "http://www.msi.com/product/mb/Z68MA-G45--B3-.html", NULL),
1001 B("MSI", "MS-7696 (A75MA-G55)", OK, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
1002 B("MSI", "MS-7698 (E350IA-E45)", OK, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
1003 B("MSI", "MS-7740 (H61MA-E35(B3))", OK, "http://www.msi.com/product/mb/H61MA-E35--B3-.html", NULL),
1004 B("MSI", "MS-7756 (H77MA-G43)", OK, "http://www.msi.com/product/mb/H77MA-G43.html", NULL),
1005 B("MSI", "MS-7760 (X79A-GD45 (8D))", OK, "http://www.msi.com/product/mb/X79A-GD45-8D.html", NULL),
1006 B("MSI", "MS-7808 (B75MA-E33)", OK, "http://www.msi.com/product/mb/B75MA-E33.html", NULL),
1007 B("MSI", "MS-7816 (H87-G43)", OK, "http://www.msi.com/product/mb/H87-G43.html", NULL),
1008 B("MSI", "MS-7817 (H81M-E33)", OK, "http://www.msi.com/product/mb/H81ME33.html", NULL),
1009 B("MSI", "MS-9830 (IM-945GSE-A, A9830IMS)", OK, "http://www.msi.com/product/ipc/IM-945GSE-A.html", NULL),
1010 B("NEC", "PowerMate 2000", OK, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
1011 B("Nokia", "IP530", OK, NULL, NULL),
1012 B("Palit", "N61S", OK, NULL, NULL),
1013 B("PCCHIPS ", "M598LMR (V9.0)", OK, NULL, NULL),
1014 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),
1015 B("PC Engines", "Alix.1c", OK, "http://pcengines.ch/alix1c.htm", NULL),
1016 B("PC Engines", "Alix.2c2", OK, "http://pcengines.ch/alix2c2.htm", NULL),
1017 B("PC Engines", "Alix.2c3", OK, "http://pcengines.ch/alix2c3.htm", NULL),
1018 B("PC Engines", "Alix.2d3", OK, "http://pcengines.ch/alix2d3.htm", NULL),
1019 B("PC Engines", "Alix.3c3", OK, "http://pcengines.ch/alix3c3.htm", NULL),
1020 B("PC Engines", "Alix.3d3", OK, "http://pcengines.ch/alix3d3.htm", NULL),
1021 B("PC Engines", "Alix.6f2", OK, "http://pcengines.ch/alix6f2.htm", NULL),
1022 B("PC Engines", "APU", OK, "http://pcengines.ch/apu.htm", NULL),
1023 B("PC Engines", "WRAP.2E", OK, "http://pcengines.ch/wrap2e1.htm", NULL),
1024 B("PCWARE", "APM80-D3", OK, "http://www.pcwarebr.com.br/produtos_mb_apm80-d3.php", "Probably manufactured by ASUS"),
1025 B("Pegatron", "IPP7A-CP", OK, NULL, NULL),
1026 B("Portwell", "PEB-4700VLA", OK, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
1027 B("RCA", "RM4100", OK, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
1028 B("Samsung", "Polaris 32", OK, NULL, NULL),
1029 B("SAPPHIRE", "IPC-E350M1", OK, "http://www.sapphiretech.com/presentation/product/?pid=1034&lid=1", NULL),
1030 B("Shuttle", "AB61", OK, "http://www.shuttle.eu/_archive/older/de/ab61.htm", NULL),
1031 B("Shuttle", "AK31", OK, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
1032 B("Shuttle", "AK38N", OK, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
1033 B("Shuttle", "AV11V30", OK, NULL, NULL),
1034 B("Shuttle", "AV18E2", OK, "http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
1035 B("Shuttle", "FB61", OK, "http://www.shuttle.eu/_archive/older/en/fb61.htm#mainboardfb6", "Used in SB61G2 systems."),
1036 B("Shuttle", "FD37", OK, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
1037 B("Shuttle", "FH67", OK, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
1038 B("Shuttle", "FN25", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
1039 B("Shuttle", "FN78S", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn78sh7/", NULL),
1040 B("Shuttle", "X50/X50(B)", OK, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
1041 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."),
1042 B("Soyo", "SY-6BA+ III", OK, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
1043 B("Soyo", "SY-7VCA", OK, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
1044 B("Sun", "Blade x6250", OK, "http://www.sun.com/servers/blades/x6250/", NULL),
1045 B("Sun", "Fire x4150", BAD, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
1046 B("Sun", "Fire x4200", BAD, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
1047 B("Sun", "Fire x4540", BAD, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
1048 B("Sun", "Fire x4600", BAD, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
1049 B("Sun", "Ultra 40 M2", OK, "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html", NULL),
1050 B("Supermicro", "A1SAi-2550F", OK, "http://www.supermicro.com/products/motherboard/Atom/X10/A1SAi-2550F.cfm", NULL),
1051 B("Supermicro", "H8QC8", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
1052 B("Supermicro", "H8QME-2", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron8000/MCP55/H8QME-2.cfm", NULL),
1053 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."),
1054 B("Supermicro", "X5DP8-G2", OK, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
1055 B("Supermicro", "X7DBT-INF", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
1056 B("Supermicro", "X7DWT", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5400/X7DWT.cfm", "Used in Dell C6100 servers."),
1057 B("Supermicro", "X7SPA-H(F)", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H", NULL),
1058 B("Supermicro", "X7SPE-HF-D525", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPE-HF-D525.cfm", NULL),
1059 B("Supermicro", "X8DT3", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
1060 B("Supermicro", "X8DT6-F", OK, "http://www.supermicro.nl/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=Y", NULL),
1061 B("Supermicro", "X8DTE-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=N", NULL),
1062 B("Supermicro", "X8DTG-D", OK, "http://www.supermicro.com/products/motherboard/qpi/5500/x8dtg-df.cfm", NULL),
1063 B("Supermicro", "X8DTH-6F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
1064 B("Supermicro", "X8DTT-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
1065 B("Supermicro", "X8DTT-HIBQF", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm", NULL),
1066 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."),
1067 B("Supermicro", "X8DTU-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
1068 B("Supermicro", "X8SAX", OK, "http://www.supermicro.com/products/motherboard/xeon3000/x58/x8sax.cfm", NULL),
1069 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)."),
1070 B("Supermicro", "X8SIL-F", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIL.cfm", NULL),
1071 B("Supermicro", "X8STi", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
1072 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."),
1073 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."),
1074 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."),
1075 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."),
1076 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."),
1077 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."),
1078 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."),
1079 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."),
1080 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."),
1081 B("T-Online", "S-100", OK, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
1082 B("Tekram", "P6Pro-A5", OK, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
1083 B("Termtek", "TK-3370 (Rev:2.5B)", OK, NULL, NULL),
1084 B("Thomson", "IP1000", OK, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
1085 B("TriGem", "Anaheim-3", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml", NULL),
1086 B("TriGem", "Lomita", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
1087 B("Tyan", "S1846 (Tsunami ATX)", OK, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
1088 B("Tyan", "S2466 (Tiger MPX)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
1089 B("Tyan", "S2498 (Tomcat K7M)", OK, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
1090 B("Tyan", "S2723 (Tiger i7501)", OK, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
1091 B("Tyan", "S2875 (Tiger K8W)", OK, "http://www.tyan.com/archive/products/html/tigerk8w.html", NULL),
1092 B("Tyan", "S2881 (Thunder K8SR)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
1093 B("Tyan", "S2882-D (Thunder K8SD Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
1094 B("Tyan", "S2882 (Thunder K8S Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
1095 B("Tyan", "S2891 (Thunder K8SRE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
1096 B("Tyan", "S2892 (Thunder K8SE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
1097 B("Tyan", "S2895 (Thunder K8WE)", OK, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
1098 B("Tyan", "S2912 (Thunder n3600R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
1099 B("Tyan", "S2915-E (Thunder n6650W)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
1100 B("Tyan", "S2915 (Thunder n6650W)", OK, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
1101 B("Tyan", "S2933 (Thunder n3600S)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
1102 B("Tyan", "S3095 (Tomcat i945GM)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
1103 B("Tyan", "S3992 (Thunder h2000M)", OK, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
1104 B("Tyan", "S4882 (Thunder K8QS Pro)", OK, "http://www.tyan.com/archive/products/html/thunderk8qspro.html", NULL),
1105 B("Tyan", "S5180 (Toledo i965R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
1106 B("Tyan", "S5191 (Toledo i3000R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
1107 B("Tyan", "S5197 (Toledo i3010W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
1108 B("Tyan", "S5211-1U (Toledo i3200R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
1109 B("Tyan", "S5211 (Toledo i3210W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
1110 B("Tyan", "S5220 (Toledo q35T)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
1111 B("Tyan", "S5375-1U (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
1112 B("Tyan", "S5375 (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
1113 B("Tyan", "S5376 (Tempest i5100W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
1114 B("Tyan", "S5377 (Tempest i5100T)", OK, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
1115 B("Tyan", "S5382 (Tempest i5000PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
1116 B("Tyan", "S5397 (Tempest i5400PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
1117 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."),
1118 B("VIA", "EITX-3000", OK, "http://www.viaembedded.com/en/products/boards/810/1/EITX-3000.html", NULL),
1119 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 */
1120 B("VIA", "EPIA SP", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
1121 B("VIA", "EPIA-CN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
1122 B("VIA", "EPIA EK", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
1123 B("VIA", "EPIA-EX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
1124 B("VIA", "EPIA-LN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
1125 B("VIA", "EPIA-M700", OK, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
1126 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 */
1127 B("VIA", "EPIA-NX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
1128 B("VIA", "NAB74X0", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
1129 B("VIA", "pc2500e", OK, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
1130 B("VIA", "PC3500G", OK, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
1131 B("VIA", "VB700X", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
1132 B("ZOTAC", "Fusion-ITX WiFi (FUSION350-A-E)", OK, NULL, NULL),
1133 B("ZOTAC", "GeForce 8200", OK, NULL, NULL),
1134 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."),
1135 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."),
1136 B("ZOTAC", "IONITX-A-E", OK, NULL, NULL),
1137 B("ZOTAC", "IONITX-F-E", OK, NULL, NULL),
1138 B("ZOTAC", "nForce 630i Supreme (N73U-Supreme)", OK, NULL, NULL),
1139 B("ZOTAC", "ZBOX AD02 (PLUS)", OK, NULL, NULL),
1140 B("ZOTAC", "ZBOX HD-ID11", OK, NULL, NULL),
hailfinger324a9cc2010-05-26 01:45:41 +00001141#endif
uwef35eeec2010-06-01 10:13:17 +00001142
Patrick Georgi8ddfee92017-03-20 14:54:28 +01001143 {0},
uwec0751f42009-10-06 13:00:00 +00001144};
1145
1146/* Please keep this list alphabetically ordered by vendor/board. */
uwef35eeec2010-06-01 10:13:17 +00001147const struct board_info laptops_known[] = {
hailfinger324a9cc2010-05-26 01:45:41 +00001148#if defined(__i386__) || defined(__x86_64__)
Edward O'Callaghanb30f7622019-11-11 14:27:26 +11001149 B("Acer", "Aspire 1520", OK, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
1150 B("Acer", "Aspire One", BAD, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
1151 B("ASUS", "A8Jm", OK, NULL, NULL),
1152 B("ASUS", "Eee PC 701 4G", BAD, "https://www.asus.com/Eee/Eee_PC/Eee_PC_4G/", "It seems the chip (25X40) is behind some SPI flash translation layer (likely in the EC, the ENE KB3310)."),
1153 B("ASUS", "M6Ne", NT, NULL, "Untested board enable."),
1154 B("ASUS", "U38N", OK, NULL, NULL),
1155 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."),
1156 B("Dell", "Latitude D630", OK, NULL, NULL),
1157 B("Dell", "Inspiron 1420", OK, NULL, NULL),
1158 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."),
1159 B("Dell", "Vostro 3700", BAD, NULL, "Locked ME, see https://flashrom.org/pipermail/flashrom/2012-May/009197.html."),
1160 B("Dell", "Latitude E6520", BAD, NULL, "Locked ME, see https://flashrom.org/pipermail/flashrom/2012-June/009420.html."),
1161 B("Elitegroup", "A928", OK, NULL, "Bootsector is locked and needs to be skipped with a layout file (writeable address range is 00000000:0003bfff)."),
1162 B("Fujitsu", "Amilo Xi 3650", OK, NULL, NULL),
1163 B("HP/Compaq", "EliteBook 8560p", BAD, NULL, "SPI lock down, SMM protection, PR in BIOS region, read-only descriptor, locked ME region."),
1164 B("HP/Compaq", "nx9005", BAD, "http://h18000.www1.hp.com/products/quickspecs/11602_na/11602_na.HTML", "Shuts down when probing for a chip. https://flashrom.org/pipermail/flashrom/2010-May/003321.html"),
1165 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)."),
1166 B("IBM/Lenovo", "ThinkPad T40p", BAD, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
1167 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)."),
1168 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)."),
1169 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)."),
1170 B("IBM/Lenovo", "ThinkPad T530", DEP, "http://www.thinkwiki.org/wiki/Category:T530", "Works fine but only with coreboot (due to locked regions and additional PR restrictions)."),
1171 B("IBM/Lenovo", "ThinkPad 240", BAD, "http://www.stanford.edu/~bresnan//tp240.html", "Seems to (partially) work at first, but one block/sector cannot be written which then leaves you with a bricked laptop. Maybe this can be investigated and fixed in software later."),
1172 B("IBM/Lenovo", "3000 V100 TF05Cxx", OK, "http://www5.pc.ibm.com/europe/products.nsf/products?openagent&brand=Lenovo3000Notebook&series=Lenovo+3000+V+Series#viewallmodelstop", NULL),
1173 //B("MSI", "GT60-2OD", OK, "http://www.msi.com/product/nb/GT60_2OD.html", NULL), requires layout patches
1174 B("Teclast", "X98 Air 3G", OK, NULL, NULL),
hailfinger324a9cc2010-05-26 01:45:41 +00001175#endif
uwec0751f42009-10-06 13:00:00 +00001176
Patrick Georgi8ddfee92017-03-20 14:54:28 +01001177 {0},
uwec0751f42009-10-06 13:00:00 +00001178};
hailfinger80422e22009-12-13 22:28:00 +00001179#endif