memory_bus: Pass master instead of flash to .chip_read/write
There is / should be no need to know flash-chip details in a programmer
driver. They should only pass data around and leave the chip details to
each chip driver.
This will allow us to probe for chips before knowing the details and as
a bonus gets rid of many `flash.h` dependencies.
Change-Id: Iae78fbbd95567134da890613114999cb14c3a011
Signed-off-by: Nico Huber <nico.h@gmx.de>
Reviewed-on: https://review.sourcearcade.org/c/flashprog/+/437
diff --git a/drkaiser.c b/drkaiser.c
index 5634b3a..a7fc84b 100644
--- a/drkaiser.c
+++ b/drkaiser.c
@@ -15,7 +15,6 @@
*/
#include <stdlib.h>
-#include "flash.h"
#include "programmer.h"
#include "hwaccess_physmap.h"
#include "platform/pci.h"
@@ -38,10 +37,8 @@
static uint8_t *drkaiser_bar;
-static void drkaiser_chip_writeb(const struct flashctx *flash, uint8_t val,
- chipaddr addr);
-static uint8_t drkaiser_chip_readb(const struct flashctx *flash,
- const chipaddr addr);
+static void drkaiser_chip_writeb(const struct par_master *, uint8_t val, chipaddr);
+static uint8_t drkaiser_chip_readb(const struct par_master *, chipaddr);
static const struct par_master par_master_drkaiser = {
.chip_readb = drkaiser_chip_readb,
.chip_readw = fallback_chip_readw,
@@ -77,14 +74,12 @@
return register_par_master(&par_master_drkaiser, BUS_PARALLEL, 0, 128*KiB, NULL);
}
-static void drkaiser_chip_writeb(const struct flashctx *flash, uint8_t val,
- chipaddr addr)
+static void drkaiser_chip_writeb(const struct par_master *par, uint8_t val, chipaddr addr)
{
pci_mmio_writeb(val, drkaiser_bar + (addr & DRKAISER_MEMMAP_MASK));
}
-static uint8_t drkaiser_chip_readb(const struct flashctx *flash,
- const chipaddr addr)
+static uint8_t drkaiser_chip_readb(const struct par_master *par, const chipaddr addr)
{
return pci_mmio_readb(drkaiser_bar + (addr & DRKAISER_MEMMAP_MASK));
}