diff options
author | Uwe Hermann <uwe@hermann-uwe.de> | 2016-08-26 15:20:17 +0200 |
---|---|---|
committer | Uwe Hermann <uwe@hermann-uwe.de> | 2016-12-07 22:45:47 +0100 |
commit | e809f7bc100f2d67bc45f35ce8fc3f01dc6684c0 (patch) | |
tree | 6c7e58341c461964dc65c206ef306854ea739a3a /decoders/swd | |
parent | e500b376b5cf74f4862688f310b9b8008bfc3eea (diff) | |
download | libsigrokdecode-e809f7bc100f2d67bc45f35ce8fc3f01dc6684c0.tar.gz libsigrokdecode-e809f7bc100f2d67bc45f35ce8fc3f01dc6684c0.zip |
swd: Convert to PD API version 3.
Diffstat (limited to 'decoders/swd')
-rw-r--r-- | decoders/swd/pd.py | 12 |
1 files changed, 5 insertions, 7 deletions
diff --git a/decoders/swd/pd.py b/decoders/swd/pd.py index 3414c35..9b318d2 100644 --- a/decoders/swd/pd.py +++ b/decoders/swd/pd.py @@ -65,7 +65,7 @@ BIT_CTRLSTAT_ORUNDETECT = 1 ANNOTATIONS = ['reset', 'enable', 'read', 'write', 'ack', 'data', 'parity'] class Decoder(srd.Decoder): - api_version = 2 + api_version = 3 id = 'swd' name = 'SWD' longname = 'Serial Wire Debug' @@ -95,7 +95,6 @@ class Decoder(srd.Decoder): def __init__(self): # SWD data/clock state self.state = 'UNKNOWN' - self.oldclk = -1 self.sample_edge = RISING self.ack = None # Ack state of the current phase self.ss_req = 0 # Start sample of current req @@ -142,11 +141,10 @@ class Decoder(srd.Decoder): }[(self.apdp, self.rw)] self.putp(ptype, (self.addr, self.data, self.ack)) - def decode(self, ss, es, data): - for (self.samplenum, (clk, dio)) in data: - if clk == self.oldclk: - continue # Not a clock edge. - self.oldclk = clk + def decode(self): + while True: + # Wait for any clock edge. + clk, dio = self.wait({0: 'e'}) # Count rising edges with DIO held high, # as a line reset (50+ high edges) can happen from any state. |