X-Git-Url: https://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=decoders%2Fusb_power_delivery%2Fpd.py;h=3258ac329674e3ac8f1f0751e34c8e051fd0b55d;hp=034c4a904ccc125ed73a77c334aaf378cbbe4f74;hb=4539e9ca58966ce3c9cad4801b16c315e86ace01;hpb=033e7d4db76f2e2a289d5567e9532f26201cfa74 diff --git a/decoders/usb_power_delivery/pd.py b/decoders/usb_power_delivery/pd.py index 034c4a9..3258ac3 100644 --- a/decoders/usb_power_delivery/pd.py +++ b/decoders/usb_power_delivery/pd.py @@ -14,8 +14,7 @@ ## GNU General Public License for more details. ## ## You should have received a copy of the GNU General Public License -## along with this program; if not, write to the Free Software -## Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +## along with this program; if not, see . ## import sigrokdecode as srd @@ -178,8 +177,11 @@ VDM_CMDS = { } VDM_ACK = ['REQ', 'ACK', 'NAK', 'BSY'] +class SamplerateError(Exception): + pass + class Decoder(srd.Decoder): - api_version = 2 + api_version = 3 id = 'usb_power_delivery' name = 'USB PD' longname = 'USB Power Delivery' @@ -436,13 +438,11 @@ class Decoder(srd.Decoder): self.putwarn('No start of packet found', 'XXX') return -1 # No Start Of Packet - def __init__(self, **kwargs): + def __init__(self): self.samplerate = None self.idx = 0 self.packet_seq = 0 - self.samplenum = 0 self.previous = 0 - self.oldpins = [0] self.startsample = None self.bits = [] self.edges = [] @@ -468,8 +468,6 @@ class Decoder(srd.Decoder): ) def us2samples(self, us): - if not self.samplerate: - raise Exception('Need the samplerate.') return int(us * self.samplerate / 1000000) def decode_packet(self): @@ -524,17 +522,13 @@ class Decoder(srd.Decoder): bitrate = self.samplerate*len(self.bits) / float(es - ss) self.put(es, ss, self.out_bitrate, int(bitrate)) # Raw binary data (BMC decoded) - self.put(es, ss, self.out_binary, (0, bytes(self.bits))) + self.put(es, ss, self.out_binary, [0, bytes(self.bits)]) - def decode(self, ss, es, data): + def decode(self): if not self.samplerate: - raise Exception('Cannot decode without samplerate.') - for (self.samplenum, pins) in data: - # find edges ... - if self.oldpins == pins: - continue - - self.oldpins, (cc, ) = pins, pins + raise SamplerateError('Cannot decode without samplerate.') + while True: + self.wait({0: 'e'}) # First sample of the packet, just record the start date if not self.startsample: