summaryrefslogtreecommitdiff
path: root/decoders
diff options
context:
space:
mode:
authorUwe Hermann <uwe@hermann-uwe.de>2012-01-05 20:26:54 +0100
committerUwe Hermann <uwe@hermann-uwe.de>2012-01-05 20:26:54 +0100
commitea42f53ece1b82434ba6f5f43e23560b81c102bc (patch)
tree7a19b6b9881d2227bdbb94ee19f97a3ecc57b56f /decoders
parent6b5b91d27aba833af9804bdf9b755790931d2800 (diff)
downloadlibsigrokdecode-ea42f53ece1b82434ba6f5f43e23560b81c102bc.tar.gz
libsigrokdecode-ea42f53ece1b82434ba6f5f43e23560b81c102bc.zip
srd: Update USB decoder to the new API.
Diffstat (limited to 'decoders')
-rw-r--r--decoders/srd_usb.py32
1 files changed, 11 insertions, 21 deletions
diff --git a/decoders/srd_usb.py b/decoders/srd_usb.py
index 2db0158..4792eeb 100644
--- a/decoders/srd_usb.py
+++ b/decoders/srd_usb.py
@@ -40,18 +40,7 @@
# http://www.usb.org/developers/docs/
#
-import sigrok
-
-class Sample():
- def __init__(self, data):
- self.data = data
- def probe(self, probe):
- s = self.data[int(probe / 8)] & (1 << (probe % 8))
- return True if s else False
-
-def sampleiter(data, unitsize):
- for i in range(0, len(data), unitsize):
- yield(Sample(data[i:i+unitsize]))
+import sigrokdecode
# States
SE0, J, K, SE1 = 0, 1, 2, 3
@@ -110,7 +99,7 @@ def packet_decode(packet):
return pid + ' ' + data
-class Decoder(sigrok.Decoder):
+class Decoder(sigrokdecode.Decoder):
id = 'usb'
name = 'USB'
desc = 'Universal Serial Bus'
@@ -122,16 +111,17 @@ class Decoder(sigrok.Decoder):
inputs = ['logic']
outputs = ['usb']
# Probe names with a set of defaults
- probes = {'dp':0, 'dm':1}
+ probes = [
+ {'id': 'dp', 'name': 'D+', 'desc': 'USB D+ signal'},
+ {'id': 'dm', 'name': 'D-', 'desc': 'USB D- signal'},
+ ]
options = {}
def __init__(self):
- self.probes = Decoder.probes.copy()
self.output_protocol = None
self.output_annotation = None
def start(self, metadata):
- self.unitsize = metadata['unitsize']
self.rate = metadata['samplerate']
# self.output_protocol = self.output_new(2)
self.output_annotation = self.output_new(1)
@@ -145,12 +135,12 @@ class Decoder(sigrok.Decoder):
def decode(self, timeoffset, duration, data):
out = []
- for sample in sampleiter(data, self.unitsize):
+ # FIXME
+ for (samplenum, (dp, dm, x, y, z, a)) in data:
self.scount += 1
- sym = syms[sample.probe(self.probes['dp']),
- sample.probe(self.probes['dm'])]
+ sym = syms[dp, dm]
if sym == self.sym:
continue
@@ -192,6 +182,6 @@ class Decoder(sigrok.Decoder):
self.sym = sym
if out != []:
- # self.put(self.output_protocol, 0, 0, out_proto)
- self.put(self.output_annotation, 0, 0, out)
+ # self.put(0, 0, self.output_protocol, out_proto)
+ self.put(0, 0, self.output_annotation, out)