Merge branch 'stm32-spi-oneline' into stm32-i2c-rework
This commit is contained in:
commit
d222c64538
@ -35,8 +35,36 @@
|
|||||||
|
|
||||||
displayio_fourwire_obj_t board_display_obj;
|
displayio_fourwire_obj_t board_display_obj;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
const uint32_t *config_data;
|
||||||
|
void *handoverHID;
|
||||||
|
void *handoverMSC;
|
||||||
|
const char *info_uf2;
|
||||||
|
} UF2_BInfo;
|
||||||
|
|
||||||
|
#define APP_START_ADDRESS 0x00004000
|
||||||
|
#define UF2_BINFO ((UF2_BInfo *)(APP_START_ADDRESS - sizeof(UF2_BInfo)))
|
||||||
|
|
||||||
|
#define CFG_DISPLAY_CFG0 39
|
||||||
|
#define CFG_MAGIC0 0x1e9e10f1
|
||||||
|
|
||||||
#define DELAY 0x80
|
#define DELAY 0x80
|
||||||
|
|
||||||
|
uint32_t lookupCfg(uint32_t key, uint32_t defl) {
|
||||||
|
const uint32_t *ptr = UF2_BINFO->config_data;
|
||||||
|
if (!ptr || (((uint32_t)ptr) & 3) || *ptr != CFG_MAGIC0) {
|
||||||
|
// no config data!
|
||||||
|
} else {
|
||||||
|
ptr += 4;
|
||||||
|
while (*ptr) {
|
||||||
|
if (*ptr == key)
|
||||||
|
return ptr[1];
|
||||||
|
ptr += 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return defl;
|
||||||
|
}
|
||||||
|
|
||||||
uint8_t display_init_sequence[] = {
|
uint8_t display_init_sequence[] = {
|
||||||
0x01, 0 | DELAY, 150, // SWRESET
|
0x01, 0 | DELAY, 150, // SWRESET
|
||||||
0x11, 0 | DELAY, 255, // SLPOUT
|
0x11, 0 | DELAY, 255, // SLPOUT
|
||||||
@ -63,8 +91,6 @@ uint8_t display_init_sequence[] = {
|
|||||||
0x2E, 0x2C, 0x29, 0x2D,
|
0x2E, 0x2C, 0x29, 0x2D,
|
||||||
0x2E, 0x2E, 0x37, 0x3F,
|
0x2E, 0x2E, 0x37, 0x3F,
|
||||||
0x00, 0x00, 0x02, 0x10,
|
0x00, 0x00, 0x02, 0x10,
|
||||||
0x2a, 3, 0x02, 0x00, 0x81, // _CASET XSTART = 2, XEND = 129
|
|
||||||
0x2b, 3, 0x02, 0x00, 0x81, // _RASET XSTART = 2, XEND = 129
|
|
||||||
0x13, 0 | DELAY, 10, // _NORON
|
0x13, 0 | DELAY, 10, // _NORON
|
||||||
0x29, 0 | DELAY, 100, // _DISPON
|
0x29, 0 | DELAY, 100, // _DISPON
|
||||||
};
|
};
|
||||||
@ -83,14 +109,17 @@ void board_init(void) {
|
|||||||
&pin_PA17, // TFT_RST Reset
|
&pin_PA17, // TFT_RST Reset
|
||||||
60000000);
|
60000000);
|
||||||
|
|
||||||
|
uint32_t cfg0 = lookupCfg(CFG_DISPLAY_CFG0, 0x000000);
|
||||||
|
uint32_t offX = (cfg0 >> 8) & 0xff;
|
||||||
|
uint32_t offY = (cfg0 >> 16) & 0xff;
|
||||||
displayio_display_obj_t* display = &displays[0].display;
|
displayio_display_obj_t* display = &displays[0].display;
|
||||||
display->base.type = &displayio_display_type;
|
display->base.type = &displayio_display_type;
|
||||||
common_hal_displayio_display_construct(display,
|
common_hal_displayio_display_construct(display,
|
||||||
bus,
|
bus,
|
||||||
160, // Width (after rotation)
|
160, // Width (after rotation)
|
||||||
128, // Height (after rotation)
|
128, // Height (after rotation)
|
||||||
0, // column start
|
offX, // column start
|
||||||
0, // row start
|
offY, // row start
|
||||||
0, // rotation
|
0, // rotation
|
||||||
16, // Color depth
|
16, // Color depth
|
||||||
false, // grayscale
|
false, // grayscale
|
||||||
|
@ -36,6 +36,9 @@
|
|||||||
#include "supervisor/shared/translate.h"
|
#include "supervisor/shared/translate.h"
|
||||||
#include "common-hal/microcontroller/Pin.h"
|
#include "common-hal/microcontroller/Pin.h"
|
||||||
|
|
||||||
|
// Note that any bugs introduced in this file can cause crashes at startup
|
||||||
|
// for chips using external SPI flash.
|
||||||
|
|
||||||
#define MAX_SPI 6 //TODO; replace this as part of periph cleanup
|
#define MAX_SPI 6 //TODO; replace this as part of periph cleanup
|
||||||
#define ALL_CLOCKS 0xFF
|
#define ALL_CLOCKS 0xFF
|
||||||
|
|
||||||
@ -53,10 +56,10 @@ STATIC void spi_clock_disable(uint8_t mask);
|
|||||||
STATIC uint32_t get_busclock(SPI_TypeDef * instance) {
|
STATIC uint32_t get_busclock(SPI_TypeDef * instance) {
|
||||||
//SPI2 and 3 are on PCLK1, if they exist.
|
//SPI2 and 3 are on PCLK1, if they exist.
|
||||||
#ifdef SPI2
|
#ifdef SPI2
|
||||||
if(instance == SPI2) return HAL_RCC_GetPCLK1Freq();
|
if (instance == SPI2) return HAL_RCC_GetPCLK1Freq();
|
||||||
#endif
|
#endif
|
||||||
#ifdef SPI3
|
#ifdef SPI3
|
||||||
if(instance == SPI3) return HAL_RCC_GetPCLK1Freq();
|
if (instance == SPI3) return HAL_RCC_GetPCLK1Freq();
|
||||||
#endif
|
#endif
|
||||||
return HAL_RCC_GetPCLK2Freq();
|
return HAL_RCC_GetPCLK2Freq();
|
||||||
}
|
}
|
||||||
@ -113,38 +116,80 @@ void common_hal_busio_spi_construct(busio_spi_obj_t *self,
|
|||||||
uint8_t sck_len = sizeof(mcu_spi_sck_list)/sizeof(*mcu_spi_sck_list);
|
uint8_t sck_len = sizeof(mcu_spi_sck_list)/sizeof(*mcu_spi_sck_list);
|
||||||
uint8_t mosi_len = sizeof(mcu_spi_mosi_list)/sizeof(*mcu_spi_mosi_list);
|
uint8_t mosi_len = sizeof(mcu_spi_mosi_list)/sizeof(*mcu_spi_mosi_list);
|
||||||
uint8_t miso_len = sizeof(mcu_spi_miso_list)/sizeof(*mcu_spi_miso_list);
|
uint8_t miso_len = sizeof(mcu_spi_miso_list)/sizeof(*mcu_spi_miso_list);
|
||||||
|
|
||||||
bool spi_taken = false;
|
bool spi_taken = false;
|
||||||
//sck
|
|
||||||
for(uint i=0; i<sck_len;i++) {
|
//SCK is not optional. MOSI and MISO are
|
||||||
|
for (uint i=0; i<sck_len;i++) {
|
||||||
if (mcu_spi_sck_list[i].pin == sck) {
|
if (mcu_spi_sck_list[i].pin == sck) {
|
||||||
//mosi
|
//if both MOSI and MISO exist, loop search normally
|
||||||
for(uint j=0; j<mosi_len;j++) {
|
if ((mosi != mp_const_none) && (miso != mp_const_none)) {
|
||||||
if (mcu_spi_mosi_list[j].pin == mosi) {
|
//MOSI
|
||||||
//miso
|
for (uint j=0; j<mosi_len;j++) {
|
||||||
for(uint k=0; k<miso_len;k++) {
|
if (mcu_spi_mosi_list[j].pin == mosi) {
|
||||||
if ((mcu_spi_miso_list[k].pin == miso) //everything needs the same index
|
//MISO
|
||||||
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_mosi_list[j].spi_index)
|
for (uint k=0; k<miso_len;k++) {
|
||||||
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_miso_list[k].spi_index)) {
|
if ((mcu_spi_miso_list[k].pin == miso) //everything needs the same index
|
||||||
//keep looking if the SPI is taken, edge case
|
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_mosi_list[j].spi_index)
|
||||||
if(reserved_spi[mcu_spi_sck_list[i].spi_index-1]) {
|
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_miso_list[k].spi_index)) {
|
||||||
spi_taken = true;
|
//keep looking if the SPI is taken, edge case
|
||||||
continue;
|
if (reserved_spi[mcu_spi_sck_list[i].spi_index-1]) {
|
||||||
|
spi_taken = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
//store pins if not
|
||||||
|
self->sck = &mcu_spi_sck_list[i];
|
||||||
|
self->mosi = &mcu_spi_mosi_list[j];
|
||||||
|
self->miso = &mcu_spi_miso_list[k];
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
//store pins if not
|
|
||||||
self->sck = &mcu_spi_sck_list[i];
|
|
||||||
self->mosi = &mcu_spi_mosi_list[j];
|
|
||||||
self->miso = &mcu_spi_miso_list[k];
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// if just MISO, reduce search
|
||||||
|
} else if (miso != mp_const_none) {
|
||||||
|
for (uint j=0; j<miso_len;j++) {
|
||||||
|
if ((mcu_spi_miso_list[j].pin == miso) //only SCK and MISO need the same index
|
||||||
|
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_miso_list[j].spi_index)) {
|
||||||
|
//keep looking if the SPI is taken, edge case
|
||||||
|
if (reserved_spi[mcu_spi_sck_list[i].spi_index-1]) {
|
||||||
|
spi_taken = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
//store pins if not
|
||||||
|
self->sck = &mcu_spi_sck_list[i];
|
||||||
|
self->mosi = NULL;
|
||||||
|
self->miso = &mcu_spi_miso_list[j];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if just MOSI, reduce search
|
||||||
|
} else if (mosi != mp_const_none) {
|
||||||
|
for (uint j=0; j<mosi_len;j++) {
|
||||||
|
if ((mcu_spi_mosi_list[j].pin == mosi) //only SCK and MOSI need the same index
|
||||||
|
&& (mcu_spi_sck_list[i].spi_index == mcu_spi_mosi_list[j].spi_index)) {
|
||||||
|
//keep looking if the SPI is taken, edge case
|
||||||
|
if (reserved_spi[mcu_spi_sck_list[i].spi_index-1]) {
|
||||||
|
spi_taken = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
//store pins if not
|
||||||
|
self->sck = &mcu_spi_sck_list[i];
|
||||||
|
self->mosi = &mcu_spi_mosi_list[j];
|
||||||
|
self->miso = NULL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
//throw an error immediately
|
||||||
|
mp_raise_ValueError(translate("Must provide MISO or MOSI pin"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//handle typedef selection, errors
|
//handle typedef selection, errors
|
||||||
if(self->sck!=NULL && self->mosi!=NULL && self->miso!=NULL ) {
|
if ( (self->sck!=NULL && self->mosi!=NULL && self->miso != NULL) ||
|
||||||
|
(self->sck!=NULL && self->mosi!=NULL && miso == mp_const_none) ||
|
||||||
|
(self->sck!=NULL && self->miso!=NULL && mosi == mp_const_none)) {
|
||||||
SPIx = mcu_spi_banks[self->sck->spi_index-1];
|
SPIx = mcu_spi_banks[self->sck->spi_index-1];
|
||||||
} else {
|
} else {
|
||||||
if (spi_taken) {
|
if (spi_taken) {
|
||||||
@ -163,26 +208,31 @@ void common_hal_busio_spi_construct(busio_spi_obj_t *self,
|
|||||||
GPIO_InitStruct.Alternate = self->sck->altfn_index;
|
GPIO_InitStruct.Alternate = self->sck->altfn_index;
|
||||||
HAL_GPIO_Init(pin_port(sck->port), &GPIO_InitStruct);
|
HAL_GPIO_Init(pin_port(sck->port), &GPIO_InitStruct);
|
||||||
|
|
||||||
GPIO_InitStruct.Pin = pin_mask(mosi->number);
|
if (self->mosi != NULL) {
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
GPIO_InitStruct.Pin = pin_mask(mosi->number);
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Alternate = self->mosi->altfn_index;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
||||||
HAL_GPIO_Init(pin_port(mosi->port), &GPIO_InitStruct);
|
GPIO_InitStruct.Alternate = self->mosi->altfn_index;
|
||||||
|
HAL_GPIO_Init(pin_port(mosi->port), &GPIO_InitStruct);
|
||||||
|
}
|
||||||
|
|
||||||
GPIO_InitStruct.Pin = pin_mask(miso->number);
|
if (self->miso != NULL) {
|
||||||
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
GPIO_InitStruct.Pin = pin_mask(miso->number);
|
||||||
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
||||||
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
||||||
GPIO_InitStruct.Alternate = self->miso->altfn_index;
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
||||||
HAL_GPIO_Init(pin_port(miso->port), &GPIO_InitStruct);
|
GPIO_InitStruct.Alternate = self->miso->altfn_index;
|
||||||
|
HAL_GPIO_Init(pin_port(miso->port), &GPIO_InitStruct);
|
||||||
|
}
|
||||||
|
|
||||||
spi_clock_enable(1<<(self->sck->spi_index - 1));
|
spi_clock_enable(1<<(self->sck->spi_index - 1));
|
||||||
reserved_spi[self->sck->spi_index - 1] = true;
|
reserved_spi[self->sck->spi_index - 1] = true;
|
||||||
|
|
||||||
self->handle.Instance = SPIx;
|
self->handle.Instance = SPIx;
|
||||||
self->handle.Init.Mode = SPI_MODE_MASTER;
|
self->handle.Init.Mode = SPI_MODE_MASTER;
|
||||||
self->handle.Init.Direction = SPI_DIRECTION_2LINES;
|
// Direction change only required for RX-only, see RefMan RM0090:884
|
||||||
|
self->handle.Init.Direction = (self->mosi == NULL) ? SPI_CR1_RXONLY : SPI_DIRECTION_2LINES;
|
||||||
self->handle.Init.DataSize = SPI_DATASIZE_8BIT;
|
self->handle.Init.DataSize = SPI_DATASIZE_8BIT;
|
||||||
self->handle.Init.CLKPolarity = SPI_POLARITY_LOW;
|
self->handle.Init.CLKPolarity = SPI_POLARITY_LOW;
|
||||||
self->handle.Init.CLKPhase = SPI_PHASE_1EDGE;
|
self->handle.Init.CLKPhase = SPI_PHASE_1EDGE;
|
||||||
@ -203,17 +253,25 @@ void common_hal_busio_spi_construct(busio_spi_obj_t *self,
|
|||||||
self->bits = 8;
|
self->bits = 8;
|
||||||
|
|
||||||
claim_pin(sck);
|
claim_pin(sck);
|
||||||
claim_pin(mosi);
|
if (self->mosi != NULL) {
|
||||||
claim_pin(miso);
|
claim_pin(mosi);
|
||||||
|
}
|
||||||
|
if (self->miso != NULL) {
|
||||||
|
claim_pin(miso);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void common_hal_busio_spi_never_reset(busio_spi_obj_t *self) {
|
void common_hal_busio_spi_never_reset(busio_spi_obj_t *self) {
|
||||||
for(size_t i = 0 ; i < MP_ARRAY_SIZE(mcu_spi_banks); i++) {
|
for (size_t i = 0 ; i < MP_ARRAY_SIZE(mcu_spi_banks); i++) {
|
||||||
if (mcu_spi_banks[i] == self->handle.Instance) {
|
if (mcu_spi_banks[i] == self->handle.Instance) {
|
||||||
never_reset_spi[i] = true;
|
never_reset_spi[i] = true;
|
||||||
never_reset_pin_number(self->sck->pin->port, self->sck->pin->number);
|
never_reset_pin_number(self->sck->pin->port, self->sck->pin->number);
|
||||||
never_reset_pin_number(self->mosi->pin->port, self->mosi->pin->number);
|
if (self->mosi != NULL) {
|
||||||
never_reset_pin_number(self->miso->pin->port, self->miso->pin->number);
|
never_reset_pin_number(self->mosi->pin->port, self->mosi->pin->number);
|
||||||
|
}
|
||||||
|
if (self->miso != NULL) {
|
||||||
|
never_reset_pin_number(self->miso->pin->port, self->miso->pin->number);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -229,8 +287,12 @@ void common_hal_busio_spi_deinit(busio_spi_obj_t *self) {
|
|||||||
never_reset_spi[self->sck->spi_index - 1] = false;
|
never_reset_spi[self->sck->spi_index - 1] = false;
|
||||||
|
|
||||||
reset_pin_number(self->sck->pin->port,self->sck->pin->number);
|
reset_pin_number(self->sck->pin->port,self->sck->pin->number);
|
||||||
reset_pin_number(self->mosi->pin->port,self->mosi->pin->number);
|
if (self->mosi != NULL) {
|
||||||
reset_pin_number(self->miso->pin->port,self->miso->pin->number);
|
reset_pin_number(self->mosi->pin->port,self->mosi->pin->number);
|
||||||
|
}
|
||||||
|
if (self->miso != NULL) {
|
||||||
|
reset_pin_number(self->miso->pin->port,self->miso->pin->number);
|
||||||
|
}
|
||||||
self->sck = mp_const_none;
|
self->sck = mp_const_none;
|
||||||
self->mosi = mp_const_none;
|
self->mosi = mp_const_none;
|
||||||
self->miso = mp_const_none;
|
self->miso = mp_const_none;
|
||||||
@ -240,7 +302,9 @@ bool common_hal_busio_spi_configure(busio_spi_obj_t *self,
|
|||||||
uint32_t baudrate, uint8_t polarity, uint8_t phase, uint8_t bits) {
|
uint32_t baudrate, uint8_t polarity, uint8_t phase, uint8_t bits) {
|
||||||
//This resets the SPI, so check before updating it redundantly
|
//This resets the SPI, so check before updating it redundantly
|
||||||
if (baudrate == self->baudrate && polarity== self->polarity
|
if (baudrate == self->baudrate && polarity== self->polarity
|
||||||
&& phase == self->phase && bits == self->bits) return true;
|
&& phase == self->phase && bits == self->bits) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
//Deinit SPI
|
//Deinit SPI
|
||||||
HAL_SPI_DeInit(&self->handle);
|
HAL_SPI_DeInit(&self->handle);
|
||||||
@ -251,13 +315,6 @@ bool common_hal_busio_spi_configure(busio_spi_obj_t *self,
|
|||||||
|
|
||||||
self->handle.Init.BaudRatePrescaler = stm32_baud_to_spi_div(baudrate, &self->prescaler,
|
self->handle.Init.BaudRatePrescaler = stm32_baud_to_spi_div(baudrate, &self->prescaler,
|
||||||
get_busclock(self->handle.Instance));
|
get_busclock(self->handle.Instance));
|
||||||
self->handle.Init.Mode = SPI_MODE_MASTER;
|
|
||||||
self->handle.Init.Direction = SPI_DIRECTION_2LINES;
|
|
||||||
self->handle.Init.NSS = SPI_NSS_SOFT;
|
|
||||||
self->handle.Init.FirstBit = SPI_FIRSTBIT_MSB;
|
|
||||||
self->handle.Init.TIMode = SPI_TIMODE_DISABLE;
|
|
||||||
self->handle.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
|
|
||||||
self->handle.Init.CRCPolynomial = 10;
|
|
||||||
|
|
||||||
if (HAL_SPI_Init(&self->handle) != HAL_OK)
|
if (HAL_SPI_Init(&self->handle) != HAL_OK)
|
||||||
{
|
{
|
||||||
@ -300,18 +357,27 @@ void common_hal_busio_spi_unlock(busio_spi_obj_t *self) {
|
|||||||
|
|
||||||
bool common_hal_busio_spi_write(busio_spi_obj_t *self,
|
bool common_hal_busio_spi_write(busio_spi_obj_t *self,
|
||||||
const uint8_t *data, size_t len) {
|
const uint8_t *data, size_t len) {
|
||||||
|
if (self->mosi == NULL) {
|
||||||
|
mp_raise_ValueError(translate("No MOSI Pin"));
|
||||||
|
}
|
||||||
HAL_StatusTypeDef result = HAL_SPI_Transmit (&self->handle, (uint8_t *)data, (uint16_t)len, HAL_MAX_DELAY);
|
HAL_StatusTypeDef result = HAL_SPI_Transmit (&self->handle, (uint8_t *)data, (uint16_t)len, HAL_MAX_DELAY);
|
||||||
return result == HAL_OK;
|
return result == HAL_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool common_hal_busio_spi_read(busio_spi_obj_t *self,
|
bool common_hal_busio_spi_read(busio_spi_obj_t *self,
|
||||||
uint8_t *data, size_t len, uint8_t write_value) {
|
uint8_t *data, size_t len, uint8_t write_value) {
|
||||||
|
if (self->miso == NULL) {
|
||||||
|
mp_raise_ValueError(translate("No MISO Pin"));
|
||||||
|
}
|
||||||
HAL_StatusTypeDef result = HAL_SPI_Receive (&self->handle, data, (uint16_t)len, HAL_MAX_DELAY);
|
HAL_StatusTypeDef result = HAL_SPI_Receive (&self->handle, data, (uint16_t)len, HAL_MAX_DELAY);
|
||||||
return result == HAL_OK;
|
return result == HAL_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool common_hal_busio_spi_transfer(busio_spi_obj_t *self,
|
bool common_hal_busio_spi_transfer(busio_spi_obj_t *self,
|
||||||
uint8_t *data_out, uint8_t *data_in, size_t len) {
|
uint8_t *data_out, uint8_t *data_in, size_t len) {
|
||||||
|
if (self->miso == NULL || self->mosi == NULL) {
|
||||||
|
mp_raise_ValueError(translate("Missing MISO or MOSI Pin"));
|
||||||
|
}
|
||||||
HAL_StatusTypeDef result = HAL_SPI_TransmitReceive (&self->handle,
|
HAL_StatusTypeDef result = HAL_SPI_TransmitReceive (&self->handle,
|
||||||
data_out, data_in, (uint16_t)len,HAL_MAX_DELAY);
|
data_out, data_in, (uint16_t)len,HAL_MAX_DELAY);
|
||||||
return result == HAL_OK;
|
return result == HAL_OK;
|
||||||
|
Loading…
Reference in New Issue
Block a user