]> sigrok.org Git - libsigrokdecode.git/commitdiff
jitter: Convert to PD API version 3.
authorUwe Hermann <redacted>
Fri, 26 Aug 2016 13:14:40 +0000 (15:14 +0200)
committerUwe Hermann <redacted>
Wed, 7 Dec 2016 21:45:46 +0000 (22:45 +0100)
decoders/jitter/pd.py

index c3579a81ddc6809e76a3d01fbcf991a9f3b52e5a..4fadbcbd23570ab08072030e5fc5c925a4910f93 100644 (file)
@@ -31,7 +31,7 @@ class SamplerateError(Exception):
     pass
 
 class Decoder(srd.Decoder):
-    api_version = 2
+    api_version = 3
     id = 'jitter'
     name = 'Jitter'
     longname = 'Timing jitter calculation'
@@ -66,8 +66,7 @@ class Decoder(srd.Decoder):
     def __init__(self):
         self.state = 'CLK'
         self.samplerate = None
-        self.oldpin = None
-        self.oldclk = self.oldsig = None
+        self.oldclk, self.oldsig = 0, 0
         self.clk_start = None
         self.sig_start = None
         self.clk_missed = 0
@@ -174,19 +173,12 @@ class Decoder(srd.Decoder):
             # everything we can with this sample.
             return True
 
-    def decode(self, ss, es, data):
+    def decode(self):
         if not self.samplerate:
             raise SamplerateError('Cannot decode without samplerate.')
-
-        for (self.samplenum, pins) in data:
-            # We are only interested in transitions.
-            if self.oldpin == pins:
-                continue
-
-            self.oldpin, (clk, sig) = pins, pins
-
-            if self.oldclk is None and self.oldsig is None:
-                self.oldclk, self.oldsig = clk, sig
+        while True:
+            # Wait for a transition on CLK and/or SIG.
+            clk, sig = self.wait([{0: 'e'}, {1: 'e'}])
 
             # State machine:
             # For each sample we can move 2 steps forward in the state machine.