blob: b543222cc47834b331b46be634029a635ac97b84 [file] [log] [blame]
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2009 Carl-Daniel Hailfinger
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000021#include <string.h>
22#include <stdlib.h>
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000023#include <ctype.h>
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000024#include <sys/types.h>
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000025#include "flash.h"
Carl-Daniel Hailfinger1b0ba892010-06-20 10:58:32 +000026#include "chipdrivers.h"
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000027
28int dummy_init(void)
29{
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000030 int i;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000031 msg_pspew("%s\n", __func__);
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000032
33 /* "all" is equivalent to specifying no type. */
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000034 if (programmer_param && (!strcmp(programmer_param, "all"))) {
35 free(programmer_param);
36 programmer_param = NULL;
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000037 }
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000038 if (!programmer_param)
39 programmer_param = strdup("parallel,lpc,fwh,spi");
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000040 /* Convert the parameters to lowercase. */
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000041 for (i = 0; programmer_param[i] != '\0'; i++)
Jonathan A. Kollaschd8dfc442010-02-16 00:49:50 +000042 programmer_param[i] =
43 (char)tolower((unsigned char)programmer_param[i]);
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000044
45 buses_supported = CHIP_BUSTYPE_NONE;
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000046 if (strstr(programmer_param, "parallel")) {
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000047 buses_supported |= CHIP_BUSTYPE_PARALLEL;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000048 msg_pdbg("Enabling support for %s flash.\n", "parallel");
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000049 }
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000050 if (strstr(programmer_param, "lpc")) {
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000051 buses_supported |= CHIP_BUSTYPE_LPC;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000052 msg_pdbg("Enabling support for %s flash.\n", "LPC");
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000053 }
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000054 if (strstr(programmer_param, "fwh")) {
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000055 buses_supported |= CHIP_BUSTYPE_FWH;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000056 msg_pdbg("Enabling support for %s flash.\n", "FWH");
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000057 }
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000058 if (strstr(programmer_param, "spi")) {
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000059 buses_supported |= CHIP_BUSTYPE_SPI;
60 spi_controller = SPI_CONTROLLER_DUMMY;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000061 msg_pdbg("Enabling support for %s flash.\n", "SPI");
Carl-Daniel Hailfinger3504b532009-06-01 00:02:11 +000062 }
63 if (buses_supported == CHIP_BUSTYPE_NONE)
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000064 msg_pdbg("Support for all flash bus types disabled.\n");
Carl-Daniel Hailfingeref58a9c2009-08-12 13:32:56 +000065 free(programmer_param);
Uwe Hermanne9d04d42009-06-02 19:54:22 +000066 return 0;
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000067}
68
69int dummy_shutdown(void)
70{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000071 msg_pspew("%s\n", __func__);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000072 return 0;
73}
74
Carl-Daniel Hailfinger1455b2b2009-05-11 14:13:25 +000075void *dummy_map(const char *descr, unsigned long phys_addr, size_t len)
76{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000077 msg_pspew("%s: Mapping %s, 0x%lx bytes at 0x%08lx\n",
78 __func__, descr, (unsigned long)len, phys_addr);
Carl-Daniel Hailfinger1455b2b2009-05-11 14:13:25 +000079 return (void *)phys_addr;
80}
81
82void dummy_unmap(void *virt_addr, size_t len)
83{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000084 msg_pspew("%s: Unmapping 0x%lx bytes at %p\n",
85 __func__, (unsigned long)len, virt_addr);
Carl-Daniel Hailfinger1455b2b2009-05-11 14:13:25 +000086}
87
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +000088void dummy_chip_writeb(uint8_t val, chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000089{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000090 msg_pspew("%s: addr=0x%lx, val=0x%02x\n", __func__, addr, val);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000091}
92
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +000093void dummy_chip_writew(uint16_t val, chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000094{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +000095 msg_pspew("%s: addr=0x%lx, val=0x%04x\n", __func__, addr, val);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000096}
97
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +000098void dummy_chip_writel(uint32_t val, chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +000099{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000100 msg_pspew("%s: addr=0x%lx, val=0x%08x\n", __func__, addr, val);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000101}
102
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000103void dummy_chip_writen(uint8_t *buf, chipaddr addr, size_t len)
104{
105 size_t i;
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000106 msg_pspew("%s: addr=0x%lx, len=0x%08lx, writing data (hex):",
107 __func__, addr, (unsigned long)len);
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000108 for (i = 0; i < len; i++) {
109 if ((i % 16) == 0)
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000110 msg_pspew("\n");
111 msg_pspew("%02x ", buf[i]);
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000112 }
113}
114
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +0000115uint8_t dummy_chip_readb(const chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000116{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000117 msg_pspew("%s: addr=0x%lx, returning 0xff\n", __func__, addr);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000118 return 0xff;
119}
120
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +0000121uint16_t dummy_chip_readw(const chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000122{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000123 msg_pspew("%s: addr=0x%lx, returning 0xffff\n", __func__, addr);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000124 return 0xffff;
125}
126
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +0000127uint32_t dummy_chip_readl(const chipaddr addr)
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000128{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000129 msg_pspew("%s: addr=0x%lx, returning 0xffffffff\n", __func__, addr);
Carl-Daniel Hailfingerc3129202009-05-09 00:54:55 +0000130 return 0xffffffff;
131}
132
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000133void dummy_chip_readn(uint8_t *buf, const chipaddr addr, size_t len)
134{
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000135 msg_pspew("%s: addr=0x%lx, len=0x%lx, returning array of 0xff\n",
136 __func__, addr, (unsigned long)len);
Carl-Daniel Hailfinger0bd2a2b2009-06-05 18:32:07 +0000137 memset(buf, 0xff, len);
138 return;
139}
140
Carl-Daniel Hailfingerd0478292009-07-10 21:08:55 +0000141int dummy_spi_send_command(unsigned int writecnt, unsigned int readcnt,
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000142 const unsigned char *writearr, unsigned char *readarr)
143{
144 int i;
145
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000146 msg_pspew("%s:", __func__);
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000147
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000148 msg_pspew(" writing %u bytes:", writecnt);
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000149 for (i = 0; i < writecnt; i++)
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000150 msg_pspew(" 0x%02x", writearr[i]);
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000151
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000152 msg_pspew(" reading %u bytes:", readcnt);
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000153 for (i = 0; i < readcnt; i++) {
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000154 msg_pspew(" 0xff");
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000155 readarr[i] = 0xff;
156 }
157
Carl-Daniel Hailfinger3ac101c2010-01-09 04:32:23 +0000158 msg_pspew("\n");
Carl-Daniel Hailfingerbfe2e0c2009-05-14 12:59:36 +0000159 return 0;
160}
Carl-Daniel Hailfinger1b0ba892010-06-20 10:58:32 +0000161
162int dummy_spi_read(struct flashchip *flash, uint8_t *buf, int start, int len)
163{
164 /* Maximum read length is unlimited, use 64kB. */
165 return spi_read_chunked(flash, buf, start, len, 64 * 1024);
166}
167