ihsm-strain-gage-controller-fw/include/serial.h
2023-05-08 23:26:51 +02:00

80 lines
2.1 KiB
C

#ifndef __SERIAL_H__
#define __SERIAL_H__
#include <global.h>
#include <cobs.h>
struct dma_tx_buf {
/* The following fields are accessed only from DMA ISR */
ssize_t xfr_start; /* Start index of running DMA transfer */
ssize_t xfr_end; /* End index of running DMA transfer plus one */
bool wraparound;
ssize_t xfr_next;
bool ack;
/* The following fields are written only from non-interrupt code */
ssize_t wr_pos; /* Next index to be written */
ssize_t wr_idx;
ssize_t packet_end[8];
/* The following may be accessed by anything */
uint8_t data[512];
};
struct uart_dma_state {
struct dma_tx_buf tx_buf;
uint32_t tx_overruns, rx_overruns;
uint32_t rx_framing_errors, rx_protocol_errors;
uint32_t retransmissions, packet_count;
ErrorCode error;
struct cobs_decode_state cobs_state;
size_t tx_dma_ch;
USART_TypeDef *usart;
uint8_t rx_buf[32];
uint8_t addr;
};
struct __attribute__((__packed__)) ll_pkt {
uint32_t crc32;
/* CRC computed over entire packet starting here */
uint8_t src;
uint8_t dst;
uint8_t pid;
uint8_t type;
uint8_t data[0];
};
enum ctrl_pkt_type {
CTRL_PKT_RESET = 1,
CTRL_PKT_ACK = 2,
CTRL_PKT_NACK = 3,
CTRL_PKT_PING = 4,
CTRL_PKT_PONG = 5,
_USER_PKT_START = 16,
};
enum user_pkt_type {
USER_PKT_ADC_DATA = _USER_PKT_START+0,
USER_PKT_SET_DISPLAY = _USER_PKT_START+1,
};
struct __attribute__((__packed__)) user_pkt_adc_data {
struct ll_pkt hdr;
uint8_t adc_data_packed[3*2*16];
};
extern volatile struct uart_dma_state uart_st;
void uart_dma_init(USART_TypeDef *usart, int tx_dma_ch, int addr);
int uart_send_packet_nonblocking(struct ll_pkt *pkt, size_t pkt_len);
int uart_ack_packet(uint8_t idx);
void uart_dma_interrupt(uint32_t channel, uint32_t flags);
void uart_interrupt(uint32_t isr);
extern void uart_handle_user_packet(struct ll_pkt *pkt, size_t len);
#endif // __SERIAL_H__