diff options
author | stephan.thiele <stephan.thiele@mailbox.org> | 2019-02-28 21:33:56 +0100 |
---|---|---|
committer | Uwe Hermann <uwe@hermann-uwe.de> | 2019-10-06 23:38:45 +0200 |
commit | 6c890c087168b929a3017613b6ebfb7822a4f0fa (patch) | |
tree | 511a71c6a30a86a59c5ab4bc62271c5f538c326d /decoders | |
parent | 655f8b16205bfb9de7a20a659bc1ee56bc164ce7 (diff) | |
download | libsigrokdecode-6c890c087168b929a3017613b6ebfb7822a4f0fa.tar.gz libsigrokdecode-6c890c087168b929a3017613b6ebfb7822a4f0fa.zip |
can: proper annotation on CAN-FD extended frames
Diffstat (limited to 'decoders')
-rw-r--r-- | decoders/can/pd.py | 21 |
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']]) |