Flashrom

Flashrom Svn Source Tree

Root/trunk/print.c

1/*
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
22#include <stdio.h>
23#include <string.h>
24#include <stdlib.h>
25#include "flash.h"
26#include "programmer.h"
27
28/*
29 * Return a string corresponding to the bustype parameter.
30 * Memory is obtained with malloc() and must be freed with free() by the caller.
31 */
32char *flashbuses_to_text(enum chipbustype bustype)
33{
34char *ret = calloc(1, 1);
35/*
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 */
39if (bustype == BUS_NONSPI) {
40ret = strcat_realloc(ret, "Non-SPI, ");
41} else {
42if (bustype & BUS_PARALLEL)
43ret = strcat_realloc(ret, "Parallel, ");
44if (bustype & BUS_LPC)
45ret = strcat_realloc(ret, "LPC, ");
46if (bustype & BUS_FWH)
47ret = strcat_realloc(ret, "FWH, ");
48if (bustype & BUS_SPI)
49ret = strcat_realloc(ret, "SPI, ");
50if (bustype & BUS_PROG)
51ret = strcat_realloc(ret, "Programmer-specific, ");
52if (bustype == BUS_NONE)
53ret = strcat_realloc(ret, "None, ");
54}
55/* Kill last comma. */
56ret[strlen(ret) - 2] = '\0';
57ret = realloc(ret, strlen(ret) + 1);
58return ret;
59}
60
61static void print_supported_chips(void)
62{
63const char *delim = "/";
64const int mintoklen = 5;
65const int border = 2;
66int i, chipcount = 0;
67int maxvendorlen = strlen("Vendor") + 1;
68int maxchiplen = strlen("Device") + 1;
69int maxtypelen = strlen("Type") + 1;
70const struct flashchip *f;
71char *s;
72char *tmpven, *tmpdev;
73int tmpvenlen, tmpdevlen, curvenlen, curdevlen;
74
75/* calculate maximum column widths and by iterating over all chips */
76for (f = flashchips; f->name != NULL; f++) {
77/* Ignore "unknown XXXX SPI chip" entries. */
78if (!strncmp(f->name, "unknown", 7))
79continue;
80chipcount++;
81
82/* Find maximum vendor length (respecting line splitting). */
83tmpven = (char *)f->vendor;
84do {
85/* and take minimum token lengths into account */
86tmpvenlen = 0;
87do {
88tmpvenlen += strcspn(tmpven, delim);
89/* skip to the address after the first token */
90tmpven += tmpvenlen;
91if (tmpven[0] == '\0')
92break;
93tmpven++;
94} while (tmpvenlen < mintoklen);
95maxvendorlen = max(maxvendorlen, tmpvenlen);
96if (tmpven[0] == '\0')
97break;
98} while (1);
99
100/* same for device name */
101tmpdev = (char *)f->name;
102do {
103tmpdevlen = 0;
104do {
105tmpdevlen += strcspn(tmpdev, delim);
106tmpdev += tmpdevlen;
107if (tmpdev[0] == '\0')
108break;
109tmpdev++;
110} while (tmpdevlen < mintoklen);
111maxchiplen = max(maxchiplen, tmpdevlen);
112if (tmpdev[0] == '\0')
113break;
114} while (1);
115
116s = flashbuses_to_text(f->bustype);
117maxtypelen = max(maxtypelen, strlen(s));
118free(s);
119}
120maxvendorlen += border;
121maxchiplen += border;
122maxtypelen += border;
123
124msg_ginfo("Supported flash chips (total: %d):\n\n", chipcount);
125msg_ginfo("Vendor");
126for (i = strlen("Vendor"); i < maxvendorlen; i++)
127msg_ginfo(" ");
128msg_ginfo("Device");
129for (i = strlen("Device"); i < maxchiplen; i++)
130msg_ginfo(" ");
131
132msg_ginfo("Test");
133for (i = 0; i < border; i++)
134msg_ginfo(" ");
135msg_ginfo("Known");
136for (i = 0; i < border; i++)
137msg_ginfo(" ");
138msg_ginfo(" Size");
139for (i = 0; i < border; i++)
140msg_ginfo(" ");
141
142msg_ginfo("Type");
143for (i = strlen("Type"); i < maxtypelen; i++)
144msg_ginfo(" ");
145msg_gdbg("Voltage");
146msg_ginfo("\n");
147
148for (i = 0; i < maxvendorlen + maxchiplen; i++)
149msg_ginfo(" ");
150msg_ginfo("OK ");
151for (i = 0; i < border; i++)
152msg_ginfo(" ");
153msg_ginfo("Broken");
154for (i = 0; i < border; i++)
155msg_ginfo(" ");
156msg_ginfo("[kB]");
157for (i = 0; i < border + maxtypelen; i++)
158msg_ginfo(" ");
159msg_gdbg("range [V]");
160msg_ginfo("\n\n");
161msg_ginfo("(P = PROBE, R = READ, E = ERASE, W = WRITE)\n\n");
162
163for (f = flashchips; f->name != NULL; f++) {
164/* Don't print "unknown XXXX SPI chip" entries. */
165if (!strncmp(f->name, "unknown", 7))
166continue;
167
168/* 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 */
178tmpven = malloc(strlen(f->vendor) + 1);
179if (tmpven == NULL) {
180msg_gerr("Out of memory!\n");
181exit(1);
182}
183strcpy(tmpven, f->vendor);
184
185tmpven = strtok(tmpven, delim);
186msg_ginfo("%s", tmpven);
187curvenlen = strlen(tmpven);
188while ((tmpven = strtok(NULL, delim)) != NULL) {
189msg_ginfo("%s", delim);
190curvenlen++;
191tmpvenlen = strlen(tmpven);
192if (tmpvenlen >= mintoklen)
193break; /* big enough to be on its own line */
194msg_ginfo("%s", tmpven);
195curvenlen += tmpvenlen;
196}
197
198for (i = curvenlen; i < maxvendorlen; i++)
199msg_ginfo(" ");
200
201/* support for multiline device names as above */
202tmpdev = malloc(strlen(f->name) + 1);
203if (tmpdev == NULL) {
204msg_gerr("Out of memory!\n");
205exit(1);
206}
207strcpy(tmpdev, f->name);
208
209tmpdev = strtok(tmpdev, delim);
210msg_ginfo("%s", tmpdev);
211curdevlen = strlen(tmpdev);
212while ((tmpdev = strtok(NULL, delim)) != NULL) {
213msg_ginfo("%s", delim);
214curdevlen++;
215tmpdevlen = strlen(tmpdev);
216if (tmpdevlen >= mintoklen)
217break; /* big enough to be on its own line */
218msg_ginfo("%s", tmpdev);
219curdevlen += tmpdevlen;
220}
221
222for (i = curdevlen; i < maxchiplen; i++)
223msg_ginfo(" ");
224
225if ((f->tested & TEST_OK_PROBE))
226msg_ginfo("P");
227else
228msg_ginfo(" ");
229if ((f->tested & TEST_OK_READ))
230msg_ginfo("R");
231else
232msg_ginfo(" ");
233if ((f->tested & TEST_OK_ERASE))
234msg_ginfo("E");
235else
236msg_ginfo(" ");
237if ((f->tested & TEST_OK_WRITE))
238msg_ginfo("W");
239else
240msg_ginfo(" ");
241for (i = 0; i < border; i++)
242msg_ginfo(" ");
243
244if ((f->tested & TEST_BAD_PROBE))
245msg_ginfo("P");
246else
247msg_ginfo(" ");
248if ((f->tested & TEST_BAD_READ))
249msg_ginfo("R");
250else
251msg_ginfo(" ");
252if ((f->tested & TEST_BAD_ERASE))
253msg_ginfo("E");
254else
255msg_ginfo(" ");
256if ((f->tested & TEST_BAD_WRITE))
257msg_ginfo("W");
258else
259msg_ginfo(" ");
260for (i = 0; i < border + 1; i++)
261msg_ginfo(" ");
262
263msg_ginfo("%5d", f->total_size);
264for (i = 0; i < border; i++)
265msg_ginfo(" ");
266
267s = flashbuses_to_text(f->bustype);
268msg_ginfo("%s", s);
269for (i = strlen(s); i < maxtypelen; i++)
270msg_ginfo(" ");
271free(s);
272
273if (f->voltage.min == 0 && f->voltage.max == 0)
274msg_gdbg("no info");
275else
276msg_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 */
281while (tmpven != NULL || tmpdev != NULL) {
282msg_ginfo("\n");
283if (tmpven != NULL){
284msg_ginfo("%s", tmpven);
285curvenlen = strlen(tmpven);
286while ((tmpven = strtok(NULL, delim)) != NULL) {
287msg_ginfo("%s", delim);
288curvenlen++;
289tmpvenlen = strlen(tmpven);
290/* big enough to be on its own line */
291if (tmpvenlen >= mintoklen)
292break;
293msg_ginfo("%s", tmpven);
294curvenlen += tmpvenlen;
295}
296} else
297curvenlen = 0;
298
299for (i = curvenlen; i < maxvendorlen; i++)
300msg_ginfo(" ");
301
302if (tmpdev != NULL){
303msg_ginfo("%s", tmpdev);
304curdevlen = strlen(tmpdev);
305while ((tmpdev = strtok(NULL, delim)) != NULL) {
306msg_ginfo("%s", delim);
307curdevlen++;
308tmpdevlen = strlen(tmpdev);
309/* big enough to be on its own line */
310if (tmpdevlen >= mintoklen)
311break;
312msg_ginfo("%s", tmpdev);
313curdevlen += tmpdevlen;
314}
315}
316}
317msg_ginfo("\n");
318}
319}
320
321#if CONFIG_INTERNAL == 1
322static void print_supported_chipsets(void)
323{
324int i, chipsetcount = 0;
325const struct penable *c = chipset_enables;
326int maxvendorlen = strlen("Vendor") + 1;
327int maxchipsetlen = strlen("Chipset") + 1;
328
329for (c = chipset_enables; c->vendor_name != NULL; c++) {
330chipsetcount++;
331maxvendorlen = max(maxvendorlen, strlen(c->vendor_name));
332maxchipsetlen = max(maxchipsetlen, strlen(c->device_name));
333}
334maxvendorlen++;
335maxchipsetlen++;
336
337msg_ginfo("Supported chipsets (total: %d):\n\n", chipsetcount);
338
339msg_ginfo("Vendor");
340for (i = strlen("Vendor"); i < maxvendorlen; i++)
341msg_ginfo(" ");
342
343msg_ginfo("Chipset");
344for (i = strlen("Chipset"); i < maxchipsetlen; i++)
345msg_ginfo(" ");
346
347msg_ginfo("PCI IDs State\n\n");
348
349for (c = chipset_enables; c->vendor_name != NULL; c++) {
350msg_ginfo("%s", c->vendor_name);
351for (i = 0; i < maxvendorlen - strlen(c->vendor_name); i++)
352msg_ginfo(" ");
353msg_ginfo("%s", c->device_name);
354for (i = 0; i < maxchipsetlen - strlen(c->device_name); i++)
355msg_ginfo(" ");
356msg_ginfo("%04x:%04x%s\n", c->vendor_id, c->device_id,
357 (c->status == OK) ? "" : " (untested)");
358}
359}
360
361static void print_supported_boards_helper(const struct board_info *boards,
362 const char *devicetype)
363{
364int i, boardcount_good = 0, boardcount_bad = 0;
365const struct board_match *e = board_matches;
366const struct board_info *b = boards;
367int maxvendorlen = strlen("Vendor") + 1;
368int maxboardlen = strlen("Board") + 1;
369
370for (b = boards; b->vendor != NULL; b++) {
371maxvendorlen = max(maxvendorlen, strlen(b->vendor));
372maxboardlen = max(maxboardlen, strlen(b->name));
373if (b->working)
374boardcount_good++;
375else
376boardcount_bad++;
377}
378maxvendorlen++;
379maxboardlen++;
380
381msg_ginfo("Known %s (good: %d, bad: %d):\n\n",
382 devicetype, boardcount_good, boardcount_bad);
383
384msg_ginfo("Vendor");
385for (i = strlen("Vendor"); i < maxvendorlen; i++)
386msg_ginfo(" ");
387
388msg_ginfo("Board");
389for (i = strlen("Board"); i < maxboardlen; i++)
390msg_ginfo(" ");
391
392msg_ginfo("Status Required value for\n");
393for (i = 0; i < maxvendorlen + maxboardlen + strlen("Status "); i++)
394msg_ginfo(" ");
395msg_ginfo("-p internal:mainboard=\n");
396
397for (b = boards; b->vendor != NULL; b++) {
398msg_ginfo("%s", b->vendor);
399for (i = 0; i < maxvendorlen - strlen(b->vendor); i++)
400msg_ginfo(" ");
401msg_ginfo("%s", b->name);
402for (i = 0; i < maxboardlen - strlen(b->name); i++)
403msg_ginfo(" ");
404msg_ginfo((b->working) ? "OK " : "BAD ");
405
406for (e = board_matches; e->vendor_name != NULL; e++) {
407if (strcmp(e->vendor_name, b->vendor)
408 || strcmp(e->board_name, b->name))
409continue;
410if (e->lb_vendor == NULL)
411msg_ginfo("(autodetected)");
412else
413msg_ginfo("%s:%s", e->lb_vendor,
414 e->lb_part);
415}
416msg_ginfo("\n");
417}
418}
419#endif
420
421void print_supported(void)
422{
423print_supported_chips();
424
425msg_ginfo("\nSupported programmers:\n");
426list_programmers_linebreak(0, 80, 0);
427#if CONFIG_INTERNAL == 1
428msg_ginfo("\nSupported devices for the %s programmer:\n\n",
429 programmer_table[PROGRAMMER_INTERNAL].name);
430print_supported_chipsets();
431msg_ginfo("\n");
432print_supported_boards_helper(boards_known, "boards");
433msg_ginfo("\n");
434print_supported_boards_helper(laptops_known, "laptops");
435#endif
436#if CONFIG_DUMMY == 1
437msg_ginfo("\nSupported devices for the %s programmer:\n",
438 programmer_table[PROGRAMMER_DUMMY].name);
439/* FIXME */
440msg_ginfo("Dummy device, does nothing and logs all accesses\n");
441#endif
442#if CONFIG_NIC3COM == 1
443msg_ginfo("\nSupported devices for the %s programmer:\n",
444 programmer_table[PROGRAMMER_NIC3COM].name);
445print_supported_pcidevs(nics_3com);
446#endif
447#if CONFIG_NICREALTEK == 1
448msg_ginfo("\nSupported devices for the %s programmer:\n",
449 programmer_table[PROGRAMMER_NICREALTEK].name);
450print_supported_pcidevs(nics_realtek);
451#endif
452#if CONFIG_NICNATSEMI == 1
453msg_ginfo("\nSupported devices for the %s programmer:\n",
454 programmer_table[PROGRAMMER_NICNATSEMI].name);
455print_supported_pcidevs(nics_natsemi);
456#endif
457#if CONFIG_GFXNVIDIA == 1
458msg_ginfo("\nSupported devices for the %s programmer:\n",
459 programmer_table[PROGRAMMER_GFXNVIDIA].name);
460print_supported_pcidevs(gfx_nvidia);
461#endif
462#if CONFIG_DRKAISER == 1
463msg_ginfo("\nSupported devices for the %s programmer:\n",
464 programmer_table[PROGRAMMER_DRKAISER].name);
465print_supported_pcidevs(drkaiser_pcidev);
466#endif
467#if CONFIG_SATASII == 1
468msg_ginfo("\nSupported devices for the %s programmer:\n",
469 programmer_table[PROGRAMMER_SATASII].name);
470print_supported_pcidevs(satas_sii);
471#endif
472#if CONFIG_ATAHPT == 1
473msg_ginfo("\nSupported devices for the %s programmer:\n",
474 programmer_table[PROGRAMMER_ATAHPT].name);
475print_supported_pcidevs(ata_hpt);
476#endif
477#if CONFIG_FT2232_SPI == 1
478msg_ginfo("\nSupported devices for the %s programmer:\n",
479 programmer_table[PROGRAMMER_FT2232_SPI].name);
480print_supported_usbdevs(devs_ft2232spi);
481#endif
482#if CONFIG_SERPROG == 1
483msg_ginfo("\nSupported devices for the %s programmer:\n",
484 programmer_table[PROGRAMMER_SERPROG].name);
485/* FIXME */
486msg_ginfo("All programmer devices speaking the serprog protocol\n");
487#endif
488#if CONFIG_BUSPIRATE_SPI == 1
489msg_ginfo("\nSupported devices for the %s programmer:\n",
490 programmer_table[PROGRAMMER_BUSPIRATE_SPI].name);
491/* FIXME */
492msg_ginfo("Dangerous Prototypes Bus Pirate\n");
493#endif
494#if CONFIG_DEDIPROG == 1
495msg_ginfo("\nSupported devices for the %s programmer:\n",
496 programmer_table[PROGRAMMER_DEDIPROG].name);
497/* FIXME */
498msg_ginfo("Dediprog SF100\n");
499#endif
500#if CONFIG_RAYER_SPI == 1
501msg_ginfo("\nSupported devices for the %s programmer:\n",
502 programmer_table[PROGRAMMER_RAYER_SPI].name);
503/* FIXME */
504msg_ginfo("RayeR parallel port programmer\n");
505#endif
506#if CONFIG_NICINTEL == 1
507msg_ginfo("\nSupported devices for the %s programmer:\n",
508 programmer_table[PROGRAMMER_NICINTEL].name);
509print_supported_pcidevs(nics_intel);
510#endif
511#if CONFIG_NICINTEL_SPI == 1
512msg_ginfo("\nSupported devices for the %s programmer:\n",
513 programmer_table[PROGRAMMER_NICINTEL_SPI].name);
514print_supported_pcidevs(nics_intel_spi);
515#endif
516#if CONFIG_OGP_SPI == 1
517msg_ginfo("\nSupported devices for the %s programmer:\n",
518 programmer_table[PROGRAMMER_OGP_SPI].name);
519print_supported_pcidevs(ogp_spi);
520#endif
521#if CONFIG_SATAMV == 1
522msg_ginfo("\nSupported devices for the %s programmer:\n",
523 programmer_table[PROGRAMMER_SATAMV].name);
524print_supported_pcidevs(satas_mv);
525#endif
526}
527
528#if CONFIG_INTERNAL == 1
529
530#ifdef CONFIG_PRINT_WIKI
531#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
532#else
533#define B(vendor, name, status, url, note) { vendor, name, status }
534#endif
535
536/* Please keep this list alphabetically ordered by vendor/board. */
537const struct board_info boards_known[] = {
538#if defined(__i386__) || defined(__x86_64__)
539B("A-Trend","ATC-6220",1, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
540B("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),
541B("abit","AV8",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AV8", NULL),
542B("abit","AX8",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AX8", NULL),
543B("abit","BM6",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=BM6&fMTYPE=Socket%20370", NULL),
544B("abit","Fatal1ty F-I90HD",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=Fatal1ty+F-I90HD&fMTYPE=LGA775", NULL),
545B("abit","IC7",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IC7&fMTYPE=Socket%20478", NULL),
546B("abit","IP35",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35", NULL),
547B("abit","IP35 Pro",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35%20Pro", NULL),
548B("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."),
549B("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),
550B("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),
551B("abit","NF-M2S",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=NF-M2S&fMTYPE=Socket%20AM2", NULL),
552B("abit","NF7-S",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20A&pMODEL_NAME=NF7-S", NULL),
553B("abit","VA6",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VA6", NULL),
554B("abit","VT6X4",1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VT6X4", NULL),
555B("Acorp","6A815EPD",1, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
556B("Advantech","PCM-5820",1, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
557B("agami","Aruma",1, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
558B("Albatron","PM266A Pro",1, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
559B("AOpen","i945GMx-VFX",1, NULL, "This is (also?) an OEM board from FCS (used in e.g. ESPRIMO Q5010 with designation D2544-B1)."),
560B("AOpen","vKM400Am-S",1, "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
561B("Artec Group","DBE61",1, "http://wiki.thincan.org/DBE61", NULL),
562B("Artec Group","DBE62",1, "http://wiki.thincan.org/DBE62", NULL),
563B("ASI","MB-5BLMP",1, "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III thin client."),
564B("ASRock","775i65G",1, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
565B("ASRock","890GX Extreme3",1, "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
566B("ASRock","939A785GMH/128M",1, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
567B("ASRock","A330GC",1, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
568B("ASRock","A770CrossFire",1, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
569B("ASRock","ALiveNF6G-DVI",1, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
570B("ASRock","ConRoeXFire-eSATA2",1, "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2", NULL),
571B("ASRock","K7S41",1, "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
572B("ASRock","K7S41GX",1, "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
573B("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"),
574B("ASRock","K8S8X",1, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
575B("ASRock","M3A790GXH/128M",1, "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
576B("ASRock","P4i65GV",1, "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
577B("ASUS","A7N8X Deluxe",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
578B("ASUS","A7N8X-E Deluxe",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
579B("ASUS","A7N8X-VM/400",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
580B("ASUS","A7V133",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socka/kt133a/a7v133/", NULL),
581B("ASUS","A7V333",1, "ftp://ftp.asus.com.tw/pub/asus/mb/socka/kt333/a7v333/", NULL),
582B("ASUS","A7V400-MX",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
583B("ASUS","A7V600-X",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
584B("ASUS","A7V8X",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
585B("ASUS","A7V8X-MX",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
586B("ASUS","A7V8X-MX SE",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
587B("ASUS","A7V8X-X",1, "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
588B("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."),
589B("ASUS","A8N-E",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
590B("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."),
591B("ASUS","A8N-SLI",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
592B("ASUS","A8N-SLI Deluxe",0, NULL, "Untested board enable."),
593B("ASUS","A8N-SLI Premium",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/", NULL),
594B("ASUS","A8N-VM",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
595B("ASUS","A8N-VM CSM",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
596B("ASUS","A8NE-FM/S",1, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
597B("ASUS","A8V Deluxe",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
598B("ASUS","A8V-E Deluxe",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
599B("ASUS","A8V-E SE",1, "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
600B("ASUS","Crosshair II Formula",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/", NULL),
601B("ASUS","Crosshair IV Extreme",1, "http://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/", NULL),
602B("ASUS","E35M1-I DELUXE",1, "http://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/", NULL),
603B("ASUS","K8N",1, "http://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
604B("ASUS","K8V",1, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
605B("ASUS","K8V SE Deluxe",1, "http://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/", NULL),
606B("ASUS","K8V-X",1, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
607B("ASUS","K8V-X SE",1, "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
608B("ASUS","M2A-MX",1, "http://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
609B("ASUS","M2A-VM",1, "http://www.asus.com/Motherboards/AMD_AM2/M2AVM/", "See http://www.coreboot.org/pipermail/coreboot/2007-September/025281.html"),
610B("ASUS","M2N32-SLI Deluxe",1, "http://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/", NULL),
611B("ASUS","M2N-E",1, "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"),
612B("ASUS","M2N-E SLI",1, "http://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
613B("ASUS","M2N-SLI Deluxe",1, "http://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
614B("ASUS","M2NBP-VM CSM",1, "http://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
615B("ASUS","M2NPV-VM",1, "http://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
616B("ASUS","M2V",1, "http://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
617B("ASUS","M2V-MX",1, "http://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
618B("ASUS","M3A",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
619B("ASUS","M3A76-CM",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
620B("ASUS","M3A78-EM",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
621B("ASUS","M3N78-VM",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
622B("ASUS","M4A78-EM",1, "http://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
623B("ASUS","M4A785TD-V EVO",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
624B("ASUS","M4A785TD-M EVO",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
625B("ASUS","M4A78LT-M LE",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
626B("ASUS","M4A79T Deluxe",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
627B("ASUS","M4A87TD/USB3",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
628B("ASUS","M4A89GTD PRO",1, "http://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
629B("ASUS","M5A99X EVO",1, "http://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
630B("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."),
631B("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."),
632B("ASUS","P2B",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b/", NULL),
633B("ASUS","P2B-D",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
634B("ASUS","P2B-DS",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-ds/", NULL),
635B("ASUS","P2B-F",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
636B("ASUS","P2B-N",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-n/", NULL),
637B("ASUS","P2E-M",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440ex/p2e-m/", NULL),
638B("ASUS","P2L97-S",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440lx/p2l97-s/", NULL),
639B("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."),
640B("ASUS","P4B266",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b266/", NULL),
641B("ASUS","P4B266-LM",1, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
642B("ASUS","P4B533-E",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b533-e/", NULL),
643B("ASUS","P4C800-E Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/", NULL),
644B("ASUS","P4GV-LA (Guppy)",1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478", NULL),
645B("ASUS","P4P800",1, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
646B("ASUS","P4P800-E Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/", NULL),
647B("ASUS","P4P800-VM",1, "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
648B("ASUS","P4SC-E",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4sc-e/", "Part of ASUS Terminator P4 533 barebone system"),
649B("ASUS","P4SD-LA",1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
650B("ASUS","P4S533-X",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4s533-x/", NULL),
651B("ASUS","P4S800-MX",1, "http://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
652B("ASUS","P5A",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock7/ali/p5a/", NULL),
653B("ASUS","P5B",1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B/", NULL),
654B("ASUS","P5B-Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/", NULL),
655B("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."),
656B("ASUS","P5GC-MX/1333",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/", NULL),
657B("ASUS","P5GD1 Pro",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
658B("ASUS","P5GD1-VM/S",1, 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."),
659B("ASUS","P5GD1(-VM)",0, NULL, "Untested board enable."),
660B("ASUS","P5GD2 Premium",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/", NULL),
661B("ASUS","P5GDC Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/", NULL),
662B("ASUS","P5GDC-V Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/", NULL),
663B("ASUS","P5GD2/C variants",0, NULL, "Untested board enable."),
664B("ASUS","P5K-VM",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
665B("ASUS","P5KC",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
666B("ASUS","P5L-MX",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
667B("ASUS","P5L-VM 1394",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/", NULL),
668B("ASUS","P5LD2",0, NULL, "Untested board enable."),
669B("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."),
670B("ASUS","P5LP-LE (Epson OEM)",1, NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
671B("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."),
672B("ASUS","P5N-E SLI",0, "http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Needs a board enable (http://patchwork.coreboot.org/patch/3298/)."),
673B("ASUS","P5N-D",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
674B("ASUS","P5N-E SLI",0, "http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/", "Untested board enable."),
675B("ASUS","P5N32-E SLI",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/", NULL),
676B("ASUS","P5ND2-SLI Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/", NULL),
677B("ASUS","P5PE-VM",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
678B("ASUS","P5VD1-X",1, "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
679B("ASUS","P6T SE",1, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
680B("ASUS","P6T Deluxe",1, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/", NULL),
681B("ASUS","P6T Deluxe V2",1, "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/", NULL),
682B("ASUS","P7H57D-V EVO",1, "http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/", NULL),
683B("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)"),
684B("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."),
685B("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."),
686B("ASUS","P8H61 PRO",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."),
687B("ASUS","P8P67 (rev. 3.1)",0, 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."),
688B("ASUS","Z8NA-D6C",1, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/", NULL),
689B("ASUS","Z8PE-D12",1, "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/", NULL),
690B("BCOM","WinNET100",1, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
691B("Biostar","N68S3+",1, NULL, NULL),
692B("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."),
693B("Biostar","M7NCD Pro",1, "http://www.biostar.com.tw/app/en/mb/content.php?S_ID=260", NULL),
694B("Biostar","P4M80-M4",1, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
695B("Biostar","TA780G M2+",1, "http://www.biostar.com.tw/app/en/t-series/content.php?S_ID=344", NULL),
696B("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."),
697B("Congatec","conga-X852",1, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
698B("Dell","OptiPlex GX1",1, "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm", NULL),
699B("Dell","PowerEdge 1850",1, "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm", NULL),
700B("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"),
701B("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),
702B("Elitegroup","GeForce6100SM-M ",1, "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=685&MenuID=24", NULL),
703B("Elitegroup","K7S5A",1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=279&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0", NULL),
704B("Elitegroup","K7S6A",1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=77&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
705B("Elitegroup","K7VTA3",1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=264&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
706B("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),
707B("Elitegroup", "P4VXMS (V1.0A)",1, NULL, NULL),
708B("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),
709B("Elitegroup","P6VAP-A+",1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=117&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0", NULL),
710B("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),
711B("Emerson","ATCA-7360",1, "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx", NULL),
712B("EPoX","EP-8K5A2",1, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
713B("EPoX","EP-8NPA7I",1, "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
714B("EPoX","EP-9NPA7I",1, "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
715B("EPoX","EP-8RDA3+",1, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
716B("EPoX","EP-BX3",1, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
717B("EVGA","132-CK-NF78",1, "http://www.evga.com/articles/385.asp", NULL),
718B("EVGA","270-WS-W555-A2 (Classified SR-2)", 1, "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
719B("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."),
720B("Foxconn","6150K8MD-8EKRSH",1, "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000157", NULL),
721B("Foxconn","A6VMX",1, "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000346", NULL),
722B("Foxconn","P4M800P7MA-RS2",1, "http://www.foxconnchannel.com/Product/Motherboards/detail_overview.aspx?id=en-us0000138", NULL),
723B("Freetech","P6F91i",1, "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html", NULL),
724B("Fujitsu-Siemens", "ESPRIMO P5915",1, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/professionalpc/ESPRIMO/P/EsprimoP5915-6.htm", "Mainboard model is D2312-A2."),
725B("GIGABYTE","GA-2761GXDK",1, "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/", NULL),
726B("GIGABYTE","GA-6BXC",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
727B("GIGABYTE","GA-6BXDU",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
728B("GIGABYTE","GA-6IEM",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
729B("GIGABYTE","GA-6VXE7+",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
730B("GIGABYTE","GA-6ZMA",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
731B("GIGABYTE","GA-MA785GMT-UD2H (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
732B("GIGABYTE","GA-770TA-UD3",1, "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
733B("GIGABYTE","GA-7DXR",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
734B("GIGABYTE","GA-7VT600",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
735B("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."),
736B("GIGABYTE","GA-8I945GZME-RH",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
737B("GIGABYTE","GA-8IP775",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
738B("GIGABYTE","GA-8IRML",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
739B("GIGABYTE","GA-8PE667 Ultra 2",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
740B("GIGABYTE","GA-8SIMLH",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
741B("GIGABYTE","GA-945PL-S3P (rev. 6.6)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
742B("GIGABYTE","GA-965GM-S2 (rev. 2.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
743B("GIGABYTE","GA-965P-DS4",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
744B("GIGABYTE","GA-EP35-DS3L",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
745B("GIGABYTE","GA-EX58-UD4P",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
746B("GIGABYTE","GA-K8N-SLI",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
747B("GIGABYTE","GA-K8N51GMF",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
748B("GIGABYTE","GA-K8N51GMF-9",1, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
749B("GIGABYTE","GA-K8NS Pro-939",0, "http://www.gigabyte.com/products/product-page.aspx?pid=1875", "Untested board enable."),
750B("GIGABYTE","GA-M57SLI-S4",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
751B("GIGABYTE","GA-M61P-S3",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
752B("GIGABYTE","GA-M720-US3",1, "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
753B("GIGABYTE","GA-MA69VM-S2",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
754B("GIGABYTE","GA-MA74GM-S2H (rev. 3.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
755B("GIGABYTE","GA-MA770-UD3 (rev. 2.1)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
756B("GIGABYTE","GA-MA770T-UD3P",1, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
757B("GIGABYTE","GA-MA780G-UD3H",1, "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
758B("GIGABYTE","GA-MA78G-DS3H (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
759B("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? */
760B("GIGABYTE","GA-MA78GPM-DS2H",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
761B("GIGABYTE","GA-MA790FX-DQ6",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
762B("GIGABYTE","GA-MA790GP-DS4H",1, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
763B("GIGABYTE","GA-MA790XT-UD4P (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
764B("GIGABYTE","GA-P55A-UD4 (rev. 1.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
765B("GIGABYTE","GA-P67A-UD3P",1, "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
766B("GIGABYTE","GA-X58A-UD7 (rev. 2.0)", 1, NULL, NULL),
767B("GIGABYTE","GA-Z68MX-UD2H-B (rev. 1.3)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
768B("HP","e-Vectra P2706T",1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454", NULL),
769B("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),
770B("HP","ProLiant DL165 G6",1, "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html", NULL),
771B("HP","Puffer2-UL8E",1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
772B("HP","Vectra VL400",1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
773B("HP","Vectra VL420 SFF",1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
774B("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"),
775B("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."),
776B("IBASE","MB899",1, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
777B("IBM","x3455",1, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
778B("IEI","PICOe-9452",1, "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144", NULL),
779B("Intel","D201GLY",1, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
780B("Intel","D865GLC",0, NULL, "ICH5 with BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
781B("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."),
782B("Intel","DH67CF",0, NULL, "H67 with BIOS lock enable and locked ME region, see http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
783B("Intel","EP80759",1, NULL, NULL),
784B("Intel","Foxhollow",1, NULL, "Intel reference board."),
785B("Intel","Greencity",1, NULL, "Intel reference board."),
786B("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"),
787B("IWILL","DK8-HTX",1, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
788B("Jetway","J-7BXAN",1, "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
789B("Jetway","J7F4K1G5D-PB",1, "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D", NULL),
790B("Kontron","986LCD-M",1, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
791B("Lanner","EM-8510C",1, NULL, NULL),
792B("Lex","CV700A",1, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
793B("Mitac","6513WU",1, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
794B("MSI","MS-6153",1, "http://www.msi.com/product/mb/MS-6153.html", NULL),
795B("MSI","MS-6156",1, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
796B("MSI","MS-6163 (MS-6163 Pro)",1, "http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
797B("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>."),
798B("MSI","MS-6330 (K7T Turbo)",1, "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
799B("MSI","MS-6391 (845 Pro4)",1, "http://www.msi.com/product/mb/845-Pro4.html", NULL),
800B("MSI","MS-6561 (745 Ultra)",1, "http://www.msi.com/product/mb/745-Ultra.html", NULL),
801B("MSI","MS-6566 (845 Ultra-C)",1, "http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
802B("MSI","MS-6570 (K7N2)",1, "http://www.msi.com/product/mb/K7N2.html", NULL),
803B("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."),
804B("MSI","MS-6590 (KT4 Ultra)",1, "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
805B("MSI","MS-6702E (K8T Neo2-F)",1, "http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL),
806B("MSI","MS-6712 (KT4V)",1, "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
807B("MSI","MS-6787 (P4MAM-V/P4MAM-L)", 1, "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
808B("MSI","MS-7005 (651M-L)",1, "http://www.msi.com/product/mb/651M-L.html", NULL),
809B("MSI","MS-7025 (K8N Neo2 Platinum)", 1, "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
810B("MSI","MS-7046",1, "http://www.heimir.de/ms7046/", NULL),
811B("MSI","MS-7061 (KM4M-V/KM4AM-V)", 1, "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
812B("MSI","MS-7065",1, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
813B("MSI","MS-7135 (K8N Neo3)",1, "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
814B("MSI","MS-7142 (K8MM-V)",1, "http://www.msi.com/product/mb/K8MM-V.html", NULL),
815B("MSI","MS-7168 (Orion)",1, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
816B("MSI","MS-7207 (K8NGM2-L)",1, "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
817B("MSI","MS-7211 (PM8M3-V)",1, "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
818B("MSI","MS-7236 (945PL Neo3)",1, "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
819B("MSI","MS-7253 (K9VGM-V)",1, "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
820B("MSI","MS-7255 (P4M890M)",1, "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
821B("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>."),
822B("MSI","MS-7312 (K9MM-V)",1, "http://www.msi.com/product/mb/K9MM-V.html", NULL),
823B("MSI","MS-7345 (P35 Neo2-FIR)", 1, "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
824B("MSI","MS-7368 (K9AG Neo2-Digital)", 1, "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
825B("MSI","MS-7369 (K9N Neo V2)", 1, "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
826B("MSI","MS-7376 (K9A2 Platinum V1)", 1, "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
827B("MSI","MS-7529 (G31M3-L(S) V2)", 1, "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
828B("MSI","MS-7529 (G31TM-P21)", 1, "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
829B("MSI","MS-7596 (785GM-E51)", 1, "http://www.msi.com/product/mb/785GM-E51.html", NULL),
830B("MSI","MS-7599 (870-C45)",1, "http://www.msi.com/product/mb/870-C45.html", NULL),
831B("MSI","MS-7613 (Iona-GL8E)",0, "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."),
832B("MSI","MS-7635 (H55M-ED55)",0, "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."),
833B("MSI","MS-7640 (890FXA-GD70)",1, "http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
834B("MSI","MS-7642 (890GXM-G65)",1, "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
835B("MSI","MS-7696 (A75MA-G55)",1, "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
836B("MSI","MS-7698 (E350IA-E45)",1, "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
837B("NEC","PowerMate 2000",1, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
838B("Nokia","IP530",1, NULL, NULL),
839B("PCCHIPS ","M598LMR (V9.0)",1, NULL, NULL),
840B("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),
841B("PC Engines","Alix.1c",1, "http://pcengines.ch/alix1c.htm", NULL),
842B("PC Engines","Alix.2c2",1, "http://pcengines.ch/alix2c2.htm", NULL),
843B("PC Engines","Alix.2c3",1, "http://pcengines.ch/alix2c3.htm", NULL),
844B("PC Engines","Alix.2d3",1, "http://pcengines.ch/alix2d3.htm", NULL),
845B("PC Engines","Alix.3c3",1, "http://pcengines.ch/alix3c3.htm", NULL),
846B("PC Engines","Alix.3d3",1, "http://pcengines.ch/alix3d3.htm", NULL),
847B("PC Engines","WRAP.2E",1, "http://pcengines.ch/wrap2e1.htm", NULL),
848B("Portwell","PEB-4700VLA",1, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
849B("RCA","RM4100",1, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
850B("Samsung","Polaris 32",1, NULL, NULL),
851B("Shuttle","AK31",1, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
852B("Shuttle","AK38N",1, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
853B("Shuttle","AV11V30",1, NULL, NULL),
854B("Shuttle","FD37",1, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
855B("Shuttle","FH67",1, "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
856B("Shuttle","FN25",1, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
857B("Shuttle","X50/X50(B)",1, "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
858B("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."),
859B("Soyo","SY-6BA+ III",1, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
860B("Soyo","SY-7VCA",1, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
861B("Sun","Blade x6250",1, "http://www.sun.com/servers/blades/x6250/", NULL),
862B("Sun","Fire x4150",0, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
863B("Sun","Fire x4200",0, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
864B("Sun","Fire x4540",0, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
865B("Sun","Fire x4600",0, "http://www.sun.com/servers/x64/x4600/", "No public report found. May work now."),
866B("Sun","Ultra 40 M2",1, "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html", NULL),
867B("Supermicro","H8QC8",1, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
868B("Supermicro", "X5DP8-G2",1, "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm", NULL),
869B("Supermicro", "X7DBT-INF",1, "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm", NULL),
870B("Supermicro", "X7SPA-HF",1, "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H&IPMI=Y", NULL),
871B("Supermicro", "X8DT3",1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm", NULL),
872B("Supermicro", "X8DTH-6F",1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm", NULL),
873B("Supermicro","X8DTT-F",1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
874B("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."),
875B("Supermicro","X8DTU-F",1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm", NULL),
876B("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)."),
877B("Supermicro","X8STi",1, "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm", NULL),
878B("Supermicro","X9SCL",0, "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."),
879B("T-Online","S-100",1, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
880B("Tekram","P6Pro-A5",1, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
881B("Termtek","TK-3370 (Rev:2.5B)",1, NULL, NULL),
882B("Thomson","IP1000",1, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
883B("TriGem","Lomita",1, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
884B("Tyan","S5375-1U (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
885B("Tyan","S1846 (Tsunami ATX)",1, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
886B("Tyan","S2466 (Tiger MPX)",1, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
887B("Tyan","S2498 (Tomcat K7M)",1, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
888B("Tyan","S2723 (Tiger i7501)",1, "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
889B("Tyan","S2881 (Thunder K8SR)",1, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
890B("Tyan","S2882 (Thunder K8S Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
891B("Tyan","S2882-D (Thunder K8SD Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
892B("Tyan","S2891 (Thunder K8SRE)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
893B("Tyan","S2892 (Thunder K8SE)",1, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
894B("Tyan","S2895 (Thunder K8WE)",1, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
895B("Tyan","S2912 (Thunder n3600R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
896B("Tyan","S2915 (Thunder n6650W)", 1, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
897B("Tyan","S2915-E (Thunder n6650W)", 1, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041", NULL),
898B("Tyan","S2933 (Thunder n3600S)", 1, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
899B("Tyan","S3095 (Tomcat i945GM)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
900B("Tyan","S3992 (Thunder h2000M)", 1, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
901B("Tyan","S5180 (Toledo i965R)",1, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
902B("Tyan","S5191 (Toledo i3000R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
903B("Tyan","S5197 (Toledo i3010W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
904B("Tyan","S5211 (Toledo i3210W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
905B("Tyan","S5211-1U (Toledo i3200R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
906B("Tyan","S5220 (Toledo q35T)",1, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
907B("Tyan","S5375 (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
908B("Tyan","S5376 (Tempest i5100W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
909B("Tyan","S5377 (Tempest i5100T)", 1, "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017", NULL),
910B("Tyan","S5382 (Tempest i5000PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
911B("Tyan","S5397 (Tempest i5400PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
912B("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 */
913B("VIA","EPIA SP",1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
914B("VIA","EPIA-CN",1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400", NULL),
915B("VIA","EPIA EK",1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420", NULL),
916B("VIA","EPIA-EX15000G",1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
917B("VIA","EPIA-LN",1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
918B("VIA","EPIA-M700",1, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
919B("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 */
920B("VIA","EPIA-NX15000G",1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
921B("VIA","NAB74X0",1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
922B("VIA","pc2500e",1, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
923B("VIA","PC3500G",1, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
924B("VIA","VB700X",1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
925B("ZOTAC","Fusion-ITX WiFi (FUSION350-A-E)", 1, NULL, NULL),
926B("ZOTAC","GeForce 8200",1, "http://pden.zotac.com/index.php?page=shop.product_details&product_id=129&category_id=92", NULL),
927B("ZOTAC","H67-ITX WiFi (H67ITX-C-E)", 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."),
928B("ZOTAC","ZBOX HD-ID11",1, "http://pdde.zotac.com/index.php?page=shop.product_details&product_id=240&category_id=75", NULL),
929#endif
930
931{},
932};
933
934/* Please keep this list alphabetically ordered by vendor/board. */
935const struct board_info laptops_known[] = {
936#if defined(__i386__) || defined(__x86_64__)
937B("Acer","Aspire 1520",1, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
938B("Acer","Aspire One",0, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
939B("ASUS","A8Jm",1, NULL, NULL),
940B("ASUS","Eee PC 701 4G",0, "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)."),
941B("ASUS","M6Ne",0, "http://www.asus.com/Notebooks/Versatile_Performance/M6NNe/", "Untested board enable."),
942B("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."),
943B("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"),
944B("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)."),
945B("IBM/Lenovo","Thinkpad T40p",0, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
946B("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."),
947B("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."),
948B("Lenovo","3000 V100 TF05Cxx",1, "http://www5.pc.ibm.com/europe/products.nsf/products?openagent&brand=Lenovo3000Notebook&series=Lenovo+3000+V+Series#viewallmodelstop", NULL),
949#endif
950
951{},
952};
953#endif
954

Archive Download this file

Revision: HEAD