1*0d6140beSAndroid Build Coastguard Worker /*
2*0d6140beSAndroid Build Coastguard Worker * This file is part of the flashrom project.
3*0d6140beSAndroid Build Coastguard Worker *
4*0d6140beSAndroid Build Coastguard Worker * Copyright (C) 2009 Carl-Daniel Hailfinger
5*0d6140beSAndroid Build Coastguard Worker *
6*0d6140beSAndroid Build Coastguard Worker * This program is free software; you can redistribute it and/or modify
7*0d6140beSAndroid Build Coastguard Worker * it under the terms of the GNU General Public License as published by
8*0d6140beSAndroid Build Coastguard Worker * the Free Software Foundation; either version 2 of the License, or
9*0d6140beSAndroid Build Coastguard Worker * (at your option) any later version.
10*0d6140beSAndroid Build Coastguard Worker *
11*0d6140beSAndroid Build Coastguard Worker * This program is distributed in the hope that it will be useful,
12*0d6140beSAndroid Build Coastguard Worker * but WITHOUT ANY WARRANTY; without even the implied warranty of
13*0d6140beSAndroid Build Coastguard Worker * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14*0d6140beSAndroid Build Coastguard Worker * GNU General Public License for more details.
15*0d6140beSAndroid Build Coastguard Worker */
16*0d6140beSAndroid Build Coastguard Worker
17*0d6140beSAndroid Build Coastguard Worker #include "programmer.h"
18*0d6140beSAndroid Build Coastguard Worker #include "hwaccess_physmap.h"
19*0d6140beSAndroid Build Coastguard Worker
internal_chip_writeb(const struct flashctx * flash,uint8_t val,chipaddr addr)20*0d6140beSAndroid Build Coastguard Worker static void internal_chip_writeb(const struct flashctx *flash, uint8_t val,
21*0d6140beSAndroid Build Coastguard Worker chipaddr addr)
22*0d6140beSAndroid Build Coastguard Worker {
23*0d6140beSAndroid Build Coastguard Worker mmio_writeb(val, (void *) addr);
24*0d6140beSAndroid Build Coastguard Worker }
25*0d6140beSAndroid Build Coastguard Worker
internal_chip_writew(const struct flashctx * flash,uint16_t val,chipaddr addr)26*0d6140beSAndroid Build Coastguard Worker static void internal_chip_writew(const struct flashctx *flash, uint16_t val,
27*0d6140beSAndroid Build Coastguard Worker chipaddr addr)
28*0d6140beSAndroid Build Coastguard Worker {
29*0d6140beSAndroid Build Coastguard Worker mmio_writew(val, (void *) addr);
30*0d6140beSAndroid Build Coastguard Worker }
31*0d6140beSAndroid Build Coastguard Worker
internal_chip_writel(const struct flashctx * flash,uint32_t val,chipaddr addr)32*0d6140beSAndroid Build Coastguard Worker static void internal_chip_writel(const struct flashctx *flash, uint32_t val,
33*0d6140beSAndroid Build Coastguard Worker chipaddr addr)
34*0d6140beSAndroid Build Coastguard Worker {
35*0d6140beSAndroid Build Coastguard Worker mmio_writel(val, (void *) addr);
36*0d6140beSAndroid Build Coastguard Worker }
37*0d6140beSAndroid Build Coastguard Worker
internal_chip_readb(const struct flashctx * flash,const chipaddr addr)38*0d6140beSAndroid Build Coastguard Worker static uint8_t internal_chip_readb(const struct flashctx *flash,
39*0d6140beSAndroid Build Coastguard Worker const chipaddr addr)
40*0d6140beSAndroid Build Coastguard Worker {
41*0d6140beSAndroid Build Coastguard Worker return mmio_readb((void *) addr);
42*0d6140beSAndroid Build Coastguard Worker }
43*0d6140beSAndroid Build Coastguard Worker
internal_chip_readw(const struct flashctx * flash,const chipaddr addr)44*0d6140beSAndroid Build Coastguard Worker static uint16_t internal_chip_readw(const struct flashctx *flash,
45*0d6140beSAndroid Build Coastguard Worker const chipaddr addr)
46*0d6140beSAndroid Build Coastguard Worker {
47*0d6140beSAndroid Build Coastguard Worker return mmio_readw((void *) addr);
48*0d6140beSAndroid Build Coastguard Worker }
49*0d6140beSAndroid Build Coastguard Worker
internal_chip_readl(const struct flashctx * flash,const chipaddr addr)50*0d6140beSAndroid Build Coastguard Worker static uint32_t internal_chip_readl(const struct flashctx *flash,
51*0d6140beSAndroid Build Coastguard Worker const chipaddr addr)
52*0d6140beSAndroid Build Coastguard Worker {
53*0d6140beSAndroid Build Coastguard Worker return mmio_readl((void *) addr);
54*0d6140beSAndroid Build Coastguard Worker }
55*0d6140beSAndroid Build Coastguard Worker
internal_chip_readn(const struct flashctx * flash,uint8_t * buf,const chipaddr addr,size_t len)56*0d6140beSAndroid Build Coastguard Worker static void internal_chip_readn(const struct flashctx *flash, uint8_t *buf,
57*0d6140beSAndroid Build Coastguard Worker const chipaddr addr, size_t len)
58*0d6140beSAndroid Build Coastguard Worker {
59*0d6140beSAndroid Build Coastguard Worker mmio_readn((void *)addr, buf, len);
60*0d6140beSAndroid Build Coastguard Worker return;
61*0d6140beSAndroid Build Coastguard Worker }
62*0d6140beSAndroid Build Coastguard Worker
63*0d6140beSAndroid Build Coastguard Worker static const struct par_master par_master_internal = {
64*0d6140beSAndroid Build Coastguard Worker .map_flash_region = physmap,
65*0d6140beSAndroid Build Coastguard Worker .unmap_flash_region = physunmap,
66*0d6140beSAndroid Build Coastguard Worker .chip_readb = internal_chip_readb,
67*0d6140beSAndroid Build Coastguard Worker .chip_readw = internal_chip_readw,
68*0d6140beSAndroid Build Coastguard Worker .chip_readl = internal_chip_readl,
69*0d6140beSAndroid Build Coastguard Worker .chip_readn = internal_chip_readn,
70*0d6140beSAndroid Build Coastguard Worker .chip_writeb = internal_chip_writeb,
71*0d6140beSAndroid Build Coastguard Worker .chip_writew = internal_chip_writew,
72*0d6140beSAndroid Build Coastguard Worker .chip_writel = internal_chip_writel,
73*0d6140beSAndroid Build Coastguard Worker };
74*0d6140beSAndroid Build Coastguard Worker
internal_par_init(enum chipbustype buses)75*0d6140beSAndroid Build Coastguard Worker void internal_par_init(enum chipbustype buses)
76*0d6140beSAndroid Build Coastguard Worker {
77*0d6140beSAndroid Build Coastguard Worker if (buses & BUS_NONSPI)
78*0d6140beSAndroid Build Coastguard Worker register_par_master(&par_master_internal, internal_buses_supported, NULL);
79*0d6140beSAndroid Build Coastguard Worker }
80