From: Luke Kenneth Casson Leighton Date: Wed, 20 Feb 2019 02:52:10 +0000 (+0000) Subject: make module out of overflow class X-Git-Tag: ls180-24jan2020~1859 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6d1c948b67f7155ab63475032b38ea5e3fdb99e3;p=ieee754fpu.git make module out of overflow class --- diff --git a/src/add/fpbase.py b/src/add/fpbase.py index fff94450..a680730c 100644 --- a/src/add/fpbase.py +++ b/src/add/fpbase.py @@ -232,6 +232,15 @@ class Overflow: self.guard = Signal(reset_less=True) # tot[2] self.round_bit = Signal(reset_less=True) # tot[1] self.sticky = Signal(reset_less=True) # tot[0] + self.m0 = Signal(reset_less=True) # mantissa zero bit + + self.roundz = Signal(reset_less=True) + + def elaborate(self, platform): + m = Module() + m.d.comb += self.roundz.eq(self.guard & \ + (self.round_bit | self.sticky | self.m0)) + return m class FPBase: @@ -299,6 +308,7 @@ class FPBase: z.m[0].eq(of.guard), # steal guard bit (was tot[2]) of.guard.eq(of.round_bit), # steal round_bit (was tot[1]) of.round_bit.eq(0), # reset round bit + of.m0.eq(of.guard), ] with m.Else(): m.next = next_state @@ -316,6 +326,7 @@ class FPBase: z.e.eq(z.e + 1), # INCREASE exponent z.m.eq(z.m >> 1), # shift mantissa DOWN of.guard.eq(z.m[0]), + of.m0.eq(z.m[1]), of.round_bit.eq(of.guard), of.sticky.eq(of.sticky | of.round_bit) ] @@ -326,9 +337,7 @@ class FPBase: """ performs rounding on the output. TODO: different kinds of rounding """ m.next = next_state - roundz = Signal(reset_less=True) - m.d.comb += roundz.eq(of.guard & (of.round_bit | of.sticky | z.m[0])) - with m.If(roundz): + with m.If(of.roundz): m.d.sync += z.m.eq(z.m + 1) # mantissa rounds up with m.If(z.m == z.m1s): # all 1s m.d.sync += z.e.eq(z.e + 1) # exponent rounds up diff --git a/src/add/nmigen_add_experiment.py b/src/add/nmigen_add_experiment.py index 1a28ba91..9f172cc8 100644 --- a/src/add/nmigen_add_experiment.py +++ b/src/add/nmigen_add_experiment.py @@ -38,6 +38,8 @@ class FPADD(FPBase): of = Overflow() + m.submodules.overflow = of + with m.FSM() as fsm: # ****** @@ -205,6 +207,7 @@ class FPADD(FPBase): with m.If(tot[-1]): m.d.sync += [ z.m.eq(tot[4:]), + of.m0.eq(tot[4]), of.guard.eq(tot[3]), of.round_bit.eq(tot[2]), of.sticky.eq(tot[1] | tot[0]), @@ -214,6 +217,7 @@ class FPADD(FPBase): with m.Else(): m.d.sync += [ z.m.eq(tot[3:]), + of.m0.eq(tot[3]), of.guard.eq(tot[2]), of.round_bit.eq(tot[1]), of.sticky.eq(tot[0])