X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=decoders%2Fadf435x%2Fpd.py;h=8c31648b873707d929a4fd01b26b078c364b2851;hb=317eaa7fd83fb049db97e863a306992a34fcf490;hp=3cc74b64ea79c136d462e68cf557977908d4753e;hpb=53cbedf5852028f54891066b0a5e698c4dd0c42a;p=libsigrokdecode.git diff --git a/decoders/adf435x/pd.py b/decoders/adf435x/pd.py index 3cc74b6..8c31648 100644 --- a/decoders/adf435x/pd.py +++ b/decoders/adf435x/pd.py @@ -18,6 +18,7 @@ ## import sigrokdecode as srd +from common.srdhelper import bitpack_lsb def disabled_enabled(v): return ['Disabled', 'Enabled'][v] @@ -86,6 +87,7 @@ regs = { } ANN_REG = 0 +ANN_WARN = 1 class Decoder(srd.Decoder): api_version = 3 @@ -100,9 +102,11 @@ class Decoder(srd.Decoder): annotations = ( # Sent from the host to the chip. ('write', 'Register write'), + ('warning', "Warnings"), ) annotation_rows = ( ('writes', 'Register writes', (ANN_REG,)), + ('warnings', 'Warnings', (ANN_WARN,)), ) def __init__(self): @@ -115,8 +119,10 @@ class Decoder(srd.Decoder): self.out_ann = self.register(srd.OUTPUT_ANN) def decode_bits(self, offset, width): - return (sum([(1 << i) if self.bits[offset + i][0] else 0 for i in range(width)]), - (self.bits[offset + width - 1][1], self.bits[offset][2])) + bits = self.bits[offset:][:width] + ss, es = bits[-1][1], bits[0][2] + value = bitpack_lsb(bits, 0) + return ( value, ( ss, es, )) def decode_field(self, name, offset, width, parser): val, pos = self.decode_bits(offset, width) @@ -125,22 +131,23 @@ class Decoder(srd.Decoder): return val def decode(self, ss, es, data): - ptype, _, _ = data - if ptype == 'CS-CHANGE': - _, cs_before, cs_after = data - if cs_before == 1: - if len(self.bits) == 32: - reg_value, reg_pos = self.decode_bits(0, 3) - self.put(reg_pos[0], reg_pos[1], self.out_ann, [ANN_REG, - ['Register: %d' % reg_value, 'Reg: %d' % reg_value, - '[%d]' % reg_value]]) - if reg_value < len(regs): - field_descs = regs[reg_value] - for field_desc in field_descs: - field = self.decode_field(*field_desc) - self.bits = [] + if ptype == 'TRANSFER': + if len(self.bits) == 32: + reg_value, reg_pos = self.decode_bits(0, 3) + self.put(reg_pos[0], reg_pos[1], self.out_ann, [ANN_REG, + ['Register: %d' % reg_value, 'Reg: %d' % reg_value, + '[%d]' % reg_value]]) + if reg_value < len(regs): + field_descs = regs[reg_value] + for field_desc in field_descs: + field = self.decode_field(*field_desc) + else: + error = "Frame error: Wrong number of bits: got %d expected 32" % len(self.bits) + self.put(ss, es, self.out_ann, [ANN_WARN, [error, 'Frame error']]) + self.bits = [] + if ptype == 'BITS': _, mosi_bits, miso_bits = data self.bits = mosi_bits + self.bits