esp32/machine_hw_spi: Check for valid SPI id in constructor, not init.
Otherwise constructing an invalid SPI instance (eg machine.SPI(3)) will mess up machine.SPI(2)'s state before it's detected that it's an invalid SPI id. Signed-off-by: Damien George <damien@micropython.org>
This commit is contained in:
parent
162dd022b1
commit
b2adfc8077
@ -44,6 +44,13 @@
|
|||||||
// SPI(id=1) | HSPI/SPI2 | FSPI/SPI2 | SPI2 | SPI2
|
// SPI(id=1) | HSPI/SPI2 | FSPI/SPI2 | SPI2 | SPI2
|
||||||
// SPI(id=2) | VSPI/SPI3 | HSPI/SPI3 | SPI3 | err
|
// SPI(id=2) | VSPI/SPI3 | HSPI/SPI3 | SPI3 | err
|
||||||
|
|
||||||
|
// Number of available hardware SPI peripherals.
|
||||||
|
#if SOC_SPI_PERIPH_NUM > 2
|
||||||
|
#define MICROPY_HW_SPI_MAX (2)
|
||||||
|
#else
|
||||||
|
#define MICROPY_HW_SPI_MAX (1)
|
||||||
|
#endif
|
||||||
|
|
||||||
// Default pins for SPI(id=1) aka IDF SPI2, can be overridden by a board
|
// Default pins for SPI(id=1) aka IDF SPI2, can be overridden by a board
|
||||||
#ifndef MICROPY_HW_SPI1_SCK
|
#ifndef MICROPY_HW_SPI1_SCK
|
||||||
// Use IO_MUX pins by default.
|
// Use IO_MUX pins by default.
|
||||||
@ -99,15 +106,15 @@ typedef struct _machine_hw_spi_obj_t {
|
|||||||
} machine_hw_spi_obj_t;
|
} machine_hw_spi_obj_t;
|
||||||
|
|
||||||
// Default pin mappings for the hardware SPI instances
|
// Default pin mappings for the hardware SPI instances
|
||||||
STATIC const machine_hw_spi_default_pins_t machine_hw_spi_default_pins[2] = {
|
STATIC const machine_hw_spi_default_pins_t machine_hw_spi_default_pins[MICROPY_HW_SPI_MAX] = {
|
||||||
{ .sck = MICROPY_HW_SPI1_SCK, .mosi = MICROPY_HW_SPI1_MOSI, .miso = MICROPY_HW_SPI1_MISO },
|
{ .sck = MICROPY_HW_SPI1_SCK, .mosi = MICROPY_HW_SPI1_MOSI, .miso = MICROPY_HW_SPI1_MISO },
|
||||||
#ifdef MICROPY_HW_SPI2_SCK
|
#ifdef MICROPY_HW_SPI2_SCK
|
||||||
{ .sck = MICROPY_HW_SPI2_SCK, .mosi = MICROPY_HW_SPI2_MOSI, .miso = MICROPY_HW_SPI2_MISO },
|
{ .sck = MICROPY_HW_SPI2_SCK, .mosi = MICROPY_HW_SPI2_MOSI, .miso = MICROPY_HW_SPI2_MISO },
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
// Static objects mapping to SPI2 and SPI3 hardware peripherals
|
// Static objects mapping to SPI2 (and SPI3 if available) hardware peripherals.
|
||||||
STATIC machine_hw_spi_obj_t machine_hw_spi_obj[2];
|
STATIC machine_hw_spi_obj_t machine_hw_spi_obj[MICROPY_HW_SPI_MAX];
|
||||||
|
|
||||||
STATIC void machine_hw_spi_deinit_internal(machine_hw_spi_obj_t *self) {
|
STATIC void machine_hw_spi_deinit_internal(machine_hw_spi_obj_t *self) {
|
||||||
switch (spi_bus_remove_device(self->spi)) {
|
switch (spi_bus_remove_device(self->spi)) {
|
||||||
@ -210,14 +217,6 @@ STATIC void machine_hw_spi_init_internal(
|
|||||||
changed = true;
|
changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (self->host != SPI2_HOST
|
|
||||||
#if SOC_SPI_PERIPH_NUM > 2
|
|
||||||
&& self->host != SPI3_HOST
|
|
||||||
#endif
|
|
||||||
) {
|
|
||||||
mp_raise_msg_varg(&mp_type_ValueError, MP_ERROR_TEXT("SPI(%d) doesn't exist"), self->host);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (changed) {
|
if (changed) {
|
||||||
if (self->state == MACHINE_HW_SPI_STATE_INIT) {
|
if (self->state == MACHINE_HW_SPI_STATE_INIT) {
|
||||||
self->state = MACHINE_HW_SPI_STATE_DEINIT;
|
self->state = MACHINE_HW_SPI_STATE_DEINIT;
|
||||||
@ -464,13 +463,14 @@ mp_obj_t machine_hw_spi_make_new(const mp_obj_type_t *type, size_t n_args, size_
|
|||||||
|
|
||||||
machine_hw_spi_obj_t *self;
|
machine_hw_spi_obj_t *self;
|
||||||
const machine_hw_spi_default_pins_t *default_pins;
|
const machine_hw_spi_default_pins_t *default_pins;
|
||||||
if (args[ARG_id].u_int == 1) { // SPI2_HOST which is FSPI_HOST on ESP32Sx, SPI2_HOST on others
|
mp_int_t spi_id = args[ARG_id].u_int;
|
||||||
self = &machine_hw_spi_obj[0];
|
if (1 <= spi_id && spi_id <= MICROPY_HW_SPI_MAX) {
|
||||||
default_pins = &machine_hw_spi_default_pins[0];
|
self = &machine_hw_spi_obj[spi_id - 1];
|
||||||
|
default_pins = &machine_hw_spi_default_pins[spi_id - 1];
|
||||||
} else {
|
} else {
|
||||||
self = &machine_hw_spi_obj[1];
|
mp_raise_msg_varg(&mp_type_ValueError, MP_ERROR_TEXT("SPI(%d) doesn't exist"), spi_id);
|
||||||
default_pins = &machine_hw_spi_default_pins[1];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
self->base.type = &machine_spi_type;
|
self->base.type = &machine_spi_type;
|
||||||
|
|
||||||
int8_t sck, mosi, miso;
|
int8_t sck, mosi, miso;
|
||||||
|
Loading…
Reference in New Issue
Block a user