1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-22 21:30:56 +00:00

fixup! feat(core:): introduce BLE driver

This commit is contained in:
tychovrahe 2025-01-03 12:53:03 +01:00
parent ea2af5e51d
commit 8af5157bf2

View File

@ -42,22 +42,19 @@ typedef struct {
typedef struct { typedef struct {
uint8_t service_id; uint8_t service_id;
uint8_t msg_len; uint8_t msg_len;
} uart_header_t; uint8_t data[NRF_MAX_TX_DATA_SIZE + 1];
// uint8_t crc; part of data, as it has variable position
} uart_packet_t;
typedef struct { #define UART_OVERHEAD_SIZE (sizeof(uart_packet_t) - NRF_MAX_TX_DATA_SIZE)
uint8_t crc; #define UART_HEADER_SIZE (UART_OVERHEAD_SIZE - 1)
} uart_footer_t;
#define UART_HEADER_SIZE (sizeof(uart_header_t))
#define UART_FOOTER_SIZE (sizeof(uart_footer_t))
#define UART_OVERHEAD_SIZE (UART_HEADER_SIZE + UART_FOOTER_SIZE)
#define UART_PACKET_SIZE (NRF_MAX_TX_DATA_SIZE + UART_OVERHEAD_SIZE)
#define TX_QUEUE_SIZE (8) #define TX_QUEUE_SIZE (8)
#define START_BYTE (0xA0) #define START_BYTE (0xA0)
typedef struct { typedef struct {
uint8_t data[UART_PACKET_SIZE]; uart_packet_t packet;
uint8_t len; uint8_t len;
nrf_tx_callback_t callback; nrf_tx_callback_t callback;
void *context; void *context;
@ -73,7 +70,7 @@ typedef struct {
nrf_tx_request_t tx_request; nrf_tx_request_t tx_request;
int32_t tx_request_id; int32_t tx_request_id;
uint8_t rx_buffer[UART_PACKET_SIZE]; uart_packet_t rx_buffer;
uint8_t rx_len; uint8_t rx_len;
uint8_t rx_byte; uint8_t rx_byte;
uint16_t rx_idx; uint16_t rx_idx;
@ -441,19 +438,12 @@ int32_t nrf_send_msg(nrf_service_id_t service, const uint8_t *data,
buffer.callback = callback; buffer.callback = callback;
buffer.context = context; buffer.context = context;
buffer.len = len + UART_OVERHEAD_SIZE; buffer.len = len + UART_OVERHEAD_SIZE;
buffer.packet.service_id = 0xA0 | (uint8_t)service;
uart_header_t header = { buffer.packet.msg_len = len + UART_OVERHEAD_SIZE;
.service_id = 0xA0 | (uint8_t)service, memcpy(&buffer.packet.data, data, len);
.msg_len = len + UART_OVERHEAD_SIZE, buffer.packet.data[len] =
}; crc8((uint8_t *)&buffer.packet, len + UART_OVERHEAD_SIZE - 1, 0x07, 0x00,
memcpy(buffer.data, &header, UART_HEADER_SIZE); false);
memcpy(&buffer.data[UART_HEADER_SIZE], data, len);
uart_footer_t footer = {
.crc = crc8(buffer.data, len + UART_HEADER_SIZE, 0x07, 0x00, false),
};
memcpy(&buffer.data[UART_HEADER_SIZE + len], &footer, UART_FOOTER_SIZE);
if (!tsqueue_enqueue(&drv->tx_queue, (uint8_t *)&buffer, if (!tsqueue_enqueue(&drv->tx_queue, (uint8_t *)&buffer,
sizeof(nrf_tx_request_t), &id)) { sizeof(nrf_tx_request_t), &id)) {
@ -465,7 +455,7 @@ int32_t nrf_send_msg(nrf_service_id_t service, const uint8_t *data,
int32_t tx_id = 0; int32_t tx_id = 0;
if (tsqueue_dequeue(&drv->tx_queue, (uint8_t *)&drv->tx_request, if (tsqueue_dequeue(&drv->tx_queue, (uint8_t *)&drv->tx_request,
sizeof(nrf_tx_request_t), NULL, &tx_id)) { sizeof(nrf_tx_request_t), NULL, &tx_id)) {
HAL_UART_Transmit_DMA(&drv->urt, drv->tx_request.data, HAL_UART_Transmit_DMA(&drv->urt, (uint8_t *)&drv->tx_request.packet,
drv->tx_request.len); drv->tx_request.len);
drv->tx_request_id = tx_id; drv->tx_request_id = tx_id;
} }
@ -516,7 +506,7 @@ void HAL_UART_RxCpltCallback(UART_HandleTypeDef *urt) {
if (drv->rx_idx == 0) { if (drv->rx_idx == 0) {
// received first byte: START BYTE // received first byte: START BYTE
if (nrf_is_valid_startbyte(drv->rx_byte)) { if (nrf_is_valid_startbyte(drv->rx_byte)) {
drv->rx_buffer[0] = drv->rx_byte; drv->rx_buffer.service_id = drv->rx_byte;
drv->rx_idx++; drv->rx_idx++;
} else { } else {
// bad message, flush the line // bad message, flush the line
@ -525,10 +515,10 @@ void HAL_UART_RxCpltCallback(UART_HandleTypeDef *urt) {
} else if (drv->rx_idx == 1) { } else if (drv->rx_idx == 1) {
// received second byte: LEN // received second byte: LEN
drv->rx_buffer[1] = drv->rx_byte; drv->rx_buffer.msg_len = drv->rx_byte;
drv->rx_len = drv->rx_byte; drv->rx_len = drv->rx_byte;
if (drv->rx_len > UART_PACKET_SIZE) { if (drv->rx_len > sizeof(uart_packet_t)) {
drv->rx_len = 0; drv->rx_len = 0;
} else { } else {
drv->rx_idx++; drv->rx_idx++;
@ -537,7 +527,7 @@ void HAL_UART_RxCpltCallback(UART_HandleTypeDef *urt) {
drv->rx_idx < (drv->rx_len - 1)) { drv->rx_idx < (drv->rx_len - 1)) {
// receive the rest of the message // receive the rest of the message
drv->rx_buffer[drv->rx_idx] = drv->rx_byte; drv->rx_buffer.data[drv->rx_idx - UART_HEADER_SIZE] = drv->rx_byte;
drv->rx_idx++; drv->rx_idx++;
if (drv->rx_idx >= NRF_MAX_TX_DATA_SIZE) { if (drv->rx_idx >= NRF_MAX_TX_DATA_SIZE) {
@ -549,13 +539,14 @@ void HAL_UART_RxCpltCallback(UART_HandleTypeDef *urt) {
} else if (drv->rx_idx == (drv->rx_len - 1)) { } else if (drv->rx_idx == (drv->rx_len - 1)) {
// received last byte: CRC // received last byte: CRC
uint8_t crc = crc8(drv->rx_buffer, drv->rx_len - 1, 0x07, 0x00, false); uint8_t crc =
crc8((uint8_t *)&drv->rx_buffer, drv->rx_len - 1, 0x07, 0x00, false);
if (drv->rx_byte == crc) { if (drv->rx_byte == crc) {
uart_header_t *header = (uart_header_t *)drv->rx_buffer; uart_packet_t *packet = &drv->rx_buffer;
nrf_process_msg(drv, drv->rx_buffer + UART_HEADER_SIZE, nrf_process_msg(drv, drv->rx_buffer.data,
drv->rx_len - UART_OVERHEAD_SIZE, drv->rx_len - UART_OVERHEAD_SIZE,
header->service_id & 0x0F); packet->service_id & 0x0F);
} }
drv->rx_idx = 0; drv->rx_idx = 0;
@ -594,7 +585,7 @@ void HAL_UART_TxCpltCallback(UART_HandleTypeDef *urt) {
tsqueue_dequeue(&drv->tx_queue, (uint8_t *)&drv->tx_request, tsqueue_dequeue(&drv->tx_queue, (uint8_t *)&drv->tx_request,
sizeof(nrf_tx_request_t), NULL, &drv->tx_request_id); sizeof(nrf_tx_request_t), NULL, &drv->tx_request_id);
if (msg) { if (msg) {
HAL_UART_Transmit_DMA(&drv->urt, drv->tx_request.data, HAL_UART_Transmit_DMA(&drv->urt, (uint8_t *)&drv->tx_request.packet,
drv->tx_request.len); drv->tx_request.len);
} }
} }