Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
F
Firmware
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Alberto Ruiz Garcia
Firmware
Commits
31323156
Commit
31323156
authored
11 years ago
by
px4dev
Browse files
Options
Downloads
Patches
Plain Diff
Encode the packet type and result in the unused high bits of the word count.
parent
e55a3769
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
src/drivers/px4io/interface_serial.cpp
+18
-8
18 additions, 8 deletions
src/drivers/px4io/interface_serial.cpp
src/modules/px4iofirmware/serial.c
+19
-7
19 additions, 7 deletions
src/modules/px4iofirmware/serial.c
with
37 additions
and
15 deletions
src/drivers/px4io/interface_serial.cpp
+
18
−
8
View file @
31323156
...
...
@@ -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_C
TRL
_WRITE
;
_dma_buffer
.
count
_code
=
num_values
|
PKT_C
ODE
_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 */
...
...
This diff is collapsed.
Click to expand it.
src/modules/px4iofirmware/serial.c
+
19
−
7
View file @
31323156
...
...
@@ -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 */
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment