summaryrefslogtreecommitdiff
path: root/decoders/swd
diff options
context:
space:
mode:
authorUwe Hermann <uwe@hermann-uwe.de>2016-08-26 15:20:17 +0200
committerUwe Hermann <uwe@hermann-uwe.de>2016-12-07 22:45:47 +0100
commite809f7bc100f2d67bc45f35ce8fc3f01dc6684c0 (patch)
tree6c7e58341c461964dc65c206ef306854ea739a3a /decoders/swd
parente500b376b5cf74f4862688f310b9b8008bfc3eea (diff)
downloadlibsigrokdecode-e809f7bc100f2d67bc45f35ce8fc3f01dc6684c0.tar.gz
libsigrokdecode-e809f7bc100f2d67bc45f35ce8fc3f01dc6684c0.zip
swd: Convert to PD API version 3.
Diffstat (limited to 'decoders/swd')
-rw-r--r--decoders/swd/pd.py12
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.