summaryrefslogtreecommitdiffstatshomepage
path: root/drivers/memory
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2017-08-29 11:37:18 +1000
committerDamien George <damien.p.george@gmail.com>2017-08-29 11:37:18 +1000
commit613510bce83b8318bd21bcd17f247ba30e0d7cea (patch)
treeb1081fce54b9f4e306edeb1159fad0889b5b09a4 /drivers/memory
parentd5336ba13637bdf07721d02c1095304bf32224ee (diff)
downloadmicropython-613510bce83b8318bd21bcd17f247ba30e0d7cea.tar.gz
micropython-613510bce83b8318bd21bcd17f247ba30e0d7cea.zip
drivers/memory/spiflash: Change from hard-coded soft SPI to generic SPI.
The SPI flash driver now supports using an arbitrary SPI object to communicate with the flash chip, and in particular can use a hardware SPI peripheral.
Diffstat (limited to 'drivers/memory')
-rw-r--r--drivers/memory/spiflash.c9
-rw-r--r--drivers/memory/spiflash.h3
2 files changed, 5 insertions, 7 deletions
diff --git a/drivers/memory/spiflash.c b/drivers/memory/spiflash.c
index 214610e0a2..08564d0540 100644
--- a/drivers/memory/spiflash.c
+++ b/drivers/memory/spiflash.c
@@ -49,10 +49,8 @@ STATIC uint8_t buf[SECTOR_SIZE];
void mp_spiflash_init(mp_spiflash_t *self) {
mp_hal_pin_write(self->cs, 1);
mp_hal_pin_output(self->cs);
- mp_hal_pin_write(self->spi.sck, 0);
- mp_hal_pin_output(self->spi.sck);
- mp_hal_pin_output(self->spi.mosi);
- mp_hal_pin_input(self->spi.miso);
+ const mp_machine_spi_p_t *protocol = self->spi->type->protocol;
+ protocol->init(self->spi, 0, NULL, (mp_map_t*)&mp_const_empty_map);
}
STATIC void mp_spiflash_acquire_bus(mp_spiflash_t *self) {
@@ -66,7 +64,8 @@ STATIC void mp_spiflash_release_bus(mp_spiflash_t *self) {
}
STATIC void mp_spiflash_transfer(mp_spiflash_t *self, size_t len, const uint8_t *src, uint8_t *dest) {
- mp_machine_soft_spi_transfer(&self->spi.base, len, src, dest);
+ const mp_machine_spi_p_t *protocol = self->spi->type->protocol;
+ protocol->transfer(self->spi, len, src, dest);
}
STATIC int mp_spiflash_wait_sr(mp_spiflash_t *self, uint8_t mask, uint8_t val, uint32_t timeout) {
diff --git a/drivers/memory/spiflash.h b/drivers/memory/spiflash.h
index 967352b04e..cd96b16f34 100644
--- a/drivers/memory/spiflash.h
+++ b/drivers/memory/spiflash.h
@@ -30,8 +30,7 @@
typedef struct _mp_spiflash_t {
mp_hal_pin_obj_t cs;
- // TODO replace with generic SPI object
- mp_machine_soft_spi_obj_t spi;
+ mp_obj_base_t *spi; // object must have protocol pointing to mp_machine_spi_p_t struct
} mp_spiflash_t;
void mp_spiflash_init(mp_spiflash_t *self);