X-Git-Url: http://sigrok.org/gitweb/?p=libsigrokdecode.git;a=blobdiff_plain;f=decoders%2Fpwm%2Fpd.py;fp=decoders%2Fpwm%2Fpd.py;h=5822f32e82c6c41a4ca861f43721044ac1fa1bd2;hp=0b7be458d881302e368bd778af0e5c4b2252ad8a;hb=2dda726be82e97887b8c3958d5a54dd9125265ad;hpb=23e806c21e6e01999163c892635c6dea9d788daa diff --git a/decoders/pwm/pd.py b/decoders/pwm/pd.py index 0b7be45..5822f32 100644 --- a/decoders/pwm/pd.py +++ b/decoders/pwm/pd.py @@ -93,10 +93,8 @@ class Decoder(srd.Decoder): def decode(self): - # Get the first rising edge. - pin, = self.wait({0: 'e'}) - if pin != self.startedge: - pin, = self.wait({0: 'e'}) + # Wait for an "active" edge (depends on config). + self.wait({0: 'f' if self.startedge == 0 else 'r'}) self.first_samplenum = self.samplenum self.start_samplenum = self.samplenum @@ -105,7 +103,7 @@ class Decoder(srd.Decoder): pin, = self.wait({0: 'e'}) if pin == self.startedge: - # Rising edge + # Active edge # We are on a full cycle we can calculate # the period, the duty cycle and its ratio. period = self.samplenum - self.start_samplenum @@ -135,5 +133,5 @@ class Decoder(srd.Decoder): self.put(self.first_samplenum, self.es_block, self.out_average, float(self.average / self.num_cycles)) else: - # Falling edge + # Non-active edge self.end_samplenum = self.ss_block = self.samplenum