blob: 85df596c893551e9fcbcc85aeb956feab432b571 [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);
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000035 if (bustype == BUS_UNKNOWN) {
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +000036 ret = strcat_realloc(ret, "Unknown, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000037 /*
38 * FIXME: Once all chipsets and flash chips have been updated, NONSPI
39 * will cease to exist and should be eliminated here as well.
40 */
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000041 } else if (bustype == BUS_NONSPI) {
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +000042 ret = strcat_realloc(ret, "Non-SPI, ");
Uwe Hermannba290d12009-06-17 12:07:12 +000043 } else {
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000044 if (bustype & BUS_PARALLEL)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000045 ret = strcat_realloc(ret, "Parallel, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000046 if (bustype & BUS_LPC)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000047 ret = strcat_realloc(ret, "LPC, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000048 if (bustype & BUS_FWH)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000049 ret = strcat_realloc(ret, "FWH, ");
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +000050 if (bustype & BUS_SPI)
Stefan Tauner355cbfd2011-05-28 02:37:14 +000051 ret = strcat_realloc(ret, "SPI, ");
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
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +000061static void 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 Hailfinger4c823182011-05-04 00:39:50 +000070 const struct flashchip *f;
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 */
Uwe Hermannba290d12009-06-17 12:07:12 +000076 for (f = flashchips; f->name != NULL; f++) {
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000077 /* Ignore "unknown XXXX SPI chip" entries. */
78 if (!strncmp(f->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +000079 continue;
Uwe Hermannba290d12009-06-17 12:07:12 +000080 chipcount++;
Stefan Tauner29e5d312011-09-12 22:55:01 +000081
82 /* Find maximum vendor length (respecting line splitting). */
83 tmpven = (char *)f->vendor;
84 do {
85 /* and take minimum token lengths into account */
86 tmpvenlen = 0;
87 do {
88 tmpvenlen += strcspn(tmpven, delim);
89 /* skip to the address after the first token */
90 tmpven += tmpvenlen;
91 if (tmpven[0] == '\0')
92 break;
93 tmpven++;
94 } while (tmpvenlen < mintoklen);
95 maxvendorlen = max(maxvendorlen, tmpvenlen);
96 if (tmpven[0] == '\0')
97 break;
98 } while (1);
99
100 /* same for device name */
101 tmpdev = (char *)f->name;
102 do {
103 tmpdevlen = 0;
104 do {
105 tmpdevlen += strcspn(tmpdev, delim);
106 tmpdev += tmpdevlen;
107 if (tmpdev[0] == '\0')
108 break;
109 tmpdev++;
110 } while (tmpdevlen < mintoklen);
111 maxchiplen = max(maxchiplen, tmpdevlen);
112 if (tmpdev[0] == '\0')
113 break;
114 } while (1);
115
116 s = flashbuses_to_text(f->bustype);
117 maxtypelen = max(maxtypelen, strlen(s));
118 free(s);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000119 }
Stefan Tauner29e5d312011-09-12 22:55:01 +0000120 maxvendorlen += border;
121 maxchiplen += border;
122 maxtypelen += border;
Uwe Hermannba290d12009-06-17 12:07:12 +0000123
Stefan Tauner12589362011-06-25 17:36:25 +0000124 msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
125 msg_ginfo("Vendor");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000126 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000127 msg_ginfo(" ");
128 msg_ginfo("Device");
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000129 for (i = strlen("Device"); i < maxchiplen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000130 msg_ginfo(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000131
Stefan Tauner29e5d312011-09-12 22:55:01 +0000132 msg_ginfo("Test");
133 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000134 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000135 msg_ginfo("Known");
136 for (i = 0; i < border; i++)
137 msg_ginfo(" ");
138 msg_ginfo(" Size");
139 for (i = 0; i < border; i++)
140 msg_ginfo(" ");
141
142 msg_ginfo("Type");
143 for (i = strlen("Type"); i < maxtypelen; i++)
144 msg_ginfo(" ");
145 msg_gdbg("Voltage");
146 msg_ginfo("\n");
147
148 for (i = 0; i < maxvendorlen + maxchiplen; i++)
149 msg_ginfo(" ");
150 msg_ginfo("OK ");
151 for (i = 0; i < border; i++)
152 msg_ginfo(" ");
153 msg_ginfo("Broken");
154 for (i = 0; i < border; i++)
155 msg_ginfo(" ");
156 msg_ginfo("[kB]");
157 for (i = 0; i < border + maxtypelen; i++)
158 msg_ginfo(" ");
159 msg_gdbg("range [V]");
160 msg_ginfo("\n\n");
Stefan Tauner12589362011-06-25 17:36:25 +0000161 msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE)\n\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000162
163 for (f = flashchips; f->name != NULL; f++) {
164 /* Don't print "unknown XXXX SPI chip" entries. */
165 if (!strncmp(f->name, "unknown", 7))
166 continue;
167
Stefan Tauner29e5d312011-09-12 22:55:01 +0000168 /* support for multiline vendor names:
169 * - make a copy of the original vendor name
170 * - use strok to put the first token in tmpven
171 * - keep track of the length of all tokens on the current line
172 * for ' '-padding in curvenlen
173 * - check if additional tokens should be printed on the current
174 * line
175 * - after all other values are printed print the surplus tokens
176 * on fresh lines
177 */
178 tmpven = malloc(strlen(f->vendor) + 1);
179 if (tmpven == NULL) {
180 msg_gerr("Out of memory!\n");
181 exit(1);
182 }
183 strcpy(tmpven, f->vendor);
Uwe Hermannba290d12009-06-17 12:07:12 +0000184
Stefan Tauner29e5d312011-09-12 22:55:01 +0000185 tmpven = strtok(tmpven, delim);
186 msg_ginfo("%s", tmpven);
187 curvenlen = strlen(tmpven);
188 while ((tmpven = strtok(NULL, delim)) != NULL) {
189 msg_ginfo("%s", delim);
190 curvenlen++;
191 tmpvenlen = strlen(tmpven);
192 if (tmpvenlen >= mintoklen)
193 break; /* big enough to be on its own line */
194 msg_ginfo("%s", tmpven);
195 curvenlen += tmpvenlen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000196 }
197
Stefan Tauner29e5d312011-09-12 22:55:01 +0000198 for (i = curvenlen; i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000199 msg_ginfo(" ");
Stefan Tauner29e5d312011-09-12 22:55:01 +0000200
201 /* support for multiline device names as above */
202 tmpdev = malloc(strlen(f->name) + 1);
203 if (tmpdev == NULL) {
204 msg_gerr("Out of memory!\n");
205 exit(1);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000206 }
Stefan Tauner29e5d312011-09-12 22:55:01 +0000207 strcpy(tmpdev, f->name);
208
209 tmpdev = strtok(tmpdev, delim);
210 msg_ginfo("%s", tmpdev);
211 curdevlen = strlen(tmpdev);
212 while ((tmpdev = strtok(NULL, delim)) != NULL) {
213 msg_ginfo("%s", delim);
214 curdevlen++;
215 tmpdevlen = strlen(tmpdev);
216 if (tmpdevlen >= mintoklen)
217 break; /* big enough to be on its own line */
218 msg_ginfo("%s", tmpdev);
219 curdevlen += tmpdevlen;
220 }
221
222 for (i = curdevlen; i < maxchiplen; i++)
223 msg_ginfo(" ");
224
225 if ((f->tested & TEST_OK_PROBE))
226 msg_ginfo("P");
227 else
228 msg_ginfo(" ");
229 if ((f->tested & TEST_OK_READ))
230 msg_ginfo("R");
231 else
232 msg_ginfo(" ");
233 if ((f->tested & TEST_OK_ERASE))
234 msg_ginfo("E");
235 else
236 msg_ginfo(" ");
237 if ((f->tested & TEST_OK_WRITE))
238 msg_ginfo("W");
239 else
240 msg_ginfo(" ");
241 for (i = 0; i < border; i++)
242 msg_ginfo(" ");
243
244 if ((f->tested & TEST_BAD_PROBE))
245 msg_ginfo("P");
246 else
247 msg_ginfo(" ");
248 if ((f->tested & TEST_BAD_READ))
249 msg_ginfo("R");
250 else
251 msg_ginfo(" ");
252 if ((f->tested & TEST_BAD_ERASE))
253 msg_ginfo("E");
254 else
255 msg_ginfo(" ");
256 if ((f->tested & TEST_BAD_WRITE))
257 msg_ginfo("W");
258 else
259 msg_ginfo(" ");
260 for (i = 0; i < border + 1; i++)
261 msg_ginfo(" ");
262
263 msg_ginfo("%5d", f->total_size);
264 for (i = 0; i < border; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000265 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000266
267 s = flashbuses_to_text(f->bustype);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000268 msg_ginfo("%s", s);
269 for (i = strlen(s); i < maxtypelen; i++)
270 msg_ginfo(" ");
Stefan Tauner00155492011-06-26 20:45:35 +0000271 free(s);
Stefan Tauner29e5d312011-09-12 22:55:01 +0000272
273 if (f->voltage.min == 0 && f->voltage.max == 0)
274 msg_gdbg("no info");
275 else
276 msg_gdbg("%0.02f;%0.02f",
277 f->voltage.min/(double)1000,
278 f->voltage.max/(double)1000);
279
280 /* print surplus vendor and device name tokens */
281 while (tmpven != NULL || tmpdev != NULL) {
282 msg_ginfo("\n");
283 if (tmpven != NULL){
284 msg_ginfo("%s", tmpven);
285 curvenlen = strlen(tmpven);
286 while ((tmpven = strtok(NULL, delim)) != NULL) {
287 msg_ginfo("%s", delim);
288 curvenlen++;
289 tmpvenlen = strlen(tmpven);
290 /* big enough to be on its own line */
291 if (tmpvenlen >= mintoklen)
292 break;
293 msg_ginfo("%s", tmpven);
294 curvenlen += tmpvenlen;
295 }
296 } else
297 curvenlen = 0;
298
299 for (i = curvenlen; i < maxvendorlen; i++)
300 msg_ginfo(" ");
301
302 if (tmpdev != NULL){
303 msg_ginfo("%s", tmpdev);
304 curdevlen = strlen(tmpdev);
305 while ((tmpdev = strtok(NULL, delim)) != NULL) {
306 msg_ginfo("%s", delim);
307 curdevlen++;
308 tmpdevlen = strlen(tmpdev);
309 /* big enough to be on its own line */
310 if (tmpdevlen >= mintoklen)
311 break;
312 msg_ginfo("%s", tmpdev);
313 curdevlen += tmpdevlen;
314 }
315 }
316 }
317 msg_ginfo("\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000318 }
319}
320
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000321#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000322static void print_supported_chipsets(void)
Uwe Hermannba290d12009-06-17 12:07:12 +0000323{
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000324 int i, chipsetcount = 0;
Uwe Hermannba290d12009-06-17 12:07:12 +0000325 const struct penable *c = chipset_enables;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000326 int maxvendorlen = strlen("Vendor") + 1;
327 int maxchipsetlen = strlen("Chipset") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000328
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000329 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Uwe Hermannba290d12009-06-17 12:07:12 +0000330 chipsetcount++;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000331 maxvendorlen = max(maxvendorlen, strlen(c->vendor_name));
332 maxchipsetlen = max(maxchipsetlen, strlen(c->device_name));
333 }
334 maxvendorlen++;
335 maxchipsetlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000336
Stefan Tauner12589362011-06-25 17:36:25 +0000337 msg_ginfo("Supported chipsets (total: %d):\n\n", chipsetcount);
Uwe Hermannba290d12009-06-17 12:07:12 +0000338
Stefan Tauner12589362011-06-25 17:36:25 +0000339 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000340 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000341 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000342
Stefan Tauner12589362011-06-25 17:36:25 +0000343 msg_ginfo("Chipset");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000344 for (i = strlen("Chipset"); i < maxchipsetlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000345 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000346
Stefan Tauner12589362011-06-25 17:36:25 +0000347 msg_ginfo("PCI IDs State\n\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000348
349 for (c = chipset_enables; c->vendor_name != NULL; c++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000350 msg_ginfo("%s", c->vendor_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000351 for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000352 msg_ginfo(" ");
353 msg_ginfo("%s", c->device_name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000354 for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000355 msg_ginfo(" ");
356 msg_ginfo("%04x:%04x%s\n", c->vendor_id, c->device_id,
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000357 (c->status == OK) ? "" : " (untested)");
Uwe Hermannba290d12009-06-17 12:07:12 +0000358 }
359}
360
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000361static void print_supported_boards_helper(const struct board_info *boards,
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000362 const char *devicetype)
Uwe Hermannba290d12009-06-17 12:07:12 +0000363{
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000364 int i, boardcount_good = 0, boardcount_bad = 0;
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000365 const struct board_match *e = board_matches;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000366 const struct board_info *b = boards;
367 int maxvendorlen = strlen("Vendor") + 1;
368 int maxboardlen = strlen("Board") + 1;
Uwe Hermannba290d12009-06-17 12:07:12 +0000369
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000370 for (b = boards; b->vendor != NULL; b++) {
371 maxvendorlen = max(maxvendorlen, strlen(b->vendor));
372 maxboardlen = max(maxboardlen, strlen(b->name));
373 if (b->working)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000374 boardcount_good++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000375 else
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000376 boardcount_bad++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000377 }
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000378 maxvendorlen++;
379 maxboardlen++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000380
Stefan Tauner12589362011-06-25 17:36:25 +0000381 msg_ginfo("Known %s (good: %d, bad: %d):\n\n",
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000382 devicetype, boardcount_good, boardcount_bad);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000383
Stefan Tauner12589362011-06-25 17:36:25 +0000384 msg_ginfo("Vendor");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000385 for (i = strlen("Vendor"); i < maxvendorlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000386 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000387
Stefan Tauner12589362011-06-25 17:36:25 +0000388 msg_ginfo("Board");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000389 for (i = strlen("Board"); i < maxboardlen; i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000390 msg_ginfo(" ");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000391
Stefan Tauner12589362011-06-25 17:36:25 +0000392 msg_ginfo("Status Required option\n\n");
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000393
394 for (b = boards; b->vendor != NULL; b++) {
Stefan Tauner12589362011-06-25 17:36:25 +0000395 msg_ginfo("%s", b->vendor);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000396 for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000397 msg_ginfo(" ");
398 msg_ginfo("%s", b->name);
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000399 for (i = 0; i < maxboardlen - strlen(b->name); i++)
Stefan Tauner12589362011-06-25 17:36:25 +0000400 msg_ginfo(" ");
401 msg_ginfo((b->working) ? "OK " : "BAD ");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000402
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +0000403 for (e = board_matches; e->vendor_name != NULL; e++) {
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000404 if (strcmp(e->vendor_name, b->vendor)
405 || strcmp(e->board_name, b->name))
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000406 continue;
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000407 if (e->lb_vendor == NULL)
Stefan Tauner12589362011-06-25 17:36:25 +0000408 msg_ginfo("(autodetected)");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000409 else
Stefan Tauner12589362011-06-25 17:36:25 +0000410 msg_ginfo("-m %s:%s", e->lb_vendor,
Stefan Tauner7bcacb12011-05-26 01:35:19 +0000411 e->lb_part);
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000412 }
Stefan Tauner12589362011-06-25 17:36:25 +0000413 msg_ginfo("\n");
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000414 }
Uwe Hermannba290d12009-06-17 12:07:12 +0000415}
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000416#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000417
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000418void print_supported(void)
419{
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000420 print_supported_chips();
421
Stefan Tauner12589362011-06-25 17:36:25 +0000422 msg_ginfo("\nSupported programmers:\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000423 list_programmers_linebreak(0, 80, 0);
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000424#if CONFIG_INTERNAL == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000425 msg_ginfo("\nSupported devices for the %s programmer:\n\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000426 programmer_table[PROGRAMMER_INTERNAL].name);
427 print_supported_chipsets();
Stefan Tauner12589362011-06-25 17:36:25 +0000428 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000429 print_supported_boards_helper(boards_known, "boards");
Stefan Tauner12589362011-06-25 17:36:25 +0000430 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000431 print_supported_boards_helper(laptops_known, "laptops");
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000432#endif
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000433#if CONFIG_DUMMY == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000434 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000435 programmer_table[PROGRAMMER_DUMMY].name);
436 /* FIXME */
Stefan Tauner12589362011-06-25 17:36:25 +0000437 msg_ginfo("Dummy device, does nothing and logs all accesses\n");
Adam Jurkowski516f9322009-12-14 03:07:31 +0000438#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000439#if CONFIG_NIC3COM == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000440 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000441 programmer_table[PROGRAMMER_NIC3COM].name);
442 print_supported_pcidevs(nics_3com);
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000443#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000444#if CONFIG_NICREALTEK == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000445 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000446 programmer_table[PROGRAMMER_NICREALTEK].name);
447 print_supported_pcidevs(nics_realtek);
Uwe Hermann829ed842010-05-24 17:39:14 +0000448#endif
Andrew Morgan74a828a2010-07-21 15:12:07 +0000449#if CONFIG_NICNATSEMI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000450 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000451 programmer_table[PROGRAMMER_NICNATSEMI].name);
452 print_supported_pcidevs(nics_natsemi);
Andrew Morgan74a828a2010-07-21 15:12:07 +0000453#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000454#if CONFIG_GFXNVIDIA == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000455 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000456 programmer_table[PROGRAMMER_GFXNVIDIA].name);
457 print_supported_pcidevs(gfx_nvidia);
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000458#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000459#if CONFIG_DRKAISER == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000460 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000461 programmer_table[PROGRAMMER_DRKAISER].name);
462 print_supported_pcidevs(drkaiser_pcidev);
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000463#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000464#if CONFIG_SATASII == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000465 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000466 programmer_table[PROGRAMMER_SATASII].name);
467 print_supported_pcidevs(satas_sii);
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000468#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000469#if CONFIG_ATAHPT == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000470 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000471 programmer_table[PROGRAMMER_ATAHPT].name);
472 print_supported_pcidevs(ata_hpt);
473#endif
474#if CONFIG_FT2232_SPI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000475 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000476 programmer_table[PROGRAMMER_FT2232_SPI].name);
477 print_supported_usbdevs(devs_ft2232spi);
478#endif
479#if CONFIG_SERPROG == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000480 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000481 programmer_table[PROGRAMMER_SERPROG].name);
482 /* FIXME */
Stefan Tauner12589362011-06-25 17:36:25 +0000483 msg_ginfo("All programmer devices speaking the serprog protocol\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000484#endif
485#if CONFIG_BUSPIRATE_SPI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000486 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000487 programmer_table[PROGRAMMER_BUSPIRATE_SPI].name);
488 /* FIXME */
Stefan Tauner12589362011-06-25 17:36:25 +0000489 msg_ginfo("Dangerous Prototypes Bus Pirate\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000490#endif
491#if CONFIG_DEDIPROG == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000492 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000493 programmer_table[PROGRAMMER_DEDIPROG].name);
494 /* FIXME */
Stefan Tauner12589362011-06-25 17:36:25 +0000495 msg_ginfo("Dediprog SF100\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000496#endif
497#if CONFIG_RAYER_SPI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000498 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000499 programmer_table[PROGRAMMER_RAYER_SPI].name);
500 /* FIXME */
Stefan Tauner12589362011-06-25 17:36:25 +0000501 msg_ginfo("RayeR parallel port programmer\n");
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +0000502#endif
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000503#if CONFIG_NICINTEL == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000504 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000505 programmer_table[PROGRAMMER_NICINTEL].name);
506 print_supported_pcidevs(nics_intel);
507#endif
Idwer Vollering004f4b72010-09-03 18:21:21 +0000508#if CONFIG_NICINTEL_SPI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000509 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +0000510 programmer_table[PROGRAMMER_NICINTEL_SPI].name);
511 print_supported_pcidevs(nics_intel_spi);
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000512#endif
Mark Marshall90021f22010-12-03 14:48:11 +0000513#if CONFIG_OGP_SPI == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000514 msg_ginfo("\nSupported devices for the %s programmer:\n",
Mark Marshall90021f22010-12-03 14:48:11 +0000515 programmer_table[PROGRAMMER_OGP_SPI].name);
516 print_supported_pcidevs(ogp_spi);
517#endif
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000518#if CONFIG_SATAMV == 1
Stefan Tauner12589362011-06-25 17:36:25 +0000519 msg_ginfo("\nSupported devices for the %s programmer:\n",
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000520 programmer_table[PROGRAMMER_SATAMV].name);
521 print_supported_pcidevs(satas_mv);
522#endif
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000523}
524
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000525#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger4146ced2010-06-07 11:10:43 +0000526
527#ifdef CONFIG_PRINT_WIKI
528#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
529#else
530#define B(vendor, name, status, url, note) { vendor, name, status }
531#endif
532
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000533/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000534const struct board_info boards_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000535#if defined(__i386__) || defined(__x86_64__)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000536 B("A-Trend", "ATC-6220", 1, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000537 B("abit", "AN-M2", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20AM2&pMODEL_NAME=AN-M2", NULL),
Christoph Grenzd13a3942011-10-21 13:20:11 +0000538 B("abit", "AV8", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AV8", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000539 B("abit", "AX8", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AX8", NULL),
Tim ter Laak4b933f02010-09-13 23:00:57 +0000540 B("abit", "BM6", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=BM6&fMTYPE=Socket%20370", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000541 B("abit", "Fatal1ty F-I90HD", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=Fatal1ty+F-I90HD&fMTYPE=LGA775", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000542 B("abit", "IC7", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IC7&fMTYPE=Socket%20478", NULL),
543 B("abit", "IP35", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000544 B("abit", "IP35 Pro", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35%20Pro", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000545 B("abit", "IS-10", 0, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IS-10&fMTYPE=Socket+478", "Reported by deejkuba@aol.com to flashrom@coreboot.org, no public archive. Missing board enable and/or M50FW040 unlocking. May work now."),
Benjamin Bellecff562672011-07-12 22:01:44 +0000546 B("abit", "KN8 Ultra", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=KN8%20Ultra", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000547 B("abit", "NF-M2 nView", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20AM2&pMODEL_NAME=NF-M2%20nView", NULL),
548 B("abit", "NF7-S", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20A&pMODEL_NAME=NF7-S", NULL),
Mattias Mattssone3df96e2010-08-15 22:43:23 +0000549 B("abit", "VA6", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VA6", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000550 B("abit", "VT6X4", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VT6X4", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000551 B("Acorp", "6A815EPD", 1, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
552 B("Advantech", "PCM-5820", 1, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
553 B("agami", "Aruma", 1, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
554 B("Albatron", "PM266A Pro", 1, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
555 B("AOpen", "vKM400Am-S", 1, "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
556 B("Artec Group","DBE61", 1, "http://wiki.thincan.org/DBE61", NULL),
557 B("Artec Group","DBE62", 1, "http://wiki.thincan.org/DBE62", NULL),
558 B("ASI", "MB-5BLMP", 1, "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III thin client."),
Joshua Roys7507de42010-08-08 16:05:23 +0000559 B("ASRock", "775i65G", 1, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
Yul Rottmann6d6ab742011-03-05 16:31:57 +0000560 B("ASRock", "890GX Extreme3", 1, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000561 B("ASRock", "939A785GMH/128M", 1, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000562 B("ASRock", "A330GC", 1, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000563 B("ASRock", "A770CrossFire", 1, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000564 B("ASRock", "ALiveNF6G-DVI", 1, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
Uwe Hermann17da61e2010-10-05 21:48:43 +0000565 B("ASRock", "K7S41", 1, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
Pawel Rozanski1d233072011-06-19 16:52:48 +0000566 B("ASRock", "K7S41GX", 1, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000567 B("ASRock", "K7VT4A+", 0, "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"),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000568 B("ASRock", "K8S8X", 1, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000569 B("ASRock", "M3A790GXH/128M", 1, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
570 B("ASRock", "P4i65GV", 1, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000571 B("ASUS", "A7N8X Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=wAsRYm41KTp78MFC", NULL),
572 B("ASUS", "A7N8X-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=TmQtPJv4jIxmL9C2", NULL),
573 B("ASUS", "A7V133", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socka/kt133a/a7v133/", NULL),
Uwe Hermann45bd1442010-09-14 23:20:35 +0000574 B("ASUS", "A7V333", 1, "ftp://ftp.asus.com.tw/pub/asus/mb/socka/kt333/a7v333/", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000575 B("ASUS", "A7V400-MX", 1, "http://www.asus.com/product.aspx?P_ID=hORgEHRBDLMfwAwx", NULL),
576 B("ASUS", "A7V600-X", 1, "http://www.asus.com/product.aspx?P_ID=L2XYS0rmtCjeOr4k", NULL),
577 B("ASUS", "A7V8X", 1, "http://www.asus.com/product.aspx?P_ID=qfpaGrAy2kLVo0f2", NULL),
578 B("ASUS", "A7V8X-MX", 1, "http://www.asus.com/product.aspx?P_ID=SEJOOYqfuQPitx2H", NULL),
579 B("ASUS", "A7V8X-MX SE", 1, "http://www.asus.com/product.aspx?P_ID=1guVBT1qV5oqhHyZ", NULL),
580 B("ASUS", "A7V8X-X", 1, "http://www.asus.com/product.aspx?P_ID=YcXfRrWHZ9RKoVmw", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000581 B("ASUS", "A8Jm", 1, "http://www.asus.com/product.aspx?P_ID=VztICtOgiU6drx4m", NULL),
Stefan Taunera9cbbac2011-08-07 13:17:20 +0000582 B("ASUS", "A8M2N-LA (NodusM3-GL8E)", 1, "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."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000583 B("ASUS", "A8N-E", 1, "http://www.asus.com/product.aspx?P_ID=DzbA8hgqchMBOVRz", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000584 B("ASUS", "A8N-LA (Nagami-GL8E)", 1, "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."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000585 B("ASUS", "A8N-SLI", 1, "http://www.asus.com/product.aspx?P_ID=J9FKa8z2xVId3pDK", NULL),
Stefan Tauner2414e092011-08-06 16:16:45 +0000586 B("ASUS", "A8N-SLI Deluxe", 0, NULL, "Untested board enable."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000587 B("ASUS", "A8N-SLI Premium", 1, "http://www.asus.com/product.aspx?P_ID=nbulqxniNmzf0mH1", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000588 B("ASUS", "A8N-VM", 1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
Michael Karcher7af6cef2010-07-08 09:32:18 +0000589 B("ASUS", "A8N-VM CSM", 1, "http://www.asus.com/product.aspx?P_ID=JBqqlpj4cspbSa3s", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000590 B("ASUS", "A8NE-FM/S", 1, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
591 B("ASUS", "A8V Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=tvpdgPNCPaABZRVU", NULL),
592 B("ASUS", "A8V-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=hQBPIJWEZnnGAZEh", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000593 B("ASUS", "A8V-E SE", 1, "http://www.asus.com/product.aspx?P_ID=VMfiJJRYTHM4gXIi", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
Paul Menzel018d4822011-10-21 12:33:07 +0000594 B("ASUS", "Crosshair II Formula", 1, "http://www.asus.com/product.aspx?P_ID=EIDxaW1Ln3YR9RA2", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000595 B("ASUS", "Crosshair IV Extreme", 1, "http://www.asus.com/product.aspx?P_ID=lt1ShF6xEn3rlLe7", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000596 B("ASUS", "E35M1-I DELUXE", 1, "http://www.asus.com/product.aspx?P_ID=9BmKhMwWCwqyl1lz", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000597 B("ASUS", "K8N", 1, "http://www.asus.com/product.aspx?P_ID=zigzffr75jWJ7j2y", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000598 B("ASUS", "K8V", 1, "http://www.asus.com/product.aspx?P_ID=fG2KZOWF7v6MRFRm", NULL),
599 B("ASUS", "K8V SE Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=65HeDI8XM1u6Uy6o", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000600 B("ASUS", "K8V-X", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000601 B("ASUS", "K8V-X SE", 1, "http://www.asus.com/product.aspx?P_ID=lzDXlbBVHkdckHVr", NULL),
602 B("ASUS", "M2A-MX", 1, "http://www.asus.com/product.aspx?P_ID=BmaOnPewi1JgltOZ", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000603 B("ASUS", "M2A-VM", 1, "http://www.asus.com/product.aspx?P_ID=St3pWpym8xXpROQS", "See http://www.coreboot.org/pipermail/coreboot/2007-September/025281.html"),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000604 B("ASUS", "M2N32-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=0jMy2X8lKstYRvev", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000605 B("ASUS", "M2N-E", 1, "http://www.asus.com/product.aspx?P_ID=NFlvt10av3F7ayQ9", "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"),
Paul Menzel018d4822011-10-21 12:33:07 +0000606 B("ASUS", "M2N-E SLI", 1, "http://www.asus.com/product.aspx?P_ID=NJ8fkR6ufRM9XvFC", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000607 B("ASUS", "M2N-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=szSFtrap7crpBaQE", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000608 B("ASUS", "M2NBP-VM CSM", 1, "http://www.asus.com/product.aspx?P_ID=MnOfzTGd2KkwG0rF", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000609 B("ASUS", "M2NPV-VM", 1, "http://www.asus.com/product.aspx?P_ID=HGTVnGv5nGahCYgK", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000610 B("ASUS", "M2V", 1, "http://www.asus.com/product.aspx?P_ID=OqYlEDFfF6ZqZGvp", NULL),
611 B("ASUS", "M2V-MX", 1, "http://www.asus.com/product.aspx?P_ID=7grf8Ci4yxnqzt3z", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000612 B("ASUS", "M3A", 1, "http://www.asus.com/product.aspx?P_ID=P48rppKk4jrc9pNd", NULL),
613 B("ASUS", "M3A76-CM", 1, "http://www.asus.com/product.aspx?P_ID=aU8effdifLvraVze", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000614 B("ASUS", "M3A78-EM", 1, "http://www.asus.com/product.aspx?P_ID=KjpYqzmAd9vsTM2D", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000615 B("ASUS", "M3N78-VM", 1, "http://www.asus.com/product.aspx?P_ID=ovqEgLFRjnSClhSV", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000616 B("ASUS", "M4A78-EM", 1, "http://www.asus.com/product.aspx?P_ID=0KyowHKUFAQqH2DO", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000617 B("ASUS", "M4A785TD-V EVO", 1, "http://www.asus.com/product.aspx?P_ID=fcsXWSxnhzZE9rnR", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000618 B("ASUS", "M4A785TD-M EVO", 1, "http://www.asus.com/product.aspx?P_ID=QHbvGVB1mXmmD8qQ", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000619 B("ASUS", "M4A78LT-M LE", 1, "http://www.asus.com/product.aspx?P_ID=exJL00uovTJaDqxR", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000620 B("ASUS", "M4A79T Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=lhJiLTN5huPfCVkW", NULL),
621 B("ASUS", "M4A87TD/USB3", 1, "http://www.asus.com/product.aspx?P_ID=nlWYrI9wlNIYHAaa", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000622 B("ASUS", "M4A89GTD PRO", 1, "http://www.asus.com/product.aspx?P_ID=Gdf0vtpVf72LTYgs", NULL),
Joshua Roysc73e2812011-07-09 19:46:53 +0000623 B("ASUS", "M6Ne", 0, "http://www.asus.com/Product.aspx?P_ID=IbqN4JCxeRiep4WN", "Untested board enable."),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000624 B("ASUS", "MEW-AM", 0, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock370/810/mew-am/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
625 B("ASUS", "MEW-VM", 0, "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."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000626 B("ASUS", "P2B", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b/", NULL),
627 B("ASUS", "P2B-D", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
628 B("ASUS", "P2B-DS", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-ds/", NULL),
629 B("ASUS", "P2B-F", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
Mattias Mattsson85016b92010-09-01 01:21:34 +0000630 B("ASUS", "P2B-N", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-n/", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000631 B("ASUS", "P2E-M", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440ex/p2e-m/", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000632 B("ASUS", "P2L97-S", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440lx/p2l97-s/", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000633 B("ASUS", "P3B-F", 0, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p3b-f/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000634 B("ASUS", "P4B266", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b266/", NULL),
635 B("ASUS", "P4B266-LM", 1, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000636 B("ASUS", "P4B533-E", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b533-e/", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000637 B("ASUS", "P4C800-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=cFuVCr9bXXCckmcK", NULL),
Michael Karcherf4b58792010-09-10 14:54:18 +0000638 B("ASUS", "P4P800", 1, "http://www.asus.com/product.aspx?P_ID=DYt1Et9MlBChqzLb", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000639 B("ASUS", "P4P800-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=INIJUvLlif7LHp3g", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000640 B("ASUS", "P4P800-VM", 1, NULL, NULL),
Mattias Mattssonfb60cec2010-09-13 19:39:25 +0000641 B("ASUS", "P4SC-E", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4sc-e/", "Part of ASUS Terminator P4 533 barebone system"),
Michael Karcher87c90992010-07-24 11:03:48 +0000642 B("ASUS", "P4SD-LA", 1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000643 B("ASUS", "P4S533-X", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4s533-x/", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000644 B("ASUS", "P4S800-MX", 1, "http://www.asus.com/product.aspx?P_ID=Bb57zoJhmO1Qkcrh", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000645 B("ASUS", "P5A", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock7/ali/p5a/", NULL),
646 B("ASUS", "P5B", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B/", NULL),
647 B("ASUS", "P5B-Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=bswT66IBSb2rEWNa", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000648 B("ASUS", "P5BV-M", 0, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B-VM/", "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."),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000649 B("ASUS", "P5GC-MX/1333", 1, "http://www.asus.com/product.aspx?P_ID=PYvbfOokwxUzJky3", NULL),
Joshua Roys1fd4f9e2011-08-11 05:47:32 +0000650 B("ASUS", "P5GD2 Premium", 1, "http://www.asus.it/product.aspx?P_ID=lRKaz1Rb6Xb0OFM7", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000651 B("ASUS", "P5GDC Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=AbeoopyNpI2TZixg", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000652 B("ASUS", "P5KC", 1, "http://www.asus.com/product.aspx?P_ID=fFZ8oUIGmLpwNMjj", NULL),
653 B("ASUS", "P5L-MX", 1, "http://www.asus.com/product.aspx?P_ID=X70d3NCzH2DE9vWH", NULL),
Joshua Roysac8b2a12011-08-11 04:21:34 +0000654 B("ASUS", "P5LD2", 0, NULL, "Untested board enable."),
Michael Karcher14ab8d42011-08-25 14:06:50 +0000655 B("ASUS", "P5LP-LE (Lithium-UL8E)", 1, "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."),
656 B("ASUS", "P5LP-LE (Epson OEM)", 1, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
657 B("ASUS", "P5LP-LE", 0, 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."),
Michael Karcher4a23e442010-09-10 14:46:46 +0000658 B("ASUS", "P5GD1 Pro", 1, "http://www.asus.com/product.aspx?P_ID=50M49xQh71EZOeM1", NULL),
Stefan Tauneraf4b1582011-08-06 16:16:33 +0000659 B("ASUS", "P5N-E SLI", 0, "http://www.asus.com/product.aspx?P_ID=KyHOsOKWujC2QguJ", "Needs a board enable (http://patchwork.coreboot.org/patch/3298/)."),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000660 B("ASUS", "P5N32-E SLI", 1, "http://www.asus.com/product.aspx?P_ID=vBZLIBtPzYB2bLcb", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000661 B("ASUS", "P5ND2-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=WY7XroDuUImVbgp5", NULL),
Michael Karcher72eeab52010-07-24 10:41:42 +0000662 B("ASUS", "P5PE-VM", 1, "http://www.asus.com/product.aspx?P_ID=k3h0ZFVu9Lo1dUvk", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000663 B("ASUS", "P5VD1-X", 1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000664 B("ASUS", "P6T SE", 1, "http://www.asus.com/product.aspx?P_ID=t4yhK6y9W9o7iQ9E", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000665 B("ASUS", "P6T Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=vXixf82co6Q5v0BZ", NULL),
666 B("ASUS", "P6T Deluxe V2", 1, "http://www.asus.com/product.aspx?P_ID=iRlP8RG9han6saZx", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000667 B("ASUS", "P7H57D-V EVO", 1, "http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000668 B("ASUS", "P7H55-M LX", 0, 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)"),
Paul Menzel018d4822011-10-21 12:33:07 +0000669 B("ASUS", "P8B-E/4L", 0, 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."),
670 B("ASUS", "P8B WS", 0, 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."),
Uwe Hermanna3473242010-09-14 22:59:39 +0000671 B("ASUS", "Z8NA-D6C", 1, "http://www.asus.com/product.aspx?P_ID=k81cpN8uEB01BpQ6", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000672 B("BCOM", "WinNET100", 1, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000673 B("Biostar", "N68S3+", 1, NULL, NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000674 B("Biostar", "M6TBA", 0, "ftp://ftp.biostar-usa.com/manuals/M6TBA/", "No public report found. Owned by Uwe Hermann <uwe@hermann-uwe.de>. May work now."),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000675 B("Biostar", "M7NCD Pro", 1, "http://www.biostar.com.tw/app/en/mb/content.php?S_ID=260", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000676 B("Biostar", "P4M80-M4", 1, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
Daniel Lenskib9e2cb52010-07-30 17:08:29 +0000677 B("Biostar", "TA780G M2+", 1, "http://www.biostar.com.tw/app/en/t-series/content.php?S_ID=344", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000678 B("Boser", "HS-6637", 0, "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."),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000679 B("Congatec", "conga-X852", 1, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
Mattias Mattsson2eaad632010-10-05 21:32:29 +0000680 B("Dell", "OptiPlex GX1", 1, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000681 B("Dell", "PowerEdge 1850", 1, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000682 B("DFI", "855GME-MGF", 0, "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"),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000683 B("DFI", "Blood-Iron P35 T2RL", 1, "http://lp.lanparty.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?itemId=516&downloadFlag=false&action=1", NULL),
Mattias Mattssonf4925162010-09-16 22:09:18 +0000684 B("Elitegroup", "GeForce6100SM-M ", 1, "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=685&MenuID=24", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000685 B("Elitegroup", "K7S5A", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=279&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0", NULL),
686 B("Elitegroup", "K7S6A", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=77&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
687 B("Elitegroup", "K7VTA3", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=264&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000688 B("Elitegroup", "P4M800PRO-M (V1.0A)", 1, "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&DetailID=574&DetailName=Feature&MenuID=52&LanID=0", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000689 B("Elitegroup", "P4VXMS (V1.0A)", 1, NULL, NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000690 B("Elitegroup", "P6IWP-Fe", 1, "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&TypeID=3&DetailID=95&DetailName=Feature&MenuID=1&LanID=0", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000691 B("Elitegroup", "P6VAP-A+", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=117&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0", NULL),
Daniel Lenskib9e2cb52010-07-30 17:08:29 +0000692 B("Elitegroup", "RS485M-M", 1, "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&DetailID=654&DetailName=Feature&MenuID=1&LanID=0", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000693 B("Emerson", "ATCA-7360", 1, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000694 B("EPoX", "EP-8K5A2", 1, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
Stefan Tauneraf4b1582011-08-06 16:16:33 +0000695 B("EPoX", "EP-8NPA7I", 1, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
696 B("EPoX", "EP-9NPA7I", 1, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000697 B("EPoX", "EP-8RDA3+", 1, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
698 B("EPoX", "EP-BX3", 1, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
Stefan Tauner93f70232011-07-26 14:33:46 +0000699 B("EVGA", "132-CK-NF78", 1, "http://www.evga.com/articles/385.asp", NULL),
Stefan Tauneref101752011-05-18 01:32:09 +0000700 B("EVGA", "270-WS-W555-A2 (Classified SR-2)", 1, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000701 B("FIC", "VA-502", 0, "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."),
Michael Karcher2842db32011-04-14 23:14:27 +0000702 B("Foxconn", "6150K8MD-8EKRSH", 1, "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000157", NULL),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000703 B("Foxconn", "A6VMX", 1, "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000346", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000704 B("Foxconn", "P4M800P7MA-RS2", 1, "http://www.foxconnchannel.com/Product/Motherboards/detail_overview.aspx?id=en-us0000138", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000705 B("Freetech", "P6F91i", 1, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000706 B("Fujitsu-Siemens", "ESPRIMO P5915", 1, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/professionalpc/ESPRIMO/P/EsprimoP5915-6.htm", "Mainboard model is D2312-A2."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000707 B("GIGABYTE", "GA-2761GXDK", 1, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000708 B("GIGABYTE", "GA-6BXC", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
709 B("GIGABYTE", "GA-6BXDU", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
Michael Karcher39dcdec2010-10-05 17:29:35 +0000710 B("GIGABYTE", "GA-6IEM", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000711 B("GIGABYTE", "GA-6VXE7+", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000712 B("GIGABYTE", "GA-6ZMA", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000713 B("GIGABYTE", "GA-MA785GMT-UD2H (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
714 B("GIGABYTE", "GA-770TA-UD3", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
715 B("GIGABYTE", "GA-7DXR", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000716 B("GIGABYTE", "GA-7VT600", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
717 B("GIGABYTE", "GA-7ZM", 1, "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."),
Uwe Hermann4335ec82011-09-07 20:20:25 +0000718 B("GIGABYTE", "GA-8I945GZME-RH", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
Joshua Roys9d9a1042011-06-13 16:59:01 +0000719 B("GIGABYTE", "GA-8IP775", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
Michael Karcherc7a1ffb2010-07-24 22:27:29 +0000720 B("GIGABYTE", "GA-8IRML", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
Michael Karcherc8613242010-08-13 12:49:01 +0000721 B("GIGABYTE", "GA-8PE667 Ultra 2", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000722 B("GIGABYTE", "GA-8SIMLH", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
723 B("GIGABYTE", "GA-945PL-S3P (rev. 6.6)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000724 B("GIGABYTE", "GA-965GM-S2 (rev. 2.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000725 B("GIGABYTE", "GA-965P-DS4", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
726 B("GIGABYTE", "GA-EP35-DS3L", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
727 B("GIGABYTE", "GA-EX58-UD4P", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
728 B("GIGABYTE", "GA-K8N-SLI", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
Michael Karcher242efd42011-03-06 12:09:05 +0000729 B("GIGABYTE", "GA-K8N51GMF", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
Joshua Roys2ee137f2010-09-07 17:52:09 +0000730 B("GIGABYTE", "GA-K8N51GMF-9", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000731 B("GIGABYTE", "GA-K8NS Pro-939", 0, "http://www.gigabyte.com/products/product-page.aspx?pid=1875", "Untested board enable."),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000732 B("GIGABYTE", "GA-M57SLI-S4", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
733 B("GIGABYTE", "GA-M61P-S3", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000734 B("GIGABYTE", "GA-M720-US3", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000735 B("GIGABYTE", "GA-MA69VM-S2", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
Peter Lemenkov12a58b22010-07-29 21:15:45 +0000736 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000737 B("GIGABYTE", "GA-MA770-UD3 (rev. 2.1)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000738 B("GIGABYTE", "GA-MA770T-UD3P", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
Bernhard Geier94b36092011-03-06 22:16:30 +0000739 B("GIGABYTE", "GA-MA780G-UD3H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
Yul Rottmann6d6ab742011-03-05 16:31:57 +0000740 B("GIGABYTE", "GA-MA78G-DS3H (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000741 B("GIGABYTE", "GA-MA78GM-S2H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2758", NULL), /* TODO: Rev. 1.0, 1.1, or 2.x? */
742 B("GIGABYTE", "GA-MA78GPM-DS2H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
743 B("GIGABYTE", "GA-MA790FX-DQ6", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
744 B("GIGABYTE", "GA-MA790GP-DS4H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
Stefan Tauner67fbd772011-05-18 01:31:39 +0000745 B("GIGABYTE", "GA-MA790XT-UD4P (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
Stefan Taunerd06d9412011-06-12 19:47:55 +0000746 B("GIGABYTE", "GA-P55A-UD4 (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000747 B("GIGABYTE", "GA-P67A-UD3P", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000748 B("GIGABYTE", "GA-X58A-UD7 (rev. 2.0)", 1, NULL, NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000749 B("GIGABYTE", "GA-Z68MX-UD2H-B (rev. 1.3)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
Michael Karchercba52de2011-03-06 12:07:19 +0000750 B("HP", "e-Vectra P2706T", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000751 B("HP", "ProLiant DL145 G3", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00816835&lang=en&cc=us&taskId=101&prodSeriesId=3219755&prodTypeId=15351", NULL),
752 B("HP", "ProLiant DL165 G6", 1, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
Michael Karchere57957c2010-07-24 11:14:37 +0000753 B("HP", "Puffer2-UL8E", 1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000754 B("HP", "Vectra VL400", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
755 B("HP", "Vectra VL420 SFF", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000756 B("HP", "xw4400 (0A68h)", 0, "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"),
757 B("HP", "xw9400", 1, "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."),
Uwe Hermannead705f2010-08-15 15:26:30 +0000758 B("IBASE", "MB899", 1, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000759 B("IBM", "x3455", 1, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000760 B("IEI", "PICOe-9452", 1, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000761 B("Intel", "D201GLY", 1, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000762 B("Intel", "D865GLC", 0, NULL, "ICH5 with BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
Stefan Tauner82f54e52011-05-18 01:31:17 +0000763 B("Intel", "DG45ID", 0, "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."),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000764 B("Intel", "DH67CF", 0, NULL, "H67 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000765 B("Intel", "EP80759", 1, NULL, NULL),
Uwe Hermanna3473242010-09-14 22:59:39 +0000766 B("Intel", "Foxhollow", 1, NULL, "Intel reference board."),
767 B("Intel", "Greencity", 1, NULL, "Intel reference board."),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000768 B("Intel", "SE440BX-2", 0, "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"),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000769 B("IWILL", "DK8-HTX", 1, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
Stefan Tauner93f70232011-07-26 14:33:46 +0000770 B("Jetway", "J-7BXAN", 1, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
771 B("Jetway", "J7F4K1G5D-PB", 1, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000772 B("Kontron", "986LCD-M", 1, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000773 B("Lanner", "EM-8510C", 1, NULL, NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000774 B("Lex", "CV700A", 1, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000775 B("Mitac", "6513WU", 1, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000776 B("MSI", "MS-6153", 1, "http://www.msi.com/product/mb/MS-6153.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000777 B("MSI", "MS-6156", 1, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000778 B("MSI", "MS-6163 (MS-6163 Pro)",1, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
779 B("MSI", "MS-6178", 0, "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>."),
780 B("MSI", "MS-6330 (K7T Turbo)", 1, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
781 B("MSI", "MS-6391 (845 Pro4)", 1, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
782 B("MSI", "MS-6561 (745 Ultra)", 1, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000783 B("MSI", "MS-6566 (845 Ultra-C)",1, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000784 B("MSI", "MS-6570 (K7N2)", 1, "http://www.msi.com/product/mb/K7N2.html", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000785 B("MSI", "MS-6577 (Xenon)", 1, "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."),
Benjamin Bellecff562672011-07-12 22:01:44 +0000786 B("MSI", "MS-6590 (KT4 Ultra)", 1, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
787 B("MSI", "MS-6702E (K8T Neo2-F)",1, "http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL),
788 B("MSI", "MS-6712 (KT4V)", 1, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
789 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", 1, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
790 B("MSI", "MS-7005 (651M-L)", 1, "http://www.msi.com/product/mb/651M-L.html", NULL),
791 B("MSI", "MS-7025 (K8N Neo2 Platinum)", 1, "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000792 B("MSI", "MS-7046", 1, "http://www.heimir.de/ms7046/", NULL),
Stefan Tauner93f70232011-07-26 14:33:46 +0000793 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", 1, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000794 B("MSI", "MS-7065", 1, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000795 B("MSI", "MS-7135 (K8N Neo3)", 1, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000796 B("MSI", "MS-7142 (K8MM-V)", 1, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000797 B("MSI", "MS-7168 (Orion)", 1, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000798 B("MSI", "MS-7207 (K8NGM2-L)", 1, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
799 B("MSI", "MS-7211 (PM8M3-V)", 1, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
800 B("MSI", "MS-7236 (945PL Neo3)", 1, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
801 B("MSI", "MS-7253 (K9VGM-V)", 1, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
802 B("MSI", "MS-7255 (P4M890M)", 1, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
803 B("MSI", "MS-7260 (K9N Neo PCB 1.0)", 0, "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>."),
804 B("MSI", "MS-7312 (K9MM-V)", 1, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
805 B("MSI", "MS-7345 (P35 Neo2-FIR)", 1, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
806 B("MSI", "MS-7368 (K9AG Neo2-Digital)", 1, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000807 B("MSI", "MS-7369 (K9N Neo V2)", 1, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000808 B("MSI", "MS-7376 (K9A2 Platinum V1)", 1, "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
Stefan Tauner8179be52011-06-04 13:13:34 +0000809 B("MSI", "MS-7529 (G31M3-L(S) V2)", 1, "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000810 B("MSI", "MS-7529 (G31TM-P21)", 1, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
811 B("MSI", "MS-7596 (785GM-E51)", 1, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
Antony Rheneus0fbba982011-05-26 14:28:51 +0000812 B("MSI", "MS-7599 (870-C45)", 1, "http://www.msi.com/product/mb/870-C45.html", NULL),
Benjamin Bellecff562672011-07-12 22:01:44 +0000813 B("MSI", "MS-7640 (890FXA-GD70)",1, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
814 B("MSI", "MS-7642 (890GXM-G65)", 1, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000815 B("MSI", "MS-7696 (A75MA-G55)", 1, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000816 B("MSI", "MS-7698 (E350IA-E45)", 1, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000817 B("NEC", "PowerMate 2000", 1, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
818 B("Nokia", "IP530", 1, NULL, NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000819 B("PCCHIPS ", "M598LMR (V9.0)", 1, NULL, NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000820 B("PCCHIPS ", "M863G (V5.1A)", 1, "http://www.pcchips.com.tw/PCCWebSite/Products/ProductsDetail.aspx?CategoryID=1&DetailID=343&DetailName=Feature&MenuID=1&LanID=0", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000821 B("PC Engines", "Alix.1c", 1, "http://pcengines.ch/alix1c.htm", NULL),
822 B("PC Engines", "Alix.2c2", 1, "http://pcengines.ch/alix2c2.htm", NULL),
823 B("PC Engines", "Alix.2c3", 1, "http://pcengines.ch/alix2c3.htm", NULL),
824 B("PC Engines", "Alix.3c3", 1, "http://pcengines.ch/alix3c3.htm", NULL),
825 B("PC Engines", "Alix.3d3", 1, "http://pcengines.ch/alix3d3.htm", NULL),
826 B("PC Engines", "WRAP.2E", 1, "http://pcengines.ch/wrap2e1.htm", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000827 B("Portwell", "PEB-4700VLA", 1, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000828 B("RCA", "RM4100", 1, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000829 B("Samsung", "Polaris 32", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000830 B("Shuttle", "AK31", 1, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
831 B("Shuttle", "AK38N", 1, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000832 B("Shuttle", "AV11V30", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000833 B("Shuttle", "FD37", 1, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000834 B("Shuttle", "FH67", 1, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000835 B("Shuttle", "FN25", 1, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000836 B("Shuttle", "X50/X50(B)", 1, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000837 B("Soyo", "SY-5VD", 0, "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."),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000838 B("Soyo", "SY-6BA+ III", 1, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000839 B("Soyo", "SY-7VCA", 1, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
840 B("Sun", "Blade x6250", 1, "http://www.sun.com/servers/blades/x6250/", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000841 B("Sun", "Fire x4150", 0, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
842 B("Sun", "Fire x4200", 0, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
843 B("Sun", "Fire x4540", 0, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
844 B("Sun", "Fire x4600", 0, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000845 B("Supermicro", "H8QC8", 1, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
Stefan Taunerd06d9412011-06-12 19:47:55 +0000846 B("Supermicro", "X5DP8-G2", 1, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
Stefan Tauner716e0982011-07-25 20:38:52 +0000847 B("Supermicro", "X7DBT-INF", 1, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000848 B("Supermicro", "X7SPA-HF", 1, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H&IPMI=Y", NULL),
Stefan Taunerd06d9412011-06-12 19:47:55 +0000849 B("Supermicro", "X8DT3", 1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
Shailendra Sodhi6dbab4d2011-05-18 01:32:25 +0000850 B("Supermicro", "X8DTH-6F", 1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000851 B("Supermicro", "X8DTT-F", 1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000852 B("Supermicro", "X8DTU-6TF+", 0, "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."),
Antony Rheneus0fbba982011-05-26 14:28:51 +0000853 B("Supermicro", "X8DTU-F", 1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
Cristian Măgherușan-Stanciu9932c7b2011-07-07 19:56:58 +0000854 B("Supermicro", "X8SIE(-F)", 0, "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)."),
Antony Rheneus0fbba982011-05-26 14:28:51 +0000855 B("Supermicro", "X8STi", 1, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000856 B("T-Online", "S-100", 1, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
857 B("Tekram", "P6Pro-A5", 1, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
858 B("Termtek", "TK-3370 (Rev:2.5B)", 1, NULL, NULL),
859 B("Thomson", "IP1000", 1, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
860 B("TriGem", "Lomita", 1, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000861 B("Tyan", "S5375-1U (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
862 B("Tyan", "S1846 (Tsunami ATX)", 1, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
863 B("Tyan", "S2466 (Tiger MPX)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000864 B("Tyan", "S2498 (Tomcat K7M)", 1, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
Uwe Hermann19f46f22011-06-18 22:56:14 +0000865 B("Tyan", "S2723 (Tiger i7501)", 1, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000866 B("Tyan", "S2881 (Thunder K8SR)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
867 B("Tyan", "S2882 (Thunder K8S Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
868 B("Tyan", "S2882-D (Thunder K8SD Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
869 B("Tyan", "S2891 (Thunder K8SRE)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
870 B("Tyan", "S2892 (Thunder K8SE)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
871 B("Tyan", "S2895 (Thunder K8WE)", 1, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000872 B("Tyan", "S2912 (Thunder n3600R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000873 B("Tyan", "S2915 (Thunder n6650W)", 1, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
Uwe Hermanna3473242010-09-14 22:59:39 +0000874 B("Tyan", "S2915-E (Thunder n6650W)", 1, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000875 B("Tyan", "S2933 (Thunder n3600S)", 1, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
876 B("Tyan", "S3095 (Tomcat i945GM)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
877 B("Tyan", "S3992 (Thunder h2000M)", 1, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
878 B("Tyan", "S5180 (Toledo i965R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
879 B("Tyan", "S5191 (Toledo i3000R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
880 B("Tyan", "S5197 (Toledo i3010W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
881 B("Tyan", "S5211 (Toledo i3210W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
882 B("Tyan", "S5211-1U (Toledo i3200R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
883 B("Tyan", "S5220 (Toledo q35T)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
884 B("Tyan", "S5375 (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
885 B("Tyan", "S5376 (Tempest i5100W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
886 B("Tyan", "S5377 (Tempest i5100T)", 1, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000887 B("Tyan", "S5382 (Tempest i5000PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000888 B("Tyan", "S5397 (Tempest i5400PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000889 B("VIA", "EPIA M/MII/...", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=202", NULL), /* EPIA-MII link for now */
890 B("VIA", "EPIA SP", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
891 B("VIA", "EPIA-CN", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
Michael Karcherbcd25562010-06-12 17:27:44 +0000892 B("VIA", "EPIA EK", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000893 B("VIA", "EPIA-EX15000G", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
894 B("VIA", "EPIA-LN", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
895 B("VIA", "EPIA-M700", 1, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
896 B("VIA", "EPIA-N/NL", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=221", NULL), /* EPIA-N link for now */
897 B("VIA", "EPIA-NX15000G", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
898 B("VIA", "NAB74X0", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
899 B("VIA", "pc2500e", 1, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
900 B("VIA", "PC3500G", 1, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
901 B("VIA", "VB700X", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
Paul Menzel018d4822011-10-21 12:33:07 +0000902 B("ZOTAC", "Fusion-ITX WiFi (FUSION350-A-E)", 1, NULL, NULL),
Sylvain "ythier" Hitier3093f8f2011-09-03 11:22:27 +0000903 B("ZOTAC", "GeForce 8200", 1, "http://pden.zotac.com/index.php?page=shop.product_details&product_id=129&category_id=92", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000904 B("ZOTAC", "ZBOX HD-ID11", 1, "http://pdde.zotac.com/index.php?page=shop.product_details&product_id=240&category_id=75", NULL),
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000905#endif
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000906
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000907 {},
908};
909
910/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000911const struct board_info laptops_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000912#if defined(__i386__) || defined(__x86_64__)
Uwe Hermann301703b2010-06-03 16:35:51 +0000913 B("Acer", "Aspire 1520", 1, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
914 B("Acer", "Aspire One", 0, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
915 B("ASUS", "Eee PC 701 4G", 0, "http://www.asus.com/product.aspx?P_ID=h6SPd3tEzLEsrEiS", "It seems the chip (25X40VSIG) is behind some SPI flash translation layer (likely in the EC, the ENE KB3310)."),
916 B("Dell", "Latitude CPi A366XT", 0, "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."),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000917 B("HP/Compaq", "nx9005", 0, "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"),
Uwe Hermann301703b2010-06-03 16:35:51 +0000918 B("HP/Compaq", "nx9010", 0, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?lang=en&cc=us&objectID=c00348514", "Hangs upon '''flashrom -V''' (needs hard power-cycle then)."),
919 B("IBM/Lenovo", "Thinkpad T40p", 0, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
Stefan Tauner82f54e52011-05-18 01:31:17 +0000920 B("IBM/Lenovo", "Thinkpad T410s", 0, "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), ME and platform are locked."),
Uwe Hermann301703b2010-06-03 16:35:51 +0000921 B("IBM/Lenovo", "240", 0, "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."),
922 B("Lenovo", "3000 V100 TF05Cxx", 1, "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 +0000923#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000924
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000925 {},
926};
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000927#endif