Moved checks for invalid pin to common-hal/microcontroller/Pin.c
This commit is contained in:
parent
ed6cc64c49
commit
2690faec43
@ -106,6 +106,10 @@ void reset_all_pins(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void never_reset_pin_number(uint8_t pin_number) {
|
void never_reset_pin_number(uint8_t pin_number) {
|
||||||
|
if (pin_number >= PORT_BITS) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
never_reset_pins[GPIO_PORT(pin_number)] |= 1 << GPIO_PIN(pin_number);
|
never_reset_pins[GPIO_PORT(pin_number)] |= 1 << GPIO_PIN(pin_number);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,6 +45,9 @@ bool apa102_mosi_in_use;
|
|||||||
bool apa102_sck_in_use;
|
bool apa102_sck_in_use;
|
||||||
|
|
||||||
void never_reset_pin_number(gpio_num_t pin_number) {
|
void never_reset_pin_number(gpio_num_t pin_number) {
|
||||||
|
if (pin_number == -1 ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
never_reset_pins[pin_number / 32] |= 1 << pin_number % 32;
|
never_reset_pins[pin_number / 32] |= 1 << pin_number % 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,6 +57,9 @@ void common_hal_never_reset_pin(const mcu_pin_obj_t* pin) {
|
|||||||
|
|
||||||
// Mark pin as free and return it to a quiescent state.
|
// Mark pin as free and return it to a quiescent state.
|
||||||
void reset_pin_number(gpio_num_t pin_number) {
|
void reset_pin_number(gpio_num_t pin_number) {
|
||||||
|
if (pin_number == -1 ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
never_reset_pins[pin_number / 32] &= ~(1 << pin_number % 32);
|
never_reset_pins[pin_number / 32] &= ~(1 << pin_number % 32);
|
||||||
in_use[pin_number / 32] &= ~(1 << pin_number % 32);
|
in_use[pin_number / 32] &= ~(1 << pin_number % 32);
|
||||||
|
|
||||||
|
@ -104,12 +104,8 @@ void common_hal_busio_spi_never_reset(busio_spi_obj_t *self) {
|
|||||||
never_reset[i] = true;
|
never_reset[i] = true;
|
||||||
|
|
||||||
never_reset_pin_number(self->clock_pin_number);
|
never_reset_pin_number(self->clock_pin_number);
|
||||||
if ( self->MOSI_pin_number != NO_PIN) {
|
never_reset_pin_number(self->MOSI_pin_number);
|
||||||
never_reset_pin_number(self->MOSI_pin_number);
|
never_reset_pin_number(self->MISO_pin_number);
|
||||||
}
|
|
||||||
if ( self->MISO_pin_number != NO_PIN) {
|
|
||||||
never_reset_pin_number(self->MISO_pin_number);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -208,12 +204,8 @@ void common_hal_busio_spi_deinit(busio_spi_obj_t *self) {
|
|||||||
nrfx_spim_uninit(&self->spim_peripheral->spim);
|
nrfx_spim_uninit(&self->spim_peripheral->spim);
|
||||||
|
|
||||||
reset_pin_number(self->clock_pin_number);
|
reset_pin_number(self->clock_pin_number);
|
||||||
if ( self->MOSI_pin_number != NO_PIN) {
|
reset_pin_number(self->MOSI_pin_number);
|
||||||
reset_pin_number(self->MOSI_pin_number);
|
reset_pin_number(self->MISO_pin_number);
|
||||||
}
|
|
||||||
if ( self->MISO_pin_number != NO_PIN) {
|
|
||||||
reset_pin_number(self->MISO_pin_number);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool common_hal_busio_spi_configure(busio_spi_obj_t *self, uint32_t baudrate, uint8_t polarity, uint8_t phase, uint8_t bits) {
|
bool common_hal_busio_spi_configure(busio_spi_obj_t *self, uint32_t baudrate, uint8_t polarity, uint8_t phase, uint8_t bits) {
|
||||||
|
@ -123,6 +123,9 @@ void reset_pin_number(uint8_t pin_number) {
|
|||||||
|
|
||||||
|
|
||||||
void never_reset_pin_number(uint8_t pin_number) {
|
void never_reset_pin_number(uint8_t pin_number) {
|
||||||
|
if (pin_number == NO_PIN) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
never_reset_pins[nrf_pin_port(pin_number)] |= 1 << nrf_relative_pin_number(pin_number);
|
never_reset_pins[nrf_pin_port(pin_number)] |= 1 << nrf_relative_pin_number(pin_number);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,6 +70,10 @@ void reset_all_pins(void) {
|
|||||||
|
|
||||||
// Mark pin as free and return it to a quiescent state.
|
// Mark pin as free and return it to a quiescent state.
|
||||||
void reset_pin_number(uint8_t pin_port, uint8_t pin_number) {
|
void reset_pin_number(uint8_t pin_port, uint8_t pin_number) {
|
||||||
|
if ( pin_number == NO_PIN ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (pin_port == 0x0F) {
|
if (pin_port == 0x0F) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -88,6 +92,9 @@ void reset_pin_number(uint8_t pin_port, uint8_t pin_number) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void never_reset_pin_number(uint8_t pin_port, uint8_t pin_number) {
|
void never_reset_pin_number(uint8_t pin_port, uint8_t pin_number) {
|
||||||
|
if ( pin_number == NO_PIN ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
never_reset_pins[pin_port] |= 1<<pin_number;
|
never_reset_pins[pin_port] |= 1<<pin_number;
|
||||||
// Make sure never reset pins are also always claimed
|
// Make sure never reset pins are also always claimed
|
||||||
claimed_pins[pin_port] |= 1<<pin_number;
|
claimed_pins[pin_port] |= 1<<pin_number;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user