blob: 85d5ab26e3b1d4d57cd186d771d9b7aa1b365e4e [file] [log] [blame]
Uwe Hermannba290d12009-06-17 12:07:12 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2009 Uwe Hermann <uwe@hermann-uwe.de>
5 * Copyright (C) 2009 Carl-Daniel Hailfinger
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20 */
21
Carl-Daniel Hailfinger831e8f42010-05-30 22:24:40 +000022#include <stdio.h>
Uwe Hermannba290d12009-06-17 12:07:12 +000023#include <string.h>
24#include <stdlib.h>
25#include "flash.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000026#include "programmer.h"
Uwe Hermannba290d12009-06-17 12:07:12 +000027
28/*
29 * Return a string corresponding to the bustype parameter.
Stefan Tauner00155492011-06-26 20:45:35 +000030 * Memory is obtained with malloc() and must be freed with free() by the caller.
Uwe Hermannba290d12009-06-17 12:07:12 +000031 */
32char *flashbuses_to_text(enum chipbustype bustype)
33{
34 char *ret = calloc(1, 1);
Uwe Hermannba290d12009-06-17 12:07:12 +000035 /*
36 * FIXME: Once all chipsets and flash chips have been updated, NONSPI
37 * will cease to exist and should be eliminated here as well.
38 */
Carl-Daniel Hailfinger532c7172011-11-04 21:35:26 +000039 if (bustype == BUS_NONSPI) {
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +000040 ret = strcat_realloc(ret, "Non-SPI, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000041 } else {
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000042 if (bustype & BUS_PARALLEL)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000043 ret = strcat_realloc(ret, "Parallel, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000044 if (bustype & BUS_LPC)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000045 ret = strcat_realloc(ret, "LPC, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000046 if (bustype & BUS_FWH)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000047 ret = strcat_realloc(ret, "FWH, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000048 if (bustype & BUS_SPI)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000049 ret = strcat_realloc(ret, "SPI, ");
Carl-Daniel Hailfinger532c7172011-11-04 21:35:26 +000050 if (bustype & BUS_PROG)
51 ret = strcat_realloc(ret, "Programmer-specific, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000052 if (bustype == BUS_NONE)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000053 ret = strcat_realloc(ret, "None, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000054 }
55 /* Kill last comma. */
Stefan Tauner355cbfd2011-05-28 02:37:14 +000056 ret[strlen(ret) - 2] = '\0';
Uwe Hermannba290d12009-06-17 12:07:12 +000057 ret = realloc(ret, strlen(ret) + 1);
58 return ret;
59}
60
Niklas Söderlundede2fa42012-10-23 13:06:46 +000061static int print_supported_chips(void)
Uwe Hermannba290d12009-06-17 12:07:12 +000062{
Stefan Tauner29e5d312011-09-12 22:55:01 +000063 const char *delim = "/";
64 const int mintoklen = 5;
65 const int border = 2;
66 int i, chipcount = 0;
Stefan Tauner7bcacb12011-05-26 01:35:19 +000067 int maxvendorlen = strlen("Vendor") + 1;
68 int maxchiplen = strlen("Device") + 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +000069 int maxtypelen = strlen("Type") + 1;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000070 const struct flashchip *chip;
Stefan Tauner00155492011-06-26 20:45:35 +000071 char *s;
Stefan Tauner29e5d312011-09-12 22:55:01 +000072 char *tmpven, *tmpdev;
73 int tmpvenlen, tmpdevlen, curvenlen, curdevlen;
Uwe Hermannba290d12009-06-17 12:07:12 +000074
Stefan Tauner29e5d312011-09-12 22:55:01 +000075 /* calculate maximum column widths and by iterating over all chips */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000076 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +000077 /* Ignore generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000078 if (!strncmp(chip->vendor, "Unknown", 7) ||
79 !strncmp(chip->vendor, "Programmer", 10) ||
80 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +000081 continue;
Uwe Hermannba290d12009-06-17 12:07:12 +000082 chipcount++;
Stefan Tauner29e5d312011-09-12 22:55:01 +000083
84 /* Find maximum vendor length (respecting line splitting). */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +000085 tmpven = (char *)chip->vendor;
Stefan Tauner29e5d312011-09-12 22:55:01 +000086 do {
87 /* and take minimum token lengths into account */
88 tmpvenlen = 0;
89 do {
90 tmpvenlen += strcspn(tmpven, delim);
91 /* skip to the address after the first token */
92 tmpven += tmpvenlen;
93 if (tmpven[0] == '\0')
94 break;
95 tmpven++;
96 } while (tmpvenlen < mintoklen);
97 maxvendorlen = max(maxvendorlen, tmpvenlen);
98 if (tmpven[0] == '\0')
99 break;
100 } while (1);
101
102 /* same for device name */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000103 tmpdev = (char *)chip->name;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000104 do {
105 tmpdevlen = 0;
106 do {
107 tmpdevlen += strcspn(tmpdev, delim);
108 tmpdev += tmpdevlen;
109 if (tmpdev[0] == '\0')
110 break;
111 tmpdev++;
112 } while (tmpdevlen < mintoklen);
113 maxchiplen = max(maxchiplen, tmpdevlen);
114 if (tmpdev[0] == '\0')
115 break;
116 } while (1);
117
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000118 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000119 maxtypelen = max(maxtypelen, strlen(s));
120 free(s);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000121 }
Stefan Tauner29e5d312011-09-12 22:55:01 +0000122 maxvendorlen += border;
123 maxchiplen += border;
124 maxtypelen += border;
Uwe Hermannba290d12009-06-17 12:07:12 +0000125
Stefan Tauner12589362011-06-25 17:36:25 +0000126 msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
127 msg_ginfo("Vendor");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000128 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000129 msg_ginfo(" ");
130 msg_ginfo("Device");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000131 for (i = strlen("Device"); i < maxchiplen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000132 msg_ginfo(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000133
Stefan Tauner29e5d312011-09-12 22:55:01 +0000134 msg_ginfo("Test");
135 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000136 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000137 msg_ginfo("Known");
138 for (i = 0; i < border; i++)
139 msg_ginfo(" ");
140 msg_ginfo(" Size");
141 for (i = 0; i < border; i++)
142 msg_ginfo(" ");
143
144 msg_ginfo("Type");
145 for (i = strlen("Type"); i < maxtypelen; i++)
146 msg_ginfo(" ");
147 msg_gdbg("Voltage");
148 msg_ginfo("\n");
149
150 for (i = 0; i < maxvendorlen + maxchiplen; i++)
151 msg_ginfo(" ");
152 msg_ginfo("OK ");
153 for (i = 0; i < border; i++)
154 msg_ginfo(" ");
155 msg_ginfo("Broken");
156 for (i = 0; i < border; i++)
157 msg_ginfo(" ");
158 msg_ginfo("[kB]");
159 for (i = 0; i < border + maxtypelen; i++)
160 msg_ginfo(" ");
161 msg_gdbg("range [V]");
162 msg_ginfo("\n\n");
Stefan Tauner12589362011-06-25 17:36:25 +0000163 msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE)\n\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000164
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000165 for (chip = flashchips; chip->name != NULL; chip++) {
Stefan Tauner035492a2012-02-03 22:32:09 +0000166 /* Don't print generic entries. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000167 if (!strncmp(chip->vendor, "Unknown", 7) ||
168 !strncmp(chip->vendor, "Programmer", 10) ||
169 !strncmp(chip->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +0000170 continue;
171
Stefan Tauner29e5d312011-09-12 22:55:01 +0000172 /* support for multiline vendor names:
173 * - make a copy of the original vendor name
174 * - use strok to put the first token in tmpven
175 * - keep track of the length of all tokens on the current line
176 * for ' '-padding in curvenlen
177 * - check if additional tokens should be printed on the current
178 * line
179 * - after all other values are printed print the surplus tokens
180 * on fresh lines
181 */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000182 tmpven = malloc(strlen(chip->vendor) + 1);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000183 if (tmpven == NULL) {
184 msg_gerr("Out of memory!\n");
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000185 return 1;
Stefan Tauner29e5d312011-09-12 22:55:01 +0000186 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000187 strcpy(tmpven, chip->vendor);
Uwe Hermannba290d12009-06-17 12:07:12 +0000188
Stefan Tauner29e5d312011-09-12 22:55:01 +0000189 tmpven = strtok(tmpven, delim);
190 msg_ginfo("%s", tmpven);
191 curvenlen = strlen(tmpven);
192 while ((tmpven = strtok(NULL, delim)) != NULL) {
193 msg_ginfo("%s", delim);
194 curvenlen++;
195 tmpvenlen = strlen(tmpven);
196 if (tmpvenlen >= mintoklen)
197 break; /* big enough to be on its own line */
198 msg_ginfo("%s", tmpven);
199 curvenlen += tmpvenlen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000200 }
201
Stefan Tauner29e5d312011-09-12 22:55:01 +0000202 for (i = curvenlen; i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000203 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000204
205 /* support for multiline device names as above */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000206 tmpdev = malloc(strlen(chip->name) + 1);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000207 if (tmpdev == NULL) {
208 msg_gerr("Out of memory!\n");
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000209 return 1;
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000210 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000211 strcpy(tmpdev, chip->name);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000212
213 tmpdev = strtok(tmpdev, delim);
214 msg_ginfo("%s", tmpdev);
215 curdevlen = strlen(tmpdev);
216 while ((tmpdev = strtok(NULL, delim)) != NULL) {
217 msg_ginfo("%s", delim);
218 curdevlen++;
219 tmpdevlen = strlen(tmpdev);
220 if (tmpdevlen >= mintoklen)
221 break; /* big enough to be on its own line */
222 msg_ginfo("%s", tmpdev);
223 curdevlen += tmpdevlen;
224 }
225
226 for (i = curdevlen; i < maxchiplen; i++)
227 msg_ginfo(" ");
228
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000229 if ((chip->tested & TEST_OK_PROBE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000230 msg_ginfo("P");
231 else
232 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000233 if ((chip->tested & TEST_OK_READ))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000234 msg_ginfo("R");
235 else
236 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000237 if ((chip->tested & TEST_OK_ERASE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000238 msg_ginfo("E");
239 else
240 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000241 if ((chip->tested & TEST_OK_WRITE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000242 msg_ginfo("W");
243 else
244 msg_ginfo(" ");
245 for (i = 0; i < border; i++)
246 msg_ginfo(" ");
247
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000248 if ((chip->tested & TEST_BAD_PROBE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000249 msg_ginfo("P");
250 else
251 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000252 if ((chip->tested & TEST_BAD_READ))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000253 msg_ginfo("R");
254 else
255 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000256 if ((chip->tested & TEST_BAD_ERASE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000257 msg_ginfo("E");
258 else
259 msg_ginfo(" ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000260 if ((chip->tested & TEST_BAD_WRITE))
Stefan Tauner29e5d312011-09-12 22:55:01 +0000261 msg_ginfo("W");
262 else
263 msg_ginfo(" ");
264 for (i = 0; i < border + 1; i++)
265 msg_ginfo(" ");
266
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000267 msg_ginfo("%5d", chip->total_size);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000268 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000269 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000270
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000271 s = flashbuses_to_text(chip->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000272 msg_ginfo("%s", s);
273 for (i = strlen(s); i < maxtypelen; i++)
274 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000275 free(s);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000276
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000277 if (chip->voltage.min == 0 && chip->voltage.max == 0)
Stefan Tauner29e5d312011-09-12 22:55:01 +0000278 msg_gdbg("no info");
279 else
280 msg_gdbg("%0.02f;%0.02f",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000281 chip->voltage.min/(double)1000,
282 chip->voltage.max/(double)1000);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000283
284 /* print surplus vendor and device name tokens */
285 while (tmpven != NULL || tmpdev != NULL) {
286 msg_ginfo("\n");
287 if (tmpven != NULL){
288 msg_ginfo("%s", tmpven);
289 curvenlen = strlen(tmpven);
290 while ((tmpven = strtok(NULL, delim)) != NULL) {
291 msg_ginfo("%s", delim);
292 curvenlen++;
293 tmpvenlen = strlen(tmpven);
294 /* big enough to be on its own line */
295 if (tmpvenlen >= mintoklen)
296 break;
297 msg_ginfo("%s", tmpven);
298 curvenlen += tmpvenlen;
299 }
300 } else
301 curvenlen = 0;
302
303 for (i = curvenlen; i < maxvendorlen; i++)
304 msg_ginfo(" ");
305
306 if (tmpdev != NULL){
307 msg_ginfo("%s", tmpdev);
308 curdevlen = strlen(tmpdev);
309 while ((tmpdev = strtok(NULL, delim)) != NULL) {
310 msg_ginfo("%s", delim);
311 curdevlen++;
312 tmpdevlen = strlen(tmpdev);
313 /* big enough to be on its own line */
314 if (tmpdevlen >= mintoklen)
315 break;
316 msg_ginfo("%s", tmpdev);
317 curdevlen += tmpdevlen;
318 }
319 }
320 }
321 msg_ginfo("\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000322 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000323
324 return 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000325}
326
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000327#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000328static void print_supported_chipsets(void)
Uwe Hermannba290d12009-06-17 12:07:12 +0000329{
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000330 int i, chipsetcount = 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000331 const struct penable *c = chipset_enables;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000332 int maxvendorlen = strlen("Vendor") + 1;
333 int maxchipsetlen = strlen("Chipset") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000334
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000335 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Uwe Hermannba290d12009-06-17 12:07:12 +0000336 chipsetcount++;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000337 maxvendorlen = max(maxvendorlen, strlen(c->vendor_name));
338 maxchipsetlen = max(maxchipsetlen, strlen(c->device_name));
339 }
340 maxvendorlen++;
341 maxchipsetlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000342
Stefan Tauner12589362011-06-25 17:36:25 +0000343 msg_ginfo("Supported chipsets (total: %d):\n\n", chipsetcount);
Uwe Hermannba290d12009-06-17 12:07:12 +0000344
Stefan Tauner12589362011-06-25 17:36:25 +0000345 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000346 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000347 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000348
Stefan Tauner12589362011-06-25 17:36:25 +0000349 msg_ginfo("Chipset");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000350 for (i = strlen("Chipset"); i < maxchipsetlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000351 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000352
Stefan Tauner12589362011-06-25 17:36:25 +0000353 msg_ginfo("PCI IDs State\n\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000354
355 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000356 msg_ginfo("%s", c->vendor_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000357 for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000358 msg_ginfo(" ");
359 msg_ginfo("%s", c->device_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000360 for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000361 msg_ginfo(" ");
362 msg_ginfo("%04x:%04x%s\n", c->vendor_id, c->device_id,
Stefan Tauner2c20b282012-07-28 19:35:26 +0000363 (c->status == NT) ? " (untested)" : "");
Uwe Hermannba290d12009-06-17 12:07:12 +0000364 }
365}
366
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000367static void print_supported_boards_helper(const struct board_info *boards,
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000368 const char *devicetype)
Uwe Hermannba290d12009-06-17 12:07:12 +0000369{
Stefan Tauner2c20b282012-07-28 19:35:26 +0000370 int i;
371 unsigned int boardcount_good = 0, boardcount_bad = 0, boardcount_nt = 0;
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000372 const struct board_match *e = board_matches;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000373 const struct board_info *b = boards;
374 int maxvendorlen = strlen("Vendor") + 1;
375 int maxboardlen = strlen("Board") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000376
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000377 for (b = boards; b->vendor != NULL; b++) {
378 maxvendorlen = max(maxvendorlen, strlen(b->vendor));
379 maxboardlen = max(maxboardlen, strlen(b->name));
Stefan Tauner2c20b282012-07-28 19:35:26 +0000380 if (b->working == OK)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000381 boardcount_good++;
Stefan Tauner2c20b282012-07-28 19:35:26 +0000382 else if (b->working == NT)
383 boardcount_nt++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000384 else
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000385 boardcount_bad++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000386 }
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000387 maxvendorlen++;
388 maxboardlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000389
Stefan Tauner2c20b282012-07-28 19:35:26 +0000390 msg_ginfo("%d known %s (good: %d, untested: %d, bad: %d):\n\n",
391 boardcount_good + boardcount_nt + boardcount_bad,
392 devicetype, boardcount_good, boardcount_nt, boardcount_bad);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000393
Stefan Tauner12589362011-06-25 17:36:25 +0000394 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000395 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000396 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000397
Stefan Tauner12589362011-06-25 17:36:25 +0000398 msg_ginfo("Board");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000399 for (i = strlen("Board"); i < maxboardlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000400 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000401
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000402 msg_ginfo("Status Required value for\n");
403 for (i = 0; i < maxvendorlen + maxboardlen + strlen("Status "); i++)
404 msg_ginfo(" ");
405 msg_ginfo("-p internal:mainboard=\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000406
407 for (b = boards; b->vendor != NULL; b++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000408 msg_ginfo("%s", b->vendor);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000409 for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000410 msg_ginfo(" ");
411 msg_ginfo("%s", b->name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000412 for (i = 0; i < maxboardlen - strlen(b->name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000413 msg_ginfo(" ");
Stefan Tauner2c20b282012-07-28 19:35:26 +0000414 if (b->working == OK)
415 msg_ginfo("OK ");
416 else if (b->working == NT)
417 msg_ginfo("NT ");
418 else
419 msg_ginfo("BAD ");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000420
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000421 for (e = board_matches; e->vendor_name != NULL; e++) {
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000422 if (strcmp(e->vendor_name, b->vendor)
423 || strcmp(e->board_name, b->name))
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000424 continue;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000425 if (e->lb_vendor == NULL)
Stefan Tauner12589362011-06-25 17:36:25 +0000426 msg_ginfo("(autodetected)");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000427 else
Carl-Daniel Hailfinger2d927fb2012-01-04 00:48:27 +0000428 msg_ginfo("%s:%s", e->lb_vendor,
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000429 e->lb_part);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000430 }
Stefan Tauner12589362011-06-25 17:36:25 +0000431 msg_ginfo("\n");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000432 }
Uwe Hermannba290d12009-06-17 12:07:12 +0000433}
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000434#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000435
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000436void print_supported_devs(const struct programmer_entry prog, const char *const type)
Stefan Tauneraf358d62012-12-27 18:40:26 +0000437{
438 int i;
439
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000440 const struct dev_entry *const devs = prog.devs.dev;
441 msg_ginfo("\nSupported %s devices for the %s programmer:\n", type, prog.name);
Stefan Tauneraf358d62012-12-27 18:40:26 +0000442 for (i = 0; devs[i].vendor_name != NULL; i++) {
443 msg_pinfo("%s %s [%04x:%04x]%s\n", devs[i].vendor_name, devs[i].device_name, devs[i].vendor_id,
444 devs[i].device_id, (devs[i].status == NT) ? " (untested)" : "");
445 }
446}
447
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000448int print_supported(void)
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000449{
Stefan Tauneraf358d62012-12-27 18:40:26 +0000450 unsigned int i;
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000451 if (print_supported_chips())
452 return 1;
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000453
Stefan Tauner12589362011-06-25 17:36:25 +0000454 msg_ginfo("\nSupported programmers:\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000455 list_programmers_linebreak(0, 80, 0);
Stefan Taunerb226cb12012-11-24 18:59:39 +0000456 msg_ginfo("\n");
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000457#if CONFIG_INTERNAL == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000458 msg_ginfo("\nSupported devices for the %s programmer:\n\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000459 programmer_table[PROGRAMMER_INTERNAL].name);
460 print_supported_chipsets();
Stefan Tauner12589362011-06-25 17:36:25 +0000461 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000462 print_supported_boards_helper(boards_known, "boards");
Stefan Tauner12589362011-06-25 17:36:25 +0000463 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000464 print_supported_boards_helper(laptops_known, "laptops");
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000465#endif
Stefan Tauneraf358d62012-12-27 18:40:26 +0000466 for (i = 0; i < PROGRAMMER_INVALID; i++) {
467 const struct programmer_entry prog = programmer_table[i];
468 switch (prog.type) {
469 case USB:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000470 print_supported_devs(prog, "USB");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000471 break;
472#if NEED_PCI == 1
473 case PCI:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000474 print_supported_devs(prog, "PCI");
Stefan Tauneraf358d62012-12-27 18:40:26 +0000475 break;
Adam Jurkowski516f9322009-12-14 03:07:31 +0000476#endif
Stefan Tauneraf358d62012-12-27 18:40:26 +0000477 case OTHER:
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000478 if (prog.devs.note != NULL) {
479 msg_ginfo("\nSupported devices for the %s programmer:\n", prog.name);
480 msg_ginfo("%s", prog.devs.note);
481 }
Stefan Tauneraf358d62012-12-27 18:40:26 +0000482 break;
483 default:
484 msg_gerr("\n%s: %s: Uninitialized programmer type! Please report a bug at "
485 "flashrom@flashrom.org\n", __func__, prog.name);
486 break;
487 }
488 }
Niklas Söderlundede2fa42012-10-23 13:06:46 +0000489 return 0;
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000490}
491
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000492#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger4146ced2010-06-07 11:10:43 +0000493
494#ifdef CONFIG_PRINT_WIKI
495#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
496#else
497#define B(vendor, name, status, url, note) { vendor, name, status }
498#endif
499
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000500/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000501const struct board_info boards_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000502#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +0000503 B("A-Trend", "ATC-6220", OK, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
504 B("abit", "A-S78H", OK, NULL, NULL),
505 B("abit", "AN-M2", OK, NULL, NULL),
506 B("abit", "AV8", OK, NULL, NULL),
507 B("abit", "AX8", OK, NULL, NULL),
508 B("abit", "BM6", OK, NULL, NULL),
509 B("abit", "Fatal1ty F-I90HD", OK, NULL, NULL),
510 B("abit", "IC7", OK, NULL, NULL),
511 B("abit", "IP35", OK, NULL, NULL),
512 B("abit", "IP35 Pro", OK, NULL, NULL),
513 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."),
514 B("abit", "KN8 Ultra", OK, NULL, NULL),
515 B("abit", "NF-M2 nView", OK, NULL, NULL),
516 B("abit", "NF-M2S", OK, NULL, NULL),
517 B("abit", "NF7-S", OK, NULL, NULL),
518 B("abit", "VA6", OK, NULL, NULL),
519 B("abit", "VT6X4", OK, NULL, NULL),
520 B("Acorp", "6A815EPD", OK, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
521 B("Advantech", "PCM-5820", OK, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
522 B("agami", "Aruma", OK, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
523 B("Albatron", "PM266A Pro", OK, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
524 B("AOpen", "i945GMx-VFX", OK, NULL, "This is (also?) an OEM board from FSC (used in e.g. ESPRIMO Q5010 with designation D2544-B1)."),
525 B("AOpen", "vKM400Am-S", OK, "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
526 B("Artec Group","DBE61", OK, "http://wiki.thincan.org/DBE61", NULL),
527 B("Artec Group","DBE62", OK, "http://wiki.thincan.org/DBE62", NULL),
528 B("ASI", "MB-5BLMP", OK, "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III thin client."),
529 B("ASRock", "775i65G", OK, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
530 B("ASRock", "880G Pro3", OK, "http://www.asrock.com/mb/overview.asp?Model=880G%20Pro3", NULL),
531 B("ASRock", "890GX Extreme3", OK, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
532 B("ASRock", "939A785GMH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
533 B("ASRock", "A330GC", OK, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
534 B("ASRock", "A770CrossFire", OK, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
535 B("ASRock", "A780FullHD", OK, "http://www.asrock.com/mb/overview.asp?Model=A780FullHD", "While flashrom is working correctly, there might be problems with the firmware images themselves. Please see http://www.flashrom.org/pipermail/flashrom/2012-July/009600.html for details."),
536 B("ASRock", "ALiveNF6G-DVI", OK, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
537 B("ASRock", "AM2NF6G-VSTA", OK, "http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
538 B("ASRock", "ConRoeXFire-eSATA2", OK, "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2", NULL),
539 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."),
540 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."),
541 B("ASRock", "K7S41", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
542 B("ASRock", "K7S41GX", OK, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
543 B("ASRock", "K7VT4A+", BAD, "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip found, probably due to flash translation. http://www.flashrom.org/pipermail/flashrom/2009-August/000393.html"),
544 B("ASRock", "K8S8X", OK, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
545 B("ASRock", "M3A790GXH/128M", OK, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
546 B("ASRock", "N61P-S", OK, "http://www.asrock.com/mb/overview.asp?Model=N61P-S", NULL),
547 B("ASRock", "P4i65GV", OK, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
548 B("ASUS", "A7N8X Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
549 B("ASUS", "A7N8X-E Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
550 B("ASUS", "A7N8X-VM/400", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000551 B("ASUS", "A7V133", OK, NULL, NULL),
552 B("ASUS", "A7V333", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000553 B("ASUS", "A7V400-MX", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
554 B("ASUS", "A7V600-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
555 B("ASUS", "A7V8X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
556 B("ASUS", "A7V8X-MX", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
557 B("ASUS", "A7V8X-MX SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
558 B("ASUS", "A7V8X-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
559 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."),
560 B("ASUS", "A8N-E", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
561 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."),
562 B("ASUS", "A8N-SLI", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
Jonathan Kollaschc8190002012-09-04 03:55:04 +0000563 B("ASUS", "A8N-SLI Deluxe", NT, NULL, "Should work out of the box since r1593."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000564 B("ASUS", "A8N-SLI Premium", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/", NULL),
565 B("ASUS", "A8N-VM", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
566 B("ASUS", "A8N-VM CSM", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
567 B("ASUS", "A8NE-FM/S", OK, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
568 B("ASUS", "A8V Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
569 B("ASUS", "A8V-E Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
570 B("ASUS", "A8V-E SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
571 B("ASUS", "Crosshair II Formula", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/", NULL),
572 B("ASUS", "Crosshair IV Extreme", OK, "http://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/", NULL),
Stefan Tauner98546c92012-11-05 12:20:29 +0000573 B("ASUS", "DSAN-DX", NT, "http://www.asus.com/Server_Workstation/Server_Motherboards/DSANDX/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000574 B("ASUS", "E35M1-I DELUXE", OK, "http://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/", NULL),
575 B("ASUS", "K8N", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
576 B("ASUS", "K8V", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
577 B("ASUS", "K8V SE Deluxe", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/", NULL),
578 B("ASUS", "K8V-X", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
579 B("ASUS", "K8V-X SE", OK, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
580 B("ASUS", "KFSN4-DRE/SAS", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/", NULL),
581 B("ASUS", "M2A-MX", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
582 B("ASUS", "M2A-VM (HDMI)", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
583 B("ASUS", "M2N32-SLI Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/", NULL),
584 B("ASUS", "M2N68-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M2N68VM/", NULL),
585 B("ASUS", "M2N-E", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NE/", "If the machine doesn't come up again after flashing, try resetting the NVRAM(CMOS). The MAC address of the onboard network card will change to the value stored in the new image, so backup the old address first. See http://www.flashrom.org/pipermail/flashrom/2009-November/000879.html"),
586 B("ASUS", "M2N-E SLI", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
587 B("ASUS", "M2N-SLI Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
588 B("ASUS", "M2NBP-VM CSM", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
589 B("ASUS", "M2NPV-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
590 B("ASUS", "M2V", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
591 B("ASUS", "M2V-MX", OK, "http://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
592 B("ASUS", "M3A", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
593 B("ASUS", "M3A76-CM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000594 B("ASUS", "M3A78-EH", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EH/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000595 B("ASUS", "M3A78-EM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
596 B("ASUS", "M3N78 PRO", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78_PRO/", NULL),
597 B("ASUS", "M3N78-VM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
598 B("ASUS", "M4A78-EM", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
599 B("ASUS", "M4A785T-M", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TM/", NULL),
600 B("ASUS", "M4A785TD-M EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
601 B("ASUS", "M4A785TD-V EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
602 B("ASUS", "M4A78LT-M LE", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
603 B("ASUS", "M4A79T Deluxe", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
604 B("ASUS", "M4A87TD/USB3", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
605 B("ASUS", "M4A89GTD PRO", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
606 B("ASUS", "M4N68T V2", OK, "http://www.asus.com/Motherboards/AMD_AM3/M4N68T_V2/", NULL),
607 B("ASUS", "M4N78 PRO", OK, "http://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
608 B("ASUS", "M5A78L-M LX", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/M5A78LM_LX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see http://www.flashrom.org/pipermail/flashrom/2012-May/009200.html"),
609 B("ASUS", "M5A99X EVO", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
610 B("ASUS", "Maximus IV Extreme", BAD, "http://www.asus.com/Motherboards/Intel_Socket_1155/Maximus_IV_Extreme/", "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunereb582572012-09-21 12:52:50 +0000611 B("ASUS", "MEW-AM", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000612 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."),
613 B("ASUS", "OPLX-M", NT, NULL, "Untested board enable."),
Stefan Taunereb582572012-09-21 12:52:50 +0000614 B("ASUS", "P2B", OK, NULL, NULL),
615 B("ASUS", "P2B-D", OK, NULL, NULL),
616 B("ASUS", "P2B-DS", OK, NULL, NULL),
617 B("ASUS", "P2B-F", OK, NULL, NULL),
618 B("ASUS", "P2B-LS", OK, NULL, NULL),
619 B("ASUS", "P2B-N", OK, NULL, NULL),
620 B("ASUS", "P2E-M", OK, NULL, NULL),
621 B("ASUS", "P2L97-S", OK, NULL, NULL),
622 B("ASUS", "P3B-F", BAD, NULL, "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
623 B("ASUS", "P4B266", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000624 B("ASUS", "P4B266-LM", OK, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000625 B("ASUS", "P4B533-E", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000626 B("ASUS", "P4C800-E Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/", NULL),
627 B("ASUS", "P4GV-LA (Guppy)", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478", NULL),
628 B("ASUS", "P4P800", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
629 B("ASUS", "P4P800-E Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/", NULL),
630 B("ASUS", "P4P800-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000631 B("ASUS", "P4P800-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800X/", NULL),
632 B("ASUS", "P4S533-X", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000633 B("ASUS", "P4S800-MX", OK, "http://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000634 B("ASUS", "P4SC-E", OK, NULL, "Part of ASUS Terminator P4 533 barebone system"),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000635 B("ASUS", "P4SD-LA", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000636 B("ASUS", "P5A", OK, NULL, NULL),
637 B("ASUS", "P5B", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000638 B("ASUS", "P5B-Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000639 B("ASUS", "P5BV-M", BAD, NULL, "Reported by Bernhard M. Wiedemann <bernhard@uml12d.zq1.de> to flashrom@coreboot.org, no public archive. Missing board enable and/or SST49LF008A unlocking. May work now."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000640 B("ASUS", "P5BV-R", OK, "http://www.asus.com/Server_Workstation/Servers/RS120E5PA2/", "Used in RS120-E5/PA2 servers."),
641 B("ASUS", "P5GC-MX/1333", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/", NULL),
642 B("ASUS", "P5GD1 Pro", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
643 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."),
644 B("ASUS", "P5GD1(-VM)", NT, NULL, "Untested board enable."),
645 B("ASUS", "P5GD2 Premium", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/", NULL),
646 B("ASUS", "P5GD2-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2X/", NULL),
647 B("ASUS", "P5GDC Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/", NULL),
648 B("ASUS", "P5GDC-V Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/", NULL),
649 B("ASUS", "P5GD2/C variants", NT, NULL, "Untested board enable."),
650 B("ASUS", "P5K-V", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
651 B("ASUS", "P5K-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
652 B("ASUS", "P5KC", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
653 B("ASUS", "P5KPL-CM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
654 B("ASUS", "P5L-MX", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
655 B("ASUS", "P5L-VM 1394", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/", NULL),
656 B("ASUS", "P5LD2", NT, NULL, "Untested board enable."),
Idwer Vollering4d0cde12012-09-07 08:27:46 +0000657 B("ASUS", "P5LD2-VM", NT, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LD2VM/", "Untested board enable."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000658 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."),
659 B("ASUS", "P5LP-LE (Epson OEM)", OK, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
660 B("ASUS", "P5LP-LE", NT, NULL, "This designation is used for OEM boards from HP, Epson and maybe others. The HP names vary and not all of them have been tested yet. Please report any success or failure, thanks."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000661 B("ASUS", "P5N-D", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
662 B("ASUS", "P5N-E SLI", NT, "http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Untested board enable."),
663 B("ASUS", "P5N32-E SLI", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/", NULL),
664 B("ASUS", "P5N7A-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
665 B("ASUS", "P5ND2-SLI Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/", NULL),
666 B("ASUS", "P5PE-VM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
667 B("ASUS", "P5QPL-AM", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
668 B("ASUS", "P5VD1-X", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
669 B("ASUS", "P5VD2-MX", OK, "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD2MX/", "The MAC address of the onboard LAN NIC is stored in flash, hence overwritten by flashrom; see http://www.flashrom.org/pipermail/flashrom/2012-March/009014.html"),
670 B("ASUS", "P6T SE", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
671 B("ASUS", "P6T Deluxe", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/", NULL),
672 B("ASUS", "P6T Deluxe V2", OK, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/", NULL),
673 B("ASUS", "P7H57D-V EVO", OK, "http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
674 B("ASUS", "P7H55-M LX", BAD, NULL, "flashrom works correctly, but GbE LAN is nonworking (probably due to a missing/bogus MAC address; see http://www.flashrom.org/pipermail/flashrom/2011-July/007432.html and http://ubuntuforums.org/showthread.php?t=1534389 for a possible workaround)"),
675 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."),
676 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."),
677 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."),
678 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."),
679 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."),
680 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."),
681 B("ASUS", "P8P67 LE", 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."),
682 B("ASUS", "P8P67 PRO (rev. 3.0)", OK, "http://www.asus.com/Motherboards/Intel_Socket_1155/P8P67_PRO/", NULL),
683 B("ASUS", "P8Z68-V", OK, "http://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
684 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."),
685 B("ASUS", "P8Z68-V PRO/GEN3", OK, "http://www.asus.com/Motherboards/Intel_Socket_1155/P8Z68V_PROGEN3/", "Warning: MAC address of LOM is stored at 0x1000 - 0x1005 of the image."),
686 B("ASUS", "SABERTOOTH 990FX", OK, "http://www.asus.com/Motherboards/AMD_AM3Plus/SABERTOOTH_990FX/", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000687 B("ASUS", "CUSL2-C", OK, NULL, "The image provided by ASUS is only 256 kB big and has to be written to the upper 256 kB of the 512 kB chip."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000688 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."),
689 B("ASUS", "Z8NA-D6C", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/", NULL),
690 B("ASUS", "Z8PE-D12", OK, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/", NULL),
691 B("Bachmann", "OT200", OK, "http://www.bachmann.info/produkte/bedien-und-beobachtungsgeraete/operator-terminals/", NULL),
692 B("BCOM", "WinNET100", OK, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
693 B("Bifferos", "Bifferboard", OK, "http://bifferos.co.uk/", NULL),
694 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."),
695 B("Biostar", "M6TBA", BAD, "ftp://ftp.biostar-usa.com/manuals/M6TBA/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Stefan Taunereb582572012-09-21 12:52:50 +0000696 B("Biostar", "M7NCD Pro", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=260", NULL),
Stefan Taunerb6304c12012-08-09 23:25:27 +0000697 B("Biostar", "M7VIQ", NT, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000698 B("Biostar", "N61PB-M2S", OK, NULL, NULL),
699 B("Biostar", "N68S3+", OK, NULL, NULL),
700 B("Biostar", "P4M80-M4", OK, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000701 B("Biostar", "TA780G M2+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=344", NULL),
702 B("Biostar", "TA790GX A3+", OK, "http://www.biostar.com.tw/app/en/mb/introduction.php?S_ID=395", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000703 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."),
704 B("Congatec", "conga-X852", OK, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
705 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."),
706 B("Dell", "OptiPlex GX1", OK, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
707 B("Dell", "PowerEdge 1850", OK, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000708 B("Dell", "PowerEdge C6220", BAD, NULL, "Mainboard model is 0HYFFG. Probing works (Macronix MX25L6405, 8192 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked (and there are even overlapping PRs)."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000709 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."),
710 B("DFI", "855GME-MGF", BAD, "http://www.dfi.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?action=e&downloadType=&windowstate=normal&mode=view&downloadFlag=false&itemId=433", "Probably needs a board enable. http://www.coreboot.org/pipermail/coreboot/2009-May/048549.html"),
Tadas Slotkus3dcdc032012-08-25 03:53:12 +0000711 B("DFI", "AD77", NT, NULL, "Untested board enable."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000712 B("DFI", "Blood-Iron P35 T2RL", OK, "http://lp.lanparty.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?itemId=516&downloadFlag=false&action=1", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000713 B("Elitegroup", "848P-A7", OK, NULL, NULL),
714 B("Elitegroup", "GeForce6100SM-M", OK, NULL, NULL),
715 B("Elitegroup", "GF7100PVT-M3 (V1.0)", OK, NULL, NULL),
716 B("Elitegroup", "GF8200A", OK, NULL, NULL),
717 B("Elitegroup", "K7S5A", OK, NULL, NULL),
718 B("Elitegroup", "K7S6A", OK, NULL, NULL),
719 B("Elitegroup", "K7SEM (V1.0A)", OK, NULL, NULL),
720 B("Elitegroup", "K7VTA3", OK, NULL, NULL),
721 B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000722 B("Elitegroup", "P4VXMS (V1.0A)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000723 B("Elitegroup", "P6IWP-Fe", OK, NULL, NULL),
724 B("Elitegroup", "P6VAP-A+", OK, NULL, NULL),
725 B("Elitegroup", "RS485M-M", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000726 B("Emerson", "ATCA-7360", OK, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
727 B("EPoX", "EP-3PTA", BAD, NULL, "Missing board enable (W83627HF/F/HG/G), see http://www.flashrom.org/pipermail/flashrom/2012-April/009043.html"),
728 B("EPoX", "EP-8K5A2", OK, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
729 B("EPoX", "EP-8NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
730 B("EPoX", "EP-8RDA3+", OK, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
731 B("EPoX", "EP-9NPA7I", OK, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
732 B("EPoX", "EP-BX3", OK, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
733 B("EVGA", "132-CK-NF78", OK, "http://www.evga.com/articles/385.asp", NULL),
734 B("EVGA", "270-WS-W555-A2 (Classified SR-2)", OK, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
735 B("FIC", "VA-502", BAD, "ftp://ftp.fic.com.tw/motherboard/manual/socket7/va-502/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. Seems the PCI subsystem IDs are identical with the Tekram P6Pro-A5. May work now."),
Stefan Taunereb582572012-09-21 12:52:50 +0000736 B("Foxconn", "6150K8MD-8EKRSH", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000157", NULL),
737 B("Foxconn", "A6VMX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000346", NULL),
738 B("Foxconn", "P4M800P7MA-RS2", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000138", NULL),
Stefan Taunerd7d423b2012-10-20 09:13:16 +0000739 B("Foxconn", "P55MX", OK, "http://www.foxconnchannel.com/ProductDetail.aspx?T=motherboard&U=en-us0000474", "Needs the MFG jumper to be set correctly before flashing to enable the Flash Descriptor Override Strap."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000740 B("Freetech", "P6F91i", OK, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000741 B("Foxconn", "Q45M", BAD, "http://www.foxconnchannel.com/ProductDetail.aspx?T=Motherboard&U=en-us0000587", "Probing works (Hardware sequencing, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000742 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."),
743 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."),
744 B("GIGABYTE", "GA-2761GXDK", OK, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
745 B("GIGABYTE", "GA-6BXC", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
746 B("GIGABYTE", "GA-6BXDU", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
747 B("GIGABYTE", "GA-6IEM", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
748 B("GIGABYTE", "GA-6VXE7+", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
749 B("GIGABYTE", "GA-6ZMA", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
750 B("GIGABYTE", "GA-MA785GMT-UD2H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
751 B("GIGABYTE", "GA-770TA-UD3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
752 B("GIGABYTE", "GA-7DXR", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
753 B("GIGABYTE", "GA-7VT600", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
754 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."),
755 B("GIGABYTE", "GA-880GMA-USB3 (rev. 3.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
756 B("GIGABYTE", "GA-8I945GZME-RH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
757 B("GIGABYTE", "GA-8IP775", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
758 B("GIGABYTE", "GA-8IRML", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
759 B("GIGABYTE", "GA-8PE667 Ultra 2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
760 B("GIGABYTE", "GA-8SIMLH", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
761 B("GIGABYTE", "GA-945PL-S3P (rev. 6.6)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
762 B("GIGABYTE", "GA-965GM-S2 (rev. 2.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
763 B("GIGABYTE", "GA-965P-DS4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
764 B("GIGABYTE", "GA-EP31-DS3L (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
765 B("GIGABYTE", "GA-EP35-DS3L", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000766 B("GIGABYTE", "GA-G41MT-S2PT", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3960", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000767 B("GIGABYTE", "GA-H61M-D2-B3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3773", NULL),
768 B("GIGABYTE", "GA-H61M-D2H-USB3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4004", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000769 B("GIGABYTE", "GA-H77-D3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=4141", "Does only work with -p internal:ich_spi_mode=hwseq due to an evil twin of MX25L6405 and ICH SPI lockdown."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000770 B("GIGABYTE", "GA-EX58-UD4P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
771 B("GIGABYTE", "GA-K8N-SLI", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
772 B("GIGABYTE", "GA-K8N51GMF", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
773 B("GIGABYTE", "GA-K8N51GMF-9", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
774 B("GIGABYTE", "GA-K8NS Pro-939", NT, "http://www.gigabyte.com/products/product-page.aspx?pid=1875", "Untested board enable."),
775 B("GIGABYTE", "GA-M57SLI-S4", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
776 B("GIGABYTE", "GA-M61P-S3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
777 B("GIGABYTE", "GA-M720-US3", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
778 B("GIGABYTE", "GA-MA69VM-S2", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
779 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
780 B("GIGABYTE", "GA-MA770-UD3 (rev. 2.1)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
781 B("GIGABYTE", "GA-MA770T-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
782 B("GIGABYTE", "GA-MA780G-UD3H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
783 B("GIGABYTE", "GA-MA78G-DS3H (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
784 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? */
785 B("GIGABYTE", "GA-MA78GPM-DS2H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
786 B("GIGABYTE", "GA-MA790FX-DQ6", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
787 B("GIGABYTE", "GA-MA790GP-DS4H", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
788 B("GIGABYTE", "GA-MA790XT-UD4P (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
789 B("GIGABYTE", "GA-P55A-UD4 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
790 B("GIGABYTE", "GA-P67A-UD3P", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
791 B("GIGABYTE", "GA-X58A-UD7 (rev. 2.0)", OK, NULL, NULL),
792 B("GIGABYTE", "GA-X58A-UDR3 (rev. 2.0)", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000793 B("GIGABYTE", "GA-X79-UD5", OK, NULL, NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000794 B("GIGABYTE", "GA-Z68MX-UD2H-B (rev. 1.3)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
795 B("GIGABYTE", "GA-Z68XP-UD3 (rev. 1.0)", OK, "http://www.gigabyte.com/products/product-page.aspx?pid=3892", NULL),
796 B("HP", "8100 Elite CMT PC (304Bh)", BAD, NULL, "SPI lock down, PR, read-only descriptor, locked ME region."),
797 B("HP", "e-Vectra P2706T", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454", NULL),
798 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),
799 B("HP", "ProLiant DL165 G6", OK, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
800 B("HP", "ProLiant N40L", OK, NULL, NULL),
801 B("HP", "Puffer2-UL8E", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
802 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."),
803 B("HP", "Vectra VL400", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
804 B("HP", "Vectra VL420 SFF", OK, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
805 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"),
806 B("HP", "xw6400", BAD, NULL, "No chip found, see http://www.flashrom.org/pipermail/flashrom/2012-March/009006.html"),
807 B("HP", "xw9300", BAD, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodTypeId=12454&prodSeriesId=459226", "Missing board enable, see http://www.flashrom.org/pipermail/flashrom/2012-February/008862.html"),
808 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."),
809 B("HP", "Z400 Workstation (0AE4h)", BAD, NULL, "ICH10R with BIOS lock enable and a protected range PRBAD, see http://www.flashrom.org/pipermail/flashrom/2012-June/009350.html"),
810 B("IBASE", "MB899", OK, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
811 B("IBM", "x3455", OK, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
812 B("IEI", "PICOe-9452", OK, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
813 B("Intel", "D201GLY", OK, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
814 B("Intel", "D425KT", BAD, "http://www.intel.com/content/www/us/en/motherboards/desktop-motherboards/desktop-board-d425kt.html", "NM10 with SPI lock down, BIOS lock, see http://www.flashrom.org/pipermail/flashrom/2012-January/008600.html"),
815 B("Intel", "D865GLC", BAD, NULL, "ICH5 with BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
816 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."),
817 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)."),
818 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)."),
819 B("Intel", "DH61AG ", BAD, NULL, "H61 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2012-June/009417.html"),
820 B("Intel", "DH67CF", BAD, NULL, "H67 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
821 B("Intel", "DN2800MT (Marshalltown)", BAD, NULL, "BIOS locked via BIOS_CNTL."),
822 B("Intel", "EP80759", OK, NULL, NULL),
823 B("Intel", "Foxhollow", OK, NULL, "Intel reference board."),
824 B("Intel", "Greencity", OK, NULL, "Intel reference board."),
825 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"),
826 B("IWILL", "DK8-HTX", OK, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
827 B("Jetway", "J-7BXAN", OK, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
828 B("Jetway", "J7F4K1G5D-PB", OK, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
829 B("Kontron", "986LCD-M", OK, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
830 B("Lanner", "EM-8510C", OK, NULL, NULL),
831 B("Lex", "CV700A", OK, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
832 B("Mitac", "6513WU", OK, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
833 B("MSC", "Q7-TCTC", OK, "http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html", NULL),
834 B("MSI", "MS-6153", OK, "http://www.msi.com/product/mb/MS-6153.html", NULL),
835 B("MSI", "MS-6156", OK, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
836 B("MSI", "MS-6163 (MS-6163 Pro)",OK, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
837 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>."),
838 B("MSI", "MS-6330 (K7T Turbo)", OK, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
839 B("MSI", "MS-6391 (845 Pro4)", OK, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
840 B("MSI", "MS-6561 (745 Ultra)", OK, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
841 B("MSI", "MS-6566 (845 Ultra-C)",OK, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
842 B("MSI", "MS-6570 (K7N2)", OK, "http://www.msi.com/product/mb/K7N2.html", NULL),
843 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."),
844 B("MSI", "MS-6590 (KT4 Ultra)", OK, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
845 B("MSI", "MS-6702E (K8T Neo2-F)",OK, "http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL),
846 B("MSI", "MS-6712 (KT4V)", OK, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
847 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", OK, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
848 B("MSI", "MS-7005 (651M-L)", OK, "http://www.msi.com/product/mb/651M-L.html", NULL),
849 B("MSI", "MS-7025 (K8N Neo2 Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
Stefan Tauner33366a02012-09-15 15:51:09 +0000850 B("MSI", "MS-7030 (K8N Neo Platinum)", OK, "http://www.msi.com/product/mb/K8N-Neo-Platinum.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000851 B("MSI", "MS-7046", OK, "http://www.heimir.de/ms7046/", NULL),
852 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", OK, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
853 B("MSI", "MS-7065", OK, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
854 B("MSI", "MS-7135 (K8N Neo3)", OK, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
855 B("MSI", "MS-7142 (K8MM-V)", OK, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
856 B("MSI", "MS-7168 (Orion)", OK, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
857 B("MSI", "MS-7207 (K8NGM2-L)", OK, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
858 B("MSI", "MS-7211 (PM8M3-V)", OK, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
859 B("MSI", "MS-7236 (945PL Neo3)", OK, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
860 B("MSI", "MS-7250 (K9N SLI (rev 2.1))", OK, "http://www.msi.com/product/mb/K9N--SLI.html", NULL),
861 B("MSI", "MS-7253 (K9VGM-V)", OK, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
862 B("MSI", "MS-7255 (P4M890M)", OK, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
863 B("MSI", "MS-7260 (K9N Neo PCB 1.0)", BAD, "http://www.msi.com/product/mb/K9N-Neo--PCB-1-0-.html", "Interestingly flashrom does not work when the vendor BIOS is booted, but it ''does'' work flawlessly when the machine is booted with coreboot. Owned by Uwe Hermann <uwe@hermann-uwe.de>."),
Stefan Taunereb582572012-09-21 12:52:50 +0000864 B("MSI", "MS-7309 (K9N6SGM-V)", BAD, "http://www.msi.com/product/mb/K9N6SGM-V---K9N6PGM-FI---K9N6PGM-F.html", "Uses Fintek F71882F/F71883F/F71887 SPI-to-LPC translation."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000865 B("MSI", "MS-7309 (K9N6PGM2-V2)", OK, "http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
866 B("MSI", "MS-7312 (K9MM-V)", OK, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
867 B("MSI", "MS-7345 (P35 Neo2-FIR)", OK, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
868 B("MSI", "MS-7368 (K9AG Neo2-Digital)", OK, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
869 B("MSI", "MS-7369 (K9N Neo V2)", OK, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
870 B("MSI", "MS-7376 (K9A2 Platinum V1)", OK, "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
871 B("MSI", "MS-7529 (G31M3-L(S) V2)", OK, "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
872 B("MSI", "MS-7529 (G31TM-P21)", OK, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
873 B("MSI", "MS-7548 (Aspen-GL8E)", OK, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c01635688&lc=en&cc=us&dlc=en", NULL),
874 B("MSI", "MS-7596 (785GM-E51)", OK, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
875 B("MSI", "MS-7597 (GF615M-P33)", BAD, NULL, "Missing board enable/SIO support (Fintek F71889), see http://www.flashrom.org/pipermail/flashrom/2012-March/008956.html"),
876 B("MSI", "MS-7599 (870-C45)", OK, "http://www.msi.com/product/mb/870-C45.html", NULL),
877 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."),
878 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."),
879 B("MSI", "MS-7640 (890FXA-GD70)",OK, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
880 B("MSI", "MS-7642 (890GXM-G65)", OK, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
881 B("MSI", "MS-7676 (H67MA-ED55(B3))", OK, "http://www.msi.com/product/mb/H67MA-ED55--B3-.html", "Seems to work fine basically, but user reported (hopefully unrelated) buggy behavior of the board after a firmware upgrade. See http://www.flashrom.org/pipermail/flashrom/2012-January/008547.html"),
882 B("MSI", "MS-7676 (Z68MA-G45 (B3))", OK, "http://www.msi.com/product/mb/Z68MA-G45--B3-.html", NULL),
883 B("MSI", "MS-7696 (A75MA-G55)", OK, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
884 B("MSI", "MS-7698 (E350IA-E45)", OK, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
885 B("MSI", "MS-7740 (H61MA-E35(B3))", OK, "http://www.msi.com/product/mb/H61MA-E35--B3-.html", NULL),
886 B("NEC", "PowerMate 2000", OK, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
887 B("Nokia", "IP530", OK, NULL, NULL),
888 B("Palit", "N61S", OK, NULL, NULL),
889 B("PCCHIPS ", "M598LMR (V9.0)", OK, NULL, NULL),
890 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),
891 B("PC Engines", "Alix.1c", OK, "http://pcengines.ch/alix1c.htm", NULL),
892 B("PC Engines", "Alix.2c2", OK, "http://pcengines.ch/alix2c2.htm", NULL),
893 B("PC Engines", "Alix.2c3", OK, "http://pcengines.ch/alix2c3.htm", NULL),
894 B("PC Engines", "Alix.2d3", OK, "http://pcengines.ch/alix2d3.htm", NULL),
895 B("PC Engines", "Alix.3c3", OK, "http://pcengines.ch/alix3c3.htm", NULL),
896 B("PC Engines", "Alix.3d3", OK, "http://pcengines.ch/alix3d3.htm", NULL),
897 B("PC Engines", "Alix.6f2", OK, "http://pcengines.ch/alix6f2.htm", NULL),
898 B("PC Engines", "WRAP.2E", OK, "http://pcengines.ch/wrap2e1.htm", NULL),
899 B("Portwell", "PEB-4700VLA", OK, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
900 B("RCA", "RM4100", OK, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
901 B("Samsung", "Polaris 32", OK, NULL, NULL),
902 B("Shuttle", "AK31", OK, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
903 B("Shuttle", "AK38N", OK, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
904 B("Shuttle", "AV11V30", OK, NULL, NULL),
905 B("Shuttle", "AV18E2", OK, "http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
906 B("Shuttle", "FD37", OK, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
907 B("Shuttle", "FH67", OK, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
908 B("Shuttle", "FN25", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000909 B("Shuttle", "FN78S", OK, "http://www.shuttle.eu/products/discontinued/barebones/sn78sh7/", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000910 B("Shuttle", "X50/X50(B)", OK, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
911 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."),
912 B("Soyo", "SY-6BA+ III", OK, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
913 B("Soyo", "SY-7VCA", OK, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
914 B("Sun", "Blade x6250", OK, "http://www.sun.com/servers/blades/x6250/", NULL),
915 B("Sun", "Fire x4150", BAD, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
916 B("Sun", "Fire x4200", BAD, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
917 B("Sun", "Fire x4540", BAD, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
918 B("Sun", "Fire x4600", BAD, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
919 B("Sun", "Ultra 40 M2", OK, "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html", NULL),
920 B("Supermicro", "H8QC8", OK, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
921 B("Supermicro", "X5DP8-G2", OK, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
922 B("Supermicro", "X7DBT-INF", OK, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
923 B("Supermicro", "X7SPA-HF", OK, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H&IPMI=Y", NULL),
924 B("Supermicro", "X8DT3", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
925 B("Supermicro", "X8DTE-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=N", NULL),
926 B("Supermicro", "X8DTH-6F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
927 B("Supermicro", "X8DTT-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
928 B("Supermicro", "X8DTT-HIBQF", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm", NULL),
929 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."),
930 B("Supermicro", "X8DTU-F", OK, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
931 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)."),
932 B("Supermicro", "X8STi", OK, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
933 B("Supermicro", "X9DR3-F", BAD, "http://www.supermicro.com/products/motherboard/xeon/c600/x9dr3-f.cfm", "Probing works (Numonyx N25Q128 (supported by SFDP only atm), 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Taunereb582572012-09-21 12:52:50 +0000934 B("Supermicro", "X9QRi-F+", BAD, "http://www.supermicro.com/products/motherboard/Xeon/C600/X9QRi-F_.cfm", "Probing works (Macronix MX25L12805, 16384 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked; SMM protection enabled."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000935 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."),
936 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."),
937 B("T-Online", "S-100", OK, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
938 B("Tekram", "P6Pro-A5", OK, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
939 B("Termtek", "TK-3370 (Rev:2.5B)", OK, NULL, NULL),
940 B("Thomson", "IP1000", OK, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
941 B("TriGem", "Anaheim-3", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml", NULL),
942 B("TriGem", "Lomita", OK, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
943 B("Tyan", "S1846 (Tsunami ATX)", OK, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
944 B("Tyan", "S2466 (Tiger MPX)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
945 B("Tyan", "S2498 (Tomcat K7M)", OK, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
946 B("Tyan", "S2723 (Tiger i7501)", OK, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
947 B("Tyan", "S2875 (Tiger K8W)", OK, "http://www.tyan.com/archive/products/html/tigerk8w.html", NULL),
948 B("Tyan", "S2881 (Thunder K8SR)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
949 B("Tyan", "S2882-D (Thunder K8SD Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
950 B("Tyan", "S2882 (Thunder K8S Pro)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
951 B("Tyan", "S2891 (Thunder K8SRE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
952 B("Tyan", "S2892 (Thunder K8SE)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
953 B("Tyan", "S2895 (Thunder K8WE)", OK, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
954 B("Tyan", "S2912 (Thunder n3600R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
955 B("Tyan", "S2915-E (Thunder n6650W)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
956 B("Tyan", "S2915 (Thunder n6650W)", OK, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
957 B("Tyan", "S2933 (Thunder n3600S)", OK, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
958 B("Tyan", "S3095 (Tomcat i945GM)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
959 B("Tyan", "S3992 (Thunder h2000M)", OK, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
960 B("Tyan", "S5180 (Toledo i965R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
961 B("Tyan", "S5191 (Toledo i3000R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
962 B("Tyan", "S5197 (Toledo i3010W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
963 B("Tyan", "S5211-1U (Toledo i3200R)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
964 B("Tyan", "S5211 (Toledo i3210W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
965 B("Tyan", "S5220 (Toledo q35T)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
966 B("Tyan", "S5375-1U (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
967 B("Tyan", "S5375 (Tempest i5100X)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
968 B("Tyan", "S5376 (Tempest i5100W)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
969 B("Tyan", "S5377 (Tempest i5100T)", OK, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
970 B("Tyan", "S5382 (Tempest i5000PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
971 B("Tyan", "S5397 (Tempest i5400PW)", OK, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000972 B("VIA", "EITX-3000", OK, "http://www.viaembedded.com/en/products/boards/810/1/EITX-3000.html", NULL),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000973 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 */
974 B("VIA", "EPIA SP", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
975 B("VIA", "EPIA-CN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
976 B("VIA", "EPIA EK", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
977 B("VIA", "EPIA-EX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
978 B("VIA", "EPIA-LN", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
979 B("VIA", "EPIA-M700", OK, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
980 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 */
981 B("VIA", "EPIA-NX15000G", OK, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
982 B("VIA", "NAB74X0", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
983 B("VIA", "pc2500e", OK, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
984 B("VIA", "PC3500G", OK, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
985 B("VIA", "VB700X", OK, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
986 B("ZOTAC", "Fusion-ITX WiFi (FUSION350-A-E)", OK, NULL, NULL),
987 B("ZOTAC", "GeForce 8200", OK, NULL, NULL),
Stefan Taunereb582572012-09-21 12:52:50 +0000988 B("ZOTAC", "H61-ITX WiFi (H61ITX-A-E)", BAD, NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are problematic: descriptor is r/o (conforming to ICH reqs), ME region is locked."),
Stefan Tauner2c20b282012-07-28 19:35:26 +0000989 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."),
990 B("ZOTAC", "nForce 630i Supreme (N73U-Supreme)", OK, NULL, NULL),
991 B("ZOTAC", "ZBOX AD02 (PLUS)", OK, NULL, NULL),
992 B("ZOTAC", "ZBOX HD-ID11", OK, NULL, NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000993#endif
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000994
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +0000995 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000996};
997
998/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000999const struct board_info laptops_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001000#if defined(__i386__) || defined(__x86_64__)
Stefan Tauner2c20b282012-07-28 19:35:26 +00001001 B("Acer", "Aspire 1520", OK, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
1002 B("Acer", "Aspire One", BAD, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
1003 B("ASUS", "A8Jm", OK, NULL, NULL),
1004 B("ASUS", "Eee PC 701 4G", BAD, "http://www.asus.com/Eee/Eee_PC/Eee_PC_4G/", "It seems the chip (25X40VSIG) is behind some SPI flash translation layer (likely in the EC, the ENE KB3310)."),
1005 B("ASUS", "M6Ne", NT, "http://www.asus.com/Notebooks/Versatile_Performance/M6NNe/", "Untested board enable."),
1006 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."),
1007 B("Dell", "Inspiron 1420", OK, NULL, NULL),
1008 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."),
1009 B("Dell", "Vostro 3700", BAD, NULL, "Locked ME, see http://www.flashrom.org/pipermail/flashrom/2012-May/009197.html."),
1010 B("Dell", "Latitude E6520", BAD, NULL, "Locked ME, see http://www.flashrom.org/pipermail/flashrom/2012-June/009420.html."),
1011 B("HP/Compaq", "nx9005", BAD, "http://h18000.www1.hp.com/products/quickspecs/11602_na/11602_na.HTML", "Shuts down when probing for a chip. http://www.flashrom.org/pipermail/flashrom/2010-May/003321.html"),
1012 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)."),
1013 B("IBM/Lenovo", "Thinkpad T40p", BAD, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
1014 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)."),
1015 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)."),
1016 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)."),
1017 B("IBM/Lenovo", "240", BAD, "http://www.stanford.edu/~bresnan//tp240.html", "Seems to (partially) work at first, but one block/sector cannot be written which then leaves you with a bricked laptop. Maybe this can be investigated and fixed in software later."),
1018 B("Lenovo", "3000 V100 TF05Cxx", OK, "http://www5.pc.ibm.com/europe/products.nsf/products?openagent&brand=Lenovo3000Notebook&series=Lenovo+3000+V+Series#viewallmodelstop", NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001019#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001020
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +00001021 {0},
Uwe Hermannd0e347d2009-10-06 13:00:00 +00001022};
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +00001023#endif