}
ANN_REG = 0
+ANN_WARN = 1
class Decoder(srd.Decoder):
api_version = 3
tags = ['Clock/timing', 'IC', 'Wireless/RF']
annotations = (
# Sent from the host to the chip.
- ('register', 'Register written to the device'),
+ ('write', 'Register write'),
+ ('warning', "Warnings"),
)
annotation_rows = (
- ('registers', 'Register writes', (ANN_REG,)),
+ ('writes', 'Register writes', (ANN_REG,)),
+ ('warnings', 'Warnings', (ANN_WARN,)),
)
def __init__(self):
def reset(self):
self.bits = []
+ self.packet_start = 0
def start(self):
self.out_ann = self.register(srd.OUTPUT_ANN)
def decode(self, ss, es, data):
- ptype, data1, data2 = data
+ ptype, _, _ = data
if ptype == 'CS-CHANGE':
- if data1 == 1:
+ _, 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,
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(self.packet_start, es, self.out_ann, [ANN_WARN, [error, 'Frame error']])
self.bits = []
+ else:
+ # Start of a new register write packet
+ self.packet_start = ss
+
if ptype == 'BITS':
- self.bits = data1 + self.bits
+ _, mosi_bits, miso_bits = data
+ self.bits = mosi_bits + self.bits