aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/drivers/px4io/interface_serial.cpp26
-rw-r--r--src/modules/px4iofirmware/serial.c26
2 files changed, 37 insertions, 15 deletions
diff --git a/src/drivers/px4io/interface_serial.cpp b/src/drivers/px4io/interface_serial.cpp
index 1ce9e9c6d..ffd852cf0 100644
--- a/src/drivers/px4io/interface_serial.cpp
+++ b/src/drivers/px4io/interface_serial.cpp
@@ -73,8 +73,7 @@ const unsigned max_rw_regs = 32; // by agreement w/IO
#pragma pack(push, 1)
struct IOPacket {
- uint8_t count;
-#define PKT_CTRL_WRITE (1<<7)
+ uint8_t count_code;
uint8_t spare;
uint8_t page;
uint8_t offset;
@@ -92,7 +91,18 @@ struct IOPacket {
#define rCR3 REG(STM32_USART_CR3_OFFSET)
#define rGTPR REG(STM32_USART_GTPR_OFFSET)
-#define PKT_SIZE(_n) (4 + (2 * (_n)))
+#define PKT_CODE_READ 0x00 /* FMU->IO read transaction */
+#define PKT_CODE_WRITE 0x40 /* FMU->IO write transaction */
+#define PKT_CODE_SUCCESS 0x00 /* IO->FMU success reply */
+#define PKT_CODE_CORRUPT 0x40 /* IO->FMU bad packet reply */
+#define PKT_CODE_ERROR 0x80 /* IO->FMU register op error reply */
+
+#define PKT_CODE_MASK 0xc0
+#define PKT_COUNT_MASK 0x3f
+
+#define PKT_COUNT(_p) ((_p).count_code & PKT_COUNT_MASK)
+#define PKT_CODE(_p) ((_p).count_code & PKT_CODE_MASK)
+#define PKT_SIZE(_p) ((uint8_t *)&((_p).regs[PKT_COUNT(_p)]) - ((uint8_t *)&(_p)))
class PX4IO_serial : public PX4IO_interface
{
@@ -327,7 +337,7 @@ PX4IO_serial::set_reg(uint8_t page, uint8_t offset, const uint16_t *values, unsi
sem_wait(&_bus_semaphore);
- _dma_buffer.count = num_values | PKT_CTRL_WRITE;
+ _dma_buffer.count_code = num_values | PKT_CODE_WRITE;
_dma_buffer.spare = 0;
_dma_buffer.page = page;
_dma_buffer.offset = offset;
@@ -338,7 +348,7 @@ PX4IO_serial::set_reg(uint8_t page, uint8_t offset, const uint16_t *values, unsi
/* XXX implement check byte */
/* start the transaction and wait for it to complete */
- int result = _wait_complete(false, PKT_SIZE(num_values));
+ int result = _wait_complete(false, PKT_SIZE(_dma_buffer));
sem_post(&_bus_semaphore);
return result;
@@ -352,18 +362,18 @@ PX4IO_serial::get_reg(uint8_t page, uint8_t offset, uint16_t *values, unsigned n
sem_wait(&_bus_semaphore);
- _dma_buffer.count = num_values;
+ _dma_buffer.count_code = num_values | PKT_CODE_READ;
_dma_buffer.spare = 0;
_dma_buffer.page = page;
_dma_buffer.offset = offset;
/* start the transaction and wait for it to complete */
- int result = _wait_complete(true, PKT_SIZE(0));
+ int result = _wait_complete(true, PKT_SIZE(_dma_buffer));
if (result != OK)
goto out;
/* compare the received count with the expected count */
- if (_dma_buffer.count != num_values) {
+ if (PKT_COUNT(_dma_buffer) != num_values) {
return -EIO;
} else {
/* XXX implement check byte */
diff --git a/src/modules/px4iofirmware/serial.c b/src/modules/px4iofirmware/serial.c
index c109cb57f..64ca6195a 100644
--- a/src/modules/px4iofirmware/serial.c
+++ b/src/modules/px4iofirmware/serial.c
@@ -80,8 +80,7 @@ static unsigned idle_ticks;
#pragma pack(push, 1)
struct IOPacket {
- uint8_t count;
-#define PKT_CTRL_WRITE (1<<7)
+ uint8_t count_code;
uint8_t spare;
uint8_t page;
uint8_t offset;
@@ -89,6 +88,21 @@ struct IOPacket {
};
#pragma pack(pop)
+#define PKT_CODE_READ 0x00 /* FMU->IO read transaction */
+#define PKT_CODE_WRITE 0x40 /* FMU->IO write transaction */
+#define PKT_CODE_SUCCESS 0x00 /* IO->FMU success reply */
+#define PKT_CODE_CORRUPT 0x40 /* IO->FMU bad packet reply */
+#define PKT_CODE_ERROR 0x80 /* IO->FMU register op error reply */
+
+#define PKT_CODE_MASK 0xc0
+#define PKT_COUNT_MASK 0x3f
+
+#define PKT_COUNT(_p) ((_p).count_code & PKT_COUNT_MASK)
+#define PKT_CODE(_p) ((_p).count_code & PKT_CODE_MASK)
+#define PKT_SIZE(_p) ((uint8_t *)&((_p).regs[PKT_COUNT(_p)]) - ((uint8_t *)&(_p)))
+
+//static uint8_t crc_packet(void);
+
static struct IOPacket dma_packet;
/* serial register accessors */
@@ -192,12 +206,10 @@ rx_dma_callback(DMA_HANDLE handle, uint8_t status, void *arg)
perf_count(pc_rx);
/* default to not sending a reply */
- if (dma_packet.count & PKT_CTRL_WRITE) {
-
- dma_packet.count &= ~PKT_CTRL_WRITE;
+ if (PKT_CODE(dma_packet) == PKT_CODE_WRITE) {
/* it's a blind write - pass it on */
- if (registers_set(dma_packet.page, dma_packet.offset, &dma_packet.regs[0], dma_packet.count))
+ if (registers_set(dma_packet.page, dma_packet.offset, &dma_packet.regs[0], PKT_COUNT(dma_packet)))
perf_count(pc_regerr);
} else {
@@ -217,7 +229,7 @@ rx_dma_callback(DMA_HANDLE handle, uint8_t status, void *arg)
/* copy reply registers into DMA buffer */
memcpy((void *)&dma_packet.regs[0], registers, count);
- dma_packet.count = count;
+ dma_packet.count_code = count | PKT_CODE_SUCCESS;
}
/* re-set DMA for reception first, so we are ready to receive before we start sending */