from fpbase import FPNumIn, FPNumOut, FPOp, Overflow, FPBase
+from singlepipe import eq
+
class FPADD(FPBase):
self.in_b = FPOp(width)
self.out_z = FPOp(width)
- def get_fragment(self, platform=None):
+ def elaborate(self, platform=None):
""" creates the HDL code-fragment for FPAdd
"""
m = Module()
# gets operand a
with m.State("get_a"):
- self.get_op(m, self.in_a, a, "get_b")
+ res = self.get_op(m, self.in_a, a, "get_b")
+ m.d.sync += eq([a, self.in_a.ack], res)
# ******
# gets operand b
with m.State("get_b"):
- self.get_op(m, self.in_b, b, "special_cases")
+ res = self.get_op(m, self.in_b, b, "special_cases")
+ m.d.sync += eq([b, self.in_b.ack], res)
# ******
# special cases: NaNs, infs, zeros, denormalised