blob: a00347e605ecabda7597901cc103f434af99d81c [file] [log] [blame]
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001/*
Uwe Hermannd1107642007-08-29 17:52:32 +00002 * This file is part of the flashrom project.
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00003 *
Uwe Hermannd22a1d42007-09-09 20:21:05 +00004 * Copyright (C) 2000 Silicon Integrated System Corporation
5 * Copyright (C) 2004 Tyan Corp <yhlu@tyan.com>
Uwe Hermannc7e8a0c2009-05-19 14:14:21 +00006 * Copyright (C) 2005-2008 coresystems GmbH
Carl-Daniel Hailfinger03b4e712009-05-08 12:49:03 +00007 * Copyright (C) 2008,2009 Carl-Daniel Hailfinger
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00008 *
Uwe Hermannd1107642007-08-29 17:52:32 +00009 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +000013 *
Uwe Hermannd1107642007-08-29 17:52:32 +000014 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +000018 *
Uwe Hermannd1107642007-08-29 17:52:32 +000019 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +000022 */
23
Carl-Daniel Hailfinger831e8f42010-05-30 22:24:40 +000024#include <stdio.h>
Stefan Reinauer018aca82006-11-21 23:48:51 +000025#include <sys/types.h>
Patrick Georgia9095a92010-09-30 17:03:32 +000026#ifndef __LIBPAYLOAD__
27#include <fcntl.h>
Stefan Reinauer018aca82006-11-21 23:48:51 +000028#include <sys/stat.h>
Patrick Georgia9095a92010-09-30 17:03:32 +000029#endif
Ronald G. Minnichceec4202003-07-25 04:37:41 +000030#include <string.h>
Ronald G. Minnicheaab50b2003-09-12 22:41:53 +000031#include <stdlib.h>
Stefan Tauner363fd7e2013-04-07 13:08:30 +000032#include <errno.h>
Carl-Daniel Hailfingerc2441382010-11-09 22:00:31 +000033#include <ctype.h>
Ollie Lho184a4042005-11-26 21:55:36 +000034#include <getopt.h>
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +000035#if HAVE_UTSNAME == 1
36#include <sys/utsname.h>
37#endif
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +000038#include "flash.h"
Carl-Daniel Hailfinger08454642009-06-15 14:14:48 +000039#include "flashchips.h"
Carl-Daniel Hailfinger5b997c32010-07-27 22:41:39 +000040#include "programmer.h"
Carl-Daniel Hailfinger06b9efa2012-08-07 11:59:59 +000041#include "hwaccess.h"
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +000042
Mathias Krausea60faab2011-01-17 07:50:42 +000043const char flashrom_version[] = FLASHROM_VERSION;
Nico Huberbcb2e5a2012-12-30 01:23:17 +000044const char *chip_to_probe = NULL;
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +000045int verbose_screen = MSG_INFO;
46int verbose_logfile = MSG_DEBUG2;
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +000047
Carl-Daniel Hailfinger2e681602011-09-08 00:00:29 +000048static enum programmer programmer = PROGRAMMER_INVALID;
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +000049
Nico Huberbcb2e5a2012-12-30 01:23:17 +000050static const char *programmer_param = NULL;
Stefan Reinauer70385642007-04-06 11:58:03 +000051
Uwe Hermann48ec1b12010-08-08 17:01:18 +000052/*
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +000053 * Programmers supporting multiple buses can have differing size limits on
54 * each bus. Store the limits for each bus in a common struct.
55 */
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +000056struct decode_sizes max_rom_decode;
57
58/* If nonzero, used as the start address of bottom-aligned flash. */
59unsigned long flashbase;
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +000060
Carl-Daniel Hailfingerd1be52d2010-07-03 12:14:25 +000061/* Is writing allowed with this programmer? */
62int programmer_may_write;
63
Carl-Daniel Hailfinger702218d2009-05-08 17:43:22 +000064const struct programmer_entry programmer_table[] = {
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +000065#if CONFIG_INTERNAL == 1
Carl-Daniel Hailfinger702218d2009-05-08 17:43:22 +000066 {
Carl-Daniel Hailfinger37fc4692009-08-12 14:34:35 +000067 .name = "internal",
Stefan Tauneraf358d62012-12-27 18:40:26 +000068 .type = OTHER,
69 .devs.note = NULL,
Carl-Daniel Hailfinger1e334e62009-05-11 15:46:43 +000070 .init = internal_init,
Carl-Daniel Hailfinger1455b2b2009-05-11 14:13:25 +000071 .map_flash_region = physmap,
72 .unmap_flash_region = physunmap,
Carl-Daniel Hailfingerca8bfc62009-06-05 17:48:08 +000073 .delay = internal_delay,
Carl-Daniel Hailfinger702218d2009-05-08 17:43:22 +000074 },
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +000075#endif
Luc Verhaegen8e3a6002007-04-04 22:45:58 +000076
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +000077#if CONFIG_DUMMY == 1
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000078 {
Carl-Daniel Hailfinger37fc4692009-08-12 14:34:35 +000079 .name = "dummy",
Stefan Tauneraf358d62012-12-27 18:40:26 +000080 .type = OTHER,
81 /* FIXME */
82 .devs.note = "Dummy device, does nothing and logs all accesses\n",
Carl-Daniel Hailfinger1e334e62009-05-11 15:46:43 +000083 .init = dummy_init,
Carl-Daniel Hailfinger1455b2b2009-05-11 14:13:25 +000084 .map_flash_region = dummy_map,
85 .unmap_flash_region = dummy_unmap,
Carl-Daniel Hailfingerca8bfc62009-06-05 17:48:08 +000086 .delay = internal_delay,
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000087 },
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +000088#endif
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000089
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +000090#if CONFIG_NIC3COM == 1
Uwe Hermannb4dcb712009-05-13 11:36:06 +000091 {
Carl-Daniel Hailfinger37fc4692009-08-12 14:34:35 +000092 .name = "nic3com",
Stefan Tauneraf358d62012-12-27 18:40:26 +000093 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +000094 .devs.dev = nics_3com,
Uwe Hermannb4dcb712009-05-13 11:36:06 +000095 .init = nic3com_init,
Uwe Hermannc6915932009-05-17 23:12:17 +000096 .map_flash_region = fallback_map,
97 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfingerca8bfc62009-06-05 17:48:08 +000098 .delay = internal_delay,
Uwe Hermannb4dcb712009-05-13 11:36:06 +000099 },
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000100#endif
Uwe Hermannb4dcb712009-05-13 11:36:06 +0000101
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000102#if CONFIG_NICREALTEK == 1
Joerg Fischer5665ef32010-05-21 21:54:07 +0000103 {
Carl-Daniel Hailfinger40446ee2011-03-07 01:08:09 +0000104 /* This programmer works for Realtek RTL8139 and SMC 1211. */
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000105 .name = "nicrealtek",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000106 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000107 .devs.dev = nics_realtek,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000108 .init = nicrealtek_init,
109 .map_flash_region = fallback_map,
110 .unmap_flash_region = fallback_unmap,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000111 .delay = internal_delay,
Joerg Fischer5665ef32010-05-21 21:54:07 +0000112 },
Joerg Fischer5665ef32010-05-21 21:54:07 +0000113#endif
114
Andrew Morganc29c2e72010-06-07 22:37:54 +0000115#if CONFIG_NICNATSEMI == 1
116 {
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000117 .name = "nicnatsemi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000118 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000119 .devs.dev = nics_natsemi,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000120 .init = nicnatsemi_init,
121 .map_flash_region = fallback_map,
122 .unmap_flash_region = fallback_unmap,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000123 .delay = internal_delay,
Andrew Morganc29c2e72010-06-07 22:37:54 +0000124 },
125#endif
Joerg Fischer5665ef32010-05-21 21:54:07 +0000126
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000127#if CONFIG_GFXNVIDIA == 1
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000128 {
129 .name = "gfxnvidia",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000130 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000131 .devs.dev = gfx_nvidia,
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000132 .init = gfxnvidia_init,
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000133 .map_flash_region = fallback_map,
134 .unmap_flash_region = fallback_unmap,
Uwe Hermann2bc98f62009-09-30 18:29:55 +0000135 .delay = internal_delay,
136 },
137#endif
138
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000139#if CONFIG_DRKAISER == 1
Rudolf Marek68720c72009-05-17 19:39:27 +0000140 {
TURBO Jb0912c02009-09-02 23:00:46 +0000141 .name = "drkaiser",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000142 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000143 .devs.dev = drkaiser_pcidev,
TURBO Jb0912c02009-09-02 23:00:46 +0000144 .init = drkaiser_init,
TURBO Jb0912c02009-09-02 23:00:46 +0000145 .map_flash_region = fallback_map,
146 .unmap_flash_region = fallback_unmap,
TURBO Jb0912c02009-09-02 23:00:46 +0000147 .delay = internal_delay,
148 },
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000149#endif
TURBO Jb0912c02009-09-02 23:00:46 +0000150
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000151#if CONFIG_SATASII == 1
TURBO Jb0912c02009-09-02 23:00:46 +0000152 {
Carl-Daniel Hailfinger37fc4692009-08-12 14:34:35 +0000153 .name = "satasii",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000154 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000155 .devs.dev = satas_sii,
Rudolf Marek68720c72009-05-17 19:39:27 +0000156 .init = satasii_init,
Uwe Hermannc6915932009-05-17 23:12:17 +0000157 .map_flash_region = fallback_map,
158 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfingerca8bfc62009-06-05 17:48:08 +0000159 .delay = internal_delay,
Rudolf Marek68720c72009-05-17 19:39:27 +0000160 },
Carl-Daniel Hailfinger4740c6f2009-09-16 10:09:21 +0000161#endif
Rudolf Marek68720c72009-05-17 19:39:27 +0000162
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000163#if CONFIG_ATAHPT == 1
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000164 {
165 .name = "atahpt",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000166 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000167 .devs.dev = ata_hpt,
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000168 .init = atahpt_init,
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000169 .map_flash_region = fallback_map,
170 .unmap_flash_region = fallback_unmap,
Uwe Hermannddd5c9e2010-02-21 21:17:00 +0000171 .delay = internal_delay,
172 },
173#endif
174
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000175#if CONFIG_FT2232_SPI == 1
Paul Fox05dfbe62009-06-16 21:08:06 +0000176 {
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000177 .name = "ft2232_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000178 .type = USB,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000179 .devs.dev = devs_ft2232spi,
Paul Fox05dfbe62009-06-16 21:08:06 +0000180 .init = ft2232_spi_init,
Carl-Daniel Hailfinger415e5132009-08-12 11:39:29 +0000181 .map_flash_region = fallback_map,
182 .unmap_flash_region = fallback_unmap,
Paul Fox05dfbe62009-06-16 21:08:06 +0000183 .delay = internal_delay,
184 },
Carl-Daniel Hailfinger3426ef62009-08-19 13:27:58 +0000185#endif
Carl-Daniel Hailfinger415e5132009-08-12 11:39:29 +0000186
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000187#if CONFIG_SERPROG == 1
Urja Rannikko22915352009-06-23 11:33:43 +0000188 {
Carl-Daniel Hailfinger37fc4692009-08-12 14:34:35 +0000189 .name = "serprog",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000190 .type = OTHER,
191 /* FIXME */
192 .devs.note = "All programmer devices speaking the serprog protocol\n",
Urja Rannikko22915352009-06-23 11:33:43 +0000193 .init = serprog_init,
Urja Rannikko22915352009-06-23 11:33:43 +0000194 .map_flash_region = fallback_map,
195 .unmap_flash_region = fallback_unmap,
Urja Rannikko22915352009-06-23 11:33:43 +0000196 .delay = serprog_delay,
197 },
Carl-Daniel Hailfinger6be74112009-08-12 16:17:41 +0000198#endif
Paul Fox05dfbe62009-06-16 21:08:06 +0000199
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000200#if CONFIG_BUSPIRATE_SPI == 1
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000201 {
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000202 .name = "buspirate_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000203 .type = OTHER,
204 /* FIXME */
205 .devs.note = "Dangerous Prototypes Bus Pirate\n",
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000206 .init = buspirate_spi_init,
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000207 .map_flash_region = fallback_map,
208 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfinger5cca01f2009-11-24 00:20:03 +0000209 .delay = internal_delay,
210 },
211#endif
212
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +0000213#if CONFIG_DEDIPROG == 1
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000214 {
215 .name = "dediprog",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000216 .type = OTHER,
217 /* FIXME */
218 .devs.note = "Dediprog SF100\n",
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000219 .init = dediprog_init,
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000220 .map_flash_region = fallback_map,
221 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfingerd38fac82010-01-19 11:15:48 +0000222 .delay = internal_delay,
223 },
224#endif
225
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000226#if CONFIG_RAYER_SPI == 1
227 {
228 .name = "rayer_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000229 .type = OTHER,
230 /* FIXME */
231 .devs.note = "RayeR parallel port programmer\n",
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000232 .init = rayer_spi_init,
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000233 .map_flash_region = fallback_map,
234 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfingere7fdd6e2010-07-21 10:26:01 +0000235 .delay = internal_delay,
236 },
237#endif
238
Virgil-Adrian Teacada7c5452012-04-30 23:11:06 +0000239#if CONFIG_PONY_SPI == 1
240 {
241 .name = "pony_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000242 .type = OTHER,
243 /* FIXME */
244 .devs.note = "Programmers compatible with SI-Prog, serbang or AJAWe\n",
Virgil-Adrian Teacada7c5452012-04-30 23:11:06 +0000245 .init = pony_spi_init,
246 .map_flash_region = fallback_map,
247 .unmap_flash_region = fallback_unmap,
248 .delay = internal_delay,
Stefan Tauneraf358d62012-12-27 18:40:26 +0000249 },
Virgil-Adrian Teacada7c5452012-04-30 23:11:06 +0000250#endif
251
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000252#if CONFIG_NICINTEL == 1
253 {
254 .name = "nicintel",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000255 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000256 .devs.dev = nics_intel,
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000257 .init = nicintel_init,
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000258 .map_flash_region = fallback_map,
259 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfingerb713d2e2011-05-08 00:24:18 +0000260 .delay = internal_delay,
261 },
262#endif
263
Idwer Vollering004f4b72010-09-03 18:21:21 +0000264#if CONFIG_NICINTEL_SPI == 1
265 {
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000266 .name = "nicintel_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000267 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000268 .devs.dev = nics_intel_spi,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000269 .init = nicintel_spi_init,
270 .map_flash_region = fallback_map,
271 .unmap_flash_region = fallback_unmap,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000272 .delay = internal_delay,
Idwer Vollering004f4b72010-09-03 18:21:21 +0000273 },
274#endif
275
Mark Marshall90021f22010-12-03 14:48:11 +0000276#if CONFIG_OGP_SPI == 1
277 {
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000278 .name = "ogp_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000279 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000280 .devs.dev = ogp_spi,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000281 .init = ogp_spi_init,
282 .map_flash_region = fallback_map,
283 .unmap_flash_region = fallback_unmap,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000284 .delay = internal_delay,
Mark Marshall90021f22010-12-03 14:48:11 +0000285 },
286#endif
287
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000288#if CONFIG_SATAMV == 1
289 {
290 .name = "satamv",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000291 .type = PCI,
Stefan Tauner4b24a2d2012-12-27 18:40:36 +0000292 .devs.dev = satas_mv,
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000293 .init = satamv_init,
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000294 .map_flash_region = fallback_map,
295 .unmap_flash_region = fallback_unmap,
Carl-Daniel Hailfinger9a1105c2011-02-04 21:37:59 +0000296 .delay = internal_delay,
297 },
298#endif
299
Sven Schnelle5ce5f702011-09-03 18:37:52 +0000300#if CONFIG_LINUX_SPI == 1
301 {
302 .name = "linux_spi",
Stefan Tauneraf358d62012-12-27 18:40:26 +0000303 .type = OTHER,
304 .devs.note = "Device files /dev/spidev*.*\n",
Sven Schnelle5ce5f702011-09-03 18:37:52 +0000305 .init = linux_spi_init,
306 .map_flash_region = fallback_map,
307 .unmap_flash_region = fallback_unmap,
Sven Schnelle5ce5f702011-09-03 18:37:52 +0000308 .delay = internal_delay,
309 },
310#endif
311
James Lairdc60de0e2013-03-27 13:00:23 +0000312#if CONFIG_USBBLASTER_SPI == 1
313 {
314 .name = "usbblaster_spi",
315 .type = USB,
316 .devs.dev = devs_usbblasterspi,
317 .init = usbblaster_spi_init,
318 .map_flash_region = fallback_map,
319 .unmap_flash_region = fallback_unmap,
320 .delay = internal_delay,
321 },
322#endif
323
Carl-Daniel Hailfinger1c6d2ff2012-08-27 00:44:42 +0000324 {0}, /* This entry corresponds to PROGRAMMER_INVALID. */
Carl-Daniel Hailfinger702218d2009-05-08 17:43:22 +0000325};
Luc Verhaegen8e3a6002007-04-04 22:45:58 +0000326
Carl-Daniel Hailfinger2bee8cf2010-11-10 15:25:18 +0000327#define SHUTDOWN_MAXFN 32
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000328static int shutdown_fn_count = 0;
329struct shutdown_func_data {
David Hendricks8bb20212011-06-14 01:35:36 +0000330 int (*func) (void *data);
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000331 void *data;
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000332} static shutdown_fn[SHUTDOWN_MAXFN];
333/* Initialize to 0 to make sure nobody registers a shutdown function before
334 * programmer init.
335 */
336static int may_register_shutdown = 0;
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000337
Stefan Taunerc4f44df2013-08-12 22:58:43 +0000338/* Did we change something or was every erase/write skipped (if any)? */
339static bool all_skipped = true;
340
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +0000341static int check_block_eraser(const struct flashctx *flash, int k, int log);
Stefan Tauner5368dca2011-07-01 00:19:12 +0000342
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000343/* Register a function to be executed on programmer shutdown.
344 * The advantage over atexit() is that you can supply a void pointer which will
345 * be used as parameter to the registered function upon programmer shutdown.
346 * This pointer can point to arbitrary data used by said function, e.g. undo
347 * information for GPIO settings etc. If unneeded, set data=NULL.
348 * Please note that the first (void *data) belongs to the function signature of
349 * the function passed as first parameter.
350 */
David Hendricks8bb20212011-06-14 01:35:36 +0000351int register_shutdown(int (*function) (void *data), void *data)
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000352{
353 if (shutdown_fn_count >= SHUTDOWN_MAXFN) {
Carl-Daniel Hailfinger9f5f2152010-06-04 23:20:21 +0000354 msg_perr("Tried to register more than %i shutdown functions.\n",
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000355 SHUTDOWN_MAXFN);
356 return 1;
357 }
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000358 if (!may_register_shutdown) {
359 msg_perr("Tried to register a shutdown function before "
360 "programmer init.\n");
361 return 1;
362 }
Carl-Daniel Hailfingercc389fc2010-02-14 01:20:28 +0000363 shutdown_fn[shutdown_fn_count].func = function;
364 shutdown_fn[shutdown_fn_count].data = data;
365 shutdown_fn_count++;
366
367 return 0;
368}
369
Nico Huberbcb2e5a2012-12-30 01:23:17 +0000370int programmer_init(enum programmer prog, const char *param)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000371{
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000372 int ret;
Carl-Daniel Hailfinger2e681602011-09-08 00:00:29 +0000373
374 if (prog >= PROGRAMMER_INVALID) {
375 msg_perr("Invalid programmer specified!\n");
376 return -1;
377 }
378 programmer = prog;
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000379 /* Initialize all programmer specific data. */
380 /* Default to unlimited decode sizes. */
381 max_rom_decode = (const struct decode_sizes) {
382 .parallel = 0xffffffff,
383 .lpc = 0xffffffff,
384 .fwh = 0xffffffff,
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000385 .spi = 0xffffffff,
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000386 };
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000387 /* Default to top aligned flash at 4 GB. */
388 flashbase = 0;
389 /* Registering shutdown functions is now allowed. */
390 may_register_shutdown = 1;
Carl-Daniel Hailfingerd1be52d2010-07-03 12:14:25 +0000391 /* Default to allowing writes. Broken programmers set this to 0. */
392 programmer_may_write = 1;
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000393
394 programmer_param = param;
Carl-Daniel Hailfinger20a36ba2013-08-13 07:09:57 +0000395 msg_pdbg("Initializing %s programmer\n", programmer_table[programmer].name);
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000396 ret = programmer_table[programmer].init();
397 if (programmer_param && strlen(programmer_param)) {
Carl-Daniel Hailfinger20a36ba2013-08-13 07:09:57 +0000398 if (ret != 0) {
399 /* It is quite possible that any unhandled programmer parameter would have been valid,
400 * but an error in actual programmer init happened before the parameter was evaluated.
401 */
402 msg_pwarn("Unhandled programmer parameters (possibly due to another failure): %s\n",
403 programmer_param);
404 } else {
405 /* Actual programmer init was successful, but the user specified an invalid or unusable
406 * (for the current programmer configuration) parameter.
407 */
408 msg_perr("Unhandled programmer parameters: %s\n", programmer_param);
409 msg_perr("Aborting.\n");
410 ret = ERROR_FATAL;
411 }
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000412 }
413 return ret;
Uwe Hermann09e04f72009-05-16 22:36:00 +0000414}
415
416int programmer_shutdown(void)
417{
David Hendricks8bb20212011-06-14 01:35:36 +0000418 int ret = 0;
419
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000420 /* Registering shutdown functions is no longer allowed. */
421 may_register_shutdown = 0;
422 while (shutdown_fn_count > 0) {
423 int i = --shutdown_fn_count;
David Hendricks8bb20212011-06-14 01:35:36 +0000424 ret |= shutdown_fn[i].func(shutdown_fn[i].data);
Carl-Daniel Hailfingerad3cc552010-07-03 11:02:10 +0000425 }
Stefan Taunere34e3e82013-01-01 00:06:51 +0000426
Stefan Taunerb8911d62012-12-26 07:55:00 +0000427 programmer_param = NULL;
Stefan Taunere34e3e82013-01-01 00:06:51 +0000428 registered_programmer_count = 0;
429
David Hendricks8bb20212011-06-14 01:35:36 +0000430 return ret;
Uwe Hermann09e04f72009-05-16 22:36:00 +0000431}
432
Stefan Tauner305e0b92013-07-17 23:46:44 +0000433void *programmer_map_flash_region(const char *descr, uintptr_t phys_addr, size_t len)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000434{
435 return programmer_table[programmer].map_flash_region(descr,
436 phys_addr, len);
437}
438
439void programmer_unmap_flash_region(void *virt_addr, size_t len)
440{
441 programmer_table[programmer].unmap_flash_region(virt_addr, len);
442}
443
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000444void chip_writeb(const struct flashctx *flash, uint8_t val, chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000445{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000446 flash->pgm->par.chip_writeb(flash, val, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000447}
448
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000449void chip_writew(const struct flashctx *flash, uint16_t val, chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000450{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000451 flash->pgm->par.chip_writew(flash, val, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000452}
453
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000454void chip_writel(const struct flashctx *flash, uint32_t val, chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000455{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000456 flash->pgm->par.chip_writel(flash, val, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000457}
458
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000459void chip_writen(const struct flashctx *flash, uint8_t *buf, chipaddr addr,
460 size_t len)
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000461{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000462 flash->pgm->par.chip_writen(flash, buf, addr, len);
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000463}
464
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000465uint8_t chip_readb(const struct flashctx *flash, const chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000466{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000467 return flash->pgm->par.chip_readb(flash, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000468}
469
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000470uint16_t chip_readw(const struct flashctx *flash, const chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000471{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000472 return flash->pgm->par.chip_readw(flash, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000473}
474
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000475uint32_t chip_readl(const struct flashctx *flash, const chipaddr addr)
Uwe Hermann09e04f72009-05-16 22:36:00 +0000476{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000477 return flash->pgm->par.chip_readl(flash, addr);
Uwe Hermann09e04f72009-05-16 22:36:00 +0000478}
479
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000480void chip_readn(const struct flashctx *flash, uint8_t *buf, chipaddr addr,
481 size_t len)
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000482{
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +0000483 flash->pgm->par.chip_readn(flash, buf, addr, len);
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000484}
485
Carl-Daniel Hailfingerca8bfc62009-06-05 17:48:08 +0000486void programmer_delay(int usecs)
487{
488 programmer_table[programmer].delay(usecs);
489}
490
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +0000491void map_flash_registers(struct flashctx *flash)
Stefan Reinauerff4f1972007-05-24 08:48:10 +0000492{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000493 size_t size = flash->chip->total_size * 1024;
Carl-Daniel Hailfingerd0fc9462009-05-11 14:01:17 +0000494 /* Flash registers live 4 MByte below the flash. */
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +0000495 /* FIXME: This is incorrect for nonstandard flashbase. */
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +0000496 flash->virtual_registers = (chipaddr)programmer_map_flash_region("flash chip registers", (0xFFFFFFFF - 0x400000 - size + 1), size);
Stefan Reinauerff4f1972007-05-24 08:48:10 +0000497}
498
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000499int read_memmapped(struct flashctx *flash, uint8_t *buf, unsigned int start,
500 int unsigned len)
Carl-Daniel Hailfinger03b4e712009-05-08 12:49:03 +0000501{
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000502 chip_readn(flash, buf, flash->virtual_memory + start, len);
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000503
Carl-Daniel Hailfinger03b4e712009-05-08 12:49:03 +0000504 return 0;
505}
506
Carl-Daniel Hailfinger38a059d2009-06-13 12:04:03 +0000507int min(int a, int b)
508{
509 return (a < b) ? a : b;
510}
511
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000512int max(int a, int b)
513{
514 return (a > b) ? a : b;
515}
516
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +0000517int bitcount(unsigned long a)
518{
519 int i = 0;
520 for (; a != 0; a >>= 1)
521 if (a & 1)
522 i++;
523 return i;
524}
525
Carl-Daniel Hailfingerc2441382010-11-09 22:00:31 +0000526void tolower_string(char *str)
527{
528 for (; *str != '\0'; str++)
529 *str = (char)tolower((unsigned char)*str);
530}
531
Carl-Daniel Hailfingerb22918c2009-06-01 02:08:58 +0000532char *strcat_realloc(char *dest, const char *src)
533{
534 dest = realloc(dest, strlen(dest) + strlen(src) + 1);
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000535 if (!dest) {
536 msg_gerr("Out of memory!\n");
Carl-Daniel Hailfingerb22918c2009-06-01 02:08:58 +0000537 return NULL;
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000538 }
Carl-Daniel Hailfingerb22918c2009-06-01 02:08:58 +0000539 strcat(dest, src);
540 return dest;
541}
542
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000543/* This is a somewhat hacked function similar in some ways to strtok().
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000544 * It will look for needle with a subsequent '=' in haystack, return a copy of
545 * needle and remove everything from the first occurrence of needle to the next
546 * delimiter from haystack.
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000547 */
Nico Huberbcb2e5a2012-12-30 01:23:17 +0000548char *extract_param(const char *const *haystack, const char *needle, const char *delim)
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000549{
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000550 char *param_pos, *opt_pos, *rest;
551 char *opt = NULL;
552 int optlen;
Carl-Daniel Hailfinger27023762010-04-28 15:22:14 +0000553 int needlelen;
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000554
Carl-Daniel Hailfinger27023762010-04-28 15:22:14 +0000555 needlelen = strlen(needle);
556 if (!needlelen) {
557 msg_gerr("%s: empty needle! Please report a bug at "
558 "flashrom@flashrom.org\n", __func__);
559 return NULL;
560 }
561 /* No programmer parameters given. */
562 if (*haystack == NULL)
563 return NULL;
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000564 param_pos = strstr(*haystack, needle);
565 do {
566 if (!param_pos)
567 return NULL;
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000568 /* Needle followed by '='? */
569 if (param_pos[needlelen] == '=') {
570
571 /* Beginning of the string? */
572 if (param_pos == *haystack)
573 break;
574 /* After a delimiter? */
575 if (strchr(delim, *(param_pos - 1)))
576 break;
577 }
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000578 /* Continue searching. */
579 param_pos++;
580 param_pos = strstr(param_pos, needle);
581 } while (1);
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000582
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000583 if (param_pos) {
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000584 /* Get the string after needle and '='. */
585 opt_pos = param_pos + needlelen + 1;
586 optlen = strcspn(opt_pos, delim);
587 /* Return an empty string if the parameter was empty. */
588 opt = malloc(optlen + 1);
589 if (!opt) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000590 msg_gerr("Out of memory!\n");
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000591 exit(1);
592 }
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000593 strncpy(opt, opt_pos, optlen);
594 opt[optlen] = '\0';
595 rest = opt_pos + optlen;
596 /* Skip all delimiters after the current parameter. */
597 rest += strspn(rest, delim);
598 memmove(param_pos, rest, strlen(rest) + 1);
599 /* We could shrink haystack, but the effort is not worth it. */
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000600 }
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000601
Carl-Daniel Hailfinger744132a2010-07-06 09:55:48 +0000602 return opt;
Carl-Daniel Hailfingerd5b28fa2009-11-24 18:27:10 +0000603}
604
Stefan Tauner66652442011-06-26 17:38:17 +0000605char *extract_programmer_param(const char *param_name)
Carl-Daniel Hailfinger2b6dcb32010-07-08 10:13:37 +0000606{
607 return extract_param(&programmer_param, param_name, ",");
608}
609
Sylvain "ythier" Hitier9db45512011-07-04 07:27:17 +0000610/* Returns the number of well-defined erasers for a chip. */
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +0000611static unsigned int count_usable_erasers(const struct flashctx *flash)
Stefan Tauner5368dca2011-07-01 00:19:12 +0000612{
613 unsigned int usable_erasefunctions = 0;
614 int k;
615 for (k = 0; k < NUM_ERASEFUNCTIONS; k++) {
616 if (!check_block_eraser(flash, k, 0))
617 usable_erasefunctions++;
618 }
619 return usable_erasefunctions;
620}
621
Stefan Tauner78ffbea2012-10-27 15:36:56 +0000622int compare_range(uint8_t *wantbuf, uint8_t *havebuf, unsigned int start, unsigned int len)
623{
624 int ret = 0, failcount = 0;
625 unsigned int i;
626 for (i = 0; i < len; i++) {
627 if (wantbuf[i] != havebuf[i]) {
628 /* Only print the first failure. */
629 if (!failcount++)
630 msg_cerr("FAILED at 0x%08x! Expected=0x%02x, Found=0x%02x,",
631 start + i, wantbuf[i], havebuf[i]);
632 }
633 }
634 if (failcount) {
635 msg_cerr(" failed byte count from 0x%08x-0x%08x: 0x%x\n",
636 start, start + len - 1, failcount);
637 ret = -1;
638 }
639 return ret;
640}
641
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000642/* start is an offset to the base address of the flash chip */
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +0000643int check_erased_range(struct flashctx *flash, unsigned int start,
644 unsigned int len)
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000645{
646 int ret;
647 uint8_t *cmpbuf = malloc(len);
648
649 if (!cmpbuf) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000650 msg_gerr("Could not allocate memory!\n");
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000651 exit(1);
652 }
653 memset(cmpbuf, 0xff, len);
Stefan Tauner78ffbea2012-10-27 15:36:56 +0000654 ret = verify_range(flash, cmpbuf, start, len);
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000655 free(cmpbuf);
656 return ret;
657}
658
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000659/*
Carl-Daniel Hailfingerd0250a32009-11-25 17:05:52 +0000660 * @cmpbuf buffer to compare against, cmpbuf[0] is expected to match the
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000661 * flash content at location start
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000662 * @start offset to the base address of the flash chip
663 * @len length of the verified area
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000664 * @return 0 for success, -1 for failure
665 */
Stefan Tauner78ffbea2012-10-27 15:36:56 +0000666int verify_range(struct flashctx *flash, uint8_t *cmpbuf, unsigned int start, unsigned int len)
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000667{
Carl-Daniel Hailfingerd8369412010-11-16 17:21:58 +0000668 uint8_t *readbuf = malloc(len);
Stefan Tauner78ffbea2012-10-27 15:36:56 +0000669 int ret = 0;
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000670
671 if (!len)
672 goto out_free;
673
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000674 if (!flash->chip->read) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000675 msg_cerr("ERROR: flashrom has no read function for this flash chip.\n");
Carl-Daniel Hailfinger23290662009-06-24 08:20:45 +0000676 return 1;
677 }
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000678 if (!readbuf) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000679 msg_gerr("Could not allocate memory!\n");
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000680 exit(1);
681 }
682
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000683 if (start + len > flash->chip->total_size * 1024) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000684 msg_gerr("Error: %s called with start 0x%x + len 0x%x >"
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000685 " total_size 0x%x\n", __func__, start, len,
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000686 flash->chip->total_size * 1024);
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000687 ret = -1;
688 goto out_free;
689 }
Uwe Hermann91f4afa2011-07-28 08:13:25 +0000690
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +0000691 ret = flash->chip->read(flash, readbuf, start, len);
Carl-Daniel Hailfingerd8369412010-11-16 17:21:58 +0000692 if (ret) {
693 msg_gerr("Verification impossible because read failed "
694 "at 0x%x (len 0x%x)\n", start, len);
695 return ret;
696 }
697
Stefan Tauner78ffbea2012-10-27 15:36:56 +0000698 ret = compare_range(cmpbuf, readbuf, start, len);
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +0000699out_free:
700 free(readbuf);
701 return ret;
702}
703
Stefan Tauner02437452013-04-01 19:34:53 +0000704/* Helper function for need_erase() that focuses on granularities of gran bytes. */
705static int need_erase_gran_bytes(uint8_t *have, uint8_t *want, unsigned int len, unsigned int gran)
706{
707 unsigned int i, j, limit;
708 for (j = 0; j < len / gran; j++) {
709 limit = min (gran, len - j * gran);
710 /* Are 'have' and 'want' identical? */
711 if (!memcmp(have + j * gran, want + j * gran, limit))
712 continue;
713 /* have needs to be in erased state. */
714 for (i = 0; i < limit; i++)
715 if (have[j * gran + i] != 0xff)
716 return 1;
717 }
718 return 0;
719}
720
Uwe Hermann48ec1b12010-08-08 17:01:18 +0000721/*
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000722 * Check if the buffer @have can be programmed to the content of @want without
723 * erasing. This is only possible if all chunks of size @gran are either kept
724 * as-is or changed from an all-ones state to any other state.
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000725 *
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000726 * Warning: This function assumes that @have and @want point to naturally
727 * aligned regions.
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000728 *
729 * @have buffer with current content
730 * @want buffer with desired content
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000731 * @len length of the checked area
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000732 * @gran write granularity (enum, not count)
733 * @return 0 if no erase is needed, 1 otherwise
734 */
Stefan Taunerc69c9c82011-11-23 09:13:48 +0000735int need_erase(uint8_t *have, uint8_t *want, unsigned int len, enum write_granularity gran)
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000736{
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +0000737 int result = 0;
Stefan Tauner02437452013-04-01 19:34:53 +0000738 unsigned int i;
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000739
740 switch (gran) {
741 case write_gran_1bit:
742 for (i = 0; i < len; i++)
743 if ((have[i] & want[i]) != want[i]) {
744 result = 1;
745 break;
746 }
747 break;
748 case write_gran_1byte:
749 for (i = 0; i < len; i++)
750 if ((have[i] != want[i]) && (have[i] != 0xff)) {
751 result = 1;
752 break;
753 }
754 break;
755 case write_gran_256bytes:
Stefan Tauner02437452013-04-01 19:34:53 +0000756 result = need_erase_gran_bytes(have, want, len, 256);
757 break;
758 case write_gran_264bytes:
759 result = need_erase_gran_bytes(have, want, len, 264);
760 break;
761 case write_gran_512bytes:
762 result = need_erase_gran_bytes(have, want, len, 512);
763 break;
764 case write_gran_528bytes:
765 result = need_erase_gran_bytes(have, want, len, 528);
766 break;
767 case write_gran_1024bytes:
768 result = need_erase_gran_bytes(have, want, len, 1024);
769 break;
770 case write_gran_1056bytes:
771 result = need_erase_gran_bytes(have, want, len, 1056);
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000772 break;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000773 default:
774 msg_cerr("%s: Unsupported granularity! Please report a bug at "
775 "flashrom@flashrom.org\n", __func__);
Carl-Daniel Hailfingere8e369f2010-03-08 00:42:32 +0000776 }
777 return result;
778}
779
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000780/**
781 * Check if the buffer @have needs to be programmed to get the content of @want.
782 * If yes, return 1 and fill in first_start with the start address of the
783 * write operation and first_len with the length of the first to-be-written
784 * chunk. If not, return 0 and leave first_start and first_len undefined.
785 *
786 * Warning: This function assumes that @have and @want point to naturally
787 * aligned regions.
788 *
789 * @have buffer with current content
790 * @want buffer with desired content
791 * @len length of the checked area
792 * @gran write granularity (enum, not count)
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000793 * @first_start offset of the first byte which needs to be written (passed in
794 * value is increased by the offset of the first needed write
795 * relative to have/want or unchanged if no write is needed)
796 * @return length of the first contiguous area which needs to be written
797 * 0 if no write is needed
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000798 *
799 * FIXME: This function needs a parameter which tells it about coalescing
800 * in relation to the max write length of the programmer and the max write
801 * length of the chip.
802 */
Stefan Taunerc69c9c82011-11-23 09:13:48 +0000803static unsigned int get_next_write(uint8_t *have, uint8_t *want, unsigned int len,
804 unsigned int *first_start,
805 enum write_granularity gran)
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000806{
Stefan Taunerc69c9c82011-11-23 09:13:48 +0000807 int need_write = 0;
808 unsigned int rel_start = 0, first_len = 0;
809 unsigned int i, limit, stride;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000810
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000811 switch (gran) {
812 case write_gran_1bit:
813 case write_gran_1byte:
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000814 stride = 1;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000815 break;
816 case write_gran_256bytes:
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000817 stride = 256;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000818 break;
Stefan Tauner02437452013-04-01 19:34:53 +0000819 case write_gran_264bytes:
820 stride = 264;
821 break;
822 case write_gran_512bytes:
823 stride = 512;
824 break;
825 case write_gran_528bytes:
826 stride = 528;
827 break;
828 case write_gran_1024bytes:
829 stride = 1024;
830 break;
831 case write_gran_1056bytes:
832 stride = 1056;
833 break;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000834 default:
835 msg_cerr("%s: Unsupported granularity! Please report a bug at "
836 "flashrom@flashrom.org\n", __func__);
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000837 /* Claim that no write was needed. A write with unknown
838 * granularity is too dangerous to try.
839 */
840 return 0;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000841 }
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000842 for (i = 0; i < len / stride; i++) {
843 limit = min(stride, len - i * stride);
844 /* Are 'have' and 'want' identical? */
845 if (memcmp(have + i * stride, want + i * stride, limit)) {
846 if (!need_write) {
847 /* First location where have and want differ. */
848 need_write = 1;
849 rel_start = i * stride;
850 }
851 } else {
852 if (need_write) {
853 /* First location where have and want
854 * do not differ anymore.
855 */
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000856 break;
857 }
858 }
859 }
Carl-Daniel Hailfinger202bf532010-12-06 13:05:44 +0000860 if (need_write)
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000861 first_len = min(i * stride - rel_start, len);
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000862 *first_start += rel_start;
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +0000863 return first_len;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +0000864}
865
Carl-Daniel Hailfingereaac68b2009-11-23 12:55:31 +0000866/* This function generates various test patterns useful for testing controller
867 * and chip communication as well as chip behaviour.
868 *
869 * If a byte can be written multiple times, each time keeping 0-bits at 0
870 * and changing 1-bits to 0 if the new value for that bit is 0, the effect
871 * is essentially an AND operation. That's also the reason why this function
872 * provides the result of AND between various patterns.
873 *
874 * Below is a list of patterns (and their block length).
875 * Pattern 0 is 05 15 25 35 45 55 65 75 85 95 a5 b5 c5 d5 e5 f5 (16 Bytes)
876 * Pattern 1 is 0a 1a 2a 3a 4a 5a 6a 7a 8a 9a aa ba ca da ea fa (16 Bytes)
877 * Pattern 2 is 50 51 52 53 54 55 56 57 58 59 5a 5b 5c 5d 5e 5f (16 Bytes)
878 * Pattern 3 is a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 aa ab ac ad ae af (16 Bytes)
879 * Pattern 4 is 00 10 20 30 40 50 60 70 80 90 a0 b0 c0 d0 e0 f0 (16 Bytes)
880 * Pattern 5 is 00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f (16 Bytes)
881 * Pattern 6 is 00 (1 Byte)
882 * Pattern 7 is ff (1 Byte)
883 * Patterns 0-7 have a big-endian block number in the last 2 bytes of each 256
884 * byte block.
885 *
886 * Pattern 8 is 00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f 10 11... (256 B)
887 * Pattern 9 is ff fe fd fc fb fa f9 f8 f7 f6 f5 f4 f3 f2 f1 f0 ef ee... (256 B)
888 * Pattern 10 is 00 00 00 01 00 02 00 03 00 04... (128 kB big-endian counter)
889 * Pattern 11 is ff ff ff fe ff fd ff fc ff fb... (128 kB big-endian downwards)
890 * Pattern 12 is 00 (1 Byte)
891 * Pattern 13 is ff (1 Byte)
892 * Patterns 8-13 have no block number.
893 *
894 * Patterns 0-3 are created to detect and efficiently diagnose communication
895 * slips like missed bits or bytes and their repetitive nature gives good visual
896 * cues to the person inspecting the results. In addition, the following holds:
897 * AND Pattern 0/1 == Pattern 4
898 * AND Pattern 2/3 == Pattern 5
899 * AND Pattern 0/1/2/3 == AND Pattern 4/5 == Pattern 6
900 * A weakness of pattern 0-5 is the inability to detect swaps/copies between
901 * any two 16-byte blocks except for the last 16-byte block in a 256-byte bloc.
902 * They work perfectly for detecting any swaps/aliasing of blocks >= 256 bytes.
903 * 0x5 and 0xa were picked because they are 0101 and 1010 binary.
904 * Patterns 8-9 are best for detecting swaps/aliasing of blocks < 256 bytes.
905 * Besides that, they provide for bit testing of the last two bytes of every
906 * 256 byte block which contains the block number for patterns 0-6.
907 * Patterns 10-11 are special purpose for detecting subblock aliasing with
908 * block sizes >256 bytes (some Dataflash chips etc.)
909 * AND Pattern 8/9 == Pattern 12
910 * AND Pattern 10/11 == Pattern 12
911 * Pattern 13 is the completely erased state.
912 * None of the patterns can detect aliasing at boundaries which are a multiple
913 * of 16 MBytes (but such chips do not exist anyway for Parallel/LPC/FWH/SPI).
914 */
915int generate_testpattern(uint8_t *buf, uint32_t size, int variant)
916{
917 int i;
918
919 if (!buf) {
Sean Nelson316a29f2010-05-07 20:09:04 +0000920 msg_gerr("Invalid buffer!\n");
Carl-Daniel Hailfingereaac68b2009-11-23 12:55:31 +0000921 return 1;
922 }
923
924 switch (variant) {
925 case 0:
926 for (i = 0; i < size; i++)
927 buf[i] = (i & 0xf) << 4 | 0x5;
928 break;
929 case 1:
930 for (i = 0; i < size; i++)
931 buf[i] = (i & 0xf) << 4 | 0xa;
932 break;
933 case 2:
934 for (i = 0; i < size; i++)
935 buf[i] = 0x50 | (i & 0xf);
936 break;
937 case 3:
938 for (i = 0; i < size; i++)
939 buf[i] = 0xa0 | (i & 0xf);
940 break;
941 case 4:
942 for (i = 0; i < size; i++)
943 buf[i] = (i & 0xf) << 4;
944 break;
945 case 5:
946 for (i = 0; i < size; i++)
947 buf[i] = i & 0xf;
948 break;
949 case 6:
950 memset(buf, 0x00, size);
951 break;
952 case 7:
953 memset(buf, 0xff, size);
954 break;
955 case 8:
956 for (i = 0; i < size; i++)
957 buf[i] = i & 0xff;
958 break;
959 case 9:
960 for (i = 0; i < size; i++)
961 buf[i] = ~(i & 0xff);
962 break;
963 case 10:
964 for (i = 0; i < size % 2; i++) {
965 buf[i * 2] = (i >> 8) & 0xff;
966 buf[i * 2 + 1] = i & 0xff;
967 }
968 if (size & 0x1)
969 buf[i * 2] = (i >> 8) & 0xff;
970 break;
971 case 11:
972 for (i = 0; i < size % 2; i++) {
973 buf[i * 2] = ~((i >> 8) & 0xff);
974 buf[i * 2 + 1] = ~(i & 0xff);
975 }
976 if (size & 0x1)
977 buf[i * 2] = ~((i >> 8) & 0xff);
978 break;
979 case 12:
980 memset(buf, 0x00, size);
981 break;
982 case 13:
983 memset(buf, 0xff, size);
984 break;
985 }
986
987 if ((variant >= 0) && (variant <= 7)) {
988 /* Write block number in the last two bytes of each 256-byte
989 * block, big endian for easier reading of the hexdump.
990 * Note that this wraps around for chips larger than 2^24 bytes
991 * (16 MB).
992 */
993 for (i = 0; i < size / 256; i++) {
994 buf[i * 256 + 254] = (i >> 8) & 0xff;
995 buf[i * 256 + 255] = i & 0xff;
996 }
997 }
998
999 return 0;
1000}
1001
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001002int check_max_decode(enum chipbustype buses, uint32_t size)
1003{
1004 int limitexceeded = 0;
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001005
1006 if ((buses & BUS_PARALLEL) && (max_rom_decode.parallel < size)) {
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001007 limitexceeded++;
Sean Nelson316a29f2010-05-07 20:09:04 +00001008 msg_pdbg("Chip size %u kB is bigger than supported "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001009 "size %u kB of chipset/board/programmer "
1010 "for %s interface, "
1011 "probe/read/erase/write may fail. ", size / 1024,
1012 max_rom_decode.parallel / 1024, "Parallel");
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001013 }
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +00001014 if ((buses & BUS_LPC) && (max_rom_decode.lpc < size)) {
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001015 limitexceeded++;
Sean Nelson316a29f2010-05-07 20:09:04 +00001016 msg_pdbg("Chip size %u kB is bigger than supported "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001017 "size %u kB of chipset/board/programmer "
1018 "for %s interface, "
1019 "probe/read/erase/write may fail. ", size / 1024,
1020 max_rom_decode.lpc / 1024, "LPC");
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001021 }
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +00001022 if ((buses & BUS_FWH) && (max_rom_decode.fwh < size)) {
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001023 limitexceeded++;
Sean Nelson316a29f2010-05-07 20:09:04 +00001024 msg_pdbg("Chip size %u kB is bigger than supported "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001025 "size %u kB of chipset/board/programmer "
1026 "for %s interface, "
1027 "probe/read/erase/write may fail. ", size / 1024,
1028 max_rom_decode.fwh / 1024, "FWH");
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001029 }
Carl-Daniel Hailfinger1a227952011-07-27 07:13:06 +00001030 if ((buses & BUS_SPI) && (max_rom_decode.spi < size)) {
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001031 limitexceeded++;
Sean Nelson316a29f2010-05-07 20:09:04 +00001032 msg_pdbg("Chip size %u kB is bigger than supported "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001033 "size %u kB of chipset/board/programmer "
1034 "for %s interface, "
1035 "probe/read/erase/write may fail. ", size / 1024,
1036 max_rom_decode.spi / 1024, "SPI");
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001037 }
1038 if (!limitexceeded)
1039 return 0;
1040 /* Sometimes chip and programmer have more than one bus in common,
1041 * and the limit is not exceeded on all buses. Tell the user.
1042 */
1043 if (bitcount(buses) > limitexceeded)
Carl-Daniel Hailfingera84835a2010-01-07 03:24:05 +00001044 /* FIXME: This message is designed towards CLI users. */
Sean Nelson316a29f2010-05-07 20:09:04 +00001045 msg_pdbg("There is at least one common chip/programmer "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001046 "interface which can support a chip of this size. "
1047 "You can try --force at your own risk.\n");
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001048 return 1;
1049}
1050
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001051int probe_flash(struct registered_programmer *pgm, int startchip, struct flashctx *flash, int force)
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001052{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001053 const struct flashchip *chip;
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001054 unsigned long base = 0;
Stefan Reinauer051e2362011-01-19 06:21:54 +00001055 char location[64];
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001056 uint32_t size;
1057 enum chipbustype buses_common;
Carl-Daniel Hailfingerb22918c2009-06-01 02:08:58 +00001058 char *tmp;
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001059
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001060 for (chip = flashchips + startchip; chip && chip->name; chip++) {
1061 if (chip_to_probe && strcmp(chip->name, chip_to_probe) != 0)
Ollie Lhocbbf1252004-03-17 22:22:08 +00001062 continue;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001063 buses_common = pgm->buses_supported & chip->bustype;
Carl-Daniel Hailfingerc40cff72011-12-20 00:19:29 +00001064 if (!buses_common)
Carl-Daniel Hailfinger6573b742011-06-17 22:38:53 +00001065 continue;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001066 msg_gdbg("Probing for %s %s, %d kB: ", chip->vendor, chip->name, chip->total_size);
1067 if (!chip->probe && !force) {
1068 msg_gdbg("failed! flashrom has no probe function for this flash chip.\n");
Carl-Daniel Hailfingerb22918c2009-06-01 02:08:58 +00001069 continue;
1070 }
Stefan Reinauer70385642007-04-06 11:58:03 +00001071
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001072 size = chip->total_size * 1024;
Carl-Daniel Hailfinger115d3902009-10-31 01:53:09 +00001073 check_max_decode(buses_common, size);
Stefan Reinauer70385642007-04-06 11:58:03 +00001074
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001075 /* Start filling in the dynamic data. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001076 flash->chip = calloc(1, sizeof(struct flashchip));
1077 if (!flash->chip) {
1078 msg_gerr("Out of memory!\n");
1079 exit(1);
1080 }
1081 memcpy(flash->chip, chip, sizeof(struct flashchip));
1082 flash->pgm = pgm;
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001083
Carl-Daniel Hailfinger97d6b092009-05-09 07:27:23 +00001084 base = flashbase ? flashbase : (0xffffffff - size + 1);
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001085 flash->virtual_memory = (chipaddr)programmer_map_flash_region("flash chip", base, size);
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001086
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001087 /* We handle a forced match like a real match, we just avoid probing. Note that probe_flash()
1088 * is only called with force=1 after normal probing failed.
1089 */
Peter Stuge27c3e2d2008-07-02 17:15:47 +00001090 if (force)
1091 break;
Stefan Reinauerfcb63682006-03-16 16:57:41 +00001092
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001093 if (flash->chip->probe(flash) != 1)
Peter Stuge483b8f02008-09-03 23:10:05 +00001094 goto notfound;
1095
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001096 /* If this is the first chip found, accept it.
1097 * If this is not the first chip found, accept it only if it is
Stefan Taunerac1b4c82012-02-17 14:51:04 +00001098 * a non-generic match. SFDP and CFI are generic matches.
1099 * startchip==0 means this call to probe_flash() is the first
1100 * one for this programmer interface and thus no other chip has
1101 * been found on this interface.
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001102 */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001103 if (startchip == 0 && flash->chip->model_id == SFDP_DEVICE_ID) {
Stefan Taunerac1b4c82012-02-17 14:51:04 +00001104 msg_cinfo("===\n"
1105 "SFDP has autodetected a flash chip which is "
1106 "not natively supported by flashrom yet.\n");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001107 if (count_usable_erasers(flash) == 0)
Stefan Taunerac1b4c82012-02-17 14:51:04 +00001108 msg_cinfo("The standard operations read and "
1109 "verify should work, but to support "
1110 "erase, write and all other "
1111 "possible features");
1112 else
1113 msg_cinfo("All standard operations (read, "
1114 "verify, erase and write) should "
1115 "work, but to support all possible "
1116 "features");
1117
Stefan Taunerb4e06bd2012-08-20 00:24:22 +00001118 msg_cinfo(" we need to add them manually.\n"
1119 "You can help us by mailing us the output of the following command to "
1120 "flashrom@flashrom.org:\n"
1121 "'flashrom -VV [plus the -p/--programmer parameter]'\n"
1122 "Thanks for your help!\n"
Stefan Taunerac1b4c82012-02-17 14:51:04 +00001123 "===\n");
1124 }
1125
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001126 /* First flash chip detected on this bus. */
1127 if (startchip == 0)
Peter Stuge27c3e2d2008-07-02 17:15:47 +00001128 break;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001129 /* Not the first flash chip detected on this bus, but not a generic match either. */
1130 if ((flash->chip->model_id != GENERIC_DEVICE_ID) && (flash->chip->model_id != SFDP_DEVICE_ID))
1131 break;
1132 /* Not the first flash chip detected on this bus, and it's just a generic match. Ignore it. */
Peter Stuge483b8f02008-09-03 23:10:05 +00001133notfound:
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001134 programmer_unmap_flash_region((void *)flash->virtual_memory, size);
1135 flash->virtual_memory = (chipaddr)NULL;
1136 free(flash->chip);
1137 flash->chip = NULL;
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001138 }
Uwe Hermannffec5f32007-08-23 16:08:21 +00001139
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001140 if (!flash->chip)
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001141 return -1;
Peter Stuge27c3e2d2008-07-02 17:15:47 +00001142
Carl-Daniel Hailfingerd9535582011-03-08 00:09:11 +00001143#if CONFIG_INTERNAL == 1
1144 if (programmer_table[programmer].map_flash_region == physmap)
Stefan Reinauer051e2362011-01-19 06:21:54 +00001145 snprintf(location, sizeof(location), "at physical address 0x%lx", base);
Carl-Daniel Hailfingerd9535582011-03-08 00:09:11 +00001146 else
1147#endif
Stefan Reinauer051e2362011-01-19 06:21:54 +00001148 snprintf(location, sizeof(location), "on %s", programmer_table[programmer].name);
Stefan Reinauer051e2362011-01-19 06:21:54 +00001149
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001150 tmp = flashbuses_to_text(flash->chip->bustype);
1151 msg_cinfo("%s %s flash chip \"%s\" (%d kB, %s) %s.\n", force ? "Assuming" : "Found",
1152 flash->chip->vendor, flash->chip->name, flash->chip->total_size, tmp, location);
Stefan Tauner00155492011-06-26 20:45:35 +00001153 free(tmp);
Uwe Hermann9899cad2009-06-28 21:47:57 +00001154
Carl-Daniel Hailfinger859f3f02010-12-02 21:59:42 +00001155 /* Flash registers will not be mapped if the chip was forced. Lock info
1156 * may be stored in registers, so avoid lock info printing.
1157 */
1158 if (!force)
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001159 if (flash->chip->printlock)
1160 flash->chip->printlock(flash);
Sean Nelson6e0b9122010-02-19 00:52:10 +00001161
Carl-Daniel Hailfinger4c823182011-05-04 00:39:50 +00001162 /* Return position of matching chip. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001163 return chip - flashchips;
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00001164}
1165
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001166int read_buf_from_file(unsigned char *buf, unsigned long size,
1167 const char *filename)
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001168{
Nico Huber7562f7d2013-08-30 21:29:45 +00001169#ifdef __LIBPAYLOAD__
1170 msg_gerr("Error: No file I/O support in libpayload\n");
1171 return 1;
1172#else
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001173 unsigned long numbytes;
1174 FILE *image;
1175 struct stat image_stat;
1176
1177 if ((image = fopen(filename, "rb")) == NULL) {
Stefan Tauner363fd7e2013-04-07 13:08:30 +00001178 msg_gerr("Error: opening file \"%s\" failed: %s\n", filename, strerror(errno));
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001179 return 1;
1180 }
1181 if (fstat(fileno(image), &image_stat) != 0) {
Stefan Tauner363fd7e2013-04-07 13:08:30 +00001182 msg_gerr("Error: getting metadata of file \"%s\" failed: %s\n", filename, strerror(errno));
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001183 fclose(image);
1184 return 1;
1185 }
1186 if (image_stat.st_size != size) {
Carl-Daniel Hailfinger11990da2013-07-13 23:21:05 +00001187 msg_gerr("Error: Image size (%jd B) doesn't match the flash chip's size (%lu B)!\n",
Stefan Taunere038e902013-02-04 04:38:42 +00001188 (intmax_t)image_stat.st_size, size);
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001189 fclose(image);
1190 return 1;
1191 }
1192 numbytes = fread(buf, 1, size, image);
1193 if (fclose(image)) {
Stefan Tauner363fd7e2013-04-07 13:08:30 +00001194 msg_gerr("Error: closing file \"%s\" failed: %s\n", filename, strerror(errno));
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001195 return 1;
1196 }
1197 if (numbytes != size) {
1198 msg_gerr("Error: Failed to read complete file. Got %ld bytes, "
1199 "wanted %ld!\n", numbytes, size);
1200 return 1;
1201 }
1202 return 0;
Nico Huber7562f7d2013-08-30 21:29:45 +00001203#endif
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001204}
1205
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001206int write_buf_to_file(unsigned char *buf, unsigned long size,
1207 const char *filename)
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001208{
Nico Huber7562f7d2013-08-30 21:29:45 +00001209#ifdef __LIBPAYLOAD__
1210 msg_gerr("Error: No file I/O support in libpayload\n");
1211 return 1;
1212#else
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001213 unsigned long numbytes;
1214 FILE *image;
Stephan Guilloux21dd55b2009-06-01 22:07:52 +00001215
1216 if (!filename) {
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001217 msg_gerr("No filename specified.\n");
Stephan Guilloux21dd55b2009-06-01 22:07:52 +00001218 return 1;
1219 }
Patrick Georgi0bf842d2010-01-25 22:55:33 +00001220 if ((image = fopen(filename, "wb")) == NULL) {
Stefan Tauner363fd7e2013-04-07 13:08:30 +00001221 msg_gerr("Error: opening file \"%s\" failed: %s\n", filename, strerror(errno));
Carl-Daniel Hailfinger03b4e712009-05-08 12:49:03 +00001222 return 1;
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001223 }
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001224
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001225 numbytes = fwrite(buf, 1, size, image);
1226 fclose(image);
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001227 if (numbytes != size) {
1228 msg_gerr("File %s could not be written completely.\n",
1229 filename);
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001230 return 1;
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001231 }
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001232 return 0;
Nico Huber7562f7d2013-08-30 21:29:45 +00001233#endif
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001234}
1235
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001236int read_flash_to_file(struct flashctx *flash, const char *filename)
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001237{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001238 unsigned long size = flash->chip->total_size * 1024;
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001239 unsigned char *buf = calloc(size, sizeof(char));
1240 int ret = 0;
1241
1242 msg_cinfo("Reading flash... ");
1243 if (!buf) {
1244 msg_gerr("Memory allocation failed!\n");
1245 msg_cinfo("FAILED.\n");
1246 return 1;
1247 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001248 if (!flash->chip->read) {
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001249 msg_cerr("No read function available for this flash chip.\n");
1250 ret = 1;
1251 goto out_free;
1252 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001253 if (flash->chip->read(flash, buf, 0, size)) {
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001254 msg_cerr("Read operation failed!\n");
1255 ret = 1;
1256 goto out_free;
1257 }
1258
Stefan Tauner355cbfd2011-05-28 02:37:14 +00001259 ret = write_buf_to_file(buf, size, filename);
Carl-Daniel Hailfinger1748c572010-07-13 23:56:13 +00001260out_free:
1261 free(buf);
1262 msg_cinfo("%s.\n", ret ? "FAILED" : "done");
1263 return ret;
1264}
1265
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001266/* This function shares a lot of its structure with erase_and_write_flash() and
1267 * walk_eraseregions().
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001268 * Even if an error is found, the function will keep going and check the rest.
1269 */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001270static int selfcheck_eraseblocks(const struct flashchip *chip)
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001271{
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +00001272 int i, j, k;
1273 int ret = 0;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001274
1275 for (k = 0; k < NUM_ERASEFUNCTIONS; k++) {
1276 unsigned int done = 0;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001277 struct block_eraser eraser = chip->block_erasers[k];
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001278
1279 for (i = 0; i < NUM_ERASEREGIONS; i++) {
1280 /* Blocks with zero size are bugs in flashchips.c. */
1281 if (eraser.eraseblocks[i].count &&
1282 !eraser.eraseblocks[i].size) {
1283 msg_gerr("ERROR: Flash chip %s erase function "
1284 "%i region %i has size 0. Please report"
1285 " a bug at flashrom@flashrom.org\n",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001286 chip->name, k, i);
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001287 ret = 1;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001288 }
1289 /* Blocks with zero count are bugs in flashchips.c. */
1290 if (!eraser.eraseblocks[i].count &&
1291 eraser.eraseblocks[i].size) {
1292 msg_gerr("ERROR: Flash chip %s erase function "
1293 "%i region %i has count 0. Please report"
1294 " a bug at flashrom@flashrom.org\n",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001295 chip->name, k, i);
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001296 ret = 1;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001297 }
1298 done += eraser.eraseblocks[i].count *
1299 eraser.eraseblocks[i].size;
1300 }
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001301 /* Empty eraseblock definition with erase function. */
1302 if (!done && eraser.block_erase)
Sean Nelson316a29f2010-05-07 20:09:04 +00001303 msg_gspew("Strange: Empty eraseblock definition with "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001304 "non-empty erase function. Not an error.\n");
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001305 if (!done)
1306 continue;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001307 if (done != chip->total_size * 1024) {
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001308 msg_gerr("ERROR: Flash chip %s erase function %i "
1309 "region walking resulted in 0x%06x bytes total,"
1310 " expected 0x%06x bytes. Please report a bug at"
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001311 " flashrom@flashrom.org\n", chip->name, k,
1312 done, chip->total_size * 1024);
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001313 ret = 1;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001314 }
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001315 if (!eraser.block_erase)
1316 continue;
1317 /* Check if there are identical erase functions for different
1318 * layouts. That would imply "magic" erase functions. The
1319 * easiest way to check this is with function pointers.
1320 */
Uwe Hermann43959702010-03-13 17:28:29 +00001321 for (j = k + 1; j < NUM_ERASEFUNCTIONS; j++) {
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001322 if (eraser.block_erase ==
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001323 chip->block_erasers[j].block_erase) {
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001324 msg_gerr("ERROR: Flash chip %s erase function "
1325 "%i and %i are identical. Please report"
1326 " a bug at flashrom@flashrom.org\n",
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001327 chip->name, k, j);
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001328 ret = 1;
1329 }
Uwe Hermann43959702010-03-13 17:28:29 +00001330 }
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001331 }
Carl-Daniel Hailfinger415afcf2010-01-19 06:42:46 +00001332 return ret;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001333}
1334
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001335static int erase_and_write_block_helper(struct flashctx *flash,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001336 unsigned int start, unsigned int len,
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001337 uint8_t *curcontents,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001338 uint8_t *newcontents,
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001339 int (*erasefn) (struct flashctx *flash,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001340 unsigned int addr,
1341 unsigned int len))
1342{
Stefan Taunerc69c9c82011-11-23 09:13:48 +00001343 unsigned int starthere = 0, lenhere = 0;
1344 int ret = 0, skip = 1, writecount = 0;
Stefan Tauner50d67aa2013-03-03 23:49:48 +00001345 enum write_granularity gran = flash->chip->gran;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001346
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001347 /* curcontents and newcontents are opaque to walk_eraseregions, and
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001348 * need to be adjusted here to keep the impression of proper abstraction
1349 */
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001350 curcontents += start;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001351 newcontents += start;
1352 msg_cdbg(":");
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001353 if (need_erase(curcontents, newcontents, len, gran)) {
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001354 msg_cdbg("E");
1355 ret = erasefn(flash, start, len);
1356 if (ret)
1357 return ret;
Carl-Daniel Hailfingerb4061f62011-06-26 17:04:16 +00001358 if (check_erased_range(flash, start, len)) {
1359 msg_cerr("ERASE FAILED!\n");
1360 return -1;
1361 }
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001362 /* Erase was successful. Adjust curcontents. */
1363 memset(curcontents, 0xff, len);
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001364 skip = 0;
1365 }
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001366 /* get_next_write() sets starthere to a new value after the call. */
1367 while ((lenhere = get_next_write(curcontents + starthere,
1368 newcontents + starthere,
1369 len - starthere, &starthere, gran))) {
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001370 if (!writecount++)
1371 msg_cdbg("W");
1372 /* Needs the partial write function signature. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001373 ret = flash->chip->write(flash, newcontents + starthere,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001374 start + starthere, lenhere);
1375 if (ret)
1376 return ret;
1377 starthere += lenhere;
1378 skip = 0;
1379 }
1380 if (skip)
1381 msg_cdbg("S");
Stefan Tauner682122b2013-06-23 22:15:39 +00001382 else
1383 all_skipped = false;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001384 return ret;
1385}
1386
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001387static int walk_eraseregions(struct flashctx *flash, int erasefunction,
1388 int (*do_something) (struct flashctx *flash,
Carl-Daniel Hailfinger4d3e9ca2010-07-13 00:42:00 +00001389 unsigned int addr,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001390 unsigned int len,
1391 uint8_t *param1,
1392 uint8_t *param2,
1393 int (*erasefn) (
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001394 struct flashctx *flash,
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001395 unsigned int addr,
1396 unsigned int len)),
1397 void *param1, void *param2)
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001398{
1399 int i, j;
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +00001400 unsigned int start = 0;
1401 unsigned int len;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001402 struct block_eraser eraser = flash->chip->block_erasers[erasefunction];
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001403
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001404 for (i = 0; i < NUM_ERASEREGIONS; i++) {
1405 /* count==0 for all automatically initialized array
1406 * members so the loop below won't be executed for them.
1407 */
1408 len = eraser.eraseblocks[i].size;
1409 for (j = 0; j < eraser.eraseblocks[i].count; j++) {
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001410 /* Print this for every block except the first one. */
1411 if (i || j)
1412 msg_cdbg(", ");
1413 msg_cdbg("0x%06x-0x%06x", start,
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001414 start + len - 1);
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001415 if (do_something(flash, start, len, param1, param2,
1416 eraser.block_erase)) {
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001417 return 1;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001418 }
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001419 start += len;
1420 }
1421 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001422 msg_cdbg("\n");
Carl-Daniel Hailfingera1223412010-07-13 00:37:19 +00001423 return 0;
1424}
1425
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001426static int check_block_eraser(const struct flashctx *flash, int k, int log)
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001427{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001428 struct block_eraser eraser = flash->chip->block_erasers[k];
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001429
1430 if (!eraser.block_erase && !eraser.eraseblocks[0].count) {
1431 if (log)
1432 msg_cdbg("not defined. ");
1433 return 1;
1434 }
1435 if (!eraser.block_erase && eraser.eraseblocks[0].count) {
1436 if (log)
1437 msg_cdbg("eraseblock layout is known, but matching "
Stefan Tauner355cbfd2011-05-28 02:37:14 +00001438 "block erase function is not implemented. ");
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001439 return 1;
1440 }
1441 if (eraser.block_erase && !eraser.eraseblocks[0].count) {
1442 if (log)
1443 msg_cdbg("block erase function found, but "
Stefan Tauner355cbfd2011-05-28 02:37:14 +00001444 "eraseblock layout is not defined. ");
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001445 return 1;
1446 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001447 // TODO: Once erase functions are annotated with allowed buses, check that as well.
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001448 return 0;
1449}
1450
Carl-Daniel Hailfinger63fd9022011-12-14 22:25:15 +00001451int erase_and_write_flash(struct flashctx *flash, uint8_t *oldcontents,
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001452 uint8_t *newcontents)
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001453{
Carl-Daniel Hailfingerd8334db2011-07-21 21:21:04 +00001454 int k, ret = 1;
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001455 uint8_t *curcontents;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001456 unsigned long size = flash->chip->total_size * 1024;
Sylvain "ythier" Hitier9db45512011-07-04 07:27:17 +00001457 unsigned int usable_erasefunctions = count_usable_erasers(flash);
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001458
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001459 msg_cinfo("Erasing and writing flash chip... ");
Stefan Tauner269de352011-07-12 22:35:21 +00001460 curcontents = malloc(size);
1461 if (!curcontents) {
1462 msg_gerr("Out of memory!\n");
1463 exit(1);
1464 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001465 /* Copy oldcontents to curcontents to avoid clobbering oldcontents. */
1466 memcpy(curcontents, oldcontents, size);
1467
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001468 for (k = 0; k < NUM_ERASEFUNCTIONS; k++) {
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001469 if (k != 0)
1470 msg_cdbg("Looking for another erase function.\n");
Carl-Daniel Hailfingerd8334db2011-07-21 21:21:04 +00001471 if (!usable_erasefunctions) {
1472 msg_cdbg("No usable erase functions left.\n");
1473 break;
1474 }
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001475 msg_cdbg("Trying erase function %i... ", k);
1476 if (check_block_eraser(flash, k, 1))
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001477 continue;
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001478 usable_erasefunctions--;
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001479 ret = walk_eraseregions(flash, k, &erase_and_write_block_helper,
1480 curcontents, newcontents);
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001481 /* If everything is OK, don't try another erase function. */
1482 if (!ret)
1483 break;
Carl-Daniel Hailfingerb23b1eb2010-12-02 02:41:55 +00001484 /* Write/erase failed, so try to find out what the current chip
Carl-Daniel Hailfingerd8334db2011-07-21 21:21:04 +00001485 * contents are. If no usable erase functions remain, we can
1486 * skip this: the next iteration will break immediately anyway.
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001487 */
Carl-Daniel Hailfingerdce73ae2010-12-05 15:14:44 +00001488 if (!usable_erasefunctions)
1489 continue;
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001490 /* Reading the whole chip may take a while, inform the user even
1491 * in non-verbose mode.
1492 */
1493 msg_cinfo("Reading current flash chip contents... ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001494 if (flash->chip->read(flash, curcontents, 0, size)) {
Carl-Daniel Hailfingerb23b1eb2010-12-02 02:41:55 +00001495 /* Now we are truly screwed. Read failed as well. */
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001496 msg_cerr("Can't read anymore! Aborting.\n");
Carl-Daniel Hailfingerb23b1eb2010-12-02 02:41:55 +00001497 /* We have no idea about the flash chip contents, so
1498 * retrying with another erase function is pointless.
1499 */
1500 break;
1501 }
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001502 msg_cinfo("done. ");
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001503 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001504 /* Free the scratchpad. */
1505 free(curcontents);
Carl-Daniel Hailfingerf160a122009-05-08 17:15:15 +00001506
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001507 if (ret) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001508 msg_cerr("FAILED!\n");
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001509 } else {
Stefan Tauner682122b2013-06-23 22:15:39 +00001510 if (all_skipped)
1511 msg_cinfo("\nWarning: Chip content is identical to the requested image.\n");
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001512 msg_cinfo("Erase/write done.\n");
Carl-Daniel Hailfingerf38431a2009-09-05 02:30:58 +00001513 }
1514 return ret;
Carl-Daniel Hailfinger7314cc32009-01-28 00:27:54 +00001515}
1516
Stefan Tauner136388f2013-07-15 10:47:53 +00001517static void nonfatal_help_message(void)
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001518{
Stefan Tauner136388f2013-07-15 10:47:53 +00001519 msg_gerr("Writing to the flash chip apparently didn't do anything.\n");
1520#if CONFIG_INTERNAL == 1
1521 if (programmer == PROGRAMMER_INTERNAL)
1522 msg_gerr("This means we have to add special support for your board, programmer or flash\n"
1523 "chip. Please report this on IRC at chat.freenode.net (channel #flashrom) or\n"
1524 "mail flashrom@flashrom.org, thanks!\n"
1525 "-------------------------------------------------------------------------------\n"
1526 "You may now reboot or simply leave the machine running.\n");
1527 else
1528#endif
1529 msg_gerr("Please check the connections (especially those to write protection pins) between\n"
1530 "the programmer and the flash chip. If you think the error is caused by flashrom\n"
1531 "please report this on IRC at chat.freenode.net (channel #flashrom) or\n"
1532 "mail flashrom@flashrom.org, thanks!\n");
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001533}
1534
Stefan Tauner136388f2013-07-15 10:47:53 +00001535static void emergency_help_message(void)
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00001536{
Stefan Tauner136388f2013-07-15 10:47:53 +00001537 msg_gerr("Your flash chip is in an unknown state.\n");
1538#if CONFIG_INTERNAL == 1
1539 if (programmer == PROGRAMMER_INTERNAL)
1540 msg_gerr("Get help on IRC at chat.freenode.net (channel #flashrom) or\n"
1541 "mail flashrom@flashrom.org with the subject \"FAILED: <your board name>\"!\n"
1542 "-------------------------------------------------------------------------------\n"
1543 "DO NOT REBOOT OR POWEROFF!\n");
1544 else
1545#endif
1546 msg_gerr("Please report this on IRC at chat.freenode.net (channel #flashrom) or\n"
1547 "mail flashrom@flashrom.org, thanks!\n");
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00001548}
1549
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001550/* The way to go if you want a delimited list of programmers */
Stefan Tauner66652442011-06-26 17:38:17 +00001551void list_programmers(const char *delim)
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001552{
1553 enum programmer p;
1554 for (p = 0; p < PROGRAMMER_INVALID; p++) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001555 msg_ginfo("%s", programmer_table[p].name);
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001556 if (p < PROGRAMMER_INVALID - 1)
Sean Nelson316a29f2010-05-07 20:09:04 +00001557 msg_ginfo("%s", delim);
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001558 }
Sean Nelson316a29f2010-05-07 20:09:04 +00001559 msg_ginfo("\n");
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001560}
1561
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001562void list_programmers_linebreak(int startcol, int cols, int paren)
1563{
1564 const char *pname;
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +00001565 int pnamelen;
1566 int remaining = 0, firstline = 1;
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001567 enum programmer p;
Carl-Daniel Hailfinger082c8b52011-08-15 19:54:20 +00001568 int i;
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001569
1570 for (p = 0; p < PROGRAMMER_INVALID; p++) {
1571 pname = programmer_table[p].name;
1572 pnamelen = strlen(pname);
1573 if (remaining - pnamelen - 2 < 0) {
1574 if (firstline)
1575 firstline = 0;
1576 else
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001577 msg_ginfo("\n");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001578 for (i = 0; i < startcol; i++)
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001579 msg_ginfo(" ");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001580 remaining = cols - startcol;
1581 } else {
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001582 msg_ginfo(" ");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001583 remaining--;
1584 }
1585 if (paren && (p == 0)) {
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001586 msg_ginfo("(");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001587 remaining--;
1588 }
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001589 msg_ginfo("%s", pname);
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001590 remaining -= pnamelen;
1591 if (p < PROGRAMMER_INVALID - 1) {
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001592 msg_ginfo(",");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001593 remaining--;
1594 } else {
1595 if (paren)
Carl-Daniel Hailfinger901a3ba2012-05-14 22:54:58 +00001596 msg_ginfo(")");
Carl-Daniel Hailfingera73fb492010-10-06 23:48:34 +00001597 }
1598 }
1599}
1600
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001601void print_sysinfo(void)
1602{
Carl-Daniel Hailfinger60d9bd22012-08-09 23:34:41 +00001603#ifdef _WIN32
1604 SYSTEM_INFO si;
1605 OSVERSIONINFOEX osvi;
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001606
Carl-Daniel Hailfinger60d9bd22012-08-09 23:34:41 +00001607 memset(&si, 0, sizeof(SYSTEM_INFO));
1608 memset(&osvi, 0, sizeof(OSVERSIONINFOEX));
1609 msg_ginfo(" on Windows");
1610 /* Tell Windows which version of the structure we want. */
1611 osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFOEX);
1612 if (GetVersionEx((OSVERSIONINFO*) &osvi))
1613 msg_ginfo(" %lu.%lu", osvi.dwMajorVersion, osvi.dwMinorVersion);
1614 else
1615 msg_ginfo(" unknown version");
1616 GetSystemInfo(&si);
1617 switch (si.wProcessorArchitecture) {
1618 case PROCESSOR_ARCHITECTURE_AMD64:
1619 msg_ginfo(" (x86_64)");
1620 break;
1621 case PROCESSOR_ARCHITECTURE_INTEL:
1622 msg_ginfo(" (x86)");
1623 break;
1624 default:
1625 msg_ginfo(" (unknown arch)");
1626 break;
1627 }
1628#elif HAVE_UTSNAME == 1
1629 struct utsname osinfo;
1630
1631 uname(&osinfo);
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001632 msg_ginfo(" on %s %s (%s)", osinfo.sysname, osinfo.release,
1633 osinfo.machine);
1634#else
1635 msg_ginfo(" on unknown machine");
1636#endif
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001637}
1638
1639void print_buildinfo(void)
1640{
1641 msg_gdbg("flashrom was built with");
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001642#if NEED_PCI == 1
1643#ifdef PCILIB_VERSION
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001644 msg_gdbg(" libpci %s,", PCILIB_VERSION);
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001645#else
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001646 msg_gdbg(" unknown PCI library,");
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001647#endif
1648#endif
1649#ifdef __clang__
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001650 msg_gdbg(" LLVM Clang");
Carl-Daniel Hailfingerb51e58e2010-07-17 14:49:30 +00001651#ifdef __clang_version__
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001652 msg_gdbg(" %s,", __clang_version__);
Carl-Daniel Hailfingerb51e58e2010-07-17 14:49:30 +00001653#else
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001654 msg_gdbg(" unknown version (before r102686),");
Carl-Daniel Hailfingerb51e58e2010-07-17 14:49:30 +00001655#endif
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001656#elif defined(__GNUC__)
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001657 msg_gdbg(" GCC");
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001658#ifdef __VERSION__
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001659 msg_gdbg(" %s,", __VERSION__);
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001660#else
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001661 msg_gdbg(" unknown version,");
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001662#endif
1663#else
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001664 msg_gdbg(" unknown compiler,");
Carl-Daniel Hailfingercceafa22010-05-26 01:45:41 +00001665#endif
1666#if defined (__FLASHROM_LITTLE_ENDIAN__)
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001667 msg_gdbg(" little endian");
Carl-Daniel Hailfinger06b9efa2012-08-07 11:59:59 +00001668#elif defined (__FLASHROM_BIG_ENDIAN__)
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001669 msg_gdbg(" big endian");
Carl-Daniel Hailfinger06b9efa2012-08-07 11:59:59 +00001670#else
1671#error Endianness could not be determined
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001672#endif
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001673 msg_gdbg("\n");
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001674}
1675
Bernhard Walle201bde32008-01-21 15:24:22 +00001676void print_version(void)
1677{
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +00001678 msg_ginfo("flashrom v%s", flashrom_version);
Carl-Daniel Hailfinger132e2ec2010-03-27 16:36:40 +00001679 print_sysinfo();
Carl-Daniel Hailfinger1c155482012-06-06 09:17:06 +00001680 msg_ginfo("\n");
Bernhard Walle201bde32008-01-21 15:24:22 +00001681}
1682
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +00001683void print_banner(void)
1684{
1685 msg_ginfo("flashrom is free software, get the source code at "
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001686 "http://www.flashrom.org\n");
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +00001687 msg_ginfo("\n");
1688}
1689
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001690int selfcheck(void)
1691{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001692 const struct flashchip *chip;
Stefan Taunera6d96482012-12-26 19:51:23 +00001693 int i;
1694 int ret = 0;
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001695
1696 /* Safety check. Instead of aborting after the first error, check
1697 * if more errors exist.
1698 */
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001699 if (ARRAY_SIZE(programmer_table) - 1 != PROGRAMMER_INVALID) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001700 msg_gerr("Programmer table miscompilation!\n");
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001701 ret = 1;
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001702 }
Stefan Taunera6d96482012-12-26 19:51:23 +00001703 for (i = 0; i < PROGRAMMER_INVALID; i++) {
1704 const struct programmer_entry p = programmer_table[i];
1705 if (p.name == NULL) {
1706 msg_gerr("All programmers need a valid name, but the one with index %d does not!\n", i);
1707 ret = 1;
1708 /* This might hide other problems with this programmer, but allows for better error
1709 * messages below without jumping through hoops. */
1710 continue;
1711 }
Stefan Tauneraf358d62012-12-27 18:40:26 +00001712 switch (p.type) {
1713 case USB:
1714 case PCI:
1715 case OTHER:
1716 if (p.devs.note == NULL) {
1717 if (strcmp("internal", p.name) == 0)
1718 break; /* This one has its device list stored separately. */
1719 msg_gerr("Programmer %s has neither a device list nor a textual description!\n",
1720 p.name);
1721 ret = 1;
1722 }
1723 break;
1724 default:
1725 msg_gerr("Programmer %s does not have a valid type set!\n", p.name);
1726 ret = 1;
1727 break;
1728 }
Stefan Taunera6d96482012-12-26 19:51:23 +00001729 if (p.init == NULL) {
1730 msg_gerr("Programmer %s does not have a valid init function!\n", p.name);
1731 ret = 1;
1732 }
1733 if (p.delay == NULL) {
1734 msg_gerr("Programmer %s does not have a valid delay function!\n", p.name);
1735 ret = 1;
1736 }
1737 if (p.map_flash_region == NULL) {
1738 msg_gerr("Programmer %s does not have a valid map_flash_region function!\n", p.name);
1739 ret = 1;
1740 }
1741 if (p.unmap_flash_region == NULL) {
1742 msg_gerr("Programmer %s does not have a valid unmap_flash_region function!\n", p.name);
1743 ret = 1;
1744 }
1745 }
Stefan Tauner93f70232011-07-26 14:33:46 +00001746 /* It would be favorable if we could also check for correct termination
Stefan Tauner716e0982011-07-25 20:38:52 +00001747 * of the following arrays, but we don't know their sizes in here...
Stefan Tauner7bcacb12011-05-26 01:35:19 +00001748 * For 'flashchips' we check the first element to be non-null. In the
1749 * other cases there exist use cases where the first element can be
1750 * null. */
1751 if (flashchips == NULL || flashchips[0].vendor == NULL) {
1752 msg_gerr("Flashchips table miscompilation!\n");
1753 ret = 1;
1754 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001755 for (chip = flashchips; chip && chip->name; chip++)
1756 if (selfcheck_eraseblocks(chip))
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001757 ret = 1;
Stefan Tauner7bcacb12011-05-26 01:35:19 +00001758
1759#if CONFIG_INTERNAL == 1
1760 if (chipset_enables == NULL) {
1761 msg_gerr("Chipset enables table does not exist!\n");
1762 ret = 1;
1763 }
Carl-Daniel Hailfinger97d5b122011-08-31 16:19:50 +00001764 if (board_matches == NULL) {
Stefan Tauner7bcacb12011-05-26 01:35:19 +00001765 msg_gerr("Board enables table does not exist!\n");
1766 ret = 1;
1767 }
1768 if (boards_known == NULL) {
1769 msg_gerr("Known boards table does not exist!\n");
1770 ret = 1;
1771 }
1772 if (laptops_known == NULL) {
1773 msg_gerr("Known laptops table does not exist!\n");
1774 ret = 1;
1775 }
Uwe Hermann91f4afa2011-07-28 08:13:25 +00001776#endif
Carl-Daniel Hailfinger293adf02010-01-18 08:14:43 +00001777 return ret;
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001778}
1779
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001780void check_chip_supported(const struct flashchip *chip)
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001781{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001782 if (chip->feature_bits & FEATURE_OTP) {
Daniel Lenski65922a32012-02-15 23:40:23 +00001783 msg_cdbg("This chip may contain one-time programmable memory. "
1784 "flashrom cannot read\nand may never be able to write "
1785 "it, hence it may not be able to completely\n"
1786 "clone the contents of this chip (see man page for "
1787 "details).\n");
1788 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001789 if (TEST_OK_MASK != (chip->tested & TEST_OK_MASK)) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001790 msg_cinfo("===\n");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001791 if (chip->tested & TEST_BAD_MASK) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001792 msg_cinfo("This flash part has status NOT WORKING for operations:");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001793 if (chip->tested & TEST_BAD_PROBE)
Sean Nelson316a29f2010-05-07 20:09:04 +00001794 msg_cinfo(" PROBE");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001795 if (chip->tested & TEST_BAD_READ)
Sean Nelson316a29f2010-05-07 20:09:04 +00001796 msg_cinfo(" READ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001797 if (chip->tested & TEST_BAD_ERASE)
Sean Nelson316a29f2010-05-07 20:09:04 +00001798 msg_cinfo(" ERASE");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001799 if (chip->tested & TEST_BAD_WRITE)
Sean Nelson316a29f2010-05-07 20:09:04 +00001800 msg_cinfo(" WRITE");
1801 msg_cinfo("\n");
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001802 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001803 if ((!(chip->tested & TEST_BAD_PROBE) && !(chip->tested & TEST_OK_PROBE)) ||
1804 (!(chip->tested & TEST_BAD_READ) && !(chip->tested & TEST_OK_READ)) ||
1805 (!(chip->tested & TEST_BAD_ERASE) && !(chip->tested & TEST_OK_ERASE)) ||
1806 (!(chip->tested & TEST_BAD_WRITE) && !(chip->tested & TEST_OK_WRITE))) {
Sean Nelson316a29f2010-05-07 20:09:04 +00001807 msg_cinfo("This flash part has status UNTESTED for operations:");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001808 if (!(chip->tested & TEST_BAD_PROBE) && !(chip->tested & TEST_OK_PROBE))
Sean Nelson316a29f2010-05-07 20:09:04 +00001809 msg_cinfo(" PROBE");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001810 if (!(chip->tested & TEST_BAD_READ) && !(chip->tested & TEST_OK_READ))
Sean Nelson316a29f2010-05-07 20:09:04 +00001811 msg_cinfo(" READ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001812 if (!(chip->tested & TEST_BAD_ERASE) && !(chip->tested & TEST_OK_ERASE))
Sean Nelson316a29f2010-05-07 20:09:04 +00001813 msg_cinfo(" ERASE");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001814 if (!(chip->tested & TEST_BAD_WRITE) && !(chip->tested & TEST_OK_WRITE))
Sean Nelson316a29f2010-05-07 20:09:04 +00001815 msg_cinfo(" WRITE");
1816 msg_cinfo("\n");
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001817 }
Carl-Daniel Hailfingera84835a2010-01-07 03:24:05 +00001818 /* FIXME: This message is designed towards CLI users. */
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +00001819 msg_cinfo("The test status of this chip may have been updated "
1820 "in the latest development\n"
1821 "version of flashrom. If you are running the latest "
1822 "development version,\n"
1823 "please email a report to flashrom@flashrom.org if "
1824 "any of the above operations\n"
1825 "work correctly for you with this flash part. Please "
1826 "include the flashrom\n"
1827 "output with the additional -V option for all "
1828 "operations you tested (-V, -Vr,\n"
Paul Menzele3800132012-01-12 13:58:43 +00001829 "-VE, -Vw), and mention which mainboard or "
Carl-Daniel Hailfinger8841d3e2010-05-15 15:04:37 +00001830 "programmer you tested.\n"
Paul Menzelab6328f2010-10-08 11:03:02 +00001831 "Please mention your board in the subject line. "
1832 "Thanks for your help!\n");
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001833 }
1834}
1835
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001836/* FIXME: This function signature needs to be improved once doit() has a better
1837 * function signature.
1838 */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001839int chip_safety_check(const struct flashctx *flash, int force, int read_it, int write_it, int erase_it,
1840 int verify_it)
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001841{
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001842 const struct flashchip *chip = flash->chip;
1843
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001844 if (!programmer_may_write && (write_it || erase_it)) {
1845 msg_perr("Write/erase is not working yet on your programmer in "
1846 "its current configuration.\n");
1847 /* --force is the wrong approach, but it's the best we can do
1848 * until the generic programmer parameter parser is merged.
1849 */
1850 if (!force)
1851 return 1;
1852 msg_cerr("Continuing anyway.\n");
1853 }
1854
1855 if (read_it || erase_it || write_it || verify_it) {
1856 /* Everything needs read. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001857 if (chip->tested & TEST_BAD_READ) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001858 msg_cerr("Read is not working on this chip. ");
1859 if (!force)
1860 return 1;
1861 msg_cerr("Continuing anyway.\n");
1862 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001863 if (!chip->read) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001864 msg_cerr("flashrom has no read function for this "
1865 "flash chip.\n");
1866 return 1;
1867 }
1868 }
1869 if (erase_it || write_it) {
1870 /* Write needs erase. */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001871 if (chip->tested & TEST_BAD_ERASE) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001872 msg_cerr("Erase is not working on this chip. ");
1873 if (!force)
1874 return 1;
1875 msg_cerr("Continuing anyway.\n");
1876 }
Sylvain "ythier" Hitier9db45512011-07-04 07:27:17 +00001877 if(count_usable_erasers(flash) == 0) {
Stefan Tauner5368dca2011-07-01 00:19:12 +00001878 msg_cerr("flashrom has no erase function for this "
1879 "flash chip.\n");
1880 return 1;
1881 }
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001882 }
1883 if (write_it) {
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001884 if (chip->tested & TEST_BAD_WRITE) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001885 msg_cerr("Write is not working on this chip. ");
1886 if (!force)
1887 return 1;
1888 msg_cerr("Continuing anyway.\n");
1889 }
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001890 if (!chip->write) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001891 msg_cerr("flashrom has no write function for this "
1892 "flash chip.\n");
1893 return 1;
1894 }
1895 }
1896 return 0;
1897}
1898
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001899/* This function signature is horrible. We need to design a better interface,
1900 * but right now it allows us to split off the CLI code.
Carl-Daniel Hailfingerf52f7842010-10-08 18:52:29 +00001901 * Besides that, the function itself is a textbook example of abysmal code flow.
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001902 */
Carl-Daniel Hailfinger8a3c60c2011-12-18 15:01:24 +00001903int doit(struct flashctx *flash, int force, const char *filename, int read_it,
1904 int write_it, int erase_it, int verify_it)
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001905{
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001906 uint8_t *oldcontents;
1907 uint8_t *newcontents;
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001908 int ret = 0;
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001909 unsigned long size = flash->chip->total_size * 1024;
Carl-Daniel Hailfinger552420b2009-12-24 02:15:55 +00001910
David Hendricks77f931a2011-05-18 01:30:56 +00001911 if (chip_safety_check(flash, force, read_it, write_it, erase_it, verify_it)) {
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001912 msg_cerr("Aborting.\n");
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001913 ret = 1;
1914 goto out_nofree;
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001915 }
1916
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001917 /* Given the existence of read locks, we want to unlock for read,
1918 * erase and write.
1919 */
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001920 if (flash->chip->unlock)
1921 flash->chip->unlock(flash);
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001922
1923 if (read_it) {
1924 ret = read_flash_to_file(flash, filename);
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001925 goto out_nofree;
Carl-Daniel Hailfingerd1be52d2010-07-03 12:14:25 +00001926 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001927
Stefan Tauner269de352011-07-12 22:35:21 +00001928 oldcontents = malloc(size);
1929 if (!oldcontents) {
1930 msg_gerr("Out of memory!\n");
1931 exit(1);
1932 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001933 /* Assume worst case: All bits are 0. */
1934 memset(oldcontents, 0x00, size);
Stefan Tauner269de352011-07-12 22:35:21 +00001935 newcontents = malloc(size);
1936 if (!newcontents) {
1937 msg_gerr("Out of memory!\n");
1938 exit(1);
1939 }
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001940 /* Assume best case: All bits should be 1. */
1941 memset(newcontents, 0xff, size);
1942 /* Side effect of the assumptions above: Default write action is erase
1943 * because newcontents looks like a completely erased chip, and
1944 * oldcontents being completely 0x00 means we have to erase everything
1945 * before we can write.
1946 */
1947
Ollie Lhoefa28582004-12-08 20:10:01 +00001948 if (erase_it) {
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001949 /* FIXME: Do we really want the scary warning if erase failed?
1950 * After all, after erase the chip is either blank or partially
1951 * blank or it has the old contents. A blank chip won't boot,
1952 * so if the user wanted erase and reboots afterwards, the user
1953 * knows very well that booting won't work.
1954 */
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001955 if (erase_and_write_flash(flash, oldcontents, newcontents)) {
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00001956 emergency_help_message();
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00001957 ret = 1;
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00001958 }
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001959 goto out;
Carl-Daniel Hailfingerf52f7842010-10-08 18:52:29 +00001960 }
Carl-Daniel Hailfinger43069442010-10-15 00:01:14 +00001961
Carl-Daniel Hailfingerf52f7842010-10-08 18:52:29 +00001962 if (write_it || verify_it) {
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001963 if (read_buf_from_file(newcontents, size, filename)) {
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001964 ret = 1;
1965 goto out;
Stefan Reinauer018aca82006-11-21 23:48:51 +00001966 }
1967
Carl-Daniel Hailfinger71127722010-05-31 15:27:27 +00001968#if CONFIG_INTERNAL == 1
Stefan Taunerb4e06bd2012-08-20 00:24:22 +00001969 if (programmer == PROGRAMMER_INTERNAL && cb_check_image(newcontents, size) < 0) {
1970 if (force_boardmismatch) {
1971 msg_pinfo("Proceeding anyway because user forced us to.\n");
1972 } else {
1973 msg_perr("Aborting. You can override this with "
1974 "-p internal:boardmismatch=force.\n");
Niklas Söderlund9e423762012-06-16 00:11:16 +00001975 ret = 1;
1976 goto out;
1977 }
Stefan Taunerb4e06bd2012-08-20 00:24:22 +00001978 }
Carl-Daniel Hailfinger66ef4e52009-12-13 22:28:00 +00001979#endif
Ollie Lhocbbf1252004-03-17 22:22:08 +00001980 }
1981
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001982 /* Read the whole chip to be able to check whether regions need to be
1983 * erased and to give better diagnostics in case write fails.
1984 * The alternative would be to read only the regions which are to be
1985 * preserved, but in that case we might perform unneeded erase which
1986 * takes time as well.
1987 */
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001988 msg_cinfo("Reading old flash chip contents... ");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00001989 if (flash->chip->read(flash, oldcontents, 0, size)) {
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001990 ret = 1;
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001991 msg_cinfo("FAILED.\n");
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00001992 goto out;
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001993 }
Carl-Daniel Hailfinger84d19682011-07-26 14:28:35 +00001994 msg_cinfo("done.\n");
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001995
Ollie Lho184a4042005-11-26 21:55:36 +00001996 // This should be moved into each flash part's code to do it
1997 // cleanly. This does the job.
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00001998 handle_romentries(flash, oldcontents, newcontents);
Uwe Hermanna7e05482007-05-09 10:17:44 +00001999
Ollie Lho184a4042005-11-26 21:55:36 +00002000 // ////////////////////////////////////////////////////////////
Uwe Hermanna7e05482007-05-09 10:17:44 +00002001
Peter Stugef31104c2008-04-28 14:47:30 +00002002 if (write_it) {
Carl-Daniel Hailfinger6e2ea322010-11-04 01:04:27 +00002003 if (erase_and_write_flash(flash, oldcontents, newcontents)) {
2004 msg_cerr("Uh oh. Erase/write failed. Checking if "
2005 "anything changed.\n");
Carl-Daniel Hailfinger5a7cb842012-08-25 01:17:58 +00002006 if (!flash->chip->read(flash, newcontents, 0, size)) {
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00002007 if (!memcmp(oldcontents, newcontents, size)) {
Stefan Tauner136388f2013-07-15 10:47:53 +00002008 msg_cinfo("Good. It seems nothing was changed.\n");
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00002009 nonfatal_help_message();
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00002010 ret = 1;
2011 goto out;
Carl-Daniel Hailfinger42d38a92010-10-19 22:06:20 +00002012 }
2013 }
Carl-Daniel Hailfingerf52f7842010-10-08 18:52:29 +00002014 emergency_help_message();
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00002015 ret = 1;
2016 goto out;
Peter Stugef31104c2008-04-28 14:47:30 +00002017 }
Peter Stugef31104c2008-04-28 14:47:30 +00002018 }
Ollie Lho184a4042005-11-26 21:55:36 +00002019
Stefan Taunerc4f44df2013-08-12 22:58:43 +00002020 /* Verify only if we either did not try to write (verify operation) or actually changed something. */
2021 if (verify_it && (!write_it || !all_skipped)) {
Stefan Tauner78ffbea2012-10-27 15:36:56 +00002022 msg_cinfo("Verifying flash... ");
2023
2024 if (write_it) {
2025 /* Work around chips which need some time to calm down. */
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00002026 programmer_delay(1000*1000);
Stefan Tauner78ffbea2012-10-27 15:36:56 +00002027 ret = verify_range(flash, newcontents, 0, size);
2028 /* If we tried to write, and verification now fails, we
2029 * might have an emergency situation.
2030 */
2031 if (ret)
2032 emergency_help_message();
2033 } else {
2034 ret = compare_range(newcontents, oldcontents, 0, size);
2035 }
2036 if (!ret)
2037 msg_cinfo("VERIFIED.\n");
Carl-Daniel Hailfinger8ab49e72009-08-19 13:55:34 +00002038 }
Ollie Lho184a4042005-11-26 21:55:36 +00002039
Carl-Daniel Hailfinger12d6d822010-11-05 14:51:59 +00002040out:
2041 free(oldcontents);
2042 free(newcontents);
2043out_nofree:
Carl-Daniel Hailfinger702218d2009-05-08 17:43:22 +00002044 programmer_shutdown();
Stefan Reinauer143da0b2006-01-04 16:42:57 +00002045 return ret;
Ronald G. Minnichf4cf2ba2002-01-29 18:26:26 +00002046}