flipperzero-firmware/lib/ST25RFAL002/platform.c

58 lines
1.6 KiB
C
Raw Normal View History

2020-10-18 22:09:48 +00:00
#include "platform.h"
#include <assert.h>
#include <main.h>
#include <api-hal-spi.h>
static osThreadAttr_t platform_irq_thread_attr;
static volatile osThreadId_t platform_irq_thread_id = NULL;
static volatile PlatformIrqCallback platform_irq_callback = NULL;
void nfc_isr() {
if(platform_irq_callback && platformGpioIsHigh( ST25R_INT_PORT, ST25R_INT_PIN )) {
osThreadFlagsSet(platform_irq_thread_id, 0x1);
}
}
void platformIrqWorker() {
while(1) {
uint32_t flags = osThreadFlagsWait(0x1, osFlagsWaitAny, osWaitForever);
if (flags & 0x1) {
platform_irq_callback();
}
}
}
void platformSetIrqCallback(PlatformIrqCallback callback) {
platform_irq_callback = callback;
platform_irq_thread_attr.name = "rfal_irq_worker";
platform_irq_thread_attr.stack_size = 512;
platform_irq_thread_attr.priority = osPriorityISR;
platform_irq_thread_id = osThreadNew(platformIrqWorker, NULL, &platform_irq_thread_attr);
}
2020-10-18 22:09:48 +00:00
HAL_StatusTypeDef platformSpiTxRx(const uint8_t *txBuf, uint8_t *rxBuf, uint16_t len) {
HAL_StatusTypeDef ret;
if (txBuf && rxBuf) {
ret = HAL_SPI_TransmitReceive(&SPI_R, (uint8_t*)txBuf, rxBuf, len, HAL_MAX_DELAY);
2020-10-18 22:09:48 +00:00
} else if (txBuf) {
ret = HAL_SPI_Transmit(&SPI_R, (uint8_t*)txBuf, len, HAL_MAX_DELAY);
2020-10-18 22:09:48 +00:00
} else if (rxBuf) {
ret = HAL_SPI_Receive(&SPI_R, (uint8_t*)rxBuf, len, HAL_MAX_DELAY);
2020-10-18 22:09:48 +00:00
}
if(ret != HAL_OK) {
asm("bkpt 1");
exit(255);
2020-10-18 22:09:48 +00:00
}
return ret;
}
void platformProtectST25RComm() {
api_hal_spi_lock(&SPI_R);
NFC_SPI_Reconfigure();
2020-10-18 22:09:48 +00:00
}
void platformUnprotectST25RComm() {
api_hal_spi_unlock(&SPI_R);
2020-10-18 22:09:48 +00:00
}