summaryrefslogtreecommitdiff
path: root/decoders
diff options
context:
space:
mode:
authorstephan.thiele <stephan.thiele@mailbox.org>2019-02-28 21:33:56 +0100
committerUwe Hermann <uwe@hermann-uwe.de>2019-10-06 23:38:45 +0200
commit6c890c087168b929a3017613b6ebfb7822a4f0fa (patch)
tree511a71c6a30a86a59c5ab4bc62271c5f538c326d /decoders
parent655f8b16205bfb9de7a20a659bc1ee56bc164ce7 (diff)
downloadlibsigrokdecode-6c890c087168b929a3017613b6ebfb7822a4f0fa.tar.gz
libsigrokdecode-6c890c087168b929a3017613b6ebfb7822a4f0fa.zip
can: proper annotation on CAN-FD extended frames
Diffstat (limited to 'decoders')
-rw-r--r--decoders/can/pd.py21
1 files changed, 16 insertions, 5 deletions
diff --git a/decoders/can/pd.py b/decoders/can/pd.py
index 2663b7d..8c417fd 100644
--- a/decoders/can/pd.py
+++ b/decoders/can/pd.py
@@ -65,7 +65,6 @@ class Decoder(srd.Decoder):
('fields', 'Fields', tuple(range(15))),
('warnings', 'Warnings', (16,)),
)
- fd = False
def __init__(self):
self.reset()
@@ -99,6 +98,10 @@ class Decoder(srd.Decoder):
def put12(self, data):
self.putg(self.ss_bit12, self.ss_bit12, data)
+ # Single-CAN-bit annotation using the samplenum of CAN bit 32.
+ def put32(self, data):
+ self.putg(self.ss_bit32, self.ss_bit32, data)
+
# Multi-CAN-bit annotation from self.ss_block to current samplenum.
def putb(self, data):
self.putg(self.ss_block, self.samplenum, data)
@@ -112,7 +115,10 @@ class Decoder(srd.Decoder):
self.last_databit = 999 # Positive value that bitnum+x will never match
self.ss_block = None
self.ss_bit12 = None
+ self.ss_bit32 = None
self.ss_databytebits = []
+ self.fd = False
+ self.rtr = None
# Poor man's clock synchronization. Use signal edges which change to
# dominant state in rather simple ways. This naive approach is neither
@@ -333,11 +339,13 @@ class Decoder(srd.Decoder):
# Remember start of RTR (see below).
if bitnum == 32:
- rtr = 'remote' if can_rx == 1 else 'data'
- self.putx([8, ['Remote transmission request: %s frame' % rtr,
- 'RTR: %s frame' % rtr, 'RTR']])
+ self.ss_bit32 = self.samplenum
+ self.rtr = can_rx
- # TODO: annotate as R1 on FD frame
+ if not self.fd:
+ rtr = 'remote' if can_rx == 1 else 'data'
+ self.putx([8, ['Remote transmission request: %s frame' % rtr,
+ 'RTR: %s frame' % rtr, 'RTR']])
# Bit 33: RB1 (reserved bit)
elif bitnum == 33:
@@ -347,6 +355,9 @@ class Decoder(srd.Decoder):
self.dlc_start = 37
self.putx([7, ['Flexible Data Format: %d' % can_rx,
'FDF: %d' % can_rx, 'FDF']])
+
+ self.put32([7, ['Reserved bit 1: %d' % self.rtr,
+ 'RB1: %d' % self.rtr, 'RB1']])
else:
self.putx([7, ['Reserved bit 1: %d' % can_rx,
'RB1: %d' % can_rx, 'RB1']])