From: Florent Kermarrec Date: Sun, 12 Aug 2012 17:42:25 +0000 (+0200) Subject: simplify EdgeDetector X-Git-Tag: 24jan2021_ls180~2575^2~176 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=051e8ac5702df95b4c1276c9f5c33f09d0c01328;p=litex.git simplify EdgeDetector --- diff --git a/migScope/__init__.py b/migScope/__init__.py index 7b7f4279..ea2fe628 100644 --- a/migScope/__init__.py +++ b/migScope/__init__.py @@ -65,26 +65,29 @@ class EdgeDetector: sync += [self.i_d.eq(self.i)] # Rising Edge if "R" in self.mode: + r_eq = [self.ro.eq(self.r_mask & self.i & (~self.i_d))] if self.pipe: - sync += [self.ro.eq(self.r_mask & self.i & (~self.i_d))] + sync += r_eq else: - comb += [self.ro.eq(self.r_mask & self.i & (~ self.i_d))] + comb += r_eq else: comb += [self.ro.eq(0)] # Falling Edge if "F" in self.mode: + f_eq = [self.fo.eq(self.f_mask & (~ self.i) & self.i_d)] if self.pipe: - sync += [self.fo.eq(self.f_mask & (~ self.i) & self.i_d)] + sync += f_eq else: - comb += [self.fo.eq(self.f_mask & (~ self.i) & self.i_d)] + comb += f_eq else: comb += [self.fo.eq(0)] # Both if "B" in self.mode: + b_eq = [self.bo.eq(self.b_mask & self.i != self.i_d)] if self.pipe: - sync += [self.bo.eq(self.b_mask & self.i != self.i_d)] + sync += b_eq else: - comb += [self.bo.eq(self.b_mask & self.i != self.i_d)] + comb += b_eq else: comb += [self.bo.eq(0)] #Output