blob: a5c36b706346e77bd381df28f423435f529599c0 [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"
26#include "flashchips.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000027#include "programmer.h"
Uwe Hermannba290d12009-06-17 12:07:12 +000028
29/*
30 * Return a string corresponding to the bustype parameter.
31 * Memory is obtained with malloc() and can be freed with free().
32 */
33char *flashbuses_to_text(enum chipbustype bustype)
34{
35 char *ret = calloc(1, 1);
36 if (bustype == CHIP_BUSTYPE_UNKNOWN) {
37 ret = strcat_realloc(ret, "Unknown,");
38 /*
39 * FIXME: Once all chipsets and flash chips have been updated, NONSPI
40 * will cease to exist and should be eliminated here as well.
41 */
42 } else if (bustype == CHIP_BUSTYPE_NONSPI) {
43 ret = strcat_realloc(ret, "Non-SPI,");
44 } else {
45 if (bustype & CHIP_BUSTYPE_PARALLEL)
46 ret = strcat_realloc(ret, "Parallel,");
47 if (bustype & CHIP_BUSTYPE_LPC)
48 ret = strcat_realloc(ret, "LPC,");
49 if (bustype & CHIP_BUSTYPE_FWH)
50 ret = strcat_realloc(ret, "FWH,");
51 if (bustype & CHIP_BUSTYPE_SPI)
52 ret = strcat_realloc(ret, "SPI,");
53 if (bustype == CHIP_BUSTYPE_NONE)
54 ret = strcat_realloc(ret, "None,");
55 }
56 /* Kill last comma. */
57 ret[strlen(ret) - 1] = '\0';
58 ret = realloc(ret, strlen(ret) + 1);
59 return ret;
60}
61
62#define POS_PRINT(x) do { pos += strlen(x); printf(x); } while (0)
63
64static int digits(int n)
65{
66 int i;
67
68 if (!n)
69 return 1;
70
71 for (i = 0; n; ++i)
72 n /= 10;
73
74 return i;
75}
76
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +000077static void print_supported_chips(void)
Uwe Hermannba290d12009-06-17 12:07:12 +000078{
79 int okcol = 0, pos = 0, i, chipcount = 0;
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000080 int maxchiplen = 0, maxvendorlen = 0;
Uwe Hermannba290d12009-06-17 12:07:12 +000081 struct flashchip *f;
82
83 for (f = flashchips; f->name != NULL; f++) {
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000084 /* Ignore "unknown XXXX SPI chip" entries. */
85 if (!strncmp(f->name, "unknown", 7))
Uwe Hermannba290d12009-06-17 12:07:12 +000086 continue;
Uwe Hermannba290d12009-06-17 12:07:12 +000087 chipcount++;
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000088 maxvendorlen = max(maxvendorlen, strlen(f->vendor));
89 maxchiplen = max(maxchiplen, strlen(f->name));
90 }
91 maxvendorlen++;
92 maxchiplen++;
93 okcol = maxvendorlen + maxchiplen;
Uwe Hermannba290d12009-06-17 12:07:12 +000094
95 printf("\nSupported flash chips (total: %d):\n\n", chipcount);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +000096 printf("Vendor");
97 for (i = strlen("Vendor"); i < maxvendorlen; i++)
98 printf(" ");
99 printf("Device");
100 for (i = strlen("Device"); i < maxchiplen; i++)
101 printf(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000102
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000103 printf("Tested Known Size/KB: Type:\n");
104 for (i = 0; i < okcol; i++)
105 printf(" ");
106 printf("OK Broken\n\n");
Uwe Hermannba290d12009-06-17 12:07:12 +0000107 printf("(P = PROBE, R = READ, E = ERASE, W = WRITE)\n\n");
108
109 for (f = flashchips; f->name != NULL; f++) {
110 /* Don't print "unknown XXXX SPI chip" entries. */
111 if (!strncmp(f->name, "unknown", 7))
112 continue;
113
114 printf("%s", f->vendor);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000115 for (i = strlen(f->vendor); i < maxvendorlen; i++)
Uwe Hermannba290d12009-06-17 12:07:12 +0000116 printf(" ");
117 printf("%s", f->name);
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000118 for (i = strlen(f->name); i < maxchiplen; i++)
119 printf(" ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000120
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000121 pos = maxvendorlen + maxchiplen;
Uwe Hermannba290d12009-06-17 12:07:12 +0000122 if ((f->tested & TEST_OK_MASK)) {
123 if ((f->tested & TEST_OK_PROBE))
124 POS_PRINT("P ");
125 if ((f->tested & TEST_OK_READ))
126 POS_PRINT("R ");
127 if ((f->tested & TEST_OK_ERASE))
128 POS_PRINT("E ");
129 if ((f->tested & TEST_OK_WRITE))
130 POS_PRINT("W ");
131 }
132 while (pos < okcol + 9) {
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000133 printf(" ");
134 pos++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000135 }
136 if ((f->tested & TEST_BAD_MASK)) {
137 if ((f->tested & TEST_BAD_PROBE))
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000138 POS_PRINT("P ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000139 if ((f->tested & TEST_BAD_READ))
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000140 POS_PRINT("R ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000141 if ((f->tested & TEST_BAD_ERASE))
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000142 POS_PRINT("E ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000143 if ((f->tested & TEST_BAD_WRITE))
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000144 POS_PRINT("W ");
Uwe Hermannba290d12009-06-17 12:07:12 +0000145 }
146
Carl-Daniel Hailfingerf7533422010-07-17 23:21:12 +0000147 while (pos < okcol + 18) {
148 printf(" ");
149 pos++;
150 }
151 printf("%d", f->total_size);
Uwe Hermannba290d12009-06-17 12:07:12 +0000152 for (i = 0; i < 10 - digits(f->total_size); i++)
153 printf(" ");
154 printf("%s\n", flashbuses_to_text(f->bustype));
155 }
156}
157
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000158#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000159static void print_supported_chipsets(void)
Uwe Hermannba290d12009-06-17 12:07:12 +0000160{
161 int i, j, chipsetcount = 0;
162 const struct penable *c = chipset_enables;
163
164 for (i = 0; c[i].vendor_name != NULL; i++)
165 chipsetcount++;
166
167 printf("\nSupported chipsets (total: %d):\n\nVendor: "
168 "Chipset: PCI IDs:\n\n", chipsetcount);
169
170 for (i = 0; c[i].vendor_name != NULL; i++) {
171 printf("%s", c[i].vendor_name);
172 for (j = 0; j < 25 - strlen(c[i].vendor_name); j++)
173 printf(" ");
174 printf("%s", c[i].device_name);
175 for (j = 0; j < 25 - strlen(c[i].device_name); j++)
176 printf(" ");
177 printf("%04x:%04x%s\n", c[i].vendor_id, c[i].device_id,
178 (c[i].status == OK) ? "" : " (untested)");
179 }
180}
181
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000182static void print_supported_boards_helper(const struct board_info *boards,
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000183 const char *devicetype)
Uwe Hermannba290d12009-06-17 12:07:12 +0000184{
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000185 int i, j, boardcount_good = 0, boardcount_bad = 0;
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000186 const struct board_pciid_enable *b = board_pciid_enables;
Uwe Hermannba290d12009-06-17 12:07:12 +0000187
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000188 for (i = 0; boards[i].vendor != NULL; i++) {
189 if (boards[i].working)
190 boardcount_good++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000191 else
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000192 boardcount_bad++;
Uwe Hermannba290d12009-06-17 12:07:12 +0000193 }
194
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000195 printf("\nKnown %s (good: %d, bad: %d):"
196 "\n\nVendor: Board: "
197 "Status: Required option:"
198 "\n\n", devicetype, boardcount_good, boardcount_bad);
199
200 for (i = 0; boards[i].vendor != NULL; i++) {
201 printf("%s", boards[i].vendor);
202 for (j = 0; j < 25 - strlen(boards[i].vendor); j++)
203 printf(" ");
204 printf("%s", boards[i].name);
205 for (j = 0; j < 28 - strlen(boards[i].name); j++)
206 printf(" ");
207 printf((boards[i].working) ? "OK " : "BAD ");
208
209 for (j = 0; b[j].vendor_name != NULL; j++) {
210 if (strcmp(b[j].vendor_name, boards[i].vendor)
211 || strcmp(b[j].board_name, boards[i].name))
212 continue;
213 if (b[j].lb_vendor == NULL)
214 printf("(autodetected)");
215 else
216 printf("-m %s:%s", b[j].lb_vendor,
217 b[j].lb_part);
218 }
219 printf("\n");
220 }
Uwe Hermannba290d12009-06-17 12:07:12 +0000221}
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000222#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000223
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000224void print_supported(void)
225{
226 print_supported_chips();
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000227#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000228 print_supported_chipsets();
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000229 print_supported_boards_helper(boards_known, "boards");
230 print_supported_boards_helper(laptops_known, "laptops");
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000231#endif
Andrew Morgan74a828a2010-07-21 15:12:07 +0000232#if CONFIG_NIC3COM+CONFIG_NICREALTEK+CONFIG_NICNATSEMI+CONFIG_GFXNVIDIA+CONFIG_DRKAISER+CONFIG_SATASII+CONFIG_ATAHPT >= 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000233 printf("\nSupported PCI devices flashrom can use "
234 "as programmer:\n\n");
Adam Jurkowski516f9322009-12-14 03:07:31 +0000235#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000236#if CONFIG_NIC3COM == 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000237 print_supported_pcidevs(nics_3com);
238#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000239#if CONFIG_NICREALTEK == 1
Uwe Hermann829ed842010-05-24 17:39:14 +0000240 print_supported_pcidevs(nics_realtek);
241 print_supported_pcidevs(nics_realteksmc1211);
242#endif
Andrew Morgan74a828a2010-07-21 15:12:07 +0000243#if CONFIG_NICNATSEMI == 1
244 print_supported_pcidevs(nics_natsemi);
245#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000246#if CONFIG_GFXNVIDIA == 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000247 print_supported_pcidevs(gfx_nvidia);
248#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000249#if CONFIG_DRKAISER == 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000250 print_supported_pcidevs(drkaiser_pcidev);
251#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000252#if CONFIG_SATASII == 1
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000253 print_supported_pcidevs(satas_sii);
254#endif
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000255#if CONFIG_ATAHPT == 1
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +0000256 print_supported_pcidevs(ata_hpt);
257#endif
Idwer Vollering004f4b72010-09-03 18:21:21 +0000258#if CONFIG_NICINTEL_SPI == 1
259 print_supported_pcidevs(nics_intel_spi);
260#endif
Jörg Fischer6529b9f2010-07-29 15:54:53 +0000261
262#if CONFIG_FT2232_SPI+CONFIG_DEDIPROG >= 1
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000263 printf("\nSupported USB devices flashrom can use "
264 "as programmer:\n\n");
Jörg Fischer6529b9f2010-07-29 15:54:53 +0000265#endif
266
267#if CONFIG_FT2232_SPI == 1
268 print_supported_usbdevs(devs_ft2232spi);
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000269#endif
Carl-Daniel Hailfingerf5292052009-11-17 09:57:34 +0000270}
271
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000272#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger4146ced2010-06-07 11:10:43 +0000273
274#ifdef CONFIG_PRINT_WIKI
275#define B(vendor, name, status, url, note) { vendor, name, status, url, note }
276#else
277#define B(vendor, name, status, url, note) { vendor, name, status }
278#endif
279
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000280/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000281const struct board_info boards_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000282#if defined(__i386__) || defined(__x86_64__)
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000283 B("A-Trend", "ATC-6220", 1, "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000284 B("abit", "AN-M2", 1, "http://www.abit.com.tw/page/de/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20AM2&pMODEL_NAME=AN-M2", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000285 B("abit", "AX8", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AX8", NULL),
286 B("abit", "Fatal1ty F-I90HD", 1, "http://www.abit.com.tw/page/de/motherboard/motherboard_detail.php?pMODEL_NAME=Fatal1ty+F-I90HD&fMTYPE=LGA775", NULL),
287 B("abit", "IC7", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IC7&fMTYPE=Socket%20478", NULL),
288 B("abit", "IP35", 1, "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35", NULL),
289 B("abit", "IP35 Pro", 1, "http://www.abit.com.tw/page/de/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35%20Pro", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000290 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."),
Uwe Hermannead705f2010-08-15 15:26:30 +0000291 B("abit", "KN8 Ultra", 1, "http://www.abit.com.tw/page/de/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=KN8%20Ultra", NULL),
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000292 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),
293 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 +0000294 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 +0000295 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 +0000296 B("Acorp", "6A815EPD", 1, "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp", NULL),
297 B("Advantech", "PCM-5820", 1, "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
298 B("agami", "Aruma", 1, "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series", NULL),
299 B("Albatron", "PM266A Pro", 1, "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56", NULL), /* FIXME */
300 B("AOpen", "vKM400Am-S", 1, "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
301 B("Artec Group","DBE61", 1, "http://wiki.thincan.org/DBE61", NULL),
302 B("Artec Group","DBE62", 1, "http://wiki.thincan.org/DBE62", NULL),
303 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 +0000304 B("ASRock", "775i65G", 1, "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000305 B("ASRock", "939A785GMH/128M", 1, "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M&s=939", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000306 B("ASRock", "A330GC", 1, "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000307 B("ASRock", "A770CrossFire", 1, "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire&s=AM2\%2b", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000308 B("ASRock", "ALiveNF6G-DVI", 1, "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000309 B("ASRock", "K7VT4A+", 0, "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%%2b&s=", "No chip found, probably due to flash translation. http://www.flashrom.org/pipermail/flashrom/2009-August/000393.html"),
310 B("ASRock", "K8S8X", 1, "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000311 B("ASRock", "M3A790GXH/128M", 1, "http://www.asrock.com/MB/overview.asp?Model=M3A790GXH/128M", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000312 B("ASRock", "P4i65GV", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000313 B("ASUS", "A7N8X Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=wAsRYm41KTp78MFC", NULL),
314 B("ASUS", "A7N8X-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=TmQtPJv4jIxmL9C2", NULL),
315 B("ASUS", "A7V133", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socka/kt133a/a7v133/", NULL),
316 B("ASUS", "A7V400-MX", 1, "http://www.asus.com/product.aspx?P_ID=hORgEHRBDLMfwAwx", NULL),
317 B("ASUS", "A7V600-X", 1, "http://www.asus.com/product.aspx?P_ID=L2XYS0rmtCjeOr4k", NULL),
318 B("ASUS", "A7V8X", 1, "http://www.asus.com/product.aspx?P_ID=qfpaGrAy2kLVo0f2", NULL),
319 B("ASUS", "A7V8X-MX", 1, "http://www.asus.com/product.aspx?P_ID=SEJOOYqfuQPitx2H", NULL),
320 B("ASUS", "A7V8X-MX SE", 1, "http://www.asus.com/product.aspx?P_ID=1guVBT1qV5oqhHyZ", NULL),
321 B("ASUS", "A7V8X-X", 1, "http://www.asus.com/product.aspx?P_ID=YcXfRrWHZ9RKoVmw", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000322 B("ASUS", "A8Jm", 1, "http://www.asus.com/product.aspx?P_ID=VztICtOgiU6drx4m", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000323 B("ASUS", "A8N", 1, NULL, NULL), /* TODO: This should probably be A8N-SLI Deluxe, see http://www.coreboot.org/pipermail/flashrom/2009-November/000878.html */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000324 B("ASUS", "A8N-E", 1, "http://www.asus.com/product.aspx?P_ID=DzbA8hgqchMBOVRz", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000325 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 +0000326 B("ASUS", "A8N-SLI", 1, "http://www.asus.com/product.aspx?P_ID=J9FKa8z2xVId3pDK", NULL),
327 B("ASUS", "A8N-SLI Premium", 1, "http://www.asus.com/product.aspx?P_ID=nbulqxniNmzf0mH1", NULL),
Michael Karcher7af6cef2010-07-08 09:32:18 +0000328 B("ASUS", "A8N-VM CSM", 1, "http://www.asus.com/product.aspx?P_ID=JBqqlpj4cspbSa3s", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000329 B("ASUS", "A8NE-FM/S", 1, "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM", NULL),
330 B("ASUS", "A8V Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=tvpdgPNCPaABZRVU", NULL),
331 B("ASUS", "A8V-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=hQBPIJWEZnnGAZEh", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000332 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"),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000333 B("ASUS", "K8V", 1, "http://www.asus.com/product.aspx?P_ID=fG2KZOWF7v6MRFRm", NULL),
334 B("ASUS", "K8V SE Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=65HeDI8XM1u6Uy6o", NULL),
335 B("ASUS", "K8V-X SE", 1, "http://www.asus.com/product.aspx?P_ID=lzDXlbBVHkdckHVr", NULL),
336 B("ASUS", "M2A-MX", 1, "http://www.asus.com/product.aspx?P_ID=BmaOnPewi1JgltOZ", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000337 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 +0000338 B("ASUS", "M2N32-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=0jMy2X8lKstYRvev", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000339 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"),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000340 B("ASUS", "M2N-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=szSFtrap7crpBaQE", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000341 B("ASUS", "M2NBP-VM CSM", 1, "http://www.asus.com/product.aspx?P_ID=MnOfzTGd2KkwG0rF", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000342 B("ASUS", "M2NPV-VM", 1, "http://www.asus.com/product.aspx?P_ID=HGTVnGv5nGahCYgK", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000343 B("ASUS", "M2V", 1, "http://www.asus.com/product.aspx?P_ID=OqYlEDFfF6ZqZGvp", NULL),
344 B("ASUS", "M2V-MX", 1, "http://www.asus.com/product.aspx?P_ID=7grf8Ci4yxnqzt3z", NULL),
Uwe Hermannc2521ab2010-07-29 22:39:47 +0000345 B("ASUS", "M3A76-CM", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000346 B("ASUS", "M3A78-EM", 1, "http://www.asus.com/product.aspx?P_ID=KjpYqzmAd9vsTM2D", NULL),
Uwe Hermann1e94fa62010-08-08 15:52:07 +0000347 B("ASUS", "M4A785TD-M EVO", 1, "http://www.asus.com/product.aspx?P_ID=QHbvGVB1mXmmD8qQ", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000348 B("ASUS", "M4A79T Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=lhJiLTN5huPfCVkW", NULL),
349 B("ASUS", "M4A87TD/USB3", 1, "http://www.asus.com/product.aspx?P_ID=nlWYrI9wlNIYHAaa", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000350 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."),
351 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 +0000352 B("ASUS", "P2B", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b/", NULL),
353 B("ASUS", "P2B-D", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
354 B("ASUS", "P2B-DS", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-ds/", NULL),
355 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 +0000356 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 +0000357 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 +0000358 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 +0000359 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 +0000360 B("ASUS", "P4B266", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b266/", NULL),
361 B("ASUS", "P4B266-LM", 1, "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000362 B("ASUS", "P4B533-E", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b533-e/", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000363 B("ASUS", "P4C800-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=cFuVCr9bXXCckmcK", NULL),
364 B("ASUS", "P4P800-E Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=INIJUvLlif7LHp3g", NULL),
Michael Karcher87c90992010-07-24 11:03:48 +0000365 B("ASUS", "P4SD-LA", 1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000366 B("ASUS", "P4S800-MX", 1, "http://www.asus.com/product.aspx?P_ID=Bb57zoJhmO1Qkcrh", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000367 B("ASUS", "P5A", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock7/ali/p5a/", NULL),
368 B("ASUS", "P5B", 1, "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B/", NULL),
369 B("ASUS", "P5B-Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=bswT66IBSb2rEWNa", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000370 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 +0000371 B("ASUS", "P5GC-MX/1333", 1, "http://www.asus.com/product.aspx?P_ID=PYvbfOokwxUzJky3", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000372 B("ASUS", "P5KC", 1, "http://www.asus.com/product.aspx?P_ID=fFZ8oUIGmLpwNMjj", NULL),
373 B("ASUS", "P5L-MX", 1, "http://www.asus.com/product.aspx?P_ID=X70d3NCzH2DE9vWH", NULL),
374 B("ASUS", "P5ND2-SLI Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=WY7XroDuUImVbgp5", NULL),
Michael Karcher72eeab52010-07-24 10:41:42 +0000375 B("ASUS", "P5PE-VM", 1, "http://www.asus.com/product.aspx?P_ID=k3h0ZFVu9Lo1dUvk", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000376 B("ASUS", "P6T SE", 1, "http://www.asus.com/product.aspx?P_ID=t4yhK6y9W9o7iQ9E", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000377 B("ASUS", "P6T Deluxe", 1, "http://www.asus.com/product.aspx?P_ID=vXixf82co6Q5v0BZ", NULL),
378 B("ASUS", "P6T Deluxe V2", 1, "http://www.asus.com/product.aspx?P_ID=iRlP8RG9han6saZx", NULL),
379 B("BCOM", "WinNET100", 1, "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin client."),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000380 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 +0000381 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 +0000382 B("Biostar", "P4M80-M4", 1, "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
Daniel Lenskib9e2cb52010-07-30 17:08:29 +0000383 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 +0000384 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 +0000385 B("Congatec", "conga-X852", 1, "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000386 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 +0000387 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 +0000388 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),
389 B("Elitegroup", "K7S5A", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=279&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0", NULL),
390 B("Elitegroup", "K7S6A", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=77&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
391 B("Elitegroup", "K7VTA3", 1, "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=264&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000392 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 +0000393 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 +0000394 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 +0000395 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 +0000396 B("EPoX", "EP-8K5A2", 1, "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
397 B("EPoX", "EP-8RDA3+", 1, "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
398 B("EPoX", "EP-BX3", 1, "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000399 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."),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000400 B("Foxconn", "A6VMX", 1, "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000346", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000401 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 +0000402 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 +0000403 B("GIGABYTE", "GA-6BXC", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
404 B("GIGABYTE", "GA-6BXDU", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
405 B("GIGABYTE", "GA-6ZMA", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000406 B("GIGABYTE", "GA-MA785GMT-UD2H", 1, "http://www.gigabyte.de/Products/Motherboard/Products_Overview.aspx?ProductID=4525", NULL),
407 B("GIGABYTE", "GA-770TA-UD3", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3272#ov", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000408 B("GIGABYTE", "GA-7VT600", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
409 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."),
Michael Karcherc7a1ffb2010-07-24 22:27:29 +0000410 B("GIGABYTE", "GA-8IRML", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
Michael Karcherc8613242010-08-13 12:49:01 +0000411 B("GIGABYTE", "GA-8PE667 Ultra 2", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000412 B("GIGABYTE", "GA-965P-DS4", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
413 B("GIGABYTE", "GA-EP35-DS3L", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
414 B("GIGABYTE", "GA-EX58-UD4P", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
415 B("GIGABYTE", "GA-K8N-SLI", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
Joshua Roys2ee137f2010-09-07 17:52:09 +0000416 B("GIGABYTE", "GA-K8N51GMF-9", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000417 B("GIGABYTE", "GA-M57SLI-S4", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
418 B("GIGABYTE", "GA-M61P-S3", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
419 B("GIGABYTE", "GA-MA69VM-S2", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
Peter Lemenkov12a58b22010-07-29 21:15:45 +0000420 B("GIGABYTE", "GA-MA74GM-S2H (rev. 3.0)", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
Peter Lemenkov8b83f552010-06-04 16:39:35 +0000421 B("GIGABYTE", "GA-MA770T-UD3P", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
422 B("GIGABYTE", "GA-MA78G-DS3H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL), /* TODO: Rev 1.x or 2.x? */
423 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? */
424 B("GIGABYTE", "GA-MA78GPM-DS2H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
425 B("GIGABYTE", "GA-MA790FX-DQ6", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
426 B("GIGABYTE", "GA-MA790GP-DS4H", 1, "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000427 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),
428 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 +0000429 B("HP", "Puffer2-UL8E", 1, "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000430 B("HP", "Vectra VL400", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us", NULL),
431 B("HP", "Vectra VL420 SFF", 1, "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us", NULL),
Michael Karcher2ead2e22010-06-01 16:09:06 +0000432 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 +0000433 B("IBASE", "MB899", 1, "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000434 B("IBM", "x3455", 1, "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000435 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 +0000436 B("Intel", "D201GLY", 1, "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm", NULL),
437 B("Intel", "EP80759", 1, NULL, NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000438 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 +0000439 B("IWILL", "DK8-HTX", 1, "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98", NULL),
440 B("Jetway", "J7F4K1G5D-PB", 1, "http://www.jetway.com.tw/jetway/system/productshow2.asp?id=389&proname=J7F4K1G5D-P", NULL),
441 B("Kontron", "986LCD-M", 1, "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000442 B("Lex", "CV700A", 1, "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000443 B("Mitac", "6513WU", 1, "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm", NULL),
444 B("MSI", "MS-6153", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=336", NULL),
445 B("MSI", "MS-6156", 1, "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000446 B("MSI", "MS-6178", 0, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=343", "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>."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000447 B("MSI", "MS-6330 (K7T Turbo)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=327", NULL),
448 B("MSI", "MS-6570 (K7N2)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=519", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000449 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."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000450 B("MSI", "MS-6590 (KT4 Ultra)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=502", NULL),
451 B("MSI", "MS-6702E (K8T Neo2-F)",1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=588", NULL),
452 B("MSI", "MS-6712 (KT4V)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=505", NULL),
Sergey A Lichackf3a4bff2010-09-07 18:14:53 +0000453 B("MSI", "MS-6787 (P4MAM-V/P4MAM-L)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=577", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000454 B("MSI", "MS-7005 (651M-L)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=559", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000455 B("MSI", "MS-7025 (K8N Neo2 Platinum)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=587", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000456 B("MSI", "MS-7046", 1, "http://www.heimir.de/ms7046/", NULL),
Mattias Mattssone295eee2010-08-15 10:21:29 +0000457 B("MSI", "MS-7061 (KM4M-V/KM4AM-V)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=594", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000458 B("MSI", "MS-7065", 1, "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
459 B("MSI", "MS-7135 (K8N Neo3)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=170", NULL),
460 B("MSI", "MS-7168 (Orion)", 1, "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart", NULL),
Uwe Hermannead705f2010-08-15 15:26:30 +0000461 B("MSI", "MS-7207 (K8NGM2-L)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=224", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000462 B("MSI", "MS-7236 (945PL Neo3)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1173", NULL),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000463 B("MSI", "MS-7253 (K9VGM-V)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=260", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000464 B("MSI", "MS-7255 (P4M890M)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1082", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000465 B("MSI", "MS-7260, (K9N Neo)", 0, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=255", "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>."),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000466 B("MSI", "MS-7312 (K9MM-V)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1104", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000467 B("MSI", "MS-7345 (P35 Neo2-FIR)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1261", NULL),
468 B("MSI", "MS-7368 (K9AG Neo2-Digital)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1241", NULL),
469 B("MSI", "MS-7376 (K9A2 Platinum)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=1332", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000470 B("MSI", "MS-7642 (890GXM-G65)", 1, "http://www.msi.com/index.php?func=proddesc&maincat_no=1&prod_no=2012", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000471 B("NEC", "PowerMate 2000", 1, "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/", NULL),
472 B("Nokia", "IP530", 1, NULL, NULL),
473 B("PC Engines", "Alix.1c", 1, "http://pcengines.ch/alix1c.htm", NULL),
474 B("PC Engines", "Alix.2c2", 1, "http://pcengines.ch/alix2c2.htm", NULL),
475 B("PC Engines", "Alix.2c3", 1, "http://pcengines.ch/alix2c3.htm", NULL),
476 B("PC Engines", "Alix.3c3", 1, "http://pcengines.ch/alix3c3.htm", NULL),
477 B("PC Engines", "Alix.3d3", 1, "http://pcengines.ch/alix3d3.htm", NULL),
478 B("PC Engines", "WRAP.2E", 1, "http://pcengines.ch/wrap2e1.htm", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000479 B("Portwell", "PEB-4700VLA", 1, "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000480 B("RCA", "RM4100", 1, "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000481 B("Samsung", "Polaris 32", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000482 B("Shuttle", "AK31", 1, "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
483 B("Shuttle", "AK38N", 1, "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/", NULL),
Uwe Hermann51afebb2010-08-01 00:13:49 +0000484 B("Shuttle", "AV11V30", 1, NULL, NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000485 B("Shuttle", "FD37", 1, "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/", NULL),
486 B("Shuttle", "FN25", 1, "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000487 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 +0000488 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 +0000489 B("Soyo", "SY-6BA+ III", 1, "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000490 B("Soyo", "SY-7VCA", 1, "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html", NULL),
491 B("Sun", "Blade x6250", 1, "http://www.sun.com/servers/blades/x6250/", NULL),
Carl-Daniel Hailfinger9017cec2010-09-04 23:37:40 +0000492 B("Sun", "Fire x4150", 0, "http://www.sun.com/servers/x64/x4150/", "No public report found. May work now."),
493 B("Sun", "Fire x4200", 0, "http://www.sun.com/servers/entry/x4200/", "No public report found. May work now."),
494 B("Sun", "Fire x4540", 0, "http://www.sun.com/servers/x64/x4540/", "No public report found. May work now."),
495 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 +0000496 B("Supermicro", "H8QC8", 1, "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm", NULL),
497 B("Supermicro", "X8DTT-F", 1, "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm", NULL),
498 B("T-Online", "S-100", 1, "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
499 B("Tekram", "P6Pro-A5", 1, "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
500 B("Termtek", "TK-3370 (Rev:2.5B)", 1, NULL, NULL),
501 B("Thomson", "IP1000", 1, "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
502 B("TriGem", "Lomita", 1, "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000503 B("Tyan", "S5375-1U (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
504 B("Tyan", "S1846 (Tsunami ATX)", 1, "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
505 B("Tyan", "S2466 (Tiger MPX)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000506 B("Tyan", "S2498 (Tomcat K7M)", 1, "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000507 B("Tyan", "S2881 (Thunder K8SR)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
508 B("Tyan", "S2882 (Thunder K8S Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
509 B("Tyan", "S2882-D (Thunder K8SD Pro)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
510 B("Tyan", "S2891 (Thunder K8SRE)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
511 B("Tyan", "S2892 (Thunder K8SE)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
512 B("Tyan", "S2895 (Thunder K8WE)", 1, "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
Uwe Hermann49228cb2010-07-29 19:26:15 +0000513 B("Tyan", "S2915 (Thunder n6650W)", 1, "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000514 B("Tyan", "S2933 (Thunder n3600S)", 1, "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063", NULL),
515 B("Tyan", "S3095 (Tomcat i945GM)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
516 B("Tyan", "S3992 (Thunder h2000M)", 1, "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
517 B("Tyan", "S5180 (Toledo i965R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
518 B("Tyan", "S5191 (Toledo i3000R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
519 B("Tyan", "S5197 (Toledo i3010W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
520 B("Tyan", "S5211 (Toledo i3210W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
521 B("Tyan", "S5211-1U (Toledo i3200R)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
522 B("Tyan", "S5220 (Toledo q35T)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
523 B("Tyan", "S5375 (Tempest i5100X)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
524 B("Tyan", "S5376 (Tempest i5100W)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both S5376G2NR and S5376WAG2NR should work."),
525 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 +0000526 B("Tyan", "S5382 (Tempest i5000PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000527 B("Tyan", "S5397 (Tempest i5400PW)", 1, "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000528 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 */
529 B("VIA", "EPIA SP", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261", NULL),
530 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 +0000531 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 +0000532 B("VIA", "EPIA-EX15000G", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450", NULL),
533 B("VIA", "EPIA-LN", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473", NULL),
534 B("VIA", "EPIA-M700", 1, "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700", NULL),
535 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 */
536 B("VIA", "EPIA-NX15000G", 1, "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470", NULL),
537 B("VIA", "NAB74X0", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590", NULL),
538 B("VIA", "pc2500e", 1, "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp", NULL),
539 B("VIA", "PC3500G", 1, "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp", NULL),
540 B("VIA", "VB700X", 1, "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490", NULL),
Uwe Hermann431f4f72010-09-05 12:41:25 +0000541 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 +0000542#endif
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000543
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000544 {},
545};
546
547/* Please keep this list alphabetically ordered by vendor/board. */
Peter Lemenkov4adf8a62010-06-01 10:13:17 +0000548const struct board_info laptops_known[] = {
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +0000549#if defined(__i386__) || defined(__x86_64__)
Uwe Hermann301703b2010-06-03 16:35:51 +0000550 B("Acer", "Aspire 1520", 1, "http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml", NULL),
551 B("Acer", "Aspire One", 0, NULL, "http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
552 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)."),
553 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 +0000554 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 +0000555 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)."),
556 B("IBM/Lenovo", "Thinkpad T40p", 0, "http://www.thinkwiki.org/wiki/Category:T40p", NULL),
557 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."),
558 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 +0000559#endif
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000560
Uwe Hermannd0e347d2009-10-06 13:00:00 +0000561 {},
562};
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +0000563#endif