[flashrom] [PATCH 1/5] print_wiki.c: count pci devices and cleanup

Idwer Vollering vidwer at gmail.com
Mon Feb 20 18:18:18 CET 2012


Can you incorporate this too?

$ svn diff pcidev.c
Index: pcidev.c
===================================================================
--- pcidev.c    (revision 1504)
+++ pcidev.c    (working copy)
@@ -244,7 +244,6 @@
 {
        int i;

-       msg_pinfo("PCI devices:\n");
        for (i = 0; devs[i].vendor_name != NULL; i++) {
                msg_pinfo("%s %s [%04x:%04x]%s\n", devs[i].vendor_name,
                          devs[i].device_name, devs[i].vendor_id,


$ svn diff print.c
Index: print.c
===================================================================
--- print.c     (revision 1504)
+++ print.c     (working copy)
@@ -422,6 +422,21 @@
 }
 #endif

+#if CONFIG_FT2232_SPI == 1
+void print_supported_usbdevs(const struct usbdev_status *devs)
+{
+       int i;
+
+       msg_pinfo("USB devices:\n");
+       for (i = 0; devs[i].vendor_name != NULL; i++) {
+               msg_pinfo("%s %s [%04x:%04x]%s\n", devs[i].vendor_name,
+                         devs[i].device_name, devs[i].vendor_id,
+                         devs[i].device_id,
+                         (devs[i].status == NT) ? " (untested)" : "");
+       }
+}
+#endif
+
 void print_supported(void)
 {
        print_supported_chips();
@@ -444,42 +459,42 @@
        msg_ginfo("Dummy device, does nothing and logs all accesses\n");
 #endif
 #if CONFIG_NIC3COM == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_NIC3COM].name);
        print_supported_pcidevs(nics_3com);
 #endif
 #if CONFIG_NICREALTEK == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_NICREALTEK].name);
        print_supported_pcidevs(nics_realtek);
 #endif
 #if CONFIG_NICNATSEMI == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_NICNATSEMI].name);
        print_supported_pcidevs(nics_natsemi);
 #endif
 #if CONFIG_GFXNVIDIA == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI/AGP devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_GFXNVIDIA].name);
        print_supported_pcidevs(gfx_nvidia);
 #endif
 #if CONFIG_DRKAISER == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_DRKAISER].name);
        print_supported_pcidevs(drkaiser_pcidev);
 #endif
 #if CONFIG_SATASII == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_SATASII].name);
        print_supported_pcidevs(satas_sii);
 #endif
 #if CONFIG_ATAHPT == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_ATAHPT].name);
        print_supported_pcidevs(ata_hpt);
 #endif
 #if CONFIG_FT2232_SPI == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported USB devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_FT2232_SPI].name);
        print_supported_usbdevs(devs_ft2232spi);
 #endif
@@ -487,16 +502,17 @@
        msg_ginfo("\nSupported devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_SERPROG].name);
        /* FIXME */
-       msg_ginfo("All programmer devices speaking the serprog protocol\n");
+//     msg_ginfo("All programmer devices speaking the serprog protocol\n");
+       msg_ginfo("All programmer devices speaking the %s protocol\n",
programmer_table[PROGRAMMER_SERPROG].name);
 #endif
 #if CONFIG_BUSPIRATE_SPI == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported USB devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_BUSPIRATE_SPI].name);
        /* FIXME */
        msg_ginfo("Dangerous Prototypes Bus Pirate\n");
 #endif
 #if CONFIG_DEDIPROG == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported USB devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_DEDIPROG].name);
        /* FIXME */
        msg_ginfo("Dediprog SF100\n");
@@ -508,22 +524,22 @@
        msg_ginfo("RayeR parallel port programmer\n");
 #endif
 #if CONFIG_NICINTEL == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_NICINTEL].name);
        print_supported_pcidevs(nics_intel);
 #endif
 #if CONFIG_NICINTEL_SPI == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_NICINTEL_SPI].name);
        print_supported_pcidevs(nics_intel_spi);
 #endif
 #if CONFIG_OGP_SPI == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_OGP_SPI].name);
        print_supported_pcidevs(ogp_spi);
 #endif
 #if CONFIG_SATAMV == 1
-       msg_ginfo("\nSupported devices for the %s programmer:\n",
+       msg_ginfo("\nSupported PCI devices for the %s programmer:\n",
               programmer_table[PROGRAMMER_SATAMV].name);
        print_supported_pcidevs(satas_mv);
 #endif
@@ -545,428 +561,427 @@
 /* Please keep this list alphabetically ordered by vendor/board. */
 const struct board_info boards_known[] = {
 #if defined(__i386__) || defined(__x86_64__)
-       B("A-Trend",    "ATC-6220",             1,
"http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
-       B("abit",       "A-S78H",               1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=A-S78H&fMTYPE=Socket+AM2",
NULL),
-       B("abit",       "AN-M2",                1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20AM2&pMODEL_NAME=AN-M2",
NULL),
-       B("abit",       "AV8",                  1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AV8",
NULL),
-       B("abit",       "AX8",                  1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AX8",
NULL),
-       B("abit",       "BM6",                  1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=BM6&fMTYPE=Socket%20370",
NULL),
-       B("abit",       "Fatal1ty F-I90HD",     1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=Fatal1ty+F-I90HD&fMTYPE=LGA775",
NULL),
-       B("abit",       "IC7",                  1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IC7&fMTYPE=Socket%20478",
NULL),
-       B("abit",       "IP35",                 1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35",
NULL),
-       B("abit",       "IP35 Pro",             1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35%20Pro",
NULL),
-       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 at aol.com to flashrom at coreboot.org, no public
archive. Missing board enable and/or M50FW040 unlocking. May work
now."),
-       B("abit",       "KN8 Ultra",            1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=KN8%20Ultra",
NULL),
-       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),
-       B("abit",       "NF-M2S",               1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=NF-M2S&fMTYPE=Socket%20AM2",
NULL),
-       B("abit",       "NF7-S",                1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20A&pMODEL_NAME=NF7-S",
NULL),
-       B("abit",       "VA6",                  1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VA6",
NULL),
-       B("abit",       "VT6X4",                1,
"http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VT6X4",
NULL),
-       B("Acorp",      "6A815EPD",             1,
"http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp",
NULL),
-       B("Advantech",  "PCM-5820",             1,
"http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
-       B("agami",      "Aruma",                1,
"http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series",
NULL),
-       B("Albatron",   "PM266A Pro",           1,
"http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56",
NULL), /* FIXME */
-       B("AOpen",      "i945GMx-VFX",          1, NULL, "This is
(also?) an OEM board from FSC (used in e.g. ESPRIMO Q5010 with
designation D2544-B1)."),
-       B("AOpen",      "vKM400Am-S",           1,
"http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
-       B("Artec Group","DBE61",                1,
"http://wiki.thincan.org/DBE61", NULL),
-       B("Artec Group","DBE62",                1,
"http://wiki.thincan.org/DBE62", NULL),
-       B("ASI",        "MB-5BLMP",             1,
"http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III
thin client."),
-       B("ASRock",     "775i65G",              1,
"http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
-       B("ASRock",     "890GX Extreme3",       1,
"http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3", NULL),
-       B("ASRock",     "939A785GMH/128M",      1,
"http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
-       B("ASRock",     "A330GC",               1,
"http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
-       B("ASRock",     "A770CrossFire",        1,
"http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
-       B("ASRock",     "ALiveNF6G-DVI",        1,
"http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
-       B("ASRock",     "AM2NF6G-VSTA",         1,
"http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
-       B("ASRock",     "ConRoeXFire-eSATA2",   1,
"http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2",
NULL),
-       B("ASRock",     "K7S41",                1,
"http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
-       B("ASRock",     "K7S41GX",              1,
"http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
-       B("ASRock",     "K7VT4A+",              0,
"http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip
found, probably due to flash translation.
http://www.flashrom.org/pipermail/flashrom/2009-August/000393.html"),
-       B("ASRock",     "K8S8X",                1,
"http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
-       B("ASRock",     "M3A790GXH/128M",       1,
"http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
-       B("ASRock",     "P4i65GV",              1,
"http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
-       B("ASUS",       "A7N8X Deluxe",         1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
-       B("ASUS",       "A7N8X-E Deluxe",       1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/", NULL),
-       B("ASUS",       "A7N8X-VM/400",         1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
-       B("ASUS",       "A7V133",               1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/socka/kt133a/a7v133/", NULL),
-       B("ASUS",       "A7V333",               1,
"ftp://ftp.asus.com.tw/pub/asus/mb/socka/kt333/a7v333/", NULL),
-       B("ASUS",       "A7V400-MX",            1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
-       B("ASUS",       "A7V600-X",             1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
-       B("ASUS",       "A7V8X",                1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
-       B("ASUS",       "A7V8X-MX",             1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
-       B("ASUS",       "A7V8X-MX SE",          1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
-       B("ASUS",       "A7V8X-X",              1,
"http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
-       B("ASUS",       "A8M2N-LA (NodusM3-GL8E)", 1,
"http://h10010.www1.hp.com/ewfrf/wc/document?docname=c00757531&cc=us&dlc=en&lc=en",
"This is an OEM board from HP, the HP name is NodusM3-GL8E."),
-       B("ASUS",       "A8N-E",                1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
-       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."),
-       B("ASUS",       "A8N-SLI",              1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
-       B("ASUS",       "A8N-SLI Deluxe",       0, NULL, "Untested
board enable."),
-       B("ASUS",       "A8N-SLI Premium",      1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/",
NULL),
-       B("ASUS",       "A8N-VM",               1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
-       B("ASUS",       "A8N-VM CSM",           1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
-       B("ASUS",       "A8NE-FM/S",            1,
"http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM",
NULL),
-       B("ASUS",       "A8V Deluxe",           1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
-       B("ASUS",       "A8V-E Deluxe",         1,
"http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/", NULL),
-       B("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"),
-       B("ASUS",       "Crosshair II Formula", 1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/",
NULL),
-       B("ASUS",       "Crosshair IV Extreme", 1,
"http://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/",
NULL),
-       B("ASUS",       "E35M1-I DELUXE",       1,
"http://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/",
NULL),
-       B("ASUS",       "K8N",                  1,
"http://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
-       B("ASUS",       "K8V",                  1,
"http://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
-       B("ASUS",       "K8V SE Deluxe",        1,
"http://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/",
NULL),
-       B("ASUS",       "K8V-X",                1,
"http://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
-       B("ASUS",       "K8V-X SE",             1,
"http://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
-       B("ASUS",       "KFSN4-DRE/SAS",        1,
"http://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/",
NULL),
-       B("ASUS",       "M2A-MX",               1,
"http://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
-       B("ASUS",       "M2A-VM (HDMI)",        1,
"http://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
-       B("ASUS",       "M2N32-SLI Deluxe",     1,
"http://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/",
NULL),
-       B("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"),
-       B("ASUS",       "M2N-E SLI",            1,
"http://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
-       B("ASUS",       "M2N-SLI Deluxe",       1,
"http://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
-       B("ASUS",       "M2NBP-VM CSM",         1,
"http://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
-       B("ASUS",       "M2NPV-VM",             1,
"http://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
-       B("ASUS",       "M2V",                  1,
"http://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
-       B("ASUS",       "M2V-MX",               1,
"http://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
-       B("ASUS",       "M3A",                  1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
-       B("ASUS",       "M3A76-CM",             1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
-       B("ASUS",       "M3A78-EM",             1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
-       B("ASUS",       "M3N78-VM",             1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
-       B("ASUS",       "M4A78-EM",             1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
-       B("ASUS",       "M4A785TD-M EVO",       1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
-       B("ASUS",       "M4A785TD-V EVO",       1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
-       B("ASUS",       "M4A78LT-M LE",         1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
-       B("ASUS",       "M4A79T Deluxe",        1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
-       B("ASUS",       "M4A87TD/USB3",         1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
-       B("ASUS",       "M4A89GTD PRO",         1,
"http://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
-       B("ASUS",       "M4N78 PRO",            1,
"http://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
-       B("ASUS",       "M5A99X EVO",           1,
"http://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
-       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 at hermann-uwe.de>. May work
now."),
-       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 at hermann-uwe.de>. May
work now."),
-       B("ASUS",       "OPLX-M",               0, NULL, "Untested
board enable."),
-       B("ASUS",       "P2B",                  1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b/", NULL),
-       B("ASUS",       "P2B-D",                1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
-       B("ASUS",       "P2B-DS",               1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-ds/", NULL),
-       B("ASUS",       "P2B-F",                1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
-       B("ASUS",       "P2B-N",                1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-n/", NULL),
-       B("ASUS",       "P2E-M",                1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440ex/p2e-m/", NULL),
-       B("ASUS",       "P2L97-S",              1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440lx/p2l97-s/", NULL),
-       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 at hermann-uwe.de>. May work
now."),
-       B("ASUS",       "P4B266",               1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b266/", NULL),
-       B("ASUS",       "P4B266-LM",            1,
"http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
-       B("ASUS",       "P4B533-E",             1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b533-e/", NULL),
-       B("ASUS",       "P4C800-E Deluxe",      1,
"http://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/",
NULL),
-       B("ASUS",       "P4GV-LA (Guppy)",      1,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478",
NULL),
-       B("ASUS",       "P4P800",               1,
"http://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
-       B("ASUS",       "P4P800-E Deluxe",      1,
"http://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/",
NULL),
-       B("ASUS",       "P4P800-VM",            1,
"http://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
-       B("ASUS",       "P4SC-E",               1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4sc-e/", "Part of ASUS
Terminator P4 533 barebone system"),
-       B("ASUS",       "P4SD-LA",              1,
"http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505",
NULL),
-       B("ASUS",       "P4S533-X",             1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4s533-x/", NULL),
-       B("ASUS",       "P4S800-MX",            1,
"http://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
-       B("ASUS",       "P5A",                  1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/sock7/ali/p5a/", NULL),
-       B("ASUS",       "P5B",                  1,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B/", NULL),
-       B("ASUS",       "P5B-Deluxe",           1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/",
NULL),
-       B("ASUS",       "P5BV-M",               0,
"ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B-VM/", "Reported by
Bernhard M. Wiedemann <bernhard at uml12d.zq1.de> to
flashrom at coreboot.org, no public archive. Missing board enable and/or
SST49LF008A unlocking. May work now."),
-       B("ASUS",       "P5GC-MX/1333",         1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/",
NULL),
-       B("ASUS",       "P5GD1 Pro",            1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/", NULL),
-       B("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."),
-       B("ASUS",       "P5GD1(-VM)",           0, NULL, "Untested
board enable."),
-       B("ASUS",       "P5GD2 Premium",        1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/",
NULL),
-       B("ASUS",       "P5GDC Deluxe",         1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/",
NULL),
-       B("ASUS",       "P5GDC-V Deluxe",       1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/",
NULL),
-       B("ASUS",       "P5GD2/C variants",     0, NULL, "Untested
board enable."),
-       B("ASUS",       "P5K-V",                1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
-       B("ASUS",       "P5K-VM",               1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
-       B("ASUS",       "P5KC",                 1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
-       B("ASUS",       "P5KPL-CM",             1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
-       B("ASUS",       "P5L-MX",               1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
-       B("ASUS",       "P5L-VM 1394",          1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/",
NULL),
-       B("ASUS",       "P5LD2",                0, NULL, "Untested
board enable."),
-       B("ASUS",       "P5LP-LE (Lithium-UL8E)", 1,
"http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00379616&tmp_task=prodinfoCategory&cc=us&dlc=en&lc=en&product=1159887",
"This is an OEM board from HP."),
-       B("ASUS",       "P5LP-LE (Epson OEM)",  1, NULL, "This is an
OEM board from Epson (e.g. Endeavor MT7700)."),
-       B("ASUS",       "P5LP-LE",              0, NULL, "This
designation is used for OEM boards from HP, Epson and maybe others.
The HP names vary and not all of them have been tested yet. Please
report any success or failure, thanks."),
-       B("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/)."),
-       B("ASUS",       "P5N-D",                1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
-       B("ASUS",       "P5N-E SLI",            0,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/",
"Untested board enable."),
-       B("ASUS",       "P5N32-E SLI",          1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/",
NULL),
-       B("ASUS",       "P5N7A-VM",             1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
-       B("ASUS",       "P5ND2-SLI Deluxe",     1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/",
NULL),
-       B("ASUS",       "P5PE-VM",              1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
-       B("ASUS",       "P5QPL-AM",             1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
-       B("ASUS",       "P5VD1-X",              1,
"http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
-       B("ASUS",       "P6T SE",               1,
"http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
-       B("ASUS",       "P6T Deluxe",           1,
"http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/",
NULL),
-       B("ASUS",       "P6T Deluxe V2",        1,
"http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/",
NULL),
-       B("ASUS",       "P7H57D-V EVO",         1,
"http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/",
NULL),
-       B("ASUS",       "P7H55-M LX",           0, NULL, "flashrom
works correctly, but GbE LAN is nonworking (probably due to a
missing/bogus MAC address; see
http://www.flashrom.org/pipermail/flashrom/2011-July/007432.html and
http://ubuntuforums.org/showthread.php?t=1534389 for a possible
workaround)"),
-       B("ASUS",       "P8B-E/4L",             0, NULL, "Probing
works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash are
problematic: descriptor is r/o (conforming to ICH reqs), ME region is
locked."),
-       B("ASUS",       "P8B WS",               0, NULL, "Probing
works (Winbond W25Q32, 4096 kB, SPI), but parts of the flash are
problematic: descriptor is r/o (conforming to ICH reqs), ME region is
locked."),
-       B("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."),
-       B("ASUS",       "P8H61-M LE/USB3",      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."),
-       B("ASUS",       "P8H67-M PRO",          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."),
-       B("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."),
-       B("ASUS",       "P8Z68-V PRO",          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."),
-       B("ASUS",       "Z8NA-D6C",             1,
"http://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/",
NULL),
-       B("ASUS",       "Z8PE-D12",             1,
"http://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/",
NULL),
-       B("BCOM",       "WinNET100",            1,
"http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin
client."),
-       B("Bifferos",   "Bifferboard",          1,
"http://bifferos.co.uk/", NULL),
-       B("Biostar",    "N68S3+",               1, NULL, NULL),
-       B("Biostar",    "M6TBA",                0,
"ftp://ftp.biostar-usa.com/manuals/M6TBA/", "No public report found.
Owned by Uwe Hermann <uwe at hermann-uwe.de>. May work now."),
-       B("Biostar",    "M7NCD Pro",            1,
"http://www.biostar.com.tw/app/en/mb/content.php?S_ID=260", NULL),
-       B("Biostar",    "P4M80-M4",             1,
"http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
-       B("Biostar",    "TA780G M2+",           1,
"http://www.biostar.com.tw/app/en/t-series/content.php?S_ID=344",
NULL),
-       B("Boser",      "HS-6637",              0,
"http://www.boser.com.tw/manual/HS-62376637v3.4.pdf", "Reported by
Mark Robinson <mark at zl2tod.net> to flashrom at coreboot.org, no public
archive. Missing board enable and/or F29C51002T unlocking. May work
now."),
-       B("Congatec",   "conga-X852",           1,
"http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
-       B("Dell",       "OptiPlex GX1",         1,
"http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm",
NULL),
-       B("Dell",       "PowerEdge 1850",       1,
"http://support.dell.com/support/edocs/systems/pe1850/en/index.htm",
NULL),
-       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"),
-       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),
-       B("Elitegroup", "GeForce6100SM-M ",     1,
"http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=685&MenuID=24",
NULL),
-       B("Elitegroup", "GF7100PVT-M3 (V1.0)",  1,
"http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=853&CategoryID=1&DetailName=Specification&MenuID=24&LanID=0",
NULL),
-       B("Elitegroup", "K7S5A",                1,
"http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=279&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0",
NULL),
-       B("Elitegroup", "K7S6A",                1,
"http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=77&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0",
NULL),
-       B("Elitegroup", "K7SEM (V1.0A)",        1,
"http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=229&CategoryID=1&DetailName=Specification&MenuID=24&LanID=0",
NULL),
-       B("Elitegroup", "K7VTA3",               1,
"http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=264&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0",
NULL),
-       B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)", 1,
"http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&DetailID=574&DetailName=Feature&MenuID=52&LanID=0",
NULL),
-       B("Elitegroup", "P4VXMS (V1.0A)",       1, NULL, NULL),
-       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),
-       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),
-       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),
-       B("Emerson",    "ATCA-7360",            1,
"http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx",
NULL),
-       B("EPoX",       "EP-8K5A2",             1,
"http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
-       B("EPoX",       "EP-8NPA7I",            1,
"http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
-       B("EPoX",       "EP-9NPA7I",            1,
"http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
-       B("EPoX",       "EP-8RDA3+",            1,
"http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
-       B("EPoX",       "EP-BX3",               1,
"http://www.epox.com/product.asp?ID=EP-BX3", NULL),
-       B("EVGA",       "132-CK-NF78",          1,
"http://www.evga.com/articles/385.asp", NULL),
-       B("EVGA",       "270-WS-W555-A2 (Classified SR-2)", 1,
"http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
-       B("FIC",        "VA-502",               0,
"ftp://ftp.fic.com.tw/motherboard/manual/socket7/va-502/", "No public
report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>. Seems the PCI
subsystem IDs are identical with the Tekram P6Pro-A5. May work now."),
-       B("Foxconn",    "6150K8MD-8EKRSH",      1,
"http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000157",
NULL),
-       B("Foxconn",    "A6VMX",                1,
"http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000346",
NULL),
-       B("Foxconn",    "P4M800P7MA-RS2",       1,
"http://www.foxconnchannel.com/Product/Motherboards/detail_overview.aspx?id=en-us0000138",
NULL),
-       B("Freetech",   "P6F91i",               1,
"http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html",
NULL),
-       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."),
-       B("GIGABYTE",   "GA-2761GXDK",          1,
"http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/",
NULL),
-       B("GIGABYTE",   "GA-6BXC",              1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
-       B("GIGABYTE",   "GA-6BXDU",             1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
-       B("GIGABYTE",   "GA-6IEM",              1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
-       B("GIGABYTE",   "GA-6VXE7+",            1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
-       B("GIGABYTE",   "GA-6ZMA",              1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
-       B("GIGABYTE",   "GA-MA785GMT-UD2H (rev. 1.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
-       B("GIGABYTE",   "GA-770TA-UD3",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
-       B("GIGABYTE",   "GA-7DXR",              1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
-       B("GIGABYTE",   "GA-7VT600",            1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
-       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."),
-       B("GIGABYTE",   "GA-880GMA-USB3 (rev. 3.1)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
-       B("GIGABYTE",   "GA-8I945GZME-RH",      1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
-       B("GIGABYTE",   "GA-8IP775",            1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
-       B("GIGABYTE",   "GA-8IRML",             1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
-       B("GIGABYTE",   "GA-8PE667 Ultra 2",    1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
-       B("GIGABYTE",   "GA-8SIMLH",            1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
-       B("GIGABYTE",   "GA-945PL-S3P (rev. 6.6)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
-       B("GIGABYTE",   "GA-965GM-S2 (rev. 2.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
-       B("GIGABYTE",   "GA-965P-DS4",          1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
-       B("GIGABYTE",   "GA-EP31-DS3L (rev. 2.1)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
-       B("GIGABYTE",   "GA-EP35-DS3L",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
-       B("GIGABYTE",   "GA-EX58-UD4P",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
-       B("GIGABYTE",   "GA-K8N-SLI",           1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
-       B("GIGABYTE",   "GA-K8N51GMF",          1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
-       B("GIGABYTE",   "GA-K8N51GMF-9",        1,
"http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
-       B("GIGABYTE",   "GA-K8NS Pro-939",      0,
"http://www.gigabyte.com/products/product-page.aspx?pid=1875",
"Untested board enable."),
-       B("GIGABYTE",   "GA-M57SLI-S4",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
-       B("GIGABYTE",   "GA-M61P-S3",           1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
-       B("GIGABYTE",   "GA-M720-US3",          1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
-       B("GIGABYTE",   "GA-MA69VM-S2",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
-       B("GIGABYTE",   "GA-MA74GM-S2H (rev. 3.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
-       B("GIGABYTE",   "GA-MA770-UD3 (rev. 2.1)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
-       B("GIGABYTE",   "GA-MA770T-UD3P",       1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
-       B("GIGABYTE",   "GA-MA780G-UD3H",       1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
-       B("GIGABYTE",   "GA-MA78G-DS3H (rev. 1.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
-       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? */
-       B("GIGABYTE",   "GA-MA78GPM-DS2H",      1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
-       B("GIGABYTE",   "GA-MA790FX-DQ6",       1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
-       B("GIGABYTE",   "GA-MA790GP-DS4H",      1,
"http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
-       B("GIGABYTE",   "GA-MA790XT-UD4P (rev. 1.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
-       B("GIGABYTE",   "GA-P55A-UD4 (rev. 1.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
-       B("GIGABYTE",   "GA-P67A-UD3P",         1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
-       B("GIGABYTE",   "GA-X58A-UD7 (rev. 2.0)", 1, NULL, NULL),
-       B("GIGABYTE",   "GA-X58A-UDR3 (rev. 2.0)", 1, NULL, NULL),
-       B("GIGABYTE",   "GA-Z68MX-UD2H-B (rev. 1.3)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
-       B("GIGABYTE",   "GA-Z68XP-UD3 (rev. 1.0)", 1,
"http://www.gigabyte.com/products/product-page.aspx?pid=3892", NULL),
-       B("HP",         "e-Vectra P2706T",      1,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454",
NULL),
-       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),
-       B("HP",         "ProLiant DL165 G6",    1,
"http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html",
NULL),
-       B("HP",         "ProLiant N40L",        1, NULL, NULL),
-       B("HP",         "Puffer2-UL8E",         1,
"http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023",
NULL),
-       B("HP",         "dc7800",               0,
"http://h10010.www1.hp.com/wwpc/us/en/sm/WF06a/12454-12454-64287-321860-3328898-3459241.html?dnr=1",
"ICH9DO with SPI lock down, BIOS lock, PR, read-only descriptor,
locked ME region."),
-       B("HP",         "Vectra VL400",         1,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us",
NULL),
-       B("HP",         "Vectra VL420 SFF",     1,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us",
NULL),
-       B("HP",         "xw4400 (0A68h)",       0,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00775230",
"ICH7 with SPI lock down, BIOS lock, flash block detection
(SST25VF080B); see http://paste.flashrom.org/view.php?id=686"),
-       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."),
-       B("IBASE",      "MB899",                1,
"http://www.ibase-i.com.tw/2009/mb899.html", NULL),
-       B("IBM",        "x3455",                1,
"http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html",
NULL),
-       B("IEI",        "PICOe-9452",           1,
"http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144",
NULL),
-       B("Intel",      "D201GLY",              1,
"http://www.intel.com/support/motherboards/desktop/d201gly/index.htm",
NULL),
-       B("Intel",      "D425KT",               0,
"http://www.intel.com/content/www/us/en/motherboards/desktop-motherboards/desktop-board-d425kt.html",
"NM10 with SPI lock down, BIOS lock, see
http://www.flashrom.org/pipermail/flashrom/2012-January/008600.html"),
-       B("Intel",      "D865GLC",              0, NULL, "ICH5 with
BIOS lock enable, see http://paste.flashrom.org/view.php?id=775"),
-       B("Intel",      "DG45ID",               0,
"http://www.intel.com/products/desktop/motherboards/dg45id/dg45id-overview.htm",
"Probing works (Winbond W25x32, 4096 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME is
locked."),
-       B("Intel",      "DH67CF",               0, NULL, "H67 with
BIOS lock enable and locked ME region, see
http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
-       B("Intel",      "EP80759",              1, NULL, NULL),
-       B("Intel",      "Foxhollow",            1, NULL, "Intel
reference board."),
-       B("Intel",      "Greencity",            1, NULL, "Intel
reference board."),
-       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"),
-       B("IWILL",      "DK8-HTX",              1,
"http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98",
NULL),
-       B("Jetway",     "J-7BXAN",              1,
"http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
-       B("Jetway",     "J7F4K1G5D-PB",         1,
"http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D",
NULL),
-       B("Kontron",    "986LCD-M",             1,
"http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html",
NULL),
-       B("Lanner",     "EM-8510C",             1, NULL, NULL),
-       B("Lex",        "CV700A",               1,
"http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
-       B("Mitac",      "6513WU",               1,
"http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm",
NULL),
-       B("MSC",        "Q7-TCTC",              1,
"http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html",
NULL),
-       B("MSI",        "MS-6153",              1,
"http://www.msi.com/product/mb/MS-6153.html", NULL),
-       B("MSI",        "MS-6156",              1,
"http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm",
NULL),
-       B("MSI",        "MS-6163 (MS-6163 Pro)",1,
"http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
-       B("MSI",        "MS-6178",              0,
"http://www.msi.com/product/mb/MS-6178.html", "Immediately powers off
if you try to hot-plug the chip. However, this does '''not''' happen
if you use coreboot. Owned by Uwe Hermann <uwe at hermann-uwe.de>."),
-       B("MSI",        "MS-6330 (K7T Turbo)",  1,
"http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
-       B("MSI",        "MS-6391 (845 Pro4)",   1,
"http://www.msi.com/product/mb/845-Pro4.html", NULL),
-       B("MSI",        "MS-6561 (745 Ultra)",  1,
"http://www.msi.com/product/mb/745-Ultra.html", NULL),
-       B("MSI",        "MS-6566 (845 Ultra-C)",1,
"http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
-       B("MSI",        "MS-6570 (K7N2)",       1,
"http://www.msi.com/product/mb/K7N2.html", NULL),
-       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."),
-       B("MSI",        "MS-6590 (KT4 Ultra)",  1,
"http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
-       B("MSI",        "MS-6702E (K8T Neo2-F)",1,
"http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL),
-       B("MSI",        "MS-6712 (KT4V)",       1,
"http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
-       B("MSI",        "MS-6787 (P4MAM-V/P4MAM-L)", 1,
"http://www.msi.com/service/search/?kw=6787&type=product", NULL),
-       B("MSI",        "MS-7005 (651M-L)",     1,
"http://www.msi.com/product/mb/651M-L.html", NULL),
-       B("MSI",        "MS-7025 (K8N Neo2 Platinum)", 1,
"http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
-       B("MSI",        "MS-7046",              1,
"http://www.heimir.de/ms7046/", NULL),
-       B("MSI",        "MS-7061 (KM4M-V/KM4AM-V)", 1,
"http://www.msi.com/service/search/?kw=7061&type=product", NULL),
-       B("MSI",        "MS-7065",              1,
"http://browse.geekbench.ca/geekbench2/view/53114", NULL),
-       B("MSI",        "MS-7135 (K8N Neo3)",   1,
"http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
-       B("MSI",        "MS-7142 (K8MM-V)",     1,
"http://www.msi.com/product/mb/K8MM-V.html", NULL),
-       B("MSI",        "MS-7168 (Orion)",      1,
"http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart",
NULL),
-       B("MSI",        "MS-7207 (K8NGM2-L)",   1,
"http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
-       B("MSI",        "MS-7211 (PM8M3-V)",    1,
"http://www.msi.com/product/mb/PM8M3-V.html", NULL),
-       B("MSI",        "MS-7236 (945PL Neo3)", 1,
"http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
-       B("MSI",        "MS-7253 (K9VGM-V)",    1,
"http://www.msi.com/product/mb/K9VGM-V.html", NULL),
-       B("MSI",        "MS-7255 (P4M890M)",    1,
"http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
-       B("MSI",        "MS-7260 (K9N Neo PCB 1.0)", 0,
"http://www.msi.com/product/mb/K9N-Neo--PCB-1-0-.html", "Interestingly
flashrom does not work when the vendor BIOS is booted, but it ''does''
work flawlessly when the machine is booted with coreboot. Owned by Uwe
Hermann <uwe at hermann-uwe.de>."),
-       B("MSI",        "MS-7309 (K9N6PGM2-V2)", 1,
"http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
-       B("MSI",        "MS-7312 (K9MM-V)",     1,
"http://www.msi.com/product/mb/K9MM-V.html", NULL),
-       B("MSI",        "MS-7345 (P35 Neo2-FIR)", 1,
"http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
-       B("MSI",        "MS-7368 (K9AG Neo2-Digital)", 1,
"http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
-       B("MSI",        "MS-7369 (K9N Neo V2)", 1,
"http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
-       B("MSI",        "MS-7376 (K9A2 Platinum V1)", 1,
"http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
-       B("MSI",        "MS-7529 (G31M3-L(S) V2)", 1,
"http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
-       B("MSI",        "MS-7529 (G31TM-P21)",  1,
"http://www.msi.com/product/mb/G31TM-P21.html", NULL),
-       B("MSI",        "MS-7548 (Aspen-GL8E)", 1,
"http://h10025.www1.hp.com/ewfrf/wc/document?docname=c01635688&lc=en&cc=us&dlc=en",
NULL),
-       B("MSI",        "MS-7596 (785GM-E51)",  1,
"http://www.msi.com/product/mb/785GM-E51.html", NULL),
-       B("MSI",        "MS-7599 (870-C45)",    1,
"http://www.msi.com/product/mb/870-C45.html", NULL),
-       B("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."),
-       B("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."),
-       B("MSI",        "MS-7640 (890FXA-GD70)",1,
"http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
-       B("MSI",        "MS-7642 (890GXM-G65)", 1,
"http://www.msi.com/product/mb/890GXM-G65.html", NULL),
-       B("MSI",        "MS-7676 (H67MA-ED55(B3))", 1,
"http://www.msi.com/product/mb/H67MA-ED55--B3-.html", "Seems to work
fine basically, but user reported (hopefully unrelated) buggy behavior
of the board after a firmware upgrade. See
http://www.flashrom.org/pipermail/flashrom/2012-January/008547.html"),
-       B("MSI",        "MS-7696 (A75MA-G55)",  1,
"http://www.msi.com/product/mb/A75MA-G55.html", NULL),
-       B("MSI",        "MS-7698 (E350IA-E45)", 1,
"http://www.msi.com/product/mb/E350IA-E45.html", NULL),
-       B("NEC",        "PowerMate 2000",       1,
"http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/",
NULL),
-       B("Nokia",      "IP530",                1, NULL, NULL),
-       B("PCCHIPS ",   "M598LMR (V9.0)",       1, NULL, NULL),
-       B("PCCHIPS ",   "M863G (V5.1A)",        1,
"http://www.pcchips.com.tw/PCCWebSite/Products/ProductsDetail.aspx?CategoryID=1&DetailID=343&DetailName=Feature&MenuID=1&LanID=0",
NULL),
-       B("PC Engines", "Alix.1c",              1,
"http://pcengines.ch/alix1c.htm", NULL),
-       B("PC Engines", "Alix.2c2",             1,
"http://pcengines.ch/alix2c2.htm", NULL),
-       B("PC Engines", "Alix.2c3",             1,
"http://pcengines.ch/alix2c3.htm", NULL),
-       B("PC Engines", "Alix.2d3",             1,
"http://pcengines.ch/alix2d3.htm", NULL),
-       B("PC Engines", "Alix.3c3",             1,
"http://pcengines.ch/alix3c3.htm", NULL),
-       B("PC Engines", "Alix.3d3",             1,
"http://pcengines.ch/alix3d3.htm", NULL),
-       B("PC Engines", "Alix.6f2",             1,
"http://pcengines.ch/alix6f2.htm", NULL),
-       B("PC Engines", "WRAP.2E",              1,
"http://pcengines.ch/wrap2e1.htm", NULL),
-       B("Portwell",   "PEB-4700VLA",          1,
"http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA",
NULL),
-       B("RCA",        "RM4100",               1,
"http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
-       B("Samsung",    "Polaris 32",           1, NULL, NULL),
-       B("Shuttle",    "AK31",                 1,
"http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
-       B("Shuttle",    "AK38N",                1,
"http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/",
NULL),
-       B("Shuttle",    "AV11V30",              1, NULL, NULL),
-       B("Shuttle",    "AV18E2",               1,
"http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
-       B("Shuttle",    "FD37",                 1,
"http://www.shuttle.eu/products/discontinued/barebones/sd37p2/",
NULL),
-       B("Shuttle",    "FH67",                 1,
"http://www.shuttle.eu/products/mini-pc/sh67h3/specification/", NULL),
-       B("Shuttle",    "FN25",                 1,
"http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=",
NULL),
-       B("Shuttle",    "X50/X50(B)",           1,
"http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
-       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 at hermann-uwe.de>. May
work now."),
-       B("Soyo",       "SY-6BA+ III",          1,
"http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
-       B("Soyo",       "SY-7VCA",              1,
"http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html",
NULL),
-       B("Sun",        "Blade x6250",          1,
"http://www.sun.com/servers/blades/x6250/", NULL),
-       B("Sun",        "Fire x4150",           0,
"http://www.sun.com/servers/x64/x4150/", "No public report found. May
work now."),
-       B("Sun",        "Fire x4200",           0,
"http://www.sun.com/servers/entry/x4200/", "No public report found.
May work now."),
-       B("Sun",        "Fire x4540",           0,
"http://www.sun.com/servers/x64/x4540/", "No public report found. May
work now."),
-       B("Sun",        "Fire x4600",           0,
"http://www.sun.com/servers/x64/x4600/", "No public report found. May
work now."),
-       B("Sun",        "Ultra 40 M2",          1,
"http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html",
NULL),
-       B("Supermicro", "H8QC8",                1,
"http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm",
NULL),
-       B("Supermicro", "X5DP8-G2",             1,
"http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm",
NULL),
-       B("Supermicro", "X7DBT-INF",            1,
"http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm",
NULL),
-       B("Supermicro", "X7SPA-HF",             1,
"http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H&IPMI=Y",
NULL),
-       B("Supermicro", "X8DT3",                1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm",
NULL),
-       B("Supermicro", "X8DTE-F",              1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=N",
NULL),
-       B("Supermicro", "X8DTH-6F",             1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm",
NULL),
-       B("Supermicro", "X8DTT-F",              1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm",
NULL),
-       B("Supermicro", "X8DTT-HIBQF",          1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm",
NULL),
-       B("Supermicro", "X8DTU-6TF+",           0,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU_.cfm?TYP=SAS&LAN=10",
"Probing works (Atmel AT25DF321A, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
-       B("Supermicro", "X8DTU-F",              1,
"http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm",
NULL),
-       B("Supermicro", "X8SIE(-F)",            0,
"http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIE.cfm?IPMI=N&TYP=LN2",
"Requires unlocking the ME although the registers are set up correctly
by the descriptor/BIOS already (tested with swseq and hwseq)."),
-       B("Supermicro", "X8STi",                1,
"http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm",
NULL),
-       B("Supermicro", "X9SCA-F",              0,
"http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCA-F.cfm",
"Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME region
is locked."),
-       B("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."),
-       B("T-Online",   "S-100",                1,
"http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
-       B("Tekram",     "P6Pro-A5",             1,
"http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
-       B("Termtek",    "TK-3370 (Rev:2.5B)",   1, NULL, NULL),
-       B("Thomson",    "IP1000",               1,
"http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
-       B("TriGem",     "Anaheim-3",            1,
"http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml",
NULL),
-       B("TriGem",     "Lomita",               1,
"http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml",
NULL),
-       B("Tyan",       "S5375-1U (Tempest i5100X)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
-       B("Tyan",       "S1846 (Tsunami ATX)",  1,
"http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
-       B("Tyan",       "S2466 (Tiger MPX)",    1,
"http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
-       B("Tyan",       "S2498 (Tomcat K7M)",   1,
"http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
-       B("Tyan",       "S2723 (Tiger i7501)",  1,
"http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
-       B("Tyan",       "S2881 (Thunder K8SR)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
-       B("Tyan",       "S2882 (Thunder K8S Pro)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
-       B("Tyan",       "S2882-D (Thunder K8SD Pro)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
-       B("Tyan",       "S2891 (Thunder K8SRE)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
-       B("Tyan",       "S2892 (Thunder K8SE)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
-       B("Tyan",       "S2895 (Thunder K8WE)", 1,
"http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
-       B("Tyan",       "S2912 (Thunder n3600R)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
-       B("Tyan",       "S2915 (Thunder n6650W)", 1,
"http://tyan.com/product_board_detail.aspx?pid=163", NULL),
-       B("Tyan",       "S2915-E (Thunder n6650W)", 1,
"http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041",
NULL),
-       B("Tyan",       "S2933 (Thunder n3600S)", 1,
"http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063",
NULL),
-       B("Tyan",       "S3095 (Tomcat i945GM)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
-       B("Tyan",       "S3992 (Thunder h2000M)", 1,
"http://tyan.com/product_board_detail.aspx?pid=235", NULL),
-       B("Tyan",       "S5180 (Toledo i965R)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
-       B("Tyan",       "S5191 (Toledo i3000R)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
-       B("Tyan",       "S5197 (Toledo i3010W)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
-       B("Tyan",       "S5211 (Toledo i3210W)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
-       B("Tyan",       "S5211-1U (Toledo i3200R)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
-       B("Tyan",       "S5220 (Toledo q35T)",  1,
"http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
-       B("Tyan",       "S5375 (Tempest i5100X)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
-       B("Tyan",       "S5376 (Tempest i5100W)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=605", "Both
S5376G2NR and S5376WAG2NR should work."),
-       B("Tyan",       "S5377 (Tempest i5100T)", 1,
"http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017",
NULL),
-       B("Tyan",       "S5382 (Tempest i5000PW)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
-       B("Tyan",       "S5397 (Tempest i5400PW)", 1,
"http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
-       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 */
-       B("VIA",        "EPIA SP",              1,
"http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261",
NULL),
-       B("VIA",        "EPIA-CN",              1,
"http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400",
NULL),
-       B("VIA",        "EPIA EK",              1,
"http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420",
NULL),
-       B("VIA",        "EPIA-EX15000G",        1,
"http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450",
NULL),
-       B("VIA",        "EPIA-LN",              1,
"http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473",
NULL),
-       B("VIA",        "EPIA-M700",            1,
"http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700",
NULL),
-       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 */
-       B("VIA",        "EPIA-NX15000G",        1,
"http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470",
NULL),
-       B("VIA",        "NAB74X0",              1,
"http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590",
NULL),
-       B("VIA",        "pc2500e",              1,
"http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp",
NULL),
-       B("VIA",        "PC3500G",              1,
"http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp",
NULL),
-       B("VIA",        "VB700X",               1,
"http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490",
NULL),
-       B("ZOTAC",      "Fusion-ITX WiFi (FUSION350-A-E)", 1, NULL, NULL),
-       B("ZOTAC",      "GeForce 8200",         1,
"http://pden.zotac.com/index.php?page=shop.product_details&product_id=129&category_id=92",
NULL),
-       B("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."),
-       B("ZOTAC",      "ZBOX HD-ID11",         1,
"http://pdde.zotac.com/index.php?page=shop.product_details&product_id=240&category_id=75",
NULL),
+       B("A-Trend",    "ATC-6220",                             OK,
 "http://www.motherboard.cz/mb/atrend/atc6220.htm", NULL),
+       B("abit",       "A-S78H",                               OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=A-S78H&fMTYPE=Socket+AM2",
NULL),
+       B("abit",       "AN-M2",                                OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20AM2&pMODEL_NAME=AN-M2",
NULL),
+       B("abit",       "AV8",                                  OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AV8",
NULL),
+       B("abit",       "AX8",                                  OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=AX8",
NULL),
+       B("abit",       "BM6",                                  OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=BM6&fMTYPE=Socket%20370",
NULL),
+       B("abit",       "Fatal1ty F-I90HD",                     OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=Fatal1ty+F-I90HD&fMTYPE=LGA775",
NULL),
+       B("abit",       "IC7",                                  OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IC7&fMTYPE=Socket%20478",
NULL),
+       B("abit",       "IP35",                                 OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35",
NULL),
+       B("abit",       "IP35 Pro",                             OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=LGA775&pMODEL_NAME=IP35%20Pro",
NULL),
+       B("abit",       "IS-10",                                BAD,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=IS-10&fMTYPE=Socket+478",
"Reported by deejkuba at aol.com to flashrom at coreboot.org, no public
archive. Missing board enable and/or M50FW040 unlocking. May work
now."),
+       B("abit",       "KN8 Ultra",                            OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?DEFTITLE=Y&fMTYPE=Socket%20939&pMODEL_NAME=KN8%20Ultra",
NULL),
+       B("abit",       "NF-M2 nView",                          OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20AM2&pMODEL_NAME=NF-M2%20nView",
NULL),
+       B("abit",       "NF-M2S",                               OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?pMODEL_NAME=NF-M2S&fMTYPE=Socket%20AM2",
NULL),
+       B("abit",       "NF7-S",                                OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Socket%20A&pMODEL_NAME=NF7-S",
NULL),
+       B("abit",       "VA6",                                  OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VA6",
NULL),
+       B("abit",       "VT6X4",                                OK,
 "http://www.abit.com.tw/page/en/motherboard/motherboard_detail.php?fMTYPE=Slot%201&pMODEL_NAME=VT6X4",
NULL),
+       B("Acorp",      "6A815EPD",                             OK,
 "http://web.archive.org/web/20021206163652/www.acorp.com.tw/English/default.asp",
NULL),
+       B("Advantech",  "PCM-5820",                             OK,
 "http://www.emacinc.com/sbc_pc_compatible/pcm_5820.htm", NULL),
+       B("agami",      "Aruma",                                OK,
 "http://web.archive.org/web/20080212111524/http://www.agami.com/site/ais-6000-series",
NULL),
+       B("Albatron",   "PM266A Pro",                           OK,
 "http://www.albatron.com.tw/English/Product/MB/pro_detail.asp?rlink=Overview&no=56",
NULL), /* FIXME */
+       B("AOpen",      "i945GMx-VFX",                          OK,
 NULL, "This is (also?) an OEM board from FSC (used in e.g. ESPRIMO
Q5010 with designation D2544-B1)."),
+       B("AOpen",      "vKM400Am-S",                           OK,
 "http://usa.aopen.com/products_detail.aspx?Auno=824", NULL),
+       B("Artec Group","DBE61",                                OK,
 "http://wiki.thincan.org/DBE61", NULL),
+       B("Artec Group","DBE62",                                OK,
 "http://wiki.thincan.org/DBE62", NULL),
+       B("ASI",        "MB-5BLMP",                             OK,
 "http://www.hojerteknik.com/winnet.htm", "Used in the IGEL WinNET III
thin client."),
+       B("ASRock",     "775i65G",                              OK,
 "http://www.asrock.com/mb/overview.asp?Model=775i65G", NULL),
+       B("ASRock",     "890GX Extreme3",                       OK,
 "http://www.asrock.com/mb/overview.asp?Model=890GX%20Extreme3",
NULL),
+       B("ASRock",     "939A785GMH/128M",                      OK,
 "http://www.asrock.com/mb/overview.asp?Model=939A785GMH/128M", NULL),
+       B("ASRock",     "A330GC",                               OK,
 "http://www.asrock.com/mb/overview.asp?Model=A330GC", NULL),
+       B("ASRock",     "A770CrossFire",                        OK,
 "http://www.asrock.com/mb/overview.asp?Model=A770CrossFire", NULL),
+       B("ASRock",     "ALiveNF6G-DVI",                        OK,
 "http://www.asrock.com/mb/overview.asp?Model=ALiveNF6G-DVI", NULL),
+       B("ASRock",     "AM2NF6G-VSTA",                         OK,
 "http://www.asrock.com/mb/overview.asp?Model=AM2NF6G-VSTA", NULL),
+       B("ASRock",     "ConRoeXFire-eSATA2",                   OK,
 "http://www.asrock.com/mb/overview.asp?model=conroexfire-esata2",
NULL),
+       B("ASRock",     "K7S41",                                OK,
 "http://www.asrock.com/mb/overview.asp?Model=K7S41", NULL),
+       B("ASRock",     "K7S41GX",                              OK,
 "http://www.asrock.com/mb/overview.asp?Model=K7S41GX", NULL),
+       B("ASRock",     "K7VT4A+",                              BAD,
 "http://www.asrock.com/mb/overview.asp?Model=K7VT4A%2b", "No chip
found, probably due to flash translation.
http://www.flashrom.org/pipermail/flashrom/2009-August/000393.html"),
+       B("ASRock",     "K8S8X",                                OK,
 "http://www.asrock.com/mb/overview.asp?Model=K8S8X", NULL),
+       B("ASRock",     "M3A790GXH/128M",                       OK,
 "http://www.asrock.com/mb/overview.asp?Model=M3A790GXH/128M", NULL),
+       B("ASRock",     "P4i65GV",                              OK,
 "http://www.asrock.com/mb/overview.asp?Model=P4i65GV", NULL),
+       B("ASUS",       "A7N8X Deluxe",                         OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8X_Deluxe/", NULL),
+       B("ASUS",       "A7N8X-E Deluxe",                       OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XE_Deluxe/",
NULL),
+       B("ASUS",       "A7N8X-VM/400",                         OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7N8XVM400/", NULL),
+       B("ASUS",       "A7V133",                               OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/socka/kt133a/a7v133/", NULL),
+       B("ASUS",       "A7V333",                               OK,
 "ftp://ftp.asus.com.tw/pub/asus/mb/socka/kt333/a7v333/", NULL),
+       B("ASUS",       "A7V400-MX",                            OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V400MX/", NULL),
+       B("ASUS",       "A7V600-X",                             OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V600X/", NULL),
+       B("ASUS",       "A7V8X",                                OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8X/", NULL),
+       B("ASUS",       "A7V8X-MX",                             OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX/", NULL),
+       B("ASUS",       "A7V8X-MX SE",                          OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XMX_SE/", NULL),
+       B("ASUS",       "A7V8X-X",                              OK,
 "http://www.asus.com/Motherboards/AMD_Socket_A/A7V8XX/", NULL),
+       B("ASUS",       "A8M2N-LA (NodusM3-GL8E)",              OK,
 "http://h10010.www1.hp.com/ewfrf/wc/document?docname=c00757531&cc=us&dlc=en&lc=en",
"This is an OEM board from HP, the HP name is NodusM3-GL8E."),
+       B("ASUS",       "A8N-E",                                OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8NE/", NULL),
+       B("ASUS",       "A8N-LA (Nagami-GL8E)",                 OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?lc=en&cc=us&docname=c00647121&dlc=en",
"This is an OEM board from HP, the HP name is Nagami-GL8E."),
+       B("ASUS",       "A8N-SLI",                              OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI/", NULL),
+       B("ASUS",       "A8N-SLI Deluxe",                       NT,
 NULL, "Untested board enable."),
+       B("ASUS",       "A8N-SLI Premium",                      OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8NSLI_Premium/",
NULL),
+       B("ASUS",       "A8N-VM",                               OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM/", NULL),
+       B("ASUS",       "A8N-VM CSM",                           OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8NVM_CSM/", NULL),
+       B("ASUS",       "A8NE-FM/S",                            OK,
 "http://www.hardwareschotte.de/hardware/preise/proid_1266090/preis_ASUS+A8NE-FM",
NULL),
+       B("ASUS",       "A8V Deluxe",                           OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8V_Deluxe/", NULL),
+       B("ASUS",       "A8V-E Deluxe",                         OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_Deluxe/",
NULL),
+       B("ASUS",       "A8V-E SE",                             OK,
 "http://www.asus.com/Motherboards/AMD_Socket_939/A8VE_SE/", "See
http://www.coreboot.org/pipermail/coreboot/2007-October/026496.html"),
+       B("ASUS",       "Crosshair II Formula",                 OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/Crosshair_II_Formula/",
NULL),
+       B("ASUS",       "Crosshair IV Extreme",                 OK,
 "http://www.asus.com/Motherboards/AMD_AM3/Crosshair_IV_Extreme/",
NULL),
+       B("ASUS",       "E35M1-I DELUXE",                       OK,
 "http://www.asus.com/Motherboards/AMD_CPU_on_Board/E35M1I_DELUXE/",
NULL),
+       B("ASUS",       "K8N",                                  OK,
 "http://www.asus.com/Motherboards/AMD_Socket_754/K8N/", NULL),
+       B("ASUS",       "K8V",                                  OK,
 "http://www.asus.com/Motherboards/AMD_Socket_754/K8V/", NULL),
+       B("ASUS",       "K8V SE Deluxe",                        OK,
 "http://www.asus.com/Motherboards/AMD_Socket_754/K8V_SE_Deluxe/",
NULL),
+       B("ASUS",       "K8V-X",                                OK,
 "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX/", NULL),
+       B("ASUS",       "K8V-X SE",                             OK,
 "http://www.asus.com/Motherboards/AMD_Socket_754/K8VX_SE/", NULL),
+       B("ASUS",       "KFSN4-DRE/SAS",                        OK,
 "http://www.asus.com/Server_Workstation/Server_Motherboards/KFSN4DRESAS/",
NULL),
+       B("ASUS",       "M2A-MX",                               OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2AMX/", NULL),
+       B("ASUS",       "M2A-VM (HDMI)",                        OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2AVM/", NULL),
+       B("ASUS",       "M2N32-SLI Deluxe",                     OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2N32SLI_DeluxeWireless_Edition/",
NULL),
+       B("ASUS",       "M2N-E",                                OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2NE/", "If the machine
doesn't come up again after flashing, try resetting the NVRAM(CMOS).
The MAC address of the onboard network card will change to the value
stored in the new image, so backup the old address first. See
http://www.flashrom.org/pipermail/flashrom/2009-November/000879.html"),
+       B("ASUS",       "M2N-E SLI",                            OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2NE_SLI/", NULL),
+       B("ASUS",       "M2N-SLI Deluxe",                       OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2NSLI_Deluxe/", NULL),
+       B("ASUS",       "M2NBP-VM CSM",                         OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2NBPVM_CSM/", NULL),
+       B("ASUS",       "M2NPV-VM",                             OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2NPVVM/", NULL),
+       B("ASUS",       "M2V",                                  OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2V/", NULL),
+       B("ASUS",       "M2V-MX",                               OK,
 "http://www.asus.com/Motherboards/AMD_AM2/M2VMX/", NULL),
+       B("ASUS",       "M3A",                                  OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A/", NULL),
+       B("ASUS",       "M3A76-CM",                             OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A76CM/", NULL),
+       B("ASUS",       "M3A78-EM",                             OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M3A78EM/", NULL),
+       B("ASUS",       "M3N78-VM",                             OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M3N78VM/", NULL),
+       B("ASUS",       "M4A78-EM",                             OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M4A78EM/", NULL),
+       B("ASUS",       "M4A785TD-M EVO",                       OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDM_EVO/", NULL),
+       B("ASUS",       "M4A785TD-V EVO",                       OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A785TDV_EVO/", NULL),
+       B("ASUS",       "M4A78LT-M LE",                         OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A78LTM_LE/", NULL),
+       B("ASUS",       "M4A79T Deluxe",                        OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A79T_Deluxe/", NULL),
+       B("ASUS",       "M4A87TD/USB3",                         OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A87TDUSB3/", NULL),
+       B("ASUS",       "M4A89GTD PRO",                         OK,
 "http://www.asus.com/Motherboards/AMD_AM3/M4A89GTD_PRO/", NULL),
+       B("ASUS",       "M4N78 PRO",                            OK,
 "http://www.asus.com/Motherboards/AMD_AM2Plus/M4N78_PRO/", NULL),
+       B("ASUS",       "M5A99X EVO",                           OK,
 "http://www.asus.com/Motherboards/AMD_AM3Plus/M5A99X_EVO/", NULL),
+       B("ASUS",       "MEW-AM",                               BAD,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock370/810/mew-am/", "No public
report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>. May work
now."),
+       B("ASUS",       "MEW-VM",                               BAD,
 "http://www.elhvb.com/mboards/OEM/HP/manual/ASUS%20MEW-VM.htm", "No
public report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>. May
work now."),
+       B("ASUS",       "OPLX-M",                               NT,
 NULL, "Untested board enable."),
+       B("ASUS",       "P2B",                                  OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b/", NULL),
+       B("ASUS",       "P2B-D",                                OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
+       B("ASUS",       "P2B-DS",                               OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-ds/", NULL),
+       B("ASUS",       "P2B-F",                                OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-d/", NULL),
+       B("ASUS",       "P2B-N",                                OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p2b-n/", NULL),
+       B("ASUS",       "P2E-M",                                OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440ex/p2e-m/", NULL),
+       B("ASUS",       "P2L97-S",                              OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440lx/p2l97-s/", NULL),
+       B("ASUS",       "P3B-F",                                BAD,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/slot1/440bx/p3b-f/", "No public
report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>. May work
now."),
+       B("ASUS",       "P4B266",                               OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b266/", NULL),
+       B("ASUS",       "P4B266-LM",                            OK,
 "http://esupport.sony.com/US/perl/swu-list.pl?mdl=PCVRX650", NULL),
+       B("ASUS",       "P4B533-E",                             OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4b533-e/", NULL),
+       B("ASUS",       "P4C800-E Deluxe",                      OK,
 "http://www.asus.com/Motherboards/Intel_Socket_478/P4C800E_Deluxe/",
NULL),
+       B("ASUS",       "P4GV-LA (Guppy)",                      OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00363478",
NULL),
+       B("ASUS",       "P4P800",                               OK,
 "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800/", NULL),
+       B("ASUS",       "P4P800-E Deluxe",                      OK,
 "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800E_Deluxe/",
NULL),
+       B("ASUS",       "P4P800-VM",                            OK,
 "http://www.asus.com/Motherboards/Intel_Socket_478/P4P800VM/", NULL),
+       B("ASUS",       "P4SC-E",                               OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4sc-e/", "Part of ASUS
Terminator P4 533 barebone system"),
+       B("ASUS",       "P4SD-LA",                              OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00022505",
NULL),
+       B("ASUS",       "P4S533-X",                             OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock478/p4s533-x/", NULL),
+       B("ASUS",       "P4S800-MX",                            OK,
 "http://www.asus.com/Motherboards/Intel_Socket_478/P4S800MX/", NULL),
+       B("ASUS",       "P5A",                                  OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/sock7/ali/p5a/", NULL),
+       B("ASUS",       "P5B",                                  OK,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B/", NULL),
+       B("ASUS",       "P5B-Deluxe",                           OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5B_Deluxe/",
NULL),
+       B("ASUS",       "P5BV-M",                               BAD,
 "ftp://ftp.asus.com.tw/pub/ASUS/mb/socket775/P5B-VM/", "Reported by
Bernhard M. Wiedemann <bernhard at uml12d.zq1.de> to
flashrom at coreboot.org, no public archive. Missing board enable and/or
SST49LF008A unlocking. May work now."),
+       B("ASUS",       "P5GC-MX/1333",                         OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5GCMX1333/",
NULL),
+       B("ASUS",       "P5GD1 Pro",                            OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD1_PRO/",
NULL),
+       B("ASUS",       "P5GD1-VM/S",                           OK,
 NULL, "This is an OEM board from FSC. Although flashrom supports it
and can probably not distinguish it from the P5GD1-VM, please note
that the P5GD1-VM BIOS does not support the FSC variants
completely."),
+       B("ASUS",       "P5GD1(-VM)",                           NT,
 NULL, "Untested board enable."),
+       B("ASUS",       "P5GD2 Premium",                        OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5GD2_Premium/",
NULL),
+       B("ASUS",       "P5GDC Deluxe",                         OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDC_Deluxe/",
NULL),
+       B("ASUS",       "P5GDC-V Deluxe",                       OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5GDCV_Deluxe/",
NULL),
+       B("ASUS",       "P5GD2/C variants",                     NT,
 NULL, "Untested board enable."),
+       B("ASUS",       "P5K-V",                                OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5KV/", NULL),
+       B("ASUS",       "P5K-VM",                               OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5KVM/", NULL),
+       B("ASUS",       "P5KC",                                 OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5KC/", NULL),
+       B("ASUS",       "P5KPL-CM",                             OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5KPLCM/", NULL),
+       B("ASUS",       "P5L-MX",                               OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5LMX/", NULL),
+       B("ASUS",       "P5L-VM 1394",                          OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5LVM_1394/",
NULL),
+       B("ASUS",       "P5LD2",                                NT,
 NULL, "Untested board enable."),
+       B("ASUS",       "P5LP-LE (Lithium-UL8E)",               OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00379616&tmp_task=prodinfoCategory&cc=us&dlc=en&lc=en&product=1159887",
"This is an OEM board from HP."),
+       B("ASUS",       "P5LP-LE (Epson OEM)",                  OK,
 NULL, "This is an OEM board from Epson (e.g. Endeavor MT7700)."),
+       B("ASUS",       "P5LP-LE",                              BAD,
 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."),
+       B("ASUS",       "P5N-D",                                OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND/", NULL),
+       B("ASUS",       "P5N-E SLI",                            NT,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5NE_SLI/",
"Untested board enable."),
+       B("ASUS",       "P5N32-E SLI",                          OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5N32E_SLI/",
NULL),
+       B("ASUS",       "P5N7A-VM",                             OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5N7AVM/", NULL),
+       B("ASUS",       "P5ND2-SLI Deluxe",                     OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5ND2SLI_Deluxe/",
NULL),
+       B("ASUS",       "P5PE-VM",                              OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5PEVM/", NULL),
+       B("ASUS",       "P5QPL-AM",                             OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5QPLAM/", NULL),
+       B("ASUS",       "P5VD1-X",                              OK,
 "http://www.asus.com/Motherboards/Intel_Socket_775/P5VD1X/", NULL),
+       B("ASUS",       "P6T SE",                               OK,
 "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_SE/", NULL),
+       B("ASUS",       "P6T Deluxe",                           OK,
 "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe/",
NULL),
+       B("ASUS",       "P6T Deluxe V2",                        OK,
 "http://www.asus.com/Motherboards/Intel_Socket_1366/P6T_Deluxe_V2/",
NULL),
+       B("ASUS",       "P7H57D-V EVO",                         OK,
 "http://www.asus.com/Motherboards/Intel_Socket_1156/P7H57DV_EVO/",
NULL),
+       B("ASUS",       "P7H55-M LX",                           BAD,
 NULL, "flashrom works correctly, but GbE LAN is nonworking (probably
due to a missing/bogus MAC address; see
http://www.flashrom.org/pipermail/flashrom/2011-July/007432.html and
http://ubuntuforums.org/showthread.php?t=1534389 for a possible
workaround)"),
+       B("ASUS",       "P8B-E/4L",                             BAD,
 NULL, "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ASUS",       "P8B WS",                               BAD,
 NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ASUS",       "P8H61 PRO",                            BAD,
 NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ASUS",       "P8H61-M LE/USB3",                      BAD,
 NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ASUS",       "P8H67-M PRO",                          BAD,
 NULL, "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of
the flash are problematic: descriptor is r/o (conforming to ICH reqs),
ME region is locked."),
+       B("ASUS",       "P8P67 (rev. 3.1)",                     BAD,
 NULL, "Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of
the flash are problematic: descriptor is r/o (conforming to ICH reqs),
ME region is locked."),
+       B("ASUS",       "P8Z68-V PRO",                          BAD,
 NULL, "Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ASUS",       "Z8NA-D6C",                             OK,
 "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8NAD6C/",
NULL),
+       B("ASUS",       "Z8PE-D12",                             OK,
 "http://www.asus.com/Server_Workstation/Server_Motherboards/Z8PED12/",
NULL),
+       B("BCOM",       "WinNET100",                            OK,
 "http://www.coreboot.org/BCOM_WINNET100", "Used in the IGEL-316 thin
client."),
+       B("Bifferos",   "Bifferboard",                          OK,
 "http://bifferos.co.uk/", NULL),
+       B("Biostar",    "N68S3+",                               OK,
 NULL, NULL),
+       B("Biostar",    "M6TBA",                                BAD,
 "ftp://ftp.biostar-usa.com/manuals/M6TBA/", "No public report found.
Owned by Uwe Hermann <uwe at hermann-uwe.de>. May work now."),
+       B("Biostar",    "M7NCD Pro",                            OK,
 "http://www.biostar.com.tw/app/en/mb/content.php?S_ID=260", NULL),
+       B("Biostar",    "P4M80-M4",                             OK,
 "http://www.biostar-usa.com/mbdetails.asp?model=p4m80-m4", NULL),
+       B("Biostar",    "TA780G M2+",                           OK,
 "http://www.biostar.com.tw/app/en/t-series/content.php?S_ID=344",
NULL),
+       B("Boser",      "HS-6637",                              BAD,
 "http://www.boser.com.tw/manual/HS-62376637v3.4.pdf", "Reported by
Mark Robinson <mark at zl2tod.net> to flashrom at coreboot.org, no public
archive. Missing board enable and/or F29C51002T unlocking. May work
now."),
+       B("Congatec",   "conga-X852",                           OK,
 "http://www.congatec.com/single_news+M57715f6263d.html?&L=1", NULL),
+       B("Dell",       "OptiPlex GX1",                         OK,
 "http://support.dell.com/support/edocs/systems/ban_gx1/en/index.htm",
NULL),
+       B("Dell",       "PowerEdge 1850",                       OK,
 "http://support.dell.com/support/edocs/systems/pe1850/en/index.htm",
NULL),
+       B("DFI",        "855GME-MGF",                           BAD,
 "http://www.dfi.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?action=e&downloadType=&windowstate=normal&mode=view&downloadFlag=false&itemId=433",
"Probably needs a board enable.
http://www.coreboot.org/pipermail/coreboot/2009-May/048549.html"),
+       B("DFI",        "Blood-Iron P35 T2RL",                  OK,
 "http://lp.lanparty.com.tw/portal/CM/cmproduct/XX_cmproddetail/XX_WbProdsWindow?itemId=516&downloadFlag=false&action=1",
NULL),
+       B("Elitegroup", "GeForce6100SM-M ",                     OK,
 "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=685&MenuID=24",
NULL),
+       B("Elitegroup", "GF7100PVT-M3 (V1.0)",                  OK,
 "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=853&CategoryID=1&DetailName=Specification&MenuID=24&LanID=0",
NULL),
+       B("Elitegroup", "K7S5A",                                OK,
 "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=279&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0",
NULL),
+       B("Elitegroup", "K7S6A",                                OK,
 "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=77&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0",
NULL),
+       B("Elitegroup", "K7SEM (V1.0A)",                        OK,
 "http://www.ecs.com.tw/ECSWebSite/Product/Product_Detail.aspx?DetailID=229&CategoryID=1&DetailName=Specification&MenuID=24&LanID=0",
NULL),
+       B("Elitegroup", "K7VTA3",                               OK,
 "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=264&CategoryID=1&DetailName=Specification&MenuID=52&LanID=0",
NULL),
+       B("Elitegroup", "P4M800PRO-M (V1.0A, V2.0)",            OK,
 "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&DetailID=574&DetailName=Feature&MenuID=52&LanID=0",
NULL),
+       B("Elitegroup", "P4VXMS (V1.0A)",                       OK,
 NULL, NULL),
+       B("Elitegroup", "P6IWP-Fe",                             OK,
 "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&TypeID=3&DetailID=95&DetailName=Feature&MenuID=1&LanID=0",
NULL),
+       B("Elitegroup", "P6VAP-A+",                             OK,
 "http://www.ecs.com.tw/ECSWebSite/Products/ProductsDetail.aspx?detailid=117&CategoryID=1&DetailName=Specification&MenuID=1&LanID=0",
NULL),
+       B("Elitegroup", "RS485M-M",                             OK,
 "http://www.ecs.com.tw/ECSWebSite_2007/Products/ProductsDetail.aspx?CategoryID=1&DetailID=654&DetailName=Feature&MenuID=1&LanID=0",
NULL),
+       B("Emerson",    "ATCA-7360",                            OK,
 "http://www.emerson.com/sites/Network_Power/en-US/Products/Product_Detail/Product1/Pages/EmbCompATCA-7360.aspx",
NULL),
+       B("EPoX",       "EP-8K5A2",                             OK,
 "http://www.epox.com/product.asp?ID=EP-8K5A2", NULL),
+       B("EPoX",       "EP-8NPA7I",                            OK,
 "http://www.epox.com/product.asp?ID=EP-8NPA7I", NULL),
+       B("EPoX",       "EP-9NPA7I",                            OK,
 "http://www.epox.com/product.asp?ID=EP-9NPA7I", NULL),
+       B("EPoX",       "EP-8RDA3+",                            OK,
 "http://www.epox.com/product.asp?ID=EP-8RDA3plus", NULL),
+       B("EPoX",       "EP-BX3",                               OK,
 "http://www.epox.com/product.asp?ID=EP-BX3", NULL),
+       B("EVGA",       "132-CK-NF78",                          OK,
 "http://www.evga.com/articles/385.asp", NULL),
+       B("EVGA",       "270-WS-W555-A2 (Classified SR-2)",     OK,
 "http://www.evga.com/products/moreInfo.asp?pn=270-WS-W555-A2", NULL),
+       B("FIC",        "VA-502",                               BAD,
 "ftp://ftp.fic.com.tw/motherboard/manual/socket7/va-502/", "No public
report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>. Seems the PCI
subsystem IDs are identical with the Tekram P6Pro-A5. May work now."),
+       B("Foxconn",    "6150K8MD-8EKRSH",                      OK,
 "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000157",
NULL),
+       B("Foxconn",    "A6VMX",                                OK,
 "http://www.foxconnchannel.com/product/motherboards/detail_overview.aspx?id=en-us0000346",
NULL),
+       B("Foxconn",    "P4M800P7MA-RS2",                       OK,
 "http://www.foxconnchannel.com/Product/Motherboards/detail_overview.aspx?id=en-us0000138",
NULL),
+       B("Freetech",   "P6F91i",                               OK,
 "http://web.archive.org/web/20010417035034/http://www.freetech.com/prod/P6F91i.html",
NULL),
+       B("Fujitsu-Siemens", "ESPRIMO P5915",                   OK,
 "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/professionalpc/ESPRIMO/P/EsprimoP5915-6.htm",
"Mainboard model is D2312-A2."),
+       B("GIGABYTE",   "GA-2761GXDK",                          OK,
 "http://www.computerbase.de/news/hardware/mainboards/amd-systeme/2007/mai/gigabyte_dtx-mainboard/",
NULL),
+       B("GIGABYTE",   "GA-6BXC",                              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1445", NULL),
+       B("GIGABYTE",   "GA-6BXDU",                             OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1429", NULL),
+       B("GIGABYTE",   "GA-6IEM",                              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1379", NULL),
+       B("GIGABYTE",   "GA-6VXE7+",                            OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2410", NULL),
+       B("GIGABYTE",   "GA-6ZMA",                              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1541", NULL),
+       B("GIGABYTE",   "GA-MA785GMT-UD2H (rev. 1.0)",          OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3156", NULL),
+       B("GIGABYTE",   "GA-770TA-UD3",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3272", NULL),
+       B("GIGABYTE",   "GA-7DXR",                              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1302", NULL),
+       B("GIGABYTE",   "GA-7VT600",                            OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1666", NULL),
+       B("GIGABYTE",   "GA-7ZM",                               OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1366", "Works
fine if you remove jumper JP9 on the board and disable the flash
protection BIOS option."),
+       B("GIGABYTE",   "GA-880GMA-USB3 (rev. 3.1)",            OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3817", NULL),
+       B("GIGABYTE",   "GA-8I945GZME-RH",                      OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2304", NULL),
+       B("GIGABYTE",   "GA-8IP775",                            OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1830", NULL),
+       B("GIGABYTE",   "GA-8IRML",                             OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1343", NULL),
+       B("GIGABYTE",   "GA-8PE667 Ultra 2",                    OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1607", NULL),
+       B("GIGABYTE",   "GA-8SIMLH",                            OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1399", NULL),
+       B("GIGABYTE",   "GA-945PL-S3P (rev. 6.6)",              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2541", NULL),
+       B("GIGABYTE",   "GA-965GM-S2 (rev. 2.0)",               OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2617", NULL),
+       B("GIGABYTE",   "GA-965P-DS4",                          OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2288", NULL),
+       B("GIGABYTE",   "GA-EP31-DS3L (rev. 2.1)",              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2964", NULL),
+       B("GIGABYTE",   "GA-EP35-DS3L",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2778", NULL),
+       B("GIGABYTE",   "GA-EX58-UD4P",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2986", NULL),
+       B("GIGABYTE",   "GA-K8N-SLI",                           OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1928", NULL),
+       B("GIGABYTE",   "GA-K8N51GMF",                          OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1950", NULL),
+       B("GIGABYTE",   "GA-K8N51GMF-9",                        OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1939", NULL),
+       B("GIGABYTE",   "GA-K8NS Pro-939",                      NT,
 "http://www.gigabyte.com/products/product-page.aspx?pid=1875",
"Untested board enable."),
+       B("GIGABYTE",   "GA-M57SLI-S4",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2287", NULL),
+       B("GIGABYTE",   "GA-M61P-S3",                           OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2434", NULL),
+       B("GIGABYTE",   "GA-M720-US3",                          OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3006", NULL),
+       B("GIGABYTE",   "GA-MA69VM-S2",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2500", NULL),
+       B("GIGABYTE",   "GA-MA74GM-S2H (rev. 3.0)",             OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3152", NULL),
+       B("GIGABYTE",   "GA-MA770-UD3 (rev. 2.1)",              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3302", NULL),
+       B("GIGABYTE",   "GA-MA770T-UD3P",                       OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3096", NULL),
+       B("GIGABYTE",   "GA-MA780G-UD3H",                       OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3004", NULL),
+       B("GIGABYTE",   "GA-MA78G-DS3H (rev. 1.0)",             OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2800", NULL),
+       B("GIGABYTE",   "GA-MA78GM-S2H",                        OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2758", NULL),
/* TODO: Rev. 1.0, 1.1, or 2.x? */
+       B("GIGABYTE",   "GA-MA78GPM-DS2H",                      OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2859", NULL),
+       B("GIGABYTE",   "GA-MA790FX-DQ6",                       OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2690", NULL),
+       B("GIGABYTE",   "GA-MA790GP-DS4H",                      OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=2887", NULL),
+       B("GIGABYTE",   "GA-MA790XT-UD4P (rev. 1.0)",           OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3010", NULL),
+       B("GIGABYTE",   "GA-P55A-UD4 (rev. 1.0)",               OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3436", NULL),
+       B("GIGABYTE",   "GA-P67A-UD3P",                         OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3649", NULL),
+       B("GIGABYTE",   "GA-X58A-UD7 (rev. 2.0)",               OK,
 NULL, NULL),
+       B("GIGABYTE",   "GA-X58A-UDR3 (rev. 2.0)",              OK,
 NULL, NULL),
+       B("GIGABYTE",   "GA-Z68MX-UD2H-B (rev. 1.3)",           OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3854", NULL),
+       B("GIGABYTE",   "GA-Z68XP-UD3 (rev. 1.0)",              OK,
 "http://www.gigabyte.com/products/product-page.aspx?pid=3892", NULL),
+       B("HP",         "e-Vectra P2706T",                      OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=77515&prodTypeId=12454",
NULL),
+       B("HP",         "ProLiant DL145 G3",                    OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00816835&lang=en&cc=us&taskId=101&prodSeriesId=3219755&prodTypeId=15351",
NULL),
+       B("HP",         "ProLiant DL165 G6",                    OK,
 "http://h10010.www1.hp.com/wwpc/us/en/sm/WF05a/15351-15351-3328412-241644-3328421-3955644.html",
NULL),
+       B("HP",         "ProLiant N40L",                        OK,
 NULL, NULL),
+       B("HP",         "Puffer2-UL8E",                         OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c00300023",
NULL),
+       B("HP",         "dc7800",                               BAD,
 "http://h10010.www1.hp.com/wwpc/us/en/sm/WF06a/12454-12454-64287-321860-3328898-3459241.html?dnr=1",
"ICH9DO with SPI lock down, BIOS lock, PR, read-only descriptor,
locked ME region."),
+       B("HP",         "Vectra VL400",                         OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060658&lang=en&cc=us",
NULL),
+       B("HP",         "Vectra VL420 SFF",                     OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00060661&lang=en&cc=us",
NULL),
+       B("HP",         "xw4400 (0A68h)",                       BAD,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?objectID=c00775230",
"ICH7 with SPI lock down, BIOS lock, flash block detection
(SST25VF080B); see http://paste.flashrom.org/view.php?id=686"),
+       B("HP",         "xw9400",                               OK,
 "http://h20000.www2.hp.com/bizsupport/TechSupport/Home.jsp?lang=en&cc=us&prodSeriesId=3211286&prodTypeId=12454",
"Boot block is write protected unless the solder points next to F2 are
shorted."),
+       B("IBASE",      "MB899",                                OK,
 "http://www.ibase-i.com.tw/2009/mb899.html", NULL),
+       B("IBM",        "x3455",                                OK,
 "http://www-03.ibm.com/systems/x/hardware/rack/x3455/index.html",
NULL),
+       B("IEI",        "PICOe-9452",                           OK,
 "http://www.ieiworld.com/product_groups/industrial/content.aspx?keyword=WSB&gid=00001000010000000001&cid=08125380291060861658&id=08142308605814597144",
NULL),
+       B("Intel",      "D201GLY",                              OK,
 "http://www.intel.com/support/motherboards/desktop/d201gly/index.htm",
NULL),
+       B("Intel",      "D425KT",                               BAD,
 "http://www.intel.com/content/www/us/en/motherboards/desktop-motherboards/desktop-board-d425kt.html",
"NM10 with SPI lock down, BIOS lock, see
http://www.flashrom.org/pipermail/flashrom/2012-January/008600.html"),
+       B("Intel",      "D865GLC",                              BAD,
 NULL, "ICH5 with BIOS lock enable, see
http://paste.flashrom.org/view.php?id=775"),
+       B("Intel",      "DG45ID",                               BAD,
 "http://www.intel.com/products/desktop/motherboards/dg45id/dg45id-overview.htm",
"Probing works (Winbond W25x32, 4096 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME is
locked."),
+       B("Intel",      "DH67CF",                               BAD,
 NULL, "H67 with BIOS lock enable and locked ME region, see
http://www.flashrom.org/pipermail/flashrom/2011-September/007789.html"),
+       B("Intel",      "EP80759",                              OK,
 NULL, NULL),
+       B("Intel",      "Foxhollow",                            OK,
 NULL, "Intel reference board."),
+       B("Intel",      "Greencity",                            OK,
 NULL, "Intel reference board."),
+       B("Intel",      "SE440BX-2",                            BAD,
 "http://downloadcenter.intel.com/SearchResult.aspx?lang=eng&ProductFamily=Desktop+Boards&ProductLine=Discontinued+Motherboards&ProductProduct=Intel%C2%AE+SE440BX-2+Motherboard",
"Probably won't work, see
http://www.coreboot.org/pipermail/flashrom/2010-July/003952.html"),
+       B("IWILL",      "DK8-HTX",                              OK,
 "http://web.archive.org/web/20060507170150/http://www.iwill.net/product_2.asp?p_id=98",
NULL),
+       B("Jetway",     "J-7BXAN",                              OK,
 "http://www.jetway.com.tw/evisn/download/d7BXAS.htm", NULL),
+       B("Jetway",     "J7F4K1G5D-PB",                         OK,
 "http://www.jetway.com.tw/jw/ipcboard_view.asp?productid=282&proname=J7F4K1G5D",
NULL),
+       B("Kontron",    "986LCD-M",                             OK,
 "http://de.kontron.com/products/boards+and+mezzanines/embedded+motherboards/miniitx+motherboards/986lcdmmitx.html",
NULL),
+       B("Lanner",     "EM-8510C",                             OK,
 NULL, NULL),
+       B("Lex",        "CV700A",                               OK,
 "http://www.lex.com.tw/product/CV700A-spec.htm", NULL),
+       B("Mitac",      "6513WU",                               OK,
 "http://web.archive.org/web/20050313054828/http://www.mitac.com/micweb/products/tyan/6513wu/6513wu.htm",
NULL),
+       B("MSC",        "Q7-TCTC",                              OK,
 "http://www.msc-ge.com/en/produkte/com/moduls/overview/5779-www.html",
NULL),
+       B("MSI",        "MS-6153",                              OK,
 "http://www.msi.com/product/mb/MS-6153.html", NULL),
+       B("MSI",        "MS-6156",                              OK,
 "http://uk.ts.fujitsu.com/rl/servicesupport/techsupport/boards/Motherboards/MicroStar/Ms6156/MS6156.htm",
NULL),
+       B("MSI",        "MS-6163 (MS-6163 Pro)",                OK,
"http://www.msi.com/product/mb/MS-6163-Pro.html", NULL),
+       B("MSI",        "MS-6178",                              BAD,
 "http://www.msi.com/product/mb/MS-6178.html", "Immediately powers off
if you try to hot-plug the chip. However, this does '''not''' happen
if you use coreboot. Owned by Uwe Hermann <uwe at hermann-uwe.de>."),
+       B("MSI",        "MS-6330 (K7T Turbo)",                  OK,
 "http://www.msi.com/product/mb/K7T-Turbo.html", NULL),
+       B("MSI",        "MS-6391 (845 Pro4)",                   OK,
 "http://www.msi.com/product/mb/845-Pro4.html", NULL),
+       B("MSI",        "MS-6561 (745 Ultra)",                  OK,
 "http://www.msi.com/product/mb/745-Ultra.html", NULL),
+       B("MSI",        "MS-6566 (845 Ultra-C)",                OK,
"http://www.msi.com/product/mb/845-Ultra-C.html", NULL),
+       B("MSI",        "MS-6570 (K7N2)",                       OK,
 "http://www.msi.com/product/mb/K7N2.html", NULL),
+       B("MSI",        "MS-6577 (Xenon)",                      OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?product=90390&lc=en&cc=us&dlc=en&docname=bph07843",
"This is an OEM board from HP, the HP name is Xenon."),
+       B("MSI",        "MS-6590 (KT4 Ultra)",                  OK,
 "http://www.msi.com/product/mb/KT4-Ultra.html", NULL),
+       B("MSI",        "MS-6702E (K8T Neo2-F)",                OK,
"http://www.msi.com/product/mb/K8T-Neo2-F--FIR.html", NULL),
+       B("MSI",        "MS-6712 (KT4V)",                       OK,
 "http://www.msi.com/product/mb/KT4V---KT4V-L--v1-0-.html", NULL),
+       B("MSI",        "MS-6787 (P4MAM-V/P4MAM-L)",            OK,
 "http://www.msi.com/service/search/?kw=6787&type=product", NULL),
+       B("MSI",        "MS-7005 (651M-L)",                     OK,
 "http://www.msi.com/product/mb/651M-L.html", NULL),
+       B("MSI",        "MS-7025 (K8N Neo2 Platinum)",          OK,
 "http://www.msi.com/product/mb/K8N-Neo2-Platinum.html", NULL),
+       B("MSI",        "MS-7046",                              OK,
 "http://www.heimir.de/ms7046/", NULL),
+       B("MSI",        "MS-7061 (KM4M-V/KM4AM-V)",             OK,
 "http://www.msi.com/service/search/?kw=7061&type=product", NULL),
+       B("MSI",        "MS-7065",                              OK,
 "http://browse.geekbench.ca/geekbench2/view/53114", NULL),
+       B("MSI",        "MS-7135 (K8N Neo3)",                   OK,
 "http://www.msi.com/product/mb/K8N-Neo3.html", NULL),
+       B("MSI",        "MS-7142 (K8MM-V)",                     OK,
 "http://www.msi.com/product/mb/K8MM-V.html", NULL),
+       B("MSI",        "MS-7168 (Orion)",                      OK,
 "http://support.packardbell.co.uk/uk/item/index.php?i=spec_orion&pi=platform_honeymoon_istart",
NULL),
+       B("MSI",        "MS-7207 (K8NGM2-L)",                   OK,
 "http://www.msi.com/product/mb/K8NGM2-FID--IL--L.html", NULL),
+       B("MSI",        "MS-7211 (PM8M3-V)",                    OK,
 "http://www.msi.com/product/mb/PM8M3-V.html", NULL),
+       B("MSI",        "MS-7236 (945PL Neo3)",                 OK,
 "http://www.msi.com/product/mb/945PL-Neo3.html", NULL),
+       B("MSI",        "MS-7253 (K9VGM-V)",                    OK,
 "http://www.msi.com/product/mb/K9VGM-V.html", NULL),
+       B("MSI",        "MS-7255 (P4M890M)",                    OK,
 "http://www.msi.com/product/mb/P4M890M-L-IL.html", NULL),
+       B("MSI",        "MS-7260 (K9N Neo PCB 1.0)",            BAD,
 "http://www.msi.com/product/mb/K9N-Neo--PCB-1-0-.html",
"Interestingly flashrom does not work when the vendor BIOS is booted,
but it ''does'' work flawlessly when the machine is booted with
coreboot. Owned by Uwe Hermann <uwe at hermann-uwe.de>."),
+       B("MSI",        "MS-7309 (K9N6PGM2-V2)",                OK,
 "http://www.msi.com/product/mb/K9N6PGM2-V2.html", NULL),
+       B("MSI",        "MS-7312 (K9MM-V)",                     OK,
 "http://www.msi.com/product/mb/K9MM-V.html", NULL),
+       B("MSI",        "MS-7345 (P35 Neo2-FIR)",               OK,
 "http://www.msi.com/product/mb/P35-Neo2-FR---FIR.html", NULL),
+       B("MSI",        "MS-7368 (K9AG Neo2-Digital)",          OK,
 "http://www.msi.com/product/mb/K9AG-Neo2-Digital.html", NULL),
+       B("MSI",        "MS-7369 (K9N Neo V2)",                 OK,
 "http://www.msi.com/product/mb/K9N-Neo-V2.html", NULL),
+       B("MSI",        "MS-7376 (K9A2 Platinum V1)",           OK,
 "http://www.msi.com/product/mb/K9A2-Platinum.html", NULL),
+       B("MSI",        "MS-7529 (G31M3-L(S) V2)",              OK,
 "http://www.msi.com/product/mb/G31M3-L-V2---G31M3-LS-V2.html", NULL),
+       B("MSI",        "MS-7529 (G31TM-P21)",                  OK,
 "http://www.msi.com/product/mb/G31TM-P21.html", NULL),
+       B("MSI",        "MS-7548 (Aspen-GL8E)",                 OK,
 "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c01635688&lc=en&cc=us&dlc=en",
NULL),
+       B("MSI",        "MS-7596 (785GM-E51)",                  OK,
 "http://www.msi.com/product/mb/785GM-E51.html", NULL),
+       B("MSI",        "MS-7599 (870-C45)",                    OK,
 "http://www.msi.com/product/mb/870-C45.html", NULL),
+       B("MSI",        "MS-7613 (Iona-GL8E)",                  BAD,
 "http://h10025.www1.hp.com/ewfrf/wc/document?docname=c02014355&lc=en&cc=dk&dlc=en&product=4348478",
"Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME region
is locked."),
+       B("MSI",        "MS-7635 (H55M-ED55)",                  BAD,
 "http://www.msi.com/product/mb/H55M-ED55.html", "Probing works
(Winbond W25Q64, 8192 kB, SPI), but parts of the flash are
problematic: descriptor is r/o (conforming to ICH reqs), ME region is
locked."),
+       B("MSI",        "MS-7640 (890FXA-GD70)",                OK,
"http://www.msi.com/product/mb/890FXA-GD70.html", NULL),
+       B("MSI",        "MS-7642 (890GXM-G65)",                 OK,
 "http://www.msi.com/product/mb/890GXM-G65.html", NULL),
+       B("MSI",        "MS-7676 (H67MA-ED55(B3))",             OK,
 "http://www.msi.com/product/mb/H67MA-ED55--B3-.html", "Seems to work
fine basically, but user reported (hopefully unrelated) buggy behavior
of the board after a firmware upgrade. See
http://www.flashrom.org/pipermail/flashrom/2012-January/008547.html"),
+       B("MSI",        "MS-7696 (A75MA-G55)",                  OK,
 "http://www.msi.com/product/mb/A75MA-G55.html", NULL),
+       B("MSI",        "MS-7698 (E350IA-E45)",                 OK,
 "http://www.msi.com/product/mb/E350IA-E45.html", NULL),
+       B("NEC",        "PowerMate 2000",                       OK,
 "http://support.necam.com/mobilesolutions/hardware/Desktops/pm2000/celeron/",
NULL),
+       B("Nokia",      "IP530",                                OK,
 NULL, NULL),
+       B("PCCHIPS ",   "M598LMR (V9.0)",                       OK,
 NULL, NULL),
+       B("PCCHIPS ",   "M863G (V5.1A)",                        OK,
 "http://www.pcchips.com.tw/PCCWebSite/Products/ProductsDetail.aspx?CategoryID=1&DetailID=343&DetailName=Feature&MenuID=1&LanID=0",
NULL),
+       B("PC Engines", "Alix.1c",                              OK,
 "http://pcengines.ch/alix1c.htm", NULL),
+       B("PC Engines", "Alix.2c2",                             OK,
 "http://pcengines.ch/alix2c2.htm", NULL),
+       B("PC Engines", "Alix.2c3",                             OK,
 "http://pcengines.ch/alix2c3.htm", NULL),
+       B("PC Engines", "Alix.2d3",                             OK,
 "http://pcengines.ch/alix2d3.htm", NULL),
+       B("PC Engines", "Alix.3c3",                             OK,
 "http://pcengines.ch/alix3c3.htm", NULL),
+       B("PC Engines", "Alix.3d3",                             OK,
 "http://pcengines.ch/alix3d3.htm", NULL),
+       B("PC Engines", "Alix.6f2",                             OK,
 "http://pcengines.ch/alix6f2.htm", NULL),
+       B("PC Engines", "WRAP.2E",                              OK,
 "http://pcengines.ch/wrap2e1.htm", NULL),
+       B("Portwell",   "PEB-4700VLA",                          OK,
 "http://www.portwell.com/products/detail.asp?CUSTCHAR1=PEB-4700VLA",
NULL),
+       B("RCA",        "RM4100",                               OK,
 "http://www.settoplinux.org/index.php?title=RCA_RM4100", NULL),
+       B("Samsung",    "Polaris 32",                           OK,
 NULL, NULL),
+       B("Shuttle",    "AK31",                                 OK,
 "http://www.motherboard.cz/mb/shuttle/AK31.htm", NULL),
+       B("Shuttle",    "AK38N",                                OK,
 "http://eu.shuttle.com/en/desktopdefault.aspx/tabid-36/558_read-9889/",
NULL),
+       B("Shuttle",    "AV11V30",                              OK,
 NULL, NULL),
+       B("Shuttle",    "AV18E2",                               OK,
 "http://www.shuttle.eu/_archive/older/de/av18.htm", NULL),
+       B("Shuttle",    "FD37",                                 OK,
 "http://www.shuttle.eu/products/discontinued/barebones/sd37p2/",
NULL),
+       B("Shuttle",    "FH67",                                 OK,
 "http://www.shuttle.eu/products/mini-pc/sh67h3/specification/",
NULL),
+       B("Shuttle",    "FN25",                                 OK,
 "http://www.shuttle.eu/products/discontinued/barebones/sn25p/?0=",
NULL),
+       B("Shuttle",    "X50/X50(B)",                           OK,
 "http://au.shuttle.com/product_detail_spec.jsp?PI=1241", NULL),
+       B("Soyo",       "SY-5VD",                               BAD,
 "http://www.soyo.com/content/Downloads/163/&c=80&p=464&l=English",
"No public report found. Owned by Uwe Hermann <uwe at hermann-uwe.de>.
May work now."),
+       B("Soyo",       "SY-6BA+ III",                          OK,
 "http://www.motherboard.cz/mb/soyo/SY-6BA+III.htm", NULL),
+       B("Soyo",       "SY-7VCA",                              OK,
 "http://www.tomshardware.com/reviews/12-socket-370-motherboards,196-15.html",
NULL),
+       B("Sun",        "Blade x6250",                          OK,
 "http://www.sun.com/servers/blades/x6250/", NULL),
+       B("Sun",        "Fire x4150",                           BAD,
 "http://www.sun.com/servers/x64/x4150/", "No public report found. May
work now."),
+       B("Sun",        "Fire x4200",                           BAD,
 "http://www.sun.com/servers/entry/x4200/", "No public report found.
May work now."),
+       B("Sun",        "Fire x4540",                           BAD,
 "http://www.sun.com/servers/x64/x4540/", "No public report found. May
work now."),
+       B("Sun",        "Fire x4600",                           BAD,
 "http://www.sun.com/servers/x64/x4600/", "No public report found. May
work now."),
+       B("Sun",        "Ultra 40 M2",                          OK,
 "http://download.oracle.com/docs/cd/E19127-01/ultra40.ws/820-0123-13/intro.html",
NULL),
+       B("Supermicro", "H8QC8",                                OK,
 "http://www.supermicro.com/Aplus/motherboard/Opteron/nforce/H8QC8.cfm",
NULL),
+       B("Supermicro", "X5DP8-G2",                             OK,
 "http://www.supermicro.com/products/motherboard/Xeon/E7501/X5DP8-G2.cfm",
NULL),
+       B("Supermicro", "X7DBT-INF",                            OK,
 "http://www.supermicro.com/products/motherboard/Xeon1333/5000P/X7DBT-INF.cfm",
NULL),
+       B("Supermicro", "X7SPA-HF",                             OK,
 "http://www.supermicro.com/products/motherboard/ATOM/ICH9/X7SPA.cfm?typ=H&IPMI=Y",
NULL),
+       B("Supermicro", "X8DT3",                                OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT3.cfm",
NULL),
+       B("Supermicro", "X8DTE-F",                              OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DT6-F.cfm?IPMI=Y&SAS=N",
NULL),
+       B("Supermicro", "X8DTH-6F",                             OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTH-6F.cfm",
NULL),
+       B("Supermicro", "X8DTT-F",                              OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-F.cfm",
NULL),
+       B("Supermicro", "X8DTT-HIBQF",                          OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTT-H.cfm",
NULL),
+       B("Supermicro", "X8DTU-6TF+",                           BAD,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU_.cfm?TYP=SAS&LAN=10",
"Probing works (Atmel AT25DF321A, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("Supermicro", "X8DTU-F",                              OK,
 "http://www.supermicro.com/products/motherboard/QPI/5500/X8DTU-F.cfm",
NULL),
+       B("Supermicro", "X8SIE(-F)",                            BAD,
 "http://www.supermicro.com/products/motherboard/Xeon3000/3400/X8SIE.cfm?IPMI=N&TYP=LN2",
"Requires unlocking the ME although the registers are set up correctly
by the descriptor/BIOS already (tested with swseq and hwseq)."),
+       B("Supermicro", "X8STi",                                OK,
 "http://www.supermicro.com/products/motherboard/Xeon3000/X58/X8STi.cfm",
NULL),
+       B("Supermicro", "X9SCA-F",                              BAD,
 "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCA-F.cfm",
"Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME region
is locked."),
+       B("Supermicro", "X9SCL",                                BAD,
 "http://www.supermicro.com/products/motherboard/Xeon/C202_C204/X9SCL.cfm",
"Probing works (Winbond W25Q64, 8192 kB, SPI), but parts of the flash
are problematic: descriptor is r/o (conforming to ICH reqs), ME region
is locked."),
+       B("T-Online",   "S-100",                                OK,
 "http://wiki.freifunk-hannover.de/T-Online_S_100", NULL),
+       B("Tekram",     "P6Pro-A5",                             OK,
 "http://www.motherboard.cz/mb/tekram/P6Pro-A5.htm", NULL),
+       B("Termtek",    "TK-3370 (Rev:2.5B)",                   OK,
 NULL, NULL),
+       B("Thomson",    "IP1000",                               OK,
 "http://www.settoplinux.org/index.php?title=Thomson_IP1000", NULL),
+       B("TriGem",     "Anaheim-3",                            OK,
 "http://www.e4allupgraders.info/dir1/motherboards/socket370/anaheim3.shtml",
NULL),
+       B("TriGem",     "Lomita",                               OK,
 "http://www.e4allupgraders.info/dir1/motherboards/socket370/lomita.shtml",
NULL),
+       B("Tyan",       "S5375-1U (Tempest i5100X)",            OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=610", NULL),
+       B("Tyan",       "S1846 (Tsunami ATX)",                  OK,
 "http://www.tyan.com/archive/products/html/tsunamiatx.html", NULL),
+       B("Tyan",       "S2466 (Tiger MPX)",                    OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=461", NULL),
+       B("Tyan",       "S2498 (Tomcat K7M)",                   OK,
 "http://www.tyan.com/archive/products/html/tomcatk7m.html", NULL),
+       B("Tyan",       "S2723 (Tiger i7501)",                  OK,
 "http://www.tyan.com/archive/products/html/tigeri7501.html", NULL),
+       B("Tyan",       "S2881 (Thunder K8SR)",                 OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=115", NULL),
+       B("Tyan",       "S2882 (Thunder K8S Pro)",              OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=121", NULL),
+       B("Tyan",       "S2882-D (Thunder K8SD Pro)",           OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=127", NULL),
+       B("Tyan",       "S2891 (Thunder K8SRE)",                OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=144", NULL),
+       B("Tyan",       "S2892 (Thunder K8SE)",                 OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=145", NULL),
+       B("Tyan",       "S2895 (Thunder K8WE)",                 OK,
 "http://www.tyan.com/archive/products/html/thunderk8we.html", NULL),
+       B("Tyan",       "S2912 (Thunder n3600R)",               OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=157", NULL),
+       B("Tyan",       "S2915 (Thunder n6650W)",               OK,
 "http://tyan.com/product_board_detail.aspx?pid=163", NULL),
+       B("Tyan",       "S2915-E (Thunder n6650W)",             OK,
 "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=541&SKU=600000041",
NULL),
+       B("Tyan",       "S2933 (Thunder n3600S)",               OK,
 "http://tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=478&SKU=600000063",
NULL),
+       B("Tyan",       "S3095 (Tomcat i945GM)",                OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=181", NULL),
+       B("Tyan",       "S3992 (Thunder h2000M)",               OK,
 "http://tyan.com/product_board_detail.aspx?pid=235", NULL),
+       B("Tyan",       "S5180 (Toledo i965R)",                 OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=456", NULL),
+       B("Tyan",       "S5191 (Toledo i3000R)",                OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=343", NULL),
+       B("Tyan",       "S5197 (Toledo i3010W)",                OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=349", NULL),
+       B("Tyan",       "S5211 (Toledo i3210W)",                OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=591", NULL),
+       B("Tyan",       "S5211-1U (Toledo i3200R)",             OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=593", NULL),
+       B("Tyan",       "S5220 (Toledo q35T)",                  OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=597", NULL),
+       B("Tyan",       "S5375 (Tempest i5100X)",               OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=566", NULL),
+       B("Tyan",       "S5376 (Tempest i5100W)",               OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=605", "Both
S5376G2NR and S5376WAG2NR should work."),
+       B("Tyan",       "S5377 (Tempest i5100T)",               OK,
 "http://www.tyan.com/product_SKU_spec.aspx?ProductType=MB&pid=642&SKU=600000017",
NULL),
+       B("Tyan",       "S5382 (Tempest i5000PW)",              OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=439", NULL),
+       B("Tyan",       "S5397 (Tempest i5400PW)",              OK,
 "http://www.tyan.com/product_board_detail.aspx?pid=560", NULL),
+       B("VIA",        "EPIA M/MII/...",                       OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=202",
NULL), /* EPIA-MII link for now */
+       B("VIA",        "EPIA SP",                              OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=261",
NULL),
+       B("VIA",        "EPIA-CN",                              OK,
 "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=400",
NULL),
+       B("VIA",        "EPIA EK",                              OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?motherboard_id=420",
NULL),
+       B("VIA",        "EPIA-EX15000G",                        OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=450",
NULL),
+       B("VIA",        "EPIA-LN",                              OK,
 "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=473",
NULL),
+       B("VIA",        "EPIA-M700",                            OK,
 "http://via.com.tw/servlet/downloadSvl?motherboard_id=670&download_file_id=3700",
NULL),
+       B("VIA",        "EPIA-N/NL",                            OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=221",
NULL), /* EPIA-N link for now */
+       B("VIA",        "EPIA-NX15000G",                        OK,
 "http://www.via.com.tw/en/products/embedded/ProductDetail.jsp?productLine=1&motherboard_id=470",
NULL),
+       B("VIA",        "NAB74X0",                              OK,
 "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=590",
NULL),
+       B("VIA",        "pc2500e",                              OK,
 "http://www.via.com.tw/en/initiatives/empowered/pc2500_mainboard/index.jsp",
NULL),
+       B("VIA",        "PC3500G",                              OK,
 "http://www.via.com.tw/en/initiatives/empowered/pc3500_mainboard/index.jsp",
NULL),
+       B("VIA",        "VB700X",                               OK,
 "http://www.via.com.tw/en/products/mainboards/motherboards.jsp?motherboard_id=490",
NULL),
+       B("ZOTAC",      "Fusion-ITX WiFi (FUSION350-A-E)",      OK,
 NULL, NULL),
+       B("ZOTAC",      "GeForce 8200",                         OK,
 "http://pden.zotac.com/index.php?page=shop.product_details&product_id=129&category_id=92",
NULL),
+       B("ZOTAC",      "H67-ITX WiFi (H67ITX-C-E)",            BAD,
 NULL, "Probing works (Winbond W25Q32, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("ZOTAC",      "ZBOX HD-ID11",                         OK,
 "http://pdde.zotac.com/index.php?page=shop.product_details&product_id=240&category_id=75",
NULL),
 #endif

        {},
@@ -975,19 +990,19 @@
 /* Please keep this list alphabetically ordered by vendor/board. */
 const struct board_info laptops_known[] = {
 #if defined(__i386__) || defined(__x86_64__)
-       B("Acer",       "Aspire 1520",          1,
"http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml",
NULL),
-       B("Acer",       "Aspire One",           0, NULL,
"http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
-       B("ASUS",       "A8Jm",                 1, NULL, NULL),
-       B("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)."),
-       B("ASUS",       "M6Ne",                 0,
"http://www.asus.com/Notebooks/Versatile_Performance/M6NNe/",
"Untested board enable."),
-       B("Clevo",      "P150HM",               0,
"http://www.clevo.com.tw/en/products/prodinfo_2.asp?productid=307",
"Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
-       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."),
-       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"),
-       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)."),
-       B("IBM/Lenovo", "Thinkpad T40p",        0,
"http://www.thinkwiki.org/wiki/Category:T40p", NULL),
-       B("IBM/Lenovo", "Thinkpad T410s",       0,
"http://www.thinkwiki.org/wiki/Category:T410s", "Probing works
(Winbond W25X64, 8192 kB, SPI), but parts of the flash are
problematic: descriptor is r/o (conforming to ICH reqs), ME and
platform are locked."),
-       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."),
-       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),
+       B("Acer",       "Aspire 1520",          OK,
"http://support.acer.com/us/en/acerpanam/notebook/0000/Acer/Aspire1520/Aspire1520nv.shtml",
NULL),
+       B("Acer",       "Aspire One",           BAD,    NULL,
"http://www.coreboot.org/pipermail/coreboot/2009-May/048041.html"),
+       B("ASUS",       "A8Jm",                 OK,     NULL, NULL),
+       B("ASUS",       "Eee PC 701 4G",        BAD,
"http://www.asus.com/Eee/Eee_PC/Eee_PC_4G/", "It seems the chip
(25X40VSIG) is behind some SPI flash translation layer (likely in the
EC, the ENE KB3310)."),
+       B("ASUS",       "M6Ne",                 NT,
"http://www.asus.com/Notebooks/Versatile_Performance/M6NNe/",
"Untested board enable."),
+       B("Clevo",      "P150HM",               BAD,
"http://www.clevo.com.tw/en/products/prodinfo_2.asp?productid=307",
"Probing works (Macronix MX25L3205, 4096 kB, SPI), but parts of the
flash are problematic: descriptor is r/o (conforming to ICH reqs), ME
region is locked."),
+       B("Dell",       "Latitude CPi A366XT",  BAD,
"http://www.coreboot.org/Dell_Latitude_CPi_A366XT", "The laptop
immediately powers off if you try to hot-swap the chip. It's not yet
tested if write/erase would work on this laptop."),
+       B("HP/Compaq",  "nx9005",               BAD,
"http://h18000.www1.hp.com/products/quickspecs/11602_na/11602_na.HTML",
"Shuts down when probing for a chip.
http://www.flashrom.org/pipermail/flashrom/2010-May/003321.html"),
+       B("HP/Compaq",  "nx9010",               BAD,
"http://h20000.www2.hp.com/bizsupport/TechSupport/Document.jsp?lang=en&cc=us&objectID=c00348514",
"Hangs upon '''flashrom -V''' (needs hard power-cycle then)."),
+       B("IBM/Lenovo", "Thinkpad T40p",        BAD,
"http://www.thinkwiki.org/wiki/Category:T40p", NULL),
+       B("IBM/Lenovo", "Thinkpad T410s",       BAD,
"http://www.thinkwiki.org/wiki/Category:T410s", "Probing works
(Winbond W25X64, 8192 kB, SPI), but parts of the flash are
problematic: descriptor is r/o (conforming to ICH reqs), ME and
platform are locked."),
+       B("IBM/Lenovo", "240",                  BAD,
"http://www.stanford.edu/~bresnan//tp240.html", "Seems to (partially)
work at first, but one block/sector cannot be written which then
leaves you with a bricked laptop. Maybe this can be investigated and
fixed in software later."),
+       B("Lenovo",     "3000 V100 TF05Cxx",    OK,
"http://www5.pc.ibm.com/europe/products.nsf/products?openagent&brand=Lenovo3000Notebook&series=Lenovo+3000+V+Series#viewallmodelstop",
NULL),
 #endif

        {},



2012/2/19 Stefan Tauner <stefan.tauner at student.tuwien.ac.at>:
>
> Signed-off-by: Stefan Tauner <stefan.tauner at student.tuwien.ac.at>
> ---
>  ft2232_spi.c |   13 -------
>  print.c      |   15 ++++++++
>  print_wiki.c |  106 +++++++++++++++++++++++++++++++++++++++++++---------------
>  3 files changed, 94 insertions(+), 40 deletions(-)
>
> diff --git a/ft2232_spi.c b/ft2232_spi.c
> index 122866f..ec4934e 100644
> --- a/ft2232_spi.c
> +++ b/ft2232_spi.c
> @@ -435,17 +435,4 @@ static int ft2232_spi_send_command(struct flashctx *flash,
>        return failed ? -1 : 0;
>  }
>
> -void print_supported_usbdevs(const struct usbdev_status *devs)
> -{
> -       int i;
> -
> -       msg_pinfo("USB devices:\n");
> -       for (i = 0; devs[i].vendor_name != NULL; i++) {
> -               msg_pinfo("%s %s [%04x:%04x]%s\n", devs[i].vendor_name,
> -                         devs[i].device_name, devs[i].vendor_id,
> -                         devs[i].device_id,
> -                         (devs[i].status == NT) ? " (untested)" : "");
> -       }
> -}
> -
>  #endif
> diff --git a/print.c b/print.c
> index 1fdeac7..f0c701e 100644
> --- a/print.c
> +++ b/print.c
> @@ -422,6 +422,21 @@ static void print_supported_boards_helper(const struct board_info *boards,
>  }
>  #endif
>
> +#if CONFIG_FT2232_SPI == 1
> +void print_supported_usbdevs(const struct usbdev_status *devs)
> +{
> +       int i;
> +
> +       msg_pinfo("USB devices:\n");
> +       for (i = 0; devs[i].vendor_name != NULL; i++) {
> +               msg_pinfo("%s %s [%04x:%04x]%s\n", devs[i].vendor_name,
> +                         devs[i].device_name, devs[i].vendor_id,
> +                         devs[i].device_id,
> +                         (devs[i].status == NT) ? " (untested)" : "");
> +       }
> +}
> +#endif
> +
>  void print_supported(void)
>  {
>        print_supported_chips();
> diff --git a/print_wiki.c b/print_wiki.c
> index 377154d..a8c9d76 100644
> --- a/print_wiki.c
> +++ b/print_wiki.c
> @@ -72,10 +72,7 @@ static const char chip_th[] = "{\
>  | Probe\n| Read\n| Erase\n| Write\n\
>  | align=\"center\" | Min \n| align=\"center\" | Max\n\n";
>
> -static const char programmer_section[] = "\
> -\n== Supported programmers ==\n\nThis is a list \
> -of supported PCI devices flashrom can use as programmer:\n\n{| border=\"0\" \
> -valign=\"top\"\n| valign=\"top\"|\n\n{| border=\"0\" style=\"font-size: \
> +static const char programmer_th[] = "{| border=\"0\" style=\"font-size: \
>  smaller\" valign=\"top\"\n|- bgcolor=\"#6699dd\"\n! align=\"left\" | Vendor\n\
>  ! align=\"left\" | Device\n! align=\"center\" | PCI IDs\n\
>  ! align=\"center\" | Status\n\n";
> @@ -126,7 +123,7 @@ static void print_supported_chipsets_wiki(int cols)
>        printf("\n|}\n\n|}\n");
>  }
>
> -static void wiki_helper(const char *devicetype, int cols,
> +static void print_supported_boards_wiki_helper(const char *devicetype, int cols,
>                        const struct board_info boards[])
>  {
>        int i, j, k = 0, boardcount_good = 0, boardcount_bad = 0, color = 1;
> @@ -199,10 +196,10 @@ static void wiki_helper(const char *devicetype, int cols,
>  static void print_supported_boards_wiki(void)
>  {
>        printf("%s", board_intro);
> -       wiki_helper("boards", 2, boards_known);
> +       print_supported_boards_wiki_helper("boards", 2, boards_known);
>
>        printf("%s", laptop_intro);
> -       wiki_helper("laptops", 1, laptops_known);
> +       print_supported_boards_wiki_helper("laptops", 1, laptops_known);
>  }
>  #endif
>
> @@ -276,7 +273,16 @@ static void print_supported_chips_wiki(int cols)
>
>  /* Not needed for CONFIG_INTERNAL, but for all other PCI-based programmers. */
>  #if CONFIG_NIC3COM+CONFIG_NICREALTEK+CONFIG_NICNATSEMI+CONFIG_GFXNVIDIA+CONFIG_DRKAISER+CONFIG_SATASII+CONFIG_ATAHPT+CONFIG_NICINTEL+CONFIG_NICINTEL_SPI+CONFIG_OGP_SPI+CONFIG_SATAMV >= 1
> -static void print_supported_pcidevs_wiki(const struct pcidev_status *devs)
> +static int count_supported_pcidevs_wiki(const struct pcidev_status *devs)
> +{
> +       int i = 0;
> +       unsigned int count = 0;
> +       for (i = 0; devs[i].vendor_name != NULL; i++)
> +                       count++;
> +       return count;
> +}
> +
> +static void print_supported_pcidevs_wiki_helper(const struct pcidev_status *devs)
>  {
>        int i = 0;
>        static int c = 0;
> @@ -294,50 +300,96 @@ static void print_supported_pcidevs_wiki(const struct pcidev_status *devs)
>  }
>  #endif
>
> -void print_supported_wiki(void)
> +static void print_supported_pcidevs_wiki()
>  {
> -       time_t t = time(NULL);
> +       unsigned int pci_count = 0;
>
> -       printf(wiki_header, ctime(&t), flashrom_version);
> -       print_supported_chips_wiki(2);
> -#if CONFIG_INTERNAL == 1
> -       print_supported_chipsets_wiki(3);
> -       print_supported_boards_wiki();
> +#if CONFIG_NIC3COM == 1
> +       pci_count += count_supported_pcidevs_wiki(nics_3com);
> +#endif
> +#if CONFIG_NICREALTEK == 1
> +       pci_count += count_supported_pcidevs_wiki(nics_realtek);
> +#endif
> +#if CONFIG_NICNATSEMI == 1
> +       pci_count += count_supported_pcidevs_wiki(nics_natsemi);
> +#endif
> +#if CONFIG_GFXNVIDIA == 1
> +       pci_count += count_supported_pcidevs_wiki(gfx_nvidia);
> +#endif
> +#if CONFIG_DRKAISER == 1
> +       pci_count += count_supported_pcidevs_wiki(drkaiser_pcidev);
> +#endif
> +#if CONFIG_SATASII == 1
> +       pci_count += count_supported_pcidevs_wiki(satas_sii);
> +#endif
> +#if CONFIG_ATAHPT == 1
> +       pci_count += count_supported_pcidevs_wiki(ata_hpt);
> +#endif
> +#if CONFIG_NICINTEL == 1
> +       pci_count += count_supported_pcidevs_wiki(nics_intel);
> +#endif
> +#if CONFIG_NICINTEL_SPI == 1
> +       pci_count += count_supported_pcidevs_wiki(nics_intel_spi);
> +#endif
> +#if CONFIG_OGP_SPI == 1
> +       pci_count += count_supported_pcidevs_wiki(ogp_spi);
> +#endif
> +#if CONFIG_SATAMV == 1
> +       pci_count += count_supported_pcidevs_wiki(satas_mv);
>  #endif
> -       printf("%s", programmer_section);
> +
> +       printf("\n== Supported programmers ==\n\nTotal amount of supported "
> +              "PCI devices flashrom can use as programmer: '''%d'''\n\n"
> +              "{| border=\"0\" valign=\"top\"\n| valign=\"top\"|\n\n",
> +              pci_count);
> +       printf("%s", programmer_th);
> +
>  #if CONFIG_NIC3COM == 1
> -       print_supported_pcidevs_wiki(nics_3com);
> +       print_supported_pcidevs_wiki_helper(nics_3com);
>  #endif
>  #if CONFIG_NICREALTEK == 1
> -       print_supported_pcidevs_wiki(nics_realtek);
> +       print_supported_pcidevs_wiki_helper(nics_realtek);
>  #endif
>  #if CONFIG_NICNATSEMI == 1
> -       print_supported_pcidevs_wiki(nics_natsemi);
> +       print_supported_pcidevs_wiki_helper(nics_natsemi);
>  #endif
>  #if CONFIG_GFXNVIDIA == 1
> -       print_supported_pcidevs_wiki(gfx_nvidia);
> +       print_supported_pcidevs_wiki_helper(gfx_nvidia);
>  #endif
>  #if CONFIG_DRKAISER == 1
> -       print_supported_pcidevs_wiki(drkaiser_pcidev);
> +       print_supported_pcidevs_wiki_helper(drkaiser_pcidev);
>  #endif
>  #if CONFIG_SATASII == 1
> -       print_supported_pcidevs_wiki(satas_sii);
> +       print_supported_pcidevs_wiki_helper(satas_sii);
>  #endif
>  #if CONFIG_ATAHPT == 1
> -       print_supported_pcidevs_wiki(ata_hpt);
> +       print_supported_pcidevs_wiki_helper(ata_hpt);
>  #endif
>  #if CONFIG_NICINTEL == 1
> -       print_supported_pcidevs_wiki(nics_intel);
> +       print_supported_pcidevs_wiki_helper(nics_intel);
>  #endif
>  #if CONFIG_NICINTEL_SPI == 1
> -       print_supported_pcidevs_wiki(nics_intel_spi);
> +       print_supported_pcidevs_wiki_helper(nics_intel_spi);
>  #endif
>  #if CONFIG_OGP_SPI == 1
> -       print_supported_pcidevs_wiki(ogp_spi);
> +       print_supported_pcidevs_wiki_helper(ogp_spi);
>  #endif
>  #if CONFIG_SATAMV == 1
> -       print_supported_pcidevs_wiki(satas_mv);
> +       print_supported_pcidevs_wiki_helper(satas_mv);
>  #endif
>        printf("\n|}\n");
>  }
>
> +void print_supported_wiki(void)
> +{
> +       time_t t = time(NULL);
> +
> +       printf(wiki_header, ctime(&t), flashrom_version);
> +       print_supported_chips_wiki(2);
> +#if CONFIG_INTERNAL == 1
> +       print_supported_chipsets_wiki(3);
> +       print_supported_boards_wiki();
> +#endif
> +       print_supported_pcidevs_wiki();
> +}
> +
> --
> 1.7.1
>
>
> _______________________________________________
> flashrom mailing list
> flashrom at flashrom.org
> http://www.flashrom.org/mailman/listinfo/flashrom




More information about the flashrom mailing list