From: Luke Kenneth Casson Leighton Date: Fri, 15 Mar 2019 09:59:07 +0000 (+0000) Subject: instantiate 2 FPGetOp instances and use them. a little awkwardly. X-Git-Tag: ls180-24jan2020~1655 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a36447fcd4d4f049b7127e1fc02dc1390d05fa75;p=ieee754fpu.git instantiate 2 FPGetOp instances and use them. a little awkwardly. --- diff --git a/src/add/nmigen_div_experiment.py b/src/add/nmigen_div_experiment.py index eb0c9351..e074c5c6 100644 --- a/src/add/nmigen_div_experiment.py +++ b/src/add/nmigen_div_experiment.py @@ -6,7 +6,7 @@ from nmigen import Module, Signal, Const, Cat from nmigen.cli import main, verilog from fpbase import FPNumIn, FPNumOut, FPOp, Overflow, FPBase -from nmigen_add_experiment import FPState +from nmigen_add_experiment import FPState, FPGetOp class Div: def __init__(self, width): @@ -66,14 +66,26 @@ class FPDIV(FPBase): # ****** # gets operand a + geta = FPGetOp("get_a", "get_b", self.in_a, self.width) + geta.setup(m, self.in_a) + with m.State("get_a"): - self.get_op(m, self.in_a, a, "get_b") + geta.action(m) + with m.If(geta.out_decode): + m.d.sync += a.decode(self.in_a.v) + #self.get_op(m, self.in_a, a, "get_b") # ****** # gets operand b + getb = FPGetOp("get_b", "special_cases", self.in_b, self.width) + getb.setup(m, self.in_b) + with m.State("get_b"): - self.get_op(m, self.in_b, b, "special_cases") + getb.action(m) + with m.If(getb.out_decode): + m.d.sync += b.decode(self.in_b.v) + #self.get_op(m, self.in_b, b, "special_cases") # ****** # special cases: NaNs, infs, zeros, denormalised