diff --git a/.gitignore b/.gitignore index a8ccd80..407020e 100644 --- a/.gitignore +++ b/.gitignore @@ -65,3 +65,6 @@ log vivado_* tight_setup_hold_pins.txt .Xil + +# Verilator debug output +simulation_dump.vcd diff --git a/Cargo.lock b/Cargo.lock index 1e0609d..2725653 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -44,6 +44,16 @@ version = "1.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6548a0ad5d2549e111e1f6a11a6c2e2d00ce6a3dafe22948d67c2b443f775e52" +[[package]] +name = "debug-test" +version = "0.1.0" +dependencies = [ + "heapless", + "panic-halt", + "riscv", + "riscv-rt", +] + [[package]] name = "embedded-hal" version = "0.2.7" diff --git a/Cargo.toml b/Cargo.toml index 596decd..10b2165 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -13,5 +13,6 @@ opt-level = "z" [workspace] members = [ "clash-vexriscv-sim/test-programs", + "debug-test", ] resolver = "2" diff --git a/cabal.project b/cabal.project index 253c2a3..eb88ec9 100644 --- a/cabal.project +++ b/cabal.project @@ -7,7 +7,6 @@ packages: clash-vexriscv-sim/ write-ghc-environment-files: always - tests: True diff --git a/clash-vexriscv-sim/app/HdlTest.hs b/clash-vexriscv-sim/app/HdlTest.hs index b82c153..f04dd29 100644 --- a/clash-vexriscv-sim/app/HdlTest.hs +++ b/clash-vexriscv-sim/app/HdlTest.hs @@ -10,10 +10,13 @@ import VexRiscv circuit :: "CLK" ::: Clock System -> "RST" ::: Reset System -> - "INPUT" ::: Signal System Input -> - "OUTPUT" ::: Signal System Output -circuit clk rst input = - withClockResetEnable clk rst enableGen vexRiscv input + "CPU_COMB_INPUT" ::: Signal System CpuIn -> + "JTAG_IN_" ::: Signal System JtagIn -> + "" ::: + ( "CPU_OUTPUT" ::: Signal System CpuOut + , "JTAG_OUT_" ::: Signal System JtagOut) +circuit clk rst input jtagIn = + vexRiscv clk rst input jtagIn makeTopEntity 'circuit diff --git a/clash-vexriscv-sim/app/VexRiscvSimulation.hs b/clash-vexriscv-sim/app/VexRiscvSimulation.hs index fcfabdc..e927ee7 100644 --- a/clash-vexriscv-sim/app/VexRiscvSimulation.hs +++ b/clash-vexriscv-sim/app/VexRiscvSimulation.hs @@ -5,16 +5,18 @@ {-# LANGUAGE MultiWayIf #-} {-# LANGUAGE GADTs #-} +{-# OPTIONS_GHC -fconstraint-solver-iterations=10 #-} + import Clash.Prelude import Protocols.Wishbone -import VexRiscv (Output(iBusWbM2S, dBusWbM2S)) +import VexRiscv (CpuOut(iBusWbM2S, dBusWbM2S)) import qualified Data.List as L import Control.Monad (forM_, when) import Data.Char (chr) -import Data.Maybe (catMaybes) +import Data.Maybe (catMaybes, fromMaybe) import System.Environment (getArgs) import System.IO (putChar, hFlush, stdout) import Text.Printf (printf) @@ -22,6 +24,7 @@ import Text.Printf (printf) import Utils.ProgramLoad (loadProgram) import Utils.Cpu (cpu) +import System.Exit (exitFailure) -------------------------------------- -- @@ -59,9 +62,9 @@ debugConfig = -- {- InspectBusses - 50 0 - (Just 300) + 0 + (Just 100) True True -- -} @@ -77,37 +80,58 @@ main = do withClockResetEnable @System clockGen resetGen enableGen $ loadProgram @System elfFile - let cpuOut@(unbundle -> (_circuit, writes, iBus, dBus)) = + let cpuOut@(unbundle -> (_circuit, writes, _iBus, _dBus)) = withClockResetEnable @System clockGen (resetGenN (SNat @2)) enableGen $ - bundle (cpu iMem dMem) + let (circ, writes1, iBus, dBus) = cpu (Just 7894) iMem dMem + dBus' = register Nothing dBus + in bundle (circ, writes1, iBus, dBus') case debugConfig of RunCharacterDevice -> - forM_ (sample_lazy @System (bundle (dBus, iBus, writes))) $ \(dS2M, iS2M, write) -> do - when (err dS2M) $ - putStrLn "D-bus ERR reply" + forM_ (sample_lazy @System (bundle (register @System (unpack 0) cpuOut, cpuOut))) $ + \((_out, write, dS2M0, iS2M0), (out1, _write, _dS2M, _iS2M)) -> do + let + iS2M = fromMaybe emptyWishboneS2M iS2M0 + dS2M = fromMaybe emptyWishboneS2M dS2M0 + + when (err dS2M) $ do + let dBusM2S = dBusWbM2S out1 + let dAddr = toInteger (addr dBusM2S) -- `shiftL` 2 + printf "D-bus ERR reply % 8X (% 8X)\n" (toInteger $ dAddr `shiftL` 2) (toInteger dAddr) + exitFailure + pure () + + when (err iS2M) $ do + let iBusM2S = iBusWbM2S out1 + let iAddr = toInteger (addr iBusM2S) -- `shiftL` 2 + printf "I-bus ERR reply % 8X (% 8X)\n" (toInteger $ iAddr `shiftL` 2) (toInteger iAddr) + printf "%s\n" (showX iBusM2S) + exitFailure + pure () - when (err iS2M) $ - putStrLn "I-bus ERR reply" - case write of Just (address, value) | address == 0x0000_1000 -> do let (_ :: BitVector 24, b :: BitVector 8) = unpack value putChar $ chr (fromEnum b) hFlush stdout + pure () _ -> pure () -- performPrintsToStdout 0x0000_1000 (sample_lazy $ bitCoerce <$> writes) InspectBusses initCycles uninteresting interesting iEnabled dEnabled -> do - + let skipTotal = initCycles + uninteresting let sampled = case interesting of Nothing -> L.zip [0 ..] $ sample_lazy @System cpuOut Just nInteresting -> - let total = initCycles + uninteresting + nInteresting in L.zip [0 ..] $ L.take total $ sample_lazy @System cpuOut + let total = initCycles + uninteresting + nInteresting in + L.zip [0 ..] $ L.take total $ sample_lazy @System cpuOut - forM_ sampled $ \(i, (out, _, iBusS2M, dBusS2M)) -> do - let doPrint = i >= skipTotal + forM_ sampled $ \(i, (out, _, iBusS2M0, dBusS2M0)) -> do + let + iBusS2M = fromMaybe emptyWishboneS2M iBusS2M0 + dBusS2M = fromMaybe emptyWishboneS2M dBusS2M0 + doPrint = i >= skipTotal -- I-bus interactions @@ -143,6 +167,9 @@ main = do <> ")" putStrLn $ " - iS2M: " <> iResp <> " - " <> iRespData + when (err iBusS2M) + exitFailure + -- D-bus interactions when (doPrint && dEnabled) $ do @@ -192,6 +219,9 @@ main = do <> writeDat <> "> - " putStrLn $ "dS2M: " <> dResp <> dRespData + + when (err dBusS2M) + exitFailure InspectWrites -> forM_ (catMaybes $ sample_lazy @System writes) $ \(address, value) -> do printf "W: % 8X <- % 8X\n" (toInteger address) (toInteger value) diff --git a/clash-vexriscv-sim/src/Utils/Cpu.hs b/clash-vexriscv-sim/src/Utils/Cpu.hs index 325492c..6c90b0f 100644 --- a/clash-vexriscv-sim/src/Utils/Cpu.hs +++ b/clash-vexriscv-sim/src/Utils/Cpu.hs @@ -5,12 +5,16 @@ {-# LANGUAGE ApplicativeDo #-} {-# LANGUAGE NumericUnderscores #-} {-# LANGUAGE RecordWildCards #-} + +{-# OPTIONS_GHC -Wno-orphans #-} + module Utils.Cpu where import Clash.Prelude import Protocols.Wishbone import VexRiscv +import VexRiscv.JtagTcpBridge as JTag import VexRiscv.VecToTuple (vecToTuple) import GHC.Stack (HasCallStack) @@ -18,6 +22,8 @@ import GHC.Stack (HasCallStack) import Utils.ProgramLoad (Memory) import Utils.Interconnect (interconnectTwo) +createDomain vXilinxSystem{vName="Basic50", vPeriod= hzToPeriod 50_000_000} + {- Address space @@ -27,24 +33,39 @@ Address space -} cpu :: (HasCallStack, HiddenClockResetEnable dom) => + Maybe Integer -> Memory dom -> Memory dom -> - ( Signal dom Output, + ( Signal dom CpuOut, -- writes Signal dom (Maybe (BitVector 32, BitVector 32)), -- iBus responses - Signal dom (WishboneS2M (BitVector 32)), + Signal dom (Maybe (WishboneS2M (BitVector 32))), -- dBus responses - Signal dom (WishboneS2M (BitVector 32)) + Signal dom (Maybe (WishboneS2M (BitVector 32))) + ) +cpu jtagPort bootIMem bootDMem = + ( output + , writes + , mux validI (Just <$> iS2M) (pure Nothing) + , mux validD (Just <$> dS2M) (pure Nothing) ) -cpu bootIMem bootDMem = (output, writes, iS2M, dS2M) where - output = vexRiscv input + (output, jtagOut) = vexRiscv hasClock hasReset input jtagIn + + jtagIn = case jtagPort of + Just port -> vexrJtagBridge (fromInteger port) jtagOut + Nothing -> pure JTag.defaultIn + -- (unbundle -> (jtagIn', _debugReset)) = unsafePerformIO $ jtagTcpBridge' 7894 hasReset (jtagOut <$> output) + dM2S = dBusWbM2S <$> output + validD = fmap busCycle dM2S .&&. fmap strobe dM2S iM2S = unBusAddr . iBusWbM2S <$> output + validI = fmap busCycle iM2S .&&. fmap strobe iM2S - iS2M = bootIMem (mapAddr (\x -> x - 0x2000_0000) <$> iM2S) + iS2M = bootIMem (mapAddr (\x -> -- trace (printf "I-addr = % 8X (% 8X)\n" (toInteger $ x - 0x2000_0000) (toInteger x)) + x - 0x2000_0000) <$> iM2S) dummy = dummyWb @@ -52,12 +73,14 @@ cpu bootIMem bootDMem = (output, writes, iS2M, dS2M) bootDS2M = bootDMem bootDM2S (dS2M, vecToTuple . unbundle -> (dummyM2S, bootDM2S)) = interconnectTwo - (unBusAddr <$> dM2S) + ((\x -> + -- trace (printf "DBUS %08X" (toInteger (addr x))) + x) <$> (unBusAddr <$> dM2S)) ((0x0000_0000, dummyS2M) :> (0x4000_0000, bootDS2M) :> Nil) input = ( \iBus dBus -> - Input + CpuIn { timerInterrupt = low, externalInterrupt = low, softwareInterrupt = low, diff --git a/clash-vexriscv-sim/src/Utils/Interconnect.hs b/clash-vexriscv-sim/src/Utils/Interconnect.hs index eea320b..5f09815 100644 --- a/clash-vexriscv-sim/src/Utils/Interconnect.hs +++ b/clash-vexriscv-sim/src/Utils/Interconnect.hs @@ -35,9 +35,12 @@ interconnectTwo m2s ((aAddr', aS2M') :> (bAddr', bS2M') :> Nil) = Vec 2 (WishboneM2S 32 4 (BitVector 32)) ) go m@WishboneM2S{..} aAddr aS2M bAddr bS2M - | not (busCycle && strobe) = (emptyWishboneS2M, m :> m :> Nil) - | addr >= bAddr = (bS2M, emptyWishboneM2S :> m { addr = addr - bAddr } :> Nil) - | addr >= aAddr = (aS2M, m { addr = addr - aAddr } :> emptyWishboneM2S :> Nil) + | not (busCycle && strobe) = + (emptyWishboneS2M, m :> m :> Nil) + | addr >= bAddr = + (bS2M, emptyWishboneM2S :> m { addr = addr - bAddr } :> Nil) + | addr >= aAddr = + (aS2M, m { addr = addr - aAddr } :> emptyWishboneM2S :> Nil) | otherwise = ( emptyWishboneS2M { err = True }, emptyWishboneM2S :> emptyWishboneM2S :> Nil diff --git a/clash-vexriscv-sim/tests/tests.hs b/clash-vexriscv-sim/tests/tests.hs index 03af70d..23283e4 100644 --- a/clash-vexriscv-sim/tests/tests.hs +++ b/clash-vexriscv-sim/tests/tests.hs @@ -39,7 +39,7 @@ runProgramExpect act n expected = withSystemTempFile "ELF" $ \fp _ -> do let _all@(unbundle -> (_circuit, writes, _iBus, _dBus)) = withClockResetEnable @System clockGen (resetGenN (SNat @2)) enableGen $ - bundle (cpu iMem dMem) + bundle (cpu Nothing iMem dMem) let output = L.take (BS.length expected) $ flip mapMaybe (sampleN_lazy n writes) $ \case diff --git a/clash-vexriscv/Makefile b/clash-vexriscv/Makefile index db1a711..a909e6b 100644 --- a/clash-vexriscv/Makefile +++ b/clash-vexriscv/Makefile @@ -7,13 +7,12 @@ OUT_DIR = build_out_dir VERILATOR_DIR = $(OUT_DIR)/verilator_output FFI_DIR = src/ffi - -VERILATOR_FLAGS = -CFLAGS '-O3 -fPIC' -Wno-fatal +1364-2001ext+v +VERILATOR_FLAGS = -CFLAGS '-O3 -fPIC' -Wno-fatal +1364-2001ext+v --trace VERILATOR_CFLAGS = $(shell pkg-config --cflags verilator) FFI_CPPFLAGS = $(VERILATOR_CFLAGS) -fPIC -O3 -I$(VERILATOR_DIR) -all: $(OUT_DIR)/libVexRiscvFFI.a +all: $(OUT_DIR)/libVexRiscvFFI.a # $(OUT_DIR)/libVexRiscvFFI.so clean: rm $(VERILATOR_DIR) -rf @@ -23,6 +22,8 @@ clean: $(CPU_DIR)/VexRiscv.v: $(CPU_DIR)/src/main/scala/example/ExampleCpu.scala cd $(CPU_DIR); sbt "runMain example.ExampleCpu" cd $(CPU_DIR); sed -i -E '/\/\/ Git hash :.*$$/d' VexRiscv.v + # cd $(CPU_DIR); sed -i 's/module VexRiscv/module VexRiscvInner/g' VexRiscv.v + # cd $(CPU_DIR); cat ../example-cpu/VexRiscvWrapped.v >> VexRiscv.v $(OUT_DIR)/VexRiscv.v: $(CPU_DIR)/VexRiscv.v mkdir -p $(OUT_DIR) @@ -37,6 +38,10 @@ $(VERILATOR_DIR)/VVexRiscv__ALL.a: $(VERILATOR_DIR)/VVexRiscv.mk $(OUT_DIR)/impl.o: $(FFI_DIR)/impl.cpp $(FFI_DIR)/interface.h $(CXX) $(FFI_CPPFLAGS) -c $(FFI_DIR)/impl.cpp -o $(OUT_DIR)/impl.o +$(OUT_DIR)/verilated_vcd_c.o: $(shell pkg-config --variable=includedir verilator)/verilated_vcd_c.cpp + $(CXX) $(FFI_CPPFLAGS) -c $(shell pkg-config --variable=includedir verilator)/verilated_vcd_c.cpp -o $(OUT_DIR)/verilated_vcd_c.o + + $(OUT_DIR)/verilated.o: $(shell pkg-config --variable=includedir verilator)/verilated.cpp $(CXX) $(FFI_CPPFLAGS) -c $(shell pkg-config --variable=includedir verilator)/verilated.cpp -o $(OUT_DIR)/verilated.o @@ -46,11 +51,19 @@ $(OUT_DIR)/verilated_threads.o: $(shell pkg-config --variable=includedir verilat $(OUT_DIR)/VVexRiscv__ALL.a: $(VERILATOR_DIR)/VVexRiscv__ALL.a cp $(VERILATOR_DIR)/VVexRiscv__ALL.a $(OUT_DIR)/VVexRiscv__ALL.a -$(OUT_DIR)/libVexRiscvFFI.a: $(OUT_DIR)/VVexRiscv__ALL.a $(OUT_DIR)/impl.o $(OUT_DIR)/verilated.o $(OUT_DIR)/verilated_threads.o +$(OUT_DIR)/libVexRiscvFFI.a: $(OUT_DIR)/VVexRiscv__ALL.a $(OUT_DIR)/impl.o $(OUT_DIR)/verilated.o $(OUT_DIR)/verilated_threads.o $(OUT_DIR)/verilated_vcd_c.o rm -f $(OUT_DIR)/libVexRiscvFFI.a cp $(OUT_DIR)/VVexRiscv__ALL.a $(OUT_DIR)/libVexRiscvFFI.a ar r \ $(OUT_DIR)/libVexRiscvFFI.a \ $(OUT_DIR)/impl.o \ $(OUT_DIR)/verilated.o \ - $(OUT_DIR)/verilated_threads.o + $(OUT_DIR)/verilated_threads.o \ + $(OUT_DIR)/verilated_vcd_c.o + +$(OUT_DIR)/libVexRiscvFFI.so: $(OUT_DIR)/libVexRiscvFFI.a + rm -f $(OUT_DIR)/libVexRiscvFFI.so + $(CXX) -shared -o $(OUT_DIR)/libVexRiscvFFI.so \ + -Wl,--whole-archive \ + $(OUT_DIR)/libVexRiscvFFI.a \ + -Wl,--no-whole-archive diff --git a/clash-vexriscv/clash-vexriscv.cabal b/clash-vexriscv/clash-vexriscv.cabal index d761071..4ae60fb 100644 --- a/clash-vexriscv/clash-vexriscv.cabal +++ b/clash-vexriscv/clash-vexriscv.cabal @@ -104,6 +104,7 @@ library VexRiscv VexRiscv.ClockTicks VexRiscv.FFI + VexRiscv.JtagTcpBridge VexRiscv.TH VexRiscv.VecToTuple @@ -116,6 +117,7 @@ library directory >= 1.3 && < 1.4, filepath, Glob, + network, process >= 1.6 && < 1.8, string-interpolate, tagged, diff --git a/clash-vexriscv/example-cpu/ExampleCpu.yaml b/clash-vexriscv/example-cpu/ExampleCpu.yaml new file mode 100644 index 0000000..3eeb252 --- /dev/null +++ b/clash-vexriscv/example-cpu/ExampleCpu.yaml @@ -0,0 +1 @@ +debug: !!vexriscv.DebugReport {hardwareBreakpointCount: 0} diff --git a/clash-vexriscv/example-cpu/VexRiscv.v b/clash-vexriscv/example-cpu/VexRiscv.v index 9f4089f..9fc3097 100644 --- a/clash-vexriscv/example-cpu/VexRiscv.v +++ b/clash-vexriscv/example-cpu/VexRiscv.v @@ -7,6 +7,7 @@ module VexRiscv ( input timerInterrupt, input externalInterrupt, input softwareInterrupt, + output debug_resetOut, output iBusWishbone_CYC, output iBusWishbone_STB, input iBusWishbone_ACK, @@ -25,29 +26,17 @@ module VexRiscv ( output [29:0] dBusWishbone_ADR, input [31:0] dBusWishbone_DAT_MISO, output [31:0] dBusWishbone_DAT_MOSI, - output [3:0] dBusWishbone_SEL, + output reg [3:0] dBusWishbone_SEL, input dBusWishbone_ERR, output [2:0] dBusWishbone_CTI, output [1:0] dBusWishbone_BTE, + input jtag_tms, + input jtag_tdi, + output jtag_tdo, + input jtag_tck, input clk, input reset ); - localparam FpuOpcode_LOAD = 4'd0; - localparam FpuOpcode_STORE = 4'd1; - localparam FpuOpcode_MUL = 4'd2; - localparam FpuOpcode_ADD = 4'd3; - localparam FpuOpcode_FMA = 4'd4; - localparam FpuOpcode_I2F = 4'd5; - localparam FpuOpcode_F2I = 4'd6; - localparam FpuOpcode_CMP = 4'd7; - localparam FpuOpcode_DIV = 4'd8; - localparam FpuOpcode_SQRT = 4'd9; - localparam FpuOpcode_MIN_MAX = 4'd10; - localparam FpuOpcode_SGNJ = 4'd11; - localparam FpuOpcode_FMV_X_W = 4'd12; - localparam FpuOpcode_FMV_W_X = 4'd13; - localparam FpuOpcode_FCLASS = 4'd14; - localparam FpuOpcode_FCVT_X_X = 4'd15; localparam BranchCtrlEnum_INC = 2'd0; localparam BranchCtrlEnum_B = 2'd1; localparam BranchCtrlEnum_JAL = 2'd2; @@ -73,35 +62,8 @@ module VexRiscv ( localparam Src1CtrlEnum_IMU = 2'd1; localparam Src1CtrlEnum_PC_INCREMENT = 2'd2; localparam Src1CtrlEnum_URS1 = 2'd3; - localparam FpuFormat_FLOAT = 1'd0; - localparam FpuFormat_DOUBLE = 1'd1; - localparam FpuRoundMode_RNE = 3'd0; - localparam FpuRoundMode_RTZ = 3'd1; - localparam FpuRoundMode_RDN = 3'd2; - localparam FpuRoundMode_RUP = 3'd3; - localparam FpuRoundMode_RMM = 3'd4; wire IBusSimplePlugin_rspJoin_rspBuffer_c_io_pop_ready; - wire dataCache_1_io_cpu_execute_isValid; - wire [31:0] dataCache_1_io_cpu_execute_address; - wire dataCache_1_io_cpu_memory_isValid; - wire [31:0] dataCache_1_io_cpu_memory_address; - reg dataCache_1_io_cpu_memory_mmuRsp_isIoAccess; - reg dataCache_1_io_cpu_writeBack_isValid; - wire dataCache_1_io_cpu_writeBack_isUser; - reg [31:0] dataCache_1_io_cpu_writeBack_storeData; - wire [31:0] dataCache_1_io_cpu_writeBack_address; - wire dataCache_1_io_cpu_writeBack_fence_SW; - wire dataCache_1_io_cpu_writeBack_fence_SR; - wire dataCache_1_io_cpu_writeBack_fence_SO; - wire dataCache_1_io_cpu_writeBack_fence_SI; - wire dataCache_1_io_cpu_writeBack_fence_PW; - wire dataCache_1_io_cpu_writeBack_fence_PR; - wire dataCache_1_io_cpu_writeBack_fence_PO; - wire dataCache_1_io_cpu_writeBack_fence_PI; - wire [3:0] dataCache_1_io_cpu_writeBack_fence_FM; - wire dataCache_1_io_cpu_flush_valid; - wire dataCache_1_io_cpu_flush_payload_singleLine; reg [31:0] _zz_RegFilePlugin_regFile_port0; reg [31:0] _zz_RegFilePlugin_regFile_port1; wire IBusSimplePlugin_rspJoin_rspBuffer_c_io_push_ready; @@ -109,40 +71,20 @@ module VexRiscv ( wire IBusSimplePlugin_rspJoin_rspBuffer_c_io_pop_payload_error; wire [31:0] IBusSimplePlugin_rspJoin_rspBuffer_c_io_pop_payload_inst; wire [0:0] IBusSimplePlugin_rspJoin_rspBuffer_c_io_occupancy; - wire dataCache_1_io_cpu_execute_haltIt; - wire dataCache_1_io_cpu_execute_refilling; - wire dataCache_1_io_cpu_memory_isWrite; - wire dataCache_1_io_cpu_writeBack_haltIt; - wire [31:0] dataCache_1_io_cpu_writeBack_data; - wire dataCache_1_io_cpu_writeBack_mmuException; - wire dataCache_1_io_cpu_writeBack_unalignedAccess; - wire dataCache_1_io_cpu_writeBack_accessError; - wire dataCache_1_io_cpu_writeBack_isWrite; - wire dataCache_1_io_cpu_writeBack_keepMemRspData; - wire dataCache_1_io_cpu_writeBack_exclusiveOk; - wire dataCache_1_io_cpu_flush_ready; - wire dataCache_1_io_cpu_redo; - wire dataCache_1_io_mem_cmd_valid; - wire dataCache_1_io_mem_cmd_payload_wr; - wire dataCache_1_io_mem_cmd_payload_uncached; - wire [31:0] dataCache_1_io_mem_cmd_payload_address; - wire [31:0] dataCache_1_io_mem_cmd_payload_data; - wire [3:0] dataCache_1_io_mem_cmd_payload_mask; - wire [1:0] dataCache_1_io_mem_cmd_payload_size; - wire dataCache_1_io_mem_cmd_payload_last; - wire FpuPlugin_fpu_io_port_0_cmd_ready; - wire FpuPlugin_fpu_io_port_0_commit_ready; - wire FpuPlugin_fpu_io_port_0_rsp_valid; - wire [31:0] FpuPlugin_fpu_io_port_0_rsp_payload_value; - wire FpuPlugin_fpu_io_port_0_rsp_payload_NV; - wire FpuPlugin_fpu_io_port_0_rsp_payload_NX; - wire FpuPlugin_fpu_io_port_0_completion_valid; - wire FpuPlugin_fpu_io_port_0_completion_payload_flags_NX; - wire FpuPlugin_fpu_io_port_0_completion_payload_flags_UF; - wire FpuPlugin_fpu_io_port_0_completion_payload_flags_OF; - wire FpuPlugin_fpu_io_port_0_completion_payload_flags_DZ; - wire FpuPlugin_fpu_io_port_0_completion_payload_flags_NV; - wire FpuPlugin_fpu_io_port_0_completion_payload_written; + wire jtagBridge_1_io_jtag_tdo; + wire jtagBridge_1_io_remote_cmd_valid; + wire jtagBridge_1_io_remote_cmd_payload_last; + wire [0:0] jtagBridge_1_io_remote_cmd_payload_fragment; + wire jtagBridge_1_io_remote_rsp_ready; + wire systemDebugger_1_io_remote_cmd_ready; + wire systemDebugger_1_io_remote_rsp_valid; + wire systemDebugger_1_io_remote_rsp_payload_error; + wire [31:0] systemDebugger_1_io_remote_rsp_payload_data; + wire systemDebugger_1_io_mem_cmd_valid; + wire [31:0] systemDebugger_1_io_mem_cmd_payload_address; + wire [31:0] systemDebugger_1_io_mem_cmd_payload_data; + wire systemDebugger_1_io_mem_cmd_payload_wr; + wire [1:0] systemDebugger_1_io_mem_cmd_payload_size; wire [51:0] _zz_memory_MUL_LOW; wire [51:0] _zz_memory_MUL_LOW_1; wire [51:0] _zz_memory_MUL_LOW_2; @@ -159,25 +101,18 @@ module VexRiscv ( wire [31:0] _zz_decode_LEGAL_INSTRUCTION_2; wire _zz_decode_LEGAL_INSTRUCTION_3; wire [0:0] _zz_decode_LEGAL_INSTRUCTION_4; - wire [21:0] _zz_decode_LEGAL_INSTRUCTION_5; + wire [11:0] _zz_decode_LEGAL_INSTRUCTION_5; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_6; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_7; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_8; wire _zz_decode_LEGAL_INSTRUCTION_9; wire [0:0] _zz_decode_LEGAL_INSTRUCTION_10; - wire [15:0] _zz_decode_LEGAL_INSTRUCTION_11; + wire [5:0] _zz_decode_LEGAL_INSTRUCTION_11; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_12; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_13; wire [31:0] _zz_decode_LEGAL_INSTRUCTION_14; wire _zz_decode_LEGAL_INSTRUCTION_15; - wire [0:0] _zz_decode_LEGAL_INSTRUCTION_16; - wire [9:0] _zz_decode_LEGAL_INSTRUCTION_17; - wire [31:0] _zz_decode_LEGAL_INSTRUCTION_18; - wire [31:0] _zz_decode_LEGAL_INSTRUCTION_19; - wire [31:0] _zz_decode_LEGAL_INSTRUCTION_20; - wire _zz_decode_LEGAL_INSTRUCTION_21; - wire [0:0] _zz_decode_LEGAL_INSTRUCTION_22; - wire [3:0] _zz_decode_LEGAL_INSTRUCTION_23; + wire _zz_decode_LEGAL_INSTRUCTION_16; wire [2:0] _zz__zz_IBusSimplePlugin_jump_pcLoad_payload_1; reg [31:0] _zz_IBusSimplePlugin_jump_pcLoad_payload_4; wire [1:0] _zz_IBusSimplePlugin_jump_pcLoad_payload_5; @@ -194,8 +129,15 @@ module VexRiscv ( wire [4:0] _zz_IBusSimplePlugin_decompressor_decompressed_33; wire [11:0] _zz_IBusSimplePlugin_decompressor_decompressed_34; wire [11:0] _zz_IBusSimplePlugin_decompressor_decompressed_35; - wire [11:0] _zz_IBusSimplePlugin_decompressor_decompressed_36; - wire [11:0] _zz_IBusSimplePlugin_decompressor_decompressed_37; + wire [11:0] _zz__zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + wire [31:0] _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_2; + wire [19:0] _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload; + wire [11:0] _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + wire [0:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_4; + wire [7:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_5; + wire _zz_IBusSimplePlugin_predictionJumpInterface_payload_6; + wire [0:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_7; + wire [0:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_8; wire [2:0] _zz_IBusSimplePlugin_pending_next; wire [2:0] _zz_IBusSimplePlugin_pending_next_1; wire [0:0] _zz_IBusSimplePlugin_pending_next_2; @@ -205,214 +147,130 @@ module VexRiscv ( wire [0:0] _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_1; wire [2:0] _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_2; wire [0:0] _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_3; - wire [2:0] _zz_DBusCachedPlugin_exceptionBus_payload_code; - wire [2:0] _zz_DBusCachedPlugin_exceptionBus_payload_code_1; - reg [7:0] _zz_writeBack_DBusCachedPlugin_rspShifted; - wire [1:0] _zz_writeBack_DBusCachedPlugin_rspShifted_1; - reg [7:0] _zz_writeBack_DBusCachedPlugin_rspShifted_2; - wire [0:0] _zz_writeBack_DBusCachedPlugin_rspShifted_3; + wire [2:0] _zz_DBusSimplePlugin_memoryExceptionPort_payload_code; wire [1:0] _zz__zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code_1; wire [1:0] _zz__zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code_1_1; wire _zz_when; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_1; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_2; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_3; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_4; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_5; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_6; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_7; - wire [2:0] _zz__zz_decode_BRANCH_CTRL_2_8; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_9; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_10; - wire _zz__zz_decode_BRANCH_CTRL_2_11; - wire _zz__zz_decode_BRANCH_CTRL_2_12; - wire _zz__zz_decode_BRANCH_CTRL_2_13; - wire _zz__zz_decode_BRANCH_CTRL_2_14; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_15; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_16; - wire [2:0] _zz__zz_decode_BRANCH_CTRL_2_17; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_18; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_19; - wire _zz__zz_decode_BRANCH_CTRL_2_20; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_21; - wire _zz__zz_decode_BRANCH_CTRL_2_22; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_23; - wire [34:0] _zz__zz_decode_BRANCH_CTRL_2_24; - wire _zz__zz_decode_BRANCH_CTRL_2_25; - wire _zz__zz_decode_BRANCH_CTRL_2_26; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_27; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_28; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_29; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_30; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_31; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_32; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_33; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_34; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_35; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_36; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_37; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_38; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_39; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_40; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_41; - wire [3:0] _zz__zz_decode_BRANCH_CTRL_2_42; - wire _zz__zz_decode_BRANCH_CTRL_2_43; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_44; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_45; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_46; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_47; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_48; - wire _zz__zz_decode_BRANCH_CTRL_2_49; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_50; - wire _zz__zz_decode_BRANCH_CTRL_2_51; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_52; - wire _zz__zz_decode_BRANCH_CTRL_2_53; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_54; - wire [3:0] _zz__zz_decode_BRANCH_CTRL_2_55; - wire _zz__zz_decode_BRANCH_CTRL_2_56; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_57; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_58; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_59; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_60; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_61; - wire _zz__zz_decode_BRANCH_CTRL_2_62; - wire _zz__zz_decode_BRANCH_CTRL_2_63; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_64; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_65; - wire [28:0] _zz__zz_decode_BRANCH_CTRL_2_66; - wire _zz__zz_decode_BRANCH_CTRL_2_67; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_68; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_69; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_70; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_71; - wire _zz__zz_decode_BRANCH_CTRL_2_72; - wire _zz__zz_decode_BRANCH_CTRL_2_73; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_74; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_75; - wire _zz__zz_decode_BRANCH_CTRL_2_76; - wire _zz__zz_decode_BRANCH_CTRL_2_77; - wire [26:0] _zz__zz_decode_BRANCH_CTRL_2_78; - wire _zz__zz_decode_BRANCH_CTRL_2_79; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_80; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_81; - wire [24:0] _zz__zz_decode_BRANCH_CTRL_2_82; - wire _zz__zz_decode_BRANCH_CTRL_2_83; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_84; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_85; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_86; - wire _zz__zz_decode_BRANCH_CTRL_2_87; - wire [22:0] _zz__zz_decode_BRANCH_CTRL_2_88; - wire [2:0] _zz__zz_decode_BRANCH_CTRL_2_89; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_90; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_91; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_92; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_93; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_94; - wire _zz__zz_decode_BRANCH_CTRL_2_95; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_96; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_97; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_98; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_99; - wire [19:0] _zz__zz_decode_BRANCH_CTRL_2_100; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_101; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_102; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_103; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_104; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_105; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_106; - wire _zz__zz_decode_BRANCH_CTRL_2_107; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_108; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_109; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_110; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_111; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_112; - wire [15:0] _zz__zz_decode_BRANCH_CTRL_2_113; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_114; - wire _zz__zz_decode_BRANCH_CTRL_2_115; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_116; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_117; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_118; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_119; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_120; - wire _zz__zz_decode_BRANCH_CTRL_2_121; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_122; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_123; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_124; - wire [12:0] _zz__zz_decode_BRANCH_CTRL_2_125; - wire [4:0] _zz__zz_decode_BRANCH_CTRL_2_126; - wire _zz__zz_decode_BRANCH_CTRL_2_127; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_128; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_129; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_130; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_131; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_132; - wire _zz__zz_decode_BRANCH_CTRL_2_133; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_134; - wire _zz__zz_decode_BRANCH_CTRL_2_135; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_136; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_137; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_138; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_139; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_140; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_141; - wire [5:0] _zz__zz_decode_BRANCH_CTRL_2_142; - wire _zz__zz_decode_BRANCH_CTRL_2_143; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_144; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_145; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_146; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_147; - wire [3:0] _zz__zz_decode_BRANCH_CTRL_2_148; - wire _zz__zz_decode_BRANCH_CTRL_2_149; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_150; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_151; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_152; - wire _zz__zz_decode_BRANCH_CTRL_2_153; - wire _zz__zz_decode_BRANCH_CTRL_2_154; - wire [8:0] _zz__zz_decode_BRANCH_CTRL_2_155; - wire [3:0] _zz__zz_decode_BRANCH_CTRL_2_156; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_157; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_158; - wire _zz__zz_decode_BRANCH_CTRL_2_159; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_160; - wire _zz__zz_decode_BRANCH_CTRL_2_161; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_162; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_163; - wire _zz__zz_decode_BRANCH_CTRL_2_164; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_165; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_166; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_167; - wire _zz__zz_decode_BRANCH_CTRL_2_168; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_169; - wire _zz__zz_decode_BRANCH_CTRL_2_170; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_171; - wire [5:0] _zz__zz_decode_BRANCH_CTRL_2_172; - wire _zz__zz_decode_BRANCH_CTRL_2_173; - wire _zz__zz_decode_BRANCH_CTRL_2_174; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_175; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_176; - wire [6:0] _zz__zz_decode_BRANCH_CTRL_2_177; - wire _zz__zz_decode_BRANCH_CTRL_2_178; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_179; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_180; - wire [4:0] _zz__zz_decode_BRANCH_CTRL_2_181; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_182; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_183; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_184; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_185; - wire [3:0] _zz__zz_decode_BRANCH_CTRL_2_186; - wire _zz__zz_decode_BRANCH_CTRL_2_187; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_188; - wire [2:0] _zz__zz_decode_BRANCH_CTRL_2_189; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_190; - wire [31:0] _zz__zz_decode_BRANCH_CTRL_2_191; - wire _zz__zz_decode_BRANCH_CTRL_2_192; - wire _zz__zz_decode_BRANCH_CTRL_2_193; - wire [1:0] _zz__zz_decode_BRANCH_CTRL_2_194; - wire _zz__zz_decode_BRANCH_CTRL_2_195; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_196; - wire [0:0] _zz__zz_decode_BRANCH_CTRL_2_197; - wire _zz__zz_decode_BRANCH_CTRL_2_198; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_1; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_2; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_3; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_4; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_5; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_6; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_7; + wire [2:0] _zz__zz_decode_SHIFT_CTRL_2_8; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_9; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_10; + wire _zz__zz_decode_SHIFT_CTRL_2_11; + wire _zz__zz_decode_SHIFT_CTRL_2_12; + wire _zz__zz_decode_SHIFT_CTRL_2_13; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_14; + wire [24:0] _zz__zz_decode_SHIFT_CTRL_2_15; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_16; + wire _zz__zz_decode_SHIFT_CTRL_2_17; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_18; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_19; + wire _zz__zz_decode_SHIFT_CTRL_2_20; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_21; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_22; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_23; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_24; + wire [21:0] _zz__zz_decode_SHIFT_CTRL_2_25; + wire _zz__zz_decode_SHIFT_CTRL_2_26; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_27; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_28; + wire _zz__zz_decode_SHIFT_CTRL_2_29; + wire _zz__zz_decode_SHIFT_CTRL_2_30; + wire _zz__zz_decode_SHIFT_CTRL_2_31; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_32; + wire [17:0] _zz__zz_decode_SHIFT_CTRL_2_33; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_34; + wire _zz__zz_decode_SHIFT_CTRL_2_35; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_36; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_37; + wire _zz__zz_decode_SHIFT_CTRL_2_38; + wire _zz__zz_decode_SHIFT_CTRL_2_39; + wire [14:0] _zz__zz_decode_SHIFT_CTRL_2_40; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_41; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_42; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_43; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_44; + wire [2:0] _zz__zz_decode_SHIFT_CTRL_2_45; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_46; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_47; + wire _zz__zz_decode_SHIFT_CTRL_2_48; + wire _zz__zz_decode_SHIFT_CTRL_2_49; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_50; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_51; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_52; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_53; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_54; + wire [3:0] _zz__zz_decode_SHIFT_CTRL_2_55; + wire _zz__zz_decode_SHIFT_CTRL_2_56; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_57; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_58; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_59; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_60; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_61; + wire [10:0] _zz__zz_decode_SHIFT_CTRL_2_62; + wire [2:0] _zz__zz_decode_SHIFT_CTRL_2_63; + wire _zz__zz_decode_SHIFT_CTRL_2_64; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_65; + wire _zz__zz_decode_SHIFT_CTRL_2_66; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_67; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_68; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_69; + wire [3:0] _zz__zz_decode_SHIFT_CTRL_2_70; + wire _zz__zz_decode_SHIFT_CTRL_2_71; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_72; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_73; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_74; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_75; + wire [1:0] _zz__zz_decode_SHIFT_CTRL_2_76; + wire _zz__zz_decode_SHIFT_CTRL_2_77; + wire _zz__zz_decode_SHIFT_CTRL_2_78; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_79; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_80; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_81; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_82; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_83; + wire [7:0] _zz__zz_decode_SHIFT_CTRL_2_84; + wire [1:0] _zz__zz_decode_SHIFT_CTRL_2_85; + wire _zz__zz_decode_SHIFT_CTRL_2_86; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_87; + wire _zz__zz_decode_SHIFT_CTRL_2_88; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_89; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_90; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_91; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_92; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_93; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_94; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_95; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_96; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_97; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_98; + wire [4:0] _zz__zz_decode_SHIFT_CTRL_2_99; + wire _zz__zz_decode_SHIFT_CTRL_2_100; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_101; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_102; + wire [2:0] _zz__zz_decode_SHIFT_CTRL_2_103; + wire _zz__zz_decode_SHIFT_CTRL_2_104; + wire _zz__zz_decode_SHIFT_CTRL_2_105; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_106; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_107; + wire [31:0] _zz__zz_decode_SHIFT_CTRL_2_108; + wire [2:0] _zz__zz_decode_SHIFT_CTRL_2_109; + wire _zz__zz_decode_SHIFT_CTRL_2_110; + wire _zz__zz_decode_SHIFT_CTRL_2_111; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_112; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_113; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_114; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_115; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_116; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_117; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_118; + wire [0:0] _zz__zz_decode_SHIFT_CTRL_2_119; wire _zz_RegFilePlugin_regFile_port; wire _zz_decode_RegFilePlugin_rs1Data; wire _zz_RegFilePlugin_regFile_port_1; @@ -430,8 +288,8 @@ module VexRiscv ( wire [31:0] _zz_execute_SrcPlugin_addSub_6; wire [65:0] _zz_writeBack_MulPlugin_result; wire [65:0] _zz_writeBack_MulPlugin_result_1; - wire [31:0] _zz__zz_lastStageRegFileWrite_payload_data; - wire [31:0] _zz__zz_lastStageRegFileWrite_payload_data_1; + wire [31:0] _zz__zz_decode_RS2_2; + wire [31:0] _zz__zz_decode_RS2_2_1; wire [5:0] _zz_memory_DivPlugin_div_counter_valueNext; wire [0:0] _zz_memory_DivPlugin_div_counter_valueNext_1; wire [32:0] _zz_memory_DivPlugin_div_stage_0_remainderMinusDenominator; @@ -447,20 +305,16 @@ module VexRiscv ( wire [0:0] _zz_memory_DivPlugin_rs1_3; wire [31:0] _zz_memory_DivPlugin_rs2_1; wire [0:0] _zz_memory_DivPlugin_rs2_2; - wire [5:0] _zz_FpuPlugin_pendings; - wire [5:0] _zz_FpuPlugin_pendings_1; - wire [5:0] _zz_FpuPlugin_pendings_2; - wire [0:0] _zz_FpuPlugin_pendings_3; - wire [5:0] _zz_FpuPlugin_pendings_4; - wire [0:0] _zz_FpuPlugin_pendings_5; - wire [5:0] _zz_FpuPlugin_pendings_6; - wire [0:0] _zz_FpuPlugin_pendings_7; - wire [31:0] _zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1; - wire [32:0] _zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1_1; - wire [19:0] _zz__zz_execute_BranchPlugin_branch_src2; + wire [31:0] _zz__zz_decode_RS2_3; + wire [32:0] _zz__zz_decode_RS2_3_1; + wire [19:0] _zz__zz_execute_BranchPlugin_branch_src2_2; wire [11:0] _zz__zz_execute_BranchPlugin_branch_src2_4; - wire [31:0] writeBack_MEMORY_LOAD_DATA; + wire _zz_execute_BranchPlugin_branch_src2_6; + wire _zz_execute_BranchPlugin_branch_src2_7; + wire _zz_execute_BranchPlugin_branch_src2_8; + wire [2:0] _zz_execute_BranchPlugin_branch_src2_9; wire [51:0] memory_MUL_LOW; + wire [31:0] memory_MEMORY_READ_DATA; wire [31:0] execute_BRANCH_CALC; wire execute_BRANCH_DO; wire [33:0] memory_MUL_HH; @@ -468,47 +322,21 @@ module VexRiscv ( wire [33:0] execute_MUL_HL; wire [33:0] execute_MUL_LH; wire [31:0] execute_MUL_LL; + wire [31:0] writeBack_REGFILE_WRITE_DATA; wire [31:0] execute_REGFILE_WRITE_DATA; - wire [31:0] memory_MEMORY_STORE_DATA_RF; - wire [31:0] execute_MEMORY_STORE_DATA_RF; - wire memory_FPU_COMMIT_LOAD; - wire execute_FPU_COMMIT_LOAD; - wire decode_FPU_COMMIT_LOAD; - wire memory_FPU_FORKED; - wire execute_FPU_FORKED; - wire decode_FPU_FORKED; + wire [1:0] memory_MEMORY_ADDRESS_LOW; + wire [1:0] execute_MEMORY_ADDRESS_LOW; + wire decode_DO_EBREAK; + wire decode_PREDICTION_HAD_BRANCHED2; wire [31:0] decode_SRC2; wire [31:0] decode_SRC1; wire decode_SRC2_FORCE_ZERO; - wire [31:0] decode_RS2; - wire [31:0] memory_RS1; - wire [31:0] decode_RS1; - wire [1:0] decode_BRANCH_CTRL; - wire [1:0] _zz_decode_BRANCH_CTRL; wire [1:0] _zz_decode_to_execute_BRANCH_CTRL; wire [1:0] _zz_decode_to_execute_BRANCH_CTRL_1; wire [1:0] decode_SHIFT_CTRL; wire [1:0] _zz_decode_SHIFT_CTRL; wire [1:0] _zz_decode_to_execute_SHIFT_CTRL; wire [1:0] _zz_decode_to_execute_SHIFT_CTRL_1; - wire [3:0] memory_FPU_OPCODE; - wire [3:0] _zz_memory_FPU_OPCODE; - wire [3:0] _zz_memory_to_writeBack_FPU_OPCODE; - wire [3:0] _zz_memory_to_writeBack_FPU_OPCODE_1; - wire [3:0] execute_FPU_OPCODE; - wire [3:0] _zz_execute_FPU_OPCODE; - wire [3:0] _zz_execute_to_memory_FPU_OPCODE; - wire [3:0] _zz_execute_to_memory_FPU_OPCODE_1; - wire [3:0] _zz_decode_to_execute_FPU_OPCODE; - wire [3:0] _zz_decode_to_execute_FPU_OPCODE_1; - wire memory_FPU_RSP; - wire execute_FPU_RSP; - wire decode_FPU_RSP; - wire memory_FPU_COMMIT; - wire execute_FPU_COMMIT; - wire decode_FPU_COMMIT; - wire memory_FPU_ENABLE; - wire execute_FPU_ENABLE; wire decode_IS_RS2_SIGNED; wire decode_IS_RS1_SIGNED; wire decode_IS_DIV; @@ -529,9 +357,7 @@ module VexRiscv ( wire [1:0] _zz_decode_to_execute_ENV_CTRL; wire [1:0] _zz_decode_to_execute_ENV_CTRL_1; wire decode_IS_CSR; - wire decode_MEMORY_MANAGMENT; - wire memory_MEMORY_WR; - wire decode_MEMORY_WR; + wire decode_MEMORY_STORE; wire execute_BYPASSABLE_MEMORY_STAGE; wire decode_BYPASSABLE_MEMORY_STAGE; wire decode_BYPASSABLE_EXECUTE_STAGE; @@ -539,17 +365,22 @@ module VexRiscv ( wire [1:0] _zz_decode_ALU_CTRL; wire [1:0] _zz_decode_to_execute_ALU_CTRL; wire [1:0] _zz_decode_to_execute_ALU_CTRL_1; + wire decode_MEMORY_ENABLE; wire decode_CSR_READ_OPCODE; wire decode_CSR_WRITE_OPCODE; - wire decode_MEMORY_FORCE_CONSTISTENCY; wire [31:0] writeBack_FORMAL_PC_NEXT; wire [31:0] memory_FORMAL_PC_NEXT; wire [31:0] execute_FORMAL_PC_NEXT; wire [31:0] decode_FORMAL_PC_NEXT; wire [31:0] memory_PC; + wire execute_DO_EBREAK; + wire decode_IS_EBREAK; wire [31:0] memory_BRANCH_CALC; wire memory_BRANCH_DO; + wire execute_IS_RVC; wire [31:0] execute_PC; + wire execute_BRANCH_COND_RESULT; + wire execute_PREDICTION_HAD_BRANCHED2; wire [1:0] execute_BRANCH_CTRL; wire [1:0] _zz_execute_BRANCH_CTRL; wire decode_RS2_USE; @@ -559,28 +390,14 @@ module VexRiscv ( wire memory_REGFILE_WRITE_VALID; wire memory_BYPASSABLE_MEMORY_STAGE; wire writeBack_REGFILE_WRITE_VALID; + reg [31:0] decode_RS2; + reg [31:0] decode_RS1; wire [1:0] execute_SHIFT_CTRL; wire [1:0] _zz_execute_SHIFT_CTRL; - reg _zz_memory_to_writeBack_FPU_FORKED; - reg _zz_execute_to_memory_FPU_FORKED; - reg _zz_decode_to_execute_FPU_FORKED; - wire [31:0] writeBack_RS1; - wire writeBack_FPU_COMMIT_LOAD; - reg DBusBypass0_cond; - wire writeBack_FPU_COMMIT; - wire writeBack_FPU_RSP; - wire writeBack_FPU_FORKED; - wire [1:0] decode_FPU_ARG; - wire [3:0] decode_FPU_OPCODE; - wire [3:0] _zz_decode_FPU_OPCODE; - wire decode_FPU_ENABLE; - wire [3:0] writeBack_FPU_OPCODE; - wire [3:0] _zz_writeBack_FPU_OPCODE; - wire writeBack_FPU_ENABLE; wire execute_IS_RS1_SIGNED; wire execute_IS_DIV; wire execute_IS_RS2_SIGNED; - reg [31:0] _zz_memory_to_writeBack_REGFILE_WRITE_DATA; + reg [31:0] _zz_decode_RS2; wire [31:0] memory_INSTRUCTION; wire memory_IS_DIV; wire writeBack_IS_MUL; @@ -589,6 +406,7 @@ module VexRiscv ( wire [33:0] memory_MUL_HL; wire [33:0] memory_MUL_LH; wire [31:0] memory_MUL_LL; + (* keep , syn_keep *) wire [31:0] execute_RS1 /* synthesis syn_keep = 1 */ ; wire execute_SRC_LESS_UNSIGNED; wire execute_SRC2_FORCE_ZERO; wire execute_SRC_USE_SUB_LESS; @@ -614,15 +432,14 @@ module VexRiscv ( wire [31:0] decode_INSTRUCTION_ANTICIPATED; reg decode_REGFILE_WRITE_VALID; wire decode_LEGAL_INSTRUCTION; - wire [1:0] _zz_decode_BRANCH_CTRL_1; + wire [1:0] _zz_decode_BRANCH_CTRL; wire [1:0] _zz_decode_SHIFT_CTRL_1; - wire [3:0] _zz_decode_FPU_OPCODE_1; wire [1:0] _zz_decode_ALU_BITWISE_CTRL_1; wire [1:0] _zz_decode_ENV_CTRL_1; wire [1:0] _zz_decode_SRC2_CTRL_1; wire [1:0] _zz_decode_ALU_CTRL_1; wire [1:0] _zz_decode_SRC1_CTRL_1; - reg [31:0] _zz_execute_to_memory_REGFILE_WRITE_DATA; + reg [31:0] _zz_decode_RS2_1; wire [31:0] execute_SRC1; wire execute_CSR_READ_OPCODE; wire execute_CSR_WRITE_OPCODE; @@ -633,23 +450,24 @@ module VexRiscv ( wire [1:0] _zz_execute_ENV_CTRL; wire [1:0] writeBack_ENV_CTRL; wire [1:0] _zz_writeBack_ENV_CTRL; - reg [31:0] _zz_lastStageRegFileWrite_payload_data; - wire writeBack_MEMORY_WR; - wire [31:0] writeBack_MEMORY_STORE_DATA_RF; - wire [31:0] writeBack_REGFILE_WRITE_DATA; + reg [31:0] _zz_decode_RS2_2; wire writeBack_MEMORY_ENABLE; + wire [1:0] writeBack_MEMORY_ADDRESS_LOW; + wire [31:0] writeBack_MEMORY_READ_DATA; + wire memory_ALIGNEMENT_FAULT; wire [31:0] memory_REGFILE_WRITE_DATA; + wire memory_MEMORY_STORE; wire memory_MEMORY_ENABLE; - wire execute_MEMORY_FORCE_CONSTISTENCY; - (* keep , syn_keep *) wire [31:0] execute_RS1 /* synthesis syn_keep = 1 */ ; - wire execute_MEMORY_MANAGMENT; - (* keep , syn_keep *) wire [31:0] execute_RS2 /* synthesis syn_keep = 1 */ ; - wire execute_MEMORY_WR; wire [31:0] execute_SRC_ADD; - wire execute_MEMORY_ENABLE; + (* keep , syn_keep *) wire [31:0] execute_RS2 /* synthesis syn_keep = 1 */ ; wire [31:0] execute_INSTRUCTION; - wire decode_MEMORY_ENABLE; + wire execute_MEMORY_STORE; + wire execute_MEMORY_ENABLE; + wire execute_ALIGNEMENT_FAULT; + wire [1:0] decode_BRANCH_CTRL; + wire [1:0] _zz_decode_BRANCH_CTRL_1; reg [31:0] _zz_memory_to_writeBack_FORMAL_PC_NEXT; + reg [31:0] _zz_decode_to_execute_FORMAL_PC_NEXT; wire [31:0] decode_PC; wire [31:0] decode_INSTRUCTION; wire decode_IS_RVC; @@ -669,7 +487,7 @@ module VexRiscv ( reg execute_arbitration_haltItself; reg execute_arbitration_haltByOther; reg execute_arbitration_removeIt; - wire execute_arbitration_flushIt; + reg execute_arbitration_flushIt; reg execute_arbitration_flushNext; reg execute_arbitration_isValid; wire execute_arbitration_isStuck; @@ -688,10 +506,10 @@ module VexRiscv ( wire memory_arbitration_isFlushed; wire memory_arbitration_isMoving; wire memory_arbitration_isFiring; - reg writeBack_arbitration_haltItself; - reg writeBack_arbitration_haltByOther; + wire writeBack_arbitration_haltItself; + wire writeBack_arbitration_haltByOther; reg writeBack_arbitration_removeIt; - reg writeBack_arbitration_flushIt; + wire writeBack_arbitration_flushIt; reg writeBack_arbitration_flushNext; reg writeBack_arbitration_isValid; wire writeBack_arbitration_isStuck; @@ -704,8 +522,12 @@ module VexRiscv ( wire lastStageIsValid /* verilator public */ ; wire lastStageIsFiring /* verilator public */ ; reg IBusSimplePlugin_fetcherHalt; - wire IBusSimplePlugin_forceNoDecodeCond; + reg IBusSimplePlugin_forceNoDecodeCond; reg IBusSimplePlugin_incomingInstruction; + wire IBusSimplePlugin_predictionJumpInterface_valid; + (* keep , syn_keep *) wire [31:0] IBusSimplePlugin_predictionJumpInterface_payload /* synthesis syn_keep = 1 */ ; + wire IBusSimplePlugin_decodePrediction_cmd_hadBranch; + wire IBusSimplePlugin_decodePrediction_rsp_wasWrong; wire IBusSimplePlugin_pcValids_0; wire IBusSimplePlugin_pcValids_1; wire IBusSimplePlugin_pcValids_2; @@ -719,39 +541,9 @@ module VexRiscv ( wire IBusSimplePlugin_decodeExceptionPort_valid; reg [3:0] IBusSimplePlugin_decodeExceptionPort_payload_code; wire [31:0] IBusSimplePlugin_decodeExceptionPort_payload_badAddr; - wire dBus_cmd_valid; - wire dBus_cmd_ready; - wire dBus_cmd_payload_wr; - wire dBus_cmd_payload_uncached; - wire [31:0] dBus_cmd_payload_address; - wire [31:0] dBus_cmd_payload_data; - wire [3:0] dBus_cmd_payload_mask; - wire [1:0] dBus_cmd_payload_size; - wire dBus_cmd_payload_last; - wire dBus_rsp_valid; - wire dBus_rsp_payload_last; - wire [31:0] dBus_rsp_payload_data; - wire dBus_rsp_payload_error; - wire DBusCachedPlugin_mmuBus_cmd_0_isValid; - wire DBusCachedPlugin_mmuBus_cmd_0_isStuck; - wire [31:0] DBusCachedPlugin_mmuBus_cmd_0_virtualAddress; - wire DBusCachedPlugin_mmuBus_cmd_0_bypassTranslation; - wire [31:0] DBusCachedPlugin_mmuBus_rsp_physicalAddress; - wire DBusCachedPlugin_mmuBus_rsp_isIoAccess; - wire DBusCachedPlugin_mmuBus_rsp_isPaging; - wire DBusCachedPlugin_mmuBus_rsp_allowRead; - wire DBusCachedPlugin_mmuBus_rsp_allowWrite; - wire DBusCachedPlugin_mmuBus_rsp_allowExecute; - wire DBusCachedPlugin_mmuBus_rsp_exception; - wire DBusCachedPlugin_mmuBus_rsp_refilling; - wire DBusCachedPlugin_mmuBus_rsp_bypassTranslation; - wire DBusCachedPlugin_mmuBus_end; - wire DBusCachedPlugin_mmuBus_busy; - reg DBusCachedPlugin_redoBranch_valid; - wire [31:0] DBusCachedPlugin_redoBranch_payload; - reg DBusCachedPlugin_exceptionBus_valid; - reg [3:0] DBusCachedPlugin_exceptionBus_payload_code; - wire [31:0] DBusCachedPlugin_exceptionBus_payload_badAddr; + reg DBusSimplePlugin_memoryExceptionPort_valid; + reg [3:0] DBusSimplePlugin_memoryExceptionPort_payload_code; + wire [31:0] DBusSimplePlugin_memoryExceptionPort_payload_badAddr; wire [31:0] CsrPlugin_csrMapping_readDataSignal; wire [31:0] CsrPlugin_csrMapping_readDataInit; wire [31:0] CsrPlugin_csrMapping_writeDataSignal; @@ -767,47 +559,28 @@ module VexRiscv ( wire CsrPlugin_exceptionPendings_3; wire contextSwitching; reg [1:0] CsrPlugin_privilege; - wire CsrPlugin_forceMachineWire; + reg CsrPlugin_forceMachineWire; reg CsrPlugin_selfException_valid; reg [3:0] CsrPlugin_selfException_payload_code; wire [31:0] CsrPlugin_selfException_payload_badAddr; - wire CsrPlugin_allowInterrupts; - wire CsrPlugin_allowException; - wire CsrPlugin_allowEbreakException; + reg CsrPlugin_allowInterrupts; + reg CsrPlugin_allowException; + reg CsrPlugin_allowEbreakException; wire decodeExceptionPort_valid; wire [3:0] decodeExceptionPort_payload_code; wire [31:0] decodeExceptionPort_payload_badAddr; - wire FpuPlugin_port_cmd_valid /* verilator public */ ; - wire FpuPlugin_port_cmd_ready /* verilator public */ ; - wire [3:0] FpuPlugin_port_cmd_payload_opcode /* verilator public */ ; - wire [1:0] FpuPlugin_port_cmd_payload_arg /* verilator public */ ; - wire [4:0] FpuPlugin_port_cmd_payload_rs1 /* verilator public */ ; - wire [4:0] FpuPlugin_port_cmd_payload_rs2 /* verilator public */ ; - wire [4:0] FpuPlugin_port_cmd_payload_rs3 /* verilator public */ ; - wire [4:0] FpuPlugin_port_cmd_payload_rd /* verilator public */ ; - wire [0:0] FpuPlugin_port_cmd_payload_format /* verilator public */ ; - wire [2:0] FpuPlugin_port_cmd_payload_roundMode /* verilator public */ ; - wire FpuPlugin_port_commit_valid /* verilator public */ ; - wire FpuPlugin_port_commit_ready /* verilator public */ ; - wire [3:0] FpuPlugin_port_commit_payload_opcode /* verilator public */ ; - wire [4:0] FpuPlugin_port_commit_payload_rd /* verilator public */ ; - wire FpuPlugin_port_commit_payload_write /* verilator public */ ; - wire [31:0] FpuPlugin_port_commit_payload_value /* verilator public */ ; - wire FpuPlugin_port_rsp_valid /* verilator public */ ; - reg FpuPlugin_port_rsp_ready /* verilator public */ ; - wire [31:0] FpuPlugin_port_rsp_payload_value /* verilator public */ ; - wire FpuPlugin_port_rsp_payload_NV /* verilator public */ ; - wire FpuPlugin_port_rsp_payload_NX /* verilator public */ ; - wire FpuPlugin_port_completion_valid /* verilator public */ ; - wire FpuPlugin_port_completion_payload_flags_NX /* verilator public */ ; - wire FpuPlugin_port_completion_payload_flags_UF /* verilator public */ ; - wire FpuPlugin_port_completion_payload_flags_OF /* verilator public */ ; - wire FpuPlugin_port_completion_payload_flags_DZ /* verilator public */ ; - wire FpuPlugin_port_completion_payload_flags_NV /* verilator public */ ; - wire FpuPlugin_port_completion_payload_written /* verilator public */ ; wire BranchPlugin_jumpInterface_valid; wire [31:0] BranchPlugin_jumpInterface_payload; - wire BranchPlugin_inDebugNoFetchFlag; + reg BranchPlugin_inDebugNoFetchFlag; + wire debug_bus_cmd_valid; + reg debug_bus_cmd_ready; + wire debug_bus_cmd_payload_wr; + wire [7:0] debug_bus_cmd_payload_address; + wire [31:0] debug_bus_cmd_payload_data; + reg [31:0] debug_bus_rsp_data; + reg IBusSimplePlugin_injectionPort_valid; + reg IBusSimplePlugin_injectionPort_ready; + wire [31:0] IBusSimplePlugin_injectionPort_payload; wire IBusSimplePlugin_externalFlush; wire IBusSimplePlugin_jump_pcLoad_valid; wire [31:0] IBusSimplePlugin_jump_pcLoad_payload; @@ -835,7 +608,7 @@ module VexRiscv ( reg IBusSimplePlugin_decodePc_flushed; reg [31:0] IBusSimplePlugin_decodePc_pcReg /* verilator public */ ; wire [31:0] IBusSimplePlugin_decodePc_pcPlus; - wire IBusSimplePlugin_decodePc_injectedDecode; + reg IBusSimplePlugin_decodePc_injectedDecode; wire when_Fetcher_l183; wire when_Fetcher_l195; wire IBusSimplePlugin_iBusRsp_redoFetch; @@ -949,6 +722,12 @@ module VexRiscv ( reg IBusSimplePlugin_injector_nextPcCalc_valids_3; wire when_Fetcher_l332_3; reg [31:0] IBusSimplePlugin_injector_formal_rawInDecode; + wire _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + reg [18:0] _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1; + wire _zz_IBusSimplePlugin_predictionJumpInterface_payload; + reg [10:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_1; + wire _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + reg [18:0] _zz_IBusSimplePlugin_predictionJumpInterface_payload_3; wire IBusSimplePlugin_cmd_valid; wire IBusSimplePlugin_cmd_ready; wire [31:0] IBusSimplePlugin_cmd_payload_pc; @@ -986,29 +765,32 @@ module VexRiscv ( wire IBusSimplePlugin_rspJoin_join_fire_1; wire _zz_IBusSimplePlugin_iBusRsp_output_valid; wire when_IBusSimplePlugin_l402; - reg [31:0] DBusCachedPlugin_rspCounter; - wire when_DBusCachedPlugin_l308; - wire [1:0] execute_DBusCachedPlugin_size; - reg [31:0] _zz_execute_MEMORY_STORE_DATA_RF; - wire dataCache_1_io_cpu_flush_isStall; - wire when_DBusCachedPlugin_l350; - wire when_DBusCachedPlugin_l366; - wire when_DBusCachedPlugin_l393; - wire when_DBusCachedPlugin_l446; - wire when_DBusCachedPlugin_l466; - wire [7:0] writeBack_DBusCachedPlugin_rspSplits_0; - wire [7:0] writeBack_DBusCachedPlugin_rspSplits_1; - wire [7:0] writeBack_DBusCachedPlugin_rspSplits_2; - wire [7:0] writeBack_DBusCachedPlugin_rspSplits_3; - reg [31:0] writeBack_DBusCachedPlugin_rspShifted; - wire [31:0] writeBack_DBusCachedPlugin_rspRf; + wire dBus_cmd_valid; + wire dBus_cmd_ready; + wire dBus_cmd_payload_wr; + wire [31:0] dBus_cmd_payload_address; + wire [31:0] dBus_cmd_payload_data; + wire [1:0] dBus_cmd_payload_size; + wire dBus_rsp_ready; + wire dBus_rsp_error; + wire [31:0] dBus_rsp_data; + wire _zz_dBus_cmd_valid; + reg execute_DBusSimplePlugin_skipCmd; + reg [31:0] _zz_dBus_cmd_payload_data; + wire when_DBusSimplePlugin_l428; + reg [3:0] _zz_execute_DBusSimplePlugin_formalMask; + wire [3:0] execute_DBusSimplePlugin_formalMask; + wire when_DBusSimplePlugin_l482; + wire when_DBusSimplePlugin_l489; + wire when_DBusSimplePlugin_l515; + reg [31:0] writeBack_DBusSimplePlugin_rspShifted; wire [1:0] switch_Misc_l210_2; - wire _zz_writeBack_DBusCachedPlugin_rspFormated; - reg [31:0] _zz_writeBack_DBusCachedPlugin_rspFormated_1; - wire _zz_writeBack_DBusCachedPlugin_rspFormated_2; - reg [31:0] _zz_writeBack_DBusCachedPlugin_rspFormated_3; - reg [31:0] writeBack_DBusCachedPlugin_rspFormated; - wire when_DBusCachedPlugin_l492; + wire _zz_writeBack_DBusSimplePlugin_rspFormated; + reg [31:0] _zz_writeBack_DBusSimplePlugin_rspFormated_1; + wire _zz_writeBack_DBusSimplePlugin_rspFormated_2; + reg [31:0] _zz_writeBack_DBusSimplePlugin_rspFormated_3; + reg [31:0] writeBack_DBusSimplePlugin_rspFormated; + wire when_DBusSimplePlugin_l558; wire [1:0] CsrPlugin_misa_base; wire [25:0] CsrPlugin_misa_extensions; reg [1:0] CsrPlugin_mtvec_mode; @@ -1096,26 +878,21 @@ module VexRiscv ( wire when_CsrPlugin_l1189; wire when_CsrPlugin_l1193; wire [11:0] execute_CsrPlugin_csrAddress; - wire [40:0] _zz_decode_BRANCH_CTRL_2; - wire _zz_decode_BRANCH_CTRL_3; - wire _zz_decode_BRANCH_CTRL_4; - wire _zz_decode_BRANCH_CTRL_5; - wire _zz_decode_BRANCH_CTRL_6; - wire _zz_decode_BRANCH_CTRL_7; - wire _zz_decode_BRANCH_CTRL_8; - wire _zz_decode_BRANCH_CTRL_9; - wire _zz_decode_BRANCH_CTRL_10; - wire _zz_decode_BRANCH_CTRL_11; - wire _zz_decode_BRANCH_CTRL_12; - wire _zz_decode_BRANCH_CTRL_13; + wire [30:0] _zz_decode_SHIFT_CTRL_2; + wire _zz_decode_SHIFT_CTRL_3; + wire _zz_decode_SHIFT_CTRL_4; + wire _zz_decode_SHIFT_CTRL_5; + wire _zz_decode_SHIFT_CTRL_6; + wire _zz_decode_SHIFT_CTRL_7; + wire _zz_decode_SHIFT_CTRL_8; + wire _zz_decode_SHIFT_CTRL_9; wire [1:0] _zz_decode_SRC1_CTRL_2; wire [1:0] _zz_decode_ALU_CTRL_2; wire [1:0] _zz_decode_SRC2_CTRL_2; wire [1:0] _zz_decode_ENV_CTRL_2; wire [1:0] _zz_decode_ALU_BITWISE_CTRL_2; - wire [3:0] _zz_decode_FPU_OPCODE_2; - wire [1:0] _zz_decode_SHIFT_CTRL_2; - wire [1:0] _zz_decode_BRANCH_CTRL_14; + wire [1:0] _zz_decode_SHIFT_CTRL_10; + wire [1:0] _zz_decode_BRANCH_CTRL_2; wire when_RegFilePlugin_l63; wire [4:0] decode_RegFilePlugin_regFileReadAddress1; wire [4:0] decode_RegFilePlugin_regFileReadAddress2; @@ -1178,63 +955,6 @@ module VexRiscv ( wire _zz_memory_DivPlugin_rs2; wire _zz_memory_DivPlugin_rs1; reg [32:0] _zz_memory_DivPlugin_rs1_1; - reg [5:0] FpuPlugin_pendings; - wire FpuPlugin_port_cmd_fire; - wire FpuPlugin_port_rsp_fire; - wire FpuPlugin_hasPending; - reg FpuPlugin_flags_NX; - reg FpuPlugin_flags_UF; - reg FpuPlugin_flags_OF; - reg FpuPlugin_flags_DZ; - reg FpuPlugin_flags_NV; - wire when_FpuPlugin_l199; - wire when_FpuPlugin_l200; - wire when_FpuPlugin_l201; - wire when_FpuPlugin_l202; - wire when_FpuPlugin_l203; - reg [2:0] FpuPlugin_rm; - wire FpuPlugin_csrActive; - wire when_FpuPlugin_l214; - reg [1:0] FpuPlugin_fs; - wire FpuPlugin_sd; - wire when_FpuPlugin_l219; - reg decode_FpuPlugin_forked; - wire FpuPlugin_port_cmd_fire_1; - wire when_FpuPlugin_l234; - wire decode_FpuPlugin_hazard; - wire when_FpuPlugin_l238; - wire FpuPlugin_port_cmd_isStall; - wire [2:0] decode_FpuPlugin_iRoundMode; - wire [2:0] decode_FpuPlugin_roundMode; - wire [2:0] _zz_FpuPlugin_port_cmd_payload_roundMode; - wire [2:0] _zz_FpuPlugin_port_cmd_payload_roundMode_1; - wire FpuPlugin_port_cmd_fire_2; - wire writeBack_FpuPlugin_isRsp; - wire writeBack_FpuPlugin_isCommit; - wire [31:0] writeBack_FpuPlugin_storeFormated; - wire [31:0] DBusBypass0_value; - wire when_FpuPlugin_l280; - wire when_FpuPlugin_l285; - wire when_FpuPlugin_l287; - wire writeBack_FpuPlugin_commit_valid /* verilator public */ ; - wire writeBack_FpuPlugin_commit_ready /* verilator public */ ; - wire [3:0] writeBack_FpuPlugin_commit_payload_opcode /* verilator public */ ; - wire [4:0] writeBack_FpuPlugin_commit_payload_rd /* verilator public */ ; - wire writeBack_FpuPlugin_commit_payload_write /* verilator public */ ; - wire [31:0] writeBack_FpuPlugin_commit_payload_value /* verilator public */ ; - wire when_FpuPlugin_l301; - wire writeBack_FpuPlugin_commit_s2mPipe_valid; - wire writeBack_FpuPlugin_commit_s2mPipe_ready; - wire [3:0] writeBack_FpuPlugin_commit_s2mPipe_payload_opcode; - wire [4:0] writeBack_FpuPlugin_commit_s2mPipe_payload_rd; - wire writeBack_FpuPlugin_commit_s2mPipe_payload_write; - wire [31:0] writeBack_FpuPlugin_commit_s2mPipe_payload_value; - reg writeBack_FpuPlugin_commit_rValid; - reg [3:0] writeBack_FpuPlugin_commit_rData_opcode; - reg [4:0] writeBack_FpuPlugin_commit_rData_rd; - reg writeBack_FpuPlugin_commit_rData_write; - reg [31:0] writeBack_FpuPlugin_commit_rData_value; - wire [3:0] _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode; reg execute_LightShifterPlugin_isActive; wire execute_LightShifterPlugin_isShift; reg [4:0] execute_LightShifterPlugin_amplitudeReg; @@ -1242,7 +962,7 @@ module VexRiscv ( wire [31:0] execute_LightShifterPlugin_shiftInput; wire execute_LightShifterPlugin_done; wire when_ShiftPlugins_l169; - reg [31:0] _zz_execute_to_memory_REGFILE_WRITE_DATA_1; + reg [31:0] _zz_decode_RS2_3; wire when_ShiftPlugins_l175; wire when_ShiftPlugins_l184; reg HazardSimplePlugin_src0Hazard; @@ -1255,16 +975,20 @@ module VexRiscv ( reg [31:0] HazardSimplePlugin_writeBackBuffer_payload_data; wire HazardSimplePlugin_addr0Match; wire HazardSimplePlugin_addr1Match; - wire when_HazardSimplePlugin_l59; - wire when_HazardSimplePlugin_l62; + wire when_HazardSimplePlugin_l47; + wire when_HazardSimplePlugin_l48; + wire when_HazardSimplePlugin_l51; + wire when_HazardSimplePlugin_l45; wire when_HazardSimplePlugin_l57; wire when_HazardSimplePlugin_l58; - wire when_HazardSimplePlugin_l59_1; - wire when_HazardSimplePlugin_l62_1; + wire when_HazardSimplePlugin_l48_1; + wire when_HazardSimplePlugin_l51_1; + wire when_HazardSimplePlugin_l45_1; wire when_HazardSimplePlugin_l57_1; wire when_HazardSimplePlugin_l58_1; - wire when_HazardSimplePlugin_l59_2; - wire when_HazardSimplePlugin_l62_2; + wire when_HazardSimplePlugin_l48_2; + wire when_HazardSimplePlugin_l51_2; + wire when_HazardSimplePlugin_l45_2; wire when_HazardSimplePlugin_l57_2; wire when_HazardSimplePlugin_l58_2; wire when_HazardSimplePlugin_l105; @@ -1272,18 +996,48 @@ module VexRiscv ( wire when_HazardSimplePlugin_l113; wire execute_BranchPlugin_eq; wire [2:0] switch_Misc_l210_4; - reg _zz_execute_BRANCH_DO; - reg _zz_execute_BRANCH_DO_1; - wire [31:0] execute_BranchPlugin_branch_src1; + reg _zz_execute_BRANCH_COND_RESULT; + reg _zz_execute_BRANCH_COND_RESULT_1; + wire execute_BranchPlugin_missAlignedTarget; + reg [31:0] execute_BranchPlugin_branch_src1; + reg [31:0] execute_BranchPlugin_branch_src2; wire _zz_execute_BranchPlugin_branch_src2; - reg [10:0] _zz_execute_BranchPlugin_branch_src2_1; + reg [19:0] _zz_execute_BranchPlugin_branch_src2_1; wire _zz_execute_BranchPlugin_branch_src2_2; - reg [19:0] _zz_execute_BranchPlugin_branch_src2_3; + reg [10:0] _zz_execute_BranchPlugin_branch_src2_3; wire _zz_execute_BranchPlugin_branch_src2_4; reg [18:0] _zz_execute_BranchPlugin_branch_src2_5; - reg [31:0] _zz_execute_BranchPlugin_branch_src2_6; - wire [31:0] execute_BranchPlugin_branch_src2; wire [31:0] execute_BranchPlugin_branchAdder; + reg DebugPlugin_firstCycle; + reg DebugPlugin_secondCycle; + reg DebugPlugin_resetIt; + reg DebugPlugin_haltIt; + reg DebugPlugin_stepIt; + reg DebugPlugin_isPipBusy; + reg DebugPlugin_godmode; + wire when_DebugPlugin_l225; + reg DebugPlugin_haltedByBreak; + reg DebugPlugin_debugUsed /* verilator public */ ; + reg DebugPlugin_disableEbreak; + wire DebugPlugin_allowEBreak; + reg [31:0] DebugPlugin_busReadDataReg; + reg _zz_when_DebugPlugin_l244; + wire when_DebugPlugin_l244; + wire [5:0] switch_DebugPlugin_l267; + wire when_DebugPlugin_l271; + wire when_DebugPlugin_l271_1; + wire when_DebugPlugin_l272; + wire when_DebugPlugin_l272_1; + wire when_DebugPlugin_l273; + wire when_DebugPlugin_l274; + wire when_DebugPlugin_l275; + wire when_DebugPlugin_l275_1; + wire when_DebugPlugin_l295; + wire when_DebugPlugin_l298; + wire when_DebugPlugin_l311; + reg _zz_3; + reg DebugPlugin_resetIt_regNext; + wire when_DebugPlugin_l331; wire when_Pipeline_l124; reg [31:0] decode_to_execute_PC; wire when_Pipeline_l124_1; @@ -1297,13 +1051,13 @@ module VexRiscv ( wire when_Pipeline_l124_5; reg [31:0] memory_to_writeBack_INSTRUCTION; wire when_Pipeline_l124_6; - reg [31:0] decode_to_execute_FORMAL_PC_NEXT; + reg decode_to_execute_IS_RVC; wire when_Pipeline_l124_7; - reg [31:0] execute_to_memory_FORMAL_PC_NEXT; + reg [31:0] decode_to_execute_FORMAL_PC_NEXT; wire when_Pipeline_l124_8; - reg [31:0] memory_to_writeBack_FORMAL_PC_NEXT; + reg [31:0] execute_to_memory_FORMAL_PC_NEXT; wire when_Pipeline_l124_9; - reg decode_to_execute_MEMORY_FORCE_CONSTISTENCY; + reg [31:0] memory_to_writeBack_FORMAL_PC_NEXT; wire when_Pipeline_l124_10; reg decode_to_execute_CSR_WRITE_OPCODE; wire when_Pipeline_l124_11; @@ -1331,116 +1085,80 @@ module VexRiscv ( wire when_Pipeline_l124_22; reg execute_to_memory_BYPASSABLE_MEMORY_STAGE; wire when_Pipeline_l124_23; - reg decode_to_execute_MEMORY_WR; + reg decode_to_execute_MEMORY_STORE; wire when_Pipeline_l124_24; - reg execute_to_memory_MEMORY_WR; + reg execute_to_memory_MEMORY_STORE; wire when_Pipeline_l124_25; - reg memory_to_writeBack_MEMORY_WR; + reg decode_to_execute_IS_CSR; wire when_Pipeline_l124_26; - reg decode_to_execute_MEMORY_MANAGMENT; + reg [1:0] decode_to_execute_ENV_CTRL; wire when_Pipeline_l124_27; - reg decode_to_execute_IS_CSR; + reg [1:0] execute_to_memory_ENV_CTRL; wire when_Pipeline_l124_28; - reg [1:0] decode_to_execute_ENV_CTRL; + reg [1:0] memory_to_writeBack_ENV_CTRL; wire when_Pipeline_l124_29; - reg [1:0] execute_to_memory_ENV_CTRL; + reg decode_to_execute_SRC_LESS_UNSIGNED; wire when_Pipeline_l124_30; - reg [1:0] memory_to_writeBack_ENV_CTRL; + reg [1:0] decode_to_execute_ALU_BITWISE_CTRL; wire when_Pipeline_l124_31; - reg decode_to_execute_SRC_LESS_UNSIGNED; + reg decode_to_execute_IS_MUL; wire when_Pipeline_l124_32; - reg [1:0] decode_to_execute_ALU_BITWISE_CTRL; + reg execute_to_memory_IS_MUL; wire when_Pipeline_l124_33; - reg decode_to_execute_IS_MUL; + reg memory_to_writeBack_IS_MUL; wire when_Pipeline_l124_34; - reg execute_to_memory_IS_MUL; + reg decode_to_execute_IS_DIV; wire when_Pipeline_l124_35; - reg memory_to_writeBack_IS_MUL; + reg execute_to_memory_IS_DIV; wire when_Pipeline_l124_36; - reg decode_to_execute_IS_DIV; + reg decode_to_execute_IS_RS1_SIGNED; wire when_Pipeline_l124_37; - reg execute_to_memory_IS_DIV; + reg decode_to_execute_IS_RS2_SIGNED; wire when_Pipeline_l124_38; - reg decode_to_execute_IS_RS1_SIGNED; + reg [1:0] decode_to_execute_SHIFT_CTRL; wire when_Pipeline_l124_39; - reg decode_to_execute_IS_RS2_SIGNED; + reg [1:0] decode_to_execute_BRANCH_CTRL; wire when_Pipeline_l124_40; - reg decode_to_execute_FPU_ENABLE; + reg [31:0] decode_to_execute_RS1; wire when_Pipeline_l124_41; - reg execute_to_memory_FPU_ENABLE; + reg [31:0] decode_to_execute_RS2; wire when_Pipeline_l124_42; - reg memory_to_writeBack_FPU_ENABLE; + reg decode_to_execute_SRC2_FORCE_ZERO; wire when_Pipeline_l124_43; - reg decode_to_execute_FPU_COMMIT; + reg [31:0] decode_to_execute_SRC1; wire when_Pipeline_l124_44; - reg execute_to_memory_FPU_COMMIT; + reg [31:0] decode_to_execute_SRC2; wire when_Pipeline_l124_45; - reg memory_to_writeBack_FPU_COMMIT; + reg decode_to_execute_PREDICTION_HAD_BRANCHED2; wire when_Pipeline_l124_46; - reg decode_to_execute_FPU_RSP; + reg decode_to_execute_DO_EBREAK; wire when_Pipeline_l124_47; - reg execute_to_memory_FPU_RSP; + reg execute_to_memory_ALIGNEMENT_FAULT; wire when_Pipeline_l124_48; - reg memory_to_writeBack_FPU_RSP; + reg [1:0] execute_to_memory_MEMORY_ADDRESS_LOW; wire when_Pipeline_l124_49; - reg [3:0] decode_to_execute_FPU_OPCODE; + reg [1:0] memory_to_writeBack_MEMORY_ADDRESS_LOW; wire when_Pipeline_l124_50; - reg [3:0] execute_to_memory_FPU_OPCODE; + reg [31:0] execute_to_memory_REGFILE_WRITE_DATA; wire when_Pipeline_l124_51; - reg [3:0] memory_to_writeBack_FPU_OPCODE; + reg [31:0] memory_to_writeBack_REGFILE_WRITE_DATA; wire when_Pipeline_l124_52; - reg [1:0] decode_to_execute_SHIFT_CTRL; + reg [31:0] execute_to_memory_MUL_LL; wire when_Pipeline_l124_53; - reg [1:0] decode_to_execute_BRANCH_CTRL; + reg [33:0] execute_to_memory_MUL_LH; wire when_Pipeline_l124_54; - reg [31:0] decode_to_execute_RS1; + reg [33:0] execute_to_memory_MUL_HL; wire when_Pipeline_l124_55; - reg [31:0] execute_to_memory_RS1; + reg [33:0] execute_to_memory_MUL_HH; wire when_Pipeline_l124_56; - reg [31:0] memory_to_writeBack_RS1; + reg [33:0] memory_to_writeBack_MUL_HH; wire when_Pipeline_l124_57; - reg [31:0] decode_to_execute_RS2; + reg execute_to_memory_BRANCH_DO; wire when_Pipeline_l124_58; - reg decode_to_execute_SRC2_FORCE_ZERO; + reg [31:0] execute_to_memory_BRANCH_CALC; wire when_Pipeline_l124_59; - reg [31:0] decode_to_execute_SRC1; + reg [31:0] memory_to_writeBack_MEMORY_READ_DATA; wire when_Pipeline_l124_60; - reg [31:0] decode_to_execute_SRC2; - wire when_Pipeline_l124_61; - reg decode_to_execute_FPU_FORKED; - wire when_Pipeline_l124_62; - reg execute_to_memory_FPU_FORKED; - wire when_Pipeline_l124_63; - reg memory_to_writeBack_FPU_FORKED; - wire when_Pipeline_l124_64; - reg decode_to_execute_FPU_COMMIT_LOAD; - wire when_Pipeline_l124_65; - reg execute_to_memory_FPU_COMMIT_LOAD; - wire when_Pipeline_l124_66; - reg memory_to_writeBack_FPU_COMMIT_LOAD; - wire when_Pipeline_l124_67; - reg [31:0] execute_to_memory_MEMORY_STORE_DATA_RF; - wire when_Pipeline_l124_68; - reg [31:0] memory_to_writeBack_MEMORY_STORE_DATA_RF; - wire when_Pipeline_l124_69; - reg [31:0] execute_to_memory_REGFILE_WRITE_DATA; - wire when_Pipeline_l124_70; - reg [31:0] memory_to_writeBack_REGFILE_WRITE_DATA; - wire when_Pipeline_l124_71; - reg [31:0] execute_to_memory_MUL_LL; - wire when_Pipeline_l124_72; - reg [33:0] execute_to_memory_MUL_LH; - wire when_Pipeline_l124_73; - reg [33:0] execute_to_memory_MUL_HL; - wire when_Pipeline_l124_74; - reg [33:0] execute_to_memory_MUL_HH; - wire when_Pipeline_l124_75; - reg [33:0] memory_to_writeBack_MUL_HH; - wire when_Pipeline_l124_76; - reg execute_to_memory_BRANCH_DO; - wire when_Pipeline_l124_77; - reg [31:0] execute_to_memory_BRANCH_CALC; - wire when_Pipeline_l124_78; reg [51:0] memory_to_writeBack_MUL_LOW; wire when_Pipeline_l151; wire when_Pipeline_l154; @@ -1448,6 +1166,10 @@ module VexRiscv ( wire when_Pipeline_l154_1; wire when_Pipeline_l151_2; wire when_Pipeline_l154_2; + reg [2:0] switch_Fetcher_l365; + wire when_Fetcher_l363; + wire when_Fetcher_l381; + wire when_Fetcher_l401; wire when_CsrPlugin_l1277; reg execute_CsrPlugin_csr_768; wire when_CsrPlugin_l1277_1; @@ -1457,25 +1179,23 @@ module VexRiscv ( wire when_CsrPlugin_l1277_3; reg execute_CsrPlugin_csr_773; wire when_CsrPlugin_l1277_4; - reg execute_CsrPlugin_csr_834; + reg execute_CsrPlugin_csr_833; wire when_CsrPlugin_l1277_5; - reg execute_CsrPlugin_csr_3; + reg execute_CsrPlugin_csr_834; wire when_CsrPlugin_l1277_6; - reg execute_CsrPlugin_csr_2; + reg execute_CsrPlugin_csr_835; wire when_CsrPlugin_l1277_7; - reg execute_CsrPlugin_csr_1; + reg execute_CsrPlugin_csr_3072; wire when_CsrPlugin_l1277_8; - reg execute_CsrPlugin_csr_256; + reg execute_CsrPlugin_csr_3200; wire [1:0] switch_CsrPlugin_l723; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_1; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_2; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_3; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_4; - wire [4:0] _zz_FpuPlugin_flags_NX; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_5; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_6; - wire [4:0] _zz_FpuPlugin_flags_NX_1; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_7; reg [31:0] _zz_CsrPlugin_csrMapping_readDataInit_8; wire when_CsrPlugin_l1310; @@ -1486,33 +1206,29 @@ module VexRiscv ( reg iBus_cmd_rValid; reg [31:0] iBus_cmd_rData_pc; wire when_Stream_l368; - reg [0:0] _zz_dBus_cmd_ready; - wire _zz_dBus_cmd_ready_1; - wire _zz_dBus_cmd_ready_2; - wire _zz_dBus_cmd_ready_3; - wire _zz_dBus_cmd_ready_4; - wire _zz_dBus_cmd_ready_5; - reg _zz_dBus_rsp_valid; - reg [31:0] dBusWishbone_DAT_MISO_regNext; + wire dBus_cmd_halfPipe_valid; + wire dBus_cmd_halfPipe_ready; + wire dBus_cmd_halfPipe_payload_wr; + wire [31:0] dBus_cmd_halfPipe_payload_address; + wire [31:0] dBus_cmd_halfPipe_payload_data; + wire [1:0] dBus_cmd_halfPipe_payload_size; + reg dBus_cmd_rValid; + wire dBus_cmd_halfPipe_fire; + reg dBus_cmd_rData_wr; + reg [31:0] dBus_cmd_rData_address; + reg [31:0] dBus_cmd_rData_data; + reg [1:0] dBus_cmd_rData_size; + reg [3:0] _zz_dBusWishbone_SEL; + wire when_DBusSimplePlugin_l189; + wire debug_bus_cmd_fire; + reg debug_bus_cmd_fire_regNext; `ifndef SYNTHESIS - reg [31:0] decode_BRANCH_CTRL_string; - reg [31:0] _zz_decode_BRANCH_CTRL_string; reg [31:0] _zz_decode_to_execute_BRANCH_CTRL_string; reg [31:0] _zz_decode_to_execute_BRANCH_CTRL_1_string; reg [71:0] decode_SHIFT_CTRL_string; reg [71:0] _zz_decode_SHIFT_CTRL_string; reg [71:0] _zz_decode_to_execute_SHIFT_CTRL_string; reg [71:0] _zz_decode_to_execute_SHIFT_CTRL_1_string; - reg [63:0] memory_FPU_OPCODE_string; - reg [63:0] _zz_memory_FPU_OPCODE_string; - reg [63:0] _zz_memory_to_writeBack_FPU_OPCODE_string; - reg [63:0] _zz_memory_to_writeBack_FPU_OPCODE_1_string; - reg [63:0] execute_FPU_OPCODE_string; - reg [63:0] _zz_execute_FPU_OPCODE_string; - reg [63:0] _zz_execute_to_memory_FPU_OPCODE_string; - reg [63:0] _zz_execute_to_memory_FPU_OPCODE_1_string; - reg [63:0] _zz_decode_to_execute_FPU_OPCODE_string; - reg [63:0] _zz_decode_to_execute_FPU_OPCODE_1_string; reg [39:0] decode_ALU_BITWISE_CTRL_string; reg [39:0] _zz_decode_ALU_BITWISE_CTRL_string; reg [39:0] _zz_decode_to_execute_ALU_BITWISE_CTRL_string; @@ -1533,10 +1249,6 @@ module VexRiscv ( reg [31:0] _zz_execute_BRANCH_CTRL_string; reg [71:0] execute_SHIFT_CTRL_string; reg [71:0] _zz_execute_SHIFT_CTRL_string; - reg [63:0] decode_FPU_OPCODE_string; - reg [63:0] _zz_decode_FPU_OPCODE_string; - reg [63:0] writeBack_FPU_OPCODE_string; - reg [63:0] _zz_writeBack_FPU_OPCODE_string; reg [23:0] decode_SRC2_CTRL_string; reg [23:0] _zz_decode_SRC2_CTRL_string; reg [95:0] decode_SRC1_CTRL_string; @@ -1545,9 +1257,8 @@ module VexRiscv ( reg [63:0] _zz_execute_ALU_CTRL_string; reg [39:0] execute_ALU_BITWISE_CTRL_string; reg [39:0] _zz_execute_ALU_BITWISE_CTRL_string; - reg [31:0] _zz_decode_BRANCH_CTRL_1_string; + reg [31:0] _zz_decode_BRANCH_CTRL_string; reg [71:0] _zz_decode_SHIFT_CTRL_1_string; - reg [63:0] _zz_decode_FPU_OPCODE_1_string; reg [39:0] _zz_decode_ALU_BITWISE_CTRL_1_string; reg [47:0] _zz_decode_ENV_CTRL_1_string; reg [23:0] _zz_decode_SRC2_CTRL_1_string; @@ -1559,32 +1270,20 @@ module VexRiscv ( reg [47:0] _zz_execute_ENV_CTRL_string; reg [47:0] writeBack_ENV_CTRL_string; reg [47:0] _zz_writeBack_ENV_CTRL_string; - reg [63:0] FpuPlugin_port_cmd_payload_opcode_string; - reg [47:0] FpuPlugin_port_cmd_payload_format_string; - reg [23:0] FpuPlugin_port_cmd_payload_roundMode_string; - reg [63:0] FpuPlugin_port_commit_payload_opcode_string; + reg [31:0] decode_BRANCH_CTRL_string; + reg [31:0] _zz_decode_BRANCH_CTRL_1_string; reg [95:0] _zz_decode_SRC1_CTRL_2_string; reg [63:0] _zz_decode_ALU_CTRL_2_string; reg [23:0] _zz_decode_SRC2_CTRL_2_string; reg [47:0] _zz_decode_ENV_CTRL_2_string; reg [39:0] _zz_decode_ALU_BITWISE_CTRL_2_string; - reg [63:0] _zz_decode_FPU_OPCODE_2_string; - reg [71:0] _zz_decode_SHIFT_CTRL_2_string; - reg [31:0] _zz_decode_BRANCH_CTRL_14_string; - reg [23:0] _zz_FpuPlugin_port_cmd_payload_roundMode_string; - reg [23:0] _zz_FpuPlugin_port_cmd_payload_roundMode_1_string; - reg [63:0] writeBack_FpuPlugin_commit_payload_opcode_string; - reg [63:0] writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string; - reg [63:0] writeBack_FpuPlugin_commit_rData_opcode_string; - reg [63:0] _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string; + reg [71:0] _zz_decode_SHIFT_CTRL_10_string; + reg [31:0] _zz_decode_BRANCH_CTRL_2_string; reg [63:0] decode_to_execute_ALU_CTRL_string; reg [47:0] decode_to_execute_ENV_CTRL_string; reg [47:0] execute_to_memory_ENV_CTRL_string; reg [47:0] memory_to_writeBack_ENV_CTRL_string; reg [39:0] decode_to_execute_ALU_BITWISE_CTRL_string; - reg [63:0] decode_to_execute_FPU_OPCODE_string; - reg [63:0] execute_to_memory_FPU_OPCODE_string; - reg [63:0] memory_to_writeBack_FPU_OPCODE_string; reg [71:0] decode_to_execute_SHIFT_CTRL_string; reg [31:0] decode_to_execute_BRANCH_CTRL_string; `endif @@ -1611,8 +1310,10 @@ module VexRiscv ( assign _zz_IBusSimplePlugin_decompressor_decompressed_27 = {{_zz_IBusSimplePlugin_decompressor_decompressed_10,_zz_IBusSimplePlugin_decompressor_decompressed[6 : 2]},12'h0}; assign _zz_IBusSimplePlugin_decompressor_decompressed_34 = {{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[8 : 7]},_zz_IBusSimplePlugin_decompressor_decompressed[12 : 9]},2'b00}; assign _zz_IBusSimplePlugin_decompressor_decompressed_35 = {{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[8 : 7]},_zz_IBusSimplePlugin_decompressor_decompressed[12 : 9]},2'b00}; - assign _zz_IBusSimplePlugin_decompressor_decompressed_36 = {{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[8 : 7]},_zz_IBusSimplePlugin_decompressor_decompressed[12 : 9]},2'b00}; - assign _zz_IBusSimplePlugin_decompressor_decompressed_37 = {{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[8 : 7]},_zz_IBusSimplePlugin_decompressor_decompressed[12 : 9]},2'b00}; + assign _zz__zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch = {{{decode_INSTRUCTION[31],decode_INSTRUCTION[7]},decode_INSTRUCTION[30 : 25]},decode_INSTRUCTION[11 : 8]}; + assign _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_2 = {{_zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1,{{{decode_INSTRUCTION[31],decode_INSTRUCTION[7]},decode_INSTRUCTION[30 : 25]},decode_INSTRUCTION[11 : 8]}},1'b0}; + assign _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload = {{{decode_INSTRUCTION[31],decode_INSTRUCTION[19 : 12]},decode_INSTRUCTION[20]},decode_INSTRUCTION[30 : 21]}; + assign _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload_2 = {{{decode_INSTRUCTION[31],decode_INSTRUCTION[7]},decode_INSTRUCTION[30 : 25]},decode_INSTRUCTION[11 : 8]}; assign _zz_IBusSimplePlugin_pending_next = (IBusSimplePlugin_pending_value + _zz_IBusSimplePlugin_pending_next_1); assign _zz_IBusSimplePlugin_pending_next_2 = IBusSimplePlugin_pending_inc; assign _zz_IBusSimplePlugin_pending_next_1 = {2'd0, _zz_IBusSimplePlugin_pending_next_2}; @@ -1622,8 +1323,7 @@ module VexRiscv ( assign _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter = {2'd0, _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_1}; assign _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_3 = IBusSimplePlugin_pending_dec; assign _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_2 = {2'd0, _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_3}; - assign _zz_DBusCachedPlugin_exceptionBus_payload_code = (writeBack_MEMORY_WR ? 3'b111 : 3'b101); - assign _zz_DBusCachedPlugin_exceptionBus_payload_code_1 = (writeBack_MEMORY_WR ? 3'b110 : 3'b100); + assign _zz_DBusSimplePlugin_memoryExceptionPort_payload_code = (memory_MEMORY_STORE ? 3'b110 : 3'b100); assign _zz__zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code_1 = (_zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code & (~ _zz__zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code_1_1)); assign _zz__zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code_1_1 = (_zz_CsrPlugin_exceptionPortCtrl_exceptionContext_code - 2'b01); assign _zz__zz_execute_REGFILE_WRITE_DATA = execute_SRC_LESS; @@ -1639,8 +1339,8 @@ module VexRiscv ( assign _zz_execute_SrcPlugin_addSub_6 = 32'h0; assign _zz_writeBack_MulPlugin_result = {{14{writeBack_MUL_LOW[51]}}, writeBack_MUL_LOW}; assign _zz_writeBack_MulPlugin_result_1 = ({32'd0,writeBack_MUL_HH} <<< 32); - assign _zz__zz_lastStageRegFileWrite_payload_data = writeBack_MUL_LOW[31 : 0]; - assign _zz__zz_lastStageRegFileWrite_payload_data_1 = writeBack_MulPlugin_result[63 : 32]; + assign _zz__zz_decode_RS2_2 = writeBack_MUL_LOW[31 : 0]; + assign _zz__zz_decode_RS2_2_1 = writeBack_MulPlugin_result[63 : 32]; assign _zz_memory_DivPlugin_div_counter_valueNext_1 = memory_DivPlugin_div_counter_willIncrement; assign _zz_memory_DivPlugin_div_counter_valueNext = {5'd0, _zz_memory_DivPlugin_div_counter_valueNext_1}; assign _zz_memory_DivPlugin_div_stage_0_remainderMinusDenominator = {1'd0, memory_DivPlugin_rs2}; @@ -1656,252 +1356,165 @@ module VexRiscv ( assign _zz_memory_DivPlugin_rs1_2 = {32'd0, _zz_memory_DivPlugin_rs1_3}; assign _zz_memory_DivPlugin_rs2_2 = _zz_memory_DivPlugin_rs2; assign _zz_memory_DivPlugin_rs2_1 = {31'd0, _zz_memory_DivPlugin_rs2_2}; - assign _zz_FpuPlugin_pendings = (_zz_FpuPlugin_pendings_1 - _zz_FpuPlugin_pendings_4); - assign _zz_FpuPlugin_pendings_1 = (FpuPlugin_pendings + _zz_FpuPlugin_pendings_2); - assign _zz_FpuPlugin_pendings_3 = FpuPlugin_port_cmd_fire; - assign _zz_FpuPlugin_pendings_2 = {5'd0, _zz_FpuPlugin_pendings_3}; - assign _zz_FpuPlugin_pendings_5 = FpuPlugin_port_completion_valid; - assign _zz_FpuPlugin_pendings_4 = {5'd0, _zz_FpuPlugin_pendings_5}; - assign _zz_FpuPlugin_pendings_7 = FpuPlugin_port_rsp_fire; - assign _zz_FpuPlugin_pendings_6 = {5'd0, _zz_FpuPlugin_pendings_7}; - assign _zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1 = (_zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1_1 >>> 1); - assign _zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1_1 = {((execute_SHIFT_CTRL == ShiftCtrlEnum_SRA_1) && execute_LightShifterPlugin_shiftInput[31]),execute_LightShifterPlugin_shiftInput}; - assign _zz__zz_execute_BranchPlugin_branch_src2 = {{{execute_INSTRUCTION[31],execute_INSTRUCTION[19 : 12]},execute_INSTRUCTION[20]},execute_INSTRUCTION[30 : 21]}; + assign _zz__zz_decode_RS2_3 = (_zz__zz_decode_RS2_3_1 >>> 1); + assign _zz__zz_decode_RS2_3_1 = {((execute_SHIFT_CTRL == ShiftCtrlEnum_SRA_1) && execute_LightShifterPlugin_shiftInput[31]),execute_LightShifterPlugin_shiftInput}; + assign _zz__zz_execute_BranchPlugin_branch_src2_2 = {{{execute_INSTRUCTION[31],execute_INSTRUCTION[19 : 12]},execute_INSTRUCTION[20]},execute_INSTRUCTION[30 : 21]}; assign _zz__zz_execute_BranchPlugin_branch_src2_4 = {{{execute_INSTRUCTION[31],execute_INSTRUCTION[7]},execute_INSTRUCTION[30 : 25]},execute_INSTRUCTION[11 : 8]}; + assign _zz_execute_BranchPlugin_branch_src2_9 = (execute_IS_RVC ? 3'b010 : 3'b100); assign _zz_decode_RegFilePlugin_rs1Data = 1'b1; assign _zz_decode_RegFilePlugin_rs2Data = 1'b1; assign _zz_IBusSimplePlugin_jump_pcLoad_payload_5 = {_zz_IBusSimplePlugin_jump_pcLoad_payload_3,_zz_IBusSimplePlugin_jump_pcLoad_payload_2}; - assign _zz_writeBack_DBusCachedPlugin_rspShifted_1 = dataCache_1_io_cpu_writeBack_address[1 : 0]; - assign _zz_writeBack_DBusCachedPlugin_rspShifted_3 = dataCache_1_io_cpu_writeBack_address[1 : 1]; - assign _zz_decode_LEGAL_INSTRUCTION = 32'h0000106f; - assign _zz_decode_LEGAL_INSTRUCTION_1 = (decode_INSTRUCTION & 32'h0000107f); - assign _zz_decode_LEGAL_INSTRUCTION_2 = 32'h00001073; - assign _zz_decode_LEGAL_INSTRUCTION_3 = ((decode_INSTRUCTION & 32'h0000207f) == 32'h00002073); - assign _zz_decode_LEGAL_INSTRUCTION_4 = ((decode_INSTRUCTION & 32'h0000407f) == 32'h00004063); - assign _zz_decode_LEGAL_INSTRUCTION_5 = {((decode_INSTRUCTION & 32'h0000207f) == 32'h00002013),{((decode_INSTRUCTION & 32'h0000705b) == 32'h00002003),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION_6) == 32'h00000023),{(_zz_decode_LEGAL_INSTRUCTION_7 == _zz_decode_LEGAL_INSTRUCTION_8),{_zz_decode_LEGAL_INSTRUCTION_9,{_zz_decode_LEGAL_INSTRUCTION_10,_zz_decode_LEGAL_INSTRUCTION_11}}}}}}; - assign _zz_decode_LEGAL_INSTRUCTION_6 = 32'h0000603f; - assign _zz_decode_LEGAL_INSTRUCTION_7 = (decode_INSTRUCTION & 32'h0000207f); - assign _zz_decode_LEGAL_INSTRUCTION_8 = 32'h00000003; - assign _zz_decode_LEGAL_INSTRUCTION_9 = ((decode_INSTRUCTION & 32'h0000707b) == 32'h00000063); - assign _zz_decode_LEGAL_INSTRUCTION_10 = ((decode_INSTRUCTION & 32'h0000607f) == 32'h0000000f); - assign _zz_decode_LEGAL_INSTRUCTION_11 = {((decode_INSTRUCTION & 32'he600007f) == 32'h00000053),{((decode_INSTRUCTION & 32'hfc00007f) == 32'h00000033),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION_12) == 32'h0000500f),{(_zz_decode_LEGAL_INSTRUCTION_13 == _zz_decode_LEGAL_INSTRUCTION_14),{_zz_decode_LEGAL_INSTRUCTION_15,{_zz_decode_LEGAL_INSTRUCTION_16,_zz_decode_LEGAL_INSTRUCTION_17}}}}}}; - assign _zz_decode_LEGAL_INSTRUCTION_12 = 32'h01f0707f; - assign _zz_decode_LEGAL_INSTRUCTION_13 = (decode_INSTRUCTION & 32'h7e00507f); - assign _zz_decode_LEGAL_INSTRUCTION_14 = 32'h20000053; - assign _zz_decode_LEGAL_INSTRUCTION_15 = ((decode_INSTRUCTION & 32'hf600607f) == 32'h20000053); - assign _zz_decode_LEGAL_INSTRUCTION_16 = ((decode_INSTRUCTION & 32'hbc00707f) == 32'h00005013); - assign _zz_decode_LEGAL_INSTRUCTION_17 = {((decode_INSTRUCTION & 32'h7e00607f) == 32'h20000053),{((decode_INSTRUCTION & 32'hfc00307f) == 32'h00001013),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION_18) == 32'h00005033),{(_zz_decode_LEGAL_INSTRUCTION_19 == _zz_decode_LEGAL_INSTRUCTION_20),{_zz_decode_LEGAL_INSTRUCTION_21,{_zz_decode_LEGAL_INSTRUCTION_22,_zz_decode_LEGAL_INSTRUCTION_23}}}}}}; - assign _zz_decode_LEGAL_INSTRUCTION_18 = 32'hbe00707f; - assign _zz_decode_LEGAL_INSTRUCTION_19 = (decode_INSTRUCTION & 32'hbe00707f); - assign _zz_decode_LEGAL_INSTRUCTION_20 = 32'h00000033; - assign _zz_decode_LEGAL_INSTRUCTION_21 = ((decode_INSTRUCTION & 32'hefe0007f) == 32'hc0000053); - assign _zz_decode_LEGAL_INSTRUCTION_22 = ((decode_INSTRUCTION & 32'hfff0007f) == 32'h58000053); - assign _zz_decode_LEGAL_INSTRUCTION_23 = {((decode_INSTRUCTION & 32'heff0707f) == 32'he0000053),{((decode_INSTRUCTION & 32'hfff0607f) == 32'he0000053),{((decode_INSTRUCTION & 32'hdfffffff) == 32'h10200073),((decode_INSTRUCTION & 32'hffffffff) == 32'h00100073)}}}; + assign _zz_decode_LEGAL_INSTRUCTION = 32'h0000107f; + assign _zz_decode_LEGAL_INSTRUCTION_1 = (decode_INSTRUCTION & 32'h0000207f); + assign _zz_decode_LEGAL_INSTRUCTION_2 = 32'h00002073; + assign _zz_decode_LEGAL_INSTRUCTION_3 = ((decode_INSTRUCTION & 32'h0000407f) == 32'h00004063); + assign _zz_decode_LEGAL_INSTRUCTION_4 = ((decode_INSTRUCTION & 32'h0000207f) == 32'h00002013); + assign _zz_decode_LEGAL_INSTRUCTION_5 = {((decode_INSTRUCTION & 32'h0000603f) == 32'h00000023),{((decode_INSTRUCTION & 32'h0000207f) == 32'h00000003),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION_6) == 32'h00000003),{(_zz_decode_LEGAL_INSTRUCTION_7 == _zz_decode_LEGAL_INSTRUCTION_8),{_zz_decode_LEGAL_INSTRUCTION_9,{_zz_decode_LEGAL_INSTRUCTION_10,_zz_decode_LEGAL_INSTRUCTION_11}}}}}}; + assign _zz_decode_LEGAL_INSTRUCTION_6 = 32'h0000505f; + assign _zz_decode_LEGAL_INSTRUCTION_7 = (decode_INSTRUCTION & 32'h0000707b); + assign _zz_decode_LEGAL_INSTRUCTION_8 = 32'h00000063; + assign _zz_decode_LEGAL_INSTRUCTION_9 = ((decode_INSTRUCTION & 32'h0000607f) == 32'h0000000f); + assign _zz_decode_LEGAL_INSTRUCTION_10 = ((decode_INSTRUCTION & 32'hfc00007f) == 32'h00000033); + assign _zz_decode_LEGAL_INSTRUCTION_11 = {((decode_INSTRUCTION & 32'hbc00707f) == 32'h00005013),{((decode_INSTRUCTION & 32'hfc00307f) == 32'h00001013),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION_12) == 32'h00005033),{(_zz_decode_LEGAL_INSTRUCTION_13 == _zz_decode_LEGAL_INSTRUCTION_14),{_zz_decode_LEGAL_INSTRUCTION_15,_zz_decode_LEGAL_INSTRUCTION_16}}}}}; + assign _zz_decode_LEGAL_INSTRUCTION_12 = 32'hbe00707f; + assign _zz_decode_LEGAL_INSTRUCTION_13 = (decode_INSTRUCTION & 32'hbe00707f); + assign _zz_decode_LEGAL_INSTRUCTION_14 = 32'h00000033; + assign _zz_decode_LEGAL_INSTRUCTION_15 = ((decode_INSTRUCTION & 32'hdfffffff) == 32'h10200073); + assign _zz_decode_LEGAL_INSTRUCTION_16 = ((decode_INSTRUCTION & 32'hffffffff) == 32'h00100073); assign _zz_IBusSimplePlugin_decompressor_decompressed_28 = (_zz_IBusSimplePlugin_decompressor_decompressed[11 : 10] == 2'b01); assign _zz_IBusSimplePlugin_decompressor_decompressed_29 = ((_zz_IBusSimplePlugin_decompressor_decompressed[11 : 10] == 2'b11) && (_zz_IBusSimplePlugin_decompressor_decompressed[6 : 5] == 2'b00)); assign _zz_IBusSimplePlugin_decompressor_decompressed_30 = 7'h0; assign _zz_IBusSimplePlugin_decompressor_decompressed_31 = _zz_IBusSimplePlugin_decompressor_decompressed[6 : 2]; assign _zz_IBusSimplePlugin_decompressor_decompressed_32 = _zz_IBusSimplePlugin_decompressor_decompressed[12]; assign _zz_IBusSimplePlugin_decompressor_decompressed_33 = _zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]; - assign _zz__zz_decode_BRANCH_CTRL_2 = (decode_INSTRUCTION & 32'h00002034); - assign _zz__zz_decode_BRANCH_CTRL_2_1 = 32'h00000024; - assign _zz__zz_decode_BRANCH_CTRL_2_2 = (decode_INSTRUCTION & 32'h00000078); - assign _zz__zz_decode_BRANCH_CTRL_2_3 = 32'h00000060; - assign _zz__zz_decode_BRANCH_CTRL_2_4 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_5) == 32'h00005010); - assign _zz__zz_decode_BRANCH_CTRL_2_6 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_7) == 32'h00005020); - assign _zz__zz_decode_BRANCH_CTRL_2_8 = {(_zz__zz_decode_BRANCH_CTRL_2_9 == _zz__zz_decode_BRANCH_CTRL_2_10),{_zz__zz_decode_BRANCH_CTRL_2_11,_zz__zz_decode_BRANCH_CTRL_2_12}}; - assign _zz__zz_decode_BRANCH_CTRL_2_13 = (|{_zz_decode_BRANCH_CTRL_11,_zz__zz_decode_BRANCH_CTRL_2_14}); - assign _zz__zz_decode_BRANCH_CTRL_2_15 = (|{_zz__zz_decode_BRANCH_CTRL_2_16,_zz__zz_decode_BRANCH_CTRL_2_17}); - assign _zz__zz_decode_BRANCH_CTRL_2_24 = {1'b0,{_zz__zz_decode_BRANCH_CTRL_2_25,{_zz__zz_decode_BRANCH_CTRL_2_34,_zz__zz_decode_BRANCH_CTRL_2_41}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_5 = 32'h00007074; - assign _zz__zz_decode_BRANCH_CTRL_2_7 = 32'h02007064; - assign _zz__zz_decode_BRANCH_CTRL_2_9 = (decode_INSTRUCTION & 32'h40003054); - assign _zz__zz_decode_BRANCH_CTRL_2_10 = 32'h40001010; - assign _zz__zz_decode_BRANCH_CTRL_2_11 = ((decode_INSTRUCTION & 32'h00007074) == 32'h00001010); - assign _zz__zz_decode_BRANCH_CTRL_2_12 = ((decode_INSTRUCTION & 32'h02007054) == 32'h00001010); - assign _zz__zz_decode_BRANCH_CTRL_2_14 = ((decode_INSTRUCTION & 32'h20002010) == 32'h20002010); - assign _zz__zz_decode_BRANCH_CTRL_2_16 = _zz_decode_BRANCH_CTRL_5; - assign _zz__zz_decode_BRANCH_CTRL_2_17 = {(_zz__zz_decode_BRANCH_CTRL_2_18 == _zz__zz_decode_BRANCH_CTRL_2_19),{_zz__zz_decode_BRANCH_CTRL_2_20,_zz__zz_decode_BRANCH_CTRL_2_22}}; - assign _zz__zz_decode_BRANCH_CTRL_2_25 = (|{_zz__zz_decode_BRANCH_CTRL_2_26,{_zz__zz_decode_BRANCH_CTRL_2_28,_zz__zz_decode_BRANCH_CTRL_2_31}}); - assign _zz__zz_decode_BRANCH_CTRL_2_34 = (|{_zz__zz_decode_BRANCH_CTRL_2_35,_zz__zz_decode_BRANCH_CTRL_2_38}); - assign _zz__zz_decode_BRANCH_CTRL_2_41 = {(|_zz__zz_decode_BRANCH_CTRL_2_42),{_zz__zz_decode_BRANCH_CTRL_2_53,{_zz__zz_decode_BRANCH_CTRL_2_64,_zz__zz_decode_BRANCH_CTRL_2_66}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_18 = (decode_INSTRUCTION & 32'h20001010); - assign _zz__zz_decode_BRANCH_CTRL_2_19 = 32'h20001010; - assign _zz__zz_decode_BRANCH_CTRL_2_20 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_21) == 32'h08000010); - assign _zz__zz_decode_BRANCH_CTRL_2_22 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_23) == 32'h80000010); - assign _zz__zz_decode_BRANCH_CTRL_2_26 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_27) == 32'h60000010); - assign _zz__zz_decode_BRANCH_CTRL_2_28 = (_zz__zz_decode_BRANCH_CTRL_2_29 == _zz__zz_decode_BRANCH_CTRL_2_30); - assign _zz__zz_decode_BRANCH_CTRL_2_31 = (_zz__zz_decode_BRANCH_CTRL_2_32 == _zz__zz_decode_BRANCH_CTRL_2_33); - assign _zz__zz_decode_BRANCH_CTRL_2_35 = (_zz__zz_decode_BRANCH_CTRL_2_36 == _zz__zz_decode_BRANCH_CTRL_2_37); - assign _zz__zz_decode_BRANCH_CTRL_2_38 = (_zz__zz_decode_BRANCH_CTRL_2_39 == _zz__zz_decode_BRANCH_CTRL_2_40); - assign _zz__zz_decode_BRANCH_CTRL_2_42 = {_zz__zz_decode_BRANCH_CTRL_2_43,{_zz__zz_decode_BRANCH_CTRL_2_45,_zz__zz_decode_BRANCH_CTRL_2_48}}; - assign _zz__zz_decode_BRANCH_CTRL_2_53 = (|{_zz__zz_decode_BRANCH_CTRL_2_54,_zz__zz_decode_BRANCH_CTRL_2_55}); - assign _zz__zz_decode_BRANCH_CTRL_2_64 = (|_zz__zz_decode_BRANCH_CTRL_2_65); - assign _zz__zz_decode_BRANCH_CTRL_2_66 = {_zz__zz_decode_BRANCH_CTRL_2_67,{_zz__zz_decode_BRANCH_CTRL_2_74,_zz__zz_decode_BRANCH_CTRL_2_78}}; - assign _zz__zz_decode_BRANCH_CTRL_2_21 = 32'h28000010; - assign _zz__zz_decode_BRANCH_CTRL_2_23 = 32'ha0100010; - assign _zz__zz_decode_BRANCH_CTRL_2_27 = 32'h60000010; - assign _zz__zz_decode_BRANCH_CTRL_2_29 = (decode_INSTRUCTION & 32'h18000010); - assign _zz__zz_decode_BRANCH_CTRL_2_30 = 32'h18000010; - assign _zz__zz_decode_BRANCH_CTRL_2_32 = (decode_INSTRUCTION & 32'ha0000010); - assign _zz__zz_decode_BRANCH_CTRL_2_33 = 32'h20000010; - assign _zz__zz_decode_BRANCH_CTRL_2_36 = (decode_INSTRUCTION & 32'h80000004); - assign _zz__zz_decode_BRANCH_CTRL_2_37 = 32'h80000000; - assign _zz__zz_decode_BRANCH_CTRL_2_39 = (decode_INSTRUCTION & 32'h00000050); - assign _zz__zz_decode_BRANCH_CTRL_2_40 = 32'h00000040; - assign _zz__zz_decode_BRANCH_CTRL_2_43 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_44) == 32'h00001010); - assign _zz__zz_decode_BRANCH_CTRL_2_45 = (_zz__zz_decode_BRANCH_CTRL_2_46 == _zz__zz_decode_BRANCH_CTRL_2_47); - assign _zz__zz_decode_BRANCH_CTRL_2_48 = {_zz__zz_decode_BRANCH_CTRL_2_49,_zz__zz_decode_BRANCH_CTRL_2_51}; - assign _zz__zz_decode_BRANCH_CTRL_2_54 = _zz_decode_BRANCH_CTRL_12; - assign _zz__zz_decode_BRANCH_CTRL_2_55 = {_zz__zz_decode_BRANCH_CTRL_2_56,{_zz__zz_decode_BRANCH_CTRL_2_58,_zz__zz_decode_BRANCH_CTRL_2_61}}; - assign _zz__zz_decode_BRANCH_CTRL_2_65 = {_zz_decode_BRANCH_CTRL_12,_zz_decode_BRANCH_CTRL_8}; - assign _zz__zz_decode_BRANCH_CTRL_2_67 = (|{_zz__zz_decode_BRANCH_CTRL_2_68,_zz__zz_decode_BRANCH_CTRL_2_71}); - assign _zz__zz_decode_BRANCH_CTRL_2_74 = (|_zz__zz_decode_BRANCH_CTRL_2_75); - assign _zz__zz_decode_BRANCH_CTRL_2_78 = {_zz__zz_decode_BRANCH_CTRL_2_79,{_zz__zz_decode_BRANCH_CTRL_2_80,_zz__zz_decode_BRANCH_CTRL_2_82}}; - assign _zz__zz_decode_BRANCH_CTRL_2_44 = 32'h10001010; - assign _zz__zz_decode_BRANCH_CTRL_2_46 = (decode_INSTRUCTION & 32'h30000010); - assign _zz__zz_decode_BRANCH_CTRL_2_47 = 32'h00000010; - assign _zz__zz_decode_BRANCH_CTRL_2_49 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_50) == 32'h00000010); - assign _zz__zz_decode_BRANCH_CTRL_2_51 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_52) == 32'h00000010); - assign _zz__zz_decode_BRANCH_CTRL_2_56 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_57) == 32'h90000010); - assign _zz__zz_decode_BRANCH_CTRL_2_58 = (_zz__zz_decode_BRANCH_CTRL_2_59 == _zz__zz_decode_BRANCH_CTRL_2_60); - assign _zz__zz_decode_BRANCH_CTRL_2_61 = {_zz__zz_decode_BRANCH_CTRL_2_62,_zz__zz_decode_BRANCH_CTRL_2_63}; - assign _zz__zz_decode_BRANCH_CTRL_2_68 = (_zz__zz_decode_BRANCH_CTRL_2_69 == _zz__zz_decode_BRANCH_CTRL_2_70); - assign _zz__zz_decode_BRANCH_CTRL_2_71 = {_zz__zz_decode_BRANCH_CTRL_2_72,_zz__zz_decode_BRANCH_CTRL_2_73}; - assign _zz__zz_decode_BRANCH_CTRL_2_75 = {_zz__zz_decode_BRANCH_CTRL_2_76,_zz__zz_decode_BRANCH_CTRL_2_77}; - assign _zz__zz_decode_BRANCH_CTRL_2_79 = (|_zz_decode_BRANCH_CTRL_13); - assign _zz__zz_decode_BRANCH_CTRL_2_80 = (|_zz__zz_decode_BRANCH_CTRL_2_81); - assign _zz__zz_decode_BRANCH_CTRL_2_82 = {_zz__zz_decode_BRANCH_CTRL_2_83,{_zz__zz_decode_BRANCH_CTRL_2_86,_zz__zz_decode_BRANCH_CTRL_2_88}}; - assign _zz__zz_decode_BRANCH_CTRL_2_50 = 32'h88000010; - assign _zz__zz_decode_BRANCH_CTRL_2_52 = 32'h50000010; - assign _zz__zz_decode_BRANCH_CTRL_2_57 = 32'h90000010; - assign _zz__zz_decode_BRANCH_CTRL_2_59 = (decode_INSTRUCTION & 32'hc0000010); - assign _zz__zz_decode_BRANCH_CTRL_2_60 = 32'h40000010; - assign _zz__zz_decode_BRANCH_CTRL_2_62 = ((decode_INSTRUCTION & 32'h58000010) == 32'h00000010); - assign _zz__zz_decode_BRANCH_CTRL_2_63 = ((decode_INSTRUCTION & 32'hb0000010) == 32'h00000010); - assign _zz__zz_decode_BRANCH_CTRL_2_69 = (decode_INSTRUCTION & 32'h10000020); - assign _zz__zz_decode_BRANCH_CTRL_2_70 = 32'h10000000; - assign _zz__zz_decode_BRANCH_CTRL_2_72 = ((decode_INSTRUCTION & 32'h80000020) == 32'h0); - assign _zz__zz_decode_BRANCH_CTRL_2_73 = ((decode_INSTRUCTION & 32'h00000030) == 32'h0); - assign _zz__zz_decode_BRANCH_CTRL_2_76 = ((decode_INSTRUCTION & 32'h00000060) == 32'h00000040); - assign _zz__zz_decode_BRANCH_CTRL_2_77 = ((decode_INSTRUCTION & 32'h0000005c) == 32'h00000004); - assign _zz__zz_decode_BRANCH_CTRL_2_81 = _zz_decode_BRANCH_CTRL_13; - assign _zz__zz_decode_BRANCH_CTRL_2_83 = (|(_zz__zz_decode_BRANCH_CTRL_2_84 == _zz__zz_decode_BRANCH_CTRL_2_85)); - assign _zz__zz_decode_BRANCH_CTRL_2_86 = (|_zz__zz_decode_BRANCH_CTRL_2_87); - assign _zz__zz_decode_BRANCH_CTRL_2_88 = {(|_zz__zz_decode_BRANCH_CTRL_2_89),{_zz__zz_decode_BRANCH_CTRL_2_95,{_zz__zz_decode_BRANCH_CTRL_2_97,_zz__zz_decode_BRANCH_CTRL_2_100}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_84 = (decode_INSTRUCTION & 32'h02004064); - assign _zz__zz_decode_BRANCH_CTRL_2_85 = 32'h02004020; - assign _zz__zz_decode_BRANCH_CTRL_2_87 = ((decode_INSTRUCTION & 32'h02004074) == 32'h02000030); - assign _zz__zz_decode_BRANCH_CTRL_2_89 = {((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_90) == 32'h00000034),{(_zz__zz_decode_BRANCH_CTRL_2_91 == _zz__zz_decode_BRANCH_CTRL_2_92),(_zz__zz_decode_BRANCH_CTRL_2_93 == _zz__zz_decode_BRANCH_CTRL_2_94)}}; - assign _zz__zz_decode_BRANCH_CTRL_2_95 = (|((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_96) == 32'h00001000)); - assign _zz__zz_decode_BRANCH_CTRL_2_97 = (|(_zz__zz_decode_BRANCH_CTRL_2_98 == _zz__zz_decode_BRANCH_CTRL_2_99)); - assign _zz__zz_decode_BRANCH_CTRL_2_100 = {(|{_zz__zz_decode_BRANCH_CTRL_2_101,_zz__zz_decode_BRANCH_CTRL_2_103}),{(|_zz__zz_decode_BRANCH_CTRL_2_105),{_zz__zz_decode_BRANCH_CTRL_2_107,{_zz__zz_decode_BRANCH_CTRL_2_110,_zz__zz_decode_BRANCH_CTRL_2_113}}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_90 = 32'h00000034; - assign _zz__zz_decode_BRANCH_CTRL_2_91 = (decode_INSTRUCTION & 32'h00003074); - assign _zz__zz_decode_BRANCH_CTRL_2_92 = 32'h00001010; - assign _zz__zz_decode_BRANCH_CTRL_2_93 = (decode_INSTRUCTION & 32'h02003054); - assign _zz__zz_decode_BRANCH_CTRL_2_94 = 32'h00001010; - assign _zz__zz_decode_BRANCH_CTRL_2_96 = 32'h00001000; - assign _zz__zz_decode_BRANCH_CTRL_2_98 = (decode_INSTRUCTION & 32'h00003000); - assign _zz__zz_decode_BRANCH_CTRL_2_99 = 32'h00002000; - assign _zz__zz_decode_BRANCH_CTRL_2_101 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_102) == 32'h00002000); - assign _zz__zz_decode_BRANCH_CTRL_2_103 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_104) == 32'h00001000); - assign _zz__zz_decode_BRANCH_CTRL_2_105 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_106) == 32'h00000070); - assign _zz__zz_decode_BRANCH_CTRL_2_107 = (|(_zz__zz_decode_BRANCH_CTRL_2_108 == _zz__zz_decode_BRANCH_CTRL_2_109)); - assign _zz__zz_decode_BRANCH_CTRL_2_110 = (|{_zz__zz_decode_BRANCH_CTRL_2_111,_zz__zz_decode_BRANCH_CTRL_2_112}); - assign _zz__zz_decode_BRANCH_CTRL_2_113 = {(|_zz__zz_decode_BRANCH_CTRL_2_114),{_zz__zz_decode_BRANCH_CTRL_2_115,{_zz__zz_decode_BRANCH_CTRL_2_120,_zz__zz_decode_BRANCH_CTRL_2_125}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_102 = 32'h00002010; - assign _zz__zz_decode_BRANCH_CTRL_2_104 = 32'h00005000; - assign _zz__zz_decode_BRANCH_CTRL_2_106 = 32'h10003070; - assign _zz__zz_decode_BRANCH_CTRL_2_108 = (decode_INSTRUCTION & 32'h10003034); - assign _zz__zz_decode_BRANCH_CTRL_2_109 = 32'h10000030; - assign _zz__zz_decode_BRANCH_CTRL_2_111 = ((decode_INSTRUCTION & 32'h00001070) == 32'h00001070); - assign _zz__zz_decode_BRANCH_CTRL_2_112 = ((decode_INSTRUCTION & 32'h00002070) == 32'h00002070); - assign _zz__zz_decode_BRANCH_CTRL_2_114 = ((decode_INSTRUCTION & 32'h00004048) == 32'h00004008); - assign _zz__zz_decode_BRANCH_CTRL_2_115 = (|{(_zz__zz_decode_BRANCH_CTRL_2_116 == _zz__zz_decode_BRANCH_CTRL_2_117),(_zz__zz_decode_BRANCH_CTRL_2_118 == _zz__zz_decode_BRANCH_CTRL_2_119)}); - assign _zz__zz_decode_BRANCH_CTRL_2_120 = (|{_zz__zz_decode_BRANCH_CTRL_2_121,{_zz__zz_decode_BRANCH_CTRL_2_122,_zz__zz_decode_BRANCH_CTRL_2_123}}); - assign _zz__zz_decode_BRANCH_CTRL_2_125 = {(|_zz_decode_BRANCH_CTRL_12),{(|_zz__zz_decode_BRANCH_CTRL_2_126),{_zz__zz_decode_BRANCH_CTRL_2_135,{_zz__zz_decode_BRANCH_CTRL_2_140,_zz__zz_decode_BRANCH_CTRL_2_155}}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_116 = (decode_INSTRUCTION & 32'h00000034); - assign _zz__zz_decode_BRANCH_CTRL_2_117 = 32'h00000020; - assign _zz__zz_decode_BRANCH_CTRL_2_118 = (decode_INSTRUCTION & 32'h00000064); - assign _zz__zz_decode_BRANCH_CTRL_2_119 = 32'h00000020; - assign _zz__zz_decode_BRANCH_CTRL_2_121 = ((decode_INSTRUCTION & 32'h00000030) == 32'h00000020); - assign _zz__zz_decode_BRANCH_CTRL_2_122 = _zz_decode_BRANCH_CTRL_6; - assign _zz__zz_decode_BRANCH_CTRL_2_123 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_124) == 32'h00000060); - assign _zz__zz_decode_BRANCH_CTRL_2_126 = {_zz_decode_BRANCH_CTRL_11,{_zz__zz_decode_BRANCH_CTRL_2_127,{_zz__zz_decode_BRANCH_CTRL_2_129,_zz__zz_decode_BRANCH_CTRL_2_132}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_135 = (|{_zz_decode_BRANCH_CTRL_11,{_zz__zz_decode_BRANCH_CTRL_2_136,_zz__zz_decode_BRANCH_CTRL_2_137}}); - assign _zz__zz_decode_BRANCH_CTRL_2_140 = (|{_zz__zz_decode_BRANCH_CTRL_2_141,_zz__zz_decode_BRANCH_CTRL_2_142}); - assign _zz__zz_decode_BRANCH_CTRL_2_155 = {(|_zz__zz_decode_BRANCH_CTRL_2_156),{_zz__zz_decode_BRANCH_CTRL_2_161,{_zz__zz_decode_BRANCH_CTRL_2_166,_zz__zz_decode_BRANCH_CTRL_2_172}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_124 = 32'h00003060; - assign _zz__zz_decode_BRANCH_CTRL_2_127 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_128) == 32'h00004020); - assign _zz__zz_decode_BRANCH_CTRL_2_129 = (_zz__zz_decode_BRANCH_CTRL_2_130 == _zz__zz_decode_BRANCH_CTRL_2_131); - assign _zz__zz_decode_BRANCH_CTRL_2_132 = {_zz__zz_decode_BRANCH_CTRL_2_133,_zz_decode_BRANCH_CTRL_10}; - assign _zz__zz_decode_BRANCH_CTRL_2_136 = _zz_decode_BRANCH_CTRL_10; - assign _zz__zz_decode_BRANCH_CTRL_2_137 = (_zz__zz_decode_BRANCH_CTRL_2_138 == _zz__zz_decode_BRANCH_CTRL_2_139); - assign _zz__zz_decode_BRANCH_CTRL_2_141 = _zz_decode_BRANCH_CTRL_9; - assign _zz__zz_decode_BRANCH_CTRL_2_142 = {_zz__zz_decode_BRANCH_CTRL_2_143,{_zz__zz_decode_BRANCH_CTRL_2_145,_zz__zz_decode_BRANCH_CTRL_2_148}}; - assign _zz__zz_decode_BRANCH_CTRL_2_156 = {_zz_decode_BRANCH_CTRL_5,{_zz__zz_decode_BRANCH_CTRL_2_157,_zz__zz_decode_BRANCH_CTRL_2_158}}; - assign _zz__zz_decode_BRANCH_CTRL_2_161 = (|{_zz__zz_decode_BRANCH_CTRL_2_162,_zz__zz_decode_BRANCH_CTRL_2_163}); - assign _zz__zz_decode_BRANCH_CTRL_2_166 = (|_zz__zz_decode_BRANCH_CTRL_2_167); - assign _zz__zz_decode_BRANCH_CTRL_2_172 = {_zz__zz_decode_BRANCH_CTRL_2_173,{_zz__zz_decode_BRANCH_CTRL_2_176,_zz__zz_decode_BRANCH_CTRL_2_186}}; - assign _zz__zz_decode_BRANCH_CTRL_2_128 = 32'h00004020; - assign _zz__zz_decode_BRANCH_CTRL_2_130 = (decode_INSTRUCTION & 32'h00000060); - assign _zz__zz_decode_BRANCH_CTRL_2_131 = 32'h00000060; - assign _zz__zz_decode_BRANCH_CTRL_2_133 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_134) == 32'h00000020); - assign _zz__zz_decode_BRANCH_CTRL_2_138 = (decode_INSTRUCTION & 32'h02000060); - assign _zz__zz_decode_BRANCH_CTRL_2_139 = 32'h00000020; - assign _zz__zz_decode_BRANCH_CTRL_2_143 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_144) == 32'h00000010); - assign _zz__zz_decode_BRANCH_CTRL_2_145 = (_zz__zz_decode_BRANCH_CTRL_2_146 == _zz__zz_decode_BRANCH_CTRL_2_147); - assign _zz__zz_decode_BRANCH_CTRL_2_148 = {_zz__zz_decode_BRANCH_CTRL_2_149,{_zz__zz_decode_BRANCH_CTRL_2_151,_zz__zz_decode_BRANCH_CTRL_2_152}}; - assign _zz__zz_decode_BRANCH_CTRL_2_157 = _zz_decode_BRANCH_CTRL_4; - assign _zz__zz_decode_BRANCH_CTRL_2_158 = {_zz_decode_BRANCH_CTRL_7,_zz__zz_decode_BRANCH_CTRL_2_159}; - assign _zz__zz_decode_BRANCH_CTRL_2_162 = _zz_decode_BRANCH_CTRL_5; - assign _zz__zz_decode_BRANCH_CTRL_2_163 = {_zz__zz_decode_BRANCH_CTRL_2_164,_zz_decode_BRANCH_CTRL_7}; - assign _zz__zz_decode_BRANCH_CTRL_2_167 = {_zz__zz_decode_BRANCH_CTRL_2_168,_zz__zz_decode_BRANCH_CTRL_2_170}; - assign _zz__zz_decode_BRANCH_CTRL_2_173 = (|_zz__zz_decode_BRANCH_CTRL_2_174); - assign _zz__zz_decode_BRANCH_CTRL_2_176 = (|_zz__zz_decode_BRANCH_CTRL_2_177); - assign _zz__zz_decode_BRANCH_CTRL_2_186 = {_zz__zz_decode_BRANCH_CTRL_2_187,{_zz__zz_decode_BRANCH_CTRL_2_188,_zz__zz_decode_BRANCH_CTRL_2_194}}; - assign _zz__zz_decode_BRANCH_CTRL_2_134 = 32'h02000020; - assign _zz__zz_decode_BRANCH_CTRL_2_144 = 32'h00000050; - assign _zz__zz_decode_BRANCH_CTRL_2_146 = (decode_INSTRUCTION & 32'h00001030); - assign _zz__zz_decode_BRANCH_CTRL_2_147 = 32'h00001030; - assign _zz__zz_decode_BRANCH_CTRL_2_149 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_150) == 32'h00002030); - assign _zz__zz_decode_BRANCH_CTRL_2_151 = _zz_decode_BRANCH_CTRL_8; - assign _zz__zz_decode_BRANCH_CTRL_2_152 = {_zz__zz_decode_BRANCH_CTRL_2_153,_zz__zz_decode_BRANCH_CTRL_2_154}; - assign _zz__zz_decode_BRANCH_CTRL_2_159 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_160) == 32'h00000020); - assign _zz__zz_decode_BRANCH_CTRL_2_164 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_165) == 32'h0); - assign _zz__zz_decode_BRANCH_CTRL_2_168 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_169) == 32'h00006010); - assign _zz__zz_decode_BRANCH_CTRL_2_170 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_171) == 32'h00004010); - assign _zz__zz_decode_BRANCH_CTRL_2_174 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_175) == 32'h00002010); - assign _zz__zz_decode_BRANCH_CTRL_2_177 = {_zz__zz_decode_BRANCH_CTRL_2_178,{_zz__zz_decode_BRANCH_CTRL_2_179,_zz__zz_decode_BRANCH_CTRL_2_181}}; - assign _zz__zz_decode_BRANCH_CTRL_2_187 = (|_zz_decode_BRANCH_CTRL_6); - assign _zz__zz_decode_BRANCH_CTRL_2_188 = (|_zz__zz_decode_BRANCH_CTRL_2_189); - assign _zz__zz_decode_BRANCH_CTRL_2_194 = {_zz__zz_decode_BRANCH_CTRL_2_195,_zz__zz_decode_BRANCH_CTRL_2_198}; - assign _zz__zz_decode_BRANCH_CTRL_2_150 = 32'h00002030; - assign _zz__zz_decode_BRANCH_CTRL_2_153 = ((decode_INSTRUCTION & 32'h00002024) == 32'h00000024); - assign _zz__zz_decode_BRANCH_CTRL_2_154 = ((decode_INSTRUCTION & 32'h00000064) == 32'h0); - assign _zz__zz_decode_BRANCH_CTRL_2_160 = 32'h00000070; - assign _zz__zz_decode_BRANCH_CTRL_2_165 = 32'h00000020; - assign _zz__zz_decode_BRANCH_CTRL_2_169 = 32'h00006014; - assign _zz__zz_decode_BRANCH_CTRL_2_171 = 32'h00005014; - assign _zz__zz_decode_BRANCH_CTRL_2_175 = 32'h00006014; - assign _zz__zz_decode_BRANCH_CTRL_2_178 = ((decode_INSTRUCTION & 32'h00000044) == 32'h0); - assign _zz__zz_decode_BRANCH_CTRL_2_179 = ((decode_INSTRUCTION & _zz__zz_decode_BRANCH_CTRL_2_180) == 32'h00000020); - assign _zz__zz_decode_BRANCH_CTRL_2_181 = {(_zz__zz_decode_BRANCH_CTRL_2_182 == _zz__zz_decode_BRANCH_CTRL_2_183),{_zz_decode_BRANCH_CTRL_6,{_zz__zz_decode_BRANCH_CTRL_2_184,_zz__zz_decode_BRANCH_CTRL_2_185}}}; - assign _zz__zz_decode_BRANCH_CTRL_2_189 = {(_zz__zz_decode_BRANCH_CTRL_2_190 == _zz__zz_decode_BRANCH_CTRL_2_191),{_zz__zz_decode_BRANCH_CTRL_2_192,_zz__zz_decode_BRANCH_CTRL_2_193}}; - assign _zz__zz_decode_BRANCH_CTRL_2_195 = (|{_zz_decode_BRANCH_CTRL_5,{_zz__zz_decode_BRANCH_CTRL_2_196,_zz__zz_decode_BRANCH_CTRL_2_197}}); - assign _zz__zz_decode_BRANCH_CTRL_2_198 = (|{_zz_decode_BRANCH_CTRL_4,_zz_decode_BRANCH_CTRL_3}); - assign _zz__zz_decode_BRANCH_CTRL_2_180 = 32'h00000038; - assign _zz__zz_decode_BRANCH_CTRL_2_182 = (decode_INSTRUCTION & 32'h00004050); - assign _zz__zz_decode_BRANCH_CTRL_2_183 = 32'h00004000; - assign _zz__zz_decode_BRANCH_CTRL_2_184 = ((decode_INSTRUCTION & 32'h00006024) == 32'h00002020); - assign _zz__zz_decode_BRANCH_CTRL_2_185 = {((decode_INSTRUCTION & 32'h00005024) == 32'h00001020),((decode_INSTRUCTION & 32'h90000034) == 32'h90000010)}; - assign _zz__zz_decode_BRANCH_CTRL_2_190 = (decode_INSTRUCTION & 32'h00000044); - assign _zz__zz_decode_BRANCH_CTRL_2_191 = 32'h00000040; - assign _zz__zz_decode_BRANCH_CTRL_2_192 = ((decode_INSTRUCTION & 32'h00002014) == 32'h00002010); - assign _zz__zz_decode_BRANCH_CTRL_2_193 = ((decode_INSTRUCTION & 32'h40004034) == 32'h40000030); - assign _zz__zz_decode_BRANCH_CTRL_2_196 = _zz_decode_BRANCH_CTRL_3; - assign _zz__zz_decode_BRANCH_CTRL_2_197 = ((decode_INSTRUCTION & 32'h00002014) == 32'h00000004); + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_4 = decode_INSTRUCTION[31]; + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_5 = decode_INSTRUCTION[19 : 12]; + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_6 = decode_INSTRUCTION[20]; + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_7 = decode_INSTRUCTION[31]; + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_8 = decode_INSTRUCTION[7]; + assign _zz__zz_decode_SHIFT_CTRL_2 = (decode_INSTRUCTION & 32'h0000001c); + assign _zz__zz_decode_SHIFT_CTRL_2_1 = 32'h00000004; + assign _zz__zz_decode_SHIFT_CTRL_2_2 = (decode_INSTRUCTION & 32'h00000058); + assign _zz__zz_decode_SHIFT_CTRL_2_3 = 32'h00000040; + assign _zz__zz_decode_SHIFT_CTRL_2_4 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_5) == 32'h00005010); + assign _zz__zz_decode_SHIFT_CTRL_2_6 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_7) == 32'h00005020); + assign _zz__zz_decode_SHIFT_CTRL_2_8 = {(_zz__zz_decode_SHIFT_CTRL_2_9 == _zz__zz_decode_SHIFT_CTRL_2_10),{_zz__zz_decode_SHIFT_CTRL_2_11,_zz__zz_decode_SHIFT_CTRL_2_12}}; + assign _zz__zz_decode_SHIFT_CTRL_2_13 = (|_zz_decode_SHIFT_CTRL_9); + assign _zz__zz_decode_SHIFT_CTRL_2_14 = (|_zz_decode_SHIFT_CTRL_9); + assign _zz__zz_decode_SHIFT_CTRL_2_15 = {(|_zz__zz_decode_SHIFT_CTRL_2_16),{_zz__zz_decode_SHIFT_CTRL_2_17,{_zz__zz_decode_SHIFT_CTRL_2_19,_zz__zz_decode_SHIFT_CTRL_2_25}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_5 = 32'h00007034; + assign _zz__zz_decode_SHIFT_CTRL_2_7 = 32'h02007064; + assign _zz__zz_decode_SHIFT_CTRL_2_9 = (decode_INSTRUCTION & 32'h40003054); + assign _zz__zz_decode_SHIFT_CTRL_2_10 = 32'h40001010; + assign _zz__zz_decode_SHIFT_CTRL_2_11 = ((decode_INSTRUCTION & 32'h00007034) == 32'h00001010); + assign _zz__zz_decode_SHIFT_CTRL_2_12 = ((decode_INSTRUCTION & 32'h02007054) == 32'h00001010); + assign _zz__zz_decode_SHIFT_CTRL_2_16 = ((decode_INSTRUCTION & 32'h02004064) == 32'h02004020); + assign _zz__zz_decode_SHIFT_CTRL_2_17 = (|((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_18) == 32'h02000030)); + assign _zz__zz_decode_SHIFT_CTRL_2_19 = (|{_zz__zz_decode_SHIFT_CTRL_2_20,{_zz__zz_decode_SHIFT_CTRL_2_21,_zz__zz_decode_SHIFT_CTRL_2_23}}); + assign _zz__zz_decode_SHIFT_CTRL_2_25 = {(|_zz__zz_decode_SHIFT_CTRL_2_26),{(|_zz__zz_decode_SHIFT_CTRL_2_27),{_zz__zz_decode_SHIFT_CTRL_2_29,{_zz__zz_decode_SHIFT_CTRL_2_32,_zz__zz_decode_SHIFT_CTRL_2_33}}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_18 = 32'h02004074; + assign _zz__zz_decode_SHIFT_CTRL_2_20 = ((decode_INSTRUCTION & 32'h00000064) == 32'h00000024); + assign _zz__zz_decode_SHIFT_CTRL_2_21 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_22) == 32'h00001010); + assign _zz__zz_decode_SHIFT_CTRL_2_23 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_24) == 32'h00001010); + assign _zz__zz_decode_SHIFT_CTRL_2_26 = ((decode_INSTRUCTION & 32'h00001000) == 32'h00001000); + assign _zz__zz_decode_SHIFT_CTRL_2_27 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_28) == 32'h00002000); + assign _zz__zz_decode_SHIFT_CTRL_2_29 = (|{_zz__zz_decode_SHIFT_CTRL_2_30,_zz__zz_decode_SHIFT_CTRL_2_31}); + assign _zz__zz_decode_SHIFT_CTRL_2_32 = (|_zz_decode_SHIFT_CTRL_8); + assign _zz__zz_decode_SHIFT_CTRL_2_33 = {(|_zz__zz_decode_SHIFT_CTRL_2_34),{_zz__zz_decode_SHIFT_CTRL_2_35,{_zz__zz_decode_SHIFT_CTRL_2_37,_zz__zz_decode_SHIFT_CTRL_2_40}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_22 = 32'h00003034; + assign _zz__zz_decode_SHIFT_CTRL_2_24 = 32'h02003054; + assign _zz__zz_decode_SHIFT_CTRL_2_28 = 32'h00003000; + assign _zz__zz_decode_SHIFT_CTRL_2_30 = ((decode_INSTRUCTION & 32'h00002010) == 32'h00002000); + assign _zz__zz_decode_SHIFT_CTRL_2_31 = ((decode_INSTRUCTION & 32'h00005000) == 32'h00001000); + assign _zz__zz_decode_SHIFT_CTRL_2_34 = _zz_decode_SHIFT_CTRL_8; + assign _zz__zz_decode_SHIFT_CTRL_2_35 = (|((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_36) == 32'h00000050)); + assign _zz__zz_decode_SHIFT_CTRL_2_37 = (|{_zz__zz_decode_SHIFT_CTRL_2_38,_zz__zz_decode_SHIFT_CTRL_2_39}); + assign _zz__zz_decode_SHIFT_CTRL_2_40 = {(|{_zz__zz_decode_SHIFT_CTRL_2_41,_zz__zz_decode_SHIFT_CTRL_2_43}),{(|_zz__zz_decode_SHIFT_CTRL_2_45),{_zz__zz_decode_SHIFT_CTRL_2_49,{_zz__zz_decode_SHIFT_CTRL_2_52,_zz__zz_decode_SHIFT_CTRL_2_62}}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_36 = 32'h00103050; + assign _zz__zz_decode_SHIFT_CTRL_2_38 = ((decode_INSTRUCTION & 32'h00001050) == 32'h00001050); + assign _zz__zz_decode_SHIFT_CTRL_2_39 = ((decode_INSTRUCTION & 32'h00002050) == 32'h00002050); + assign _zz__zz_decode_SHIFT_CTRL_2_41 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_42) == 32'h00000020); + assign _zz__zz_decode_SHIFT_CTRL_2_43 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_44) == 32'h00000020); + assign _zz__zz_decode_SHIFT_CTRL_2_45 = {(_zz__zz_decode_SHIFT_CTRL_2_46 == _zz__zz_decode_SHIFT_CTRL_2_47),{_zz_decode_SHIFT_CTRL_4,_zz__zz_decode_SHIFT_CTRL_2_48}}; + assign _zz__zz_decode_SHIFT_CTRL_2_49 = (|(_zz__zz_decode_SHIFT_CTRL_2_50 == _zz__zz_decode_SHIFT_CTRL_2_51)); + assign _zz__zz_decode_SHIFT_CTRL_2_52 = (|{_zz__zz_decode_SHIFT_CTRL_2_53,_zz__zz_decode_SHIFT_CTRL_2_55}); + assign _zz__zz_decode_SHIFT_CTRL_2_62 = {(|_zz__zz_decode_SHIFT_CTRL_2_63),{_zz__zz_decode_SHIFT_CTRL_2_66,{_zz__zz_decode_SHIFT_CTRL_2_79,_zz__zz_decode_SHIFT_CTRL_2_84}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_42 = 32'h00000034; + assign _zz__zz_decode_SHIFT_CTRL_2_44 = 32'h00000064; + assign _zz__zz_decode_SHIFT_CTRL_2_46 = (decode_INSTRUCTION & 32'h00000050); + assign _zz__zz_decode_SHIFT_CTRL_2_47 = 32'h00000040; + assign _zz__zz_decode_SHIFT_CTRL_2_48 = ((decode_INSTRUCTION & 32'h00003040) == 32'h00000040); + assign _zz__zz_decode_SHIFT_CTRL_2_50 = (decode_INSTRUCTION & 32'h00000020); + assign _zz__zz_decode_SHIFT_CTRL_2_51 = 32'h00000020; + assign _zz__zz_decode_SHIFT_CTRL_2_53 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_54) == 32'h00000040); + assign _zz__zz_decode_SHIFT_CTRL_2_55 = {_zz_decode_SHIFT_CTRL_5,{_zz__zz_decode_SHIFT_CTRL_2_56,{_zz__zz_decode_SHIFT_CTRL_2_58,_zz__zz_decode_SHIFT_CTRL_2_59}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_63 = {_zz_decode_SHIFT_CTRL_5,{_zz_decode_SHIFT_CTRL_7,_zz__zz_decode_SHIFT_CTRL_2_64}}; + assign _zz__zz_decode_SHIFT_CTRL_2_66 = (|{_zz_decode_SHIFT_CTRL_6,{_zz__zz_decode_SHIFT_CTRL_2_67,_zz__zz_decode_SHIFT_CTRL_2_70}}); + assign _zz__zz_decode_SHIFT_CTRL_2_79 = (|{_zz__zz_decode_SHIFT_CTRL_2_80,_zz__zz_decode_SHIFT_CTRL_2_81}); + assign _zz__zz_decode_SHIFT_CTRL_2_84 = {(|_zz__zz_decode_SHIFT_CTRL_2_85),{_zz__zz_decode_SHIFT_CTRL_2_88,{_zz__zz_decode_SHIFT_CTRL_2_95,_zz__zz_decode_SHIFT_CTRL_2_99}}}; + assign _zz__zz_decode_SHIFT_CTRL_2_54 = 32'h00000040; + assign _zz__zz_decode_SHIFT_CTRL_2_56 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_57) == 32'h00004020); + assign _zz__zz_decode_SHIFT_CTRL_2_58 = _zz_decode_SHIFT_CTRL_7; + assign _zz__zz_decode_SHIFT_CTRL_2_59 = (_zz__zz_decode_SHIFT_CTRL_2_60 == _zz__zz_decode_SHIFT_CTRL_2_61); + assign _zz__zz_decode_SHIFT_CTRL_2_64 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_65) == 32'h00000020); + assign _zz__zz_decode_SHIFT_CTRL_2_67 = (_zz__zz_decode_SHIFT_CTRL_2_68 == _zz__zz_decode_SHIFT_CTRL_2_69); + assign _zz__zz_decode_SHIFT_CTRL_2_70 = {_zz__zz_decode_SHIFT_CTRL_2_71,{_zz__zz_decode_SHIFT_CTRL_2_73,_zz__zz_decode_SHIFT_CTRL_2_76}}; + assign _zz__zz_decode_SHIFT_CTRL_2_80 = _zz_decode_SHIFT_CTRL_5; + assign _zz__zz_decode_SHIFT_CTRL_2_81 = (_zz__zz_decode_SHIFT_CTRL_2_82 == _zz__zz_decode_SHIFT_CTRL_2_83); + assign _zz__zz_decode_SHIFT_CTRL_2_85 = {_zz_decode_SHIFT_CTRL_5,_zz__zz_decode_SHIFT_CTRL_2_86}; + assign _zz__zz_decode_SHIFT_CTRL_2_88 = (|{_zz__zz_decode_SHIFT_CTRL_2_89,_zz__zz_decode_SHIFT_CTRL_2_92}); + assign _zz__zz_decode_SHIFT_CTRL_2_95 = (|_zz__zz_decode_SHIFT_CTRL_2_96); + assign _zz__zz_decode_SHIFT_CTRL_2_99 = {_zz__zz_decode_SHIFT_CTRL_2_100,{_zz__zz_decode_SHIFT_CTRL_2_106,_zz__zz_decode_SHIFT_CTRL_2_109}}; + assign _zz__zz_decode_SHIFT_CTRL_2_57 = 32'h00004020; + assign _zz__zz_decode_SHIFT_CTRL_2_60 = (decode_INSTRUCTION & 32'h02000020); + assign _zz__zz_decode_SHIFT_CTRL_2_61 = 32'h00000020; + assign _zz__zz_decode_SHIFT_CTRL_2_65 = 32'h02000060; + assign _zz__zz_decode_SHIFT_CTRL_2_68 = (decode_INSTRUCTION & 32'h00001010); + assign _zz__zz_decode_SHIFT_CTRL_2_69 = 32'h00001010; + assign _zz__zz_decode_SHIFT_CTRL_2_71 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_72) == 32'h00002010); + assign _zz__zz_decode_SHIFT_CTRL_2_73 = (_zz__zz_decode_SHIFT_CTRL_2_74 == _zz__zz_decode_SHIFT_CTRL_2_75); + assign _zz__zz_decode_SHIFT_CTRL_2_76 = {_zz__zz_decode_SHIFT_CTRL_2_77,_zz__zz_decode_SHIFT_CTRL_2_78}; + assign _zz__zz_decode_SHIFT_CTRL_2_82 = (decode_INSTRUCTION & 32'h00000070); + assign _zz__zz_decode_SHIFT_CTRL_2_83 = 32'h00000020; + assign _zz__zz_decode_SHIFT_CTRL_2_86 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_87) == 32'h0); + assign _zz__zz_decode_SHIFT_CTRL_2_89 = (_zz__zz_decode_SHIFT_CTRL_2_90 == _zz__zz_decode_SHIFT_CTRL_2_91); + assign _zz__zz_decode_SHIFT_CTRL_2_92 = (_zz__zz_decode_SHIFT_CTRL_2_93 == _zz__zz_decode_SHIFT_CTRL_2_94); + assign _zz__zz_decode_SHIFT_CTRL_2_96 = (_zz__zz_decode_SHIFT_CTRL_2_97 == _zz__zz_decode_SHIFT_CTRL_2_98); + assign _zz__zz_decode_SHIFT_CTRL_2_100 = (|{_zz__zz_decode_SHIFT_CTRL_2_101,_zz__zz_decode_SHIFT_CTRL_2_103}); + assign _zz__zz_decode_SHIFT_CTRL_2_106 = (|_zz__zz_decode_SHIFT_CTRL_2_107); + assign _zz__zz_decode_SHIFT_CTRL_2_109 = {_zz__zz_decode_SHIFT_CTRL_2_110,{_zz__zz_decode_SHIFT_CTRL_2_114,_zz__zz_decode_SHIFT_CTRL_2_117}}; + assign _zz__zz_decode_SHIFT_CTRL_2_72 = 32'h00002010; + assign _zz__zz_decode_SHIFT_CTRL_2_74 = (decode_INSTRUCTION & 32'h00000050); + assign _zz__zz_decode_SHIFT_CTRL_2_75 = 32'h00000010; + assign _zz__zz_decode_SHIFT_CTRL_2_77 = ((decode_INSTRUCTION & 32'h0000000c) == 32'h00000004); + assign _zz__zz_decode_SHIFT_CTRL_2_78 = ((decode_INSTRUCTION & 32'h00000028) == 32'h0); + assign _zz__zz_decode_SHIFT_CTRL_2_87 = 32'h00000020; + assign _zz__zz_decode_SHIFT_CTRL_2_90 = (decode_INSTRUCTION & 32'h00006014); + assign _zz__zz_decode_SHIFT_CTRL_2_91 = 32'h00006010; + assign _zz__zz_decode_SHIFT_CTRL_2_93 = (decode_INSTRUCTION & 32'h00005014); + assign _zz__zz_decode_SHIFT_CTRL_2_94 = 32'h00004010; + assign _zz__zz_decode_SHIFT_CTRL_2_97 = (decode_INSTRUCTION & 32'h00006014); + assign _zz__zz_decode_SHIFT_CTRL_2_98 = 32'h00002010; + assign _zz__zz_decode_SHIFT_CTRL_2_101 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_102) == 32'h0); + assign _zz__zz_decode_SHIFT_CTRL_2_103 = {_zz_decode_SHIFT_CTRL_4,{_zz__zz_decode_SHIFT_CTRL_2_104,_zz__zz_decode_SHIFT_CTRL_2_105}}; + assign _zz__zz_decode_SHIFT_CTRL_2_107 = ((decode_INSTRUCTION & _zz__zz_decode_SHIFT_CTRL_2_108) == 32'h0); + assign _zz__zz_decode_SHIFT_CTRL_2_110 = (|{_zz__zz_decode_SHIFT_CTRL_2_111,{_zz__zz_decode_SHIFT_CTRL_2_112,_zz__zz_decode_SHIFT_CTRL_2_113}}); + assign _zz__zz_decode_SHIFT_CTRL_2_114 = (|{_zz__zz_decode_SHIFT_CTRL_2_115,_zz__zz_decode_SHIFT_CTRL_2_116}); + assign _zz__zz_decode_SHIFT_CTRL_2_117 = (|{_zz__zz_decode_SHIFT_CTRL_2_118,_zz__zz_decode_SHIFT_CTRL_2_119}); + assign _zz__zz_decode_SHIFT_CTRL_2_102 = 32'h00000044; + assign _zz__zz_decode_SHIFT_CTRL_2_104 = ((decode_INSTRUCTION & 32'h00006004) == 32'h00002000); + assign _zz__zz_decode_SHIFT_CTRL_2_105 = ((decode_INSTRUCTION & 32'h00005004) == 32'h00001000); + assign _zz__zz_decode_SHIFT_CTRL_2_108 = 32'h00000058; + assign _zz__zz_decode_SHIFT_CTRL_2_111 = ((decode_INSTRUCTION & 32'h00000044) == 32'h00000040); + assign _zz__zz_decode_SHIFT_CTRL_2_112 = ((decode_INSTRUCTION & 32'h00002014) == 32'h00002010); + assign _zz__zz_decode_SHIFT_CTRL_2_113 = ((decode_INSTRUCTION & 32'h40004034) == 32'h40000030); + assign _zz__zz_decode_SHIFT_CTRL_2_115 = ((decode_INSTRUCTION & 32'h00000014) == 32'h00000004); + assign _zz__zz_decode_SHIFT_CTRL_2_116 = _zz_decode_SHIFT_CTRL_3; + assign _zz__zz_decode_SHIFT_CTRL_2_118 = ((decode_INSTRUCTION & 32'h00000044) == 32'h00000004); + assign _zz__zz_decode_SHIFT_CTRL_2_119 = _zz_decode_SHIFT_CTRL_3; + assign _zz_execute_BranchPlugin_branch_src2_6 = execute_INSTRUCTION[31]; + assign _zz_execute_BranchPlugin_branch_src2_7 = execute_INSTRUCTION[31]; + assign _zz_execute_BranchPlugin_branch_src2_8 = execute_INSTRUCTION[7]; always @(posedge clk) begin if(_zz_decode_RegFilePlugin_rs1Data) begin _zz_RegFilePlugin_regFile_port0 <= RegFilePlugin_regFile[decode_RegFilePlugin_regFileReadAddress1]; @@ -1934,145 +1547,51 @@ module VexRiscv ( .clk (clk ), //i .reset (reset ) //i ); - DataCache dataCache_1 ( - .io_cpu_execute_isValid (dataCache_1_io_cpu_execute_isValid ), //i - .io_cpu_execute_address (dataCache_1_io_cpu_execute_address[31:0] ), //i - .io_cpu_execute_haltIt (dataCache_1_io_cpu_execute_haltIt ), //o - .io_cpu_execute_args_wr (execute_MEMORY_WR ), //i - .io_cpu_execute_args_size (execute_DBusCachedPlugin_size[1:0] ), //i - .io_cpu_execute_args_totalyConsistent (execute_MEMORY_FORCE_CONSTISTENCY ), //i - .io_cpu_execute_refilling (dataCache_1_io_cpu_execute_refilling ), //o - .io_cpu_memory_isValid (dataCache_1_io_cpu_memory_isValid ), //i - .io_cpu_memory_isStuck (memory_arbitration_isStuck ), //i - .io_cpu_memory_isWrite (dataCache_1_io_cpu_memory_isWrite ), //o - .io_cpu_memory_address (dataCache_1_io_cpu_memory_address[31:0] ), //i - .io_cpu_memory_mmuRsp_physicalAddress (DBusCachedPlugin_mmuBus_rsp_physicalAddress[31:0]), //i - .io_cpu_memory_mmuRsp_isIoAccess (dataCache_1_io_cpu_memory_mmuRsp_isIoAccess ), //i - .io_cpu_memory_mmuRsp_isPaging (DBusCachedPlugin_mmuBus_rsp_isPaging ), //i - .io_cpu_memory_mmuRsp_allowRead (DBusCachedPlugin_mmuBus_rsp_allowRead ), //i - .io_cpu_memory_mmuRsp_allowWrite (DBusCachedPlugin_mmuBus_rsp_allowWrite ), //i - .io_cpu_memory_mmuRsp_allowExecute (DBusCachedPlugin_mmuBus_rsp_allowExecute ), //i - .io_cpu_memory_mmuRsp_exception (DBusCachedPlugin_mmuBus_rsp_exception ), //i - .io_cpu_memory_mmuRsp_refilling (DBusCachedPlugin_mmuBus_rsp_refilling ), //i - .io_cpu_memory_mmuRsp_bypassTranslation (DBusCachedPlugin_mmuBus_rsp_bypassTranslation ), //i - .io_cpu_writeBack_isValid (dataCache_1_io_cpu_writeBack_isValid ), //i - .io_cpu_writeBack_isStuck (writeBack_arbitration_isStuck ), //i - .io_cpu_writeBack_isFiring (writeBack_arbitration_isFiring ), //i - .io_cpu_writeBack_isUser (dataCache_1_io_cpu_writeBack_isUser ), //i - .io_cpu_writeBack_haltIt (dataCache_1_io_cpu_writeBack_haltIt ), //o - .io_cpu_writeBack_isWrite (dataCache_1_io_cpu_writeBack_isWrite ), //o - .io_cpu_writeBack_storeData (dataCache_1_io_cpu_writeBack_storeData[31:0] ), //i - .io_cpu_writeBack_data (dataCache_1_io_cpu_writeBack_data[31:0] ), //o - .io_cpu_writeBack_address (dataCache_1_io_cpu_writeBack_address[31:0] ), //i - .io_cpu_writeBack_mmuException (dataCache_1_io_cpu_writeBack_mmuException ), //o - .io_cpu_writeBack_unalignedAccess (dataCache_1_io_cpu_writeBack_unalignedAccess ), //o - .io_cpu_writeBack_accessError (dataCache_1_io_cpu_writeBack_accessError ), //o - .io_cpu_writeBack_keepMemRspData (dataCache_1_io_cpu_writeBack_keepMemRspData ), //o - .io_cpu_writeBack_fence_SW (dataCache_1_io_cpu_writeBack_fence_SW ), //i - .io_cpu_writeBack_fence_SR (dataCache_1_io_cpu_writeBack_fence_SR ), //i - .io_cpu_writeBack_fence_SO (dataCache_1_io_cpu_writeBack_fence_SO ), //i - .io_cpu_writeBack_fence_SI (dataCache_1_io_cpu_writeBack_fence_SI ), //i - .io_cpu_writeBack_fence_PW (dataCache_1_io_cpu_writeBack_fence_PW ), //i - .io_cpu_writeBack_fence_PR (dataCache_1_io_cpu_writeBack_fence_PR ), //i - .io_cpu_writeBack_fence_PO (dataCache_1_io_cpu_writeBack_fence_PO ), //i - .io_cpu_writeBack_fence_PI (dataCache_1_io_cpu_writeBack_fence_PI ), //i - .io_cpu_writeBack_fence_FM (dataCache_1_io_cpu_writeBack_fence_FM[3:0] ), //i - .io_cpu_writeBack_exclusiveOk (dataCache_1_io_cpu_writeBack_exclusiveOk ), //o - .io_cpu_redo (dataCache_1_io_cpu_redo ), //o - .io_cpu_flush_valid (dataCache_1_io_cpu_flush_valid ), //i - .io_cpu_flush_ready (dataCache_1_io_cpu_flush_ready ), //o - .io_cpu_flush_payload_singleLine (dataCache_1_io_cpu_flush_payload_singleLine ), //i - .io_mem_cmd_valid (dataCache_1_io_mem_cmd_valid ), //o - .io_mem_cmd_ready (dBus_cmd_ready ), //i - .io_mem_cmd_payload_wr (dataCache_1_io_mem_cmd_payload_wr ), //o - .io_mem_cmd_payload_uncached (dataCache_1_io_mem_cmd_payload_uncached ), //o - .io_mem_cmd_payload_address (dataCache_1_io_mem_cmd_payload_address[31:0] ), //o - .io_mem_cmd_payload_data (dataCache_1_io_mem_cmd_payload_data[31:0] ), //o - .io_mem_cmd_payload_mask (dataCache_1_io_mem_cmd_payload_mask[3:0] ), //o - .io_mem_cmd_payload_size (dataCache_1_io_mem_cmd_payload_size[1:0] ), //o - .io_mem_cmd_payload_last (dataCache_1_io_mem_cmd_payload_last ), //o - .io_mem_rsp_valid (dBus_rsp_valid ), //i - .io_mem_rsp_payload_last (dBus_rsp_payload_last ), //i - .io_mem_rsp_payload_data (dBus_rsp_payload_data[31:0] ), //i - .io_mem_rsp_payload_error (dBus_rsp_payload_error ), //i - .clk (clk ), //i - .reset (reset ) //i + JtagBridge jtagBridge_1 ( + .io_jtag_tms (jtag_tms ), //i + .io_jtag_tdi (jtag_tdi ), //i + .io_jtag_tdo (jtagBridge_1_io_jtag_tdo ), //o + .io_jtag_tck (jtag_tck ), //i + .io_remote_cmd_valid (jtagBridge_1_io_remote_cmd_valid ), //o + .io_remote_cmd_ready (systemDebugger_1_io_remote_cmd_ready ), //i + .io_remote_cmd_payload_last (jtagBridge_1_io_remote_cmd_payload_last ), //o + .io_remote_cmd_payload_fragment (jtagBridge_1_io_remote_cmd_payload_fragment ), //o + .io_remote_rsp_valid (systemDebugger_1_io_remote_rsp_valid ), //i + .io_remote_rsp_ready (jtagBridge_1_io_remote_rsp_ready ), //o + .io_remote_rsp_payload_error (systemDebugger_1_io_remote_rsp_payload_error ), //i + .io_remote_rsp_payload_data (systemDebugger_1_io_remote_rsp_payload_data[31:0]), //i + .clk (clk ), //i + .reset (reset ) //i ); - FpuCore FpuPlugin_fpu ( - .io_port_0_cmd_valid (FpuPlugin_port_cmd_valid ), //i - .io_port_0_cmd_ready (FpuPlugin_fpu_io_port_0_cmd_ready ), //o - .io_port_0_cmd_payload_opcode (FpuPlugin_port_cmd_payload_opcode[3:0] ), //i - .io_port_0_cmd_payload_arg (FpuPlugin_port_cmd_payload_arg[1:0] ), //i - .io_port_0_cmd_payload_rs1 (FpuPlugin_port_cmd_payload_rs1[4:0] ), //i - .io_port_0_cmd_payload_rs2 (FpuPlugin_port_cmd_payload_rs2[4:0] ), //i - .io_port_0_cmd_payload_rs3 (FpuPlugin_port_cmd_payload_rs3[4:0] ), //i - .io_port_0_cmd_payload_rd (FpuPlugin_port_cmd_payload_rd[4:0] ), //i - .io_port_0_cmd_payload_format (FpuPlugin_port_cmd_payload_format ), //i - .io_port_0_cmd_payload_roundMode (FpuPlugin_port_cmd_payload_roundMode[2:0] ), //i - .io_port_0_commit_valid (FpuPlugin_port_commit_valid ), //i - .io_port_0_commit_ready (FpuPlugin_fpu_io_port_0_commit_ready ), //o - .io_port_0_commit_payload_opcode (FpuPlugin_port_commit_payload_opcode[3:0] ), //i - .io_port_0_commit_payload_rd (FpuPlugin_port_commit_payload_rd[4:0] ), //i - .io_port_0_commit_payload_write (FpuPlugin_port_commit_payload_write ), //i - .io_port_0_commit_payload_value (FpuPlugin_port_commit_payload_value[31:0] ), //i - .io_port_0_rsp_valid (FpuPlugin_fpu_io_port_0_rsp_valid ), //o - .io_port_0_rsp_ready (FpuPlugin_port_rsp_ready ), //i - .io_port_0_rsp_payload_value (FpuPlugin_fpu_io_port_0_rsp_payload_value[31:0] ), //o - .io_port_0_rsp_payload_NV (FpuPlugin_fpu_io_port_0_rsp_payload_NV ), //o - .io_port_0_rsp_payload_NX (FpuPlugin_fpu_io_port_0_rsp_payload_NX ), //o - .io_port_0_completion_valid (FpuPlugin_fpu_io_port_0_completion_valid ), //o - .io_port_0_completion_payload_flags_NX (FpuPlugin_fpu_io_port_0_completion_payload_flags_NX), //o - .io_port_0_completion_payload_flags_UF (FpuPlugin_fpu_io_port_0_completion_payload_flags_UF), //o - .io_port_0_completion_payload_flags_OF (FpuPlugin_fpu_io_port_0_completion_payload_flags_OF), //o - .io_port_0_completion_payload_flags_DZ (FpuPlugin_fpu_io_port_0_completion_payload_flags_DZ), //o - .io_port_0_completion_payload_flags_NV (FpuPlugin_fpu_io_port_0_completion_payload_flags_NV), //o - .io_port_0_completion_payload_written (FpuPlugin_fpu_io_port_0_completion_payload_written ), //o - .clk (clk ), //i - .reset (reset ) //i + SystemDebugger systemDebugger_1 ( + .io_remote_cmd_valid (jtagBridge_1_io_remote_cmd_valid ), //i + .io_remote_cmd_ready (systemDebugger_1_io_remote_cmd_ready ), //o + .io_remote_cmd_payload_last (jtagBridge_1_io_remote_cmd_payload_last ), //i + .io_remote_cmd_payload_fragment (jtagBridge_1_io_remote_cmd_payload_fragment ), //i + .io_remote_rsp_valid (systemDebugger_1_io_remote_rsp_valid ), //o + .io_remote_rsp_ready (jtagBridge_1_io_remote_rsp_ready ), //i + .io_remote_rsp_payload_error (systemDebugger_1_io_remote_rsp_payload_error ), //o + .io_remote_rsp_payload_data (systemDebugger_1_io_remote_rsp_payload_data[31:0]), //o + .io_mem_cmd_valid (systemDebugger_1_io_mem_cmd_valid ), //o + .io_mem_cmd_ready (debug_bus_cmd_ready ), //i + .io_mem_cmd_payload_address (systemDebugger_1_io_mem_cmd_payload_address[31:0]), //o + .io_mem_cmd_payload_data (systemDebugger_1_io_mem_cmd_payload_data[31:0] ), //o + .io_mem_cmd_payload_wr (systemDebugger_1_io_mem_cmd_payload_wr ), //o + .io_mem_cmd_payload_size (systemDebugger_1_io_mem_cmd_payload_size[1:0] ), //o + .io_mem_rsp_valid (debug_bus_cmd_fire_regNext ), //i + .io_mem_rsp_payload (debug_bus_rsp_data[31:0] ), //i + .clk (clk ), //i + .reset (reset ) //i ); always @(*) begin case(_zz_IBusSimplePlugin_jump_pcLoad_payload_5) - 2'b00 : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = DBusCachedPlugin_redoBranch_payload; - 2'b01 : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = CsrPlugin_jumpInterface_payload; - default : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = BranchPlugin_jumpInterface_payload; - endcase - end - - always @(*) begin - case(_zz_writeBack_DBusCachedPlugin_rspShifted_1) - 2'b00 : _zz_writeBack_DBusCachedPlugin_rspShifted = writeBack_DBusCachedPlugin_rspSplits_0; - 2'b01 : _zz_writeBack_DBusCachedPlugin_rspShifted = writeBack_DBusCachedPlugin_rspSplits_1; - 2'b10 : _zz_writeBack_DBusCachedPlugin_rspShifted = writeBack_DBusCachedPlugin_rspSplits_2; - default : _zz_writeBack_DBusCachedPlugin_rspShifted = writeBack_DBusCachedPlugin_rspSplits_3; - endcase - end - - always @(*) begin - case(_zz_writeBack_DBusCachedPlugin_rspShifted_3) - 1'b0 : _zz_writeBack_DBusCachedPlugin_rspShifted_2 = writeBack_DBusCachedPlugin_rspSplits_1; - default : _zz_writeBack_DBusCachedPlugin_rspShifted_2 = writeBack_DBusCachedPlugin_rspSplits_3; + 2'b00 : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = CsrPlugin_jumpInterface_payload; + 2'b01 : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = BranchPlugin_jumpInterface_payload; + default : _zz_IBusSimplePlugin_jump_pcLoad_payload_4 = IBusSimplePlugin_predictionJumpInterface_payload; endcase end `ifndef SYNTHESIS - always @(*) begin - case(decode_BRANCH_CTRL) - BranchCtrlEnum_INC : decode_BRANCH_CTRL_string = "INC "; - BranchCtrlEnum_B : decode_BRANCH_CTRL_string = "B "; - BranchCtrlEnum_JAL : decode_BRANCH_CTRL_string = "JAL "; - BranchCtrlEnum_JALR : decode_BRANCH_CTRL_string = "JALR"; - default : decode_BRANCH_CTRL_string = "????"; - endcase - end - always @(*) begin - case(_zz_decode_BRANCH_CTRL) - BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_string = "INC "; - BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_string = "B "; - BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_string = "JAL "; - BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_string = "JALR"; - default : _zz_decode_BRANCH_CTRL_string = "????"; - endcase - end always @(*) begin case(_zz_decode_to_execute_BRANCH_CTRL) BranchCtrlEnum_INC : _zz_decode_to_execute_BRANCH_CTRL_string = "INC "; @@ -2127,216 +1646,6 @@ module VexRiscv ( default : _zz_decode_to_execute_SHIFT_CTRL_1_string = "?????????"; endcase end - always @(*) begin - case(memory_FPU_OPCODE) - FpuOpcode_LOAD : memory_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : memory_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : memory_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : memory_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : memory_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : memory_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : memory_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : memory_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : memory_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : memory_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : memory_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : memory_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : memory_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : memory_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : memory_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : memory_FPU_OPCODE_string = "FCVT_X_X"; - default : memory_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_memory_FPU_OPCODE) - FpuOpcode_LOAD : _zz_memory_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_memory_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_memory_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_memory_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_memory_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_memory_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_memory_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_memory_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_memory_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_memory_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_memory_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_memory_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_memory_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_memory_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_memory_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_memory_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_memory_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_memory_to_writeBack_FPU_OPCODE) - FpuOpcode_LOAD : _zz_memory_to_writeBack_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_memory_to_writeBack_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_memory_to_writeBack_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_memory_to_writeBack_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_memory_to_writeBack_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_memory_to_writeBack_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_memory_to_writeBack_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_memory_to_writeBack_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_memory_to_writeBack_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_memory_to_writeBack_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_memory_to_writeBack_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_memory_to_writeBack_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_memory_to_writeBack_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_memory_to_writeBack_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_memory_to_writeBack_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_memory_to_writeBack_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_memory_to_writeBack_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_memory_to_writeBack_FPU_OPCODE_1) - FpuOpcode_LOAD : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "LOAD "; - FpuOpcode_STORE : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "STORE "; - FpuOpcode_MUL : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "MUL "; - FpuOpcode_ADD : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "ADD "; - FpuOpcode_FMA : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "FMA "; - FpuOpcode_I2F : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "I2F "; - FpuOpcode_F2I : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "F2I "; - FpuOpcode_CMP : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "CMP "; - FpuOpcode_DIV : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "DIV "; - FpuOpcode_SQRT : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "FCVT_X_X"; - default : _zz_memory_to_writeBack_FPU_OPCODE_1_string = "????????"; - endcase - end - always @(*) begin - case(execute_FPU_OPCODE) - FpuOpcode_LOAD : execute_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : execute_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : execute_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : execute_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : execute_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : execute_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : execute_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : execute_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : execute_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : execute_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : execute_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : execute_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : execute_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : execute_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : execute_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : execute_FPU_OPCODE_string = "FCVT_X_X"; - default : execute_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_execute_FPU_OPCODE) - FpuOpcode_LOAD : _zz_execute_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_execute_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_execute_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_execute_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_execute_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_execute_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_execute_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_execute_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_execute_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_execute_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_execute_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_execute_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_execute_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_execute_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_execute_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_execute_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_execute_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_execute_to_memory_FPU_OPCODE) - FpuOpcode_LOAD : _zz_execute_to_memory_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_execute_to_memory_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_execute_to_memory_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_execute_to_memory_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_execute_to_memory_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_execute_to_memory_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_execute_to_memory_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_execute_to_memory_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_execute_to_memory_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_execute_to_memory_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_execute_to_memory_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_execute_to_memory_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_execute_to_memory_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_execute_to_memory_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_execute_to_memory_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_execute_to_memory_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_execute_to_memory_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_execute_to_memory_FPU_OPCODE_1) - FpuOpcode_LOAD : _zz_execute_to_memory_FPU_OPCODE_1_string = "LOAD "; - FpuOpcode_STORE : _zz_execute_to_memory_FPU_OPCODE_1_string = "STORE "; - FpuOpcode_MUL : _zz_execute_to_memory_FPU_OPCODE_1_string = "MUL "; - FpuOpcode_ADD : _zz_execute_to_memory_FPU_OPCODE_1_string = "ADD "; - FpuOpcode_FMA : _zz_execute_to_memory_FPU_OPCODE_1_string = "FMA "; - FpuOpcode_I2F : _zz_execute_to_memory_FPU_OPCODE_1_string = "I2F "; - FpuOpcode_F2I : _zz_execute_to_memory_FPU_OPCODE_1_string = "F2I "; - FpuOpcode_CMP : _zz_execute_to_memory_FPU_OPCODE_1_string = "CMP "; - FpuOpcode_DIV : _zz_execute_to_memory_FPU_OPCODE_1_string = "DIV "; - FpuOpcode_SQRT : _zz_execute_to_memory_FPU_OPCODE_1_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_execute_to_memory_FPU_OPCODE_1_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_execute_to_memory_FPU_OPCODE_1_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_execute_to_memory_FPU_OPCODE_1_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_execute_to_memory_FPU_OPCODE_1_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_execute_to_memory_FPU_OPCODE_1_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_execute_to_memory_FPU_OPCODE_1_string = "FCVT_X_X"; - default : _zz_execute_to_memory_FPU_OPCODE_1_string = "????????"; - endcase - end - always @(*) begin - case(_zz_decode_to_execute_FPU_OPCODE) - FpuOpcode_LOAD : _zz_decode_to_execute_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_decode_to_execute_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_decode_to_execute_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_decode_to_execute_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_decode_to_execute_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_decode_to_execute_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_decode_to_execute_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_decode_to_execute_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_decode_to_execute_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_decode_to_execute_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_decode_to_execute_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_decode_to_execute_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_decode_to_execute_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_decode_to_execute_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_decode_to_execute_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_decode_to_execute_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_decode_to_execute_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_decode_to_execute_FPU_OPCODE_1) - FpuOpcode_LOAD : _zz_decode_to_execute_FPU_OPCODE_1_string = "LOAD "; - FpuOpcode_STORE : _zz_decode_to_execute_FPU_OPCODE_1_string = "STORE "; - FpuOpcode_MUL : _zz_decode_to_execute_FPU_OPCODE_1_string = "MUL "; - FpuOpcode_ADD : _zz_decode_to_execute_FPU_OPCODE_1_string = "ADD "; - FpuOpcode_FMA : _zz_decode_to_execute_FPU_OPCODE_1_string = "FMA "; - FpuOpcode_I2F : _zz_decode_to_execute_FPU_OPCODE_1_string = "I2F "; - FpuOpcode_F2I : _zz_decode_to_execute_FPU_OPCODE_1_string = "F2I "; - FpuOpcode_CMP : _zz_decode_to_execute_FPU_OPCODE_1_string = "CMP "; - FpuOpcode_DIV : _zz_decode_to_execute_FPU_OPCODE_1_string = "DIV "; - FpuOpcode_SQRT : _zz_decode_to_execute_FPU_OPCODE_1_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_decode_to_execute_FPU_OPCODE_1_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_decode_to_execute_FPU_OPCODE_1_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_decode_to_execute_FPU_OPCODE_1_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_decode_to_execute_FPU_OPCODE_1_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_decode_to_execute_FPU_OPCODE_1_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_decode_to_execute_FPU_OPCODE_1_string = "FCVT_X_X"; - default : _zz_decode_to_execute_FPU_OPCODE_1_string = "????????"; - endcase - end always @(*) begin case(decode_ALU_BITWISE_CTRL) AluBitwiseCtrlEnum_XOR_1 : decode_ALU_BITWISE_CTRL_string = "XOR_1"; @@ -2501,90 +1810,6 @@ module VexRiscv ( default : _zz_execute_SHIFT_CTRL_string = "?????????"; endcase end - always @(*) begin - case(decode_FPU_OPCODE) - FpuOpcode_LOAD : decode_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : decode_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : decode_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : decode_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : decode_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : decode_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : decode_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : decode_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : decode_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : decode_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : decode_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : decode_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : decode_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : decode_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : decode_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : decode_FPU_OPCODE_string = "FCVT_X_X"; - default : decode_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_decode_FPU_OPCODE) - FpuOpcode_LOAD : _zz_decode_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_decode_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_decode_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_decode_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_decode_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_decode_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_decode_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_decode_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_decode_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_decode_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_decode_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_decode_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_decode_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_decode_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_decode_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_decode_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_decode_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(writeBack_FPU_OPCODE) - FpuOpcode_LOAD : writeBack_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : writeBack_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : writeBack_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : writeBack_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : writeBack_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : writeBack_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : writeBack_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : writeBack_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : writeBack_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : writeBack_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : writeBack_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : writeBack_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : writeBack_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : writeBack_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : writeBack_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : writeBack_FPU_OPCODE_string = "FCVT_X_X"; - default : writeBack_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(_zz_writeBack_FPU_OPCODE) - FpuOpcode_LOAD : _zz_writeBack_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : _zz_writeBack_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : _zz_writeBack_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : _zz_writeBack_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : _zz_writeBack_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : _zz_writeBack_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : _zz_writeBack_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : _zz_writeBack_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : _zz_writeBack_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : _zz_writeBack_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_writeBack_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_writeBack_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_writeBack_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_writeBack_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_writeBack_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_writeBack_FPU_OPCODE_string = "FCVT_X_X"; - default : _zz_writeBack_FPU_OPCODE_string = "????????"; - endcase - end always @(*) begin case(decode_SRC2_CTRL) Src2CtrlEnum_RS : decode_SRC2_CTRL_string = "RS "; @@ -2654,12 +1879,12 @@ module VexRiscv ( endcase end always @(*) begin - case(_zz_decode_BRANCH_CTRL_1) - BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_1_string = "INC "; - BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_1_string = "B "; - BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_1_string = "JAL "; - BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_1_string = "JALR"; - default : _zz_decode_BRANCH_CTRL_1_string = "????"; + case(_zz_decode_BRANCH_CTRL) + BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_string = "INC "; + BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_string = "B "; + BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_string = "JAL "; + BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_string = "JALR"; + default : _zz_decode_BRANCH_CTRL_string = "????"; endcase end always @(*) begin @@ -2671,27 +1896,6 @@ module VexRiscv ( default : _zz_decode_SHIFT_CTRL_1_string = "?????????"; endcase end - always @(*) begin - case(_zz_decode_FPU_OPCODE_1) - FpuOpcode_LOAD : _zz_decode_FPU_OPCODE_1_string = "LOAD "; - FpuOpcode_STORE : _zz_decode_FPU_OPCODE_1_string = "STORE "; - FpuOpcode_MUL : _zz_decode_FPU_OPCODE_1_string = "MUL "; - FpuOpcode_ADD : _zz_decode_FPU_OPCODE_1_string = "ADD "; - FpuOpcode_FMA : _zz_decode_FPU_OPCODE_1_string = "FMA "; - FpuOpcode_I2F : _zz_decode_FPU_OPCODE_1_string = "I2F "; - FpuOpcode_F2I : _zz_decode_FPU_OPCODE_1_string = "F2I "; - FpuOpcode_CMP : _zz_decode_FPU_OPCODE_1_string = "CMP "; - FpuOpcode_DIV : _zz_decode_FPU_OPCODE_1_string = "DIV "; - FpuOpcode_SQRT : _zz_decode_FPU_OPCODE_1_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_decode_FPU_OPCODE_1_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_decode_FPU_OPCODE_1_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_decode_FPU_OPCODE_1_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_decode_FPU_OPCODE_1_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_decode_FPU_OPCODE_1_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_decode_FPU_OPCODE_1_string = "FCVT_X_X"; - default : _zz_decode_FPU_OPCODE_1_string = "????????"; - endcase - end always @(*) begin case(_zz_decode_ALU_BITWISE_CTRL_1) AluBitwiseCtrlEnum_XOR_1 : _zz_decode_ALU_BITWISE_CTRL_1_string = "XOR_1"; @@ -2783,62 +1987,21 @@ module VexRiscv ( endcase end always @(*) begin - case(FpuPlugin_port_cmd_payload_opcode) - FpuOpcode_LOAD : FpuPlugin_port_cmd_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : FpuPlugin_port_cmd_payload_opcode_string = "STORE "; - FpuOpcode_MUL : FpuPlugin_port_cmd_payload_opcode_string = "MUL "; - FpuOpcode_ADD : FpuPlugin_port_cmd_payload_opcode_string = "ADD "; - FpuOpcode_FMA : FpuPlugin_port_cmd_payload_opcode_string = "FMA "; - FpuOpcode_I2F : FpuPlugin_port_cmd_payload_opcode_string = "I2F "; - FpuOpcode_F2I : FpuPlugin_port_cmd_payload_opcode_string = "F2I "; - FpuOpcode_CMP : FpuPlugin_port_cmd_payload_opcode_string = "CMP "; - FpuOpcode_DIV : FpuPlugin_port_cmd_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : FpuPlugin_port_cmd_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : FpuPlugin_port_cmd_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : FpuPlugin_port_cmd_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : FpuPlugin_port_cmd_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : FpuPlugin_port_cmd_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : FpuPlugin_port_cmd_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : FpuPlugin_port_cmd_payload_opcode_string = "FCVT_X_X"; - default : FpuPlugin_port_cmd_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(FpuPlugin_port_cmd_payload_format) - FpuFormat_FLOAT : FpuPlugin_port_cmd_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : FpuPlugin_port_cmd_payload_format_string = "DOUBLE"; - default : FpuPlugin_port_cmd_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(FpuPlugin_port_cmd_payload_roundMode) - FpuRoundMode_RNE : FpuPlugin_port_cmd_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : FpuPlugin_port_cmd_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : FpuPlugin_port_cmd_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : FpuPlugin_port_cmd_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : FpuPlugin_port_cmd_payload_roundMode_string = "RMM"; - default : FpuPlugin_port_cmd_payload_roundMode_string = "???"; + case(decode_BRANCH_CTRL) + BranchCtrlEnum_INC : decode_BRANCH_CTRL_string = "INC "; + BranchCtrlEnum_B : decode_BRANCH_CTRL_string = "B "; + BranchCtrlEnum_JAL : decode_BRANCH_CTRL_string = "JAL "; + BranchCtrlEnum_JALR : decode_BRANCH_CTRL_string = "JALR"; + default : decode_BRANCH_CTRL_string = "????"; endcase end always @(*) begin - case(FpuPlugin_port_commit_payload_opcode) - FpuOpcode_LOAD : FpuPlugin_port_commit_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : FpuPlugin_port_commit_payload_opcode_string = "STORE "; - FpuOpcode_MUL : FpuPlugin_port_commit_payload_opcode_string = "MUL "; - FpuOpcode_ADD : FpuPlugin_port_commit_payload_opcode_string = "ADD "; - FpuOpcode_FMA : FpuPlugin_port_commit_payload_opcode_string = "FMA "; - FpuOpcode_I2F : FpuPlugin_port_commit_payload_opcode_string = "I2F "; - FpuOpcode_F2I : FpuPlugin_port_commit_payload_opcode_string = "F2I "; - FpuOpcode_CMP : FpuPlugin_port_commit_payload_opcode_string = "CMP "; - FpuOpcode_DIV : FpuPlugin_port_commit_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : FpuPlugin_port_commit_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : FpuPlugin_port_commit_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : FpuPlugin_port_commit_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : FpuPlugin_port_commit_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : FpuPlugin_port_commit_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : FpuPlugin_port_commit_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : FpuPlugin_port_commit_payload_opcode_string = "FCVT_X_X"; - default : FpuPlugin_port_commit_payload_opcode_string = "????????"; + case(_zz_decode_BRANCH_CTRL_1) + BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_1_string = "INC "; + BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_1_string = "B "; + BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_1_string = "JAL "; + BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_1_string = "JALR"; + default : _zz_decode_BRANCH_CTRL_1_string = "????"; endcase end always @(*) begin @@ -2884,146 +2047,21 @@ module VexRiscv ( endcase end always @(*) begin - case(_zz_decode_FPU_OPCODE_2) - FpuOpcode_LOAD : _zz_decode_FPU_OPCODE_2_string = "LOAD "; - FpuOpcode_STORE : _zz_decode_FPU_OPCODE_2_string = "STORE "; - FpuOpcode_MUL : _zz_decode_FPU_OPCODE_2_string = "MUL "; - FpuOpcode_ADD : _zz_decode_FPU_OPCODE_2_string = "ADD "; - FpuOpcode_FMA : _zz_decode_FPU_OPCODE_2_string = "FMA "; - FpuOpcode_I2F : _zz_decode_FPU_OPCODE_2_string = "I2F "; - FpuOpcode_F2I : _zz_decode_FPU_OPCODE_2_string = "F2I "; - FpuOpcode_CMP : _zz_decode_FPU_OPCODE_2_string = "CMP "; - FpuOpcode_DIV : _zz_decode_FPU_OPCODE_2_string = "DIV "; - FpuOpcode_SQRT : _zz_decode_FPU_OPCODE_2_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_decode_FPU_OPCODE_2_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_decode_FPU_OPCODE_2_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_decode_FPU_OPCODE_2_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_decode_FPU_OPCODE_2_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_decode_FPU_OPCODE_2_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_decode_FPU_OPCODE_2_string = "FCVT_X_X"; - default : _zz_decode_FPU_OPCODE_2_string = "????????"; - endcase - end - always @(*) begin - case(_zz_decode_SHIFT_CTRL_2) - ShiftCtrlEnum_DISABLE_1 : _zz_decode_SHIFT_CTRL_2_string = "DISABLE_1"; - ShiftCtrlEnum_SLL_1 : _zz_decode_SHIFT_CTRL_2_string = "SLL_1 "; - ShiftCtrlEnum_SRL_1 : _zz_decode_SHIFT_CTRL_2_string = "SRL_1 "; - ShiftCtrlEnum_SRA_1 : _zz_decode_SHIFT_CTRL_2_string = "SRA_1 "; - default : _zz_decode_SHIFT_CTRL_2_string = "?????????"; - endcase - end - always @(*) begin - case(_zz_decode_BRANCH_CTRL_14) - BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_14_string = "INC "; - BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_14_string = "B "; - BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_14_string = "JAL "; - BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_14_string = "JALR"; - default : _zz_decode_BRANCH_CTRL_14_string = "????"; + case(_zz_decode_SHIFT_CTRL_10) + ShiftCtrlEnum_DISABLE_1 : _zz_decode_SHIFT_CTRL_10_string = "DISABLE_1"; + ShiftCtrlEnum_SLL_1 : _zz_decode_SHIFT_CTRL_10_string = "SLL_1 "; + ShiftCtrlEnum_SRL_1 : _zz_decode_SHIFT_CTRL_10_string = "SRL_1 "; + ShiftCtrlEnum_SRA_1 : _zz_decode_SHIFT_CTRL_10_string = "SRA_1 "; + default : _zz_decode_SHIFT_CTRL_10_string = "?????????"; endcase end always @(*) begin - case(_zz_FpuPlugin_port_cmd_payload_roundMode) - FpuRoundMode_RNE : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "RMM"; - default : _zz_FpuPlugin_port_cmd_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_FpuPlugin_port_cmd_payload_roundMode_1) - FpuRoundMode_RNE : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "RNE"; - FpuRoundMode_RTZ : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "RTZ"; - FpuRoundMode_RDN : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "RDN"; - FpuRoundMode_RUP : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "RUP"; - FpuRoundMode_RMM : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "RMM"; - default : _zz_FpuPlugin_port_cmd_payload_roundMode_1_string = "???"; - endcase - end - always @(*) begin - case(writeBack_FpuPlugin_commit_payload_opcode) - FpuOpcode_LOAD : writeBack_FpuPlugin_commit_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : writeBack_FpuPlugin_commit_payload_opcode_string = "STORE "; - FpuOpcode_MUL : writeBack_FpuPlugin_commit_payload_opcode_string = "MUL "; - FpuOpcode_ADD : writeBack_FpuPlugin_commit_payload_opcode_string = "ADD "; - FpuOpcode_FMA : writeBack_FpuPlugin_commit_payload_opcode_string = "FMA "; - FpuOpcode_I2F : writeBack_FpuPlugin_commit_payload_opcode_string = "I2F "; - FpuOpcode_F2I : writeBack_FpuPlugin_commit_payload_opcode_string = "F2I "; - FpuOpcode_CMP : writeBack_FpuPlugin_commit_payload_opcode_string = "CMP "; - FpuOpcode_DIV : writeBack_FpuPlugin_commit_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : writeBack_FpuPlugin_commit_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : writeBack_FpuPlugin_commit_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : writeBack_FpuPlugin_commit_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : writeBack_FpuPlugin_commit_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : writeBack_FpuPlugin_commit_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : writeBack_FpuPlugin_commit_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : writeBack_FpuPlugin_commit_payload_opcode_string = "FCVT_X_X"; - default : writeBack_FpuPlugin_commit_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(writeBack_FpuPlugin_commit_s2mPipe_payload_opcode) - FpuOpcode_LOAD : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "STORE "; - FpuOpcode_MUL : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "MUL "; - FpuOpcode_ADD : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "ADD "; - FpuOpcode_FMA : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMA "; - FpuOpcode_I2F : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "I2F "; - FpuOpcode_F2I : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "F2I "; - FpuOpcode_CMP : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "CMP "; - FpuOpcode_DIV : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FCVT_X_X"; - default : writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(writeBack_FpuPlugin_commit_rData_opcode) - FpuOpcode_LOAD : writeBack_FpuPlugin_commit_rData_opcode_string = "LOAD "; - FpuOpcode_STORE : writeBack_FpuPlugin_commit_rData_opcode_string = "STORE "; - FpuOpcode_MUL : writeBack_FpuPlugin_commit_rData_opcode_string = "MUL "; - FpuOpcode_ADD : writeBack_FpuPlugin_commit_rData_opcode_string = "ADD "; - FpuOpcode_FMA : writeBack_FpuPlugin_commit_rData_opcode_string = "FMA "; - FpuOpcode_I2F : writeBack_FpuPlugin_commit_rData_opcode_string = "I2F "; - FpuOpcode_F2I : writeBack_FpuPlugin_commit_rData_opcode_string = "F2I "; - FpuOpcode_CMP : writeBack_FpuPlugin_commit_rData_opcode_string = "CMP "; - FpuOpcode_DIV : writeBack_FpuPlugin_commit_rData_opcode_string = "DIV "; - FpuOpcode_SQRT : writeBack_FpuPlugin_commit_rData_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : writeBack_FpuPlugin_commit_rData_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : writeBack_FpuPlugin_commit_rData_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : writeBack_FpuPlugin_commit_rData_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : writeBack_FpuPlugin_commit_rData_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : writeBack_FpuPlugin_commit_rData_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : writeBack_FpuPlugin_commit_rData_opcode_string = "FCVT_X_X"; - default : writeBack_FpuPlugin_commit_rData_opcode_string = "????????"; - endcase - end - always @(*) begin - case(_zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode) - FpuOpcode_LOAD : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "FCVT_X_X"; - default : _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode_string = "????????"; + case(_zz_decode_BRANCH_CTRL_2) + BranchCtrlEnum_INC : _zz_decode_BRANCH_CTRL_2_string = "INC "; + BranchCtrlEnum_B : _zz_decode_BRANCH_CTRL_2_string = "B "; + BranchCtrlEnum_JAL : _zz_decode_BRANCH_CTRL_2_string = "JAL "; + BranchCtrlEnum_JALR : _zz_decode_BRANCH_CTRL_2_string = "JALR"; + default : _zz_decode_BRANCH_CTRL_2_string = "????"; endcase end always @(*) begin @@ -3066,69 +2104,6 @@ module VexRiscv ( default : decode_to_execute_ALU_BITWISE_CTRL_string = "?????"; endcase end - always @(*) begin - case(decode_to_execute_FPU_OPCODE) - FpuOpcode_LOAD : decode_to_execute_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : decode_to_execute_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : decode_to_execute_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : decode_to_execute_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : decode_to_execute_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : decode_to_execute_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : decode_to_execute_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : decode_to_execute_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : decode_to_execute_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : decode_to_execute_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : decode_to_execute_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : decode_to_execute_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : decode_to_execute_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : decode_to_execute_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : decode_to_execute_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : decode_to_execute_FPU_OPCODE_string = "FCVT_X_X"; - default : decode_to_execute_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(execute_to_memory_FPU_OPCODE) - FpuOpcode_LOAD : execute_to_memory_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : execute_to_memory_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : execute_to_memory_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : execute_to_memory_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : execute_to_memory_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : execute_to_memory_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : execute_to_memory_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : execute_to_memory_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : execute_to_memory_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : execute_to_memory_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : execute_to_memory_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : execute_to_memory_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : execute_to_memory_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : execute_to_memory_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : execute_to_memory_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : execute_to_memory_FPU_OPCODE_string = "FCVT_X_X"; - default : execute_to_memory_FPU_OPCODE_string = "????????"; - endcase - end - always @(*) begin - case(memory_to_writeBack_FPU_OPCODE) - FpuOpcode_LOAD : memory_to_writeBack_FPU_OPCODE_string = "LOAD "; - FpuOpcode_STORE : memory_to_writeBack_FPU_OPCODE_string = "STORE "; - FpuOpcode_MUL : memory_to_writeBack_FPU_OPCODE_string = "MUL "; - FpuOpcode_ADD : memory_to_writeBack_FPU_OPCODE_string = "ADD "; - FpuOpcode_FMA : memory_to_writeBack_FPU_OPCODE_string = "FMA "; - FpuOpcode_I2F : memory_to_writeBack_FPU_OPCODE_string = "I2F "; - FpuOpcode_F2I : memory_to_writeBack_FPU_OPCODE_string = "F2I "; - FpuOpcode_CMP : memory_to_writeBack_FPU_OPCODE_string = "CMP "; - FpuOpcode_DIV : memory_to_writeBack_FPU_OPCODE_string = "DIV "; - FpuOpcode_SQRT : memory_to_writeBack_FPU_OPCODE_string = "SQRT "; - FpuOpcode_MIN_MAX : memory_to_writeBack_FPU_OPCODE_string = "MIN_MAX "; - FpuOpcode_SGNJ : memory_to_writeBack_FPU_OPCODE_string = "SGNJ "; - FpuOpcode_FMV_X_W : memory_to_writeBack_FPU_OPCODE_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : memory_to_writeBack_FPU_OPCODE_string = "FMV_W_X "; - FpuOpcode_FCLASS : memory_to_writeBack_FPU_OPCODE_string = "FCLASS "; - FpuOpcode_FCVT_X_X : memory_to_writeBack_FPU_OPCODE_string = "FCVT_X_X"; - default : memory_to_writeBack_FPU_OPCODE_string = "????????"; - endcase - end always @(*) begin case(decode_to_execute_SHIFT_CTRL) ShiftCtrlEnum_DISABLE_1 : decode_to_execute_SHIFT_CTRL_string = "DISABLE_1"; @@ -3149,137 +2124,140 @@ module VexRiscv ( end `endif - assign writeBack_MEMORY_LOAD_DATA = writeBack_DBusCachedPlugin_rspShifted; assign memory_MUL_LOW = ($signed(_zz_memory_MUL_LOW) + $signed(_zz_memory_MUL_LOW_7)); + assign memory_MEMORY_READ_DATA = dBus_rsp_data; assign execute_BRANCH_CALC = {execute_BranchPlugin_branchAdder[31 : 1],1'b0}; - assign execute_BRANCH_DO = _zz_execute_BRANCH_DO_1; + assign execute_BRANCH_DO = ((execute_PREDICTION_HAD_BRANCHED2 != execute_BRANCH_COND_RESULT) || execute_BranchPlugin_missAlignedTarget); assign memory_MUL_HH = execute_to_memory_MUL_HH; assign execute_MUL_HH = ($signed(execute_MulPlugin_aHigh) * $signed(execute_MulPlugin_bHigh)); assign execute_MUL_HL = ($signed(execute_MulPlugin_aHigh) * $signed(execute_MulPlugin_bSLow)); assign execute_MUL_LH = ($signed(execute_MulPlugin_aSLow) * $signed(execute_MulPlugin_bHigh)); assign execute_MUL_LL = (execute_MulPlugin_aULow * execute_MulPlugin_bULow); + assign writeBack_REGFILE_WRITE_DATA = memory_to_writeBack_REGFILE_WRITE_DATA; assign execute_REGFILE_WRITE_DATA = _zz_execute_REGFILE_WRITE_DATA; - assign memory_MEMORY_STORE_DATA_RF = execute_to_memory_MEMORY_STORE_DATA_RF; - assign execute_MEMORY_STORE_DATA_RF = _zz_execute_MEMORY_STORE_DATA_RF; - assign memory_FPU_COMMIT_LOAD = execute_to_memory_FPU_COMMIT_LOAD; - assign execute_FPU_COMMIT_LOAD = decode_to_execute_FPU_COMMIT_LOAD; - assign decode_FPU_COMMIT_LOAD = (decode_FPU_OPCODE == FpuOpcode_LOAD); - assign memory_FPU_FORKED = execute_to_memory_FPU_FORKED; - assign execute_FPU_FORKED = decode_to_execute_FPU_FORKED; - assign decode_FPU_FORKED = (decode_FpuPlugin_forked || FpuPlugin_port_cmd_fire_2); + assign memory_MEMORY_ADDRESS_LOW = execute_to_memory_MEMORY_ADDRESS_LOW; + assign execute_MEMORY_ADDRESS_LOW = dBus_cmd_payload_address[1 : 0]; + assign decode_DO_EBREAK = (((! DebugPlugin_haltIt) && (decode_IS_EBREAK || 1'b0)) && DebugPlugin_allowEBreak); + assign decode_PREDICTION_HAD_BRANCHED2 = IBusSimplePlugin_decodePrediction_cmd_hadBranch; assign decode_SRC2 = _zz_decode_SRC2_6; assign decode_SRC1 = _zz_decode_SRC1_1; assign decode_SRC2_FORCE_ZERO = (decode_SRC_ADD_ZERO && (! decode_SRC_USE_SUB_LESS)); - assign decode_RS2 = decode_RegFilePlugin_rs2Data; - assign memory_RS1 = execute_to_memory_RS1; - assign decode_RS1 = decode_RegFilePlugin_rs1Data; - assign decode_BRANCH_CTRL = _zz_decode_BRANCH_CTRL; assign _zz_decode_to_execute_BRANCH_CTRL = _zz_decode_to_execute_BRANCH_CTRL_1; assign decode_SHIFT_CTRL = _zz_decode_SHIFT_CTRL; assign _zz_decode_to_execute_SHIFT_CTRL = _zz_decode_to_execute_SHIFT_CTRL_1; - assign memory_FPU_OPCODE = _zz_memory_FPU_OPCODE; - assign _zz_memory_to_writeBack_FPU_OPCODE = _zz_memory_to_writeBack_FPU_OPCODE_1; - assign execute_FPU_OPCODE = _zz_execute_FPU_OPCODE; - assign _zz_execute_to_memory_FPU_OPCODE = _zz_execute_to_memory_FPU_OPCODE_1; - assign _zz_decode_to_execute_FPU_OPCODE = _zz_decode_to_execute_FPU_OPCODE_1; - assign memory_FPU_RSP = execute_to_memory_FPU_RSP; - assign execute_FPU_RSP = decode_to_execute_FPU_RSP; - assign decode_FPU_RSP = _zz_decode_BRANCH_CTRL_2[29]; - assign memory_FPU_COMMIT = execute_to_memory_FPU_COMMIT; - assign execute_FPU_COMMIT = decode_to_execute_FPU_COMMIT; - assign decode_FPU_COMMIT = _zz_decode_BRANCH_CTRL_2[28]; - assign memory_FPU_ENABLE = execute_to_memory_FPU_ENABLE; - assign execute_FPU_ENABLE = decode_to_execute_FPU_ENABLE; - assign decode_IS_RS2_SIGNED = _zz_decode_BRANCH_CTRL_2[26]; - assign decode_IS_RS1_SIGNED = _zz_decode_BRANCH_CTRL_2[25]; - assign decode_IS_DIV = _zz_decode_BRANCH_CTRL_2[24]; + assign decode_IS_RS2_SIGNED = _zz_decode_SHIFT_CTRL_2[26]; + assign decode_IS_RS1_SIGNED = _zz_decode_SHIFT_CTRL_2[25]; + assign decode_IS_DIV = _zz_decode_SHIFT_CTRL_2[24]; assign memory_IS_MUL = execute_to_memory_IS_MUL; assign execute_IS_MUL = decode_to_execute_IS_MUL; - assign decode_IS_MUL = _zz_decode_BRANCH_CTRL_2[23]; + assign decode_IS_MUL = _zz_decode_SHIFT_CTRL_2[23]; assign decode_ALU_BITWISE_CTRL = _zz_decode_ALU_BITWISE_CTRL; assign _zz_decode_to_execute_ALU_BITWISE_CTRL = _zz_decode_to_execute_ALU_BITWISE_CTRL_1; - assign decode_SRC_LESS_UNSIGNED = _zz_decode_BRANCH_CTRL_2[19]; + assign decode_SRC_LESS_UNSIGNED = _zz_decode_SHIFT_CTRL_2[19]; assign _zz_memory_to_writeBack_ENV_CTRL = _zz_memory_to_writeBack_ENV_CTRL_1; assign _zz_execute_to_memory_ENV_CTRL = _zz_execute_to_memory_ENV_CTRL_1; assign decode_ENV_CTRL = _zz_decode_ENV_CTRL; assign _zz_decode_to_execute_ENV_CTRL = _zz_decode_to_execute_ENV_CTRL_1; - assign decode_IS_CSR = _zz_decode_BRANCH_CTRL_2[16]; - assign decode_MEMORY_MANAGMENT = _zz_decode_BRANCH_CTRL_2[15]; - assign memory_MEMORY_WR = execute_to_memory_MEMORY_WR; - assign decode_MEMORY_WR = _zz_decode_BRANCH_CTRL_2[12]; + assign decode_IS_CSR = _zz_decode_SHIFT_CTRL_2[15]; + assign decode_MEMORY_STORE = _zz_decode_SHIFT_CTRL_2[12]; assign execute_BYPASSABLE_MEMORY_STAGE = decode_to_execute_BYPASSABLE_MEMORY_STAGE; - assign decode_BYPASSABLE_MEMORY_STAGE = _zz_decode_BRANCH_CTRL_2[11]; - assign decode_BYPASSABLE_EXECUTE_STAGE = _zz_decode_BRANCH_CTRL_2[10]; + assign decode_BYPASSABLE_MEMORY_STAGE = _zz_decode_SHIFT_CTRL_2[11]; + assign decode_BYPASSABLE_EXECUTE_STAGE = _zz_decode_SHIFT_CTRL_2[10]; assign decode_ALU_CTRL = _zz_decode_ALU_CTRL; assign _zz_decode_to_execute_ALU_CTRL = _zz_decode_to_execute_ALU_CTRL_1; + assign decode_MEMORY_ENABLE = _zz_decode_SHIFT_CTRL_2[3]; assign decode_CSR_READ_OPCODE = (decode_INSTRUCTION[13 : 7] != 7'h20); assign decode_CSR_WRITE_OPCODE = (! (((decode_INSTRUCTION[14 : 13] == 2'b01) && (decode_INSTRUCTION[19 : 15] == 5'h0)) || ((decode_INSTRUCTION[14 : 13] == 2'b11) && (decode_INSTRUCTION[19 : 15] == 5'h0)))); - assign decode_MEMORY_FORCE_CONSTISTENCY = 1'b0; assign writeBack_FORMAL_PC_NEXT = memory_to_writeBack_FORMAL_PC_NEXT; assign memory_FORMAL_PC_NEXT = execute_to_memory_FORMAL_PC_NEXT; assign execute_FORMAL_PC_NEXT = decode_to_execute_FORMAL_PC_NEXT; assign decode_FORMAL_PC_NEXT = (decode_PC + _zz_decode_FORMAL_PC_NEXT); assign memory_PC = execute_to_memory_PC; + assign execute_DO_EBREAK = decode_to_execute_DO_EBREAK; + assign decode_IS_EBREAK = _zz_decode_SHIFT_CTRL_2[18]; assign memory_BRANCH_CALC = execute_to_memory_BRANCH_CALC; assign memory_BRANCH_DO = execute_to_memory_BRANCH_DO; + assign execute_IS_RVC = decode_to_execute_IS_RVC; assign execute_PC = decode_to_execute_PC; + assign execute_BRANCH_COND_RESULT = _zz_execute_BRANCH_COND_RESULT_1; + assign execute_PREDICTION_HAD_BRANCHED2 = decode_to_execute_PREDICTION_HAD_BRANCHED2; assign execute_BRANCH_CTRL = _zz_execute_BRANCH_CTRL; - assign decode_RS2_USE = _zz_decode_BRANCH_CTRL_2[14]; - assign decode_RS1_USE = _zz_decode_BRANCH_CTRL_2[4]; + assign decode_RS2_USE = _zz_decode_SHIFT_CTRL_2[14]; + assign decode_RS1_USE = _zz_decode_SHIFT_CTRL_2[4]; assign execute_REGFILE_WRITE_VALID = decode_to_execute_REGFILE_WRITE_VALID; assign execute_BYPASSABLE_EXECUTE_STAGE = decode_to_execute_BYPASSABLE_EXECUTE_STAGE; assign memory_REGFILE_WRITE_VALID = execute_to_memory_REGFILE_WRITE_VALID; assign memory_BYPASSABLE_MEMORY_STAGE = execute_to_memory_BYPASSABLE_MEMORY_STAGE; assign writeBack_REGFILE_WRITE_VALID = memory_to_writeBack_REGFILE_WRITE_VALID; - assign execute_SHIFT_CTRL = _zz_execute_SHIFT_CTRL; always @(*) begin - _zz_memory_to_writeBack_FPU_FORKED = memory_FPU_FORKED; - if(memory_arbitration_isStuck) begin - _zz_memory_to_writeBack_FPU_FORKED = 1'b0; + decode_RS2 = decode_RegFilePlugin_rs2Data; + if(HazardSimplePlugin_writeBackBuffer_valid) begin + if(HazardSimplePlugin_addr1Match) begin + decode_RS2 = HazardSimplePlugin_writeBackBuffer_payload_data; + end end - end - - always @(*) begin - _zz_execute_to_memory_FPU_FORKED = execute_FPU_FORKED; - if(execute_arbitration_isStuck) begin - _zz_execute_to_memory_FPU_FORKED = 1'b0; + if(when_HazardSimplePlugin_l45) begin + if(when_HazardSimplePlugin_l47) begin + if(when_HazardSimplePlugin_l51) begin + decode_RS2 = _zz_decode_RS2_2; + end + end end - end - - always @(*) begin - _zz_decode_to_execute_FPU_FORKED = decode_FPU_FORKED; - if(decode_arbitration_isStuck) begin - _zz_decode_to_execute_FPU_FORKED = 1'b0; + if(when_HazardSimplePlugin_l45_1) begin + if(memory_BYPASSABLE_MEMORY_STAGE) begin + if(when_HazardSimplePlugin_l51_1) begin + decode_RS2 = _zz_decode_RS2; + end + end end - end - - assign writeBack_RS1 = memory_to_writeBack_RS1; - assign writeBack_FPU_COMMIT_LOAD = memory_to_writeBack_FPU_COMMIT_LOAD; - always @(*) begin - DBusBypass0_cond = 1'b0; - if(writeBack_FpuPlugin_isRsp) begin - if(writeBack_arbitration_isValid) begin - DBusBypass0_cond = 1'b1; + if(when_HazardSimplePlugin_l45_2) begin + if(execute_BYPASSABLE_EXECUTE_STAGE) begin + if(when_HazardSimplePlugin_l51_2) begin + decode_RS2 = _zz_decode_RS2_1; + end end end end - assign writeBack_FPU_COMMIT = memory_to_writeBack_FPU_COMMIT; - assign writeBack_FPU_RSP = memory_to_writeBack_FPU_RSP; - assign writeBack_FPU_FORKED = memory_to_writeBack_FPU_FORKED; - assign decode_FPU_ARG = _zz_decode_BRANCH_CTRL_2[36 : 35]; - assign decode_FPU_OPCODE = _zz_decode_FPU_OPCODE; - assign decode_FPU_ENABLE = _zz_decode_BRANCH_CTRL_2[27]; - assign writeBack_FPU_OPCODE = _zz_writeBack_FPU_OPCODE; - assign writeBack_FPU_ENABLE = memory_to_writeBack_FPU_ENABLE; - assign execute_IS_RS1_SIGNED = decode_to_execute_IS_RS1_SIGNED; - assign execute_IS_DIV = decode_to_execute_IS_DIV; - assign execute_IS_RS2_SIGNED = decode_to_execute_IS_RS2_SIGNED; always @(*) begin - _zz_memory_to_writeBack_REGFILE_WRITE_DATA = memory_REGFILE_WRITE_DATA; - if(when_MulDivIterativePlugin_l128) begin - _zz_memory_to_writeBack_REGFILE_WRITE_DATA = memory_DivPlugin_div_result; - end + decode_RS1 = decode_RegFilePlugin_rs1Data; + if(HazardSimplePlugin_writeBackBuffer_valid) begin + if(HazardSimplePlugin_addr0Match) begin + decode_RS1 = HazardSimplePlugin_writeBackBuffer_payload_data; + end + end + if(when_HazardSimplePlugin_l45) begin + if(when_HazardSimplePlugin_l47) begin + if(when_HazardSimplePlugin_l48) begin + decode_RS1 = _zz_decode_RS2_2; + end + end + end + if(when_HazardSimplePlugin_l45_1) begin + if(memory_BYPASSABLE_MEMORY_STAGE) begin + if(when_HazardSimplePlugin_l48_1) begin + decode_RS1 = _zz_decode_RS2; + end + end + end + if(when_HazardSimplePlugin_l45_2) begin + if(execute_BYPASSABLE_EXECUTE_STAGE) begin + if(when_HazardSimplePlugin_l48_2) begin + decode_RS1 = _zz_decode_RS2_1; + end + end + end + end + + assign execute_SHIFT_CTRL = _zz_execute_SHIFT_CTRL; + assign execute_IS_RS1_SIGNED = decode_to_execute_IS_RS1_SIGNED; + assign execute_IS_DIV = decode_to_execute_IS_DIV; + assign execute_IS_RS2_SIGNED = decode_to_execute_IS_RS2_SIGNED; + always @(*) begin + _zz_decode_RS2 = memory_REGFILE_WRITE_DATA; + if(when_MulDivIterativePlugin_l128) begin + _zz_decode_RS2 = memory_DivPlugin_div_result; + end end assign memory_INSTRUCTION = execute_to_memory_INSTRUCTION; @@ -3290,6 +2268,7 @@ module VexRiscv ( assign memory_MUL_HL = execute_to_memory_MUL_HL; assign memory_MUL_LH = execute_to_memory_MUL_LH; assign memory_MUL_LL = execute_to_memory_MUL_LL; + assign execute_RS1 = decode_to_execute_RS1; assign execute_SRC_LESS_UNSIGNED = decode_to_execute_SRC_LESS_UNSIGNED; assign execute_SRC2_FORCE_ZERO = decode_to_execute_SRC2_FORCE_ZERO; assign execute_SRC_USE_SUB_LESS = decode_to_execute_SRC_USE_SUB_LESS; @@ -3298,8 +2277,8 @@ module VexRiscv ( assign decode_SRC2_CTRL = _zz_decode_SRC2_CTRL; assign _zz_decode_SRC1 = decode_RS1; assign decode_SRC1_CTRL = _zz_decode_SRC1_CTRL; - assign decode_SRC_USE_SUB_LESS = _zz_decode_BRANCH_CTRL_2[2]; - assign decode_SRC_ADD_ZERO = _zz_decode_BRANCH_CTRL_2[22]; + assign decode_SRC_USE_SUB_LESS = _zz_decode_SHIFT_CTRL_2[2]; + assign decode_SRC_ADD_ZERO = _zz_decode_SHIFT_CTRL_2[22]; assign execute_SRC_ADD_SUB = execute_SrcPlugin_addSub; assign execute_SRC_LESS = execute_SrcPlugin_less; assign execute_ALU_CTRL = _zz_execute_ALU_CTRL; @@ -3316,20 +2295,20 @@ module VexRiscv ( assign decode_INSTRUCTION_ANTICIPATED = (decode_arbitration_isStuck ? decode_INSTRUCTION : IBusSimplePlugin_decompressor_output_payload_rsp_inst); always @(*) begin - decode_REGFILE_WRITE_VALID = _zz_decode_BRANCH_CTRL_2[9]; + decode_REGFILE_WRITE_VALID = _zz_decode_SHIFT_CTRL_2[9]; if(when_RegFilePlugin_l63) begin decode_REGFILE_WRITE_VALID = 1'b0; end end - assign decode_LEGAL_INSTRUCTION = (|{((decode_INSTRUCTION & 32'h0000005f) == 32'h00000017),{((decode_INSTRUCTION & 32'h0000007f) == 32'h0000006f),{((decode_INSTRUCTION & 32'h06000073) == 32'h00000043),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION) == 32'h00000003),{(_zz_decode_LEGAL_INSTRUCTION_1 == _zz_decode_LEGAL_INSTRUCTION_2),{_zz_decode_LEGAL_INSTRUCTION_3,{_zz_decode_LEGAL_INSTRUCTION_4,_zz_decode_LEGAL_INSTRUCTION_5}}}}}}}); + assign decode_LEGAL_INSTRUCTION = (|{((decode_INSTRUCTION & 32'h0000005f) == 32'h00000017),{((decode_INSTRUCTION & 32'h0000007f) == 32'h0000006f),{((decode_INSTRUCTION & 32'h0000106f) == 32'h00000003),{((decode_INSTRUCTION & _zz_decode_LEGAL_INSTRUCTION) == 32'h00001073),{(_zz_decode_LEGAL_INSTRUCTION_1 == _zz_decode_LEGAL_INSTRUCTION_2),{_zz_decode_LEGAL_INSTRUCTION_3,{_zz_decode_LEGAL_INSTRUCTION_4,_zz_decode_LEGAL_INSTRUCTION_5}}}}}}}); always @(*) begin - _zz_execute_to_memory_REGFILE_WRITE_DATA = execute_REGFILE_WRITE_DATA; + _zz_decode_RS2_1 = execute_REGFILE_WRITE_DATA; if(when_CsrPlugin_l1189) begin - _zz_execute_to_memory_REGFILE_WRITE_DATA = CsrPlugin_csrMapping_readDataSignal; + _zz_decode_RS2_1 = CsrPlugin_csrMapping_readDataSignal; end if(when_ShiftPlugins_l169) begin - _zz_execute_to_memory_REGFILE_WRITE_DATA = _zz_execute_to_memory_REGFILE_WRITE_DATA_1; + _zz_decode_RS2_1 = _zz_decode_RS2_3; end end @@ -3341,42 +2320,36 @@ module VexRiscv ( assign execute_ENV_CTRL = _zz_execute_ENV_CTRL; assign writeBack_ENV_CTRL = _zz_writeBack_ENV_CTRL; always @(*) begin - _zz_lastStageRegFileWrite_payload_data = writeBack_REGFILE_WRITE_DATA; - if(when_DBusCachedPlugin_l492) begin - _zz_lastStageRegFileWrite_payload_data = writeBack_DBusCachedPlugin_rspFormated; + _zz_decode_RS2_2 = writeBack_REGFILE_WRITE_DATA; + if(when_DBusSimplePlugin_l558) begin + _zz_decode_RS2_2 = writeBack_DBusSimplePlugin_rspFormated; end if(when_MulPlugin_l147) begin case(switch_MulPlugin_l148) 2'b00 : begin - _zz_lastStageRegFileWrite_payload_data = _zz__zz_lastStageRegFileWrite_payload_data; + _zz_decode_RS2_2 = _zz__zz_decode_RS2_2; end default : begin - _zz_lastStageRegFileWrite_payload_data = _zz__zz_lastStageRegFileWrite_payload_data_1; + _zz_decode_RS2_2 = _zz__zz_decode_RS2_2_1; end endcase end - if(writeBack_FpuPlugin_isRsp) begin - if(writeBack_arbitration_isValid) begin - _zz_lastStageRegFileWrite_payload_data = FpuPlugin_port_rsp_payload_value[31 : 0]; - end - end end - assign writeBack_MEMORY_WR = memory_to_writeBack_MEMORY_WR; - assign writeBack_MEMORY_STORE_DATA_RF = memory_to_writeBack_MEMORY_STORE_DATA_RF; - assign writeBack_REGFILE_WRITE_DATA = memory_to_writeBack_REGFILE_WRITE_DATA; assign writeBack_MEMORY_ENABLE = memory_to_writeBack_MEMORY_ENABLE; + assign writeBack_MEMORY_ADDRESS_LOW = memory_to_writeBack_MEMORY_ADDRESS_LOW; + assign writeBack_MEMORY_READ_DATA = memory_to_writeBack_MEMORY_READ_DATA; + assign memory_ALIGNEMENT_FAULT = execute_to_memory_ALIGNEMENT_FAULT; assign memory_REGFILE_WRITE_DATA = execute_to_memory_REGFILE_WRITE_DATA; + assign memory_MEMORY_STORE = execute_to_memory_MEMORY_STORE; assign memory_MEMORY_ENABLE = execute_to_memory_MEMORY_ENABLE; - assign execute_MEMORY_FORCE_CONSTISTENCY = decode_to_execute_MEMORY_FORCE_CONSTISTENCY; - assign execute_RS1 = decode_to_execute_RS1; - assign execute_MEMORY_MANAGMENT = decode_to_execute_MEMORY_MANAGMENT; - assign execute_RS2 = decode_to_execute_RS2; - assign execute_MEMORY_WR = decode_to_execute_MEMORY_WR; assign execute_SRC_ADD = execute_SrcPlugin_addSub; - assign execute_MEMORY_ENABLE = decode_to_execute_MEMORY_ENABLE; + assign execute_RS2 = decode_to_execute_RS2; assign execute_INSTRUCTION = decode_to_execute_INSTRUCTION; - assign decode_MEMORY_ENABLE = _zz_decode_BRANCH_CTRL_2[3]; + assign execute_MEMORY_STORE = decode_to_execute_MEMORY_STORE; + assign execute_MEMORY_ENABLE = decode_to_execute_MEMORY_ENABLE; + assign execute_ALIGNEMENT_FAULT = (((dBus_cmd_payload_size == 2'b10) && (dBus_cmd_payload_address[1 : 0] != 2'b00)) || ((dBus_cmd_payload_size == 2'b01) && (dBus_cmd_payload_address[0 : 0] != 1'b0))); + assign decode_BRANCH_CTRL = _zz_decode_BRANCH_CTRL_1; always @(*) begin _zz_memory_to_writeBack_FORMAL_PC_NEXT = memory_FORMAL_PC_NEXT; if(BranchPlugin_jumpInterface_valid) begin @@ -3384,6 +2357,13 @@ module VexRiscv ( end end + always @(*) begin + _zz_decode_to_execute_FORMAL_PC_NEXT = decode_FORMAL_PC_NEXT; + if(IBusSimplePlugin_predictionJumpInterface_valid) begin + _zz_decode_to_execute_FORMAL_PC_NEXT = IBusSimplePlugin_predictionJumpInterface_payload; + end + end + assign decode_PC = IBusSimplePlugin_decodePc_pcReg; assign decode_INSTRUCTION = IBusSimplePlugin_injector_decodeInput_payload_rsp_inst; assign decode_IS_RVC = IBusSimplePlugin_injector_decodeInput_payload_isRvc; @@ -3391,15 +2371,13 @@ module VexRiscv ( assign writeBack_INSTRUCTION = memory_to_writeBack_INSTRUCTION; always @(*) begin decode_arbitration_haltItself = 1'b0; - if(when_DBusCachedPlugin_l308) begin - decode_arbitration_haltItself = 1'b1; - end - if(when_FpuPlugin_l238) begin - decode_arbitration_haltItself = 1'b1; - end - if(FpuPlugin_port_cmd_isStall) begin - decode_arbitration_haltItself = 1'b1; - end + case(switch_Fetcher_l365) + 3'b010 : begin + decode_arbitration_haltItself = 1'b1; + end + default : begin + end + endcase end always @(*) begin @@ -3428,6 +2406,9 @@ module VexRiscv ( assign decode_arbitration_flushIt = 1'b0; always @(*) begin decode_arbitration_flushNext = 1'b0; + if(IBusSimplePlugin_predictionJumpInterface_valid) begin + decode_arbitration_flushNext = 1'b1; + end if(_zz_when) begin decode_arbitration_flushNext = 1'b1; end @@ -3435,7 +2416,7 @@ module VexRiscv ( always @(*) begin execute_arbitration_haltItself = 1'b0; - if(when_DBusCachedPlugin_l350) begin + if(when_DBusSimplePlugin_l428) begin execute_arbitration_haltItself = 1'b1; end if(when_CsrPlugin_l1193) begin @@ -3452,10 +2433,7 @@ module VexRiscv ( always @(*) begin execute_arbitration_haltByOther = 1'b0; - if(when_DBusCachedPlugin_l366) begin - execute_arbitration_haltByOther = 1'b1; - end - if(when_FpuPlugin_l214) begin + if(when_DebugPlugin_l295) begin execute_arbitration_haltByOther = 1'b1; end end @@ -3470,16 +2448,38 @@ module VexRiscv ( end end - assign execute_arbitration_flushIt = 1'b0; + always @(*) begin + execute_arbitration_flushIt = 1'b0; + if(when_DebugPlugin_l295) begin + if(when_DebugPlugin_l298) begin + execute_arbitration_flushIt = 1'b1; + end + end + end + always @(*) begin execute_arbitration_flushNext = 1'b0; if(CsrPlugin_selfException_valid) begin execute_arbitration_flushNext = 1'b1; end + if(when_DebugPlugin_l295) begin + if(when_DebugPlugin_l298) begin + execute_arbitration_flushNext = 1'b1; + end + end + if(_zz_3) begin + execute_arbitration_flushNext = 1'b1; + end + if(_zz_3) begin + execute_arbitration_flushNext = 1'b1; + end end always @(*) begin memory_arbitration_haltItself = 1'b0; + if(when_DBusSimplePlugin_l482) begin + memory_arbitration_haltItself = 1'b1; + end if(when_MulDivIterativePlugin_l128) begin if(when_MulDivIterativePlugin_l129) begin memory_arbitration_haltItself = 1'b1; @@ -3490,6 +2490,9 @@ module VexRiscv ( assign memory_arbitration_haltByOther = 1'b0; always @(*) begin memory_arbitration_removeIt = 1'b0; + if(DBusSimplePlugin_memoryExceptionPort_valid) begin + memory_arbitration_removeIt = 1'b1; + end if(memory_arbitration_isFlushed) begin memory_arbitration_removeIt = 1'b1; end @@ -3498,55 +2501,26 @@ module VexRiscv ( assign memory_arbitration_flushIt = 1'b0; always @(*) begin memory_arbitration_flushNext = 1'b0; - if(BranchPlugin_jumpInterface_valid) begin + if(DBusSimplePlugin_memoryExceptionPort_valid) begin memory_arbitration_flushNext = 1'b1; end - end - - always @(*) begin - writeBack_arbitration_haltItself = 1'b0; - if(when_DBusCachedPlugin_l466) begin - writeBack_arbitration_haltItself = 1'b1; - end - end - - always @(*) begin - writeBack_arbitration_haltByOther = 1'b0; - if(writeBack_FpuPlugin_isRsp) begin - if(when_FpuPlugin_l285) begin - writeBack_arbitration_haltByOther = 1'b1; - end - end - if(when_FpuPlugin_l301) begin - writeBack_arbitration_haltByOther = 1'b1; + if(BranchPlugin_jumpInterface_valid) begin + memory_arbitration_flushNext = 1'b1; end end + assign writeBack_arbitration_haltItself = 1'b0; + assign writeBack_arbitration_haltByOther = 1'b0; always @(*) begin writeBack_arbitration_removeIt = 1'b0; - if(DBusCachedPlugin_exceptionBus_valid) begin - writeBack_arbitration_removeIt = 1'b1; - end if(writeBack_arbitration_isFlushed) begin writeBack_arbitration_removeIt = 1'b1; end end - always @(*) begin - writeBack_arbitration_flushIt = 1'b0; - if(DBusCachedPlugin_redoBranch_valid) begin - writeBack_arbitration_flushIt = 1'b1; - end - end - + assign writeBack_arbitration_flushIt = 1'b0; always @(*) begin writeBack_arbitration_flushNext = 1'b0; - if(DBusCachedPlugin_redoBranch_valid) begin - writeBack_arbitration_flushNext = 1'b1; - end - if(DBusCachedPlugin_exceptionBus_valid) begin - writeBack_arbitration_flushNext = 1'b1; - end if(when_CsrPlugin_l1032) begin writeBack_arbitration_flushNext = 1'b1; end @@ -3570,9 +2544,26 @@ module VexRiscv ( if(when_CsrPlugin_l1077) begin IBusSimplePlugin_fetcherHalt = 1'b1; end + if(when_DebugPlugin_l295) begin + if(when_DebugPlugin_l298) begin + IBusSimplePlugin_fetcherHalt = 1'b1; + end + end + if(DebugPlugin_haltIt) begin + IBusSimplePlugin_fetcherHalt = 1'b1; + end + if(when_DebugPlugin_l311) begin + IBusSimplePlugin_fetcherHalt = 1'b1; + end + end + + always @(*) begin + IBusSimplePlugin_forceNoDecodeCond = 1'b0; + if(_zz_3) begin + IBusSimplePlugin_forceNoDecodeCond = 1'b1; + end end - assign IBusSimplePlugin_forceNoDecodeCond = 1'b0; always @(*) begin IBusSimplePlugin_incomingInstruction = 1'b0; if(IBusSimplePlugin_iBusRsp_stages_1_input_valid) begin @@ -3588,7 +2579,7 @@ module VexRiscv ( assign CsrPlugin_inWfi = 1'b0; always @(*) begin CsrPlugin_thirdPartyWake = 1'b0; - if(decode_FpuPlugin_forked) begin + if(DebugPlugin_haltIt) begin CsrPlugin_thirdPartyWake = 1'b1; end end @@ -3619,14 +2610,44 @@ module VexRiscv ( end end - assign CsrPlugin_forceMachineWire = 1'b0; - assign CsrPlugin_allowInterrupts = 1'b1; - assign CsrPlugin_allowException = 1'b1; - assign CsrPlugin_allowEbreakException = 1'b1; - assign BranchPlugin_inDebugNoFetchFlag = 1'b0; + always @(*) begin + CsrPlugin_forceMachineWire = 1'b0; + if(DebugPlugin_godmode) begin + CsrPlugin_forceMachineWire = 1'b1; + end + end + + always @(*) begin + CsrPlugin_allowInterrupts = 1'b1; + if(when_DebugPlugin_l331) begin + CsrPlugin_allowInterrupts = 1'b0; + end + end + + always @(*) begin + CsrPlugin_allowException = 1'b1; + if(DebugPlugin_godmode) begin + CsrPlugin_allowException = 1'b0; + end + end + + always @(*) begin + CsrPlugin_allowEbreakException = 1'b1; + if(DebugPlugin_allowEBreak) begin + CsrPlugin_allowEbreakException = 1'b0; + end + end + + always @(*) begin + BranchPlugin_inDebugNoFetchFlag = 1'b0; + if(DebugPlugin_godmode) begin + BranchPlugin_inDebugNoFetchFlag = 1'b1; + end + end + assign IBusSimplePlugin_externalFlush = ({writeBack_arbitration_flushNext,{memory_arbitration_flushNext,{execute_arbitration_flushNext,decode_arbitration_flushNext}}} != 4'b0000); - assign IBusSimplePlugin_jump_pcLoad_valid = ({BranchPlugin_jumpInterface_valid,{CsrPlugin_jumpInterface_valid,DBusCachedPlugin_redoBranch_valid}} != 3'b000); - assign _zz_IBusSimplePlugin_jump_pcLoad_payload = {BranchPlugin_jumpInterface_valid,{CsrPlugin_jumpInterface_valid,DBusCachedPlugin_redoBranch_valid}}; + assign IBusSimplePlugin_jump_pcLoad_valid = ({BranchPlugin_jumpInterface_valid,{CsrPlugin_jumpInterface_valid,IBusSimplePlugin_predictionJumpInterface_valid}} != 3'b000); + assign _zz_IBusSimplePlugin_jump_pcLoad_payload = {IBusSimplePlugin_predictionJumpInterface_valid,{BranchPlugin_jumpInterface_valid,CsrPlugin_jumpInterface_valid}}; assign _zz_IBusSimplePlugin_jump_pcLoad_payload_1 = (_zz_IBusSimplePlugin_jump_pcLoad_payload & (~ _zz__zz_IBusSimplePlugin_jump_pcLoad_payload_1)); assign _zz_IBusSimplePlugin_jump_pcLoad_payload_2 = _zz_IBusSimplePlugin_jump_pcLoad_payload_1[1]; assign _zz_IBusSimplePlugin_jump_pcLoad_payload_3 = _zz_IBusSimplePlugin_jump_pcLoad_payload_1[2]; @@ -3679,7 +2700,13 @@ module VexRiscv ( end assign IBusSimplePlugin_decodePc_pcPlus = (IBusSimplePlugin_decodePc_pcReg + _zz_IBusSimplePlugin_decodePc_pcPlus); - assign IBusSimplePlugin_decodePc_injectedDecode = 1'b0; + always @(*) begin + IBusSimplePlugin_decodePc_injectedDecode = 1'b0; + if(when_Fetcher_l363) begin + IBusSimplePlugin_decodePc_injectedDecode = 1'b1; + end + end + assign when_Fetcher_l183 = (decode_arbitration_isFiring && (! IBusSimplePlugin_decodePc_injectedDecode)); assign when_Fetcher_l195 = (IBusSimplePlugin_jump_pcLoad_valid && ((! decode_arbitration_isStuck) || decode_arbitration_removeIt)); assign IBusSimplePlugin_iBusRsp_redoFetch = 1'b0; @@ -3741,15 +2768,9 @@ module VexRiscv ( 5'h02 : begin IBusSimplePlugin_decompressor_decompressed = {{{{_zz_IBusSimplePlugin_decompressor_decompressed_3,_zz_IBusSimplePlugin_decompressor_decompressed_1},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_2},7'h03}; end - 5'h03 : begin - IBusSimplePlugin_decompressor_decompressed = {{{{_zz_IBusSimplePlugin_decompressor_decompressed_3,_zz_IBusSimplePlugin_decompressor_decompressed_1},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_2},7'h07}; - end 5'h06 : begin IBusSimplePlugin_decompressor_decompressed = {{{{{_zz_IBusSimplePlugin_decompressor_decompressed_3[11 : 5],_zz_IBusSimplePlugin_decompressor_decompressed_2},_zz_IBusSimplePlugin_decompressor_decompressed_1},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_3[4 : 0]},7'h23}; end - 5'h07 : begin - IBusSimplePlugin_decompressor_decompressed = {{{{{_zz_IBusSimplePlugin_decompressor_decompressed_3[11 : 5],_zz_IBusSimplePlugin_decompressor_decompressed_2},_zz_IBusSimplePlugin_decompressor_decompressed_1},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_3[4 : 0]},7'h27}; - end 5'h08 : begin IBusSimplePlugin_decompressor_decompressed = {{{{_zz_IBusSimplePlugin_decompressor_decompressed_5,_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},3'b000},_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},7'h13}; end @@ -3780,18 +2801,12 @@ module VexRiscv ( 5'h12 : begin IBusSimplePlugin_decompressor_decompressed = {{{{{{{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[3 : 2]},_zz_IBusSimplePlugin_decompressor_decompressed[12]},_zz_IBusSimplePlugin_decompressor_decompressed[6 : 4]},2'b00},_zz_IBusSimplePlugin_decompressor_decompressed_21},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},7'h03}; end - 5'h13 : begin - IBusSimplePlugin_decompressor_decompressed = {{{{{{{{4'b0000,_zz_IBusSimplePlugin_decompressor_decompressed[3 : 2]},_zz_IBusSimplePlugin_decompressor_decompressed[12]},_zz_IBusSimplePlugin_decompressor_decompressed[6 : 4]},2'b00},_zz_IBusSimplePlugin_decompressor_decompressed_21},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},7'h07}; - end 5'h14 : begin IBusSimplePlugin_decompressor_decompressed = ((_zz_IBusSimplePlugin_decompressor_decompressed[12 : 2] == 11'h400) ? 32'h00100073 : ((_zz_IBusSimplePlugin_decompressor_decompressed[6 : 2] == 5'h0) ? {{{{12'h0,_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},3'b000},(_zz_IBusSimplePlugin_decompressor_decompressed[12] ? _zz_IBusSimplePlugin_decompressor_decompressed_20 : _zz_IBusSimplePlugin_decompressor_decompressed_19)},7'h67} : {{{{{_zz_IBusSimplePlugin_decompressor_decompressed_30,_zz_IBusSimplePlugin_decompressor_decompressed_31},(_zz_IBusSimplePlugin_decompressor_decompressed_32 ? _zz_IBusSimplePlugin_decompressor_decompressed_33 : _zz_IBusSimplePlugin_decompressor_decompressed_19)},3'b000},_zz_IBusSimplePlugin_decompressor_decompressed[11 : 7]},7'h33})); end 5'h16 : begin IBusSimplePlugin_decompressor_decompressed = {{{{{_zz_IBusSimplePlugin_decompressor_decompressed_34[11 : 5],_zz_IBusSimplePlugin_decompressor_decompressed[6 : 2]},_zz_IBusSimplePlugin_decompressor_decompressed_21},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_35[4 : 0]},7'h23}; end - 5'h17 : begin - IBusSimplePlugin_decompressor_decompressed = {{{{{_zz_IBusSimplePlugin_decompressor_decompressed_36[11 : 5],_zz_IBusSimplePlugin_decompressor_decompressed[6 : 2]},_zz_IBusSimplePlugin_decompressor_decompressed_21},3'b010},_zz_IBusSimplePlugin_decompressor_decompressed_37[4 : 0]},7'h27}; - end default : begin end endcase @@ -3957,11 +2972,85 @@ module VexRiscv ( assign IBusSimplePlugin_injector_decodeInput_ready = (! decode_arbitration_isStuck); always @(*) begin decode_arbitration_isValid = IBusSimplePlugin_injector_decodeInput_valid; + case(switch_Fetcher_l365) + 3'b010 : begin + decode_arbitration_isValid = 1'b1; + end + 3'b011 : begin + decode_arbitration_isValid = 1'b1; + end + default : begin + end + endcase if(IBusSimplePlugin_forceNoDecodeCond) begin decode_arbitration_isValid = 1'b0; end end + assign _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch = _zz__zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch[11]; + always @(*) begin + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[18] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[17] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[16] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[15] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[14] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[13] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[12] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[11] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[10] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[9] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[8] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[7] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[6] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[5] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[4] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[3] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[2] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[1] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_1[0] = _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch; + end + + assign IBusSimplePlugin_decodePrediction_cmd_hadBranch = ((decode_BRANCH_CTRL == BranchCtrlEnum_JAL) || ((decode_BRANCH_CTRL == BranchCtrlEnum_B) && _zz_IBusSimplePlugin_decodePrediction_cmd_hadBranch_2[31])); + assign IBusSimplePlugin_predictionJumpInterface_valid = (decode_arbitration_isValid && IBusSimplePlugin_decodePrediction_cmd_hadBranch); + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload = _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload[19]; + always @(*) begin + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[10] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[9] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[8] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[7] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[6] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[5] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[4] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[3] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[2] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[1] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_1[0] = _zz_IBusSimplePlugin_predictionJumpInterface_payload; + end + + assign _zz_IBusSimplePlugin_predictionJumpInterface_payload_2 = _zz__zz_IBusSimplePlugin_predictionJumpInterface_payload_2[11]; + always @(*) begin + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[18] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[17] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[16] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[15] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[14] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[13] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[12] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[11] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[10] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[9] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[8] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[7] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[6] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[5] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[4] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[3] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[2] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[1] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + _zz_IBusSimplePlugin_predictionJumpInterface_payload_3[0] = _zz_IBusSimplePlugin_predictionJumpInterface_payload_2; + end + + assign IBusSimplePlugin_predictionJumpInterface_payload = (decode_PC + ((decode_BRANCH_CTRL == BranchCtrlEnum_JAL) ? {{_zz_IBusSimplePlugin_predictionJumpInterface_payload_1,{{{_zz_IBusSimplePlugin_predictionJumpInterface_payload_4,_zz_IBusSimplePlugin_predictionJumpInterface_payload_5},_zz_IBusSimplePlugin_predictionJumpInterface_payload_6},decode_INSTRUCTION[30 : 21]}},1'b0} : {{_zz_IBusSimplePlugin_predictionJumpInterface_payload_3,{{{_zz_IBusSimplePlugin_predictionJumpInterface_payload_7,_zz_IBusSimplePlugin_predictionJumpInterface_payload_8},decode_INSTRUCTION[30 : 25]},decode_INSTRUCTION[11 : 8]}},1'b0})); assign iBus_cmd_valid = IBusSimplePlugin_cmd_valid; assign IBusSimplePlugin_cmd_ready = iBus_cmd_ready; assign iBus_cmd_payload_pc = IBusSimplePlugin_cmd_payload_pc; @@ -4026,201 +3115,159 @@ module VexRiscv ( assign IBusSimplePlugin_decodeExceptionPort_payload_badAddr = {IBusSimplePlugin_rspJoin_join_payload_pc[31 : 2],2'b00}; assign when_IBusSimplePlugin_l402 = (IBusSimplePlugin_rspJoin_join_valid && IBusSimplePlugin_rspJoin_join_payload_rsp_error); assign IBusSimplePlugin_decodeExceptionPort_valid = (IBusSimplePlugin_rspJoin_exceptionDetected && IBusSimplePlugin_iBusRsp_readyForError); - assign dBus_cmd_valid = dataCache_1_io_mem_cmd_valid; - assign dBus_cmd_payload_wr = dataCache_1_io_mem_cmd_payload_wr; - assign dBus_cmd_payload_uncached = dataCache_1_io_mem_cmd_payload_uncached; - assign dBus_cmd_payload_address = dataCache_1_io_mem_cmd_payload_address; - assign dBus_cmd_payload_data = dataCache_1_io_mem_cmd_payload_data; - assign dBus_cmd_payload_mask = dataCache_1_io_mem_cmd_payload_mask; - assign dBus_cmd_payload_size = dataCache_1_io_mem_cmd_payload_size; - assign dBus_cmd_payload_last = dataCache_1_io_mem_cmd_payload_last; - assign when_DBusCachedPlugin_l308 = ((DBusCachedPlugin_mmuBus_busy && decode_arbitration_isValid) && decode_MEMORY_ENABLE); - assign execute_DBusCachedPlugin_size = execute_INSTRUCTION[13 : 12]; - assign dataCache_1_io_cpu_execute_isValid = (execute_arbitration_isValid && execute_MEMORY_ENABLE); - assign dataCache_1_io_cpu_execute_address = execute_SRC_ADD; - always @(*) begin - case(execute_DBusCachedPlugin_size) + assign _zz_dBus_cmd_valid = 1'b0; + always @(*) begin + execute_DBusSimplePlugin_skipCmd = 1'b0; + if(execute_ALIGNEMENT_FAULT) begin + execute_DBusSimplePlugin_skipCmd = 1'b1; + end + end + + assign dBus_cmd_valid = (((((execute_arbitration_isValid && execute_MEMORY_ENABLE) && (! execute_arbitration_isStuckByOthers)) && (! execute_arbitration_isFlushed)) && (! execute_DBusSimplePlugin_skipCmd)) && (! _zz_dBus_cmd_valid)); + assign dBus_cmd_payload_wr = execute_MEMORY_STORE; + assign dBus_cmd_payload_size = execute_INSTRUCTION[13 : 12]; + always @(*) begin + case(dBus_cmd_payload_size) 2'b00 : begin - _zz_execute_MEMORY_STORE_DATA_RF = {{{execute_RS2[7 : 0],execute_RS2[7 : 0]},execute_RS2[7 : 0]},execute_RS2[7 : 0]}; + _zz_dBus_cmd_payload_data = {{{execute_RS2[7 : 0],execute_RS2[7 : 0]},execute_RS2[7 : 0]},execute_RS2[7 : 0]}; end 2'b01 : begin - _zz_execute_MEMORY_STORE_DATA_RF = {execute_RS2[15 : 0],execute_RS2[15 : 0]}; + _zz_dBus_cmd_payload_data = {execute_RS2[15 : 0],execute_RS2[15 : 0]}; end default : begin - _zz_execute_MEMORY_STORE_DATA_RF = execute_RS2[31 : 0]; + _zz_dBus_cmd_payload_data = execute_RS2[31 : 0]; end endcase end - assign dataCache_1_io_cpu_flush_valid = (execute_arbitration_isValid && execute_MEMORY_MANAGMENT); - assign dataCache_1_io_cpu_flush_payload_singleLine = (execute_INSTRUCTION[19 : 15] != 5'h0); - assign dataCache_1_io_cpu_flush_isStall = (dataCache_1_io_cpu_flush_valid && (! dataCache_1_io_cpu_flush_ready)); - assign when_DBusCachedPlugin_l350 = (dataCache_1_io_cpu_flush_isStall || dataCache_1_io_cpu_execute_haltIt); - assign when_DBusCachedPlugin_l366 = (dataCache_1_io_cpu_execute_refilling && execute_arbitration_isValid); - assign dataCache_1_io_cpu_memory_isValid = (memory_arbitration_isValid && memory_MEMORY_ENABLE); - assign dataCache_1_io_cpu_memory_address = memory_REGFILE_WRITE_DATA; - assign DBusCachedPlugin_mmuBus_cmd_0_isValid = dataCache_1_io_cpu_memory_isValid; - assign DBusCachedPlugin_mmuBus_cmd_0_isStuck = memory_arbitration_isStuck; - assign DBusCachedPlugin_mmuBus_cmd_0_virtualAddress = dataCache_1_io_cpu_memory_address; - assign DBusCachedPlugin_mmuBus_cmd_0_bypassTranslation = 1'b0; - assign DBusCachedPlugin_mmuBus_end = ((! memory_arbitration_isStuck) || memory_arbitration_removeIt); + assign dBus_cmd_payload_data = _zz_dBus_cmd_payload_data; + assign when_DBusSimplePlugin_l428 = ((((execute_arbitration_isValid && execute_MEMORY_ENABLE) && (! dBus_cmd_ready)) && (! execute_DBusSimplePlugin_skipCmd)) && (! _zz_dBus_cmd_valid)); always @(*) begin - dataCache_1_io_cpu_memory_mmuRsp_isIoAccess = DBusCachedPlugin_mmuBus_rsp_isIoAccess; - if(when_DBusCachedPlugin_l393) begin - dataCache_1_io_cpu_memory_mmuRsp_isIoAccess = 1'b1; - end + case(dBus_cmd_payload_size) + 2'b00 : begin + _zz_execute_DBusSimplePlugin_formalMask = 4'b0001; + end + 2'b01 : begin + _zz_execute_DBusSimplePlugin_formalMask = 4'b0011; + end + default : begin + _zz_execute_DBusSimplePlugin_formalMask = 4'b1111; + end + endcase end - assign when_DBusCachedPlugin_l393 = (1'b0 && (! dataCache_1_io_cpu_memory_isWrite)); + assign execute_DBusSimplePlugin_formalMask = (_zz_execute_DBusSimplePlugin_formalMask <<< dBus_cmd_payload_address[1 : 0]); + assign dBus_cmd_payload_address = execute_SRC_ADD; + assign when_DBusSimplePlugin_l482 = (((memory_arbitration_isValid && memory_MEMORY_ENABLE) && (! memory_MEMORY_STORE)) && ((! dBus_rsp_ready) || 1'b0)); always @(*) begin - dataCache_1_io_cpu_writeBack_isValid = (writeBack_arbitration_isValid && writeBack_MEMORY_ENABLE); - if(writeBack_arbitration_haltByOther) begin - dataCache_1_io_cpu_writeBack_isValid = 1'b0; + DBusSimplePlugin_memoryExceptionPort_valid = 1'b0; + if(when_DBusSimplePlugin_l489) begin + DBusSimplePlugin_memoryExceptionPort_valid = 1'b1; end - end - - assign dataCache_1_io_cpu_writeBack_isUser = (CsrPlugin_privilege == 2'b00); - assign dataCache_1_io_cpu_writeBack_address = writeBack_REGFILE_WRITE_DATA; - always @(*) begin - dataCache_1_io_cpu_writeBack_storeData[31 : 0] = writeBack_MEMORY_STORE_DATA_RF; - if(DBusBypass0_cond) begin - dataCache_1_io_cpu_writeBack_storeData[31 : 0] = DBusBypass0_value; + if(memory_ALIGNEMENT_FAULT) begin + DBusSimplePlugin_memoryExceptionPort_valid = 1'b1; end - end - - always @(*) begin - DBusCachedPlugin_redoBranch_valid = 1'b0; - if(when_DBusCachedPlugin_l446) begin - if(dataCache_1_io_cpu_redo) begin - DBusCachedPlugin_redoBranch_valid = 1'b1; - end + if(when_DBusSimplePlugin_l515) begin + DBusSimplePlugin_memoryExceptionPort_valid = 1'b0; end end - assign DBusCachedPlugin_redoBranch_payload = writeBack_PC; always @(*) begin - DBusCachedPlugin_exceptionBus_valid = 1'b0; - if(when_DBusCachedPlugin_l446) begin - if(dataCache_1_io_cpu_writeBack_accessError) begin - DBusCachedPlugin_exceptionBus_valid = 1'b1; - end - if(dataCache_1_io_cpu_writeBack_mmuException) begin - DBusCachedPlugin_exceptionBus_valid = 1'b1; - end - if(dataCache_1_io_cpu_writeBack_unalignedAccess) begin - DBusCachedPlugin_exceptionBus_valid = 1'b1; - end - if(dataCache_1_io_cpu_redo) begin - DBusCachedPlugin_exceptionBus_valid = 1'b0; - end + DBusSimplePlugin_memoryExceptionPort_payload_code = 4'bxxxx; + if(when_DBusSimplePlugin_l489) begin + DBusSimplePlugin_memoryExceptionPort_payload_code = 4'b0101; + end + if(memory_ALIGNEMENT_FAULT) begin + DBusSimplePlugin_memoryExceptionPort_payload_code = {1'd0, _zz_DBusSimplePlugin_memoryExceptionPort_payload_code}; end end - assign DBusCachedPlugin_exceptionBus_payload_badAddr = writeBack_REGFILE_WRITE_DATA; + assign DBusSimplePlugin_memoryExceptionPort_payload_badAddr = memory_REGFILE_WRITE_DATA; + assign when_DBusSimplePlugin_l489 = ((dBus_rsp_ready && dBus_rsp_error) && (! memory_MEMORY_STORE)); + assign when_DBusSimplePlugin_l515 = (! ((memory_arbitration_isValid && memory_MEMORY_ENABLE) && (1'b1 || (! memory_arbitration_isStuckByOthers)))); always @(*) begin - DBusCachedPlugin_exceptionBus_payload_code = 4'bxxxx; - if(when_DBusCachedPlugin_l446) begin - if(dataCache_1_io_cpu_writeBack_accessError) begin - DBusCachedPlugin_exceptionBus_payload_code = {1'd0, _zz_DBusCachedPlugin_exceptionBus_payload_code}; + writeBack_DBusSimplePlugin_rspShifted = writeBack_MEMORY_READ_DATA; + case(writeBack_MEMORY_ADDRESS_LOW) + 2'b01 : begin + writeBack_DBusSimplePlugin_rspShifted[7 : 0] = writeBack_MEMORY_READ_DATA[15 : 8]; end - if(dataCache_1_io_cpu_writeBack_mmuException) begin - DBusCachedPlugin_exceptionBus_payload_code = (writeBack_MEMORY_WR ? 4'b1111 : 4'b1101); + 2'b10 : begin + writeBack_DBusSimplePlugin_rspShifted[15 : 0] = writeBack_MEMORY_READ_DATA[31 : 16]; end - if(dataCache_1_io_cpu_writeBack_unalignedAccess) begin - DBusCachedPlugin_exceptionBus_payload_code = {1'd0, _zz_DBusCachedPlugin_exceptionBus_payload_code_1}; + 2'b11 : begin + writeBack_DBusSimplePlugin_rspShifted[7 : 0] = writeBack_MEMORY_READ_DATA[31 : 24]; end - end - end - - assign when_DBusCachedPlugin_l446 = (writeBack_arbitration_isValid && writeBack_MEMORY_ENABLE); - assign when_DBusCachedPlugin_l466 = (dataCache_1_io_cpu_writeBack_isValid && dataCache_1_io_cpu_writeBack_haltIt); - assign writeBack_DBusCachedPlugin_rspSplits_0 = dataCache_1_io_cpu_writeBack_data[7 : 0]; - assign writeBack_DBusCachedPlugin_rspSplits_1 = dataCache_1_io_cpu_writeBack_data[15 : 8]; - assign writeBack_DBusCachedPlugin_rspSplits_2 = dataCache_1_io_cpu_writeBack_data[23 : 16]; - assign writeBack_DBusCachedPlugin_rspSplits_3 = dataCache_1_io_cpu_writeBack_data[31 : 24]; - always @(*) begin - writeBack_DBusCachedPlugin_rspShifted[7 : 0] = _zz_writeBack_DBusCachedPlugin_rspShifted; - writeBack_DBusCachedPlugin_rspShifted[15 : 8] = _zz_writeBack_DBusCachedPlugin_rspShifted_2; - writeBack_DBusCachedPlugin_rspShifted[23 : 16] = writeBack_DBusCachedPlugin_rspSplits_2; - writeBack_DBusCachedPlugin_rspShifted[31 : 24] = writeBack_DBusCachedPlugin_rspSplits_3; + default : begin + end + endcase end - assign writeBack_DBusCachedPlugin_rspRf = writeBack_DBusCachedPlugin_rspShifted[31 : 0]; assign switch_Misc_l210_2 = writeBack_INSTRUCTION[13 : 12]; - assign _zz_writeBack_DBusCachedPlugin_rspFormated = (writeBack_DBusCachedPlugin_rspRf[7] && (! writeBack_INSTRUCTION[14])); - always @(*) begin - _zz_writeBack_DBusCachedPlugin_rspFormated_1[31] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[30] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[29] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[28] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[27] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[26] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[25] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[24] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[23] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[22] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[21] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[20] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[19] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[18] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[17] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[16] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[15] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[14] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[13] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[12] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[11] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[10] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[9] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[8] = _zz_writeBack_DBusCachedPlugin_rspFormated; - _zz_writeBack_DBusCachedPlugin_rspFormated_1[7 : 0] = writeBack_DBusCachedPlugin_rspRf[7 : 0]; - end - - assign _zz_writeBack_DBusCachedPlugin_rspFormated_2 = (writeBack_DBusCachedPlugin_rspRf[15] && (! writeBack_INSTRUCTION[14])); - always @(*) begin - _zz_writeBack_DBusCachedPlugin_rspFormated_3[31] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[30] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[29] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[28] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[27] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[26] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[25] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[24] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[23] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[22] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[21] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[20] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[19] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[18] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[17] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[16] = _zz_writeBack_DBusCachedPlugin_rspFormated_2; - _zz_writeBack_DBusCachedPlugin_rspFormated_3[15 : 0] = writeBack_DBusCachedPlugin_rspRf[15 : 0]; + assign _zz_writeBack_DBusSimplePlugin_rspFormated = (writeBack_DBusSimplePlugin_rspShifted[7] && (! writeBack_INSTRUCTION[14])); + always @(*) begin + _zz_writeBack_DBusSimplePlugin_rspFormated_1[31] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[30] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[29] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[28] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[27] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[26] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[25] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[24] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[23] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[22] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[21] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[20] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[19] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[18] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[17] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[16] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[15] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[14] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[13] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[12] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[11] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[10] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[9] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[8] = _zz_writeBack_DBusSimplePlugin_rspFormated; + _zz_writeBack_DBusSimplePlugin_rspFormated_1[7 : 0] = writeBack_DBusSimplePlugin_rspShifted[7 : 0]; + end + + assign _zz_writeBack_DBusSimplePlugin_rspFormated_2 = (writeBack_DBusSimplePlugin_rspShifted[15] && (! writeBack_INSTRUCTION[14])); + always @(*) begin + _zz_writeBack_DBusSimplePlugin_rspFormated_3[31] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[30] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[29] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[28] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[27] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[26] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[25] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[24] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[23] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[22] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[21] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[20] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[19] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[18] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[17] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[16] = _zz_writeBack_DBusSimplePlugin_rspFormated_2; + _zz_writeBack_DBusSimplePlugin_rspFormated_3[15 : 0] = writeBack_DBusSimplePlugin_rspShifted[15 : 0]; end always @(*) begin case(switch_Misc_l210_2) 2'b00 : begin - writeBack_DBusCachedPlugin_rspFormated = _zz_writeBack_DBusCachedPlugin_rspFormated_1; + writeBack_DBusSimplePlugin_rspFormated = _zz_writeBack_DBusSimplePlugin_rspFormated_1; end 2'b01 : begin - writeBack_DBusCachedPlugin_rspFormated = _zz_writeBack_DBusCachedPlugin_rspFormated_3; + writeBack_DBusSimplePlugin_rspFormated = _zz_writeBack_DBusSimplePlugin_rspFormated_3; end default : begin - writeBack_DBusCachedPlugin_rspFormated = writeBack_DBusCachedPlugin_rspRf; + writeBack_DBusSimplePlugin_rspFormated = writeBack_DBusSimplePlugin_rspShifted; end endcase end - assign when_DBusCachedPlugin_l492 = (writeBack_arbitration_isValid && writeBack_MEMORY_ENABLE); - assign DBusCachedPlugin_mmuBus_rsp_physicalAddress = DBusCachedPlugin_mmuBus_cmd_0_virtualAddress; - assign DBusCachedPlugin_mmuBus_rsp_allowRead = 1'b1; - assign DBusCachedPlugin_mmuBus_rsp_allowWrite = 1'b1; - assign DBusCachedPlugin_mmuBus_rsp_allowExecute = 1'b1; - assign DBusCachedPlugin_mmuBus_rsp_isIoAccess = 1'b1; - assign DBusCachedPlugin_mmuBus_rsp_isPaging = 1'b0; - assign DBusCachedPlugin_mmuBus_rsp_exception = 1'b0; - assign DBusCachedPlugin_mmuBus_rsp_refilling = 1'b0; - assign DBusCachedPlugin_mmuBus_busy = 1'b0; + assign when_DBusSimplePlugin_l558 = (writeBack_arbitration_isValid && writeBack_MEMORY_ENABLE); always @(*) begin CsrPlugin_privilege = 2'b11; if(CsrPlugin_forceMachineWire) begin @@ -4259,6 +3306,9 @@ module VexRiscv ( always @(*) begin CsrPlugin_exceptionPortCtrl_exceptionValids_memory = CsrPlugin_exceptionPortCtrl_exceptionValidsRegs_memory; + if(DBusSimplePlugin_memoryExceptionPort_valid) begin + CsrPlugin_exceptionPortCtrl_exceptionValids_memory = 1'b1; + end if(memory_arbitration_isFlushed) begin CsrPlugin_exceptionPortCtrl_exceptionValids_memory = 1'b0; end @@ -4266,9 +3316,6 @@ module VexRiscv ( always @(*) begin CsrPlugin_exceptionPortCtrl_exceptionValids_writeBack = CsrPlugin_exceptionPortCtrl_exceptionValidsRegs_writeBack; - if(DBusCachedPlugin_exceptionBus_valid) begin - CsrPlugin_exceptionPortCtrl_exceptionValids_writeBack = 1'b1; - end if(writeBack_arbitration_isFlushed) begin CsrPlugin_exceptionPortCtrl_exceptionValids_writeBack = 1'b0; end @@ -4362,22 +3409,28 @@ module VexRiscv ( if(execute_CsrPlugin_csr_773) begin execute_CsrPlugin_illegalAccess = 1'b0; end + if(execute_CsrPlugin_csr_833) begin + execute_CsrPlugin_illegalAccess = 1'b0; + end if(execute_CsrPlugin_csr_834) begin if(execute_CSR_READ_OPCODE) begin execute_CsrPlugin_illegalAccess = 1'b0; end end - if(execute_CsrPlugin_csr_3) begin - execute_CsrPlugin_illegalAccess = 1'b0; - end - if(execute_CsrPlugin_csr_2) begin - execute_CsrPlugin_illegalAccess = 1'b0; + if(execute_CsrPlugin_csr_835) begin + if(execute_CSR_READ_OPCODE) begin + execute_CsrPlugin_illegalAccess = 1'b0; + end end - if(execute_CsrPlugin_csr_1) begin - execute_CsrPlugin_illegalAccess = 1'b0; + if(execute_CsrPlugin_csr_3072) begin + if(execute_CSR_READ_OPCODE) begin + execute_CsrPlugin_illegalAccess = 1'b0; + end end - if(execute_CsrPlugin_csr_256) begin - execute_CsrPlugin_illegalAccess = 1'b0; + if(execute_CsrPlugin_csr_3200) begin + if(execute_CSR_READ_OPCODE) begin + execute_CsrPlugin_illegalAccess = 1'b0; + end end if(CsrPlugin_csrMapping_allowCsrSignal) begin execute_CsrPlugin_illegalAccess = 1'b0; @@ -4451,34 +3504,28 @@ module VexRiscv ( assign when_CsrPlugin_l1189 = (execute_arbitration_isValid && execute_IS_CSR); assign when_CsrPlugin_l1193 = (execute_arbitration_isValid && (execute_IS_CSR || 1'b0)); assign execute_CsrPlugin_csrAddress = execute_INSTRUCTION[31 : 20]; - assign _zz_decode_BRANCH_CTRL_3 = ((decode_INSTRUCTION & 32'h00004050) == 32'h00004050); - assign _zz_decode_BRANCH_CTRL_4 = ((decode_INSTRUCTION & 32'h00000014) == 32'h00000014); - assign _zz_decode_BRANCH_CTRL_5 = ((decode_INSTRUCTION & 32'h00000008) == 32'h00000008); - assign _zz_decode_BRANCH_CTRL_6 = ((decode_INSTRUCTION & 32'h00000058) == 32'h0); - assign _zz_decode_BRANCH_CTRL_7 = ((decode_INSTRUCTION & 32'h00002004) == 32'h00000004); - assign _zz_decode_BRANCH_CTRL_8 = ((decode_INSTRUCTION & 32'h90000010) == 32'h80000010); - assign _zz_decode_BRANCH_CTRL_9 = ((decode_INSTRUCTION & 32'h00000028) == 32'h00000028); - assign _zz_decode_BRANCH_CTRL_10 = ((decode_INSTRUCTION & 32'h00000070) == 32'h00000010); - assign _zz_decode_BRANCH_CTRL_11 = ((decode_INSTRUCTION & 32'h00000004) == 32'h00000004); - assign _zz_decode_BRANCH_CTRL_12 = ((decode_INSTRUCTION & 32'h00000020) == 32'h00000020); - assign _zz_decode_BRANCH_CTRL_13 = ((decode_INSTRUCTION & 32'h00001000) == 32'h0); - assign _zz_decode_BRANCH_CTRL_2 = {(|{_zz_decode_BRANCH_CTRL_9,(_zz__zz_decode_BRANCH_CTRL_2 == _zz__zz_decode_BRANCH_CTRL_2_1)}),{(|(_zz__zz_decode_BRANCH_CTRL_2_2 == _zz__zz_decode_BRANCH_CTRL_2_3)),{(|{_zz__zz_decode_BRANCH_CTRL_2_4,_zz__zz_decode_BRANCH_CTRL_2_6}),{(|_zz__zz_decode_BRANCH_CTRL_2_8),{_zz__zz_decode_BRANCH_CTRL_2_13,{_zz__zz_decode_BRANCH_CTRL_2_15,_zz__zz_decode_BRANCH_CTRL_2_24}}}}}}; - assign _zz_decode_SRC1_CTRL_2 = _zz_decode_BRANCH_CTRL_2[1 : 0]; + assign _zz_decode_SHIFT_CTRL_3 = ((decode_INSTRUCTION & 32'h00004050) == 32'h00004050); + assign _zz_decode_SHIFT_CTRL_4 = ((decode_INSTRUCTION & 32'h00000018) == 32'h0); + assign _zz_decode_SHIFT_CTRL_5 = ((decode_INSTRUCTION & 32'h00000004) == 32'h00000004); + assign _zz_decode_SHIFT_CTRL_6 = ((decode_INSTRUCTION & 32'h00000048) == 32'h00000048); + assign _zz_decode_SHIFT_CTRL_7 = ((decode_INSTRUCTION & 32'h00000030) == 32'h00000010); + assign _zz_decode_SHIFT_CTRL_8 = ((decode_INSTRUCTION & 32'h10003050) == 32'h00000050); + assign _zz_decode_SHIFT_CTRL_9 = ((decode_INSTRUCTION & 32'h00001000) == 32'h0); + assign _zz_decode_SHIFT_CTRL_2 = {(|{_zz_decode_SHIFT_CTRL_6,(_zz__zz_decode_SHIFT_CTRL_2 == _zz__zz_decode_SHIFT_CTRL_2_1)}),{(|(_zz__zz_decode_SHIFT_CTRL_2_2 == _zz__zz_decode_SHIFT_CTRL_2_3)),{(|{_zz__zz_decode_SHIFT_CTRL_2_4,_zz__zz_decode_SHIFT_CTRL_2_6}),{(|_zz__zz_decode_SHIFT_CTRL_2_8),{_zz__zz_decode_SHIFT_CTRL_2_13,{_zz__zz_decode_SHIFT_CTRL_2_14,_zz__zz_decode_SHIFT_CTRL_2_15}}}}}}; + assign _zz_decode_SRC1_CTRL_2 = _zz_decode_SHIFT_CTRL_2[1 : 0]; assign _zz_decode_SRC1_CTRL_1 = _zz_decode_SRC1_CTRL_2; - assign _zz_decode_ALU_CTRL_2 = _zz_decode_BRANCH_CTRL_2[6 : 5]; + assign _zz_decode_ALU_CTRL_2 = _zz_decode_SHIFT_CTRL_2[6 : 5]; assign _zz_decode_ALU_CTRL_1 = _zz_decode_ALU_CTRL_2; - assign _zz_decode_SRC2_CTRL_2 = _zz_decode_BRANCH_CTRL_2[8 : 7]; + assign _zz_decode_SRC2_CTRL_2 = _zz_decode_SHIFT_CTRL_2[8 : 7]; assign _zz_decode_SRC2_CTRL_1 = _zz_decode_SRC2_CTRL_2; - assign _zz_decode_ENV_CTRL_2 = _zz_decode_BRANCH_CTRL_2[18 : 17]; + assign _zz_decode_ENV_CTRL_2 = _zz_decode_SHIFT_CTRL_2[17 : 16]; assign _zz_decode_ENV_CTRL_1 = _zz_decode_ENV_CTRL_2; - assign _zz_decode_ALU_BITWISE_CTRL_2 = _zz_decode_BRANCH_CTRL_2[21 : 20]; + assign _zz_decode_ALU_BITWISE_CTRL_2 = _zz_decode_SHIFT_CTRL_2[21 : 20]; assign _zz_decode_ALU_BITWISE_CTRL_1 = _zz_decode_ALU_BITWISE_CTRL_2; - assign _zz_decode_FPU_OPCODE_2 = _zz_decode_BRANCH_CTRL_2[33 : 30]; - assign _zz_decode_FPU_OPCODE_1 = _zz_decode_FPU_OPCODE_2; - assign _zz_decode_SHIFT_CTRL_2 = _zz_decode_BRANCH_CTRL_2[38 : 37]; - assign _zz_decode_SHIFT_CTRL_1 = _zz_decode_SHIFT_CTRL_2; - assign _zz_decode_BRANCH_CTRL_14 = _zz_decode_BRANCH_CTRL_2[40 : 39]; - assign _zz_decode_BRANCH_CTRL_1 = _zz_decode_BRANCH_CTRL_14; + assign _zz_decode_SHIFT_CTRL_10 = _zz_decode_SHIFT_CTRL_2[28 : 27]; + assign _zz_decode_SHIFT_CTRL_1 = _zz_decode_SHIFT_CTRL_10; + assign _zz_decode_BRANCH_CTRL_2 = _zz_decode_SHIFT_CTRL_2[30 : 29]; + assign _zz_decode_BRANCH_CTRL = _zz_decode_BRANCH_CTRL_2; assign decodeExceptionPort_valid = (decode_arbitration_isValid && (! decode_LEGAL_INSTRUCTION)); assign decodeExceptionPort_payload_code = 4'b0010; assign decodeExceptionPort_payload_badAddr = decode_INSTRUCTION; @@ -4502,7 +3549,7 @@ module VexRiscv ( end always @(*) begin - lastStageRegFileWrite_payload_data = _zz_lastStageRegFileWrite_payload_data; + lastStageRegFileWrite_payload_data = _zz_decode_RS2_2; if(_zz_2) begin lastStageRegFileWrite_payload_data = 32'h0; end @@ -4716,87 +3763,6 @@ module VexRiscv ( _zz_memory_DivPlugin_rs1_1[31 : 0] = execute_RS1; end - assign FpuPlugin_port_cmd_ready = FpuPlugin_fpu_io_port_0_cmd_ready; - assign FpuPlugin_port_commit_ready = FpuPlugin_fpu_io_port_0_commit_ready; - assign FpuPlugin_port_rsp_valid = FpuPlugin_fpu_io_port_0_rsp_valid; - assign FpuPlugin_port_rsp_payload_value = FpuPlugin_fpu_io_port_0_rsp_payload_value; - assign FpuPlugin_port_rsp_payload_NV = FpuPlugin_fpu_io_port_0_rsp_payload_NV; - assign FpuPlugin_port_rsp_payload_NX = FpuPlugin_fpu_io_port_0_rsp_payload_NX; - assign FpuPlugin_port_completion_valid = FpuPlugin_fpu_io_port_0_completion_valid; - assign FpuPlugin_port_completion_payload_flags_NX = FpuPlugin_fpu_io_port_0_completion_payload_flags_NX; - assign FpuPlugin_port_completion_payload_flags_UF = FpuPlugin_fpu_io_port_0_completion_payload_flags_UF; - assign FpuPlugin_port_completion_payload_flags_OF = FpuPlugin_fpu_io_port_0_completion_payload_flags_OF; - assign FpuPlugin_port_completion_payload_flags_DZ = FpuPlugin_fpu_io_port_0_completion_payload_flags_DZ; - assign FpuPlugin_port_completion_payload_flags_NV = FpuPlugin_fpu_io_port_0_completion_payload_flags_NV; - assign FpuPlugin_port_completion_payload_written = FpuPlugin_fpu_io_port_0_completion_payload_written; - assign FpuPlugin_port_cmd_fire = (FpuPlugin_port_cmd_valid && FpuPlugin_port_cmd_ready); - assign FpuPlugin_port_rsp_fire = (FpuPlugin_port_rsp_valid && FpuPlugin_port_rsp_ready); - assign FpuPlugin_hasPending = (FpuPlugin_pendings != 6'h0); - assign when_FpuPlugin_l199 = (FpuPlugin_port_completion_valid && FpuPlugin_port_completion_payload_flags_NV); - assign when_FpuPlugin_l200 = (FpuPlugin_port_completion_valid && FpuPlugin_port_completion_payload_flags_DZ); - assign when_FpuPlugin_l201 = (FpuPlugin_port_completion_valid && FpuPlugin_port_completion_payload_flags_OF); - assign when_FpuPlugin_l202 = (FpuPlugin_port_completion_valid && FpuPlugin_port_completion_payload_flags_UF); - assign when_FpuPlugin_l203 = (FpuPlugin_port_completion_valid && FpuPlugin_port_completion_payload_flags_NX); - assign FpuPlugin_csrActive = (execute_arbitration_isValid && execute_IS_CSR); - assign when_FpuPlugin_l214 = (FpuPlugin_csrActive && FpuPlugin_hasPending); - assign FpuPlugin_sd = (FpuPlugin_fs == 2'b11); - assign when_FpuPlugin_l219 = ((writeBack_arbitration_isFiring && writeBack_FPU_ENABLE) && (writeBack_FPU_OPCODE != FpuOpcode_STORE)); - assign FpuPlugin_port_cmd_fire_1 = (FpuPlugin_port_cmd_valid && FpuPlugin_port_cmd_ready); - assign when_FpuPlugin_l234 = (! decode_arbitration_isStuck); - assign decode_FpuPlugin_hazard = (FpuPlugin_pendings[5] || FpuPlugin_csrActive); - assign when_FpuPlugin_l238 = ((decode_arbitration_isValid && decode_FPU_ENABLE) && decode_FpuPlugin_hazard); - assign FpuPlugin_port_cmd_isStall = (FpuPlugin_port_cmd_valid && (! FpuPlugin_port_cmd_ready)); - assign decode_FpuPlugin_iRoundMode = decode_INSTRUCTION[14 : 12]; - assign decode_FpuPlugin_roundMode = ((decode_INSTRUCTION[14 : 12] == 3'b111) ? FpuPlugin_rm : decode_INSTRUCTION[14 : 12]); - assign FpuPlugin_port_cmd_valid = (((decode_arbitration_isValid && decode_FPU_ENABLE) && (! decode_FpuPlugin_forked)) && (! decode_FpuPlugin_hazard)); - assign FpuPlugin_port_cmd_payload_opcode = decode_FPU_OPCODE; - assign FpuPlugin_port_cmd_payload_arg = decode_FPU_ARG; - assign FpuPlugin_port_cmd_payload_rs1 = decode_INSTRUCTION[19 : 15]; - assign FpuPlugin_port_cmd_payload_rs2 = decode_INSTRUCTION[24 : 20]; - assign FpuPlugin_port_cmd_payload_rs3 = decode_INSTRUCTION[31 : 27]; - assign FpuPlugin_port_cmd_payload_rd = decode_INSTRUCTION[11 : 7]; - assign FpuPlugin_port_cmd_payload_format = FpuFormat_FLOAT; - assign _zz_FpuPlugin_port_cmd_payload_roundMode_1 = decode_FpuPlugin_roundMode; - assign _zz_FpuPlugin_port_cmd_payload_roundMode = _zz_FpuPlugin_port_cmd_payload_roundMode_1; - assign FpuPlugin_port_cmd_payload_roundMode = _zz_FpuPlugin_port_cmd_payload_roundMode; - assign FpuPlugin_port_cmd_fire_2 = (FpuPlugin_port_cmd_valid && FpuPlugin_port_cmd_ready); - assign writeBack_FpuPlugin_isRsp = (writeBack_FPU_FORKED && writeBack_FPU_RSP); - assign writeBack_FpuPlugin_isCommit = (writeBack_FPU_FORKED && writeBack_FPU_COMMIT); - assign writeBack_FpuPlugin_storeFormated = FpuPlugin_port_rsp_payload_value; - always @(*) begin - FpuPlugin_port_rsp_ready = 1'b0; - if(writeBack_FpuPlugin_isRsp) begin - if(!when_FpuPlugin_l285) begin - if(when_FpuPlugin_l287) begin - FpuPlugin_port_rsp_ready = 1'b1; - end - end - end - end - - assign DBusBypass0_value = writeBack_FpuPlugin_storeFormated; - assign when_FpuPlugin_l280 = ((! writeBack_arbitration_isStuck) && (! writeBack_arbitration_removeIt)); - assign when_FpuPlugin_l285 = (! FpuPlugin_port_rsp_valid); - assign when_FpuPlugin_l287 = (! writeBack_arbitration_haltItself); - assign writeBack_FpuPlugin_commit_valid = (writeBack_FpuPlugin_isCommit && (! writeBack_arbitration_isStuck)); - assign writeBack_FpuPlugin_commit_payload_value[31 : 0] = (writeBack_FPU_COMMIT_LOAD ? writeBack_MEMORY_LOAD_DATA[31 : 0] : writeBack_RS1); - assign writeBack_FpuPlugin_commit_payload_write = (writeBack_arbitration_isValid && (! writeBack_arbitration_removeIt)); - assign writeBack_FpuPlugin_commit_payload_opcode = writeBack_FPU_OPCODE; - assign writeBack_FpuPlugin_commit_payload_rd = writeBack_INSTRUCTION[11 : 7]; - assign when_FpuPlugin_l301 = (writeBack_FpuPlugin_isCommit && (! writeBack_FpuPlugin_commit_ready)); - assign writeBack_FpuPlugin_commit_ready = (! writeBack_FpuPlugin_commit_rValid); - assign writeBack_FpuPlugin_commit_s2mPipe_valid = (writeBack_FpuPlugin_commit_valid || writeBack_FpuPlugin_commit_rValid); - assign _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode = (writeBack_FpuPlugin_commit_rValid ? writeBack_FpuPlugin_commit_rData_opcode : writeBack_FpuPlugin_commit_payload_opcode); - assign writeBack_FpuPlugin_commit_s2mPipe_payload_opcode = _zz_writeBack_FpuPlugin_commit_s2mPipe_payload_opcode; - assign writeBack_FpuPlugin_commit_s2mPipe_payload_rd = (writeBack_FpuPlugin_commit_rValid ? writeBack_FpuPlugin_commit_rData_rd : writeBack_FpuPlugin_commit_payload_rd); - assign writeBack_FpuPlugin_commit_s2mPipe_payload_write = (writeBack_FpuPlugin_commit_rValid ? writeBack_FpuPlugin_commit_rData_write : writeBack_FpuPlugin_commit_payload_write); - assign writeBack_FpuPlugin_commit_s2mPipe_payload_value = (writeBack_FpuPlugin_commit_rValid ? writeBack_FpuPlugin_commit_rData_value : writeBack_FpuPlugin_commit_payload_value); - assign FpuPlugin_port_commit_valid = writeBack_FpuPlugin_commit_s2mPipe_valid; - assign writeBack_FpuPlugin_commit_s2mPipe_ready = FpuPlugin_port_commit_ready; - assign FpuPlugin_port_commit_payload_opcode = writeBack_FpuPlugin_commit_s2mPipe_payload_opcode; - assign FpuPlugin_port_commit_payload_rd = writeBack_FpuPlugin_commit_s2mPipe_payload_rd; - assign FpuPlugin_port_commit_payload_write = writeBack_FpuPlugin_commit_s2mPipe_payload_write; - assign FpuPlugin_port_commit_payload_value = writeBack_FpuPlugin_commit_s2mPipe_payload_value; assign execute_LightShifterPlugin_isShift = (execute_SHIFT_CTRL != ShiftCtrlEnum_DISABLE_1); assign execute_LightShifterPlugin_amplitude = (execute_LightShifterPlugin_isActive ? execute_LightShifterPlugin_amplitudeReg : execute_SRC2[4 : 0]); assign execute_LightShifterPlugin_shiftInput = (execute_LightShifterPlugin_isActive ? memory_REGFILE_WRITE_DATA : execute_SRC1); @@ -4805,10 +3771,10 @@ module VexRiscv ( always @(*) begin case(execute_SHIFT_CTRL) ShiftCtrlEnum_SLL_1 : begin - _zz_execute_to_memory_REGFILE_WRITE_DATA_1 = (execute_LightShifterPlugin_shiftInput <<< 1); + _zz_decode_RS2_3 = (execute_LightShifterPlugin_shiftInput <<< 1); end default : begin - _zz_execute_to_memory_REGFILE_WRITE_DATA_1 = _zz__zz_execute_to_memory_REGFILE_WRITE_DATA_1; + _zz_decode_RS2_3 = _zz__zz_decode_RS2_3; end endcase end @@ -4817,28 +3783,23 @@ module VexRiscv ( assign when_ShiftPlugins_l184 = (! execute_LightShifterPlugin_done); always @(*) begin HazardSimplePlugin_src0Hazard = 1'b0; - if(HazardSimplePlugin_writeBackBuffer_valid) begin - if(HazardSimplePlugin_addr0Match) begin - HazardSimplePlugin_src0Hazard = 1'b1; - end - end if(when_HazardSimplePlugin_l57) begin if(when_HazardSimplePlugin_l58) begin - if(when_HazardSimplePlugin_l59) begin + if(when_HazardSimplePlugin_l48) begin HazardSimplePlugin_src0Hazard = 1'b1; end end end if(when_HazardSimplePlugin_l57_1) begin if(when_HazardSimplePlugin_l58_1) begin - if(when_HazardSimplePlugin_l59_1) begin + if(when_HazardSimplePlugin_l48_1) begin HazardSimplePlugin_src0Hazard = 1'b1; end end end if(when_HazardSimplePlugin_l57_2) begin if(when_HazardSimplePlugin_l58_2) begin - if(when_HazardSimplePlugin_l59_2) begin + if(when_HazardSimplePlugin_l48_2) begin HazardSimplePlugin_src0Hazard = 1'b1; end end @@ -4850,28 +3811,23 @@ module VexRiscv ( always @(*) begin HazardSimplePlugin_src1Hazard = 1'b0; - if(HazardSimplePlugin_writeBackBuffer_valid) begin - if(HazardSimplePlugin_addr1Match) begin - HazardSimplePlugin_src1Hazard = 1'b1; - end - end if(when_HazardSimplePlugin_l57) begin if(when_HazardSimplePlugin_l58) begin - if(when_HazardSimplePlugin_l62) begin + if(when_HazardSimplePlugin_l51) begin HazardSimplePlugin_src1Hazard = 1'b1; end end end if(when_HazardSimplePlugin_l57_1) begin if(when_HazardSimplePlugin_l58_1) begin - if(when_HazardSimplePlugin_l62_1) begin + if(when_HazardSimplePlugin_l51_1) begin HazardSimplePlugin_src1Hazard = 1'b1; end end end if(when_HazardSimplePlugin_l57_2) begin if(when_HazardSimplePlugin_l58_2) begin - if(when_HazardSimplePlugin_l62_2) begin + if(when_HazardSimplePlugin_l51_2) begin HazardSimplePlugin_src1Hazard = 1'b1; end end @@ -4883,21 +3839,25 @@ module VexRiscv ( assign HazardSimplePlugin_writeBackWrites_valid = (_zz_lastStageRegFileWrite_valid && writeBack_arbitration_isFiring); assign HazardSimplePlugin_writeBackWrites_payload_address = _zz_lastStageRegFileWrite_payload_address[11 : 7]; - assign HazardSimplePlugin_writeBackWrites_payload_data = _zz_lastStageRegFileWrite_payload_data; + assign HazardSimplePlugin_writeBackWrites_payload_data = _zz_decode_RS2_2; assign HazardSimplePlugin_addr0Match = (HazardSimplePlugin_writeBackBuffer_payload_address == decode_INSTRUCTION[19 : 15]); assign HazardSimplePlugin_addr1Match = (HazardSimplePlugin_writeBackBuffer_payload_address == decode_INSTRUCTION[24 : 20]); - assign when_HazardSimplePlugin_l59 = (writeBack_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); - assign when_HazardSimplePlugin_l62 = (writeBack_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l47 = 1'b1; + assign when_HazardSimplePlugin_l48 = (writeBack_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); + assign when_HazardSimplePlugin_l51 = (writeBack_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l45 = (writeBack_arbitration_isValid && writeBack_REGFILE_WRITE_VALID); assign when_HazardSimplePlugin_l57 = (writeBack_arbitration_isValid && writeBack_REGFILE_WRITE_VALID); - assign when_HazardSimplePlugin_l58 = (1'b1 || (! 1'b1)); - assign when_HazardSimplePlugin_l59_1 = (memory_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); - assign when_HazardSimplePlugin_l62_1 = (memory_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l58 = (1'b0 || (! when_HazardSimplePlugin_l47)); + assign when_HazardSimplePlugin_l48_1 = (memory_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); + assign when_HazardSimplePlugin_l51_1 = (memory_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l45_1 = (memory_arbitration_isValid && memory_REGFILE_WRITE_VALID); assign when_HazardSimplePlugin_l57_1 = (memory_arbitration_isValid && memory_REGFILE_WRITE_VALID); - assign when_HazardSimplePlugin_l58_1 = (1'b1 || (! memory_BYPASSABLE_MEMORY_STAGE)); - assign when_HazardSimplePlugin_l59_2 = (execute_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); - assign when_HazardSimplePlugin_l62_2 = (execute_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l58_1 = (1'b0 || (! memory_BYPASSABLE_MEMORY_STAGE)); + assign when_HazardSimplePlugin_l48_2 = (execute_INSTRUCTION[11 : 7] == decode_INSTRUCTION[19 : 15]); + assign when_HazardSimplePlugin_l51_2 = (execute_INSTRUCTION[11 : 7] == decode_INSTRUCTION[24 : 20]); + assign when_HazardSimplePlugin_l45_2 = (execute_arbitration_isValid && execute_REGFILE_WRITE_VALID); assign when_HazardSimplePlugin_l57_2 = (execute_arbitration_isValid && execute_REGFILE_WRITE_VALID); - assign when_HazardSimplePlugin_l58_2 = (1'b1 || (! execute_BYPASSABLE_EXECUTE_STAGE)); + assign when_HazardSimplePlugin_l58_2 = (1'b0 || (! execute_BYPASSABLE_EXECUTE_STAGE)); assign when_HazardSimplePlugin_l105 = (! decode_RS1_USE); assign when_HazardSimplePlugin_l108 = (! decode_RS2_USE); assign when_HazardSimplePlugin_l113 = (decode_arbitration_isValid && (HazardSimplePlugin_src0Hazard || HazardSimplePlugin_src1Hazard)); @@ -4906,16 +3866,16 @@ module VexRiscv ( always @(*) begin casez(switch_Misc_l210_4) 3'b000 : begin - _zz_execute_BRANCH_DO = execute_BranchPlugin_eq; + _zz_execute_BRANCH_COND_RESULT = execute_BranchPlugin_eq; end 3'b001 : begin - _zz_execute_BRANCH_DO = (! execute_BranchPlugin_eq); + _zz_execute_BRANCH_COND_RESULT = (! execute_BranchPlugin_eq); end 3'b1?1 : begin - _zz_execute_BRANCH_DO = (! execute_SRC_LESS); + _zz_execute_BRANCH_COND_RESULT = (! execute_SRC_LESS); end default : begin - _zz_execute_BRANCH_DO = execute_SRC_LESS; + _zz_execute_BRANCH_COND_RESULT = execute_SRC_LESS; end endcase end @@ -4923,23 +3883,43 @@ module VexRiscv ( always @(*) begin case(execute_BRANCH_CTRL) BranchCtrlEnum_INC : begin - _zz_execute_BRANCH_DO_1 = 1'b0; + _zz_execute_BRANCH_COND_RESULT_1 = 1'b0; end BranchCtrlEnum_JAL : begin - _zz_execute_BRANCH_DO_1 = 1'b1; + _zz_execute_BRANCH_COND_RESULT_1 = 1'b1; + end + BranchCtrlEnum_JALR : begin + _zz_execute_BRANCH_COND_RESULT_1 = 1'b1; + end + default : begin + _zz_execute_BRANCH_COND_RESULT_1 = _zz_execute_BRANCH_COND_RESULT; end + endcase + end + + assign execute_BranchPlugin_missAlignedTarget = 1'b0; + always @(*) begin + case(execute_BRANCH_CTRL) BranchCtrlEnum_JALR : begin - _zz_execute_BRANCH_DO_1 = 1'b1; + execute_BranchPlugin_branch_src1 = execute_RS1; end default : begin - _zz_execute_BRANCH_DO_1 = _zz_execute_BRANCH_DO; + execute_BranchPlugin_branch_src1 = execute_PC; end endcase end - assign execute_BranchPlugin_branch_src1 = ((execute_BRANCH_CTRL == BranchCtrlEnum_JALR) ? execute_RS1 : execute_PC); - assign _zz_execute_BranchPlugin_branch_src2 = _zz__zz_execute_BranchPlugin_branch_src2[19]; + assign _zz_execute_BranchPlugin_branch_src2 = execute_INSTRUCTION[31]; always @(*) begin + _zz_execute_BranchPlugin_branch_src2_1[19] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[18] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[17] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[16] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[15] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[14] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[13] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[12] = _zz_execute_BranchPlugin_branch_src2; + _zz_execute_BranchPlugin_branch_src2_1[11] = _zz_execute_BranchPlugin_branch_src2; _zz_execute_BranchPlugin_branch_src2_1[10] = _zz_execute_BranchPlugin_branch_src2; _zz_execute_BranchPlugin_branch_src2_1[9] = _zz_execute_BranchPlugin_branch_src2; _zz_execute_BranchPlugin_branch_src2_1[8] = _zz_execute_BranchPlugin_branch_src2; @@ -4953,17 +3933,22 @@ module VexRiscv ( _zz_execute_BranchPlugin_branch_src2_1[0] = _zz_execute_BranchPlugin_branch_src2; end - assign _zz_execute_BranchPlugin_branch_src2_2 = execute_INSTRUCTION[31]; always @(*) begin - _zz_execute_BranchPlugin_branch_src2_3[19] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[18] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[17] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[16] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[15] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[14] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[13] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[12] = _zz_execute_BranchPlugin_branch_src2_2; - _zz_execute_BranchPlugin_branch_src2_3[11] = _zz_execute_BranchPlugin_branch_src2_2; + case(execute_BRANCH_CTRL) + BranchCtrlEnum_JALR : begin + execute_BranchPlugin_branch_src2 = {_zz_execute_BranchPlugin_branch_src2_1,execute_INSTRUCTION[31 : 20]}; + end + default : begin + execute_BranchPlugin_branch_src2 = ((execute_BRANCH_CTRL == BranchCtrlEnum_JAL) ? {{_zz_execute_BranchPlugin_branch_src2_3,{{{_zz_execute_BranchPlugin_branch_src2_6,execute_INSTRUCTION[19 : 12]},execute_INSTRUCTION[20]},execute_INSTRUCTION[30 : 21]}},1'b0} : {{_zz_execute_BranchPlugin_branch_src2_5,{{{_zz_execute_BranchPlugin_branch_src2_7,_zz_execute_BranchPlugin_branch_src2_8},execute_INSTRUCTION[30 : 25]},execute_INSTRUCTION[11 : 8]}},1'b0}); + if(execute_PREDICTION_HAD_BRANCHED2) begin + execute_BranchPlugin_branch_src2 = {29'd0, _zz_execute_BranchPlugin_branch_src2_9}; + end + end + endcase + end + + assign _zz_execute_BranchPlugin_branch_src2_2 = _zz__zz_execute_BranchPlugin_branch_src2_2[19]; + always @(*) begin _zz_execute_BranchPlugin_branch_src2_3[10] = _zz_execute_BranchPlugin_branch_src2_2; _zz_execute_BranchPlugin_branch_src2_3[9] = _zz_execute_BranchPlugin_branch_src2_2; _zz_execute_BranchPlugin_branch_src2_3[8] = _zz_execute_BranchPlugin_branch_src2_2; @@ -5000,24 +3985,69 @@ module VexRiscv ( _zz_execute_BranchPlugin_branch_src2_5[0] = _zz_execute_BranchPlugin_branch_src2_4; end - always @(*) begin - case(execute_BRANCH_CTRL) - BranchCtrlEnum_JAL : begin - _zz_execute_BranchPlugin_branch_src2_6 = {{_zz_execute_BranchPlugin_branch_src2_1,{{{execute_INSTRUCTION[31],execute_INSTRUCTION[19 : 12]},execute_INSTRUCTION[20]},execute_INSTRUCTION[30 : 21]}},1'b0}; - end - BranchCtrlEnum_JALR : begin - _zz_execute_BranchPlugin_branch_src2_6 = {_zz_execute_BranchPlugin_branch_src2_3,execute_INSTRUCTION[31 : 20]}; - end - default : begin - _zz_execute_BranchPlugin_branch_src2_6 = {{_zz_execute_BranchPlugin_branch_src2_5,{{{execute_INSTRUCTION[31],execute_INSTRUCTION[7]},execute_INSTRUCTION[30 : 25]},execute_INSTRUCTION[11 : 8]}},1'b0}; - end - endcase - end - - assign execute_BranchPlugin_branch_src2 = _zz_execute_BranchPlugin_branch_src2_6; assign execute_BranchPlugin_branchAdder = (execute_BranchPlugin_branch_src1 + execute_BranchPlugin_branch_src2); assign BranchPlugin_jumpInterface_valid = ((memory_arbitration_isValid && memory_BRANCH_DO) && (! 1'b0)); assign BranchPlugin_jumpInterface_payload = memory_BRANCH_CALC; + assign IBusSimplePlugin_decodePrediction_rsp_wasWrong = BranchPlugin_jumpInterface_valid; + assign when_DebugPlugin_l225 = (DebugPlugin_haltIt && (! DebugPlugin_isPipBusy)); + assign DebugPlugin_allowEBreak = (DebugPlugin_debugUsed && (! DebugPlugin_disableEbreak)); + always @(*) begin + debug_bus_cmd_ready = 1'b1; + if(debug_bus_cmd_valid) begin + case(switch_DebugPlugin_l267) + 6'h01 : begin + if(debug_bus_cmd_payload_wr) begin + debug_bus_cmd_ready = IBusSimplePlugin_injectionPort_ready; + end + end + default : begin + end + endcase + end + end + + always @(*) begin + debug_bus_rsp_data = DebugPlugin_busReadDataReg; + if(when_DebugPlugin_l244) begin + debug_bus_rsp_data[0] = DebugPlugin_resetIt; + debug_bus_rsp_data[1] = DebugPlugin_haltIt; + debug_bus_rsp_data[2] = DebugPlugin_isPipBusy; + debug_bus_rsp_data[3] = DebugPlugin_haltedByBreak; + debug_bus_rsp_data[4] = DebugPlugin_stepIt; + end + end + + assign when_DebugPlugin_l244 = (! _zz_when_DebugPlugin_l244); + always @(*) begin + IBusSimplePlugin_injectionPort_valid = 1'b0; + if(debug_bus_cmd_valid) begin + case(switch_DebugPlugin_l267) + 6'h01 : begin + if(debug_bus_cmd_payload_wr) begin + IBusSimplePlugin_injectionPort_valid = 1'b1; + end + end + default : begin + end + endcase + end + end + + assign IBusSimplePlugin_injectionPort_payload = debug_bus_cmd_payload_data; + assign switch_DebugPlugin_l267 = debug_bus_cmd_payload_address[7 : 2]; + assign when_DebugPlugin_l271 = debug_bus_cmd_payload_data[16]; + assign when_DebugPlugin_l271_1 = debug_bus_cmd_payload_data[24]; + assign when_DebugPlugin_l272 = debug_bus_cmd_payload_data[17]; + assign when_DebugPlugin_l272_1 = debug_bus_cmd_payload_data[25]; + assign when_DebugPlugin_l273 = debug_bus_cmd_payload_data[25]; + assign when_DebugPlugin_l274 = debug_bus_cmd_payload_data[25]; + assign when_DebugPlugin_l275 = debug_bus_cmd_payload_data[18]; + assign when_DebugPlugin_l275_1 = debug_bus_cmd_payload_data[26]; + assign when_DebugPlugin_l295 = (execute_arbitration_isValid && execute_DO_EBREAK); + assign when_DebugPlugin_l298 = (({writeBack_arbitration_isValid,memory_arbitration_isValid} != 2'b00) == 1'b0); + assign when_DebugPlugin_l311 = (DebugPlugin_stepIt && IBusSimplePlugin_incomingInstruction); + assign debug_resetOut = DebugPlugin_resetIt_regNext; + assign when_DebugPlugin_l331 = (DebugPlugin_haltIt || DebugPlugin_stepIt); assign when_Pipeline_l124 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_1 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_2 = ((! writeBack_arbitration_isStuck) && (! CsrPlugin_exceptionPortCtrl_exceptionValids_writeBack)); @@ -5025,9 +4055,9 @@ module VexRiscv ( assign when_Pipeline_l124_4 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_5 = (! writeBack_arbitration_isStuck); assign when_Pipeline_l124_6 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_7 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_8 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_9 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_7 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_8 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_9 = (! writeBack_arbitration_isStuck); assign when_Pipeline_l124_10 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_11 = (! execute_arbitration_isStuck); assign _zz_decode_SRC1_CTRL = _zz_decode_SRC1_CTRL_1; @@ -5048,83 +4078,58 @@ module VexRiscv ( assign when_Pipeline_l124_22 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_23 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_24 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_25 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_26 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_27 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_25 = (! execute_arbitration_isStuck); assign _zz_decode_to_execute_ENV_CTRL_1 = decode_ENV_CTRL; assign _zz_execute_to_memory_ENV_CTRL_1 = execute_ENV_CTRL; assign _zz_memory_to_writeBack_ENV_CTRL_1 = memory_ENV_CTRL; assign _zz_decode_ENV_CTRL = _zz_decode_ENV_CTRL_1; - assign when_Pipeline_l124_28 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_26 = (! execute_arbitration_isStuck); assign _zz_execute_ENV_CTRL = decode_to_execute_ENV_CTRL; - assign when_Pipeline_l124_29 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_27 = (! memory_arbitration_isStuck); assign _zz_memory_ENV_CTRL = execute_to_memory_ENV_CTRL; - assign when_Pipeline_l124_30 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_28 = (! writeBack_arbitration_isStuck); assign _zz_writeBack_ENV_CTRL = memory_to_writeBack_ENV_CTRL; - assign when_Pipeline_l124_31 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_29 = (! execute_arbitration_isStuck); assign _zz_decode_to_execute_ALU_BITWISE_CTRL_1 = decode_ALU_BITWISE_CTRL; assign _zz_decode_ALU_BITWISE_CTRL = _zz_decode_ALU_BITWISE_CTRL_1; - assign when_Pipeline_l124_32 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_30 = (! execute_arbitration_isStuck); assign _zz_execute_ALU_BITWISE_CTRL = decode_to_execute_ALU_BITWISE_CTRL; - assign when_Pipeline_l124_33 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_34 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_35 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_31 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_32 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_33 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_34 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_35 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_36 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_37 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_37 = (! execute_arbitration_isStuck); + assign _zz_decode_to_execute_SHIFT_CTRL_1 = decode_SHIFT_CTRL; + assign _zz_decode_SHIFT_CTRL = _zz_decode_SHIFT_CTRL_1; assign when_Pipeline_l124_38 = (! execute_arbitration_isStuck); + assign _zz_execute_SHIFT_CTRL = decode_to_execute_SHIFT_CTRL; + assign _zz_decode_to_execute_BRANCH_CTRL_1 = decode_BRANCH_CTRL; + assign _zz_decode_BRANCH_CTRL_1 = _zz_decode_BRANCH_CTRL; assign when_Pipeline_l124_39 = (! execute_arbitration_isStuck); + assign _zz_execute_BRANCH_CTRL = decode_to_execute_BRANCH_CTRL; assign when_Pipeline_l124_40 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_41 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_42 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_41 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_42 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_43 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_44 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_45 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_44 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_45 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_46 = (! execute_arbitration_isStuck); assign when_Pipeline_l124_47 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_48 = (! writeBack_arbitration_isStuck); - assign _zz_decode_to_execute_FPU_OPCODE_1 = decode_FPU_OPCODE; - assign _zz_execute_to_memory_FPU_OPCODE_1 = execute_FPU_OPCODE; - assign _zz_memory_to_writeBack_FPU_OPCODE_1 = memory_FPU_OPCODE; - assign _zz_decode_FPU_OPCODE = _zz_decode_FPU_OPCODE_1; - assign when_Pipeline_l124_49 = (! execute_arbitration_isStuck); - assign _zz_execute_FPU_OPCODE = decode_to_execute_FPU_OPCODE; - assign when_Pipeline_l124_50 = (! memory_arbitration_isStuck); - assign _zz_memory_FPU_OPCODE = execute_to_memory_FPU_OPCODE; + assign when_Pipeline_l124_48 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_49 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_50 = ((! memory_arbitration_isStuck) && (! execute_arbitration_isStuckByOthers)); assign when_Pipeline_l124_51 = (! writeBack_arbitration_isStuck); - assign _zz_writeBack_FPU_OPCODE = memory_to_writeBack_FPU_OPCODE; - assign _zz_decode_to_execute_SHIFT_CTRL_1 = decode_SHIFT_CTRL; - assign _zz_decode_SHIFT_CTRL = _zz_decode_SHIFT_CTRL_1; - assign when_Pipeline_l124_52 = (! execute_arbitration_isStuck); - assign _zz_execute_SHIFT_CTRL = decode_to_execute_SHIFT_CTRL; - assign _zz_decode_to_execute_BRANCH_CTRL_1 = decode_BRANCH_CTRL; - assign _zz_decode_BRANCH_CTRL = _zz_decode_BRANCH_CTRL_1; - assign when_Pipeline_l124_53 = (! execute_arbitration_isStuck); - assign _zz_execute_BRANCH_CTRL = decode_to_execute_BRANCH_CTRL; - assign when_Pipeline_l124_54 = (! execute_arbitration_isStuck); + assign when_Pipeline_l124_52 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_53 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_54 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_55 = (! memory_arbitration_isStuck); assign when_Pipeline_l124_56 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_57 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_58 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_59 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_60 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_61 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_62 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_63 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_64 = (! execute_arbitration_isStuck); - assign when_Pipeline_l124_65 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_66 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_67 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_68 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_69 = ((! memory_arbitration_isStuck) && (! execute_arbitration_isStuckByOthers)); - assign when_Pipeline_l124_70 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_71 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_72 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_73 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_74 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_75 = (! writeBack_arbitration_isStuck); - assign when_Pipeline_l124_76 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_77 = (! memory_arbitration_isStuck); - assign when_Pipeline_l124_78 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_57 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_58 = (! memory_arbitration_isStuck); + assign when_Pipeline_l124_59 = (! writeBack_arbitration_isStuck); + assign when_Pipeline_l124_60 = (! writeBack_arbitration_isStuck); assign decode_arbitration_isFlushed = (({writeBack_arbitration_flushNext,{memory_arbitration_flushNext,execute_arbitration_flushNext}} != 3'b000) || ({writeBack_arbitration_flushIt,{memory_arbitration_flushIt,{execute_arbitration_flushIt,decode_arbitration_flushIt}}} != 4'b0000)); assign execute_arbitration_isFlushed = (({writeBack_arbitration_flushNext,memory_arbitration_flushNext} != 2'b00) || ({writeBack_arbitration_flushIt,{memory_arbitration_flushIt,execute_arbitration_flushIt}} != 3'b000)); assign memory_arbitration_isFlushed = ((writeBack_arbitration_flushNext != 1'b0) || ({writeBack_arbitration_flushIt,memory_arbitration_flushIt} != 2'b00)); @@ -5151,6 +4156,20 @@ module VexRiscv ( assign when_Pipeline_l154_1 = ((! execute_arbitration_isStuck) && (! execute_arbitration_removeIt)); assign when_Pipeline_l151_2 = ((! writeBack_arbitration_isStuck) || writeBack_arbitration_removeIt); assign when_Pipeline_l154_2 = ((! memory_arbitration_isStuck) && (! memory_arbitration_removeIt)); + always @(*) begin + IBusSimplePlugin_injectionPort_ready = 1'b0; + case(switch_Fetcher_l365) + 3'b100 : begin + IBusSimplePlugin_injectionPort_ready = 1'b1; + end + default : begin + end + endcase + end + + assign when_Fetcher_l363 = (switch_Fetcher_l365 != 3'b000); + assign when_Fetcher_l381 = (! decode_arbitration_isStuck); + assign when_Fetcher_l401 = (switch_Fetcher_l365 != 3'b000); assign when_CsrPlugin_l1277 = (! execute_arbitration_isStuck); assign when_CsrPlugin_l1277_1 = (! execute_arbitration_isStuck); assign when_CsrPlugin_l1277_2 = (! execute_arbitration_isStuck); @@ -5167,8 +4186,6 @@ module VexRiscv ( _zz_CsrPlugin_csrMapping_readDataInit[7 : 7] = CsrPlugin_mstatus_MPIE; _zz_CsrPlugin_csrMapping_readDataInit[3 : 3] = CsrPlugin_mstatus_MIE; _zz_CsrPlugin_csrMapping_readDataInit[12 : 11] = CsrPlugin_mstatus_MPP; - _zz_CsrPlugin_csrMapping_readDataInit[14 : 13] = FpuPlugin_fs; - _zz_CsrPlugin_csrMapping_readDataInit[31 : 31] = FpuPlugin_sd; end end @@ -5200,41 +4217,37 @@ module VexRiscv ( always @(*) begin _zz_CsrPlugin_csrMapping_readDataInit_4 = 32'h0; - if(execute_CsrPlugin_csr_834) begin - _zz_CsrPlugin_csrMapping_readDataInit_4[31 : 31] = CsrPlugin_mcause_interrupt; - _zz_CsrPlugin_csrMapping_readDataInit_4[3 : 0] = CsrPlugin_mcause_exceptionCode; + if(execute_CsrPlugin_csr_833) begin + _zz_CsrPlugin_csrMapping_readDataInit_4[31 : 0] = CsrPlugin_mepc; end end - assign _zz_FpuPlugin_flags_NX = CsrPlugin_csrMapping_writeDataSignal[4 : 0]; always @(*) begin _zz_CsrPlugin_csrMapping_readDataInit_5 = 32'h0; - if(execute_CsrPlugin_csr_3) begin - _zz_CsrPlugin_csrMapping_readDataInit_5[7 : 5] = FpuPlugin_rm; - _zz_CsrPlugin_csrMapping_readDataInit_5[4 : 0] = {FpuPlugin_flags_NV,{FpuPlugin_flags_DZ,{FpuPlugin_flags_OF,{FpuPlugin_flags_UF,FpuPlugin_flags_NX}}}}; + if(execute_CsrPlugin_csr_834) begin + _zz_CsrPlugin_csrMapping_readDataInit_5[31 : 31] = CsrPlugin_mcause_interrupt; + _zz_CsrPlugin_csrMapping_readDataInit_5[3 : 0] = CsrPlugin_mcause_exceptionCode; end end always @(*) begin _zz_CsrPlugin_csrMapping_readDataInit_6 = 32'h0; - if(execute_CsrPlugin_csr_2) begin - _zz_CsrPlugin_csrMapping_readDataInit_6[2 : 0] = FpuPlugin_rm; + if(execute_CsrPlugin_csr_835) begin + _zz_CsrPlugin_csrMapping_readDataInit_6[31 : 0] = CsrPlugin_mtval; end end - assign _zz_FpuPlugin_flags_NX_1 = CsrPlugin_csrMapping_writeDataSignal[4 : 0]; always @(*) begin _zz_CsrPlugin_csrMapping_readDataInit_7 = 32'h0; - if(execute_CsrPlugin_csr_1) begin - _zz_CsrPlugin_csrMapping_readDataInit_7[4 : 0] = {FpuPlugin_flags_NV,{FpuPlugin_flags_DZ,{FpuPlugin_flags_OF,{FpuPlugin_flags_UF,FpuPlugin_flags_NX}}}}; + if(execute_CsrPlugin_csr_3072) begin + _zz_CsrPlugin_csrMapping_readDataInit_7[31 : 0] = CsrPlugin_mcycle[31 : 0]; end end always @(*) begin _zz_CsrPlugin_csrMapping_readDataInit_8 = 32'h0; - if(execute_CsrPlugin_csr_256) begin - _zz_CsrPlugin_csrMapping_readDataInit_8[14 : 13] = FpuPlugin_fs; - _zz_CsrPlugin_csrMapping_readDataInit_8[31 : 31] = FpuPlugin_sd; + if(execute_CsrPlugin_csr_3200) begin + _zz_CsrPlugin_csrMapping_readDataInit_8[31 : 0] = CsrPlugin_mcycle[63 : 32]; end end @@ -5263,23 +4276,52 @@ module VexRiscv ( assign iBus_rsp_valid = (iBusWishbone_CYC && iBusWishbone_ACK); assign iBus_rsp_payload_inst = iBusWishbone_DAT_MISO; assign iBus_rsp_payload_error = 1'b0; - assign _zz_dBus_cmd_ready_5 = (dBus_cmd_payload_size == 2'b11); - assign _zz_dBus_cmd_ready_1 = dBus_cmd_valid; - assign _zz_dBus_cmd_ready_3 = dBus_cmd_payload_wr; - assign _zz_dBus_cmd_ready_4 = ((! _zz_dBus_cmd_ready_5) || (_zz_dBus_cmd_ready == 1'b1)); - assign dBus_cmd_ready = (_zz_dBus_cmd_ready_2 && (_zz_dBus_cmd_ready_3 || _zz_dBus_cmd_ready_4)); - assign dBusWishbone_ADR = ((_zz_dBus_cmd_ready_5 ? {{dBus_cmd_payload_address[31 : 3],_zz_dBus_cmd_ready},2'b00} : {dBus_cmd_payload_address[31 : 2],2'b00}) >>> 2); - assign dBusWishbone_CTI = (_zz_dBus_cmd_ready_5 ? (_zz_dBus_cmd_ready_4 ? 3'b111 : 3'b010) : 3'b000); + assign dBus_cmd_halfPipe_fire = (dBus_cmd_halfPipe_valid && dBus_cmd_halfPipe_ready); + assign dBus_cmd_ready = (! dBus_cmd_rValid); + assign dBus_cmd_halfPipe_valid = dBus_cmd_rValid; + assign dBus_cmd_halfPipe_payload_wr = dBus_cmd_rData_wr; + assign dBus_cmd_halfPipe_payload_address = dBus_cmd_rData_address; + assign dBus_cmd_halfPipe_payload_data = dBus_cmd_rData_data; + assign dBus_cmd_halfPipe_payload_size = dBus_cmd_rData_size; + assign dBusWishbone_ADR = (dBus_cmd_halfPipe_payload_address >>> 2); + assign dBusWishbone_CTI = 3'b000; assign dBusWishbone_BTE = 2'b00; - assign dBusWishbone_SEL = (_zz_dBus_cmd_ready_3 ? dBus_cmd_payload_mask : 4'b1111); - assign dBusWishbone_WE = _zz_dBus_cmd_ready_3; - assign dBusWishbone_DAT_MOSI = dBus_cmd_payload_data; - assign _zz_dBus_cmd_ready_2 = (_zz_dBus_cmd_ready_1 && dBusWishbone_ACK); - assign dBusWishbone_CYC = _zz_dBus_cmd_ready_1; - assign dBusWishbone_STB = _zz_dBus_cmd_ready_1; - assign dBus_rsp_valid = _zz_dBus_rsp_valid; - assign dBus_rsp_payload_data = dBusWishbone_DAT_MISO_regNext; - assign dBus_rsp_payload_error = 1'b0; + always @(*) begin + case(dBus_cmd_halfPipe_payload_size) + 2'b00 : begin + _zz_dBusWishbone_SEL = 4'b0001; + end + 2'b01 : begin + _zz_dBusWishbone_SEL = 4'b0011; + end + default : begin + _zz_dBusWishbone_SEL = 4'b1111; + end + endcase + end + + always @(*) begin + dBusWishbone_SEL = (_zz_dBusWishbone_SEL <<< dBus_cmd_halfPipe_payload_address[1 : 0]); + if(when_DBusSimplePlugin_l189) begin + dBusWishbone_SEL = 4'b1111; + end + end + + assign when_DBusSimplePlugin_l189 = (! dBus_cmd_halfPipe_payload_wr); + assign dBusWishbone_WE = dBus_cmd_halfPipe_payload_wr; + assign dBusWishbone_DAT_MOSI = dBus_cmd_halfPipe_payload_data; + assign dBus_cmd_halfPipe_ready = (dBus_cmd_halfPipe_valid && dBusWishbone_ACK); + assign dBusWishbone_CYC = dBus_cmd_halfPipe_valid; + assign dBusWishbone_STB = dBus_cmd_halfPipe_valid; + assign dBus_rsp_ready = ((dBus_cmd_halfPipe_valid && (! dBusWishbone_WE)) && dBusWishbone_ACK); + assign dBus_rsp_data = dBusWishbone_DAT_MISO; + assign dBus_rsp_error = 1'b0; + assign debug_bus_cmd_valid = systemDebugger_1_io_mem_cmd_valid; + assign debug_bus_cmd_payload_wr = systemDebugger_1_io_mem_cmd_payload_wr; + assign debug_bus_cmd_payload_data = systemDebugger_1_io_mem_cmd_payload_data; + assign debug_bus_cmd_payload_address = systemDebugger_1_io_mem_cmd_payload_address[7:0]; + assign debug_bus_cmd_fire = (debug_bus_cmd_valid && debug_bus_cmd_ready); + assign jtag_tdo = jtagBridge_1_io_jtag_tdo; always @(posedge clk or posedge reset) begin if(reset) begin IBusSimplePlugin_fetchPc_pcReg <= 32'h20000000; @@ -5297,7 +4339,6 @@ module VexRiscv ( IBusSimplePlugin_injector_nextPcCalc_valids_3 <= 1'b0; IBusSimplePlugin_pending_value <= 3'b000; IBusSimplePlugin_rspJoin_rspBuffer_discardCounter <= 3'b000; - DBusCachedPlugin_rspCounter <= 32'h0; CsrPlugin_mtvec_mode <= 2'b00; CsrPlugin_mtvec_base <= 30'h00000008; CsrPlugin_mstatus_MIE <= 1'b0; @@ -5320,27 +4361,23 @@ module VexRiscv ( execute_CsrPlugin_wfiWake <= 1'b0; _zz_2 <= 1'b1; memory_DivPlugin_div_counter_value <= 6'h0; - FpuPlugin_pendings <= 6'h0; - FpuPlugin_flags_NV <= 1'b0; - FpuPlugin_flags_DZ <= 1'b0; - FpuPlugin_flags_OF <= 1'b0; - FpuPlugin_flags_UF <= 1'b0; - FpuPlugin_flags_NX <= 1'b0; - FpuPlugin_rm <= 3'b000; - FpuPlugin_fs <= 2'b01; - decode_FpuPlugin_forked <= 1'b0; - writeBack_FpuPlugin_commit_rValid <= 1'b0; execute_LightShifterPlugin_isActive <= 1'b0; HazardSimplePlugin_writeBackBuffer_valid <= 1'b0; + DebugPlugin_resetIt <= 1'b0; + DebugPlugin_haltIt <= 1'b0; + DebugPlugin_stepIt <= 1'b0; + DebugPlugin_godmode <= 1'b0; + DebugPlugin_haltedByBreak <= 1'b0; + DebugPlugin_debugUsed <= 1'b0; + DebugPlugin_disableEbreak <= 1'b0; + _zz_3 <= 1'b0; execute_arbitration_isValid <= 1'b0; memory_arbitration_isValid <= 1'b0; writeBack_arbitration_isValid <= 1'b0; - decode_to_execute_FPU_FORKED <= 1'b0; - execute_to_memory_FPU_FORKED <= 1'b0; - memory_to_writeBack_FPU_FORKED <= 1'b0; + switch_Fetcher_l365 <= 3'b000; iBus_cmd_rValid <= 1'b0; - _zz_dBus_cmd_ready <= 1'b0; - _zz_dBus_rsp_valid <= 1'b0; + dBus_cmd_rValid <= 1'b0; + debug_bus_cmd_fire_regNext <= 1'b0; end else begin if(IBusSimplePlugin_fetchPc_correction) begin IBusSimplePlugin_fetchPc_correctionReg <= 1'b1; @@ -5423,9 +4460,6 @@ module VexRiscv ( if(IBusSimplePlugin_iBusRsp_flush) begin IBusSimplePlugin_rspJoin_rspBuffer_discardCounter <= (IBusSimplePlugin_pending_value - _zz_IBusSimplePlugin_rspJoin_rspBuffer_discardCounter_2); end - if(dBus_rsp_valid) begin - DBusCachedPlugin_rspCounter <= (DBusCachedPlugin_rspCounter + 32'h00000001); - end CsrPlugin_mcycle <= (CsrPlugin_mcycle + 64'h0000000000000001); if(writeBack_arbitration_isFiring) begin CsrPlugin_minstret <= (CsrPlugin_minstret + 64'h0000000000000001); @@ -5507,49 +4541,6 @@ module VexRiscv ( execute_CsrPlugin_wfiWake <= (({_zz_when_CsrPlugin_l965_2,{_zz_when_CsrPlugin_l965_1,_zz_when_CsrPlugin_l965}} != 3'b000) || CsrPlugin_thirdPartyWake); _zz_2 <= 1'b0; memory_DivPlugin_div_counter_value <= memory_DivPlugin_div_counter_valueNext; - FpuPlugin_pendings <= (_zz_FpuPlugin_pendings - _zz_FpuPlugin_pendings_6); - if(when_FpuPlugin_l199) begin - FpuPlugin_flags_NV <= 1'b1; - end - if(when_FpuPlugin_l200) begin - FpuPlugin_flags_DZ <= 1'b1; - end - if(when_FpuPlugin_l201) begin - FpuPlugin_flags_OF <= 1'b1; - end - if(when_FpuPlugin_l202) begin - FpuPlugin_flags_UF <= 1'b1; - end - if(when_FpuPlugin_l203) begin - FpuPlugin_flags_NX <= 1'b1; - end - if(when_FpuPlugin_l219) begin - FpuPlugin_fs <= 2'b11; - end - if(FpuPlugin_port_cmd_fire_1) begin - decode_FpuPlugin_forked <= 1'b1; - end - if(when_FpuPlugin_l234) begin - decode_FpuPlugin_forked <= 1'b0; - end - if(writeBack_FpuPlugin_isRsp) begin - if(writeBack_arbitration_isValid) begin - if(when_FpuPlugin_l280) begin - if(FpuPlugin_port_rsp_payload_NV) begin - FpuPlugin_flags_NV <= 1'b1; - end - if(FpuPlugin_port_rsp_payload_NX) begin - FpuPlugin_flags_NX <= 1'b1; - end - end - end - end - if(writeBack_FpuPlugin_commit_valid) begin - writeBack_FpuPlugin_commit_rValid <= 1'b1; - end - if(writeBack_FpuPlugin_commit_s2mPipe_ready) begin - writeBack_FpuPlugin_commit_rValid <= 1'b0; - end if(when_ShiftPlugins_l169) begin if(when_ShiftPlugins_l175) begin execute_LightShifterPlugin_isActive <= 1'b1; @@ -5562,15 +4553,59 @@ module VexRiscv ( execute_LightShifterPlugin_isActive <= 1'b0; end HazardSimplePlugin_writeBackBuffer_valid <= HazardSimplePlugin_writeBackWrites_valid; - if(when_Pipeline_l124_61) begin - decode_to_execute_FPU_FORKED <= _zz_decode_to_execute_FPU_FORKED; + if(when_DebugPlugin_l225) begin + DebugPlugin_godmode <= 1'b1; + end + if(debug_bus_cmd_valid) begin + DebugPlugin_debugUsed <= 1'b1; + end + if(debug_bus_cmd_valid) begin + case(switch_DebugPlugin_l267) + 6'h0 : begin + if(debug_bus_cmd_payload_wr) begin + DebugPlugin_stepIt <= debug_bus_cmd_payload_data[4]; + if(when_DebugPlugin_l271) begin + DebugPlugin_resetIt <= 1'b1; + end + if(when_DebugPlugin_l271_1) begin + DebugPlugin_resetIt <= 1'b0; + end + if(when_DebugPlugin_l272) begin + DebugPlugin_haltIt <= 1'b1; + end + if(when_DebugPlugin_l272_1) begin + DebugPlugin_haltIt <= 1'b0; + end + if(when_DebugPlugin_l273) begin + DebugPlugin_haltedByBreak <= 1'b0; + end + if(when_DebugPlugin_l274) begin + DebugPlugin_godmode <= 1'b0; + end + if(when_DebugPlugin_l275) begin + DebugPlugin_disableEbreak <= 1'b1; + end + if(when_DebugPlugin_l275_1) begin + DebugPlugin_disableEbreak <= 1'b0; + end + end + end + default : begin + end + endcase end - if(when_Pipeline_l124_62) begin - execute_to_memory_FPU_FORKED <= _zz_execute_to_memory_FPU_FORKED; + if(when_DebugPlugin_l295) begin + if(when_DebugPlugin_l298) begin + DebugPlugin_haltIt <= 1'b1; + DebugPlugin_haltedByBreak <= 1'b1; + end end - if(when_Pipeline_l124_63) begin - memory_to_writeBack_FPU_FORKED <= _zz_memory_to_writeBack_FPU_FORKED; + if(when_DebugPlugin_l311) begin + if(decode_arbitration_isValid) begin + DebugPlugin_haltIt <= 1'b1; + end end + _zz_3 <= (DebugPlugin_stepIt && decode_arbitration_isFiring); if(when_Pipeline_l151) begin execute_arbitration_isValid <= 1'b0; end @@ -5589,6 +4624,29 @@ module VexRiscv ( if(when_Pipeline_l154_2) begin writeBack_arbitration_isValid <= memory_arbitration_isValid; end + case(switch_Fetcher_l365) + 3'b000 : begin + if(IBusSimplePlugin_injectionPort_valid) begin + switch_Fetcher_l365 <= 3'b001; + end + end + 3'b001 : begin + switch_Fetcher_l365 <= 3'b010; + end + 3'b010 : begin + switch_Fetcher_l365 <= 3'b011; + end + 3'b011 : begin + if(when_Fetcher_l381) begin + switch_Fetcher_l365 <= 3'b100; + end + end + 3'b100 : begin + switch_Fetcher_l365 <= 3'b000; + end + default : begin + end + endcase if(execute_CsrPlugin_csr_768) begin if(execute_CsrPlugin_writeEnable) begin CsrPlugin_mstatus_MPIE <= CsrPlugin_csrMapping_writeDataSignal[7]; @@ -5600,7 +4658,6 @@ module VexRiscv ( default : begin end endcase - FpuPlugin_fs <= CsrPlugin_csrMapping_writeDataSignal[14 : 13]; end end if(execute_CsrPlugin_csr_772) begin @@ -5616,45 +4673,16 @@ module VexRiscv ( CsrPlugin_mtvec_mode <= CsrPlugin_csrMapping_writeDataSignal[1 : 0]; end end - if(execute_CsrPlugin_csr_3) begin - if(execute_CsrPlugin_writeEnable) begin - FpuPlugin_rm <= CsrPlugin_csrMapping_writeDataSignal[7 : 5]; - FpuPlugin_flags_NX <= _zz_FpuPlugin_flags_NX[0]; - FpuPlugin_flags_UF <= _zz_FpuPlugin_flags_NX[1]; - FpuPlugin_flags_OF <= _zz_FpuPlugin_flags_NX[2]; - FpuPlugin_flags_DZ <= _zz_FpuPlugin_flags_NX[3]; - FpuPlugin_flags_NV <= _zz_FpuPlugin_flags_NX[4]; - end - end - if(execute_CsrPlugin_csr_2) begin - if(execute_CsrPlugin_writeEnable) begin - FpuPlugin_rm <= CsrPlugin_csrMapping_writeDataSignal[2 : 0]; - end - end - if(execute_CsrPlugin_csr_1) begin - if(execute_CsrPlugin_writeEnable) begin - FpuPlugin_flags_NX <= _zz_FpuPlugin_flags_NX_1[0]; - FpuPlugin_flags_UF <= _zz_FpuPlugin_flags_NX_1[1]; - FpuPlugin_flags_OF <= _zz_FpuPlugin_flags_NX_1[2]; - FpuPlugin_flags_DZ <= _zz_FpuPlugin_flags_NX_1[3]; - FpuPlugin_flags_NV <= _zz_FpuPlugin_flags_NX_1[4]; - end - end - if(execute_CsrPlugin_csr_256) begin - if(execute_CsrPlugin_writeEnable) begin - FpuPlugin_fs <= CsrPlugin_csrMapping_writeDataSignal[14 : 13]; - end - end if(iBus_cmd_ready) begin iBus_cmd_rValid <= iBus_cmd_valid; end - if((_zz_dBus_cmd_ready_1 && _zz_dBus_cmd_ready_2)) begin - _zz_dBus_cmd_ready <= (_zz_dBus_cmd_ready + 1'b1); - if(_zz_dBus_cmd_ready_4) begin - _zz_dBus_cmd_ready <= 1'b0; - end + if(dBus_cmd_valid) begin + dBus_cmd_rValid <= 1'b1; end - _zz_dBus_rsp_valid <= ((_zz_dBus_cmd_ready_1 && (! dBusWishbone_WE)) && dBusWishbone_ACK); + if(dBus_cmd_halfPipe_fire) begin + dBus_cmd_rValid <= 1'b0; + end + debug_bus_cmd_fire_regNext <= debug_bus_cmd_fire; end end @@ -5688,9 +4716,9 @@ module VexRiscv ( CsrPlugin_exceptionPortCtrl_exceptionContext_code <= CsrPlugin_selfException_payload_code; CsrPlugin_exceptionPortCtrl_exceptionContext_badAddr <= CsrPlugin_selfException_payload_badAddr; end - if(DBusCachedPlugin_exceptionBus_valid) begin - CsrPlugin_exceptionPortCtrl_exceptionContext_code <= DBusCachedPlugin_exceptionBus_payload_code; - CsrPlugin_exceptionPortCtrl_exceptionContext_badAddr <= DBusCachedPlugin_exceptionBus_payload_badAddr; + if(DBusSimplePlugin_memoryExceptionPort_valid) begin + CsrPlugin_exceptionPortCtrl_exceptionContext_code <= DBusSimplePlugin_memoryExceptionPort_payload_code; + CsrPlugin_exceptionPortCtrl_exceptionContext_badAddr <= DBusSimplePlugin_memoryExceptionPort_payload_badAddr; end if(when_CsrPlugin_l959) begin if(when_CsrPlugin_l965) begin @@ -5741,12 +4769,6 @@ module VexRiscv ( memory_DivPlugin_rs2 <= ((_zz_memory_DivPlugin_rs2 ? (~ execute_RS2) : execute_RS2) + _zz_memory_DivPlugin_rs2_1); memory_DivPlugin_div_needRevert <= ((_zz_memory_DivPlugin_rs1 ^ (_zz_memory_DivPlugin_rs2 && (! execute_INSTRUCTION[13]))) && (! (((execute_RS2 == 32'h0) && execute_IS_RS2_SIGNED) && (! execute_INSTRUCTION[13])))); end - if(writeBack_FpuPlugin_commit_ready) begin - writeBack_FpuPlugin_commit_rData_opcode <= writeBack_FpuPlugin_commit_payload_opcode; - writeBack_FpuPlugin_commit_rData_rd <= writeBack_FpuPlugin_commit_payload_rd; - writeBack_FpuPlugin_commit_rData_write <= writeBack_FpuPlugin_commit_payload_write; - writeBack_FpuPlugin_commit_rData_value <= writeBack_FpuPlugin_commit_payload_value; - end if(when_ShiftPlugins_l169) begin if(when_ShiftPlugins_l175) begin execute_LightShifterPlugin_amplitudeReg <= (execute_LightShifterPlugin_amplitude - 5'h01); @@ -5754,6 +4776,20 @@ module VexRiscv ( end HazardSimplePlugin_writeBackBuffer_payload_address <= HazardSimplePlugin_writeBackWrites_payload_address; HazardSimplePlugin_writeBackBuffer_payload_data <= HazardSimplePlugin_writeBackWrites_payload_data; + DebugPlugin_firstCycle <= 1'b0; + if(debug_bus_cmd_ready) begin + DebugPlugin_firstCycle <= 1'b1; + end + DebugPlugin_secondCycle <= DebugPlugin_firstCycle; + DebugPlugin_isPipBusy <= (({writeBack_arbitration_isValid,{memory_arbitration_isValid,{execute_arbitration_isValid,decode_arbitration_isValid}}} != 4'b0000) || IBusSimplePlugin_incomingInstruction); + if(writeBack_arbitration_isValid) begin + DebugPlugin_busReadDataReg <= _zz_decode_RS2_2; + end + _zz_when_DebugPlugin_l244 <= debug_bus_cmd_payload_address[2]; + if(when_DebugPlugin_l295) begin + DebugPlugin_busReadDataReg <= execute_PC; + end + DebugPlugin_resetIt_regNext <= DebugPlugin_resetIt; if(when_Pipeline_l124) begin decode_to_execute_PC <= _zz_decode_SRC2; end @@ -5773,16 +4809,16 @@ module VexRiscv ( memory_to_writeBack_INSTRUCTION <= memory_INSTRUCTION; end if(when_Pipeline_l124_6) begin - decode_to_execute_FORMAL_PC_NEXT <= decode_FORMAL_PC_NEXT; + decode_to_execute_IS_RVC <= decode_IS_RVC; end if(when_Pipeline_l124_7) begin - execute_to_memory_FORMAL_PC_NEXT <= execute_FORMAL_PC_NEXT; + decode_to_execute_FORMAL_PC_NEXT <= _zz_decode_to_execute_FORMAL_PC_NEXT; end if(when_Pipeline_l124_8) begin - memory_to_writeBack_FORMAL_PC_NEXT <= _zz_memory_to_writeBack_FORMAL_PC_NEXT; + execute_to_memory_FORMAL_PC_NEXT <= execute_FORMAL_PC_NEXT; end if(when_Pipeline_l124_9) begin - decode_to_execute_MEMORY_FORCE_CONSTISTENCY <= decode_MEMORY_FORCE_CONSTISTENCY; + memory_to_writeBack_FORMAL_PC_NEXT <= _zz_memory_to_writeBack_FORMAL_PC_NEXT; end if(when_Pipeline_l124_10) begin decode_to_execute_CSR_WRITE_OPCODE <= decode_CSR_WRITE_OPCODE; @@ -5824,164 +4860,122 @@ module VexRiscv ( execute_to_memory_BYPASSABLE_MEMORY_STAGE <= execute_BYPASSABLE_MEMORY_STAGE; end if(when_Pipeline_l124_23) begin - decode_to_execute_MEMORY_WR <= decode_MEMORY_WR; + decode_to_execute_MEMORY_STORE <= decode_MEMORY_STORE; end if(when_Pipeline_l124_24) begin - execute_to_memory_MEMORY_WR <= execute_MEMORY_WR; + execute_to_memory_MEMORY_STORE <= execute_MEMORY_STORE; end if(when_Pipeline_l124_25) begin - memory_to_writeBack_MEMORY_WR <= memory_MEMORY_WR; + decode_to_execute_IS_CSR <= decode_IS_CSR; end if(when_Pipeline_l124_26) begin - decode_to_execute_MEMORY_MANAGMENT <= decode_MEMORY_MANAGMENT; + decode_to_execute_ENV_CTRL <= _zz_decode_to_execute_ENV_CTRL; end if(when_Pipeline_l124_27) begin - decode_to_execute_IS_CSR <= decode_IS_CSR; + execute_to_memory_ENV_CTRL <= _zz_execute_to_memory_ENV_CTRL; end if(when_Pipeline_l124_28) begin - decode_to_execute_ENV_CTRL <= _zz_decode_to_execute_ENV_CTRL; + memory_to_writeBack_ENV_CTRL <= _zz_memory_to_writeBack_ENV_CTRL; end if(when_Pipeline_l124_29) begin - execute_to_memory_ENV_CTRL <= _zz_execute_to_memory_ENV_CTRL; + decode_to_execute_SRC_LESS_UNSIGNED <= decode_SRC_LESS_UNSIGNED; end if(when_Pipeline_l124_30) begin - memory_to_writeBack_ENV_CTRL <= _zz_memory_to_writeBack_ENV_CTRL; + decode_to_execute_ALU_BITWISE_CTRL <= _zz_decode_to_execute_ALU_BITWISE_CTRL; end if(when_Pipeline_l124_31) begin - decode_to_execute_SRC_LESS_UNSIGNED <= decode_SRC_LESS_UNSIGNED; + decode_to_execute_IS_MUL <= decode_IS_MUL; end if(when_Pipeline_l124_32) begin - decode_to_execute_ALU_BITWISE_CTRL <= _zz_decode_to_execute_ALU_BITWISE_CTRL; + execute_to_memory_IS_MUL <= execute_IS_MUL; end if(when_Pipeline_l124_33) begin - decode_to_execute_IS_MUL <= decode_IS_MUL; + memory_to_writeBack_IS_MUL <= memory_IS_MUL; end if(when_Pipeline_l124_34) begin - execute_to_memory_IS_MUL <= execute_IS_MUL; + decode_to_execute_IS_DIV <= decode_IS_DIV; end if(when_Pipeline_l124_35) begin - memory_to_writeBack_IS_MUL <= memory_IS_MUL; + execute_to_memory_IS_DIV <= execute_IS_DIV; end if(when_Pipeline_l124_36) begin - decode_to_execute_IS_DIV <= decode_IS_DIV; + decode_to_execute_IS_RS1_SIGNED <= decode_IS_RS1_SIGNED; end if(when_Pipeline_l124_37) begin - execute_to_memory_IS_DIV <= execute_IS_DIV; + decode_to_execute_IS_RS2_SIGNED <= decode_IS_RS2_SIGNED; end if(when_Pipeline_l124_38) begin - decode_to_execute_IS_RS1_SIGNED <= decode_IS_RS1_SIGNED; + decode_to_execute_SHIFT_CTRL <= _zz_decode_to_execute_SHIFT_CTRL; end if(when_Pipeline_l124_39) begin - decode_to_execute_IS_RS2_SIGNED <= decode_IS_RS2_SIGNED; + decode_to_execute_BRANCH_CTRL <= _zz_decode_to_execute_BRANCH_CTRL; end if(when_Pipeline_l124_40) begin - decode_to_execute_FPU_ENABLE <= decode_FPU_ENABLE; + decode_to_execute_RS1 <= _zz_decode_SRC1; end if(when_Pipeline_l124_41) begin - execute_to_memory_FPU_ENABLE <= execute_FPU_ENABLE; + decode_to_execute_RS2 <= _zz_decode_SRC2_1; end if(when_Pipeline_l124_42) begin - memory_to_writeBack_FPU_ENABLE <= memory_FPU_ENABLE; + decode_to_execute_SRC2_FORCE_ZERO <= decode_SRC2_FORCE_ZERO; end if(when_Pipeline_l124_43) begin - decode_to_execute_FPU_COMMIT <= decode_FPU_COMMIT; + decode_to_execute_SRC1 <= decode_SRC1; end if(when_Pipeline_l124_44) begin - execute_to_memory_FPU_COMMIT <= execute_FPU_COMMIT; + decode_to_execute_SRC2 <= decode_SRC2; end if(when_Pipeline_l124_45) begin - memory_to_writeBack_FPU_COMMIT <= memory_FPU_COMMIT; + decode_to_execute_PREDICTION_HAD_BRANCHED2 <= decode_PREDICTION_HAD_BRANCHED2; end if(when_Pipeline_l124_46) begin - decode_to_execute_FPU_RSP <= decode_FPU_RSP; + decode_to_execute_DO_EBREAK <= decode_DO_EBREAK; end if(when_Pipeline_l124_47) begin - execute_to_memory_FPU_RSP <= execute_FPU_RSP; + execute_to_memory_ALIGNEMENT_FAULT <= execute_ALIGNEMENT_FAULT; end if(when_Pipeline_l124_48) begin - memory_to_writeBack_FPU_RSP <= memory_FPU_RSP; + execute_to_memory_MEMORY_ADDRESS_LOW <= execute_MEMORY_ADDRESS_LOW; end if(when_Pipeline_l124_49) begin - decode_to_execute_FPU_OPCODE <= _zz_decode_to_execute_FPU_OPCODE; + memory_to_writeBack_MEMORY_ADDRESS_LOW <= memory_MEMORY_ADDRESS_LOW; end if(when_Pipeline_l124_50) begin - execute_to_memory_FPU_OPCODE <= _zz_execute_to_memory_FPU_OPCODE; + execute_to_memory_REGFILE_WRITE_DATA <= _zz_decode_RS2_1; end if(when_Pipeline_l124_51) begin - memory_to_writeBack_FPU_OPCODE <= _zz_memory_to_writeBack_FPU_OPCODE; + memory_to_writeBack_REGFILE_WRITE_DATA <= _zz_decode_RS2; end if(when_Pipeline_l124_52) begin - decode_to_execute_SHIFT_CTRL <= _zz_decode_to_execute_SHIFT_CTRL; + execute_to_memory_MUL_LL <= execute_MUL_LL; end if(when_Pipeline_l124_53) begin - decode_to_execute_BRANCH_CTRL <= _zz_decode_to_execute_BRANCH_CTRL; + execute_to_memory_MUL_LH <= execute_MUL_LH; end if(when_Pipeline_l124_54) begin - decode_to_execute_RS1 <= _zz_decode_SRC1; + execute_to_memory_MUL_HL <= execute_MUL_HL; end if(when_Pipeline_l124_55) begin - execute_to_memory_RS1 <= execute_RS1; + execute_to_memory_MUL_HH <= execute_MUL_HH; end if(when_Pipeline_l124_56) begin - memory_to_writeBack_RS1 <= memory_RS1; + memory_to_writeBack_MUL_HH <= memory_MUL_HH; end if(when_Pipeline_l124_57) begin - decode_to_execute_RS2 <= _zz_decode_SRC2_1; + execute_to_memory_BRANCH_DO <= execute_BRANCH_DO; end if(when_Pipeline_l124_58) begin - decode_to_execute_SRC2_FORCE_ZERO <= decode_SRC2_FORCE_ZERO; + execute_to_memory_BRANCH_CALC <= execute_BRANCH_CALC; end if(when_Pipeline_l124_59) begin - decode_to_execute_SRC1 <= decode_SRC1; + memory_to_writeBack_MEMORY_READ_DATA <= memory_MEMORY_READ_DATA; end if(when_Pipeline_l124_60) begin - decode_to_execute_SRC2 <= decode_SRC2; - end - if(when_Pipeline_l124_64) begin - decode_to_execute_FPU_COMMIT_LOAD <= decode_FPU_COMMIT_LOAD; - end - if(when_Pipeline_l124_65) begin - execute_to_memory_FPU_COMMIT_LOAD <= execute_FPU_COMMIT_LOAD; - end - if(when_Pipeline_l124_66) begin - memory_to_writeBack_FPU_COMMIT_LOAD <= memory_FPU_COMMIT_LOAD; - end - if(when_Pipeline_l124_67) begin - execute_to_memory_MEMORY_STORE_DATA_RF <= execute_MEMORY_STORE_DATA_RF; - end - if(when_Pipeline_l124_68) begin - memory_to_writeBack_MEMORY_STORE_DATA_RF <= memory_MEMORY_STORE_DATA_RF; - end - if(when_Pipeline_l124_69) begin - execute_to_memory_REGFILE_WRITE_DATA <= _zz_execute_to_memory_REGFILE_WRITE_DATA; - end - if(when_Pipeline_l124_70) begin - memory_to_writeBack_REGFILE_WRITE_DATA <= _zz_memory_to_writeBack_REGFILE_WRITE_DATA; - end - if(when_Pipeline_l124_71) begin - execute_to_memory_MUL_LL <= execute_MUL_LL; - end - if(when_Pipeline_l124_72) begin - execute_to_memory_MUL_LH <= execute_MUL_LH; - end - if(when_Pipeline_l124_73) begin - execute_to_memory_MUL_HL <= execute_MUL_HL; - end - if(when_Pipeline_l124_74) begin - execute_to_memory_MUL_HH <= execute_MUL_HH; - end - if(when_Pipeline_l124_75) begin - memory_to_writeBack_MUL_HH <= memory_MUL_HH; - end - if(when_Pipeline_l124_76) begin - execute_to_memory_BRANCH_DO <= execute_BRANCH_DO; - end - if(when_Pipeline_l124_77) begin - execute_to_memory_BRANCH_CALC <= execute_BRANCH_CALC; - end - if(when_Pipeline_l124_78) begin memory_to_writeBack_MUL_LOW <= memory_MUL_LOW; end + if(when_Fetcher_l401) begin + _zz_IBusSimplePlugin_injector_decodeInput_payload_rsp_inst <= IBusSimplePlugin_injectionPort_payload; + end if(when_CsrPlugin_l1277) begin execute_CsrPlugin_csr_768 <= (decode_INSTRUCTION[31 : 20] == 12'h300); end @@ -5995,8168 +4989,878 @@ module VexRiscv ( execute_CsrPlugin_csr_773 <= (decode_INSTRUCTION[31 : 20] == 12'h305); end if(when_CsrPlugin_l1277_4) begin - execute_CsrPlugin_csr_834 <= (decode_INSTRUCTION[31 : 20] == 12'h342); + execute_CsrPlugin_csr_833 <= (decode_INSTRUCTION[31 : 20] == 12'h341); end if(when_CsrPlugin_l1277_5) begin - execute_CsrPlugin_csr_3 <= (decode_INSTRUCTION[31 : 20] == 12'h003); + execute_CsrPlugin_csr_834 <= (decode_INSTRUCTION[31 : 20] == 12'h342); end if(when_CsrPlugin_l1277_6) begin - execute_CsrPlugin_csr_2 <= (decode_INSTRUCTION[31 : 20] == 12'h002); + execute_CsrPlugin_csr_835 <= (decode_INSTRUCTION[31 : 20] == 12'h343); end if(when_CsrPlugin_l1277_7) begin - execute_CsrPlugin_csr_1 <= (decode_INSTRUCTION[31 : 20] == 12'h001); + execute_CsrPlugin_csr_3072 <= (decode_INSTRUCTION[31 : 20] == 12'hc00); end if(when_CsrPlugin_l1277_8) begin - execute_CsrPlugin_csr_256 <= (decode_INSTRUCTION[31 : 20] == 12'h100); + execute_CsrPlugin_csr_3200 <= (decode_INSTRUCTION[31 : 20] == 12'hc80); end if(execute_CsrPlugin_csr_836) begin if(execute_CsrPlugin_writeEnable) begin CsrPlugin_mip_MSIP <= CsrPlugin_csrMapping_writeDataSignal[3]; end end + if(execute_CsrPlugin_csr_833) begin + if(execute_CsrPlugin_writeEnable) begin + CsrPlugin_mepc <= CsrPlugin_csrMapping_writeDataSignal[31 : 0]; + end + end if(iBus_cmd_ready) begin iBus_cmd_rData_pc <= iBus_cmd_payload_pc; end - dBusWishbone_DAT_MISO_regNext <= dBusWishbone_DAT_MISO; + if(dBus_cmd_ready) begin + dBus_cmd_rData_wr <= dBus_cmd_payload_wr; + dBus_cmd_rData_address <= dBus_cmd_payload_address; + dBus_cmd_rData_data <= dBus_cmd_payload_data; + dBus_cmd_rData_size <= dBus_cmd_payload_size; + end end endmodule -module FpuCore ( - input io_port_0_cmd_valid, - output io_port_0_cmd_ready, - input [3:0] io_port_0_cmd_payload_opcode, - input [1:0] io_port_0_cmd_payload_arg, - input [4:0] io_port_0_cmd_payload_rs1, - input [4:0] io_port_0_cmd_payload_rs2, - input [4:0] io_port_0_cmd_payload_rs3, - input [4:0] io_port_0_cmd_payload_rd, - input [0:0] io_port_0_cmd_payload_format, - input [2:0] io_port_0_cmd_payload_roundMode, - input io_port_0_commit_valid, - output io_port_0_commit_ready, - input [3:0] io_port_0_commit_payload_opcode, - input [4:0] io_port_0_commit_payload_rd, - input io_port_0_commit_payload_write, - input [31:0] io_port_0_commit_payload_value, - output io_port_0_rsp_valid, - input io_port_0_rsp_ready, - output [31:0] io_port_0_rsp_payload_value, - output io_port_0_rsp_payload_NV, - output io_port_0_rsp_payload_NX, - output io_port_0_completion_valid, - output io_port_0_completion_payload_flags_NX, - output io_port_0_completion_payload_flags_UF, - output io_port_0_completion_payload_flags_OF, - output io_port_0_completion_payload_flags_DZ, - output io_port_0_completion_payload_flags_NV, - output io_port_0_completion_payload_written, +module SystemDebugger ( + input io_remote_cmd_valid, + output io_remote_cmd_ready, + input io_remote_cmd_payload_last, + input [0:0] io_remote_cmd_payload_fragment, + output io_remote_rsp_valid, + input io_remote_rsp_ready, + output io_remote_rsp_payload_error, + output [31:0] io_remote_rsp_payload_data, + output io_mem_cmd_valid, + input io_mem_cmd_ready, + output [31:0] io_mem_cmd_payload_address, + output [31:0] io_mem_cmd_payload_data, + output io_mem_cmd_payload_wr, + output [1:0] io_mem_cmd_payload_size, + input io_mem_rsp_valid, + input [31:0] io_mem_rsp_payload, input clk, input reset ); - localparam FpuOpcode_LOAD = 4'd0; - localparam FpuOpcode_STORE = 4'd1; - localparam FpuOpcode_MUL = 4'd2; - localparam FpuOpcode_ADD = 4'd3; - localparam FpuOpcode_FMA = 4'd4; - localparam FpuOpcode_I2F = 4'd5; - localparam FpuOpcode_F2I = 4'd6; - localparam FpuOpcode_CMP = 4'd7; - localparam FpuOpcode_DIV = 4'd8; - localparam FpuOpcode_SQRT = 4'd9; - localparam FpuOpcode_MIN_MAX = 4'd10; - localparam FpuOpcode_SGNJ = 4'd11; - localparam FpuOpcode_FMV_X_W = 4'd12; - localparam FpuOpcode_FMV_W_X = 4'd13; - localparam FpuOpcode_FCLASS = 4'd14; - localparam FpuOpcode_FCVT_X_X = 4'd15; - localparam FpuFormat_FLOAT = 1'd0; - localparam FpuFormat_DOUBLE = 1'd1; - localparam FpuRoundMode_RNE = 3'd0; - localparam FpuRoundMode_RTZ = 3'd1; - localparam FpuRoundMode_RDN = 3'd2; - localparam FpuRoundMode_RUP = 3'd3; - localparam FpuRoundMode_RMM = 3'd4; - - wire streamFork_1_io_outputs_1_ready; - wire div_divider_io_input_valid; - wire [23:0] div_divider_io_input_payload_a; - wire [23:0] div_divider_io_input_payload_b; - wire sqrt_sqrt_io_input_valid; - wire [24:0] sqrt_sqrt_io_input_payload_a; - reg [33:0] _zz_rf_ram_port0; - reg [33:0] _zz_rf_ram_port1; - reg [33:0] _zz_rf_ram_port2; - wire [0:0] _zz_rf_scoreboards_0_target_port1; - wire [0:0] _zz_rf_scoreboards_0_target_port2; - wire [0:0] _zz_rf_scoreboards_0_target_port3; - wire [0:0] _zz_rf_scoreboards_0_target_port4; - wire [0:0] _zz_rf_scoreboards_0_hit_port1; - wire [0:0] _zz_rf_scoreboards_0_hit_port2; - wire [0:0] _zz_rf_scoreboards_0_hit_port3; - wire [0:0] _zz_rf_scoreboards_0_hit_port4; - wire [0:0] _zz_rf_scoreboards_0_hit_port5; - wire [0:0] _zz_rf_scoreboards_0_writes_port1; - wire streamFork_1_io_input_ready; - wire streamFork_1_io_outputs_0_valid; - wire [3:0] streamFork_1_io_outputs_0_payload_opcode; - wire [4:0] streamFork_1_io_outputs_0_payload_rd; - wire streamFork_1_io_outputs_0_payload_write; - wire [31:0] streamFork_1_io_outputs_0_payload_value; - wire streamFork_1_io_outputs_1_valid; - wire [3:0] streamFork_1_io_outputs_1_payload_opcode; - wire [4:0] streamFork_1_io_outputs_1_payload_rd; - wire streamFork_1_io_outputs_1_payload_write; - wire [31:0] streamFork_1_io_outputs_1_payload_value; - wire cmdArbiter_arbiter_io_inputs_0_ready; - wire cmdArbiter_arbiter_io_output_valid; - wire [3:0] cmdArbiter_arbiter_io_output_payload_opcode; - wire [1:0] cmdArbiter_arbiter_io_output_payload_arg; - wire [4:0] cmdArbiter_arbiter_io_output_payload_rs1; - wire [4:0] cmdArbiter_arbiter_io_output_payload_rs2; - wire [4:0] cmdArbiter_arbiter_io_output_payload_rs3; - wire [4:0] cmdArbiter_arbiter_io_output_payload_rd; - wire [0:0] cmdArbiter_arbiter_io_output_payload_format; - wire [2:0] cmdArbiter_arbiter_io_output_payload_roundMode; - wire [0:0] cmdArbiter_arbiter_io_chosenOH; - wire div_divider_io_input_ready; - wire div_divider_io_output_valid; - wire [26:0] div_divider_io_output_payload_result; - wire [24:0] div_divider_io_output_payload_remain; - wire sqrt_sqrt_io_input_ready; - wire sqrt_sqrt_io_output_valid; - wire [23:0] sqrt_sqrt_io_output_payload_result; - wire [27:0] sqrt_sqrt_io_output_payload_remain; - wire streamArbiter_2_io_inputs_0_ready; - wire streamArbiter_2_io_inputs_1_ready; - wire streamArbiter_2_io_inputs_2_ready; - wire streamArbiter_2_io_inputs_3_ready; - wire streamArbiter_2_io_inputs_4_ready; - wire streamArbiter_2_io_inputs_5_ready; - wire streamArbiter_2_io_output_valid; - wire [4:0] streamArbiter_2_io_output_payload_rd; - wire [23:0] streamArbiter_2_io_output_payload_value_mantissa; - wire [8:0] streamArbiter_2_io_output_payload_value_exponent; - wire streamArbiter_2_io_output_payload_value_sign; - wire streamArbiter_2_io_output_payload_value_special; - wire streamArbiter_2_io_output_payload_scrap; - wire [2:0] streamArbiter_2_io_output_payload_roundMode; - wire streamArbiter_2_io_output_payload_NV; - wire streamArbiter_2_io_output_payload_DZ; - wire [2:0] streamArbiter_2_io_chosen; - wire [5:0] streamArbiter_2_io_chosenOH; - wire [0:0] _zz_rf_scoreboards_0_target_port; - wire [0:0] _zz_rf_scoreboards_0_hit_port; - wire [3:0] _zz_commitLogic_0_pending_counter; - wire [3:0] _zz_commitLogic_0_pending_counter_1; - wire [0:0] _zz_commitLogic_0_pending_counter_2; - wire [3:0] _zz_commitLogic_0_pending_counter_3; - wire [0:0] _zz_commitLogic_0_pending_counter_4; - wire [3:0] _zz_commitLogic_0_add_counter; - wire [3:0] _zz_commitLogic_0_add_counter_1; - wire [0:0] _zz_commitLogic_0_add_counter_2; - wire [3:0] _zz_commitLogic_0_add_counter_3; - wire [0:0] _zz_commitLogic_0_add_counter_4; - wire [3:0] _zz_commitLogic_0_mul_counter; - wire [3:0] _zz_commitLogic_0_mul_counter_1; - wire [0:0] _zz_commitLogic_0_mul_counter_2; - wire [3:0] _zz_commitLogic_0_mul_counter_3; - wire [0:0] _zz_commitLogic_0_mul_counter_4; - wire [3:0] _zz_commitLogic_0_div_counter; - wire [3:0] _zz_commitLogic_0_div_counter_1; - wire [0:0] _zz_commitLogic_0_div_counter_2; - wire [3:0] _zz_commitLogic_0_div_counter_3; - wire [0:0] _zz_commitLogic_0_div_counter_4; - wire [3:0] _zz_commitLogic_0_sqrt_counter; - wire [3:0] _zz_commitLogic_0_sqrt_counter_1; - wire [0:0] _zz_commitLogic_0_sqrt_counter_2; - wire [3:0] _zz_commitLogic_0_sqrt_counter_3; - wire [0:0] _zz_commitLogic_0_sqrt_counter_4; - wire [3:0] _zz_commitLogic_0_short_counter; - wire [3:0] _zz_commitLogic_0_short_counter_1; - wire [0:0] _zz_commitLogic_0_short_counter_2; - wire [3:0] _zz_commitLogic_0_short_counter_3; - wire [0:0] _zz_commitLogic_0_short_counter_4; - wire [0:0] _zz_rf_scoreboards_0_writes_port; - wire [3:0] _zz_decode_shortPipHit; - wire _zz_decode_shortPipHit_1; - wire [0:0] _zz_decode_shortPipHit_2; - wire [0:0] _zz_decode_shortPipHit_3; - wire [0:0] _zz_when; - wire [31:0] _zz_load_s1_fsm_shift_input_1; - wire [31:0] _zz_load_s1_fsm_shift_input_2; - wire [31:0] _zz_load_s1_fsm_shift_input_3; - wire [31:0] _zz_load_s1_fsm_shift_input_4; - wire [31:0] _zz_load_s1_fsm_shift_input_5; - wire [31:0] _zz_load_s0_output_rData_value_2; - wire [32:0] _zz_load_s0_output_rData_value_3; - wire [32:0] _zz_load_s0_output_rData_value_4; - wire [32:0] _zz_load_s0_output_rData_value_5; - wire [0:0] _zz_load_s0_output_rData_value_6; - wire _zz__zz_load_s1_fsm_shift_by; - wire [0:0] _zz__zz_load_s1_fsm_shift_by_1; - wire [20:0] _zz__zz_load_s1_fsm_shift_by_2; - wire _zz__zz_load_s1_fsm_shift_by_3; - wire [0:0] _zz__zz_load_s1_fsm_shift_by_4; - wire [9:0] _zz__zz_load_s1_fsm_shift_by_5; - wire [31:0] _zz__zz_load_s1_fsm_shift_by_1_1; - wire [9:0] _zz_load_s1_recoded_exponent; - wire [9:0] _zz_load_s1_recoded_exponent_1; - wire [9:0] _zz_load_s1_recoded_exponent_2; - wire [8:0] _zz_load_s1_output_payload_value_exponent; - wire [8:0] _zz_shortPip_f32_exp; - wire [8:0] _zz_shortPip_expInSubnormalRange; - wire [32:0] _zz_shortPip_fsm_shift_input_1; - wire [32:0] _zz_shortPip_fsm_shift_input_2; - wire [32:0] _zz_shortPip_fsm_shift_input_3; - wire [32:0] _zz_shortPip_fsm_shift_input_4; - wire [32:0] _zz_shortPip_fsm_shift_input_5; - wire [32:0] _zz_shortPip_fsm_shift_input_6; - wire [8:0] _zz_shortPip_fsm_shift_by_2; - wire [8:0] _zz_shortPip_fsm_shift_by_3; - wire [8:0] _zz_shortPip_fsm_shift_by_4; - wire [8:0] _zz_shortPip_fsm_shift_by_5; - wire [8:0] _zz_shortPip_fsm_shift_by_6; - wire [31:0] _zz_shortPip_f2i_result; - wire [0:0] _zz_shortPip_f2i_result_1; - wire [47:0] _zz_mul_sum1_sum; - wire [47:0] _zz_mul_sum1_sum_1; - wire [41:0] _zz_mul_sum1_sum_2; - wire [47:0] _zz_mul_sum2_sum; - wire [47:0] _zz_mul_sum2_sum_1; - wire [41:0] _zz_mul_sum2_sum_2; - wire [47:0] _zz_mul_sum2_sum_3; - wire [47:0] _zz_mul_sum2_sum_4; - wire [9:0] _zz_mul_norm_exp; - wire [0:0] _zz_mul_norm_exp_1; - wire [9:0] _zz_mul_norm_forceUnderflow; - wire [9:0] _zz_mul_norm_output_exponent; - wire [10:0] _zz_div_exponent; - wire [10:0] _zz_div_exponent_1; - wire [10:0] _zz_div_exponent_2; - wire [10:0] _zz_div_exponent_3; - wire [10:0] _zz_div_exponent_4; - wire [0:0] _zz_div_exponent_5; - wire [8:0] _zz_sqrt_exponent; - wire [8:0] _zz_sqrt_exponent_1; - wire [7:0] _zz_sqrt_exponent_2; - wire [7:0] _zz_sqrt_exponent_3; - wire [8:0] _zz_sqrt_exponent_4; - wire [0:0] _zz_sqrt_exponent_5; - wire [9:0] _zz_add_shifter_shiftBy_1; - wire [9:0] _zz_add_shifter_shiftBy_2; - wire [9:0] _zz_add_shifter_shiftBy_3; - wire [0:0] _zz_add_shifter_shiftBy_4; - wire [25:0] _zz_add_shifter_yMantissa_1; - wire [25:0] _zz_add_shifter_yMantissa_2; - wire [25:0] _zz_add_shifter_yMantissa_3; - wire [25:0] _zz_add_shifter_yMantissa_4; - wire [25:0] _zz_add_shifter_yMantissa_5; - wire [26:0] _zz_add_math_xSigned; - wire [26:0] _zz_add_math_xSigned_1; - wire [0:0] _zz_add_math_xSigned_2; - wire [26:0] _zz_add_math_ySigned; - wire [26:0] _zz_add_math_ySigned_1; - wire [0:0] _zz_add_math_ySigned_2; - wire [27:0] _zz_add_math_output_payload_xyMantissa; - wire [27:0] _zz_add_math_output_payload_xyMantissa_1; - wire [27:0] _zz_add_math_output_payload_xyMantissa_2; - wire [27:0] _zz_add_math_output_payload_xyMantissa_3; - wire _zz__zz_add_oh_shift; - wire [0:0] _zz__zz_add_oh_shift_1; - wire [15:0] _zz__zz_add_oh_shift_2; - wire _zz__zz_add_oh_shift_3; - wire [0:0] _zz__zz_add_oh_shift_4; - wire [4:0] _zz__zz_add_oh_shift_5; - wire [26:0] _zz__zz_add_oh_shift_1_1; - wire [9:0] _zz_add_norm_output_payload_exponent; - wire [9:0] _zz_add_norm_output_payload_exponent_1; - wire [5:0] _zz_add_norm_output_payload_exponent_2; - wire [24:0] _zz_add_result_output_payload_value_mantissa; - wire [9:0] _zz_roundFront_expDif; - wire [8:0] _zz_roundFront_expDif_1; - wire [4:0] _zz_roundFront_discardCount; - wire [4:0] _zz_roundFront_exactMask; - wire _zz_roundFront_exactMask_1; - wire [0:0] _zz_roundFront_exactMask_2; - wire [17:0] _zz_roundFront_exactMask_3; - wire [4:0] _zz_roundFront_exactMask_4; - wire _zz_roundFront_exactMask_5; - wire [0:0] _zz_roundFront_exactMask_6; - wire [9:0] _zz_roundFront_exactMask_7; - wire [4:0] _zz_roundFront_exactMask_8; - wire _zz_roundFront_exactMask_9; - wire [0:0] _zz_roundFront_exactMask_10; - wire [1:0] _zz_roundFront_exactMask_11; - wire [24:0] _zz_roundFront_roundAdjusted; - wire [23:0] _zz_roundFront_roundAdjusted_1; - wire [24:0] _zz__zz_roundFront_mantissaIncrement; - wire [22:0] _zz__zz_roundFront_mantissaIncrement_1; - wire [22:0] _zz_roundBack_adderMantissa; - wire [23:0] _zz_roundBack_adderRightOp; - wire [23:0] _zz_roundBack_adderRightOp_1; - wire [31:0] _zz_roundBack_adder_2; - wire [31:0] _zz_roundBack_adder_3; - wire [31:0] _zz_roundBack_adder_4; - wire [8:0] _zz_roundBack_borringCase; - wire [8:0] _zz_when_FpuCore_l1608; - wire [8:0] _zz_when_FpuCore_l1630; - wire [33:0] _zz_rf_ram_port; - reg _zz_1; - reg [25:0] add_shifter_yMantissa_5; - reg [25:0] add_shifter_yMantissa_4; - reg [25:0] add_shifter_yMantissa_3; - reg [25:0] add_shifter_yMantissa_2; - reg [25:0] add_shifter_yMantissa_1; - reg [32:0] shortPip_fsm_shift_input_6; - reg [32:0] shortPip_fsm_shift_input_5; - reg [32:0] shortPip_fsm_shift_input_4; - reg [32:0] shortPip_fsm_shift_input_3; - reg [32:0] shortPip_fsm_shift_input_2; - reg [32:0] shortPip_fsm_shift_input_1; - reg [31:0] load_s1_fsm_shift_input_5; - reg [31:0] load_s1_fsm_shift_input_4; - reg [31:0] load_s1_fsm_shift_input_3; - reg [31:0] load_s1_fsm_shift_input_2; - reg [31:0] load_s1_fsm_shift_input_1; - reg _zz_2; - reg _zz_3; - reg _zz_4; - reg [5:0] rf_init_counter; - wire rf_init_done; - wire when_FpuCore_l163; - reg rf_scoreboards_0_targetWrite_valid; - reg [4:0] rf_scoreboards_0_targetWrite_payload_address; - reg rf_scoreboards_0_targetWrite_payload_data; - reg rf_scoreboards_0_hitWrite_valid; - reg [4:0] rf_scoreboards_0_hitWrite_payload_address; - reg rf_scoreboards_0_hitWrite_payload_data; - wire commitFork_load_0_valid; - reg commitFork_load_0_ready; - wire [3:0] commitFork_load_0_payload_opcode; - wire [4:0] commitFork_load_0_payload_rd; - wire commitFork_load_0_payload_write; - wire [31:0] commitFork_load_0_payload_value; - wire commitFork_commit_0_valid; - wire commitFork_commit_0_ready; - wire [3:0] commitFork_commit_0_payload_opcode; - wire [4:0] commitFork_commit_0_payload_rd; - wire commitFork_commit_0_payload_write; - wire [31:0] commitFork_commit_0_payload_value; - wire streamFork_1_io_outputs_1_s2mPipe_valid; - wire streamFork_1_io_outputs_1_s2mPipe_ready; - wire [3:0] streamFork_1_io_outputs_1_s2mPipe_payload_opcode; - wire [4:0] streamFork_1_io_outputs_1_s2mPipe_payload_rd; - wire streamFork_1_io_outputs_1_s2mPipe_payload_write; - wire [31:0] streamFork_1_io_outputs_1_s2mPipe_payload_value; - reg streamFork_1_io_outputs_1_rValid; - reg [3:0] streamFork_1_io_outputs_1_rData_opcode; - reg [4:0] streamFork_1_io_outputs_1_rData_rd; - reg streamFork_1_io_outputs_1_rData_write; - reg [31:0] streamFork_1_io_outputs_1_rData_value; - wire [3:0] _zz_payload_opcode; - reg [3:0] commitLogic_0_pending_counter; - wire commitLogic_0_pending_full; - wire commitLogic_0_pending_notEmpty; - reg commitLogic_0_pending_inc; - reg commitLogic_0_pending_dec; - reg [3:0] commitLogic_0_add_counter; - wire commitLogic_0_add_full; - wire commitLogic_0_add_notEmpty; - reg commitLogic_0_add_inc; - reg commitLogic_0_add_dec; - reg [3:0] commitLogic_0_mul_counter; - wire commitLogic_0_mul_full; - wire commitLogic_0_mul_notEmpty; - reg commitLogic_0_mul_inc; - reg commitLogic_0_mul_dec; - reg [3:0] commitLogic_0_div_counter; - wire commitLogic_0_div_full; - wire commitLogic_0_div_notEmpty; - reg commitLogic_0_div_inc; - reg commitLogic_0_div_dec; - reg [3:0] commitLogic_0_sqrt_counter; - wire commitLogic_0_sqrt_full; - wire commitLogic_0_sqrt_notEmpty; - reg commitLogic_0_sqrt_inc; - reg commitLogic_0_sqrt_dec; - reg [3:0] commitLogic_0_short_counter; - wire commitLogic_0_short_full; - wire commitLogic_0_short_notEmpty; - reg commitLogic_0_short_inc; - reg commitLogic_0_short_dec; - wire _zz_commitFork_commit_0_ready; - wire [3:0] _zz_commitLogic_0_input_payload_opcode; - wire commitLogic_0_input_valid; - wire [3:0] commitLogic_0_input_payload_opcode; - wire [4:0] commitLogic_0_input_payload_rd; - wire commitLogic_0_input_payload_write; - wire [31:0] commitLogic_0_input_payload_value; - wire when_FpuCore_l208; - wire when_FpuCore_l209; - wire when_FpuCore_l210; - wire when_FpuCore_l211; - wire when_FpuCore_l212; - wire scheduler_0_input_valid; - wire scheduler_0_input_ready; - wire [3:0] scheduler_0_input_payload_opcode; - wire [1:0] scheduler_0_input_payload_arg; - wire [4:0] scheduler_0_input_payload_rs1; - wire [4:0] scheduler_0_input_payload_rs2; - wire [4:0] scheduler_0_input_payload_rs3; - wire [4:0] scheduler_0_input_payload_rd; - wire [0:0] scheduler_0_input_payload_format; - wire [2:0] scheduler_0_input_payload_roundMode; - reg io_port_0_cmd_rValid; - reg [3:0] io_port_0_cmd_rData_opcode; - reg [1:0] io_port_0_cmd_rData_arg; - reg [4:0] io_port_0_cmd_rData_rs1; - reg [4:0] io_port_0_cmd_rData_rs2; - reg [4:0] io_port_0_cmd_rData_rs3; - reg [4:0] io_port_0_cmd_rData_rd; - reg [0:0] io_port_0_cmd_rData_format; - reg [2:0] io_port_0_cmd_rData_roundMode; - wire [3:0] _zz_scheduler_0_input_payload_opcode; - wire [0:0] _zz_scheduler_0_input_payload_format; - wire [2:0] _zz_scheduler_0_input_payload_roundMode; - reg scheduler_0_useRs1; - reg scheduler_0_useRs2; - reg scheduler_0_useRs3; - reg scheduler_0_useRd; - wire scheduler_0_rfHits_0; - wire scheduler_0_rfHits_1; - wire scheduler_0_rfHits_2; - wire scheduler_0_rfHits_3; - wire scheduler_0_rfTargets_0; - wire scheduler_0_rfTargets_1; - wire scheduler_0_rfTargets_2; - wire scheduler_0_rfTargets_3; - wire scheduler_0_rfBusy_0; - wire scheduler_0_rfBusy_1; - wire scheduler_0_rfBusy_2; - wire scheduler_0_rfBusy_3; - wire scheduler_0_hits_0; - wire scheduler_0_hits_1; - wire scheduler_0_hits_2; - wire scheduler_0_hits_3; - wire scheduler_0_hazard; - wire _zz_scheduler_0_input_ready; - wire scheduler_0_output_valid; - wire scheduler_0_output_ready; - wire [3:0] scheduler_0_output_payload_opcode; - wire [1:0] scheduler_0_output_payload_arg; - reg [4:0] scheduler_0_output_payload_rs1; - wire [4:0] scheduler_0_output_payload_rs2; - wire [4:0] scheduler_0_output_payload_rs3; - wire [4:0] scheduler_0_output_payload_rd; - wire [0:0] scheduler_0_output_payload_format; - wire [2:0] scheduler_0_output_payload_roundMode; - wire when_FpuCore_l258; - wire when_FpuCore_l261; - wire scheduler_0_output_fire; - wire when_FpuCore_l265; - wire [3:0] _zz_io_inputs_0_payload_opcode; - wire [0:0] _zz_io_inputs_0_payload_format; - wire [2:0] _zz_io_inputs_0_payload_roundMode; - wire cmdArbiter_output_valid; - wire cmdArbiter_output_ready; - wire [3:0] cmdArbiter_output_payload_opcode; - wire [4:0] cmdArbiter_output_payload_rs1; - wire [4:0] cmdArbiter_output_payload_rs2; - wire [4:0] cmdArbiter_output_payload_rs3; - wire [4:0] cmdArbiter_output_payload_rd; - wire [1:0] cmdArbiter_output_payload_arg; - wire [2:0] cmdArbiter_output_payload_roundMode; - wire read_s0_valid; - reg read_s0_ready; - wire [3:0] read_s0_payload_opcode; - wire [4:0] read_s0_payload_rs1; - wire [4:0] read_s0_payload_rs2; - wire [4:0] read_s0_payload_rs3; - wire [4:0] read_s0_payload_rd; - wire [1:0] read_s0_payload_arg; - wire [2:0] read_s0_payload_roundMode; - wire read_s1_valid; - wire read_s1_ready; - wire [3:0] read_s1_payload_opcode; - wire [4:0] read_s1_payload_rs1; - wire [4:0] read_s1_payload_rs2; - wire [4:0] read_s1_payload_rs3; - wire [4:0] read_s1_payload_rd; - wire [1:0] read_s1_payload_arg; - wire [2:0] read_s1_payload_roundMode; - reg read_s0_rValid; - reg [3:0] read_s0_rData_opcode; - reg [4:0] read_s0_rData_rs1; - reg [4:0] read_s0_rData_rs2; - reg [4:0] read_s0_rData_rs3; - reg [4:0] read_s0_rData_rd; - reg [1:0] read_s0_rData_arg; - reg [2:0] read_s0_rData_roundMode; - wire when_Stream_l368; - wire read_output_valid; - wire read_output_ready; - wire [3:0] read_output_payload_opcode; - wire [22:0] read_output_payload_rs1_mantissa; - wire [8:0] read_output_payload_rs1_exponent; - wire read_output_payload_rs1_sign; - wire read_output_payload_rs1_special; - wire [22:0] read_output_payload_rs2_mantissa; - wire [8:0] read_output_payload_rs2_exponent; - wire read_output_payload_rs2_sign; - wire read_output_payload_rs2_special; - wire [22:0] read_output_payload_rs3_mantissa; - wire [8:0] read_output_payload_rs3_exponent; - wire read_output_payload_rs3_sign; - wire read_output_payload_rs3_special; - wire [4:0] read_output_payload_rd; - wire [1:0] read_output_payload_arg; - wire [2:0] read_output_payload_roundMode; - wire [4:0] _zz_read_rs_0_value_mantissa; - wire read_output_isStall; - wire _zz_read_rs_0_value_mantissa_1; - wire [22:0] read_rs_0_value_mantissa; - wire [8:0] read_rs_0_value_exponent; - wire read_rs_0_value_sign; - wire read_rs_0_value_special; - wire [33:0] _zz_read_rs_0_value_mantissa_2; - wire [4:0] _zz_read_rs_1_value_mantissa; - wire read_output_isStall_1; - wire _zz_read_rs_1_value_mantissa_1; - wire [22:0] read_rs_1_value_mantissa; - wire [8:0] read_rs_1_value_exponent; - wire read_rs_1_value_sign; - wire read_rs_1_value_special; - wire [33:0] _zz_read_rs_1_value_mantissa_2; - wire [4:0] _zz_read_rs_2_value_mantissa; - wire read_output_isStall_2; - wire _zz_read_rs_2_value_mantissa_1; - wire [22:0] read_rs_2_value_mantissa; - wire [8:0] read_rs_2_value_exponent; - wire read_rs_2_value_sign; - wire read_rs_2_value_special; - wire [33:0] _zz_read_rs_2_value_mantissa_2; - wire decode_input_valid; - reg decode_input_ready; - wire [3:0] decode_input_payload_opcode; - wire [22:0] decode_input_payload_rs1_mantissa; - wire [8:0] decode_input_payload_rs1_exponent; - wire decode_input_payload_rs1_sign; - wire decode_input_payload_rs1_special; - wire [22:0] decode_input_payload_rs2_mantissa; - wire [8:0] decode_input_payload_rs2_exponent; - wire decode_input_payload_rs2_sign; - wire decode_input_payload_rs2_special; - wire [22:0] decode_input_payload_rs3_mantissa; - wire [8:0] decode_input_payload_rs3_exponent; - wire decode_input_payload_rs3_sign; - wire decode_input_payload_rs3_special; - wire [4:0] decode_input_payload_rd; - wire [1:0] decode_input_payload_arg; - wire [2:0] decode_input_payload_roundMode; - wire decode_loadHit; - wire decode_load_valid; - wire decode_load_ready; - wire [4:0] decode_load_payload_rd; - wire decode_load_payload_i2f; - wire [1:0] decode_load_payload_arg; - wire [2:0] decode_load_payload_roundMode; - wire when_FpuCore_l329; - wire decode_shortPipHit; - wire decode_shortPip_valid; - reg decode_shortPip_ready; - wire [3:0] decode_shortPip_payload_opcode; - wire [22:0] decode_shortPip_payload_rs1_mantissa; - wire [8:0] decode_shortPip_payload_rs1_exponent; - wire decode_shortPip_payload_rs1_sign; - wire decode_shortPip_payload_rs1_special; - wire [22:0] decode_shortPip_payload_rs2_mantissa; - wire [8:0] decode_shortPip_payload_rs2_exponent; - wire decode_shortPip_payload_rs2_sign; - wire decode_shortPip_payload_rs2_special; - wire [4:0] decode_shortPip_payload_rd; - wire [31:0] decode_shortPip_payload_value; - wire [1:0] decode_shortPip_payload_arg; - wire [2:0] decode_shortPip_payload_roundMode; - wire when_FpuCore_l335; - wire decode_divSqrtHit; - wire decode_divSqrt_valid; - wire decode_divSqrt_ready; - wire [22:0] decode_divSqrt_payload_rs1_mantissa; - wire [8:0] decode_divSqrt_payload_rs1_exponent; - wire decode_divSqrt_payload_rs1_sign; - wire decode_divSqrt_payload_rs1_special; - wire [22:0] decode_divSqrt_payload_rs2_mantissa; - wire [8:0] decode_divSqrt_payload_rs2_exponent; - wire decode_divSqrt_payload_rs2_sign; - wire decode_divSqrt_payload_rs2_special; - wire [4:0] decode_divSqrt_payload_rd; - wire decode_divSqrt_payload_div; - wire [2:0] decode_divSqrt_payload_roundMode; - wire decode_divHit; - wire decode_div_valid; - wire decode_div_ready; - wire [22:0] decode_div_payload_rs1_mantissa; - wire [8:0] decode_div_payload_rs1_exponent; - wire decode_div_payload_rs1_sign; - wire decode_div_payload_rs1_special; - wire [22:0] decode_div_payload_rs2_mantissa; - wire [8:0] decode_div_payload_rs2_exponent; - wire decode_div_payload_rs2_sign; - wire decode_div_payload_rs2_special; - wire [4:0] decode_div_payload_rd; - wire [2:0] decode_div_payload_roundMode; - wire when_FpuCore_l351; - wire decode_sqrtHit; - wire decode_sqrt_valid; - wire decode_sqrt_ready; - wire [22:0] decode_sqrt_payload_rs1_mantissa; - wire [8:0] decode_sqrt_payload_rs1_exponent; - wire decode_sqrt_payload_rs1_sign; - wire decode_sqrt_payload_rs1_special; - wire [4:0] decode_sqrt_payload_rd; - wire [2:0] decode_sqrt_payload_roundMode; - wire when_FpuCore_l359; - wire decode_fmaHit; - wire decode_mulHit; - wire decode_mul_valid; - reg decode_mul_ready; - reg [22:0] decode_mul_payload_rs1_mantissa; - reg [8:0] decode_mul_payload_rs1_exponent; - reg decode_mul_payload_rs1_sign; - reg decode_mul_payload_rs1_special; - reg [22:0] decode_mul_payload_rs2_mantissa; - reg [8:0] decode_mul_payload_rs2_exponent; - reg decode_mul_payload_rs2_sign; - reg decode_mul_payload_rs2_special; - reg [22:0] decode_mul_payload_rs3_mantissa; - reg [8:0] decode_mul_payload_rs3_exponent; - reg decode_mul_payload_rs3_sign; - reg decode_mul_payload_rs3_special; - reg [4:0] decode_mul_payload_rd; - reg decode_mul_payload_add; - reg decode_mul_payload_divSqrt; - reg decode_mul_payload_msb1; - reg decode_mul_payload_msb2; - reg [2:0] decode_mul_payload_roundMode; - wire decode_divSqrtToMul_valid; - wire decode_divSqrtToMul_ready; - wire [22:0] decode_divSqrtToMul_payload_rs1_mantissa; - wire [8:0] decode_divSqrtToMul_payload_rs1_exponent; - wire decode_divSqrtToMul_payload_rs1_sign; - wire decode_divSqrtToMul_payload_rs1_special; - wire [22:0] decode_divSqrtToMul_payload_rs2_mantissa; - wire [8:0] decode_divSqrtToMul_payload_rs2_exponent; - wire decode_divSqrtToMul_payload_rs2_sign; - wire decode_divSqrtToMul_payload_rs2_special; - wire [22:0] decode_divSqrtToMul_payload_rs3_mantissa; - wire [8:0] decode_divSqrtToMul_payload_rs3_exponent; - wire decode_divSqrtToMul_payload_rs3_sign; - wire decode_divSqrtToMul_payload_rs3_special; - wire [4:0] decode_divSqrtToMul_payload_rd; - wire decode_divSqrtToMul_payload_add; - wire decode_divSqrtToMul_payload_divSqrt; - wire decode_divSqrtToMul_payload_msb1; - wire decode_divSqrtToMul_payload_msb2; - wire [2:0] decode_divSqrtToMul_payload_roundMode; - wire when_FpuCore_l375; - wire when_FpuCore_l380; - wire decode_addHit; - wire decode_add_valid; - wire decode_add_ready; - reg [24:0] decode_add_payload_rs1_mantissa; - reg [8:0] decode_add_payload_rs1_exponent; - reg decode_add_payload_rs1_sign; - reg decode_add_payload_rs1_special; - reg [24:0] decode_add_payload_rs2_mantissa; - reg [8:0] decode_add_payload_rs2_exponent; - reg decode_add_payload_rs2_sign; - reg decode_add_payload_rs2_special; - reg [4:0] decode_add_payload_rd; - reg [2:0] decode_add_payload_roundMode; - reg decode_add_payload_needCommit; - wire decode_mulToAdd_valid; - wire decode_mulToAdd_ready; - wire [24:0] decode_mulToAdd_payload_rs1_mantissa; - wire [8:0] decode_mulToAdd_payload_rs1_exponent; - wire decode_mulToAdd_payload_rs1_sign; - wire decode_mulToAdd_payload_rs1_special; - wire [24:0] decode_mulToAdd_payload_rs2_mantissa; - wire [8:0] decode_mulToAdd_payload_rs2_exponent; - wire decode_mulToAdd_payload_rs2_sign; - wire decode_mulToAdd_payload_rs2_special; - wire [4:0] decode_mulToAdd_payload_rd; - wire [2:0] decode_mulToAdd_payload_roundMode; - wire decode_mulToAdd_payload_needCommit; - wire when_FpuCore_l399; - wire when_FpuCore_l404; - wire decode_load_s2mPipe_valid; - reg decode_load_s2mPipe_ready; - wire [4:0] decode_load_s2mPipe_payload_rd; - wire decode_load_s2mPipe_payload_i2f; - wire [1:0] decode_load_s2mPipe_payload_arg; - wire [2:0] decode_load_s2mPipe_payload_roundMode; - reg decode_load_rValid; - reg [4:0] decode_load_rData_rd; - reg decode_load_rData_i2f; - reg [1:0] decode_load_rData_arg; - reg [2:0] decode_load_rData_roundMode; - wire [2:0] _zz_decode_load_s2mPipe_payload_roundMode; - wire decode_load_s2mPipe_m2sPipe_valid; - reg decode_load_s2mPipe_m2sPipe_ready; - wire [4:0] decode_load_s2mPipe_m2sPipe_payload_rd; - wire decode_load_s2mPipe_m2sPipe_payload_i2f; - wire [1:0] decode_load_s2mPipe_m2sPipe_payload_arg; - wire [2:0] decode_load_s2mPipe_m2sPipe_payload_roundMode; - reg decode_load_s2mPipe_rValid; - reg [4:0] decode_load_s2mPipe_rData_rd; - reg decode_load_s2mPipe_rData_i2f; - reg [1:0] decode_load_s2mPipe_rData_arg; - reg [2:0] decode_load_s2mPipe_rData_roundMode; - wire when_Stream_l368_1; - wire load_s0_input_valid; - wire load_s0_input_ready; - wire [4:0] load_s0_input_payload_rd; - wire load_s0_input_payload_i2f; - wire [1:0] load_s0_input_payload_arg; - wire [2:0] load_s0_input_payload_roundMode; - reg decode_load_s2mPipe_m2sPipe_rValid; - reg [4:0] decode_load_s2mPipe_m2sPipe_rData_rd; - reg decode_load_s2mPipe_m2sPipe_rData_i2f; - reg [1:0] decode_load_s2mPipe_m2sPipe_rData_arg; - reg [2:0] decode_load_s2mPipe_m2sPipe_rData_roundMode; - wire when_Stream_l368_2; - wire when_Stream_l438; - reg load_s0_filtred_0_valid; - reg load_s0_filtred_0_ready; - wire [3:0] load_s0_filtred_0_payload_opcode; - wire [4:0] load_s0_filtred_0_payload_rd; - wire load_s0_filtred_0_payload_write; - wire [31:0] load_s0_filtred_0_payload_value; - wire load_s0_hazard; - wire _zz_load_s0_input_ready; - wire load_s0_output_valid; - reg load_s0_output_ready; - wire [4:0] load_s0_output_payload_rd; - wire [31:0] load_s0_output_payload_value; - wire load_s0_output_payload_i2f; - wire [1:0] load_s0_output_payload_arg; - wire [2:0] load_s0_output_payload_roundMode; - wire load_s1_input_valid; - wire load_s1_input_ready; - wire [4:0] load_s1_input_payload_rd; - wire [31:0] load_s1_input_payload_value; - wire load_s1_input_payload_i2f; - wire [1:0] load_s1_input_payload_arg; - wire [2:0] load_s1_input_payload_roundMode; - reg load_s0_output_rValid; - reg [4:0] load_s0_output_rData_rd; - reg [31:0] load_s0_output_rData_value; - reg load_s0_output_rData_i2f; - reg [1:0] load_s0_output_rData_arg; - reg [2:0] load_s0_output_rData_roundMode; - wire when_Stream_l368_3; - reg load_s1_busy; - wire [22:0] load_s1_f32_mantissa; - wire [7:0] load_s1_f32_exponent; - wire load_s1_f32_sign; - wire [8:0] load_s1_recodedExpOffset; - wire [22:0] load_s1_passThroughFloat_mantissa; - wire [8:0] load_s1_passThroughFloat_exponent; - wire load_s1_passThroughFloat_sign; - wire load_s1_passThroughFloat_special; - wire load_s1_manZero; - wire load_s1_expZero; - wire load_s1_expOne; - wire load_s1_isZero; - wire load_s1_isSubnormal; - wire load_s1_isInfinity; - wire load_s1_isNan; - reg load_s1_fsm_done; - reg load_s1_fsm_boot; - reg load_s1_fsm_patched; - reg [31:0] load_s1_fsm_ohInput; - wire when_FpuCore_l508; - reg load_s1_fsm_i2fZero; - reg [4:0] load_s1_fsm_shift_by; - reg [31:0] load_s1_fsm_shift_input; - wire when_FpuCore_l525; - reg [31:0] load_s1_fsm_shift_output; - wire when_FpuCore_l529; - wire when_FpuCore_l532; - wire [31:0] _zz_load_s0_output_rData_value; - wire _zz_load_s0_output_rData_value_1; - wire [31:0] _zz_load_s1_fsm_shift_by; - wire [31:0] _zz_load_s1_fsm_shift_by_1; - wire _zz_load_s1_fsm_shift_by_2; - wire _zz_load_s1_fsm_shift_by_3; - wire _zz_load_s1_fsm_shift_by_4; - wire _zz_load_s1_fsm_shift_by_5; - wire _zz_load_s1_fsm_shift_by_6; - wire _zz_load_s1_fsm_shift_by_7; - wire _zz_load_s1_fsm_shift_by_8; - wire _zz_load_s1_fsm_shift_by_9; - wire _zz_load_s1_fsm_shift_by_10; - wire _zz_load_s1_fsm_shift_by_11; - wire _zz_load_s1_fsm_shift_by_12; - wire _zz_load_s1_fsm_shift_by_13; - wire _zz_load_s1_fsm_shift_by_14; - wire _zz_load_s1_fsm_shift_by_15; - wire _zz_load_s1_fsm_shift_by_16; - wire _zz_load_s1_fsm_shift_by_17; - wire _zz_load_s1_fsm_shift_by_18; - wire _zz_load_s1_fsm_shift_by_19; - wire _zz_load_s1_fsm_shift_by_20; - wire _zz_load_s1_fsm_shift_by_21; - wire _zz_load_s1_fsm_shift_by_22; - wire _zz_load_s1_fsm_shift_by_23; - wire _zz_load_s1_fsm_shift_by_24; - wire _zz_load_s1_fsm_shift_by_25; - wire _zz_load_s1_fsm_shift_by_26; - wire _zz_load_s1_fsm_shift_by_27; - wire _zz_load_s1_fsm_shift_by_28; - wire _zz_load_s1_fsm_shift_by_29; - wire _zz_load_s1_fsm_shift_by_30; - wire _zz_load_s1_fsm_shift_by_31; - wire _zz_load_s1_fsm_shift_by_32; - reg [8:0] load_s1_fsm_expOffset; - wire load_s1_input_isStall; - wire when_FpuCore_l551; - wire [23:0] load_s1_i2fHigh; - wire [7:0] load_s1_i2fLow; - wire load_s1_scrap; - wire [22:0] load_s1_recoded_mantissa; - reg [8:0] load_s1_recoded_exponent; - wire load_s1_recoded_sign; - reg load_s1_recoded_special; - wire _zz_load_s1_input_ready; - wire load_s1_output_valid; - reg load_s1_output_ready; - wire [4:0] load_s1_output_payload_rd; - reg [23:0] load_s1_output_payload_value_mantissa; - reg [8:0] load_s1_output_payload_value_exponent; - reg load_s1_output_payload_value_sign; - reg load_s1_output_payload_value_special; - reg load_s1_output_payload_scrap; - wire [2:0] load_s1_output_payload_roundMode; - wire load_s1_output_payload_NV; - wire load_s1_output_payload_DZ; - wire when_FpuCore_l594; - wire shortPip_input_valid; - wire shortPip_input_ready; - wire [3:0] shortPip_input_payload_opcode; - wire [22:0] shortPip_input_payload_rs1_mantissa; - wire [8:0] shortPip_input_payload_rs1_exponent; - wire shortPip_input_payload_rs1_sign; - wire shortPip_input_payload_rs1_special; - wire [22:0] shortPip_input_payload_rs2_mantissa; - wire [8:0] shortPip_input_payload_rs2_exponent; - wire shortPip_input_payload_rs2_sign; - wire shortPip_input_payload_rs2_special; - wire [4:0] shortPip_input_payload_rd; - wire [31:0] shortPip_input_payload_value; - wire [1:0] shortPip_input_payload_arg; - wire [2:0] shortPip_input_payload_roundMode; - reg decode_shortPip_rValid; - reg [3:0] decode_shortPip_rData_opcode; - reg [22:0] decode_shortPip_rData_rs1_mantissa; - reg [8:0] decode_shortPip_rData_rs1_exponent; - reg decode_shortPip_rData_rs1_sign; - reg decode_shortPip_rData_rs1_special; - reg [22:0] decode_shortPip_rData_rs2_mantissa; - reg [8:0] decode_shortPip_rData_rs2_exponent; - reg decode_shortPip_rData_rs2_sign; - reg decode_shortPip_rData_rs2_special; - reg [4:0] decode_shortPip_rData_rd; - reg [31:0] decode_shortPip_rData_value; - reg [1:0] decode_shortPip_rData_arg; - reg [2:0] decode_shortPip_rData_roundMode; - wire when_Stream_l368_4; - wire shortPip_toFpuRf; - wire shortPip_rfOutput_valid; - wire shortPip_rfOutput_ready; - wire [4:0] shortPip_rfOutput_payload_rd; - reg [23:0] shortPip_rfOutput_payload_value_mantissa; - reg [8:0] shortPip_rfOutput_payload_value_exponent; - reg shortPip_rfOutput_payload_value_sign; - reg shortPip_rfOutput_payload_value_special; - wire shortPip_rfOutput_payload_scrap; - wire [2:0] shortPip_rfOutput_payload_roundMode; - wire shortPip_rfOutput_payload_NV; - wire shortPip_rfOutput_payload_DZ; - wire shortPip_input_fire; - wire when_FpuCore_l221; - wire shortPip_isCommited; - wire _zz_shortPip_rfOutput_ready; - wire shortPip_output_valid; - reg shortPip_output_ready; - wire [4:0] shortPip_output_payload_rd; - wire [23:0] shortPip_output_payload_value_mantissa; - wire [8:0] shortPip_output_payload_value_exponent; - wire shortPip_output_payload_value_sign; - wire shortPip_output_payload_value_special; - wire shortPip_output_payload_scrap; - wire [2:0] shortPip_output_payload_roundMode; - wire shortPip_output_payload_NV; - wire shortPip_output_payload_DZ; - reg [31:0] shortPip_result; - reg shortPip_halt; - reg [31:0] shortPip_recodedResult; - wire [7:0] shortPip_f32_exp; - wire [22:0] shortPip_f32_man; - wire [7:0] shortPip_expSubnormalThreshold; - wire shortPip_expInSubnormalRange; - wire shortPip_isSubnormal; - wire shortPip_isNormal; - wire [8:0] shortPip_fsm_f2iShift; - wire shortPip_fsm_isF2i; - wire shortPip_fsm_needRecoding; - reg shortPip_fsm_done; - reg shortPip_fsm_boot; - wire shortPip_fsm_isZero; - reg [5:0] shortPip_fsm_shift_by; - reg [32:0] shortPip_fsm_shift_input; - reg shortPip_fsm_shift_scrap; - wire when_FpuCore_l646; - wire when_FpuCore_l646_1; - wire when_FpuCore_l646_2; - wire when_FpuCore_l646_3; - wire when_FpuCore_l646_4; - wire when_FpuCore_l646_5; - wire when_FpuCore_l652; - reg [32:0] shortPip_fsm_shift_output; - wire [7:0] shortPip_fsm_formatShiftOffset; - wire when_FpuCore_l658; - wire [8:0] _zz_shortPip_fsm_shift_by; - wire [5:0] _zz_shortPip_fsm_shift_by_1; - wire shortPip_input_isStall; - wire when_FpuCore_l672; - reg shortPip_mantissaForced; - reg shortPip_exponentForced; - reg shortPip_mantissaForcedValue; - reg shortPip_exponentForcedValue; - reg shortPip_cononicalForced; - wire [1:0] switch_FpuCore_l686; - wire when_FpuCore_l702; - reg shortPip_rspNv; - reg shortPip_rspNx; - wire [31:0] shortPip_f2i_unsigned; - wire shortPip_f2i_resign; - wire [1:0] shortPip_f2i_round; - reg shortPip_f2i_increment; - reg [31:0] shortPip_f2i_result; - wire shortPip_f2i_overflow; - wire shortPip_f2i_underflow; - wire shortPip_f2i_isZero; - wire when_FpuCore_l767; - wire shortPip_bothZero; - reg shortPip_rs1Equal; - reg shortPip_rs1AbsSmaller; - wire when_FpuCore_l780; - wire when_FpuCore_l781; - wire when_FpuCore_l782; - wire when_FpuCore_l783; - wire when_FpuCore_l784; - wire [1:0] switch_Misc_l210; - reg shortPip_rs1Smaller; - wire shortPip_minMaxSelectRs2; - wire shortPip_minMaxSelectNanQuiet; - reg [0:0] shortPip_cmpResult; - wire when_FpuCore_l796; - wire shortPip_sgnjRs1Sign; - wire shortPip_sgnjRs2Sign; - wire shortPip_sgnjResult; - reg [31:0] shortPip_fclassResult; - wire shortPip_decoded_isNan; - wire shortPip_decoded_isNormal; - wire shortPip_decoded_isSubnormal; - wire shortPip_decoded_isZero; - wire shortPip_decoded_isInfinity; - wire shortPip_decoded_isQuiet; - wire when_FpuCore_l850; - wire shortPip_signalQuiet; - wire shortPip_rs1Nan; - wire shortPip_rs2Nan; - wire shortPip_rs1NanNv; - wire shortPip_rs2NanNv; - wire shortPip_NV; - wire shortPip_rspStreams_0_valid; - reg shortPip_rspStreams_0_ready; - wire [31:0] shortPip_rspStreams_0_payload_value; - wire shortPip_rspStreams_0_payload_NV; - wire shortPip_rspStreams_0_payload_NX; - wire shortPip_rspStreams_0_m2sPipe_valid; - wire shortPip_rspStreams_0_m2sPipe_ready; - wire [31:0] shortPip_rspStreams_0_m2sPipe_payload_value; - wire shortPip_rspStreams_0_m2sPipe_payload_NV; - wire shortPip_rspStreams_0_m2sPipe_payload_NX; - reg shortPip_rspStreams_0_rValid; - reg [31:0] shortPip_rspStreams_0_rData_value; - reg shortPip_rspStreams_0_rData_NV; - reg shortPip_rspStreams_0_rData_NX; - wire when_Stream_l368_5; - wire mul_preMul_input_valid; - wire mul_preMul_input_ready; - wire [22:0] mul_preMul_input_payload_rs1_mantissa; - wire [8:0] mul_preMul_input_payload_rs1_exponent; - wire mul_preMul_input_payload_rs1_sign; - wire mul_preMul_input_payload_rs1_special; - wire [22:0] mul_preMul_input_payload_rs2_mantissa; - wire [8:0] mul_preMul_input_payload_rs2_exponent; - wire mul_preMul_input_payload_rs2_sign; - wire mul_preMul_input_payload_rs2_special; - wire [22:0] mul_preMul_input_payload_rs3_mantissa; - wire [8:0] mul_preMul_input_payload_rs3_exponent; - wire mul_preMul_input_payload_rs3_sign; - wire mul_preMul_input_payload_rs3_special; - wire [4:0] mul_preMul_input_payload_rd; - wire mul_preMul_input_payload_add; - wire mul_preMul_input_payload_divSqrt; - wire mul_preMul_input_payload_msb1; - wire mul_preMul_input_payload_msb2; - wire [2:0] mul_preMul_input_payload_roundMode; - reg decode_mul_rValid; - reg [22:0] decode_mul_rData_rs1_mantissa; - reg [8:0] decode_mul_rData_rs1_exponent; - reg decode_mul_rData_rs1_sign; - reg decode_mul_rData_rs1_special; - reg [22:0] decode_mul_rData_rs2_mantissa; - reg [8:0] decode_mul_rData_rs2_exponent; - reg decode_mul_rData_rs2_sign; - reg decode_mul_rData_rs2_special; - reg [22:0] decode_mul_rData_rs3_mantissa; - reg [8:0] decode_mul_rData_rs3_exponent; - reg decode_mul_rData_rs3_sign; - reg decode_mul_rData_rs3_special; - reg [4:0] decode_mul_rData_rd; - reg decode_mul_rData_add; - reg decode_mul_rData_divSqrt; - reg decode_mul_rData_msb1; - reg decode_mul_rData_msb2; - reg [2:0] decode_mul_rData_roundMode; - wire when_Stream_l368_6; - wire mul_preMul_output_valid; - reg mul_preMul_output_ready; - wire [22:0] mul_preMul_output_payload_rs1_mantissa; - wire [8:0] mul_preMul_output_payload_rs1_exponent; - wire mul_preMul_output_payload_rs1_sign; - wire mul_preMul_output_payload_rs1_special; - wire [22:0] mul_preMul_output_payload_rs2_mantissa; - wire [8:0] mul_preMul_output_payload_rs2_exponent; - wire mul_preMul_output_payload_rs2_sign; - wire mul_preMul_output_payload_rs2_special; - wire [22:0] mul_preMul_output_payload_rs3_mantissa; - wire [8:0] mul_preMul_output_payload_rs3_exponent; - wire mul_preMul_output_payload_rs3_sign; - wire mul_preMul_output_payload_rs3_special; - wire [4:0] mul_preMul_output_payload_rd; - wire mul_preMul_output_payload_add; - wire mul_preMul_output_payload_divSqrt; - wire mul_preMul_output_payload_msb1; - wire mul_preMul_output_payload_msb2; - wire [2:0] mul_preMul_output_payload_roundMode; - wire [9:0] mul_preMul_output_payload_exp; - wire mul_mul_input_valid; - wire mul_mul_input_ready; - wire [22:0] mul_mul_input_payload_rs1_mantissa; - wire [8:0] mul_mul_input_payload_rs1_exponent; - wire mul_mul_input_payload_rs1_sign; - wire mul_mul_input_payload_rs1_special; - wire [22:0] mul_mul_input_payload_rs2_mantissa; - wire [8:0] mul_mul_input_payload_rs2_exponent; - wire mul_mul_input_payload_rs2_sign; - wire mul_mul_input_payload_rs2_special; - wire [22:0] mul_mul_input_payload_rs3_mantissa; - wire [8:0] mul_mul_input_payload_rs3_exponent; - wire mul_mul_input_payload_rs3_sign; - wire mul_mul_input_payload_rs3_special; - wire [4:0] mul_mul_input_payload_rd; - wire mul_mul_input_payload_add; - wire mul_mul_input_payload_divSqrt; - wire mul_mul_input_payload_msb1; - wire mul_mul_input_payload_msb2; - wire [2:0] mul_mul_input_payload_roundMode; - wire [9:0] mul_mul_input_payload_exp; - reg mul_preMul_output_rValid; - reg [22:0] mul_preMul_output_rData_rs1_mantissa; - reg [8:0] mul_preMul_output_rData_rs1_exponent; - reg mul_preMul_output_rData_rs1_sign; - reg mul_preMul_output_rData_rs1_special; - reg [22:0] mul_preMul_output_rData_rs2_mantissa; - reg [8:0] mul_preMul_output_rData_rs2_exponent; - reg mul_preMul_output_rData_rs2_sign; - reg mul_preMul_output_rData_rs2_special; - reg [22:0] mul_preMul_output_rData_rs3_mantissa; - reg [8:0] mul_preMul_output_rData_rs3_exponent; - reg mul_preMul_output_rData_rs3_sign; - reg mul_preMul_output_rData_rs3_special; - reg [4:0] mul_preMul_output_rData_rd; - reg mul_preMul_output_rData_add; - reg mul_preMul_output_rData_divSqrt; - reg mul_preMul_output_rData_msb1; - reg mul_preMul_output_rData_msb2; - reg [2:0] mul_preMul_output_rData_roundMode; - reg [9:0] mul_preMul_output_rData_exp; - wire when_Stream_l368_7; - wire mul_mul_output_valid; - reg mul_mul_output_ready; - wire [22:0] mul_mul_output_payload_rs1_mantissa; - wire [8:0] mul_mul_output_payload_rs1_exponent; - wire mul_mul_output_payload_rs1_sign; - wire mul_mul_output_payload_rs1_special; - wire [22:0] mul_mul_output_payload_rs2_mantissa; - wire [8:0] mul_mul_output_payload_rs2_exponent; - wire mul_mul_output_payload_rs2_sign; - wire mul_mul_output_payload_rs2_special; - wire [22:0] mul_mul_output_payload_rs3_mantissa; - wire [8:0] mul_mul_output_payload_rs3_exponent; - wire mul_mul_output_payload_rs3_sign; - wire mul_mul_output_payload_rs3_special; - wire [4:0] mul_mul_output_payload_rd; - wire mul_mul_output_payload_add; - wire mul_mul_output_payload_divSqrt; - wire mul_mul_output_payload_msb1; - wire mul_mul_output_payload_msb2; - wire [2:0] mul_mul_output_payload_roundMode; - wire [9:0] mul_mul_output_payload_exp; - wire [35:0] mul_mul_output_payload_muls_0; - wire [23:0] mul_mul_output_payload_muls_1; - wire [23:0] mul_mul_output_payload_muls_2; - wire [11:0] mul_mul_output_payload_muls_3; - wire [23:0] mul_mul_mulA; - wire [23:0] mul_mul_mulB; - wire mul_sum1_input_valid; - wire mul_sum1_input_ready; - wire [22:0] mul_sum1_input_payload_rs1_mantissa; - wire [8:0] mul_sum1_input_payload_rs1_exponent; - wire mul_sum1_input_payload_rs1_sign; - wire mul_sum1_input_payload_rs1_special; - wire [22:0] mul_sum1_input_payload_rs2_mantissa; - wire [8:0] mul_sum1_input_payload_rs2_exponent; - wire mul_sum1_input_payload_rs2_sign; - wire mul_sum1_input_payload_rs2_special; - wire [22:0] mul_sum1_input_payload_rs3_mantissa; - wire [8:0] mul_sum1_input_payload_rs3_exponent; - wire mul_sum1_input_payload_rs3_sign; - wire mul_sum1_input_payload_rs3_special; - wire [4:0] mul_sum1_input_payload_rd; - wire mul_sum1_input_payload_add; - wire mul_sum1_input_payload_divSqrt; - wire mul_sum1_input_payload_msb1; - wire mul_sum1_input_payload_msb2; - wire [2:0] mul_sum1_input_payload_roundMode; - wire [9:0] mul_sum1_input_payload_exp; - wire [35:0] mul_sum1_input_payload_muls_0; - wire [23:0] mul_sum1_input_payload_muls_1; - wire [23:0] mul_sum1_input_payload_muls_2; - wire [11:0] mul_sum1_input_payload_muls_3; - reg mul_mul_output_rValid; - reg [22:0] mul_mul_output_rData_rs1_mantissa; - reg [8:0] mul_mul_output_rData_rs1_exponent; - reg mul_mul_output_rData_rs1_sign; - reg mul_mul_output_rData_rs1_special; - reg [22:0] mul_mul_output_rData_rs2_mantissa; - reg [8:0] mul_mul_output_rData_rs2_exponent; - reg mul_mul_output_rData_rs2_sign; - reg mul_mul_output_rData_rs2_special; - reg [22:0] mul_mul_output_rData_rs3_mantissa; - reg [8:0] mul_mul_output_rData_rs3_exponent; - reg mul_mul_output_rData_rs3_sign; - reg mul_mul_output_rData_rs3_special; - reg [4:0] mul_mul_output_rData_rd; - reg mul_mul_output_rData_add; - reg mul_mul_output_rData_divSqrt; - reg mul_mul_output_rData_msb1; - reg mul_mul_output_rData_msb2; - reg [2:0] mul_mul_output_rData_roundMode; - reg [9:0] mul_mul_output_rData_exp; - reg [35:0] mul_mul_output_rData_muls_0; - reg [23:0] mul_mul_output_rData_muls_1; - reg [23:0] mul_mul_output_rData_muls_2; - reg [11:0] mul_mul_output_rData_muls_3; - wire when_Stream_l368_8; - wire [47:0] mul_sum1_sum; - wire mul_sum1_output_valid; - reg mul_sum1_output_ready; - wire [22:0] mul_sum1_output_payload_rs1_mantissa; - wire [8:0] mul_sum1_output_payload_rs1_exponent; - wire mul_sum1_output_payload_rs1_sign; - wire mul_sum1_output_payload_rs1_special; - wire [22:0] mul_sum1_output_payload_rs2_mantissa; - wire [8:0] mul_sum1_output_payload_rs2_exponent; - wire mul_sum1_output_payload_rs2_sign; - wire mul_sum1_output_payload_rs2_special; - wire [22:0] mul_sum1_output_payload_rs3_mantissa; - wire [8:0] mul_sum1_output_payload_rs3_exponent; - wire mul_sum1_output_payload_rs3_sign; - wire mul_sum1_output_payload_rs3_special; - wire [4:0] mul_sum1_output_payload_rd; - wire mul_sum1_output_payload_add; - wire mul_sum1_output_payload_divSqrt; - wire mul_sum1_output_payload_msb1; - wire mul_sum1_output_payload_msb2; - wire [2:0] mul_sum1_output_payload_roundMode; - wire [9:0] mul_sum1_output_payload_exp; - wire [23:0] mul_sum1_output_payload_muls2_0; - wire [11:0] mul_sum1_output_payload_muls2_1; - wire [47:0] mul_sum1_output_payload_mulC2; - wire mul_sum2_input_valid; - wire mul_sum2_input_ready; - wire [22:0] mul_sum2_input_payload_rs1_mantissa; - wire [8:0] mul_sum2_input_payload_rs1_exponent; - wire mul_sum2_input_payload_rs1_sign; - wire mul_sum2_input_payload_rs1_special; - wire [22:0] mul_sum2_input_payload_rs2_mantissa; - wire [8:0] mul_sum2_input_payload_rs2_exponent; - wire mul_sum2_input_payload_rs2_sign; - wire mul_sum2_input_payload_rs2_special; - wire [22:0] mul_sum2_input_payload_rs3_mantissa; - wire [8:0] mul_sum2_input_payload_rs3_exponent; - wire mul_sum2_input_payload_rs3_sign; - wire mul_sum2_input_payload_rs3_special; - wire [4:0] mul_sum2_input_payload_rd; - wire mul_sum2_input_payload_add; - wire mul_sum2_input_payload_divSqrt; - wire mul_sum2_input_payload_msb1; - wire mul_sum2_input_payload_msb2; - wire [2:0] mul_sum2_input_payload_roundMode; - wire [9:0] mul_sum2_input_payload_exp; - wire [23:0] mul_sum2_input_payload_muls2_0; - wire [11:0] mul_sum2_input_payload_muls2_1; - wire [47:0] mul_sum2_input_payload_mulC2; - reg mul_sum1_output_rValid; - reg [22:0] mul_sum1_output_rData_rs1_mantissa; - reg [8:0] mul_sum1_output_rData_rs1_exponent; - reg mul_sum1_output_rData_rs1_sign; - reg mul_sum1_output_rData_rs1_special; - reg [22:0] mul_sum1_output_rData_rs2_mantissa; - reg [8:0] mul_sum1_output_rData_rs2_exponent; - reg mul_sum1_output_rData_rs2_sign; - reg mul_sum1_output_rData_rs2_special; - reg [22:0] mul_sum1_output_rData_rs3_mantissa; - reg [8:0] mul_sum1_output_rData_rs3_exponent; - reg mul_sum1_output_rData_rs3_sign; - reg mul_sum1_output_rData_rs3_special; - reg [4:0] mul_sum1_output_rData_rd; - reg mul_sum1_output_rData_add; - reg mul_sum1_output_rData_divSqrt; - reg mul_sum1_output_rData_msb1; - reg mul_sum1_output_rData_msb2; - reg [2:0] mul_sum1_output_rData_roundMode; - reg [9:0] mul_sum1_output_rData_exp; - reg [23:0] mul_sum1_output_rData_muls2_0; - reg [11:0] mul_sum1_output_rData_muls2_1; - reg [47:0] mul_sum1_output_rData_mulC2; - wire when_Stream_l368_9; - wire [47:0] mul_sum2_sum; - wire mul_sum2_input_fire; - wire when_FpuCore_l221_1; - wire mul_sum2_isCommited; - wire _zz_mul_sum2_input_ready; - wire mul_sum2_output_valid; - reg mul_sum2_output_ready; - wire [22:0] mul_sum2_output_payload_rs1_mantissa; - wire [8:0] mul_sum2_output_payload_rs1_exponent; - wire mul_sum2_output_payload_rs1_sign; - wire mul_sum2_output_payload_rs1_special; - wire [22:0] mul_sum2_output_payload_rs2_mantissa; - wire [8:0] mul_sum2_output_payload_rs2_exponent; - wire mul_sum2_output_payload_rs2_sign; - wire mul_sum2_output_payload_rs2_special; - wire [22:0] mul_sum2_output_payload_rs3_mantissa; - wire [8:0] mul_sum2_output_payload_rs3_exponent; - wire mul_sum2_output_payload_rs3_sign; - wire mul_sum2_output_payload_rs3_special; - wire [4:0] mul_sum2_output_payload_rd; - wire mul_sum2_output_payload_add; - wire mul_sum2_output_payload_divSqrt; - wire mul_sum2_output_payload_msb1; - wire mul_sum2_output_payload_msb2; - wire [2:0] mul_sum2_output_payload_roundMode; - wire [9:0] mul_sum2_output_payload_exp; - wire [47:0] mul_sum2_output_payload_mulC; - wire mul_norm_input_valid; - wire mul_norm_input_ready; - wire [22:0] mul_norm_input_payload_rs1_mantissa; - wire [8:0] mul_norm_input_payload_rs1_exponent; - wire mul_norm_input_payload_rs1_sign; - wire mul_norm_input_payload_rs1_special; - wire [22:0] mul_norm_input_payload_rs2_mantissa; - wire [8:0] mul_norm_input_payload_rs2_exponent; - wire mul_norm_input_payload_rs2_sign; - wire mul_norm_input_payload_rs2_special; - wire [22:0] mul_norm_input_payload_rs3_mantissa; - wire [8:0] mul_norm_input_payload_rs3_exponent; - wire mul_norm_input_payload_rs3_sign; - wire mul_norm_input_payload_rs3_special; - wire [4:0] mul_norm_input_payload_rd; - wire mul_norm_input_payload_add; - wire mul_norm_input_payload_divSqrt; - wire mul_norm_input_payload_msb1; - wire mul_norm_input_payload_msb2; - wire [2:0] mul_norm_input_payload_roundMode; - wire [9:0] mul_norm_input_payload_exp; - wire [47:0] mul_norm_input_payload_mulC; - reg mul_sum2_output_rValid; - reg [22:0] mul_sum2_output_rData_rs1_mantissa; - reg [8:0] mul_sum2_output_rData_rs1_exponent; - reg mul_sum2_output_rData_rs1_sign; - reg mul_sum2_output_rData_rs1_special; - reg [22:0] mul_sum2_output_rData_rs2_mantissa; - reg [8:0] mul_sum2_output_rData_rs2_exponent; - reg mul_sum2_output_rData_rs2_sign; - reg mul_sum2_output_rData_rs2_special; - reg [22:0] mul_sum2_output_rData_rs3_mantissa; - reg [8:0] mul_sum2_output_rData_rs3_exponent; - reg mul_sum2_output_rData_rs3_sign; - reg mul_sum2_output_rData_rs3_special; - reg [4:0] mul_sum2_output_rData_rd; - reg mul_sum2_output_rData_add; - reg mul_sum2_output_rData_divSqrt; - reg mul_sum2_output_rData_msb1; - reg mul_sum2_output_rData_msb2; - reg [2:0] mul_sum2_output_rData_roundMode; - reg [9:0] mul_sum2_output_rData_exp; - reg [47:0] mul_sum2_output_rData_mulC; - wire when_Stream_l368_10; - wire [25:0] mul_norm_mulHigh; - wire [21:0] mul_norm_mulLow; - reg mul_norm_scrap; - wire mul_norm_needShift; - wire [9:0] mul_norm_exp; - wire [23:0] mul_norm_man; - wire when_FpuCore_l967; - wire mul_norm_forceZero; - wire [8:0] mul_norm_underflowThreshold; - wire [6:0] mul_norm_underflowExp; - wire mul_norm_forceUnderflow; - wire mul_norm_forceOverflow; - wire mul_norm_infinitynan; - wire mul_norm_forceNan; - reg [23:0] mul_norm_output_mantissa; - reg [8:0] mul_norm_output_exponent; - wire mul_norm_output_sign; - reg mul_norm_output_special; - reg mul_norm_NV; - wire when_FpuCore_l983; - wire when_FpuCore_l987; - wire mul_result_notMul_output_valid; - wire [23:0] mul_result_notMul_output_payload; - wire mul_result_output_valid; - wire mul_result_output_ready; - wire [4:0] mul_result_output_payload_rd; - wire [23:0] mul_result_output_payload_value_mantissa; - wire [8:0] mul_result_output_payload_value_exponent; - wire mul_result_output_payload_value_sign; - wire mul_result_output_payload_value_special; - wire mul_result_output_payload_scrap; - wire [2:0] mul_result_output_payload_roundMode; - wire mul_result_output_payload_NV; - wire mul_result_output_payload_DZ; - wire mul_result_mulToAdd_valid; - reg mul_result_mulToAdd_ready; - reg [24:0] mul_result_mulToAdd_payload_rs1_mantissa; - wire [8:0] mul_result_mulToAdd_payload_rs1_exponent; - wire mul_result_mulToAdd_payload_rs1_sign; - wire mul_result_mulToAdd_payload_rs1_special; - wire [24:0] mul_result_mulToAdd_payload_rs2_mantissa; - wire [8:0] mul_result_mulToAdd_payload_rs2_exponent; - wire mul_result_mulToAdd_payload_rs2_sign; - wire mul_result_mulToAdd_payload_rs2_special; - wire [4:0] mul_result_mulToAdd_payload_rd; - wire [2:0] mul_result_mulToAdd_payload_roundMode; - wire mul_result_mulToAdd_payload_needCommit; - wire mul_result_mulToAdd_m2sPipe_valid; - wire mul_result_mulToAdd_m2sPipe_ready; - wire [24:0] mul_result_mulToAdd_m2sPipe_payload_rs1_mantissa; - wire [8:0] mul_result_mulToAdd_m2sPipe_payload_rs1_exponent; - wire mul_result_mulToAdd_m2sPipe_payload_rs1_sign; - wire mul_result_mulToAdd_m2sPipe_payload_rs1_special; - wire [24:0] mul_result_mulToAdd_m2sPipe_payload_rs2_mantissa; - wire [8:0] mul_result_mulToAdd_m2sPipe_payload_rs2_exponent; - wire mul_result_mulToAdd_m2sPipe_payload_rs2_sign; - wire mul_result_mulToAdd_m2sPipe_payload_rs2_special; - wire [4:0] mul_result_mulToAdd_m2sPipe_payload_rd; - wire [2:0] mul_result_mulToAdd_m2sPipe_payload_roundMode; - wire mul_result_mulToAdd_m2sPipe_payload_needCommit; - reg mul_result_mulToAdd_rValid; - reg [24:0] mul_result_mulToAdd_rData_rs1_mantissa; - reg [8:0] mul_result_mulToAdd_rData_rs1_exponent; - reg mul_result_mulToAdd_rData_rs1_sign; - reg mul_result_mulToAdd_rData_rs1_special; - reg [24:0] mul_result_mulToAdd_rData_rs2_mantissa; - reg [8:0] mul_result_mulToAdd_rData_rs2_exponent; - reg mul_result_mulToAdd_rData_rs2_sign; - reg mul_result_mulToAdd_rData_rs2_special; - reg [4:0] mul_result_mulToAdd_rData_rd; - reg [2:0] mul_result_mulToAdd_rData_roundMode; - reg mul_result_mulToAdd_rData_needCommit; - wire when_Stream_l368_11; - wire div_input_valid; - wire div_input_ready; - wire [22:0] div_input_payload_rs1_mantissa; - wire [8:0] div_input_payload_rs1_exponent; - wire div_input_payload_rs1_sign; - wire div_input_payload_rs1_special; - wire [22:0] div_input_payload_rs2_mantissa; - wire [8:0] div_input_payload_rs2_exponent; - wire div_input_payload_rs2_sign; - wire div_input_payload_rs2_special; - wire [4:0] div_input_payload_rd; - wire [2:0] div_input_payload_roundMode; - reg decode_div_rValid; - wire div_input_fire; - reg [22:0] decode_div_rData_rs1_mantissa; - reg [8:0] decode_div_rData_rs1_exponent; - reg decode_div_rData_rs1_sign; - reg decode_div_rData_rs1_special; - reg [22:0] decode_div_rData_rs2_mantissa; - reg [8:0] decode_div_rData_rs2_exponent; - reg decode_div_rData_rs2_sign; - reg decode_div_rData_rs2_special; - reg [4:0] decode_div_rData_rd; - reg [2:0] decode_div_rData_roundMode; - reg div_haltIt; - wire div_input_fire_1; - wire when_FpuCore_l221_2; - reg div_isCommited; - wire _zz_div_input_ready; - wire div_output_valid; - wire div_output_ready; - wire [4:0] div_output_payload_rd; - reg [23:0] div_output_payload_value_mantissa; - reg [8:0] div_output_payload_value_exponent; - wire div_output_payload_value_sign; - reg div_output_payload_value_special; - wire div_output_payload_scrap; - wire [2:0] div_output_payload_roundMode; - reg div_output_payload_NV; - wire div_output_payload_DZ; - wire [25:0] div_dividerResult; - wire div_dividerScrap; - reg div_cmdSent; - wire div_divider_io_input_fire; - wire when_FpuCore_l1056; - wire div_needShift; - wire [23:0] div_mantissa; - wire div_scrap; - wire [10:0] div_exponent; - wire when_FpuCore_l1072; - wire [10:0] div_underflowThreshold; - wire [10:0] div_underflowExp; - wire div_forceUnderflow; - wire div_forceOverflow; - wire div_infinitynan; - wire div_forceNan; - wire div_forceZero; - wire when_FpuCore_l1089; - wire when_FpuCore_l1093; - wire sqrt_input_valid; - wire sqrt_input_ready; - wire [22:0] sqrt_input_payload_rs1_mantissa; - wire [8:0] sqrt_input_payload_rs1_exponent; - wire sqrt_input_payload_rs1_sign; - wire sqrt_input_payload_rs1_special; - wire [4:0] sqrt_input_payload_rd; - wire [2:0] sqrt_input_payload_roundMode; - reg decode_sqrt_rValid; - wire sqrt_input_fire; - reg [22:0] decode_sqrt_rData_rs1_mantissa; - reg [8:0] decode_sqrt_rData_rs1_exponent; - reg decode_sqrt_rData_rs1_sign; - reg decode_sqrt_rData_rs1_special; - reg [4:0] decode_sqrt_rData_rd; - reg [2:0] decode_sqrt_rData_roundMode; - reg sqrt_haltIt; - wire sqrt_input_fire_1; - wire when_FpuCore_l221_3; - reg sqrt_isCommited; - wire _zz_sqrt_input_ready; - wire sqrt_output_valid; - wire sqrt_output_ready; - wire [4:0] sqrt_output_payload_rd; - reg [23:0] sqrt_output_payload_value_mantissa; - reg [8:0] sqrt_output_payload_value_exponent; - wire sqrt_output_payload_value_sign; - reg sqrt_output_payload_value_special; - wire sqrt_output_payload_scrap; - wire [2:0] sqrt_output_payload_roundMode; - reg sqrt_output_payload_NV; - wire sqrt_output_payload_DZ; - wire sqrt_needShift; - reg sqrt_cmdSent; - wire sqrt_sqrt_io_input_fire; - wire when_FpuCore_l1118; - wire sqrt_scrap; - reg [8:0] sqrt_exponent; - wire sqrt_negative; - wire when_FpuCore_l1137; - wire when_FpuCore_l1144; - wire when_FpuCore_l1148; - wire add_preShifter_input_valid; - wire add_preShifter_input_ready; - wire [24:0] add_preShifter_input_payload_rs1_mantissa; - wire [8:0] add_preShifter_input_payload_rs1_exponent; - wire add_preShifter_input_payload_rs1_sign; - wire add_preShifter_input_payload_rs1_special; - wire [24:0] add_preShifter_input_payload_rs2_mantissa; - wire [8:0] add_preShifter_input_payload_rs2_exponent; - wire add_preShifter_input_payload_rs2_sign; - wire add_preShifter_input_payload_rs2_special; - wire [4:0] add_preShifter_input_payload_rd; - wire [2:0] add_preShifter_input_payload_roundMode; - wire add_preShifter_input_payload_needCommit; - wire add_preShifter_output_valid; - reg add_preShifter_output_ready; - wire [24:0] add_preShifter_output_payload_rs1_mantissa; - wire [8:0] add_preShifter_output_payload_rs1_exponent; - wire add_preShifter_output_payload_rs1_sign; - wire add_preShifter_output_payload_rs1_special; - wire [24:0] add_preShifter_output_payload_rs2_mantissa; - wire [8:0] add_preShifter_output_payload_rs2_exponent; - wire add_preShifter_output_payload_rs2_sign; - wire add_preShifter_output_payload_rs2_special; - wire [4:0] add_preShifter_output_payload_rd; - wire [2:0] add_preShifter_output_payload_roundMode; - wire add_preShifter_output_payload_needCommit; - wire add_preShifter_output_payload_absRs1Bigger; - wire add_preShifter_output_payload_rs1ExponentBigger; - wire [9:0] add_preShifter_exp21; - wire add_preShifter_rs1ExponentBigger; - wire add_preShifter_rs1ExponentEqual; - wire add_preShifter_rs1MantissaBigger; - wire add_preShifter_absRs1Bigger; - wire add_shifter_input_valid; - wire add_shifter_input_ready; - wire [24:0] add_shifter_input_payload_rs1_mantissa; - wire [8:0] add_shifter_input_payload_rs1_exponent; - wire add_shifter_input_payload_rs1_sign; - wire add_shifter_input_payload_rs1_special; - wire [24:0] add_shifter_input_payload_rs2_mantissa; - wire [8:0] add_shifter_input_payload_rs2_exponent; - wire add_shifter_input_payload_rs2_sign; - wire add_shifter_input_payload_rs2_special; - wire [4:0] add_shifter_input_payload_rd; - wire [2:0] add_shifter_input_payload_roundMode; - wire add_shifter_input_payload_needCommit; - wire add_shifter_input_payload_absRs1Bigger; - wire add_shifter_input_payload_rs1ExponentBigger; - reg add_preShifter_output_rValid; - reg [24:0] add_preShifter_output_rData_rs1_mantissa; - reg [8:0] add_preShifter_output_rData_rs1_exponent; - reg add_preShifter_output_rData_rs1_sign; - reg add_preShifter_output_rData_rs1_special; - reg [24:0] add_preShifter_output_rData_rs2_mantissa; - reg [8:0] add_preShifter_output_rData_rs2_exponent; - reg add_preShifter_output_rData_rs2_sign; - reg add_preShifter_output_rData_rs2_special; - reg [4:0] add_preShifter_output_rData_rd; - reg [2:0] add_preShifter_output_rData_roundMode; - reg add_preShifter_output_rData_needCommit; - reg add_preShifter_output_rData_absRs1Bigger; - reg add_preShifter_output_rData_rs1ExponentBigger; - wire when_Stream_l368_12; - wire add_shifter_output_valid; - reg add_shifter_output_ready; - wire [24:0] add_shifter_output_payload_rs1_mantissa; - wire [8:0] add_shifter_output_payload_rs1_exponent; - wire add_shifter_output_payload_rs1_sign; - wire add_shifter_output_payload_rs1_special; - wire [24:0] add_shifter_output_payload_rs2_mantissa; - wire [8:0] add_shifter_output_payload_rs2_exponent; - wire add_shifter_output_payload_rs2_sign; - wire add_shifter_output_payload_rs2_special; - wire [4:0] add_shifter_output_payload_rd; - wire [2:0] add_shifter_output_payload_roundMode; - wire add_shifter_output_payload_needCommit; - wire add_shifter_output_payload_xSign; - wire add_shifter_output_payload_ySign; - wire [25:0] add_shifter_output_payload_xMantissa; - wire [25:0] add_shifter_output_payload_yMantissa; - wire [8:0] add_shifter_output_payload_xyExponent; - wire add_shifter_output_payload_xySign; - wire add_shifter_output_payload_roundingScrap; - wire [9:0] add_shifter_exp21; - wire [9:0] _zz_add_shifter_shiftBy; - wire [9:0] add_shifter_shiftBy; - wire add_shifter_shiftOverflow; - wire add_shifter_passThrough; - wire add_shifter_xySign; - wire [25:0] add_shifter_xMantissa; - wire [25:0] add_shifter_yMantissaUnshifted; - wire [25:0] add_shifter_yMantissa; - reg add_shifter_roundingScrap; - wire when_FpuCore_l1419; - wire when_FpuCore_l1419_1; - wire when_FpuCore_l1419_2; - wire when_FpuCore_l1419_3; - wire when_FpuCore_l1419_4; - wire when_FpuCore_l1424; - wire add_math_input_valid; - wire add_math_input_ready; - wire [24:0] add_math_input_payload_rs1_mantissa; - wire [8:0] add_math_input_payload_rs1_exponent; - wire add_math_input_payload_rs1_sign; - wire add_math_input_payload_rs1_special; - wire [24:0] add_math_input_payload_rs2_mantissa; - wire [8:0] add_math_input_payload_rs2_exponent; - wire add_math_input_payload_rs2_sign; - wire add_math_input_payload_rs2_special; - wire [4:0] add_math_input_payload_rd; - wire [2:0] add_math_input_payload_roundMode; - wire add_math_input_payload_needCommit; - wire add_math_input_payload_xSign; - wire add_math_input_payload_ySign; - wire [25:0] add_math_input_payload_xMantissa; - wire [25:0] add_math_input_payload_yMantissa; - wire [8:0] add_math_input_payload_xyExponent; - wire add_math_input_payload_xySign; - wire add_math_input_payload_roundingScrap; - reg add_shifter_output_rValid; - reg [24:0] add_shifter_output_rData_rs1_mantissa; - reg [8:0] add_shifter_output_rData_rs1_exponent; - reg add_shifter_output_rData_rs1_sign; - reg add_shifter_output_rData_rs1_special; - reg [24:0] add_shifter_output_rData_rs2_mantissa; - reg [8:0] add_shifter_output_rData_rs2_exponent; - reg add_shifter_output_rData_rs2_sign; - reg add_shifter_output_rData_rs2_special; - reg [4:0] add_shifter_output_rData_rd; - reg [2:0] add_shifter_output_rData_roundMode; - reg add_shifter_output_rData_needCommit; - reg add_shifter_output_rData_xSign; - reg add_shifter_output_rData_ySign; - reg [25:0] add_shifter_output_rData_xMantissa; - reg [25:0] add_shifter_output_rData_yMantissa; - reg [8:0] add_shifter_output_rData_xyExponent; - reg add_shifter_output_rData_xySign; - reg add_shifter_output_rData_roundingScrap; - wire when_Stream_l368_13; - wire add_math_output_valid; - reg add_math_output_ready; - wire [24:0] add_math_output_payload_rs1_mantissa; - wire [8:0] add_math_output_payload_rs1_exponent; - wire add_math_output_payload_rs1_sign; - wire add_math_output_payload_rs1_special; - wire [24:0] add_math_output_payload_rs2_mantissa; - wire [8:0] add_math_output_payload_rs2_exponent; - wire add_math_output_payload_rs2_sign; - wire add_math_output_payload_rs2_special; - wire [4:0] add_math_output_payload_rd; - wire [2:0] add_math_output_payload_roundMode; - wire add_math_output_payload_needCommit; - wire add_math_output_payload_xSign; - wire add_math_output_payload_ySign; - wire [25:0] add_math_output_payload_xMantissa; - wire [25:0] add_math_output_payload_yMantissa; - wire [8:0] add_math_output_payload_xyExponent; - wire add_math_output_payload_xySign; - wire add_math_output_payload_roundingScrap; - wire [26:0] add_math_output_payload_xyMantissa; - wire [26:0] add_math_xSigned; - wire [26:0] add_math_ySigned; - wire add_oh_input_valid; - wire add_oh_input_ready; - wire [24:0] add_oh_input_payload_rs1_mantissa; - wire [8:0] add_oh_input_payload_rs1_exponent; - wire add_oh_input_payload_rs1_sign; - wire add_oh_input_payload_rs1_special; - wire [24:0] add_oh_input_payload_rs2_mantissa; - wire [8:0] add_oh_input_payload_rs2_exponent; - wire add_oh_input_payload_rs2_sign; - wire add_oh_input_payload_rs2_special; - wire [4:0] add_oh_input_payload_rd; - wire [2:0] add_oh_input_payload_roundMode; - wire add_oh_input_payload_needCommit; - wire add_oh_input_payload_xSign; - wire add_oh_input_payload_ySign; - wire [25:0] add_oh_input_payload_xMantissa; - wire [25:0] add_oh_input_payload_yMantissa; - wire [8:0] add_oh_input_payload_xyExponent; - wire add_oh_input_payload_xySign; - wire add_oh_input_payload_roundingScrap; - wire [26:0] add_oh_input_payload_xyMantissa; - reg add_math_output_rValid; - reg [24:0] add_math_output_rData_rs1_mantissa; - reg [8:0] add_math_output_rData_rs1_exponent; - reg add_math_output_rData_rs1_sign; - reg add_math_output_rData_rs1_special; - reg [24:0] add_math_output_rData_rs2_mantissa; - reg [8:0] add_math_output_rData_rs2_exponent; - reg add_math_output_rData_rs2_sign; - reg add_math_output_rData_rs2_special; - reg [4:0] add_math_output_rData_rd; - reg [2:0] add_math_output_rData_roundMode; - reg add_math_output_rData_needCommit; - reg add_math_output_rData_xSign; - reg add_math_output_rData_ySign; - reg [25:0] add_math_output_rData_xMantissa; - reg [25:0] add_math_output_rData_yMantissa; - reg [8:0] add_math_output_rData_xyExponent; - reg add_math_output_rData_xySign; - reg add_math_output_rData_roundingScrap; - reg [26:0] add_math_output_rData_xyMantissa; - wire when_Stream_l368_14; - wire add_oh_input_fire; - wire when_FpuCore_l221_4; - wire add_oh_isCommited; - wire _zz_add_oh_input_ready; - wire add_oh_output_valid; - reg add_oh_output_ready; - wire [24:0] add_oh_output_payload_rs1_mantissa; - wire [8:0] add_oh_output_payload_rs1_exponent; - wire add_oh_output_payload_rs1_sign; - wire add_oh_output_payload_rs1_special; - wire [24:0] add_oh_output_payload_rs2_mantissa; - wire [8:0] add_oh_output_payload_rs2_exponent; - wire add_oh_output_payload_rs2_sign; - wire add_oh_output_payload_rs2_special; - wire [4:0] add_oh_output_payload_rd; - wire [2:0] add_oh_output_payload_roundMode; - wire add_oh_output_payload_needCommit; - wire add_oh_output_payload_xSign; - wire add_oh_output_payload_ySign; - wire [25:0] add_oh_output_payload_xMantissa; - wire [25:0] add_oh_output_payload_yMantissa; - wire [8:0] add_oh_output_payload_xyExponent; - wire add_oh_output_payload_xySign; - wire add_oh_output_payload_roundingScrap; - wire [26:0] add_oh_output_payload_xyMantissa; - wire [4:0] add_oh_output_payload_shift; - wire [26:0] _zz_add_oh_shift; - wire [26:0] _zz_add_oh_shift_1; - wire _zz_add_oh_shift_2; - wire _zz_add_oh_shift_3; - wire _zz_add_oh_shift_4; - wire _zz_add_oh_shift_5; - wire _zz_add_oh_shift_6; - wire _zz_add_oh_shift_7; - wire _zz_add_oh_shift_8; - wire _zz_add_oh_shift_9; - wire _zz_add_oh_shift_10; - wire _zz_add_oh_shift_11; - wire _zz_add_oh_shift_12; - wire _zz_add_oh_shift_13; - wire _zz_add_oh_shift_14; - wire _zz_add_oh_shift_15; - wire _zz_add_oh_shift_16; - wire _zz_add_oh_shift_17; - wire _zz_add_oh_shift_18; - wire _zz_add_oh_shift_19; - wire _zz_add_oh_shift_20; - wire _zz_add_oh_shift_21; - wire _zz_add_oh_shift_22; - wire _zz_add_oh_shift_23; - wire _zz_add_oh_shift_24; - wire _zz_add_oh_shift_25; - wire _zz_add_oh_shift_26; - wire _zz_add_oh_shift_27; - wire [4:0] add_oh_shift; - wire add_norm_input_valid; - wire add_norm_input_ready; - wire [24:0] add_norm_input_payload_rs1_mantissa; - wire [8:0] add_norm_input_payload_rs1_exponent; - wire add_norm_input_payload_rs1_sign; - wire add_norm_input_payload_rs1_special; - wire [24:0] add_norm_input_payload_rs2_mantissa; - wire [8:0] add_norm_input_payload_rs2_exponent; - wire add_norm_input_payload_rs2_sign; - wire add_norm_input_payload_rs2_special; - wire [4:0] add_norm_input_payload_rd; - wire [2:0] add_norm_input_payload_roundMode; - wire add_norm_input_payload_needCommit; - wire add_norm_input_payload_xSign; - wire add_norm_input_payload_ySign; - wire [25:0] add_norm_input_payload_xMantissa; - wire [25:0] add_norm_input_payload_yMantissa; - wire [8:0] add_norm_input_payload_xyExponent; - wire add_norm_input_payload_xySign; - wire add_norm_input_payload_roundingScrap; - wire [26:0] add_norm_input_payload_xyMantissa; - wire [4:0] add_norm_input_payload_shift; - reg add_oh_output_rValid; - reg [24:0] add_oh_output_rData_rs1_mantissa; - reg [8:0] add_oh_output_rData_rs1_exponent; - reg add_oh_output_rData_rs1_sign; - reg add_oh_output_rData_rs1_special; - reg [24:0] add_oh_output_rData_rs2_mantissa; - reg [8:0] add_oh_output_rData_rs2_exponent; - reg add_oh_output_rData_rs2_sign; - reg add_oh_output_rData_rs2_special; - reg [4:0] add_oh_output_rData_rd; - reg [2:0] add_oh_output_rData_roundMode; - reg add_oh_output_rData_needCommit; - reg add_oh_output_rData_xSign; - reg add_oh_output_rData_ySign; - reg [25:0] add_oh_output_rData_xMantissa; - reg [25:0] add_oh_output_rData_yMantissa; - reg [8:0] add_oh_output_rData_xyExponent; - reg add_oh_output_rData_xySign; - reg add_oh_output_rData_roundingScrap; - reg [26:0] add_oh_output_rData_xyMantissa; - reg [4:0] add_oh_output_rData_shift; - wire when_Stream_l368_15; - wire add_norm_output_valid; - wire add_norm_output_ready; - wire [24:0] add_norm_output_payload_rs1_mantissa; - wire [8:0] add_norm_output_payload_rs1_exponent; - wire add_norm_output_payload_rs1_sign; - wire add_norm_output_payload_rs1_special; - wire [24:0] add_norm_output_payload_rs2_mantissa; - wire [8:0] add_norm_output_payload_rs2_exponent; - wire add_norm_output_payload_rs2_sign; - wire add_norm_output_payload_rs2_special; - wire [4:0] add_norm_output_payload_rd; - wire [2:0] add_norm_output_payload_roundMode; - wire add_norm_output_payload_needCommit; - wire [26:0] add_norm_output_payload_mantissa; - wire [9:0] add_norm_output_payload_exponent; - wire add_norm_output_payload_infinityNan; - wire add_norm_output_payload_forceNan; - wire add_norm_output_payload_forceZero; - wire add_norm_output_payload_forceInfinity; - wire add_norm_output_payload_xySign; - wire add_norm_output_payload_roundingScrap; - wire add_norm_output_payload_xyMantissaZero; - wire add_result_input_valid; - wire add_result_input_ready; - wire [24:0] add_result_input_payload_rs1_mantissa; - wire [8:0] add_result_input_payload_rs1_exponent; - wire add_result_input_payload_rs1_sign; - wire add_result_input_payload_rs1_special; - wire [24:0] add_result_input_payload_rs2_mantissa; - wire [8:0] add_result_input_payload_rs2_exponent; - wire add_result_input_payload_rs2_sign; - wire add_result_input_payload_rs2_special; - wire [4:0] add_result_input_payload_rd; - wire [2:0] add_result_input_payload_roundMode; - wire add_result_input_payload_needCommit; - wire [26:0] add_result_input_payload_mantissa; - wire [9:0] add_result_input_payload_exponent; - wire add_result_input_payload_infinityNan; - wire add_result_input_payload_forceNan; - wire add_result_input_payload_forceZero; - wire add_result_input_payload_forceInfinity; - wire add_result_input_payload_xySign; - wire add_result_input_payload_roundingScrap; - wire add_result_input_payload_xyMantissaZero; - wire add_result_output_valid; - wire add_result_output_ready; - wire [4:0] add_result_output_payload_rd; - reg [23:0] add_result_output_payload_value_mantissa; - reg [8:0] add_result_output_payload_value_exponent; - reg add_result_output_payload_value_sign; - reg add_result_output_payload_value_special; - wire add_result_output_payload_scrap; - wire [2:0] add_result_output_payload_roundMode; - wire add_result_output_payload_NV; - wire add_result_output_payload_DZ; - wire when_FpuCore_l1513; - wire when_FpuCore_l1516; - wire load_s1_output_m2sPipe_valid; - wire load_s1_output_m2sPipe_ready; - wire [4:0] load_s1_output_m2sPipe_payload_rd; - wire [23:0] load_s1_output_m2sPipe_payload_value_mantissa; - wire [8:0] load_s1_output_m2sPipe_payload_value_exponent; - wire load_s1_output_m2sPipe_payload_value_sign; - wire load_s1_output_m2sPipe_payload_value_special; - wire load_s1_output_m2sPipe_payload_scrap; - wire [2:0] load_s1_output_m2sPipe_payload_roundMode; - wire load_s1_output_m2sPipe_payload_NV; - wire load_s1_output_m2sPipe_payload_DZ; - reg load_s1_output_rValid; - reg [4:0] load_s1_output_rData_rd; - reg [23:0] load_s1_output_rData_value_mantissa; - reg [8:0] load_s1_output_rData_value_exponent; - reg load_s1_output_rData_value_sign; - reg load_s1_output_rData_value_special; - reg load_s1_output_rData_scrap; - reg [2:0] load_s1_output_rData_roundMode; - reg load_s1_output_rData_NV; - reg load_s1_output_rData_DZ; - wire when_Stream_l368_16; - wire shortPip_output_m2sPipe_valid; - wire shortPip_output_m2sPipe_ready; - wire [4:0] shortPip_output_m2sPipe_payload_rd; - wire [23:0] shortPip_output_m2sPipe_payload_value_mantissa; - wire [8:0] shortPip_output_m2sPipe_payload_value_exponent; - wire shortPip_output_m2sPipe_payload_value_sign; - wire shortPip_output_m2sPipe_payload_value_special; - wire shortPip_output_m2sPipe_payload_scrap; - wire [2:0] shortPip_output_m2sPipe_payload_roundMode; - wire shortPip_output_m2sPipe_payload_NV; - wire shortPip_output_m2sPipe_payload_DZ; - reg shortPip_output_rValid; - reg [4:0] shortPip_output_rData_rd; - reg [23:0] shortPip_output_rData_value_mantissa; - reg [8:0] shortPip_output_rData_value_exponent; - reg shortPip_output_rData_value_sign; - reg shortPip_output_rData_value_special; - reg shortPip_output_rData_scrap; - reg [2:0] shortPip_output_rData_roundMode; - reg shortPip_output_rData_NV; - reg shortPip_output_rData_DZ; - wire when_Stream_l368_17; - wire merge_arbitrated_valid; - wire [4:0] merge_arbitrated_payload_rd; - wire [23:0] merge_arbitrated_payload_value_mantissa; - wire [8:0] merge_arbitrated_payload_value_exponent; - wire merge_arbitrated_payload_value_sign; - wire merge_arbitrated_payload_value_special; - wire merge_arbitrated_payload_scrap; - wire [2:0] merge_arbitrated_payload_roundMode; - wire merge_arbitrated_payload_NV; - wire merge_arbitrated_payload_DZ; - reg roundFront_input_valid; - reg [4:0] roundFront_input_payload_rd; - reg [23:0] roundFront_input_payload_value_mantissa; - reg [8:0] roundFront_input_payload_value_exponent; - reg roundFront_input_payload_value_sign; - reg roundFront_input_payload_value_special; - reg roundFront_input_payload_scrap; - reg [2:0] roundFront_input_payload_roundMode; - reg roundFront_input_payload_NV; - reg roundFront_input_payload_DZ; - wire roundFront_output_valid; - wire [4:0] roundFront_output_payload_rd; - wire [23:0] roundFront_output_payload_value_mantissa; - wire [8:0] roundFront_output_payload_value_exponent; - wire roundFront_output_payload_value_sign; - wire roundFront_output_payload_value_special; - wire roundFront_output_payload_scrap; - wire [2:0] roundFront_output_payload_roundMode; - wire roundFront_output_payload_NV; - wire roundFront_output_payload_DZ; - wire roundFront_output_payload_mantissaIncrement; - wire [1:0] roundFront_output_payload_roundAdjusted; - wire [24:0] roundFront_output_payload_exactMask; - wire [24:0] roundFront_manAggregate; - wire [7:0] roundFront_expBase; - wire [9:0] roundFront_expDif; - wire roundFront_expSubnormal; - wire [4:0] roundFront_discardCount; - wire [24:0] roundFront_exactMask; - wire [1:0] roundFront_roundAdjusted; - reg _zz_roundFront_mantissaIncrement; - wire roundFront_mantissaIncrement; - reg roundBack_input_valid; - reg [4:0] roundBack_input_payload_rd; - reg [23:0] roundBack_input_payload_value_mantissa; - reg [8:0] roundBack_input_payload_value_exponent; - reg roundBack_input_payload_value_sign; - reg roundBack_input_payload_value_special; - reg roundBack_input_payload_scrap; - reg [2:0] roundBack_input_payload_roundMode; - reg roundBack_input_payload_NV; - reg roundBack_input_payload_DZ; - reg roundBack_input_payload_mantissaIncrement; - reg [1:0] roundBack_input_payload_roundAdjusted; - reg [24:0] roundBack_input_payload_exactMask; - wire roundBack_output_valid; - wire [4:0] roundBack_output_payload_rd; - wire [22:0] roundBack_output_payload_value_mantissa; - wire [8:0] roundBack_output_payload_value_exponent; - wire roundBack_output_payload_value_sign; - wire roundBack_output_payload_value_special; - wire roundBack_output_payload_NV; - wire roundBack_output_payload_NX; - wire roundBack_output_payload_OF; - wire roundBack_output_payload_UF; - wire roundBack_output_payload_DZ; - wire roundBack_output_payload_write; - wire [22:0] roundBack_math_mantissa; - wire [8:0] roundBack_math_exponent; - wire roundBack_math_sign; - wire roundBack_math_special; - wire [22:0] roundBack_adderMantissa; - (* keep , syn_keep *) wire [22:0] roundBack_adderRightOp /* synthesis syn_keep = 1 */ ; - (* keep , syn_keep *) wire [31:0] _zz_roundBack_adder /* synthesis syn_keep = 1 */ ; - (* keep , syn_keep *) wire [0:0] _zz_roundBack_adder_1 /* synthesis syn_keep = 1 */ ; - (* keep , syn_keep *) wire [31:0] roundBack_adder /* synthesis syn_keep = 1 */ ; - reg [22:0] roundBack_patched_mantissa; - reg [8:0] roundBack_patched_exponent; - wire roundBack_patched_sign; - reg roundBack_patched_special; - reg roundBack_nx; - reg roundBack_of; - reg roundBack_uf; - wire [7:0] roundBack_ufSubnormalThreshold; - wire [6:0] roundBack_ufThreshold; - wire [8:0] roundBack_ofThreshold; - reg [2:0] roundBack_threshold; - wire [2:0] roundBack_borringRound; - wire roundBack_borringCase; - wire when_FpuCore_l1608; - wire when_FpuCore_l1611; - reg when_FpuCore_l1621; - wire when_FpuCore_l1630; - reg when_FpuCore_l1640; - wire when_FpuCore_l1649; - wire roundBack_writes_0; - wire roundBack_write; - reg writeback_input_valid; - reg [4:0] writeback_input_payload_rd; - reg [22:0] writeback_input_payload_value_mantissa; - reg [8:0] writeback_input_payload_value_exponent; - reg writeback_input_payload_value_sign; - reg writeback_input_payload_value_special; - reg writeback_input_payload_NV; - reg writeback_input_payload_NX; - reg writeback_input_payload_OF; - reg writeback_input_payload_UF; - reg writeback_input_payload_DZ; - reg writeback_input_payload_write; - wire when_FpuCore_l1681; - wire writeback_port_valid; - wire [4:0] writeback_port_payload_address; - wire [22:0] writeback_port_payload_data_value_mantissa; - wire [8:0] writeback_port_payload_data_value_exponent; - wire writeback_port_payload_data_value_sign; - wire writeback_port_payload_data_value_special; - `ifndef SYNTHESIS - reg [63:0] io_port_0_cmd_payload_opcode_string; - reg [47:0] io_port_0_cmd_payload_format_string; - reg [23:0] io_port_0_cmd_payload_roundMode_string; - reg [63:0] io_port_0_commit_payload_opcode_string; - reg [63:0] commitFork_load_0_payload_opcode_string; - reg [63:0] commitFork_commit_0_payload_opcode_string; - reg [63:0] streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string; - reg [63:0] streamFork_1_io_outputs_1_rData_opcode_string; - reg [63:0] _zz_payload_opcode_string; - reg [63:0] _zz_commitLogic_0_input_payload_opcode_string; - reg [63:0] commitLogic_0_input_payload_opcode_string; - reg [63:0] scheduler_0_input_payload_opcode_string; - reg [47:0] scheduler_0_input_payload_format_string; - reg [23:0] scheduler_0_input_payload_roundMode_string; - reg [63:0] io_port_0_cmd_rData_opcode_string; - reg [47:0] io_port_0_cmd_rData_format_string; - reg [23:0] io_port_0_cmd_rData_roundMode_string; - reg [63:0] _zz_scheduler_0_input_payload_opcode_string; - reg [47:0] _zz_scheduler_0_input_payload_format_string; - reg [23:0] _zz_scheduler_0_input_payload_roundMode_string; - reg [63:0] scheduler_0_output_payload_opcode_string; - reg [47:0] scheduler_0_output_payload_format_string; - reg [23:0] scheduler_0_output_payload_roundMode_string; - reg [63:0] _zz_io_inputs_0_payload_opcode_string; - reg [47:0] _zz_io_inputs_0_payload_format_string; - reg [23:0] _zz_io_inputs_0_payload_roundMode_string; - reg [63:0] cmdArbiter_output_payload_opcode_string; - reg [23:0] cmdArbiter_output_payload_roundMode_string; - reg [63:0] read_s0_payload_opcode_string; - reg [23:0] read_s0_payload_roundMode_string; - reg [63:0] read_s1_payload_opcode_string; - reg [23:0] read_s1_payload_roundMode_string; - reg [63:0] read_s0_rData_opcode_string; - reg [23:0] read_s0_rData_roundMode_string; - reg [63:0] read_output_payload_opcode_string; - reg [23:0] read_output_payload_roundMode_string; - reg [63:0] decode_input_payload_opcode_string; - reg [23:0] decode_input_payload_roundMode_string; - reg [23:0] decode_load_payload_roundMode_string; - reg [63:0] decode_shortPip_payload_opcode_string; - reg [23:0] decode_shortPip_payload_roundMode_string; - reg [23:0] decode_divSqrt_payload_roundMode_string; - reg [23:0] decode_div_payload_roundMode_string; - reg [23:0] decode_sqrt_payload_roundMode_string; - reg [23:0] decode_mul_payload_roundMode_string; - reg [23:0] decode_divSqrtToMul_payload_roundMode_string; - reg [23:0] decode_add_payload_roundMode_string; - reg [23:0] decode_mulToAdd_payload_roundMode_string; - reg [23:0] decode_load_s2mPipe_payload_roundMode_string; - reg [23:0] decode_load_rData_roundMode_string; - reg [23:0] _zz_decode_load_s2mPipe_payload_roundMode_string; - reg [23:0] decode_load_s2mPipe_m2sPipe_payload_roundMode_string; - reg [23:0] decode_load_s2mPipe_rData_roundMode_string; - reg [23:0] load_s0_input_payload_roundMode_string; - reg [23:0] decode_load_s2mPipe_m2sPipe_rData_roundMode_string; - reg [63:0] load_s0_filtred_0_payload_opcode_string; - reg [23:0] load_s0_output_payload_roundMode_string; - reg [23:0] load_s1_input_payload_roundMode_string; - reg [23:0] load_s0_output_rData_roundMode_string; - reg [23:0] load_s1_output_payload_roundMode_string; - reg [63:0] shortPip_input_payload_opcode_string; - reg [23:0] shortPip_input_payload_roundMode_string; - reg [63:0] decode_shortPip_rData_opcode_string; - reg [23:0] decode_shortPip_rData_roundMode_string; - reg [23:0] shortPip_rfOutput_payload_roundMode_string; - reg [23:0] shortPip_output_payload_roundMode_string; - reg [23:0] mul_preMul_input_payload_roundMode_string; - reg [23:0] decode_mul_rData_roundMode_string; - reg [23:0] mul_preMul_output_payload_roundMode_string; - reg [23:0] mul_mul_input_payload_roundMode_string; - reg [23:0] mul_preMul_output_rData_roundMode_string; - reg [23:0] mul_mul_output_payload_roundMode_string; - reg [23:0] mul_sum1_input_payload_roundMode_string; - reg [23:0] mul_mul_output_rData_roundMode_string; - reg [23:0] mul_sum1_output_payload_roundMode_string; - reg [23:0] mul_sum2_input_payload_roundMode_string; - reg [23:0] mul_sum1_output_rData_roundMode_string; - reg [23:0] mul_sum2_output_payload_roundMode_string; - reg [23:0] mul_norm_input_payload_roundMode_string; - reg [23:0] mul_sum2_output_rData_roundMode_string; - reg [23:0] mul_result_output_payload_roundMode_string; - reg [23:0] mul_result_mulToAdd_payload_roundMode_string; - reg [23:0] mul_result_mulToAdd_m2sPipe_payload_roundMode_string; - reg [23:0] mul_result_mulToAdd_rData_roundMode_string; - reg [23:0] div_input_payload_roundMode_string; - reg [23:0] decode_div_rData_roundMode_string; - reg [23:0] div_output_payload_roundMode_string; - reg [23:0] sqrt_input_payload_roundMode_string; - reg [23:0] decode_sqrt_rData_roundMode_string; - reg [23:0] sqrt_output_payload_roundMode_string; - reg [23:0] add_preShifter_input_payload_roundMode_string; - reg [23:0] add_preShifter_output_payload_roundMode_string; - reg [23:0] add_shifter_input_payload_roundMode_string; - reg [23:0] add_preShifter_output_rData_roundMode_string; - reg [23:0] add_shifter_output_payload_roundMode_string; - reg [23:0] add_math_input_payload_roundMode_string; - reg [23:0] add_shifter_output_rData_roundMode_string; - reg [23:0] add_math_output_payload_roundMode_string; - reg [23:0] add_oh_input_payload_roundMode_string; - reg [23:0] add_math_output_rData_roundMode_string; - reg [23:0] add_oh_output_payload_roundMode_string; - reg [23:0] add_norm_input_payload_roundMode_string; - reg [23:0] add_oh_output_rData_roundMode_string; - reg [23:0] add_norm_output_payload_roundMode_string; - reg [23:0] add_result_input_payload_roundMode_string; - reg [23:0] add_result_output_payload_roundMode_string; - reg [23:0] load_s1_output_m2sPipe_payload_roundMode_string; - reg [23:0] load_s1_output_rData_roundMode_string; - reg [23:0] shortPip_output_m2sPipe_payload_roundMode_string; - reg [23:0] shortPip_output_rData_roundMode_string; - reg [23:0] merge_arbitrated_payload_roundMode_string; - reg [23:0] roundFront_input_payload_roundMode_string; - reg [23:0] roundFront_output_payload_roundMode_string; - reg [23:0] roundBack_input_payload_roundMode_string; - `endif - reg [33:0] rf_ram [0:31]; - (* ram_style = "distributed" *) reg [0:0] rf_scoreboards_0_target [0:31]; - (* ram_style = "distributed" *) reg [0:0] rf_scoreboards_0_hit [0:31]; - (* ram_style = "distributed" *) reg [0:0] rf_scoreboards_0_writes [0:31]; - - assign _zz_commitLogic_0_pending_counter = (commitLogic_0_pending_counter + _zz_commitLogic_0_pending_counter_1); - assign _zz_commitLogic_0_pending_counter_2 = commitLogic_0_pending_inc; - assign _zz_commitLogic_0_pending_counter_1 = {3'd0, _zz_commitLogic_0_pending_counter_2}; - assign _zz_commitLogic_0_pending_counter_4 = commitLogic_0_pending_dec; - assign _zz_commitLogic_0_pending_counter_3 = {3'd0, _zz_commitLogic_0_pending_counter_4}; - assign _zz_commitLogic_0_add_counter = (commitLogic_0_add_counter + _zz_commitLogic_0_add_counter_1); - assign _zz_commitLogic_0_add_counter_2 = commitLogic_0_add_inc; - assign _zz_commitLogic_0_add_counter_1 = {3'd0, _zz_commitLogic_0_add_counter_2}; - assign _zz_commitLogic_0_add_counter_4 = commitLogic_0_add_dec; - assign _zz_commitLogic_0_add_counter_3 = {3'd0, _zz_commitLogic_0_add_counter_4}; - assign _zz_commitLogic_0_mul_counter = (commitLogic_0_mul_counter + _zz_commitLogic_0_mul_counter_1); - assign _zz_commitLogic_0_mul_counter_2 = commitLogic_0_mul_inc; - assign _zz_commitLogic_0_mul_counter_1 = {3'd0, _zz_commitLogic_0_mul_counter_2}; - assign _zz_commitLogic_0_mul_counter_4 = commitLogic_0_mul_dec; - assign _zz_commitLogic_0_mul_counter_3 = {3'd0, _zz_commitLogic_0_mul_counter_4}; - assign _zz_commitLogic_0_div_counter = (commitLogic_0_div_counter + _zz_commitLogic_0_div_counter_1); - assign _zz_commitLogic_0_div_counter_2 = commitLogic_0_div_inc; - assign _zz_commitLogic_0_div_counter_1 = {3'd0, _zz_commitLogic_0_div_counter_2}; - assign _zz_commitLogic_0_div_counter_4 = commitLogic_0_div_dec; - assign _zz_commitLogic_0_div_counter_3 = {3'd0, _zz_commitLogic_0_div_counter_4}; - assign _zz_commitLogic_0_sqrt_counter = (commitLogic_0_sqrt_counter + _zz_commitLogic_0_sqrt_counter_1); - assign _zz_commitLogic_0_sqrt_counter_2 = commitLogic_0_sqrt_inc; - assign _zz_commitLogic_0_sqrt_counter_1 = {3'd0, _zz_commitLogic_0_sqrt_counter_2}; - assign _zz_commitLogic_0_sqrt_counter_4 = commitLogic_0_sqrt_dec; - assign _zz_commitLogic_0_sqrt_counter_3 = {3'd0, _zz_commitLogic_0_sqrt_counter_4}; - assign _zz_commitLogic_0_short_counter = (commitLogic_0_short_counter + _zz_commitLogic_0_short_counter_1); - assign _zz_commitLogic_0_short_counter_2 = commitLogic_0_short_inc; - assign _zz_commitLogic_0_short_counter_1 = {3'd0, _zz_commitLogic_0_short_counter_2}; - assign _zz_commitLogic_0_short_counter_4 = commitLogic_0_short_dec; - assign _zz_commitLogic_0_short_counter_3 = {3'd0, _zz_commitLogic_0_short_counter_4}; - assign _zz_when = 1'b1; - assign _zz_load_s1_fsm_shift_input_1 = (load_s1_fsm_shift_input <<< 1'b1); - assign _zz_load_s1_fsm_shift_input_2 = (load_s1_fsm_shift_input_1 <<< 2'b10); - assign _zz_load_s1_fsm_shift_input_3 = (load_s1_fsm_shift_input_2 <<< 3'b100); - assign _zz_load_s1_fsm_shift_input_4 = (load_s1_fsm_shift_input_3 <<< 4'b1000); - assign _zz_load_s1_fsm_shift_input_5 = (load_s1_fsm_shift_input_4 <<< 5'h10); - assign _zz_load_s0_output_rData_value_3 = _zz_load_s0_output_rData_value_4; - assign _zz_load_s0_output_rData_value_2 = _zz_load_s0_output_rData_value_3[31:0]; - assign _zz_load_s0_output_rData_value_4 = ({_zz_load_s0_output_rData_value_1,(_zz_load_s0_output_rData_value_1 ? (~ _zz_load_s0_output_rData_value) : _zz_load_s0_output_rData_value)} + _zz_load_s0_output_rData_value_5); - assign _zz_load_s0_output_rData_value_6 = _zz_load_s0_output_rData_value_1; - assign _zz_load_s0_output_rData_value_5 = {32'd0, _zz_load_s0_output_rData_value_6}; - assign _zz__zz_load_s1_fsm_shift_by_1_1 = (_zz_load_s1_fsm_shift_by - 32'h00000001); - assign _zz_load_s1_recoded_exponent = (_zz_load_s1_recoded_exponent_1 + _zz_load_s1_recoded_exponent_2); - assign _zz_load_s1_recoded_exponent_1 = ({1'b0,load_s1_passThroughFloat_exponent} - {1'b0,load_s1_fsm_expOffset}); - assign _zz_load_s1_recoded_exponent_2 = {1'd0, load_s1_recodedExpOffset}; - assign _zz_load_s1_output_payload_value_exponent = {4'd0, load_s1_fsm_shift_by}; - assign _zz_shortPip_f32_exp = (shortPip_input_payload_rs1_exponent - 9'h080); - assign _zz_shortPip_expInSubnormalRange = {1'd0, shortPip_expSubnormalThreshold}; - assign _zz_shortPip_fsm_shift_input_1 = (shortPip_fsm_shift_input >>> 6'h20); - assign _zz_shortPip_fsm_shift_input_2 = (shortPip_fsm_shift_input_1 >>> 5'h10); - assign _zz_shortPip_fsm_shift_input_3 = (shortPip_fsm_shift_input_2 >>> 4'b1000); - assign _zz_shortPip_fsm_shift_input_4 = (shortPip_fsm_shift_input_3 >>> 3'b100); - assign _zz_shortPip_fsm_shift_input_5 = (shortPip_fsm_shift_input_4 >>> 2'b10); - assign _zz_shortPip_fsm_shift_input_6 = (shortPip_fsm_shift_input_5 >>> 1'b1); - assign _zz_shortPip_fsm_shift_by_2 = (((_zz_shortPip_fsm_shift_by < _zz_shortPip_fsm_shift_by_3) ? _zz_shortPip_fsm_shift_by : _zz_shortPip_fsm_shift_by_4) + 9'h0); - assign _zz_shortPip_fsm_shift_by_3 = {3'd0, _zz_shortPip_fsm_shift_by_1}; - assign _zz_shortPip_fsm_shift_by_4 = {3'd0, _zz_shortPip_fsm_shift_by_1}; - assign _zz_shortPip_fsm_shift_by_5 = (_zz_shortPip_fsm_shift_by_6 - shortPip_input_payload_rs1_exponent); - assign _zz_shortPip_fsm_shift_by_6 = {1'd0, shortPip_fsm_formatShiftOffset}; - assign _zz_shortPip_f2i_result_1 = (shortPip_f2i_resign ^ shortPip_f2i_increment); - assign _zz_shortPip_f2i_result = {31'd0, _zz_shortPip_f2i_result_1}; - assign _zz_mul_sum1_sum = {12'd0, mul_sum1_input_payload_muls_0}; - assign _zz_mul_sum1_sum_2 = ({18'd0,mul_sum1_input_payload_muls_1} <<< 18); - assign _zz_mul_sum1_sum_1 = {6'd0, _zz_mul_sum1_sum_2}; - assign _zz_mul_sum2_sum = (_zz_mul_sum2_sum_1 + _zz_mul_sum2_sum_3); - assign _zz_mul_sum2_sum_2 = ({18'd0,mul_sum2_input_payload_muls2_0} <<< 18); - assign _zz_mul_sum2_sum_1 = {6'd0, _zz_mul_sum2_sum_2}; - assign _zz_mul_sum2_sum_4 = ({36'd0,mul_sum2_input_payload_muls2_1} <<< 36); - assign _zz_mul_sum2_sum_3 = _zz_mul_sum2_sum_4; - assign _zz_mul_norm_exp_1 = mul_norm_needShift; - assign _zz_mul_norm_exp = {9'd0, _zz_mul_norm_exp_1}; - assign _zz_mul_norm_forceUnderflow = {1'd0, mul_norm_underflowThreshold}; - assign _zz_mul_norm_output_exponent = (mul_norm_exp - 10'h0ff); - assign _zz_div_exponent = (_zz_div_exponent_1 - _zz_div_exponent_3); - assign _zz_div_exponent_1 = (_zz_div_exponent_2 + 11'h4ff); - assign _zz_div_exponent_2 = {2'd0, div_input_payload_rs1_exponent}; - assign _zz_div_exponent_3 = {2'd0, div_input_payload_rs2_exponent}; - assign _zz_div_exponent_5 = div_needShift; - assign _zz_div_exponent_4 = {10'd0, _zz_div_exponent_5}; - assign _zz_sqrt_exponent = (_zz_sqrt_exponent_1 + {1'b0,_zz_sqrt_exponent_3}); - assign _zz_sqrt_exponent_2 = {1'b0,7'h7f}; - assign _zz_sqrt_exponent_1 = {1'd0, _zz_sqrt_exponent_2}; - assign _zz_sqrt_exponent_3 = (sqrt_input_payload_rs1_exponent >>> 1); - assign _zz_sqrt_exponent_5 = sqrt_input_payload_rs1_exponent[0]; - assign _zz_sqrt_exponent_4 = {8'd0, _zz_sqrt_exponent_5}; - assign _zz_add_shifter_shiftBy_1 = (_zz_add_shifter_shiftBy[9] ? _zz_add_shifter_shiftBy_2 : _zz_add_shifter_shiftBy); - assign _zz_add_shifter_shiftBy_2 = (~ _zz_add_shifter_shiftBy); - assign _zz_add_shifter_shiftBy_4 = _zz_add_shifter_shiftBy[9]; - assign _zz_add_shifter_shiftBy_3 = {9'd0, _zz_add_shifter_shiftBy_4}; - assign _zz_add_shifter_yMantissa_1 = (add_shifter_yMantissa >>> 5'h10); - assign _zz_add_shifter_yMantissa_2 = (add_shifter_yMantissa_1 >>> 4'b1000); - assign _zz_add_shifter_yMantissa_3 = (add_shifter_yMantissa_2 >>> 3'b100); - assign _zz_add_shifter_yMantissa_4 = (add_shifter_yMantissa_3 >>> 2'b10); - assign _zz_add_shifter_yMantissa_5 = (add_shifter_yMantissa_4 >>> 1'b1); - assign _zz_add_math_xSigned = ({add_math_input_payload_xSign,(add_math_input_payload_xSign ? (~ add_math_input_payload_xMantissa) : add_math_input_payload_xMantissa)} + _zz_add_math_xSigned_1); - assign _zz_add_math_xSigned_2 = add_math_input_payload_xSign; - assign _zz_add_math_xSigned_1 = {26'd0, _zz_add_math_xSigned_2}; - assign _zz_add_math_ySigned = ({add_math_input_payload_ySign,(add_math_input_payload_ySign ? (~ add_math_input_payload_yMantissa) : add_math_input_payload_yMantissa)} + _zz_add_math_ySigned_1); - assign _zz_add_math_ySigned_2 = (add_math_input_payload_ySign && (! add_math_input_payload_roundingScrap)); - assign _zz_add_math_ySigned_1 = {26'd0, _zz_add_math_ySigned_2}; - assign _zz_add_math_output_payload_xyMantissa = _zz_add_math_output_payload_xyMantissa_1; - assign _zz_add_math_output_payload_xyMantissa_1 = ($signed(_zz_add_math_output_payload_xyMantissa_2) + $signed(_zz_add_math_output_payload_xyMantissa_3)); - assign _zz_add_math_output_payload_xyMantissa_2 = {add_math_xSigned[26],add_math_xSigned}; - assign _zz_add_math_output_payload_xyMantissa_3 = {add_math_ySigned[26],add_math_ySigned}; - assign _zz__zz_add_oh_shift_1_1 = (_zz_add_oh_shift - 27'h0000001); - assign _zz_add_norm_output_payload_exponent = ({1'b0,add_norm_input_payload_xyExponent} - _zz_add_norm_output_payload_exponent_1); - assign _zz_add_norm_output_payload_exponent_2 = {1'b0,add_norm_input_payload_shift}; - assign _zz_add_norm_output_payload_exponent_1 = {4'd0, _zz_add_norm_output_payload_exponent_2}; - assign _zz_add_result_output_payload_value_mantissa = (add_result_input_payload_mantissa >>> 2); - assign _zz_roundFront_expDif_1 = {1'b0,roundFront_expBase}; - assign _zz_roundFront_expDif = {1'd0, _zz_roundFront_expDif_1}; - assign _zz_roundFront_discardCount = roundFront_expDif[4:0]; - assign _zz_roundFront_roundAdjusted = {1'b1,_zz_roundFront_roundAdjusted_1}; - assign _zz_roundFront_roundAdjusted_1 = (roundFront_manAggregate >>> 1); - assign _zz__zz_roundFront_mantissaIncrement = {2'b01,_zz__zz_roundFront_mantissaIncrement_1}; - assign _zz__zz_roundFront_mantissaIncrement_1 = (roundFront_manAggregate >>> 2); - assign _zz_roundBack_adderMantissa = (roundBack_input_payload_exactMask[23 : 0] >>> 1); - assign _zz_roundBack_adderRightOp = (roundBack_input_payload_mantissaIncrement ? _zz_roundBack_adderRightOp_1 : 24'h0); - assign _zz_roundBack_adderRightOp_1 = (roundBack_input_payload_exactMask >>> 1); - assign _zz_roundBack_adder_2 = (_zz_roundBack_adder + _zz_roundBack_adder_3); - assign _zz_roundBack_adder_3 = {9'd0, roundBack_adderRightOp}; - assign _zz_roundBack_adder_4 = {31'd0, _zz_roundBack_adder_1}; - assign _zz_roundBack_borringCase = {1'd0, roundBack_ufSubnormalThreshold}; - assign _zz_when_FpuCore_l1608 = {1'd0, roundBack_ufSubnormalThreshold}; - assign _zz_when_FpuCore_l1630 = {2'd0, roundBack_ufThreshold}; - assign _zz_rf_ram_port = {writeback_port_payload_data_value_special,{writeback_port_payload_data_value_sign,{writeback_port_payload_data_value_exponent,writeback_port_payload_data_value_mantissa}}}; - assign _zz_rf_scoreboards_0_target_port = rf_scoreboards_0_targetWrite_payload_data; - assign _zz_rf_scoreboards_0_hit_port = rf_scoreboards_0_hitWrite_payload_data; - assign _zz_rf_scoreboards_0_writes_port = commitLogic_0_input_payload_write; - assign _zz_decode_shortPipHit = FpuOpcode_MIN_MAX; - assign _zz_decode_shortPipHit_1 = (decode_input_payload_opcode == FpuOpcode_CMP); - assign _zz_decode_shortPipHit_2 = (decode_input_payload_opcode == FpuOpcode_F2I); - assign _zz_decode_shortPipHit_3 = (decode_input_payload_opcode == FpuOpcode_STORE); - assign _zz__zz_load_s1_fsm_shift_by = load_s1_fsm_ohInput[9]; - assign _zz__zz_load_s1_fsm_shift_by_1 = load_s1_fsm_ohInput[10]; - assign _zz__zz_load_s1_fsm_shift_by_2 = {load_s1_fsm_ohInput[11],{load_s1_fsm_ohInput[12],{load_s1_fsm_ohInput[13],{load_s1_fsm_ohInput[14],{load_s1_fsm_ohInput[15],{load_s1_fsm_ohInput[16],{load_s1_fsm_ohInput[17],{load_s1_fsm_ohInput[18],{load_s1_fsm_ohInput[19],{_zz__zz_load_s1_fsm_shift_by_3,{_zz__zz_load_s1_fsm_shift_by_4,_zz__zz_load_s1_fsm_shift_by_5}}}}}}}}}}}; - assign _zz__zz_load_s1_fsm_shift_by_3 = load_s1_fsm_ohInput[20]; - assign _zz__zz_load_s1_fsm_shift_by_4 = load_s1_fsm_ohInput[21]; - assign _zz__zz_load_s1_fsm_shift_by_5 = {load_s1_fsm_ohInput[22],{load_s1_fsm_ohInput[23],{load_s1_fsm_ohInput[24],{load_s1_fsm_ohInput[25],{load_s1_fsm_ohInput[26],{load_s1_fsm_ohInput[27],{load_s1_fsm_ohInput[28],{load_s1_fsm_ohInput[29],{load_s1_fsm_ohInput[30],load_s1_fsm_ohInput[31]}}}}}}}}}; - assign _zz__zz_add_oh_shift = add_oh_output_payload_xyMantissa[9]; - assign _zz__zz_add_oh_shift_1 = add_oh_output_payload_xyMantissa[10]; - assign _zz__zz_add_oh_shift_2 = {add_oh_output_payload_xyMantissa[11],{add_oh_output_payload_xyMantissa[12],{add_oh_output_payload_xyMantissa[13],{add_oh_output_payload_xyMantissa[14],{add_oh_output_payload_xyMantissa[15],{add_oh_output_payload_xyMantissa[16],{add_oh_output_payload_xyMantissa[17],{add_oh_output_payload_xyMantissa[18],{add_oh_output_payload_xyMantissa[19],{_zz__zz_add_oh_shift_3,{_zz__zz_add_oh_shift_4,_zz__zz_add_oh_shift_5}}}}}}}}}}}; - assign _zz__zz_add_oh_shift_3 = add_oh_output_payload_xyMantissa[20]; - assign _zz__zz_add_oh_shift_4 = add_oh_output_payload_xyMantissa[21]; - assign _zz__zz_add_oh_shift_5 = {add_oh_output_payload_xyMantissa[22],{add_oh_output_payload_xyMantissa[23],{add_oh_output_payload_xyMantissa[24],{add_oh_output_payload_xyMantissa[25],add_oh_output_payload_xyMantissa[26]}}}}; - assign _zz_roundFront_exactMask = 5'h13; - assign _zz_roundFront_exactMask_1 = (5'h12 < roundFront_discardCount); - assign _zz_roundFront_exactMask_2 = (5'h11 < roundFront_discardCount); - assign _zz_roundFront_exactMask_3 = {(5'h10 < roundFront_discardCount),{(5'h0f < roundFront_discardCount),{(5'h0e < roundFront_discardCount),{(5'h0d < roundFront_discardCount),{(5'h0c < roundFront_discardCount),{(_zz_roundFront_exactMask_4 < roundFront_discardCount),{_zz_roundFront_exactMask_5,{_zz_roundFront_exactMask_6,_zz_roundFront_exactMask_7}}}}}}}}; - assign _zz_roundFront_exactMask_4 = 5'h0b; - assign _zz_roundFront_exactMask_5 = (5'h0a < roundFront_discardCount); - assign _zz_roundFront_exactMask_6 = (5'h09 < roundFront_discardCount); - assign _zz_roundFront_exactMask_7 = {(5'h08 < roundFront_discardCount),{(5'h07 < roundFront_discardCount),{(5'h06 < roundFront_discardCount),{(5'h05 < roundFront_discardCount),{(5'h04 < roundFront_discardCount),{(_zz_roundFront_exactMask_8 < roundFront_discardCount),{_zz_roundFront_exactMask_9,{_zz_roundFront_exactMask_10,_zz_roundFront_exactMask_11}}}}}}}}; - assign _zz_roundFront_exactMask_8 = 5'h03; - assign _zz_roundFront_exactMask_9 = (5'h02 < roundFront_discardCount); - assign _zz_roundFront_exactMask_10 = (5'h01 < roundFront_discardCount); - assign _zz_roundFront_exactMask_11 = {(5'h0 < roundFront_discardCount),1'b1}; - always @(posedge clk) begin - if(_zz_read_rs_0_value_mantissa_1) begin - _zz_rf_ram_port0 <= rf_ram[_zz_read_rs_0_value_mantissa]; + reg [66:0] dispatcher_dataShifter; + reg dispatcher_dataLoaded; + reg [7:0] dispatcher_headerShifter; + wire [7:0] dispatcher_header; + reg dispatcher_headerLoaded; + reg [2:0] dispatcher_counter; + wire when_Fragment_l346; + wire when_Fragment_l349; + wire [66:0] _zz_io_mem_cmd_payload_address; + wire io_mem_cmd_isStall; + wire when_Fragment_l372; + + assign dispatcher_header = dispatcher_headerShifter[7 : 0]; + assign when_Fragment_l346 = (dispatcher_headerLoaded == 1'b0); + assign when_Fragment_l349 = (dispatcher_counter == 3'b111); + assign io_remote_cmd_ready = (! dispatcher_dataLoaded); + assign _zz_io_mem_cmd_payload_address = dispatcher_dataShifter[66 : 0]; + assign io_mem_cmd_payload_address = _zz_io_mem_cmd_payload_address[31 : 0]; + assign io_mem_cmd_payload_data = _zz_io_mem_cmd_payload_address[63 : 32]; + assign io_mem_cmd_payload_wr = _zz_io_mem_cmd_payload_address[64]; + assign io_mem_cmd_payload_size = _zz_io_mem_cmd_payload_address[66 : 65]; + assign io_mem_cmd_valid = (dispatcher_dataLoaded && (dispatcher_header == 8'h0)); + assign io_mem_cmd_isStall = (io_mem_cmd_valid && (! io_mem_cmd_ready)); + assign when_Fragment_l372 = ((dispatcher_headerLoaded && dispatcher_dataLoaded) && (! io_mem_cmd_isStall)); + assign io_remote_rsp_valid = io_mem_rsp_valid; + assign io_remote_rsp_payload_error = 1'b0; + assign io_remote_rsp_payload_data = io_mem_rsp_payload; + always @(posedge clk or posedge reset) begin + if(reset) begin + dispatcher_dataLoaded <= 1'b0; + dispatcher_headerLoaded <= 1'b0; + dispatcher_counter <= 3'b000; + end else begin + if(io_remote_cmd_valid) begin + if(when_Fragment_l346) begin + dispatcher_counter <= (dispatcher_counter + 3'b001); + if(when_Fragment_l349) begin + dispatcher_headerLoaded <= 1'b1; + end + end + if(io_remote_cmd_payload_last) begin + dispatcher_headerLoaded <= 1'b1; + dispatcher_dataLoaded <= 1'b1; + dispatcher_counter <= 3'b000; + end + end + if(when_Fragment_l372) begin + dispatcher_headerLoaded <= 1'b0; + dispatcher_dataLoaded <= 1'b0; + end end end always @(posedge clk) begin - if(_zz_read_rs_1_value_mantissa_1) begin - _zz_rf_ram_port1 <= rf_ram[_zz_read_rs_1_value_mantissa]; + if(io_remote_cmd_valid) begin + if(when_Fragment_l346) begin + dispatcher_headerShifter <= ({io_remote_cmd_payload_fragment,dispatcher_headerShifter} >>> 1); + end else begin + dispatcher_dataShifter <= ({io_remote_cmd_payload_fragment,dispatcher_dataShifter} >>> 1); + end end end - always @(posedge clk) begin - if(_zz_read_rs_2_value_mantissa_1) begin - _zz_rf_ram_port2 <= rf_ram[_zz_read_rs_2_value_mantissa]; - end - end - always @(posedge clk) begin - if(_zz_1) begin - rf_ram[writeback_port_payload_address] <= _zz_rf_ram_port; - end - end +endmodule - always @(posedge clk) begin - if(_zz_4) begin - rf_scoreboards_0_target[rf_scoreboards_0_targetWrite_payload_address] <= _zz_rf_scoreboards_0_target_port; - end - end +module JtagBridge ( + input io_jtag_tms, + input io_jtag_tdi, + output io_jtag_tdo, + input io_jtag_tck, + output io_remote_cmd_valid, + input io_remote_cmd_ready, + output io_remote_cmd_payload_last, + output [0:0] io_remote_cmd_payload_fragment, + input io_remote_rsp_valid, + output io_remote_rsp_ready, + input io_remote_rsp_payload_error, + input [31:0] io_remote_rsp_payload_data, + input clk, + input reset +); + localparam JtagState_RESET = 4'd0; + localparam JtagState_IDLE = 4'd1; + localparam JtagState_IR_SELECT = 4'd2; + localparam JtagState_IR_CAPTURE = 4'd3; + localparam JtagState_IR_SHIFT = 4'd4; + localparam JtagState_IR_EXIT1 = 4'd5; + localparam JtagState_IR_PAUSE = 4'd6; + localparam JtagState_IR_EXIT2 = 4'd7; + localparam JtagState_IR_UPDATE = 4'd8; + localparam JtagState_DR_SELECT = 4'd9; + localparam JtagState_DR_CAPTURE = 4'd10; + localparam JtagState_DR_SHIFT = 4'd11; + localparam JtagState_DR_EXIT1 = 4'd12; + localparam JtagState_DR_PAUSE = 4'd13; + localparam JtagState_DR_EXIT2 = 4'd14; + localparam JtagState_DR_UPDATE = 4'd15; + + wire flowCCByToggle_1_io_output_valid; + wire flowCCByToggle_1_io_output_payload_last; + wire [0:0] flowCCByToggle_1_io_output_payload_fragment; + wire [3:0] _zz_jtag_tap_isBypass; + wire [3:0] _zz_jtag_tap_isBypass_1; + wire [1:0] _zz_jtag_tap_instructionShift; + wire system_cmd_valid; + wire system_cmd_payload_last; + wire [0:0] system_cmd_payload_fragment; + wire system_cmd_toStream_valid; + wire system_cmd_toStream_ready; + wire system_cmd_toStream_payload_last; + wire [0:0] system_cmd_toStream_payload_fragment; + (* async_reg = "true" *) reg system_rsp_valid; + (* async_reg = "true" *) reg system_rsp_payload_error; + (* async_reg = "true" *) reg [31:0] system_rsp_payload_data; + wire io_remote_rsp_fire; + wire [3:0] jtag_tap_fsm_stateNext; + reg [3:0] jtag_tap_fsm_state; + wire [3:0] _zz_jtag_tap_fsm_stateNext; + wire [3:0] _zz_jtag_tap_fsm_stateNext_1; + wire [3:0] _zz_jtag_tap_fsm_stateNext_2; + wire [3:0] _zz_jtag_tap_fsm_stateNext_3; + wire [3:0] _zz_jtag_tap_fsm_stateNext_4; + wire [3:0] _zz_jtag_tap_fsm_stateNext_5; + wire [3:0] _zz_jtag_tap_fsm_stateNext_6; + wire [3:0] _zz_jtag_tap_fsm_stateNext_7; + wire [3:0] _zz_jtag_tap_fsm_stateNext_8; + wire [3:0] _zz_jtag_tap_fsm_stateNext_9; + wire [3:0] _zz_jtag_tap_fsm_stateNext_10; + wire [3:0] _zz_jtag_tap_fsm_stateNext_11; + wire [3:0] _zz_jtag_tap_fsm_stateNext_12; + wire [3:0] _zz_jtag_tap_fsm_stateNext_13; + wire [3:0] _zz_jtag_tap_fsm_stateNext_14; + wire [3:0] _zz_jtag_tap_fsm_stateNext_15; + reg [3:0] _zz_jtag_tap_fsm_stateNext_16; + reg [3:0] jtag_tap_instruction; + reg [3:0] jtag_tap_instructionShift; + reg jtag_tap_bypass; + reg jtag_tap_tdoUnbufferd; + reg jtag_tap_tdoDr; + wire jtag_tap_tdoIr; + wire jtag_tap_isBypass; + reg jtag_tap_tdoUnbufferd_regNext; + wire jtag_idcodeArea_ctrl_tdi; + wire jtag_idcodeArea_ctrl_enable; + wire jtag_idcodeArea_ctrl_capture; + wire jtag_idcodeArea_ctrl_shift; + wire jtag_idcodeArea_ctrl_update; + wire jtag_idcodeArea_ctrl_reset; + wire jtag_idcodeArea_ctrl_tdo; + reg [31:0] jtag_idcodeArea_shifter; + wire when_JtagTap_l120; + wire jtag_writeArea_ctrl_tdi; + wire jtag_writeArea_ctrl_enable; + wire jtag_writeArea_ctrl_capture; + wire jtag_writeArea_ctrl_shift; + wire jtag_writeArea_ctrl_update; + wire jtag_writeArea_ctrl_reset; + wire jtag_writeArea_ctrl_tdo; + wire jtag_writeArea_source_valid; + wire jtag_writeArea_source_payload_last; + wire [0:0] jtag_writeArea_source_payload_fragment; + reg jtag_writeArea_valid; + reg jtag_writeArea_data; + wire jtag_readArea_ctrl_tdi; + wire jtag_readArea_ctrl_enable; + wire jtag_readArea_ctrl_capture; + wire jtag_readArea_ctrl_shift; + wire jtag_readArea_ctrl_update; + wire jtag_readArea_ctrl_reset; + wire jtag_readArea_ctrl_tdo; + reg [33:0] jtag_readArea_full_shifter; + `ifndef SYNTHESIS + reg [79:0] jtag_tap_fsm_stateNext_string; + reg [79:0] jtag_tap_fsm_state_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_1_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_2_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_3_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_4_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_5_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_6_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_7_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_8_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_9_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_10_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_11_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_12_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_13_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_14_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_15_string; + reg [79:0] _zz_jtag_tap_fsm_stateNext_16_string; + `endif - assign _zz_rf_scoreboards_0_target_port1 = rf_scoreboards_0_target[scheduler_0_input_payload_rs1]; - assign _zz_rf_scoreboards_0_target_port2 = rf_scoreboards_0_target[scheduler_0_input_payload_rs2]; - assign _zz_rf_scoreboards_0_target_port3 = rf_scoreboards_0_target[scheduler_0_input_payload_rs3]; - assign _zz_rf_scoreboards_0_target_port4 = rf_scoreboards_0_target[scheduler_0_input_payload_rd]; - always @(posedge clk) begin - if(_zz_3) begin - rf_scoreboards_0_hit[rf_scoreboards_0_hitWrite_payload_address] <= _zz_rf_scoreboards_0_hit_port; - end - end - assign _zz_rf_scoreboards_0_hit_port1 = rf_scoreboards_0_hit[scheduler_0_input_payload_rs1]; - assign _zz_rf_scoreboards_0_hit_port2 = rf_scoreboards_0_hit[scheduler_0_input_payload_rs2]; - assign _zz_rf_scoreboards_0_hit_port3 = rf_scoreboards_0_hit[scheduler_0_input_payload_rs3]; - assign _zz_rf_scoreboards_0_hit_port4 = rf_scoreboards_0_hit[scheduler_0_input_payload_rd]; - assign _zz_rf_scoreboards_0_hit_port5 = rf_scoreboards_0_hit[writeback_input_payload_rd]; - always @(posedge clk) begin - if(_zz_2) begin - rf_scoreboards_0_writes[commitLogic_0_input_payload_rd] <= _zz_rf_scoreboards_0_writes_port; - end - end - - assign _zz_rf_scoreboards_0_writes_port1 = rf_scoreboards_0_writes[roundBack_input_payload_rd]; - StreamFork streamFork_1 ( - .io_input_valid (io_port_0_commit_valid ), //i - .io_input_ready (streamFork_1_io_input_ready ), //o - .io_input_payload_opcode (io_port_0_commit_payload_opcode[3:0] ), //i - .io_input_payload_rd (io_port_0_commit_payload_rd[4:0] ), //i - .io_input_payload_write (io_port_0_commit_payload_write ), //i - .io_input_payload_value (io_port_0_commit_payload_value[31:0] ), //i - .io_outputs_0_valid (streamFork_1_io_outputs_0_valid ), //o - .io_outputs_0_ready (commitFork_load_0_ready ), //i - .io_outputs_0_payload_opcode (streamFork_1_io_outputs_0_payload_opcode[3:0]), //o - .io_outputs_0_payload_rd (streamFork_1_io_outputs_0_payload_rd[4:0] ), //o - .io_outputs_0_payload_write (streamFork_1_io_outputs_0_payload_write ), //o - .io_outputs_0_payload_value (streamFork_1_io_outputs_0_payload_value[31:0]), //o - .io_outputs_1_valid (streamFork_1_io_outputs_1_valid ), //o - .io_outputs_1_ready (streamFork_1_io_outputs_1_ready ), //i - .io_outputs_1_payload_opcode (streamFork_1_io_outputs_1_payload_opcode[3:0]), //o - .io_outputs_1_payload_rd (streamFork_1_io_outputs_1_payload_rd[4:0] ), //o - .io_outputs_1_payload_write (streamFork_1_io_outputs_1_payload_write ), //o - .io_outputs_1_payload_value (streamFork_1_io_outputs_1_payload_value[31:0]) //o - ); - StreamArbiter cmdArbiter_arbiter ( - .io_inputs_0_valid (scheduler_0_output_valid ), //i - .io_inputs_0_ready (cmdArbiter_arbiter_io_inputs_0_ready ), //o - .io_inputs_0_payload_opcode (_zz_io_inputs_0_payload_opcode[3:0] ), //i - .io_inputs_0_payload_arg (scheduler_0_output_payload_arg[1:0] ), //i - .io_inputs_0_payload_rs1 (scheduler_0_output_payload_rs1[4:0] ), //i - .io_inputs_0_payload_rs2 (scheduler_0_output_payload_rs2[4:0] ), //i - .io_inputs_0_payload_rs3 (scheduler_0_output_payload_rs3[4:0] ), //i - .io_inputs_0_payload_rd (scheduler_0_output_payload_rd[4:0] ), //i - .io_inputs_0_payload_format (_zz_io_inputs_0_payload_format ), //i - .io_inputs_0_payload_roundMode (_zz_io_inputs_0_payload_roundMode[2:0] ), //i - .io_output_valid (cmdArbiter_arbiter_io_output_valid ), //o - .io_output_ready (cmdArbiter_output_ready ), //i - .io_output_payload_opcode (cmdArbiter_arbiter_io_output_payload_opcode[3:0] ), //o - .io_output_payload_arg (cmdArbiter_arbiter_io_output_payload_arg[1:0] ), //o - .io_output_payload_rs1 (cmdArbiter_arbiter_io_output_payload_rs1[4:0] ), //o - .io_output_payload_rs2 (cmdArbiter_arbiter_io_output_payload_rs2[4:0] ), //o - .io_output_payload_rs3 (cmdArbiter_arbiter_io_output_payload_rs3[4:0] ), //o - .io_output_payload_rd (cmdArbiter_arbiter_io_output_payload_rd[4:0] ), //o - .io_output_payload_format (cmdArbiter_arbiter_io_output_payload_format ), //o - .io_output_payload_roundMode (cmdArbiter_arbiter_io_output_payload_roundMode[2:0]), //o - .io_chosenOH (cmdArbiter_arbiter_io_chosenOH ), //o - .clk (clk ), //i - .reset (reset ) //i - ); - FpuDiv div_divider ( - .io_input_valid (div_divider_io_input_valid ), //i - .io_input_ready (div_divider_io_input_ready ), //o - .io_input_payload_a (div_divider_io_input_payload_a[23:0] ), //i - .io_input_payload_b (div_divider_io_input_payload_b[23:0] ), //i - .io_output_valid (div_divider_io_output_valid ), //o - .io_output_ready (div_input_ready ), //i - .io_output_payload_result (div_divider_io_output_payload_result[26:0]), //o - .io_output_payload_remain (div_divider_io_output_payload_remain[24:0]), //o - .clk (clk ), //i - .reset (reset ) //i - ); - FpuSqrt sqrt_sqrt ( - .io_input_valid (sqrt_sqrt_io_input_valid ), //i - .io_input_ready (sqrt_sqrt_io_input_ready ), //o - .io_input_payload_a (sqrt_sqrt_io_input_payload_a[24:0] ), //i - .io_output_valid (sqrt_sqrt_io_output_valid ), //o - .io_output_ready (sqrt_input_ready ), //i - .io_output_payload_result (sqrt_sqrt_io_output_payload_result[23:0]), //o - .io_output_payload_remain (sqrt_sqrt_io_output_payload_remain[27:0]), //o - .clk (clk ), //i - .reset (reset ) //i - ); - StreamArbiter_1 streamArbiter_2 ( - .io_inputs_0_valid (load_s1_output_m2sPipe_valid ), //i - .io_inputs_0_ready (streamArbiter_2_io_inputs_0_ready ), //o - .io_inputs_0_payload_rd (load_s1_output_m2sPipe_payload_rd[4:0] ), //i - .io_inputs_0_payload_value_mantissa (load_s1_output_m2sPipe_payload_value_mantissa[23:0] ), //i - .io_inputs_0_payload_value_exponent (load_s1_output_m2sPipe_payload_value_exponent[8:0] ), //i - .io_inputs_0_payload_value_sign (load_s1_output_m2sPipe_payload_value_sign ), //i - .io_inputs_0_payload_value_special (load_s1_output_m2sPipe_payload_value_special ), //i - .io_inputs_0_payload_scrap (load_s1_output_m2sPipe_payload_scrap ), //i - .io_inputs_0_payload_roundMode (load_s1_output_m2sPipe_payload_roundMode[2:0] ), //i - .io_inputs_0_payload_NV (load_s1_output_m2sPipe_payload_NV ), //i - .io_inputs_0_payload_DZ (load_s1_output_m2sPipe_payload_DZ ), //i - .io_inputs_1_valid (sqrt_output_valid ), //i - .io_inputs_1_ready (streamArbiter_2_io_inputs_1_ready ), //o - .io_inputs_1_payload_rd (sqrt_output_payload_rd[4:0] ), //i - .io_inputs_1_payload_value_mantissa (sqrt_output_payload_value_mantissa[23:0] ), //i - .io_inputs_1_payload_value_exponent (sqrt_output_payload_value_exponent[8:0] ), //i - .io_inputs_1_payload_value_sign (sqrt_output_payload_value_sign ), //i - .io_inputs_1_payload_value_special (sqrt_output_payload_value_special ), //i - .io_inputs_1_payload_scrap (sqrt_output_payload_scrap ), //i - .io_inputs_1_payload_roundMode (sqrt_output_payload_roundMode[2:0] ), //i - .io_inputs_1_payload_NV (sqrt_output_payload_NV ), //i - .io_inputs_1_payload_DZ (sqrt_output_payload_DZ ), //i - .io_inputs_2_valid (div_output_valid ), //i - .io_inputs_2_ready (streamArbiter_2_io_inputs_2_ready ), //o - .io_inputs_2_payload_rd (div_output_payload_rd[4:0] ), //i - .io_inputs_2_payload_value_mantissa (div_output_payload_value_mantissa[23:0] ), //i - .io_inputs_2_payload_value_exponent (div_output_payload_value_exponent[8:0] ), //i - .io_inputs_2_payload_value_sign (div_output_payload_value_sign ), //i - .io_inputs_2_payload_value_special (div_output_payload_value_special ), //i - .io_inputs_2_payload_scrap (div_output_payload_scrap ), //i - .io_inputs_2_payload_roundMode (div_output_payload_roundMode[2:0] ), //i - .io_inputs_2_payload_NV (div_output_payload_NV ), //i - .io_inputs_2_payload_DZ (div_output_payload_DZ ), //i - .io_inputs_3_valid (add_result_output_valid ), //i - .io_inputs_3_ready (streamArbiter_2_io_inputs_3_ready ), //o - .io_inputs_3_payload_rd (add_result_output_payload_rd[4:0] ), //i - .io_inputs_3_payload_value_mantissa (add_result_output_payload_value_mantissa[23:0] ), //i - .io_inputs_3_payload_value_exponent (add_result_output_payload_value_exponent[8:0] ), //i - .io_inputs_3_payload_value_sign (add_result_output_payload_value_sign ), //i - .io_inputs_3_payload_value_special (add_result_output_payload_value_special ), //i - .io_inputs_3_payload_scrap (add_result_output_payload_scrap ), //i - .io_inputs_3_payload_roundMode (add_result_output_payload_roundMode[2:0] ), //i - .io_inputs_3_payload_NV (add_result_output_payload_NV ), //i - .io_inputs_3_payload_DZ (add_result_output_payload_DZ ), //i - .io_inputs_4_valid (mul_result_output_valid ), //i - .io_inputs_4_ready (streamArbiter_2_io_inputs_4_ready ), //o - .io_inputs_4_payload_rd (mul_result_output_payload_rd[4:0] ), //i - .io_inputs_4_payload_value_mantissa (mul_result_output_payload_value_mantissa[23:0] ), //i - .io_inputs_4_payload_value_exponent (mul_result_output_payload_value_exponent[8:0] ), //i - .io_inputs_4_payload_value_sign (mul_result_output_payload_value_sign ), //i - .io_inputs_4_payload_value_special (mul_result_output_payload_value_special ), //i - .io_inputs_4_payload_scrap (mul_result_output_payload_scrap ), //i - .io_inputs_4_payload_roundMode (mul_result_output_payload_roundMode[2:0] ), //i - .io_inputs_4_payload_NV (mul_result_output_payload_NV ), //i - .io_inputs_4_payload_DZ (mul_result_output_payload_DZ ), //i - .io_inputs_5_valid (shortPip_output_m2sPipe_valid ), //i - .io_inputs_5_ready (streamArbiter_2_io_inputs_5_ready ), //o - .io_inputs_5_payload_rd (shortPip_output_m2sPipe_payload_rd[4:0] ), //i - .io_inputs_5_payload_value_mantissa (shortPip_output_m2sPipe_payload_value_mantissa[23:0] ), //i - .io_inputs_5_payload_value_exponent (shortPip_output_m2sPipe_payload_value_exponent[8:0] ), //i - .io_inputs_5_payload_value_sign (shortPip_output_m2sPipe_payload_value_sign ), //i - .io_inputs_5_payload_value_special (shortPip_output_m2sPipe_payload_value_special ), //i - .io_inputs_5_payload_scrap (shortPip_output_m2sPipe_payload_scrap ), //i - .io_inputs_5_payload_roundMode (shortPip_output_m2sPipe_payload_roundMode[2:0] ), //i - .io_inputs_5_payload_NV (shortPip_output_m2sPipe_payload_NV ), //i - .io_inputs_5_payload_DZ (shortPip_output_m2sPipe_payload_DZ ), //i - .io_output_valid (streamArbiter_2_io_output_valid ), //o - .io_output_ready (1'b1 ), //i - .io_output_payload_rd (streamArbiter_2_io_output_payload_rd[4:0] ), //o - .io_output_payload_value_mantissa (streamArbiter_2_io_output_payload_value_mantissa[23:0]), //o - .io_output_payload_value_exponent (streamArbiter_2_io_output_payload_value_exponent[8:0] ), //o - .io_output_payload_value_sign (streamArbiter_2_io_output_payload_value_sign ), //o - .io_output_payload_value_special (streamArbiter_2_io_output_payload_value_special ), //o - .io_output_payload_scrap (streamArbiter_2_io_output_payload_scrap ), //o - .io_output_payload_roundMode (streamArbiter_2_io_output_payload_roundMode[2:0] ), //o - .io_output_payload_NV (streamArbiter_2_io_output_payload_NV ), //o - .io_output_payload_DZ (streamArbiter_2_io_output_payload_DZ ), //o - .io_chosen (streamArbiter_2_io_chosen[2:0] ), //o - .io_chosenOH (streamArbiter_2_io_chosenOH[5:0] ), //o - .clk (clk ), //i - .reset (reset ) //i + assign _zz_jtag_tap_isBypass = jtag_tap_instruction; + assign _zz_jtag_tap_isBypass_1 = 4'b1111; + assign _zz_jtag_tap_instructionShift = 2'b01; + FlowCCByToggle flowCCByToggle_1 ( + .io_input_valid (jtag_writeArea_source_valid ), //i + .io_input_payload_last (jtag_writeArea_source_payload_last ), //i + .io_input_payload_fragment (jtag_writeArea_source_payload_fragment ), //i + .io_output_valid (flowCCByToggle_1_io_output_valid ), //o + .io_output_payload_last (flowCCByToggle_1_io_output_payload_last ), //o + .io_output_payload_fragment (flowCCByToggle_1_io_output_payload_fragment), //o + .io_jtag_tck (io_jtag_tck ), //i + .clk (clk ), //i + .reset (reset ) //i ); + initial begin `ifndef SYNTHESIS - always @(*) begin - case(io_port_0_cmd_payload_opcode) - FpuOpcode_LOAD : io_port_0_cmd_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_port_0_cmd_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_port_0_cmd_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_port_0_cmd_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_port_0_cmd_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_port_0_cmd_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_port_0_cmd_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_port_0_cmd_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_port_0_cmd_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_port_0_cmd_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_port_0_cmd_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_port_0_cmd_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_port_0_cmd_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_port_0_cmd_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_port_0_cmd_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_port_0_cmd_payload_opcode_string = "FCVT_X_X"; - default : io_port_0_cmd_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_port_0_cmd_payload_format) - FpuFormat_FLOAT : io_port_0_cmd_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : io_port_0_cmd_payload_format_string = "DOUBLE"; - default : io_port_0_cmd_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(io_port_0_cmd_payload_roundMode) - FpuRoundMode_RNE : io_port_0_cmd_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_port_0_cmd_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_port_0_cmd_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_port_0_cmd_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_port_0_cmd_payload_roundMode_string = "RMM"; - default : io_port_0_cmd_payload_roundMode_string = "???"; - endcase + jtag_tap_fsm_state = {1{$urandom}}; + `endif end + + `ifndef SYNTHESIS always @(*) begin - case(io_port_0_commit_payload_opcode) - FpuOpcode_LOAD : io_port_0_commit_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_port_0_commit_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_port_0_commit_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_port_0_commit_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_port_0_commit_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_port_0_commit_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_port_0_commit_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_port_0_commit_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_port_0_commit_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_port_0_commit_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_port_0_commit_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_port_0_commit_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_port_0_commit_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_port_0_commit_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_port_0_commit_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_port_0_commit_payload_opcode_string = "FCVT_X_X"; - default : io_port_0_commit_payload_opcode_string = "????????"; + case(jtag_tap_fsm_stateNext) + JtagState_RESET : jtag_tap_fsm_stateNext_string = "RESET "; + JtagState_IDLE : jtag_tap_fsm_stateNext_string = "IDLE "; + JtagState_IR_SELECT : jtag_tap_fsm_stateNext_string = "IR_SELECT "; + JtagState_IR_CAPTURE : jtag_tap_fsm_stateNext_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : jtag_tap_fsm_stateNext_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : jtag_tap_fsm_stateNext_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : jtag_tap_fsm_stateNext_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : jtag_tap_fsm_stateNext_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : jtag_tap_fsm_stateNext_string = "IR_UPDATE "; + JtagState_DR_SELECT : jtag_tap_fsm_stateNext_string = "DR_SELECT "; + JtagState_DR_CAPTURE : jtag_tap_fsm_stateNext_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : jtag_tap_fsm_stateNext_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : jtag_tap_fsm_stateNext_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : jtag_tap_fsm_stateNext_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : jtag_tap_fsm_stateNext_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : jtag_tap_fsm_stateNext_string = "DR_UPDATE "; + default : jtag_tap_fsm_stateNext_string = "??????????"; + endcase + end + always @(*) begin + case(jtag_tap_fsm_state) + JtagState_RESET : jtag_tap_fsm_state_string = "RESET "; + JtagState_IDLE : jtag_tap_fsm_state_string = "IDLE "; + JtagState_IR_SELECT : jtag_tap_fsm_state_string = "IR_SELECT "; + JtagState_IR_CAPTURE : jtag_tap_fsm_state_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : jtag_tap_fsm_state_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : jtag_tap_fsm_state_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : jtag_tap_fsm_state_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : jtag_tap_fsm_state_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : jtag_tap_fsm_state_string = "IR_UPDATE "; + JtagState_DR_SELECT : jtag_tap_fsm_state_string = "DR_SELECT "; + JtagState_DR_CAPTURE : jtag_tap_fsm_state_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : jtag_tap_fsm_state_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : jtag_tap_fsm_state_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : jtag_tap_fsm_state_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : jtag_tap_fsm_state_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : jtag_tap_fsm_state_string = "DR_UPDATE "; + default : jtag_tap_fsm_state_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_1) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_1_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_1_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_1_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_1_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_1_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_1_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_1_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_1_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_1_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_1_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_1_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_1_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_1_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_1_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_1_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_1_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_1_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_2) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_2_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_2_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_2_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_2_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_2_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_2_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_2_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_2_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_2_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_2_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_2_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_2_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_2_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_2_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_2_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_2_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_2_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_3) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_3_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_3_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_3_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_3_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_3_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_3_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_3_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_3_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_3_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_3_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_3_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_3_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_3_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_3_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_3_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_3_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_3_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_4) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_4_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_4_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_4_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_4_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_4_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_4_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_4_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_4_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_4_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_4_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_4_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_4_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_4_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_4_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_4_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_4_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_4_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_5) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_5_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_5_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_5_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_5_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_5_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_5_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_5_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_5_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_5_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_5_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_5_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_5_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_5_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_5_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_5_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_5_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_5_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_6) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_6_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_6_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_6_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_6_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_6_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_6_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_6_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_6_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_6_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_6_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_6_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_6_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_6_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_6_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_6_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_6_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_6_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_7) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_7_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_7_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_7_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_7_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_7_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_7_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_7_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_7_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_7_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_7_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_7_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_7_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_7_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_7_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_7_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_7_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_7_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_8) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_8_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_8_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_8_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_8_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_8_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_8_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_8_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_8_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_8_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_8_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_8_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_8_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_8_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_8_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_8_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_8_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_8_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_9) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_9_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_9_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_9_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_9_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_9_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_9_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_9_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_9_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_9_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_9_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_9_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_9_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_9_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_9_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_9_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_9_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_9_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_10) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_10_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_10_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_10_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_10_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_10_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_10_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_10_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_10_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_10_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_10_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_10_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_10_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_10_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_10_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_10_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_10_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_10_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_11) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_11_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_11_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_11_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_11_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_11_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_11_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_11_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_11_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_11_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_11_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_11_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_11_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_11_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_11_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_11_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_11_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_11_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_12) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_12_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_12_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_12_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_12_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_12_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_12_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_12_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_12_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_12_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_12_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_12_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_12_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_12_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_12_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_12_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_12_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_12_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_13) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_13_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_13_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_13_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_13_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_13_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_13_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_13_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_13_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_13_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_13_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_13_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_13_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_13_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_13_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_13_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_13_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_13_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_14) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_14_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_14_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_14_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_14_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_14_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_14_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_14_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_14_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_14_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_14_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_14_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_14_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_14_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_14_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_14_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_14_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_14_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_15) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_15_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_15_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_15_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_15_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_15_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_15_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_15_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_15_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_15_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_15_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_15_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_15_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_15_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_15_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_15_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_15_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_15_string = "??????????"; + endcase + end + always @(*) begin + case(_zz_jtag_tap_fsm_stateNext_16) + JtagState_RESET : _zz_jtag_tap_fsm_stateNext_16_string = "RESET "; + JtagState_IDLE : _zz_jtag_tap_fsm_stateNext_16_string = "IDLE "; + JtagState_IR_SELECT : _zz_jtag_tap_fsm_stateNext_16_string = "IR_SELECT "; + JtagState_IR_CAPTURE : _zz_jtag_tap_fsm_stateNext_16_string = "IR_CAPTURE"; + JtagState_IR_SHIFT : _zz_jtag_tap_fsm_stateNext_16_string = "IR_SHIFT "; + JtagState_IR_EXIT1 : _zz_jtag_tap_fsm_stateNext_16_string = "IR_EXIT1 "; + JtagState_IR_PAUSE : _zz_jtag_tap_fsm_stateNext_16_string = "IR_PAUSE "; + JtagState_IR_EXIT2 : _zz_jtag_tap_fsm_stateNext_16_string = "IR_EXIT2 "; + JtagState_IR_UPDATE : _zz_jtag_tap_fsm_stateNext_16_string = "IR_UPDATE "; + JtagState_DR_SELECT : _zz_jtag_tap_fsm_stateNext_16_string = "DR_SELECT "; + JtagState_DR_CAPTURE : _zz_jtag_tap_fsm_stateNext_16_string = "DR_CAPTURE"; + JtagState_DR_SHIFT : _zz_jtag_tap_fsm_stateNext_16_string = "DR_SHIFT "; + JtagState_DR_EXIT1 : _zz_jtag_tap_fsm_stateNext_16_string = "DR_EXIT1 "; + JtagState_DR_PAUSE : _zz_jtag_tap_fsm_stateNext_16_string = "DR_PAUSE "; + JtagState_DR_EXIT2 : _zz_jtag_tap_fsm_stateNext_16_string = "DR_EXIT2 "; + JtagState_DR_UPDATE : _zz_jtag_tap_fsm_stateNext_16_string = "DR_UPDATE "; + default : _zz_jtag_tap_fsm_stateNext_16_string = "??????????"; endcase end - always @(*) begin - case(commitFork_load_0_payload_opcode) - FpuOpcode_LOAD : commitFork_load_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : commitFork_load_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : commitFork_load_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : commitFork_load_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : commitFork_load_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : commitFork_load_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : commitFork_load_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : commitFork_load_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : commitFork_load_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : commitFork_load_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : commitFork_load_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : commitFork_load_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : commitFork_load_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : commitFork_load_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : commitFork_load_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : commitFork_load_0_payload_opcode_string = "FCVT_X_X"; - default : commitFork_load_0_payload_opcode_string = "????????"; + `endif + + assign system_cmd_toStream_valid = system_cmd_valid; + assign system_cmd_toStream_payload_last = system_cmd_payload_last; + assign system_cmd_toStream_payload_fragment = system_cmd_payload_fragment; + assign io_remote_cmd_valid = system_cmd_toStream_valid; + assign system_cmd_toStream_ready = io_remote_cmd_ready; + assign io_remote_cmd_payload_last = system_cmd_toStream_payload_last; + assign io_remote_cmd_payload_fragment = system_cmd_toStream_payload_fragment; + assign io_remote_rsp_fire = (io_remote_rsp_valid && io_remote_rsp_ready); + assign io_remote_rsp_ready = 1'b1; + assign _zz_jtag_tap_fsm_stateNext = (io_jtag_tms ? JtagState_RESET : JtagState_IDLE); + assign _zz_jtag_tap_fsm_stateNext_1 = (io_jtag_tms ? JtagState_DR_SELECT : JtagState_IDLE); + assign _zz_jtag_tap_fsm_stateNext_2 = (io_jtag_tms ? JtagState_RESET : JtagState_IR_CAPTURE); + assign _zz_jtag_tap_fsm_stateNext_3 = (io_jtag_tms ? JtagState_IR_EXIT1 : JtagState_IR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_4 = (io_jtag_tms ? JtagState_IR_EXIT1 : JtagState_IR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_5 = (io_jtag_tms ? JtagState_IR_UPDATE : JtagState_IR_PAUSE); + assign _zz_jtag_tap_fsm_stateNext_6 = (io_jtag_tms ? JtagState_IR_EXIT2 : JtagState_IR_PAUSE); + assign _zz_jtag_tap_fsm_stateNext_7 = (io_jtag_tms ? JtagState_IR_UPDATE : JtagState_IR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_8 = (io_jtag_tms ? JtagState_DR_SELECT : JtagState_IDLE); + assign _zz_jtag_tap_fsm_stateNext_9 = (io_jtag_tms ? JtagState_IR_SELECT : JtagState_DR_CAPTURE); + assign _zz_jtag_tap_fsm_stateNext_10 = (io_jtag_tms ? JtagState_DR_EXIT1 : JtagState_DR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_11 = (io_jtag_tms ? JtagState_DR_EXIT1 : JtagState_DR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_12 = (io_jtag_tms ? JtagState_DR_UPDATE : JtagState_DR_PAUSE); + assign _zz_jtag_tap_fsm_stateNext_13 = (io_jtag_tms ? JtagState_DR_EXIT2 : JtagState_DR_PAUSE); + assign _zz_jtag_tap_fsm_stateNext_14 = (io_jtag_tms ? JtagState_DR_UPDATE : JtagState_DR_SHIFT); + assign _zz_jtag_tap_fsm_stateNext_15 = (io_jtag_tms ? JtagState_DR_SELECT : JtagState_IDLE); + always @(*) begin + case(jtag_tap_fsm_state) + JtagState_IDLE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_1; + end + JtagState_IR_SELECT : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_2; + end + JtagState_IR_CAPTURE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_3; + end + JtagState_IR_SHIFT : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_4; + end + JtagState_IR_EXIT1 : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_5; + end + JtagState_IR_PAUSE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_6; + end + JtagState_IR_EXIT2 : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_7; + end + JtagState_IR_UPDATE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_8; + end + JtagState_DR_SELECT : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_9; + end + JtagState_DR_CAPTURE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_10; + end + JtagState_DR_SHIFT : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_11; + end + JtagState_DR_EXIT1 : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_12; + end + JtagState_DR_PAUSE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_13; + end + JtagState_DR_EXIT2 : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_14; + end + JtagState_DR_UPDATE : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext_15; + end + default : begin + _zz_jtag_tap_fsm_stateNext_16 = _zz_jtag_tap_fsm_stateNext; + end endcase end + + assign jtag_tap_fsm_stateNext = _zz_jtag_tap_fsm_stateNext_16; always @(*) begin - case(commitFork_commit_0_payload_opcode) - FpuOpcode_LOAD : commitFork_commit_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : commitFork_commit_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : commitFork_commit_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : commitFork_commit_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : commitFork_commit_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : commitFork_commit_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : commitFork_commit_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : commitFork_commit_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : commitFork_commit_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : commitFork_commit_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : commitFork_commit_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : commitFork_commit_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : commitFork_commit_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : commitFork_commit_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : commitFork_commit_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : commitFork_commit_0_payload_opcode_string = "FCVT_X_X"; - default : commitFork_commit_0_payload_opcode_string = "????????"; + jtag_tap_tdoUnbufferd = jtag_tap_bypass; + case(jtag_tap_fsm_state) + JtagState_IR_SHIFT : begin + jtag_tap_tdoUnbufferd = jtag_tap_tdoIr; + end + JtagState_DR_SHIFT : begin + if(jtag_tap_isBypass) begin + jtag_tap_tdoUnbufferd = jtag_tap_bypass; + end else begin + jtag_tap_tdoUnbufferd = jtag_tap_tdoDr; + end + end + default : begin + end endcase end + always @(*) begin - case(streamFork_1_io_outputs_1_s2mPipe_payload_opcode) - FpuOpcode_LOAD : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "STORE "; - FpuOpcode_MUL : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "MUL "; - FpuOpcode_ADD : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "ADD "; - FpuOpcode_FMA : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "FMA "; - FpuOpcode_I2F : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "I2F "; - FpuOpcode_F2I : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "F2I "; - FpuOpcode_CMP : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "CMP "; - FpuOpcode_DIV : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "FCVT_X_X"; - default : streamFork_1_io_outputs_1_s2mPipe_payload_opcode_string = "????????"; - endcase + jtag_tap_tdoDr = 1'b0; + if(jtag_idcodeArea_ctrl_enable) begin + jtag_tap_tdoDr = jtag_idcodeArea_ctrl_tdo; + end + if(jtag_writeArea_ctrl_enable) begin + jtag_tap_tdoDr = jtag_writeArea_ctrl_tdo; + end + if(jtag_readArea_ctrl_enable) begin + jtag_tap_tdoDr = jtag_readArea_ctrl_tdo; + end + end + + assign jtag_tap_tdoIr = jtag_tap_instructionShift[0]; + assign jtag_tap_isBypass = ($signed(_zz_jtag_tap_isBypass) == $signed(_zz_jtag_tap_isBypass_1)); + assign io_jtag_tdo = jtag_tap_tdoUnbufferd_regNext; + assign jtag_idcodeArea_ctrl_tdo = jtag_idcodeArea_shifter[0]; + assign jtag_idcodeArea_ctrl_tdi = io_jtag_tdi; + assign jtag_idcodeArea_ctrl_enable = (jtag_tap_instruction == 4'b0001); + assign jtag_idcodeArea_ctrl_capture = (jtag_tap_fsm_state == JtagState_DR_CAPTURE); + assign jtag_idcodeArea_ctrl_shift = (jtag_tap_fsm_state == JtagState_DR_SHIFT); + assign jtag_idcodeArea_ctrl_update = (jtag_tap_fsm_state == JtagState_DR_UPDATE); + assign jtag_idcodeArea_ctrl_reset = (jtag_tap_fsm_state == JtagState_RESET); + assign when_JtagTap_l120 = (jtag_tap_fsm_state == JtagState_RESET); + assign jtag_writeArea_source_valid = jtag_writeArea_valid; + assign jtag_writeArea_source_payload_last = (! (jtag_writeArea_ctrl_enable && jtag_writeArea_ctrl_shift)); + assign jtag_writeArea_source_payload_fragment[0] = jtag_writeArea_data; + assign system_cmd_valid = flowCCByToggle_1_io_output_valid; + assign system_cmd_payload_last = flowCCByToggle_1_io_output_payload_last; + assign system_cmd_payload_fragment = flowCCByToggle_1_io_output_payload_fragment; + assign jtag_writeArea_ctrl_tdo = 1'b0; + assign jtag_writeArea_ctrl_tdi = io_jtag_tdi; + assign jtag_writeArea_ctrl_enable = (jtag_tap_instruction == 4'b0010); + assign jtag_writeArea_ctrl_capture = (jtag_tap_fsm_state == JtagState_DR_CAPTURE); + assign jtag_writeArea_ctrl_shift = (jtag_tap_fsm_state == JtagState_DR_SHIFT); + assign jtag_writeArea_ctrl_update = (jtag_tap_fsm_state == JtagState_DR_UPDATE); + assign jtag_writeArea_ctrl_reset = (jtag_tap_fsm_state == JtagState_RESET); + assign jtag_readArea_ctrl_tdo = jtag_readArea_full_shifter[0]; + assign jtag_readArea_ctrl_tdi = io_jtag_tdi; + assign jtag_readArea_ctrl_enable = (jtag_tap_instruction == 4'b0011); + assign jtag_readArea_ctrl_capture = (jtag_tap_fsm_state == JtagState_DR_CAPTURE); + assign jtag_readArea_ctrl_shift = (jtag_tap_fsm_state == JtagState_DR_SHIFT); + assign jtag_readArea_ctrl_update = (jtag_tap_fsm_state == JtagState_DR_UPDATE); + assign jtag_readArea_ctrl_reset = (jtag_tap_fsm_state == JtagState_RESET); + always @(posedge clk) begin + if(io_remote_cmd_valid) begin + system_rsp_valid <= 1'b0; + end + if(io_remote_rsp_fire) begin + system_rsp_valid <= 1'b1; + system_rsp_payload_error <= io_remote_rsp_payload_error; + system_rsp_payload_data <= io_remote_rsp_payload_data; + end end - always @(*) begin - case(streamFork_1_io_outputs_1_rData_opcode) - FpuOpcode_LOAD : streamFork_1_io_outputs_1_rData_opcode_string = "LOAD "; - FpuOpcode_STORE : streamFork_1_io_outputs_1_rData_opcode_string = "STORE "; - FpuOpcode_MUL : streamFork_1_io_outputs_1_rData_opcode_string = "MUL "; - FpuOpcode_ADD : streamFork_1_io_outputs_1_rData_opcode_string = "ADD "; - FpuOpcode_FMA : streamFork_1_io_outputs_1_rData_opcode_string = "FMA "; - FpuOpcode_I2F : streamFork_1_io_outputs_1_rData_opcode_string = "I2F "; - FpuOpcode_F2I : streamFork_1_io_outputs_1_rData_opcode_string = "F2I "; - FpuOpcode_CMP : streamFork_1_io_outputs_1_rData_opcode_string = "CMP "; - FpuOpcode_DIV : streamFork_1_io_outputs_1_rData_opcode_string = "DIV "; - FpuOpcode_SQRT : streamFork_1_io_outputs_1_rData_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : streamFork_1_io_outputs_1_rData_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : streamFork_1_io_outputs_1_rData_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : streamFork_1_io_outputs_1_rData_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : streamFork_1_io_outputs_1_rData_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : streamFork_1_io_outputs_1_rData_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : streamFork_1_io_outputs_1_rData_opcode_string = "FCVT_X_X"; - default : streamFork_1_io_outputs_1_rData_opcode_string = "????????"; + + always @(posedge io_jtag_tck) begin + jtag_tap_fsm_state <= jtag_tap_fsm_stateNext; + jtag_tap_bypass <= io_jtag_tdi; + case(jtag_tap_fsm_state) + JtagState_IR_CAPTURE : begin + jtag_tap_instructionShift <= {2'd0, _zz_jtag_tap_instructionShift}; + end + JtagState_IR_SHIFT : begin + jtag_tap_instructionShift <= ({io_jtag_tdi,jtag_tap_instructionShift} >>> 1); + end + JtagState_IR_UPDATE : begin + jtag_tap_instruction <= jtag_tap_instructionShift; + end + JtagState_DR_SHIFT : begin + jtag_tap_instructionShift <= ({io_jtag_tdi,jtag_tap_instructionShift} >>> 1); + end + default : begin + end endcase + if(jtag_idcodeArea_ctrl_enable) begin + if(jtag_idcodeArea_ctrl_shift) begin + jtag_idcodeArea_shifter <= ({jtag_idcodeArea_ctrl_tdi,jtag_idcodeArea_shifter} >>> 1); + end + end + if(jtag_idcodeArea_ctrl_capture) begin + jtag_idcodeArea_shifter <= 32'h10001fff; + end + if(when_JtagTap_l120) begin + jtag_tap_instruction <= 4'b0001; + end + jtag_writeArea_valid <= (jtag_writeArea_ctrl_enable && jtag_writeArea_ctrl_shift); + jtag_writeArea_data <= jtag_writeArea_ctrl_tdi; + if(jtag_readArea_ctrl_enable) begin + if(jtag_readArea_ctrl_capture) begin + jtag_readArea_full_shifter <= {{system_rsp_payload_data,system_rsp_payload_error},system_rsp_valid}; + end + if(jtag_readArea_ctrl_shift) begin + jtag_readArea_full_shifter <= ({jtag_readArea_ctrl_tdi,jtag_readArea_full_shifter} >>> 1); + end + end end - always @(*) begin - case(_zz_payload_opcode) - FpuOpcode_LOAD : _zz_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_payload_opcode_string = "FCVT_X_X"; - default : _zz_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(_zz_commitLogic_0_input_payload_opcode) - FpuOpcode_LOAD : _zz_commitLogic_0_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_commitLogic_0_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_commitLogic_0_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_commitLogic_0_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_commitLogic_0_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_commitLogic_0_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_commitLogic_0_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_commitLogic_0_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_commitLogic_0_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_commitLogic_0_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_commitLogic_0_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_commitLogic_0_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_commitLogic_0_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_commitLogic_0_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_commitLogic_0_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_commitLogic_0_input_payload_opcode_string = "FCVT_X_X"; - default : _zz_commitLogic_0_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(commitLogic_0_input_payload_opcode) - FpuOpcode_LOAD : commitLogic_0_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : commitLogic_0_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : commitLogic_0_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : commitLogic_0_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : commitLogic_0_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : commitLogic_0_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : commitLogic_0_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : commitLogic_0_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : commitLogic_0_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : commitLogic_0_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : commitLogic_0_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : commitLogic_0_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : commitLogic_0_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : commitLogic_0_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : commitLogic_0_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : commitLogic_0_input_payload_opcode_string = "FCVT_X_X"; - default : commitLogic_0_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : scheduler_0_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : scheduler_0_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : scheduler_0_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : scheduler_0_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : scheduler_0_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : scheduler_0_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : scheduler_0_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : scheduler_0_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : scheduler_0_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : scheduler_0_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : scheduler_0_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : scheduler_0_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : scheduler_0_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : scheduler_0_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : scheduler_0_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : scheduler_0_input_payload_opcode_string = "FCVT_X_X"; - default : scheduler_0_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(scheduler_0_input_payload_format) - FpuFormat_FLOAT : scheduler_0_input_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : scheduler_0_input_payload_format_string = "DOUBLE"; - default : scheduler_0_input_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(scheduler_0_input_payload_roundMode) - FpuRoundMode_RNE : scheduler_0_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : scheduler_0_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : scheduler_0_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : scheduler_0_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : scheduler_0_input_payload_roundMode_string = "RMM"; - default : scheduler_0_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_port_0_cmd_rData_opcode) - FpuOpcode_LOAD : io_port_0_cmd_rData_opcode_string = "LOAD "; - FpuOpcode_STORE : io_port_0_cmd_rData_opcode_string = "STORE "; - FpuOpcode_MUL : io_port_0_cmd_rData_opcode_string = "MUL "; - FpuOpcode_ADD : io_port_0_cmd_rData_opcode_string = "ADD "; - FpuOpcode_FMA : io_port_0_cmd_rData_opcode_string = "FMA "; - FpuOpcode_I2F : io_port_0_cmd_rData_opcode_string = "I2F "; - FpuOpcode_F2I : io_port_0_cmd_rData_opcode_string = "F2I "; - FpuOpcode_CMP : io_port_0_cmd_rData_opcode_string = "CMP "; - FpuOpcode_DIV : io_port_0_cmd_rData_opcode_string = "DIV "; - FpuOpcode_SQRT : io_port_0_cmd_rData_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_port_0_cmd_rData_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_port_0_cmd_rData_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_port_0_cmd_rData_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_port_0_cmd_rData_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_port_0_cmd_rData_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_port_0_cmd_rData_opcode_string = "FCVT_X_X"; - default : io_port_0_cmd_rData_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_port_0_cmd_rData_format) - FpuFormat_FLOAT : io_port_0_cmd_rData_format_string = "FLOAT "; - FpuFormat_DOUBLE : io_port_0_cmd_rData_format_string = "DOUBLE"; - default : io_port_0_cmd_rData_format_string = "??????"; - endcase - end - always @(*) begin - case(io_port_0_cmd_rData_roundMode) - FpuRoundMode_RNE : io_port_0_cmd_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_port_0_cmd_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_port_0_cmd_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_port_0_cmd_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_port_0_cmd_rData_roundMode_string = "RMM"; - default : io_port_0_cmd_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : _zz_scheduler_0_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_scheduler_0_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_scheduler_0_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_scheduler_0_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_scheduler_0_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_scheduler_0_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_scheduler_0_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_scheduler_0_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_scheduler_0_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_scheduler_0_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_scheduler_0_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_scheduler_0_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_scheduler_0_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_scheduler_0_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_scheduler_0_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_scheduler_0_input_payload_opcode_string = "FCVT_X_X"; - default : _zz_scheduler_0_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(_zz_scheduler_0_input_payload_format) - FpuFormat_FLOAT : _zz_scheduler_0_input_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : _zz_scheduler_0_input_payload_format_string = "DOUBLE"; - default : _zz_scheduler_0_input_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(_zz_scheduler_0_input_payload_roundMode) - FpuRoundMode_RNE : _zz_scheduler_0_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_scheduler_0_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_scheduler_0_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_scheduler_0_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_scheduler_0_input_payload_roundMode_string = "RMM"; - default : _zz_scheduler_0_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(scheduler_0_output_payload_opcode) - FpuOpcode_LOAD : scheduler_0_output_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : scheduler_0_output_payload_opcode_string = "STORE "; - FpuOpcode_MUL : scheduler_0_output_payload_opcode_string = "MUL "; - FpuOpcode_ADD : scheduler_0_output_payload_opcode_string = "ADD "; - FpuOpcode_FMA : scheduler_0_output_payload_opcode_string = "FMA "; - FpuOpcode_I2F : scheduler_0_output_payload_opcode_string = "I2F "; - FpuOpcode_F2I : scheduler_0_output_payload_opcode_string = "F2I "; - FpuOpcode_CMP : scheduler_0_output_payload_opcode_string = "CMP "; - FpuOpcode_DIV : scheduler_0_output_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : scheduler_0_output_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : scheduler_0_output_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : scheduler_0_output_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : scheduler_0_output_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : scheduler_0_output_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : scheduler_0_output_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : scheduler_0_output_payload_opcode_string = "FCVT_X_X"; - default : scheduler_0_output_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(scheduler_0_output_payload_format) - FpuFormat_FLOAT : scheduler_0_output_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : scheduler_0_output_payload_format_string = "DOUBLE"; - default : scheduler_0_output_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(scheduler_0_output_payload_roundMode) - FpuRoundMode_RNE : scheduler_0_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : scheduler_0_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : scheduler_0_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : scheduler_0_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : scheduler_0_output_payload_roundMode_string = "RMM"; - default : scheduler_0_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_io_inputs_0_payload_opcode) - FpuOpcode_LOAD : _zz_io_inputs_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_io_inputs_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_io_inputs_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_io_inputs_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_io_inputs_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_io_inputs_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_io_inputs_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_io_inputs_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_io_inputs_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_io_inputs_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_io_inputs_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_io_inputs_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_io_inputs_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_io_inputs_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_io_inputs_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_io_inputs_0_payload_opcode_string = "FCVT_X_X"; - default : _zz_io_inputs_0_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(_zz_io_inputs_0_payload_format) - FpuFormat_FLOAT : _zz_io_inputs_0_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : _zz_io_inputs_0_payload_format_string = "DOUBLE"; - default : _zz_io_inputs_0_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(_zz_io_inputs_0_payload_roundMode) - FpuRoundMode_RNE : _zz_io_inputs_0_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_io_inputs_0_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_io_inputs_0_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_io_inputs_0_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_io_inputs_0_payload_roundMode_string = "RMM"; - default : _zz_io_inputs_0_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(cmdArbiter_output_payload_opcode) - FpuOpcode_LOAD : cmdArbiter_output_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : cmdArbiter_output_payload_opcode_string = "STORE "; - FpuOpcode_MUL : cmdArbiter_output_payload_opcode_string = "MUL "; - FpuOpcode_ADD : cmdArbiter_output_payload_opcode_string = "ADD "; - FpuOpcode_FMA : cmdArbiter_output_payload_opcode_string = "FMA "; - FpuOpcode_I2F : cmdArbiter_output_payload_opcode_string = "I2F "; - FpuOpcode_F2I : cmdArbiter_output_payload_opcode_string = "F2I "; - FpuOpcode_CMP : cmdArbiter_output_payload_opcode_string = "CMP "; - FpuOpcode_DIV : cmdArbiter_output_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : cmdArbiter_output_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : cmdArbiter_output_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : cmdArbiter_output_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : cmdArbiter_output_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : cmdArbiter_output_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : cmdArbiter_output_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : cmdArbiter_output_payload_opcode_string = "FCVT_X_X"; - default : cmdArbiter_output_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(cmdArbiter_output_payload_roundMode) - FpuRoundMode_RNE : cmdArbiter_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : cmdArbiter_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : cmdArbiter_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : cmdArbiter_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : cmdArbiter_output_payload_roundMode_string = "RMM"; - default : cmdArbiter_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(read_s0_payload_opcode) - FpuOpcode_LOAD : read_s0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : read_s0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : read_s0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : read_s0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : read_s0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : read_s0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : read_s0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : read_s0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : read_s0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : read_s0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : read_s0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : read_s0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : read_s0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : read_s0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : read_s0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : read_s0_payload_opcode_string = "FCVT_X_X"; - default : read_s0_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(read_s0_payload_roundMode) - FpuRoundMode_RNE : read_s0_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : read_s0_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : read_s0_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : read_s0_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : read_s0_payload_roundMode_string = "RMM"; - default : read_s0_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(read_s1_payload_opcode) - FpuOpcode_LOAD : read_s1_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : read_s1_payload_opcode_string = "STORE "; - FpuOpcode_MUL : read_s1_payload_opcode_string = "MUL "; - FpuOpcode_ADD : read_s1_payload_opcode_string = "ADD "; - FpuOpcode_FMA : read_s1_payload_opcode_string = "FMA "; - FpuOpcode_I2F : read_s1_payload_opcode_string = "I2F "; - FpuOpcode_F2I : read_s1_payload_opcode_string = "F2I "; - FpuOpcode_CMP : read_s1_payload_opcode_string = "CMP "; - FpuOpcode_DIV : read_s1_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : read_s1_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : read_s1_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : read_s1_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : read_s1_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : read_s1_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : read_s1_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : read_s1_payload_opcode_string = "FCVT_X_X"; - default : read_s1_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(read_s1_payload_roundMode) - FpuRoundMode_RNE : read_s1_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : read_s1_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : read_s1_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : read_s1_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : read_s1_payload_roundMode_string = "RMM"; - default : read_s1_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(read_s0_rData_opcode) - FpuOpcode_LOAD : read_s0_rData_opcode_string = "LOAD "; - FpuOpcode_STORE : read_s0_rData_opcode_string = "STORE "; - FpuOpcode_MUL : read_s0_rData_opcode_string = "MUL "; - FpuOpcode_ADD : read_s0_rData_opcode_string = "ADD "; - FpuOpcode_FMA : read_s0_rData_opcode_string = "FMA "; - FpuOpcode_I2F : read_s0_rData_opcode_string = "I2F "; - FpuOpcode_F2I : read_s0_rData_opcode_string = "F2I "; - FpuOpcode_CMP : read_s0_rData_opcode_string = "CMP "; - FpuOpcode_DIV : read_s0_rData_opcode_string = "DIV "; - FpuOpcode_SQRT : read_s0_rData_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : read_s0_rData_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : read_s0_rData_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : read_s0_rData_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : read_s0_rData_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : read_s0_rData_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : read_s0_rData_opcode_string = "FCVT_X_X"; - default : read_s0_rData_opcode_string = "????????"; - endcase - end - always @(*) begin - case(read_s0_rData_roundMode) - FpuRoundMode_RNE : read_s0_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : read_s0_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : read_s0_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : read_s0_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : read_s0_rData_roundMode_string = "RMM"; - default : read_s0_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(read_output_payload_opcode) - FpuOpcode_LOAD : read_output_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : read_output_payload_opcode_string = "STORE "; - FpuOpcode_MUL : read_output_payload_opcode_string = "MUL "; - FpuOpcode_ADD : read_output_payload_opcode_string = "ADD "; - FpuOpcode_FMA : read_output_payload_opcode_string = "FMA "; - FpuOpcode_I2F : read_output_payload_opcode_string = "I2F "; - FpuOpcode_F2I : read_output_payload_opcode_string = "F2I "; - FpuOpcode_CMP : read_output_payload_opcode_string = "CMP "; - FpuOpcode_DIV : read_output_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : read_output_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : read_output_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : read_output_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : read_output_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : read_output_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : read_output_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : read_output_payload_opcode_string = "FCVT_X_X"; - default : read_output_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(read_output_payload_roundMode) - FpuRoundMode_RNE : read_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : read_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : read_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : read_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : read_output_payload_roundMode_string = "RMM"; - default : read_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_input_payload_opcode) - FpuOpcode_LOAD : decode_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : decode_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : decode_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : decode_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : decode_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : decode_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : decode_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : decode_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : decode_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : decode_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : decode_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : decode_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : decode_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : decode_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : decode_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : decode_input_payload_opcode_string = "FCVT_X_X"; - default : decode_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(decode_input_payload_roundMode) - FpuRoundMode_RNE : decode_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_input_payload_roundMode_string = "RMM"; - default : decode_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_payload_roundMode) - FpuRoundMode_RNE : decode_load_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_payload_roundMode_string = "RMM"; - default : decode_load_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_shortPip_payload_opcode) - FpuOpcode_LOAD : decode_shortPip_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : decode_shortPip_payload_opcode_string = "STORE "; - FpuOpcode_MUL : decode_shortPip_payload_opcode_string = "MUL "; - FpuOpcode_ADD : decode_shortPip_payload_opcode_string = "ADD "; - FpuOpcode_FMA : decode_shortPip_payload_opcode_string = "FMA "; - FpuOpcode_I2F : decode_shortPip_payload_opcode_string = "I2F "; - FpuOpcode_F2I : decode_shortPip_payload_opcode_string = "F2I "; - FpuOpcode_CMP : decode_shortPip_payload_opcode_string = "CMP "; - FpuOpcode_DIV : decode_shortPip_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : decode_shortPip_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : decode_shortPip_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : decode_shortPip_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : decode_shortPip_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : decode_shortPip_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : decode_shortPip_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : decode_shortPip_payload_opcode_string = "FCVT_X_X"; - default : decode_shortPip_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(decode_shortPip_payload_roundMode) - FpuRoundMode_RNE : decode_shortPip_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_shortPip_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_shortPip_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_shortPip_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_shortPip_payload_roundMode_string = "RMM"; - default : decode_shortPip_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_divSqrt_payload_roundMode) - FpuRoundMode_RNE : decode_divSqrt_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_divSqrt_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_divSqrt_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_divSqrt_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_divSqrt_payload_roundMode_string = "RMM"; - default : decode_divSqrt_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_div_payload_roundMode) - FpuRoundMode_RNE : decode_div_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_div_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_div_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_div_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_div_payload_roundMode_string = "RMM"; - default : decode_div_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_sqrt_payload_roundMode) - FpuRoundMode_RNE : decode_sqrt_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_sqrt_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_sqrt_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_sqrt_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_sqrt_payload_roundMode_string = "RMM"; - default : decode_sqrt_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_mul_payload_roundMode) - FpuRoundMode_RNE : decode_mul_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_mul_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_mul_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_mul_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_mul_payload_roundMode_string = "RMM"; - default : decode_mul_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_divSqrtToMul_payload_roundMode) - FpuRoundMode_RNE : decode_divSqrtToMul_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_divSqrtToMul_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_divSqrtToMul_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_divSqrtToMul_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_divSqrtToMul_payload_roundMode_string = "RMM"; - default : decode_divSqrtToMul_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_add_payload_roundMode) - FpuRoundMode_RNE : decode_add_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_add_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_add_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_add_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_add_payload_roundMode_string = "RMM"; - default : decode_add_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_mulToAdd_payload_roundMode) - FpuRoundMode_RNE : decode_mulToAdd_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_mulToAdd_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_mulToAdd_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_mulToAdd_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_mulToAdd_payload_roundMode_string = "RMM"; - default : decode_mulToAdd_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_s2mPipe_payload_roundMode) - FpuRoundMode_RNE : decode_load_s2mPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_s2mPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_s2mPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_s2mPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_s2mPipe_payload_roundMode_string = "RMM"; - default : decode_load_s2mPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_rData_roundMode) - FpuRoundMode_RNE : decode_load_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_rData_roundMode_string = "RMM"; - default : decode_load_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_decode_load_s2mPipe_payload_roundMode) - FpuRoundMode_RNE : _zz_decode_load_s2mPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_decode_load_s2mPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_decode_load_s2mPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_decode_load_s2mPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_decode_load_s2mPipe_payload_roundMode_string = "RMM"; - default : _zz_decode_load_s2mPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_s2mPipe_m2sPipe_payload_roundMode) - FpuRoundMode_RNE : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "RMM"; - default : decode_load_s2mPipe_m2sPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_s2mPipe_rData_roundMode) - FpuRoundMode_RNE : decode_load_s2mPipe_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_s2mPipe_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_s2mPipe_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_s2mPipe_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_s2mPipe_rData_roundMode_string = "RMM"; - default : decode_load_s2mPipe_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s0_input_payload_roundMode) - FpuRoundMode_RNE : load_s0_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s0_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s0_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s0_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s0_input_payload_roundMode_string = "RMM"; - default : load_s0_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_load_s2mPipe_m2sPipe_rData_roundMode) - FpuRoundMode_RNE : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "RMM"; - default : decode_load_s2mPipe_m2sPipe_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s0_filtred_0_payload_opcode) - FpuOpcode_LOAD : load_s0_filtred_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : load_s0_filtred_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : load_s0_filtred_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : load_s0_filtred_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : load_s0_filtred_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : load_s0_filtred_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : load_s0_filtred_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : load_s0_filtred_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : load_s0_filtred_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : load_s0_filtred_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : load_s0_filtred_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : load_s0_filtred_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : load_s0_filtred_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : load_s0_filtred_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : load_s0_filtred_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : load_s0_filtred_0_payload_opcode_string = "FCVT_X_X"; - default : load_s0_filtred_0_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(load_s0_output_payload_roundMode) - FpuRoundMode_RNE : load_s0_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s0_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s0_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s0_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s0_output_payload_roundMode_string = "RMM"; - default : load_s0_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s1_input_payload_roundMode) - FpuRoundMode_RNE : load_s1_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s1_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s1_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s1_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s1_input_payload_roundMode_string = "RMM"; - default : load_s1_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s0_output_rData_roundMode) - FpuRoundMode_RNE : load_s0_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s0_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s0_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s0_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s0_output_rData_roundMode_string = "RMM"; - default : load_s0_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s1_output_payload_roundMode) - FpuRoundMode_RNE : load_s1_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s1_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s1_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s1_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s1_output_payload_roundMode_string = "RMM"; - default : load_s1_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(shortPip_input_payload_opcode) - FpuOpcode_LOAD : shortPip_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : shortPip_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : shortPip_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : shortPip_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : shortPip_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : shortPip_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : shortPip_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : shortPip_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : shortPip_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : shortPip_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : shortPip_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : shortPip_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : shortPip_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : shortPip_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : shortPip_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : shortPip_input_payload_opcode_string = "FCVT_X_X"; - default : shortPip_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(shortPip_input_payload_roundMode) - FpuRoundMode_RNE : shortPip_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : shortPip_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : shortPip_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : shortPip_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : shortPip_input_payload_roundMode_string = "RMM"; - default : shortPip_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_shortPip_rData_opcode) - FpuOpcode_LOAD : decode_shortPip_rData_opcode_string = "LOAD "; - FpuOpcode_STORE : decode_shortPip_rData_opcode_string = "STORE "; - FpuOpcode_MUL : decode_shortPip_rData_opcode_string = "MUL "; - FpuOpcode_ADD : decode_shortPip_rData_opcode_string = "ADD "; - FpuOpcode_FMA : decode_shortPip_rData_opcode_string = "FMA "; - FpuOpcode_I2F : decode_shortPip_rData_opcode_string = "I2F "; - FpuOpcode_F2I : decode_shortPip_rData_opcode_string = "F2I "; - FpuOpcode_CMP : decode_shortPip_rData_opcode_string = "CMP "; - FpuOpcode_DIV : decode_shortPip_rData_opcode_string = "DIV "; - FpuOpcode_SQRT : decode_shortPip_rData_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : decode_shortPip_rData_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : decode_shortPip_rData_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : decode_shortPip_rData_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : decode_shortPip_rData_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : decode_shortPip_rData_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : decode_shortPip_rData_opcode_string = "FCVT_X_X"; - default : decode_shortPip_rData_opcode_string = "????????"; - endcase - end - always @(*) begin - case(decode_shortPip_rData_roundMode) - FpuRoundMode_RNE : decode_shortPip_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_shortPip_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_shortPip_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_shortPip_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_shortPip_rData_roundMode_string = "RMM"; - default : decode_shortPip_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(shortPip_rfOutput_payload_roundMode) - FpuRoundMode_RNE : shortPip_rfOutput_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : shortPip_rfOutput_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : shortPip_rfOutput_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : shortPip_rfOutput_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : shortPip_rfOutput_payload_roundMode_string = "RMM"; - default : shortPip_rfOutput_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(shortPip_output_payload_roundMode) - FpuRoundMode_RNE : shortPip_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : shortPip_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : shortPip_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : shortPip_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : shortPip_output_payload_roundMode_string = "RMM"; - default : shortPip_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_preMul_input_payload_roundMode) - FpuRoundMode_RNE : mul_preMul_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_preMul_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_preMul_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_preMul_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_preMul_input_payload_roundMode_string = "RMM"; - default : mul_preMul_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_mul_rData_roundMode) - FpuRoundMode_RNE : decode_mul_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_mul_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_mul_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_mul_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_mul_rData_roundMode_string = "RMM"; - default : decode_mul_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_preMul_output_payload_roundMode) - FpuRoundMode_RNE : mul_preMul_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_preMul_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_preMul_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_preMul_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_preMul_output_payload_roundMode_string = "RMM"; - default : mul_preMul_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_mul_input_payload_roundMode) - FpuRoundMode_RNE : mul_mul_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_mul_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_mul_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_mul_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_mul_input_payload_roundMode_string = "RMM"; - default : mul_mul_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_preMul_output_rData_roundMode) - FpuRoundMode_RNE : mul_preMul_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_preMul_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_preMul_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_preMul_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_preMul_output_rData_roundMode_string = "RMM"; - default : mul_preMul_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_mul_output_payload_roundMode) - FpuRoundMode_RNE : mul_mul_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_mul_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_mul_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_mul_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_mul_output_payload_roundMode_string = "RMM"; - default : mul_mul_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum1_input_payload_roundMode) - FpuRoundMode_RNE : mul_sum1_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum1_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum1_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum1_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum1_input_payload_roundMode_string = "RMM"; - default : mul_sum1_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_mul_output_rData_roundMode) - FpuRoundMode_RNE : mul_mul_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_mul_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_mul_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_mul_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_mul_output_rData_roundMode_string = "RMM"; - default : mul_mul_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum1_output_payload_roundMode) - FpuRoundMode_RNE : mul_sum1_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum1_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum1_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum1_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum1_output_payload_roundMode_string = "RMM"; - default : mul_sum1_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum2_input_payload_roundMode) - FpuRoundMode_RNE : mul_sum2_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum2_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum2_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum2_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum2_input_payload_roundMode_string = "RMM"; - default : mul_sum2_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum1_output_rData_roundMode) - FpuRoundMode_RNE : mul_sum1_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum1_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum1_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum1_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum1_output_rData_roundMode_string = "RMM"; - default : mul_sum1_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum2_output_payload_roundMode) - FpuRoundMode_RNE : mul_sum2_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum2_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum2_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum2_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum2_output_payload_roundMode_string = "RMM"; - default : mul_sum2_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_norm_input_payload_roundMode) - FpuRoundMode_RNE : mul_norm_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_norm_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_norm_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_norm_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_norm_input_payload_roundMode_string = "RMM"; - default : mul_norm_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_sum2_output_rData_roundMode) - FpuRoundMode_RNE : mul_sum2_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_sum2_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_sum2_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_sum2_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_sum2_output_rData_roundMode_string = "RMM"; - default : mul_sum2_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_result_output_payload_roundMode) - FpuRoundMode_RNE : mul_result_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_result_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_result_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_result_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_result_output_payload_roundMode_string = "RMM"; - default : mul_result_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_result_mulToAdd_payload_roundMode) - FpuRoundMode_RNE : mul_result_mulToAdd_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_result_mulToAdd_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_result_mulToAdd_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_result_mulToAdd_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_result_mulToAdd_payload_roundMode_string = "RMM"; - default : mul_result_mulToAdd_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_result_mulToAdd_m2sPipe_payload_roundMode) - FpuRoundMode_RNE : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "RMM"; - default : mul_result_mulToAdd_m2sPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(mul_result_mulToAdd_rData_roundMode) - FpuRoundMode_RNE : mul_result_mulToAdd_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : mul_result_mulToAdd_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : mul_result_mulToAdd_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : mul_result_mulToAdd_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : mul_result_mulToAdd_rData_roundMode_string = "RMM"; - default : mul_result_mulToAdd_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(div_input_payload_roundMode) - FpuRoundMode_RNE : div_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : div_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : div_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : div_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : div_input_payload_roundMode_string = "RMM"; - default : div_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_div_rData_roundMode) - FpuRoundMode_RNE : decode_div_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_div_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_div_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_div_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_div_rData_roundMode_string = "RMM"; - default : decode_div_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(div_output_payload_roundMode) - FpuRoundMode_RNE : div_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : div_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : div_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : div_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : div_output_payload_roundMode_string = "RMM"; - default : div_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(sqrt_input_payload_roundMode) - FpuRoundMode_RNE : sqrt_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : sqrt_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : sqrt_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : sqrt_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : sqrt_input_payload_roundMode_string = "RMM"; - default : sqrt_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(decode_sqrt_rData_roundMode) - FpuRoundMode_RNE : decode_sqrt_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : decode_sqrt_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : decode_sqrt_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : decode_sqrt_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : decode_sqrt_rData_roundMode_string = "RMM"; - default : decode_sqrt_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(sqrt_output_payload_roundMode) - FpuRoundMode_RNE : sqrt_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : sqrt_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : sqrt_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : sqrt_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : sqrt_output_payload_roundMode_string = "RMM"; - default : sqrt_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_preShifter_input_payload_roundMode) - FpuRoundMode_RNE : add_preShifter_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_preShifter_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_preShifter_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_preShifter_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_preShifter_input_payload_roundMode_string = "RMM"; - default : add_preShifter_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_preShifter_output_payload_roundMode) - FpuRoundMode_RNE : add_preShifter_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_preShifter_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_preShifter_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_preShifter_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_preShifter_output_payload_roundMode_string = "RMM"; - default : add_preShifter_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_shifter_input_payload_roundMode) - FpuRoundMode_RNE : add_shifter_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_shifter_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_shifter_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_shifter_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_shifter_input_payload_roundMode_string = "RMM"; - default : add_shifter_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_preShifter_output_rData_roundMode) - FpuRoundMode_RNE : add_preShifter_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_preShifter_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_preShifter_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_preShifter_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_preShifter_output_rData_roundMode_string = "RMM"; - default : add_preShifter_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_shifter_output_payload_roundMode) - FpuRoundMode_RNE : add_shifter_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_shifter_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_shifter_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_shifter_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_shifter_output_payload_roundMode_string = "RMM"; - default : add_shifter_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_math_input_payload_roundMode) - FpuRoundMode_RNE : add_math_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_math_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_math_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_math_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_math_input_payload_roundMode_string = "RMM"; - default : add_math_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_shifter_output_rData_roundMode) - FpuRoundMode_RNE : add_shifter_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_shifter_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_shifter_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_shifter_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_shifter_output_rData_roundMode_string = "RMM"; - default : add_shifter_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_math_output_payload_roundMode) - FpuRoundMode_RNE : add_math_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_math_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_math_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_math_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_math_output_payload_roundMode_string = "RMM"; - default : add_math_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_oh_input_payload_roundMode) - FpuRoundMode_RNE : add_oh_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_oh_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_oh_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_oh_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_oh_input_payload_roundMode_string = "RMM"; - default : add_oh_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_math_output_rData_roundMode) - FpuRoundMode_RNE : add_math_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_math_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_math_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_math_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_math_output_rData_roundMode_string = "RMM"; - default : add_math_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_oh_output_payload_roundMode) - FpuRoundMode_RNE : add_oh_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_oh_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_oh_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_oh_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_oh_output_payload_roundMode_string = "RMM"; - default : add_oh_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_norm_input_payload_roundMode) - FpuRoundMode_RNE : add_norm_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_norm_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_norm_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_norm_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_norm_input_payload_roundMode_string = "RMM"; - default : add_norm_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_oh_output_rData_roundMode) - FpuRoundMode_RNE : add_oh_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_oh_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_oh_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_oh_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_oh_output_rData_roundMode_string = "RMM"; - default : add_oh_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_norm_output_payload_roundMode) - FpuRoundMode_RNE : add_norm_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_norm_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_norm_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_norm_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_norm_output_payload_roundMode_string = "RMM"; - default : add_norm_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_result_input_payload_roundMode) - FpuRoundMode_RNE : add_result_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_result_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_result_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_result_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_result_input_payload_roundMode_string = "RMM"; - default : add_result_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(add_result_output_payload_roundMode) - FpuRoundMode_RNE : add_result_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : add_result_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : add_result_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : add_result_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : add_result_output_payload_roundMode_string = "RMM"; - default : add_result_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s1_output_m2sPipe_payload_roundMode) - FpuRoundMode_RNE : load_s1_output_m2sPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s1_output_m2sPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s1_output_m2sPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s1_output_m2sPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s1_output_m2sPipe_payload_roundMode_string = "RMM"; - default : load_s1_output_m2sPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(load_s1_output_rData_roundMode) - FpuRoundMode_RNE : load_s1_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : load_s1_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : load_s1_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : load_s1_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : load_s1_output_rData_roundMode_string = "RMM"; - default : load_s1_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(shortPip_output_m2sPipe_payload_roundMode) - FpuRoundMode_RNE : shortPip_output_m2sPipe_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : shortPip_output_m2sPipe_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : shortPip_output_m2sPipe_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : shortPip_output_m2sPipe_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : shortPip_output_m2sPipe_payload_roundMode_string = "RMM"; - default : shortPip_output_m2sPipe_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(shortPip_output_rData_roundMode) - FpuRoundMode_RNE : shortPip_output_rData_roundMode_string = "RNE"; - FpuRoundMode_RTZ : shortPip_output_rData_roundMode_string = "RTZ"; - FpuRoundMode_RDN : shortPip_output_rData_roundMode_string = "RDN"; - FpuRoundMode_RUP : shortPip_output_rData_roundMode_string = "RUP"; - FpuRoundMode_RMM : shortPip_output_rData_roundMode_string = "RMM"; - default : shortPip_output_rData_roundMode_string = "???"; - endcase - end - always @(*) begin - case(merge_arbitrated_payload_roundMode) - FpuRoundMode_RNE : merge_arbitrated_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : merge_arbitrated_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : merge_arbitrated_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : merge_arbitrated_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : merge_arbitrated_payload_roundMode_string = "RMM"; - default : merge_arbitrated_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(roundFront_input_payload_roundMode) - FpuRoundMode_RNE : roundFront_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : roundFront_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : roundFront_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : roundFront_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : roundFront_input_payload_roundMode_string = "RMM"; - default : roundFront_input_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(roundFront_output_payload_roundMode) - FpuRoundMode_RNE : roundFront_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : roundFront_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : roundFront_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : roundFront_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : roundFront_output_payload_roundMode_string = "RMM"; - default : roundFront_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(roundBack_input_payload_roundMode) - FpuRoundMode_RNE : roundBack_input_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : roundBack_input_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : roundBack_input_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : roundBack_input_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : roundBack_input_payload_roundMode_string = "RMM"; - default : roundBack_input_payload_roundMode_string = "???"; - endcase - end - `endif - - always @(*) begin - _zz_1 = 1'b0; - if(writeback_port_valid) begin - _zz_1 = 1'b1; - end - end - - always @(*) begin - add_shifter_yMantissa_5 = add_shifter_yMantissa_4; - add_shifter_yMantissa_5 = (add_shifter_shiftBy[0] ? _zz_add_shifter_yMantissa_5 : add_shifter_yMantissa_4); - if(add_shifter_passThrough) begin - add_shifter_yMantissa_5 = 26'h0; - end - end - - always @(*) begin - add_shifter_yMantissa_4 = add_shifter_yMantissa_3; - add_shifter_yMantissa_4 = (add_shifter_shiftBy[1] ? _zz_add_shifter_yMantissa_4 : add_shifter_yMantissa_3); - end - - always @(*) begin - add_shifter_yMantissa_3 = add_shifter_yMantissa_2; - add_shifter_yMantissa_3 = (add_shifter_shiftBy[2] ? _zz_add_shifter_yMantissa_3 : add_shifter_yMantissa_2); - end - - always @(*) begin - add_shifter_yMantissa_2 = add_shifter_yMantissa_1; - add_shifter_yMantissa_2 = (add_shifter_shiftBy[3] ? _zz_add_shifter_yMantissa_2 : add_shifter_yMantissa_1); - end - - always @(*) begin - add_shifter_yMantissa_1 = add_shifter_yMantissa; - add_shifter_yMantissa_1 = (add_shifter_shiftBy[4] ? _zz_add_shifter_yMantissa_1 : add_shifter_yMantissa); - end - - always @(*) begin - shortPip_fsm_shift_input_6 = shortPip_fsm_shift_input_5; - shortPip_fsm_shift_input_6 = (shortPip_fsm_shift_by[0] ? _zz_shortPip_fsm_shift_input_6 : shortPip_fsm_shift_input_5); - end - - always @(*) begin - shortPip_fsm_shift_input_5 = shortPip_fsm_shift_input_4; - shortPip_fsm_shift_input_5 = (shortPip_fsm_shift_by[1] ? _zz_shortPip_fsm_shift_input_5 : shortPip_fsm_shift_input_4); - end - - always @(*) begin - shortPip_fsm_shift_input_4 = shortPip_fsm_shift_input_3; - shortPip_fsm_shift_input_4 = (shortPip_fsm_shift_by[2] ? _zz_shortPip_fsm_shift_input_4 : shortPip_fsm_shift_input_3); - end - - always @(*) begin - shortPip_fsm_shift_input_3 = shortPip_fsm_shift_input_2; - shortPip_fsm_shift_input_3 = (shortPip_fsm_shift_by[3] ? _zz_shortPip_fsm_shift_input_3 : shortPip_fsm_shift_input_2); - end - - always @(*) begin - shortPip_fsm_shift_input_2 = shortPip_fsm_shift_input_1; - shortPip_fsm_shift_input_2 = (shortPip_fsm_shift_by[4] ? _zz_shortPip_fsm_shift_input_2 : shortPip_fsm_shift_input_1); - end - - always @(*) begin - shortPip_fsm_shift_input_1 = shortPip_fsm_shift_input; - shortPip_fsm_shift_input_1 = (shortPip_fsm_shift_by[5] ? _zz_shortPip_fsm_shift_input_1 : shortPip_fsm_shift_input); - end - - always @(*) begin - load_s1_fsm_shift_input_5 = load_s1_fsm_shift_input_4; - load_s1_fsm_shift_input_5 = (load_s1_fsm_shift_by[4] ? _zz_load_s1_fsm_shift_input_5 : load_s1_fsm_shift_input_4); - end - - always @(*) begin - load_s1_fsm_shift_input_4 = load_s1_fsm_shift_input_3; - load_s1_fsm_shift_input_4 = (load_s1_fsm_shift_by[3] ? _zz_load_s1_fsm_shift_input_4 : load_s1_fsm_shift_input_3); - end - - always @(*) begin - load_s1_fsm_shift_input_3 = load_s1_fsm_shift_input_2; - load_s1_fsm_shift_input_3 = (load_s1_fsm_shift_by[2] ? _zz_load_s1_fsm_shift_input_3 : load_s1_fsm_shift_input_2); - end - - always @(*) begin - load_s1_fsm_shift_input_2 = load_s1_fsm_shift_input_1; - load_s1_fsm_shift_input_2 = (load_s1_fsm_shift_by[1] ? _zz_load_s1_fsm_shift_input_2 : load_s1_fsm_shift_input_1); - end - - always @(*) begin - load_s1_fsm_shift_input_1 = load_s1_fsm_shift_input; - load_s1_fsm_shift_input_1 = (load_s1_fsm_shift_by[0] ? _zz_load_s1_fsm_shift_input_1 : load_s1_fsm_shift_input); - end - - always @(*) begin - _zz_2 = 1'b0; - if(commitLogic_0_input_valid) begin - _zz_2 = 1'b1; - end - end - - always @(*) begin - _zz_3 = 1'b0; - if(rf_scoreboards_0_hitWrite_valid) begin - _zz_3 = 1'b1; - end - end - - always @(*) begin - _zz_4 = 1'b0; - if(rf_scoreboards_0_targetWrite_valid) begin - _zz_4 = 1'b1; - end - end - - assign rf_init_done = rf_init_counter[5]; - assign when_FpuCore_l163 = (! rf_init_done); - always @(*) begin - rf_scoreboards_0_targetWrite_valid = (! rf_init_done); - if(when_FpuCore_l265) begin - rf_scoreboards_0_targetWrite_valid = 1'b1; - end - end - - always @(*) begin - rf_scoreboards_0_targetWrite_payload_address = rf_init_counter[4:0]; - if(when_FpuCore_l261) begin - rf_scoreboards_0_targetWrite_payload_address = scheduler_0_input_payload_rd; - end - end - - always @(*) begin - rf_scoreboards_0_targetWrite_payload_data = 1'b0; - if(when_FpuCore_l261) begin - rf_scoreboards_0_targetWrite_payload_data = (! scheduler_0_rfTargets_3); - end - end - - always @(*) begin - rf_scoreboards_0_hitWrite_valid = (! rf_init_done); - if(writeback_input_valid) begin - if(when_FpuCore_l1681) begin - rf_scoreboards_0_hitWrite_valid = 1'b1; - end - end - end - - always @(*) begin - rf_scoreboards_0_hitWrite_payload_address = rf_init_counter[4:0]; - if(writeback_input_valid) begin - rf_scoreboards_0_hitWrite_payload_address = writeback_input_payload_rd; - end - end - - always @(*) begin - rf_scoreboards_0_hitWrite_payload_data = 1'b0; - if(writeback_input_valid) begin - rf_scoreboards_0_hitWrite_payload_data = (! _zz_rf_scoreboards_0_hit_port5[0]); - end - end - - assign io_port_0_commit_ready = streamFork_1_io_input_ready; - assign commitFork_load_0_valid = streamFork_1_io_outputs_0_valid; - assign commitFork_load_0_payload_opcode = streamFork_1_io_outputs_0_payload_opcode; - assign commitFork_load_0_payload_rd = streamFork_1_io_outputs_0_payload_rd; - assign commitFork_load_0_payload_write = streamFork_1_io_outputs_0_payload_write; - assign commitFork_load_0_payload_value = streamFork_1_io_outputs_0_payload_value; - assign streamFork_1_io_outputs_1_ready = (! streamFork_1_io_outputs_1_rValid); - assign streamFork_1_io_outputs_1_s2mPipe_valid = (streamFork_1_io_outputs_1_valid || streamFork_1_io_outputs_1_rValid); - assign _zz_payload_opcode = (streamFork_1_io_outputs_1_rValid ? streamFork_1_io_outputs_1_rData_opcode : streamFork_1_io_outputs_1_payload_opcode); - assign streamFork_1_io_outputs_1_s2mPipe_payload_opcode = _zz_payload_opcode; - assign streamFork_1_io_outputs_1_s2mPipe_payload_rd = (streamFork_1_io_outputs_1_rValid ? streamFork_1_io_outputs_1_rData_rd : streamFork_1_io_outputs_1_payload_rd); - assign streamFork_1_io_outputs_1_s2mPipe_payload_write = (streamFork_1_io_outputs_1_rValid ? streamFork_1_io_outputs_1_rData_write : streamFork_1_io_outputs_1_payload_write); - assign streamFork_1_io_outputs_1_s2mPipe_payload_value = (streamFork_1_io_outputs_1_rValid ? streamFork_1_io_outputs_1_rData_value : streamFork_1_io_outputs_1_payload_value); - assign commitFork_commit_0_valid = streamFork_1_io_outputs_1_s2mPipe_valid; - assign streamFork_1_io_outputs_1_s2mPipe_ready = commitFork_commit_0_ready; - assign commitFork_commit_0_payload_opcode = streamFork_1_io_outputs_1_s2mPipe_payload_opcode; - assign commitFork_commit_0_payload_rd = streamFork_1_io_outputs_1_s2mPipe_payload_rd; - assign commitFork_commit_0_payload_write = streamFork_1_io_outputs_1_s2mPipe_payload_write; - assign commitFork_commit_0_payload_value = streamFork_1_io_outputs_1_s2mPipe_payload_value; - assign commitLogic_0_pending_full = (&commitLogic_0_pending_counter); - assign commitLogic_0_pending_notEmpty = (|commitLogic_0_pending_counter); - always @(*) begin - commitLogic_0_pending_inc = 1'b0; - if(when_FpuCore_l265) begin - commitLogic_0_pending_inc = 1'b1; - end - end - - always @(*) begin - commitLogic_0_pending_dec = 1'b0; - if(commitLogic_0_input_valid) begin - commitLogic_0_pending_dec = 1'b1; - end - end - - assign commitLogic_0_add_full = (&commitLogic_0_add_counter); - assign commitLogic_0_add_notEmpty = (|commitLogic_0_add_counter); - always @(*) begin - commitLogic_0_add_inc = 1'b0; - if(commitLogic_0_input_valid) begin - if(when_FpuCore_l208) begin - commitLogic_0_add_inc = 1'b1; - end - end - end - - always @(*) begin - commitLogic_0_add_dec = 1'b0; - if(when_FpuCore_l221_4) begin - commitLogic_0_add_dec = 1'b1; - end - end - - assign commitLogic_0_mul_full = (&commitLogic_0_mul_counter); - assign commitLogic_0_mul_notEmpty = (|commitLogic_0_mul_counter); - always @(*) begin - commitLogic_0_mul_inc = 1'b0; - if(commitLogic_0_input_valid) begin - if(when_FpuCore_l209) begin - commitLogic_0_mul_inc = 1'b1; - end - end - end - - always @(*) begin - commitLogic_0_mul_dec = 1'b0; - if(when_FpuCore_l221_1) begin - commitLogic_0_mul_dec = 1'b1; - end - end - - assign commitLogic_0_div_full = (&commitLogic_0_div_counter); - assign commitLogic_0_div_notEmpty = (|commitLogic_0_div_counter); - always @(*) begin - commitLogic_0_div_inc = 1'b0; - if(commitLogic_0_input_valid) begin - if(when_FpuCore_l210) begin - commitLogic_0_div_inc = 1'b1; - end - end - end - - always @(*) begin - commitLogic_0_div_dec = 1'b0; - if(when_FpuCore_l221_2) begin - commitLogic_0_div_dec = 1'b1; - end - end - - assign commitLogic_0_sqrt_full = (&commitLogic_0_sqrt_counter); - assign commitLogic_0_sqrt_notEmpty = (|commitLogic_0_sqrt_counter); - always @(*) begin - commitLogic_0_sqrt_inc = 1'b0; - if(commitLogic_0_input_valid) begin - if(when_FpuCore_l211) begin - commitLogic_0_sqrt_inc = 1'b1; - end - end - end - - always @(*) begin - commitLogic_0_sqrt_dec = 1'b0; - if(when_FpuCore_l221_3) begin - commitLogic_0_sqrt_dec = 1'b1; - end - end - - assign commitLogic_0_short_full = (&commitLogic_0_short_counter); - assign commitLogic_0_short_notEmpty = (|commitLogic_0_short_counter); - always @(*) begin - commitLogic_0_short_inc = 1'b0; - if(commitLogic_0_input_valid) begin - if(when_FpuCore_l212) begin - commitLogic_0_short_inc = 1'b1; - end - end - end - - always @(*) begin - commitLogic_0_short_dec = 1'b0; - if(when_FpuCore_l221) begin - commitLogic_0_short_dec = 1'b1; - end - end - - assign _zz_commitFork_commit_0_ready = (! (({commitLogic_0_short_full,{commitLogic_0_sqrt_full,{commitLogic_0_div_full,{commitLogic_0_mul_full,commitLogic_0_add_full}}}} != 5'h0) || (! commitLogic_0_pending_notEmpty))); - assign commitFork_commit_0_ready = (1'b1 && _zz_commitFork_commit_0_ready); - assign _zz_commitLogic_0_input_payload_opcode = commitFork_commit_0_payload_opcode; - assign commitLogic_0_input_valid = (commitFork_commit_0_valid && _zz_commitFork_commit_0_ready); - assign commitLogic_0_input_payload_opcode = _zz_commitLogic_0_input_payload_opcode; - assign commitLogic_0_input_payload_rd = commitFork_commit_0_payload_rd; - assign commitLogic_0_input_payload_write = commitFork_commit_0_payload_write; - assign commitLogic_0_input_payload_value = commitFork_commit_0_payload_value; - assign when_FpuCore_l208 = ((commitLogic_0_input_payload_opcode == FpuOpcode_ADD) != 1'b0); - assign when_FpuCore_l209 = ({(commitLogic_0_input_payload_opcode == FpuOpcode_FMA),(commitLogic_0_input_payload_opcode == FpuOpcode_MUL)} != 2'b00); - assign when_FpuCore_l210 = ((commitLogic_0_input_payload_opcode == FpuOpcode_DIV) != 1'b0); - assign when_FpuCore_l211 = ((commitLogic_0_input_payload_opcode == FpuOpcode_SQRT) != 1'b0); - assign when_FpuCore_l212 = ({(commitLogic_0_input_payload_opcode == FpuOpcode_FCVT_X_X),{(commitLogic_0_input_payload_opcode == FpuOpcode_MIN_MAX),(commitLogic_0_input_payload_opcode == FpuOpcode_SGNJ)}} != 3'b000); - assign io_port_0_cmd_ready = (! io_port_0_cmd_rValid); - assign scheduler_0_input_valid = (io_port_0_cmd_valid || io_port_0_cmd_rValid); - assign _zz_scheduler_0_input_payload_opcode = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_opcode : io_port_0_cmd_payload_opcode); - assign _zz_scheduler_0_input_payload_format = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_format : io_port_0_cmd_payload_format); - assign _zz_scheduler_0_input_payload_roundMode = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_roundMode : io_port_0_cmd_payload_roundMode); - assign scheduler_0_input_payload_opcode = _zz_scheduler_0_input_payload_opcode; - assign scheduler_0_input_payload_arg = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_arg : io_port_0_cmd_payload_arg); - assign scheduler_0_input_payload_rs1 = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_rs1 : io_port_0_cmd_payload_rs1); - assign scheduler_0_input_payload_rs2 = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_rs2 : io_port_0_cmd_payload_rs2); - assign scheduler_0_input_payload_rs3 = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_rs3 : io_port_0_cmd_payload_rs3); - assign scheduler_0_input_payload_rd = (io_port_0_cmd_rValid ? io_port_0_cmd_rData_rd : io_port_0_cmd_payload_rd); - assign scheduler_0_input_payload_format = _zz_scheduler_0_input_payload_format; - assign scheduler_0_input_payload_roundMode = _zz_scheduler_0_input_payload_roundMode; - always @(*) begin - scheduler_0_useRs1 = 1'b0; - case(scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : begin - end - FpuOpcode_STORE : begin - end - FpuOpcode_ADD : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_MUL : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_DIV : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_SQRT : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_FMA : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_I2F : begin - end - FpuOpcode_F2I : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_MIN_MAX : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_CMP : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_SGNJ : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_FMV_X_W : begin - scheduler_0_useRs1 = 1'b1; - end - FpuOpcode_FMV_W_X : begin - end - FpuOpcode_FCLASS : begin - scheduler_0_useRs1 = 1'b1; - end - default : begin - scheduler_0_useRs1 = 1'b1; - end - endcase - end - - always @(*) begin - scheduler_0_useRs2 = 1'b0; - case(scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : begin - end - FpuOpcode_STORE : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_ADD : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_MUL : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_DIV : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_SQRT : begin - end - FpuOpcode_FMA : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_I2F : begin - end - FpuOpcode_F2I : begin - end - FpuOpcode_MIN_MAX : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_CMP : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_SGNJ : begin - scheduler_0_useRs2 = 1'b1; - end - FpuOpcode_FMV_X_W : begin - end - FpuOpcode_FMV_W_X : begin - end - FpuOpcode_FCLASS : begin - end - default : begin - end - endcase - end - - always @(*) begin - scheduler_0_useRs3 = 1'b0; - case(scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : begin - end - FpuOpcode_STORE : begin - end - FpuOpcode_ADD : begin - end - FpuOpcode_MUL : begin - end - FpuOpcode_DIV : begin - end - FpuOpcode_SQRT : begin - end - FpuOpcode_FMA : begin - scheduler_0_useRs3 = 1'b1; - end - FpuOpcode_I2F : begin - end - FpuOpcode_F2I : begin - end - FpuOpcode_MIN_MAX : begin - end - FpuOpcode_CMP : begin - end - FpuOpcode_SGNJ : begin - end - FpuOpcode_FMV_X_W : begin - end - FpuOpcode_FMV_W_X : begin - end - FpuOpcode_FCLASS : begin - end - default : begin - end - endcase - end - - always @(*) begin - scheduler_0_useRd = 1'b0; - case(scheduler_0_input_payload_opcode) - FpuOpcode_LOAD : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_STORE : begin - end - FpuOpcode_ADD : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_MUL : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_DIV : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_SQRT : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_FMA : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_I2F : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_F2I : begin - end - FpuOpcode_MIN_MAX : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_CMP : begin - end - FpuOpcode_SGNJ : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_FMV_X_W : begin - end - FpuOpcode_FMV_W_X : begin - scheduler_0_useRd = 1'b1; - end - FpuOpcode_FCLASS : begin - end - default : begin - scheduler_0_useRd = 1'b1; - end - endcase - end - - assign scheduler_0_rfHits_0 = _zz_rf_scoreboards_0_hit_port1[0]; - assign scheduler_0_rfHits_1 = _zz_rf_scoreboards_0_hit_port2[0]; - assign scheduler_0_rfHits_2 = _zz_rf_scoreboards_0_hit_port3[0]; - assign scheduler_0_rfHits_3 = _zz_rf_scoreboards_0_hit_port4[0]; - assign scheduler_0_rfTargets_0 = _zz_rf_scoreboards_0_target_port1[0]; - assign scheduler_0_rfTargets_1 = _zz_rf_scoreboards_0_target_port2[0]; - assign scheduler_0_rfTargets_2 = _zz_rf_scoreboards_0_target_port3[0]; - assign scheduler_0_rfTargets_3 = _zz_rf_scoreboards_0_target_port4[0]; - assign scheduler_0_rfBusy_0 = (scheduler_0_rfHits_0 ^ scheduler_0_rfTargets_0); - assign scheduler_0_rfBusy_1 = (scheduler_0_rfHits_1 ^ scheduler_0_rfTargets_1); - assign scheduler_0_rfBusy_2 = (scheduler_0_rfHits_2 ^ scheduler_0_rfTargets_2); - assign scheduler_0_rfBusy_3 = (scheduler_0_rfHits_3 ^ scheduler_0_rfTargets_3); - assign scheduler_0_hits_0 = (scheduler_0_useRs1 && scheduler_0_rfBusy_0); - assign scheduler_0_hits_1 = (scheduler_0_useRs2 && scheduler_0_rfBusy_1); - assign scheduler_0_hits_2 = (scheduler_0_useRs3 && scheduler_0_rfBusy_2); - assign scheduler_0_hits_3 = (scheduler_0_useRd && scheduler_0_rfBusy_3); - assign scheduler_0_hazard = ((({scheduler_0_hits_3,{scheduler_0_hits_2,{scheduler_0_hits_1,scheduler_0_hits_0}}} != 4'b0000) || (! rf_init_done)) || commitLogic_0_pending_full); - assign _zz_scheduler_0_input_ready = (! scheduler_0_hazard); - assign scheduler_0_output_valid = (scheduler_0_input_valid && _zz_scheduler_0_input_ready); - assign scheduler_0_input_ready = (scheduler_0_output_ready && _zz_scheduler_0_input_ready); - assign scheduler_0_output_payload_opcode = scheduler_0_input_payload_opcode; - assign scheduler_0_output_payload_arg = scheduler_0_input_payload_arg; - always @(*) begin - scheduler_0_output_payload_rs1 = scheduler_0_input_payload_rs1; - if(when_FpuCore_l258) begin - scheduler_0_output_payload_rs1 = scheduler_0_input_payload_rs2; - end - end - - assign scheduler_0_output_payload_rs2 = scheduler_0_input_payload_rs2; - assign scheduler_0_output_payload_rs3 = scheduler_0_input_payload_rs3; - assign scheduler_0_output_payload_rd = scheduler_0_input_payload_rd; - assign scheduler_0_output_payload_format = scheduler_0_input_payload_format; - assign scheduler_0_output_payload_roundMode = scheduler_0_input_payload_roundMode; - assign when_FpuCore_l258 = (scheduler_0_input_payload_opcode == FpuOpcode_STORE); - assign when_FpuCore_l261 = (scheduler_0_input_valid && rf_init_done); - assign scheduler_0_output_fire = (scheduler_0_output_valid && scheduler_0_output_ready); - assign when_FpuCore_l265 = (scheduler_0_output_fire && scheduler_0_useRd); - assign scheduler_0_output_ready = cmdArbiter_arbiter_io_inputs_0_ready; - assign _zz_io_inputs_0_payload_opcode = scheduler_0_output_payload_opcode; - assign _zz_io_inputs_0_payload_format = scheduler_0_output_payload_format; - assign _zz_io_inputs_0_payload_roundMode = scheduler_0_output_payload_roundMode; - assign cmdArbiter_output_valid = cmdArbiter_arbiter_io_output_valid; - assign cmdArbiter_output_payload_opcode = cmdArbiter_arbiter_io_output_payload_opcode; - assign cmdArbiter_output_payload_rs1 = cmdArbiter_arbiter_io_output_payload_rs1; - assign cmdArbiter_output_payload_rs2 = cmdArbiter_arbiter_io_output_payload_rs2; - assign cmdArbiter_output_payload_rs3 = cmdArbiter_arbiter_io_output_payload_rs3; - assign cmdArbiter_output_payload_rd = cmdArbiter_arbiter_io_output_payload_rd; - assign cmdArbiter_output_payload_arg = cmdArbiter_arbiter_io_output_payload_arg; - assign cmdArbiter_output_payload_roundMode = cmdArbiter_arbiter_io_output_payload_roundMode; - assign read_s0_valid = cmdArbiter_output_valid; - assign cmdArbiter_output_ready = read_s0_ready; - assign read_s0_payload_opcode = cmdArbiter_output_payload_opcode; - assign read_s0_payload_rs1 = cmdArbiter_output_payload_rs1; - assign read_s0_payload_rs2 = cmdArbiter_output_payload_rs2; - assign read_s0_payload_rs3 = cmdArbiter_output_payload_rs3; - assign read_s0_payload_rd = cmdArbiter_output_payload_rd; - assign read_s0_payload_arg = cmdArbiter_output_payload_arg; - assign read_s0_payload_roundMode = cmdArbiter_output_payload_roundMode; - always @(*) begin - read_s0_ready = read_s1_ready; - if(when_Stream_l368) begin - read_s0_ready = 1'b1; - end - end - - assign when_Stream_l368 = (! read_s1_valid); - assign read_s1_valid = read_s0_rValid; - assign read_s1_payload_opcode = read_s0_rData_opcode; - assign read_s1_payload_rs1 = read_s0_rData_rs1; - assign read_s1_payload_rs2 = read_s0_rData_rs2; - assign read_s1_payload_rs3 = read_s0_rData_rs3; - assign read_s1_payload_rd = read_s0_rData_rd; - assign read_s1_payload_arg = read_s0_rData_arg; - assign read_s1_payload_roundMode = read_s0_rData_roundMode; - assign read_output_valid = read_s1_valid; - assign read_s1_ready = read_output_ready; - assign _zz_read_rs_0_value_mantissa = read_s0_payload_rs1; - assign read_output_isStall = (read_output_valid && (! read_output_ready)); - assign _zz_read_rs_0_value_mantissa_1 = (! read_output_isStall); - assign _zz_read_rs_0_value_mantissa_2 = _zz_rf_ram_port0[33 : 0]; - assign read_rs_0_value_mantissa = _zz_read_rs_0_value_mantissa_2[22 : 0]; - assign read_rs_0_value_exponent = _zz_read_rs_0_value_mantissa_2[31 : 23]; - assign read_rs_0_value_sign = _zz_read_rs_0_value_mantissa_2[32]; - assign read_rs_0_value_special = _zz_read_rs_0_value_mantissa_2[33]; - assign _zz_read_rs_1_value_mantissa = read_s0_payload_rs2; - assign read_output_isStall_1 = (read_output_valid && (! read_output_ready)); - assign _zz_read_rs_1_value_mantissa_1 = (! read_output_isStall_1); - assign _zz_read_rs_1_value_mantissa_2 = _zz_rf_ram_port1[33 : 0]; - assign read_rs_1_value_mantissa = _zz_read_rs_1_value_mantissa_2[22 : 0]; - assign read_rs_1_value_exponent = _zz_read_rs_1_value_mantissa_2[31 : 23]; - assign read_rs_1_value_sign = _zz_read_rs_1_value_mantissa_2[32]; - assign read_rs_1_value_special = _zz_read_rs_1_value_mantissa_2[33]; - assign _zz_read_rs_2_value_mantissa = read_s0_payload_rs3; - assign read_output_isStall_2 = (read_output_valid && (! read_output_ready)); - assign _zz_read_rs_2_value_mantissa_1 = (! read_output_isStall_2); - assign _zz_read_rs_2_value_mantissa_2 = _zz_rf_ram_port2[33 : 0]; - assign read_rs_2_value_mantissa = _zz_read_rs_2_value_mantissa_2[22 : 0]; - assign read_rs_2_value_exponent = _zz_read_rs_2_value_mantissa_2[31 : 23]; - assign read_rs_2_value_sign = _zz_read_rs_2_value_mantissa_2[32]; - assign read_rs_2_value_special = _zz_read_rs_2_value_mantissa_2[33]; - assign read_output_payload_opcode = read_s1_payload_opcode; - assign read_output_payload_arg = read_s1_payload_arg; - assign read_output_payload_roundMode = read_s1_payload_roundMode; - assign read_output_payload_rd = read_s1_payload_rd; - assign read_output_payload_rs1_mantissa = read_rs_0_value_mantissa; - assign read_output_payload_rs1_exponent = read_rs_0_value_exponent; - assign read_output_payload_rs1_sign = read_rs_0_value_sign; - assign read_output_payload_rs1_special = read_rs_0_value_special; - assign read_output_payload_rs2_mantissa = read_rs_1_value_mantissa; - assign read_output_payload_rs2_exponent = read_rs_1_value_exponent; - assign read_output_payload_rs2_sign = read_rs_1_value_sign; - assign read_output_payload_rs2_special = read_rs_1_value_special; - assign read_output_payload_rs3_mantissa = read_rs_2_value_mantissa; - assign read_output_payload_rs3_exponent = read_rs_2_value_exponent; - assign read_output_payload_rs3_sign = read_rs_2_value_sign; - assign read_output_payload_rs3_special = read_rs_2_value_special; - assign decode_input_valid = read_output_valid; - assign read_output_ready = decode_input_ready; - assign decode_input_payload_opcode = read_output_payload_opcode; - assign decode_input_payload_rs1_mantissa = read_output_payload_rs1_mantissa; - assign decode_input_payload_rs1_exponent = read_output_payload_rs1_exponent; - assign decode_input_payload_rs1_sign = read_output_payload_rs1_sign; - assign decode_input_payload_rs1_special = read_output_payload_rs1_special; - assign decode_input_payload_rs2_mantissa = read_output_payload_rs2_mantissa; - assign decode_input_payload_rs2_exponent = read_output_payload_rs2_exponent; - assign decode_input_payload_rs2_sign = read_output_payload_rs2_sign; - assign decode_input_payload_rs2_special = read_output_payload_rs2_special; - assign decode_input_payload_rs3_mantissa = read_output_payload_rs3_mantissa; - assign decode_input_payload_rs3_exponent = read_output_payload_rs3_exponent; - assign decode_input_payload_rs3_sign = read_output_payload_rs3_sign; - assign decode_input_payload_rs3_special = read_output_payload_rs3_special; - assign decode_input_payload_rd = read_output_payload_rd; - assign decode_input_payload_arg = read_output_payload_arg; - assign decode_input_payload_roundMode = read_output_payload_roundMode; - always @(*) begin - decode_input_ready = 1'b0; - if(when_FpuCore_l329) begin - decode_input_ready = 1'b1; - end - if(when_FpuCore_l335) begin - decode_input_ready = 1'b1; - end - if(when_FpuCore_l351) begin - decode_input_ready = 1'b1; - end - if(when_FpuCore_l359) begin - decode_input_ready = 1'b1; - end - if(when_FpuCore_l375) begin - decode_input_ready = 1'b1; - end - if(when_FpuCore_l399) begin - decode_input_ready = 1'b1; - end - end - - assign decode_loadHit = ({(decode_input_payload_opcode == FpuOpcode_I2F),{(decode_input_payload_opcode == FpuOpcode_FMV_W_X),(decode_input_payload_opcode == FpuOpcode_LOAD)}} != 3'b000); - assign decode_load_valid = (decode_input_valid && decode_loadHit); - assign when_FpuCore_l329 = (decode_loadHit && decode_load_ready); - assign decode_load_payload_rd = decode_input_payload_rd; - assign decode_load_payload_arg = decode_input_payload_arg; - assign decode_load_payload_roundMode = decode_input_payload_roundMode; - assign decode_load_payload_i2f = (decode_input_payload_opcode == FpuOpcode_I2F); - assign decode_shortPipHit = ({(decode_input_payload_opcode == FpuOpcode_FCVT_X_X),{(decode_input_payload_opcode == FpuOpcode_FCLASS),{(decode_input_payload_opcode == FpuOpcode_FMV_X_W),{(decode_input_payload_opcode == FpuOpcode_SGNJ),{(decode_input_payload_opcode == _zz_decode_shortPipHit),{_zz_decode_shortPipHit_1,{_zz_decode_shortPipHit_2,_zz_decode_shortPipHit_3}}}}}}} != 8'h0); - assign when_FpuCore_l335 = (decode_shortPipHit && decode_shortPip_ready); - assign decode_shortPip_valid = (decode_input_valid && decode_shortPipHit); - assign decode_shortPip_payload_opcode = decode_input_payload_opcode; - assign decode_shortPip_payload_rs1_mantissa = decode_input_payload_rs1_mantissa; - assign decode_shortPip_payload_rs1_exponent = decode_input_payload_rs1_exponent; - assign decode_shortPip_payload_rs1_sign = decode_input_payload_rs1_sign; - assign decode_shortPip_payload_rs1_special = decode_input_payload_rs1_special; - assign decode_shortPip_payload_rs2_mantissa = decode_input_payload_rs2_mantissa; - assign decode_shortPip_payload_rs2_exponent = decode_input_payload_rs2_exponent; - assign decode_shortPip_payload_rs2_sign = decode_input_payload_rs2_sign; - assign decode_shortPip_payload_rs2_special = decode_input_payload_rs2_special; - assign decode_shortPip_payload_rd = decode_input_payload_rd; - assign decode_shortPip_payload_arg = decode_input_payload_arg; - assign decode_shortPip_payload_roundMode = decode_input_payload_roundMode; - assign decode_divSqrtHit = ((decode_input_payload_opcode == FpuOpcode_DIV) || (decode_input_payload_opcode == FpuOpcode_SQRT)); - assign decode_divHit = (decode_input_payload_opcode == FpuOpcode_DIV); - assign when_FpuCore_l351 = (decode_divHit && decode_div_ready); - assign decode_div_valid = (decode_input_valid && decode_divHit); - assign decode_div_payload_rs1_mantissa = decode_input_payload_rs1_mantissa; - assign decode_div_payload_rs1_exponent = decode_input_payload_rs1_exponent; - assign decode_div_payload_rs1_sign = decode_input_payload_rs1_sign; - assign decode_div_payload_rs1_special = decode_input_payload_rs1_special; - assign decode_div_payload_rs2_mantissa = decode_input_payload_rs2_mantissa; - assign decode_div_payload_rs2_exponent = decode_input_payload_rs2_exponent; - assign decode_div_payload_rs2_sign = decode_input_payload_rs2_sign; - assign decode_div_payload_rs2_special = decode_input_payload_rs2_special; - assign decode_div_payload_rd = decode_input_payload_rd; - assign decode_div_payload_roundMode = decode_input_payload_roundMode; - assign decode_sqrtHit = (decode_input_payload_opcode == FpuOpcode_SQRT); - assign when_FpuCore_l359 = (decode_sqrtHit && decode_sqrt_ready); - assign decode_sqrt_valid = (decode_input_valid && decode_sqrtHit); - assign decode_sqrt_payload_rs1_mantissa = decode_input_payload_rs1_mantissa; - assign decode_sqrt_payload_rs1_exponent = decode_input_payload_rs1_exponent; - assign decode_sqrt_payload_rs1_sign = decode_input_payload_rs1_sign; - assign decode_sqrt_payload_rs1_special = decode_input_payload_rs1_special; - assign decode_sqrt_payload_rd = decode_input_payload_rd; - assign decode_sqrt_payload_roundMode = decode_input_payload_roundMode; - assign decode_fmaHit = (decode_input_payload_opcode == FpuOpcode_FMA); - assign decode_mulHit = ((decode_input_payload_opcode == FpuOpcode_MUL) || decode_fmaHit); - assign decode_divSqrtToMul_valid = 1'b0; - assign decode_divSqrtToMul_payload_rs1_mantissa = 23'bxxxxxxxxxxxxxxxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs1_exponent = 9'bxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs1_sign = 1'bx; - assign decode_divSqrtToMul_payload_rs1_special = 1'bx; - assign decode_divSqrtToMul_payload_rs2_mantissa = 23'bxxxxxxxxxxxxxxxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs2_exponent = 9'bxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs2_sign = 1'bx; - assign decode_divSqrtToMul_payload_rs2_special = 1'bx; - assign decode_divSqrtToMul_payload_rs3_mantissa = 23'bxxxxxxxxxxxxxxxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs3_exponent = 9'bxxxxxxxxx; - assign decode_divSqrtToMul_payload_rs3_sign = 1'bx; - assign decode_divSqrtToMul_payload_rs3_special = 1'bx; - assign decode_divSqrtToMul_payload_rd = 5'bxxxxx; - assign decode_divSqrtToMul_payload_add = 1'bx; - assign decode_divSqrtToMul_payload_divSqrt = 1'bx; - assign decode_divSqrtToMul_payload_msb1 = 1'bx; - assign decode_divSqrtToMul_payload_msb2 = 1'bx; - assign decode_divSqrtToMul_payload_roundMode = (3'bxxx); - assign when_FpuCore_l375 = ((decode_mulHit && decode_mul_ready) && (! decode_divSqrtToMul_valid)); - assign decode_mul_valid = ((decode_input_valid && decode_mulHit) || decode_divSqrtToMul_valid); - assign decode_divSqrtToMul_ready = decode_mul_ready; - always @(*) begin - decode_mul_payload_rs1_mantissa = decode_divSqrtToMul_payload_rs1_mantissa; - if(when_FpuCore_l380) begin - decode_mul_payload_rs1_mantissa = decode_input_payload_rs1_mantissa; - end - end - - always @(*) begin - decode_mul_payload_rs1_exponent = decode_divSqrtToMul_payload_rs1_exponent; - if(when_FpuCore_l380) begin - decode_mul_payload_rs1_exponent = decode_input_payload_rs1_exponent; - end - end - - always @(*) begin - decode_mul_payload_rs1_sign = decode_divSqrtToMul_payload_rs1_sign; - if(when_FpuCore_l380) begin - decode_mul_payload_rs1_sign = decode_input_payload_rs1_sign; - end - end - - always @(*) begin - decode_mul_payload_rs1_special = decode_divSqrtToMul_payload_rs1_special; - if(when_FpuCore_l380) begin - decode_mul_payload_rs1_special = decode_input_payload_rs1_special; - end - end - - always @(*) begin - decode_mul_payload_rs2_mantissa = decode_divSqrtToMul_payload_rs2_mantissa; - if(when_FpuCore_l380) begin - decode_mul_payload_rs2_mantissa = decode_input_payload_rs2_mantissa; - end - end - - always @(*) begin - decode_mul_payload_rs2_exponent = decode_divSqrtToMul_payload_rs2_exponent; - if(when_FpuCore_l380) begin - decode_mul_payload_rs2_exponent = decode_input_payload_rs2_exponent; - end - end - - always @(*) begin - decode_mul_payload_rs2_sign = decode_divSqrtToMul_payload_rs2_sign; - if(when_FpuCore_l380) begin - decode_mul_payload_rs2_sign = decode_input_payload_rs2_sign; - decode_mul_payload_rs2_sign = (decode_input_payload_rs2_sign ^ decode_input_payload_arg[0]); - end - end - - always @(*) begin - decode_mul_payload_rs2_special = decode_divSqrtToMul_payload_rs2_special; - if(when_FpuCore_l380) begin - decode_mul_payload_rs2_special = decode_input_payload_rs2_special; - end - end - - always @(*) begin - decode_mul_payload_rs3_mantissa = decode_divSqrtToMul_payload_rs3_mantissa; - if(when_FpuCore_l380) begin - decode_mul_payload_rs3_mantissa = decode_input_payload_rs3_mantissa; - end - end - - always @(*) begin - decode_mul_payload_rs3_exponent = decode_divSqrtToMul_payload_rs3_exponent; - if(when_FpuCore_l380) begin - decode_mul_payload_rs3_exponent = decode_input_payload_rs3_exponent; - end - end - - always @(*) begin - decode_mul_payload_rs3_sign = decode_divSqrtToMul_payload_rs3_sign; - if(when_FpuCore_l380) begin - decode_mul_payload_rs3_sign = decode_input_payload_rs3_sign; - decode_mul_payload_rs3_sign = (decode_input_payload_rs3_sign ^ decode_input_payload_arg[1]); - end - end - - always @(*) begin - decode_mul_payload_rs3_special = decode_divSqrtToMul_payload_rs3_special; - if(when_FpuCore_l380) begin - decode_mul_payload_rs3_special = decode_input_payload_rs3_special; - end - end - - always @(*) begin - decode_mul_payload_rd = decode_divSqrtToMul_payload_rd; - if(when_FpuCore_l380) begin - decode_mul_payload_rd = decode_input_payload_rd; - end - end - - always @(*) begin - decode_mul_payload_add = decode_divSqrtToMul_payload_add; - if(when_FpuCore_l380) begin - decode_mul_payload_add = decode_fmaHit; - end - end - - always @(*) begin - decode_mul_payload_divSqrt = decode_divSqrtToMul_payload_divSqrt; - if(when_FpuCore_l380) begin - decode_mul_payload_divSqrt = 1'b0; - end - end - - always @(*) begin - decode_mul_payload_msb1 = decode_divSqrtToMul_payload_msb1; - if(when_FpuCore_l380) begin - decode_mul_payload_msb1 = 1'b1; - end - end - - always @(*) begin - decode_mul_payload_msb2 = decode_divSqrtToMul_payload_msb2; - if(when_FpuCore_l380) begin - decode_mul_payload_msb2 = 1'b1; - end - end - - always @(*) begin - decode_mul_payload_roundMode = decode_divSqrtToMul_payload_roundMode; - if(when_FpuCore_l380) begin - decode_mul_payload_roundMode = decode_input_payload_roundMode; - end - end - - assign when_FpuCore_l380 = (! decode_divSqrtToMul_valid); - assign decode_addHit = (decode_input_payload_opcode == FpuOpcode_ADD); - assign when_FpuCore_l399 = ((decode_addHit && decode_add_ready) && (! decode_mulToAdd_valid)); - assign decode_add_valid = ((decode_input_valid && decode_addHit) || decode_mulToAdd_valid); - assign decode_mulToAdd_ready = decode_add_ready; - always @(*) begin - decode_add_payload_rs1_mantissa = decode_mulToAdd_payload_rs1_mantissa; - if(when_FpuCore_l404) begin - decode_add_payload_rs1_mantissa = ({2'd0,decode_input_payload_rs1_mantissa} <<< 2); - end - end - - always @(*) begin - decode_add_payload_rs1_exponent = decode_mulToAdd_payload_rs1_exponent; - if(when_FpuCore_l404) begin - decode_add_payload_rs1_exponent = decode_input_payload_rs1_exponent; - end - end - - always @(*) begin - decode_add_payload_rs1_sign = decode_mulToAdd_payload_rs1_sign; - if(when_FpuCore_l404) begin - decode_add_payload_rs1_sign = decode_input_payload_rs1_sign; - end - end - - always @(*) begin - decode_add_payload_rs1_special = decode_mulToAdd_payload_rs1_special; - if(when_FpuCore_l404) begin - decode_add_payload_rs1_special = decode_input_payload_rs1_special; - end - end - - always @(*) begin - decode_add_payload_rs2_mantissa = decode_mulToAdd_payload_rs2_mantissa; - if(when_FpuCore_l404) begin - decode_add_payload_rs2_mantissa = ({2'd0,decode_input_payload_rs2_mantissa} <<< 2); - end - end - - always @(*) begin - decode_add_payload_rs2_exponent = decode_mulToAdd_payload_rs2_exponent; - if(when_FpuCore_l404) begin - decode_add_payload_rs2_exponent = decode_input_payload_rs2_exponent; - end - end - - always @(*) begin - decode_add_payload_rs2_sign = decode_mulToAdd_payload_rs2_sign; - if(when_FpuCore_l404) begin - decode_add_payload_rs2_sign = (decode_input_payload_rs2_sign ^ decode_input_payload_arg[0]); - end - end - - always @(*) begin - decode_add_payload_rs2_special = decode_mulToAdd_payload_rs2_special; - if(when_FpuCore_l404) begin - decode_add_payload_rs2_special = decode_input_payload_rs2_special; - end - end - - always @(*) begin - decode_add_payload_rd = decode_mulToAdd_payload_rd; - if(when_FpuCore_l404) begin - decode_add_payload_rd = decode_input_payload_rd; - end - end - - always @(*) begin - decode_add_payload_roundMode = decode_mulToAdd_payload_roundMode; - if(when_FpuCore_l404) begin - decode_add_payload_roundMode = decode_input_payload_roundMode; - end - end - - always @(*) begin - decode_add_payload_needCommit = decode_mulToAdd_payload_needCommit; - if(when_FpuCore_l404) begin - decode_add_payload_needCommit = 1'b1; - end - end - - assign when_FpuCore_l404 = (! decode_mulToAdd_valid); - assign decode_load_ready = (! decode_load_rValid); - assign decode_load_s2mPipe_valid = (decode_load_valid || decode_load_rValid); - assign _zz_decode_load_s2mPipe_payload_roundMode = (decode_load_rValid ? decode_load_rData_roundMode : decode_load_payload_roundMode); - assign decode_load_s2mPipe_payload_rd = (decode_load_rValid ? decode_load_rData_rd : decode_load_payload_rd); - assign decode_load_s2mPipe_payload_i2f = (decode_load_rValid ? decode_load_rData_i2f : decode_load_payload_i2f); - assign decode_load_s2mPipe_payload_arg = (decode_load_rValid ? decode_load_rData_arg : decode_load_payload_arg); - assign decode_load_s2mPipe_payload_roundMode = _zz_decode_load_s2mPipe_payload_roundMode; - always @(*) begin - decode_load_s2mPipe_ready = decode_load_s2mPipe_m2sPipe_ready; - if(when_Stream_l368_1) begin - decode_load_s2mPipe_ready = 1'b1; - end - end - - assign when_Stream_l368_1 = (! decode_load_s2mPipe_m2sPipe_valid); - assign decode_load_s2mPipe_m2sPipe_valid = decode_load_s2mPipe_rValid; - assign decode_load_s2mPipe_m2sPipe_payload_rd = decode_load_s2mPipe_rData_rd; - assign decode_load_s2mPipe_m2sPipe_payload_i2f = decode_load_s2mPipe_rData_i2f; - assign decode_load_s2mPipe_m2sPipe_payload_arg = decode_load_s2mPipe_rData_arg; - assign decode_load_s2mPipe_m2sPipe_payload_roundMode = decode_load_s2mPipe_rData_roundMode; - always @(*) begin - decode_load_s2mPipe_m2sPipe_ready = load_s0_input_ready; - if(when_Stream_l368_2) begin - decode_load_s2mPipe_m2sPipe_ready = 1'b1; - end - end - - assign when_Stream_l368_2 = (! load_s0_input_valid); - assign load_s0_input_valid = decode_load_s2mPipe_m2sPipe_rValid; - assign load_s0_input_payload_rd = decode_load_s2mPipe_m2sPipe_rData_rd; - assign load_s0_input_payload_i2f = decode_load_s2mPipe_m2sPipe_rData_i2f; - assign load_s0_input_payload_arg = decode_load_s2mPipe_m2sPipe_rData_arg; - assign load_s0_input_payload_roundMode = decode_load_s2mPipe_m2sPipe_rData_roundMode; - assign when_Stream_l438 = (! ({(commitFork_load_0_payload_opcode == FpuOpcode_I2F),{(commitFork_load_0_payload_opcode == FpuOpcode_FMV_W_X),(commitFork_load_0_payload_opcode == FpuOpcode_LOAD)}} != 3'b000)); - always @(*) begin - load_s0_filtred_0_valid = commitFork_load_0_valid; - if(when_Stream_l438) begin - load_s0_filtred_0_valid = 1'b0; - end - end - - always @(*) begin - commitFork_load_0_ready = load_s0_filtred_0_ready; - if(when_Stream_l438) begin - commitFork_load_0_ready = 1'b1; - end - end - - assign load_s0_filtred_0_payload_opcode = commitFork_load_0_payload_opcode; - assign load_s0_filtred_0_payload_rd = commitFork_load_0_payload_rd; - assign load_s0_filtred_0_payload_write = commitFork_load_0_payload_write; - assign load_s0_filtred_0_payload_value = commitFork_load_0_payload_value; - assign load_s0_hazard = (! load_s0_filtred_0_valid); - assign _zz_load_s0_input_ready = (! load_s0_hazard); - assign load_s0_input_ready = (load_s0_output_ready && _zz_load_s0_input_ready); - assign load_s0_output_valid = (load_s0_input_valid && _zz_load_s0_input_ready); - always @(*) begin - load_s0_filtred_0_ready = 1'b0; - if(_zz_when[0]) begin - load_s0_filtred_0_ready = (load_s0_input_valid && load_s0_output_ready); - end - end - - assign load_s0_output_payload_rd = load_s0_input_payload_rd; - assign load_s0_output_payload_value = load_s0_filtred_0_payload_value; - assign load_s0_output_payload_i2f = load_s0_input_payload_i2f; - assign load_s0_output_payload_arg = load_s0_input_payload_arg; - assign load_s0_output_payload_roundMode = load_s0_input_payload_roundMode; - always @(*) begin - load_s0_output_ready = load_s1_input_ready; - if(when_Stream_l368_3) begin - load_s0_output_ready = 1'b1; - end - end - - assign when_Stream_l368_3 = (! load_s1_input_valid); - assign load_s1_input_valid = load_s0_output_rValid; - assign load_s1_input_payload_rd = load_s0_output_rData_rd; - assign load_s1_input_payload_value = load_s0_output_rData_value; - assign load_s1_input_payload_i2f = load_s0_output_rData_i2f; - assign load_s1_input_payload_arg = load_s0_output_rData_arg; - assign load_s1_input_payload_roundMode = load_s0_output_rData_roundMode; - always @(*) begin - load_s1_busy = 1'b0; - if(when_FpuCore_l529) begin - load_s1_busy = 1'b1; - end - end - - assign load_s1_f32_mantissa = load_s1_input_payload_value[22 : 0]; - assign load_s1_f32_exponent = load_s1_input_payload_value[30 : 23]; - assign load_s1_f32_sign = load_s1_input_payload_value[31]; - assign load_s1_passThroughFloat_special = 1'b0; - assign load_s1_passThroughFloat_sign = load_s1_f32_sign; - assign load_s1_passThroughFloat_exponent = {1'd0, load_s1_f32_exponent}; - assign load_s1_passThroughFloat_mantissa = load_s1_f32_mantissa; - assign load_s1_recodedExpOffset = 9'h080; - assign load_s1_manZero = (load_s1_passThroughFloat_mantissa == 23'h0); - assign load_s1_expZero = (load_s1_passThroughFloat_exponent == 9'h0); - assign load_s1_expOne = (&load_s1_passThroughFloat_exponent[7 : 0]); - assign load_s1_isZero = (load_s1_expZero && load_s1_manZero); - assign load_s1_isSubnormal = (load_s1_expZero && (! load_s1_manZero)); - assign load_s1_isInfinity = (load_s1_expOne && load_s1_manZero); - assign load_s1_isNan = (load_s1_expOne && (! load_s1_manZero)); - always @(*) begin - load_s1_fsm_ohInput = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - if(when_FpuCore_l508) begin - load_s1_fsm_ohInput = ({9'd0,load_s1_input_payload_value[22 : 0]} <<< 9); - end else begin - load_s1_fsm_ohInput[31 : 0] = load_s1_input_payload_value[31 : 0]; - end - end - - assign when_FpuCore_l508 = (! load_s1_input_payload_i2f); - always @(*) begin - load_s1_fsm_shift_input = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - load_s1_fsm_shift_input = (load_s1_fsm_ohInput <<< 1); - end - - assign when_FpuCore_l525 = (! load_s1_fsm_done); - assign when_FpuCore_l529 = ((load_s1_input_valid && (load_s1_input_payload_i2f || load_s1_isSubnormal)) && (! load_s1_fsm_done)); - assign when_FpuCore_l532 = (((load_s1_input_payload_i2f && (! load_s1_fsm_patched)) && load_s1_input_payload_value[31]) && load_s1_input_payload_arg[0]); - assign _zz_load_s0_output_rData_value = load_s1_input_payload_value; - assign _zz_load_s0_output_rData_value_1 = 1'b1; - assign _zz_load_s1_fsm_shift_by = {load_s1_fsm_ohInput[0],{load_s1_fsm_ohInput[1],{load_s1_fsm_ohInput[2],{load_s1_fsm_ohInput[3],{load_s1_fsm_ohInput[4],{load_s1_fsm_ohInput[5],{load_s1_fsm_ohInput[6],{load_s1_fsm_ohInput[7],{load_s1_fsm_ohInput[8],{_zz__zz_load_s1_fsm_shift_by,{_zz__zz_load_s1_fsm_shift_by_1,_zz__zz_load_s1_fsm_shift_by_2}}}}}}}}}}}; - assign _zz_load_s1_fsm_shift_by_1 = (_zz_load_s1_fsm_shift_by & (~ _zz__zz_load_s1_fsm_shift_by_1_1)); - assign _zz_load_s1_fsm_shift_by_2 = _zz_load_s1_fsm_shift_by_1[3]; - assign _zz_load_s1_fsm_shift_by_3 = _zz_load_s1_fsm_shift_by_1[5]; - assign _zz_load_s1_fsm_shift_by_4 = _zz_load_s1_fsm_shift_by_1[6]; - assign _zz_load_s1_fsm_shift_by_5 = _zz_load_s1_fsm_shift_by_1[7]; - assign _zz_load_s1_fsm_shift_by_6 = _zz_load_s1_fsm_shift_by_1[9]; - assign _zz_load_s1_fsm_shift_by_7 = _zz_load_s1_fsm_shift_by_1[10]; - assign _zz_load_s1_fsm_shift_by_8 = _zz_load_s1_fsm_shift_by_1[11]; - assign _zz_load_s1_fsm_shift_by_9 = _zz_load_s1_fsm_shift_by_1[12]; - assign _zz_load_s1_fsm_shift_by_10 = _zz_load_s1_fsm_shift_by_1[13]; - assign _zz_load_s1_fsm_shift_by_11 = _zz_load_s1_fsm_shift_by_1[14]; - assign _zz_load_s1_fsm_shift_by_12 = _zz_load_s1_fsm_shift_by_1[15]; - assign _zz_load_s1_fsm_shift_by_13 = _zz_load_s1_fsm_shift_by_1[17]; - assign _zz_load_s1_fsm_shift_by_14 = _zz_load_s1_fsm_shift_by_1[18]; - assign _zz_load_s1_fsm_shift_by_15 = _zz_load_s1_fsm_shift_by_1[19]; - assign _zz_load_s1_fsm_shift_by_16 = _zz_load_s1_fsm_shift_by_1[20]; - assign _zz_load_s1_fsm_shift_by_17 = _zz_load_s1_fsm_shift_by_1[21]; - assign _zz_load_s1_fsm_shift_by_18 = _zz_load_s1_fsm_shift_by_1[22]; - assign _zz_load_s1_fsm_shift_by_19 = _zz_load_s1_fsm_shift_by_1[23]; - assign _zz_load_s1_fsm_shift_by_20 = _zz_load_s1_fsm_shift_by_1[24]; - assign _zz_load_s1_fsm_shift_by_21 = _zz_load_s1_fsm_shift_by_1[25]; - assign _zz_load_s1_fsm_shift_by_22 = _zz_load_s1_fsm_shift_by_1[26]; - assign _zz_load_s1_fsm_shift_by_23 = _zz_load_s1_fsm_shift_by_1[27]; - assign _zz_load_s1_fsm_shift_by_24 = _zz_load_s1_fsm_shift_by_1[28]; - assign _zz_load_s1_fsm_shift_by_25 = _zz_load_s1_fsm_shift_by_1[29]; - assign _zz_load_s1_fsm_shift_by_26 = _zz_load_s1_fsm_shift_by_1[30]; - assign _zz_load_s1_fsm_shift_by_27 = _zz_load_s1_fsm_shift_by_1[31]; - assign _zz_load_s1_fsm_shift_by_28 = (((((((((((((((_zz_load_s1_fsm_shift_by_1[1] || _zz_load_s1_fsm_shift_by_2) || _zz_load_s1_fsm_shift_by_3) || _zz_load_s1_fsm_shift_by_5) || _zz_load_s1_fsm_shift_by_6) || _zz_load_s1_fsm_shift_by_8) || _zz_load_s1_fsm_shift_by_10) || _zz_load_s1_fsm_shift_by_12) || _zz_load_s1_fsm_shift_by_13) || _zz_load_s1_fsm_shift_by_15) || _zz_load_s1_fsm_shift_by_17) || _zz_load_s1_fsm_shift_by_19) || _zz_load_s1_fsm_shift_by_21) || _zz_load_s1_fsm_shift_by_23) || _zz_load_s1_fsm_shift_by_25) || _zz_load_s1_fsm_shift_by_27); - assign _zz_load_s1_fsm_shift_by_29 = (((((((((((((((_zz_load_s1_fsm_shift_by_1[2] || _zz_load_s1_fsm_shift_by_2) || _zz_load_s1_fsm_shift_by_4) || _zz_load_s1_fsm_shift_by_5) || _zz_load_s1_fsm_shift_by_7) || _zz_load_s1_fsm_shift_by_8) || _zz_load_s1_fsm_shift_by_11) || _zz_load_s1_fsm_shift_by_12) || _zz_load_s1_fsm_shift_by_14) || _zz_load_s1_fsm_shift_by_15) || _zz_load_s1_fsm_shift_by_18) || _zz_load_s1_fsm_shift_by_19) || _zz_load_s1_fsm_shift_by_22) || _zz_load_s1_fsm_shift_by_23) || _zz_load_s1_fsm_shift_by_26) || _zz_load_s1_fsm_shift_by_27); - assign _zz_load_s1_fsm_shift_by_30 = (((((((((((((((_zz_load_s1_fsm_shift_by_1[4] || _zz_load_s1_fsm_shift_by_3) || _zz_load_s1_fsm_shift_by_4) || _zz_load_s1_fsm_shift_by_5) || _zz_load_s1_fsm_shift_by_9) || _zz_load_s1_fsm_shift_by_10) || _zz_load_s1_fsm_shift_by_11) || _zz_load_s1_fsm_shift_by_12) || _zz_load_s1_fsm_shift_by_16) || _zz_load_s1_fsm_shift_by_17) || _zz_load_s1_fsm_shift_by_18) || _zz_load_s1_fsm_shift_by_19) || _zz_load_s1_fsm_shift_by_24) || _zz_load_s1_fsm_shift_by_25) || _zz_load_s1_fsm_shift_by_26) || _zz_load_s1_fsm_shift_by_27); - assign _zz_load_s1_fsm_shift_by_31 = (((((((((((((((_zz_load_s1_fsm_shift_by_1[8] || _zz_load_s1_fsm_shift_by_6) || _zz_load_s1_fsm_shift_by_7) || _zz_load_s1_fsm_shift_by_8) || _zz_load_s1_fsm_shift_by_9) || _zz_load_s1_fsm_shift_by_10) || _zz_load_s1_fsm_shift_by_11) || _zz_load_s1_fsm_shift_by_12) || _zz_load_s1_fsm_shift_by_20) || _zz_load_s1_fsm_shift_by_21) || _zz_load_s1_fsm_shift_by_22) || _zz_load_s1_fsm_shift_by_23) || _zz_load_s1_fsm_shift_by_24) || _zz_load_s1_fsm_shift_by_25) || _zz_load_s1_fsm_shift_by_26) || _zz_load_s1_fsm_shift_by_27); - assign _zz_load_s1_fsm_shift_by_32 = (((((((((((((((_zz_load_s1_fsm_shift_by_1[16] || _zz_load_s1_fsm_shift_by_13) || _zz_load_s1_fsm_shift_by_14) || _zz_load_s1_fsm_shift_by_15) || _zz_load_s1_fsm_shift_by_16) || _zz_load_s1_fsm_shift_by_17) || _zz_load_s1_fsm_shift_by_18) || _zz_load_s1_fsm_shift_by_19) || _zz_load_s1_fsm_shift_by_20) || _zz_load_s1_fsm_shift_by_21) || _zz_load_s1_fsm_shift_by_22) || _zz_load_s1_fsm_shift_by_23) || _zz_load_s1_fsm_shift_by_24) || _zz_load_s1_fsm_shift_by_25) || _zz_load_s1_fsm_shift_by_26) || _zz_load_s1_fsm_shift_by_27); - always @(*) begin - load_s1_fsm_expOffset = 9'h0; - if(load_s1_isSubnormal) begin - load_s1_fsm_expOffset = {4'd0, load_s1_fsm_shift_by}; - end - end - - assign load_s1_input_isStall = (load_s1_input_valid && (! load_s1_input_ready)); - assign when_FpuCore_l551 = (! load_s1_input_isStall); - assign load_s1_i2fHigh = load_s1_fsm_shift_output[31 : 8]; - assign load_s1_i2fLow = load_s1_fsm_shift_output[7 : 0]; - assign load_s1_scrap = (load_s1_i2fLow != 8'h0); - assign load_s1_recoded_mantissa = load_s1_passThroughFloat_mantissa; - always @(*) begin - load_s1_recoded_exponent = _zz_load_s1_recoded_exponent[8:0]; - if(load_s1_isZero) begin - load_s1_recoded_exponent[1 : 0] = 2'b00; - end - if(load_s1_isInfinity) begin - load_s1_recoded_exponent[1 : 0] = 2'b01; - end - if(load_s1_isNan) begin - load_s1_recoded_exponent[1 : 0] = 2'b10; - load_s1_recoded_exponent[2] = 1'b0; - end - end - - assign load_s1_recoded_sign = load_s1_passThroughFloat_sign; - always @(*) begin - load_s1_recoded_special = 1'b0; - if(load_s1_isZero) begin - load_s1_recoded_special = 1'b1; - end - if(load_s1_isInfinity) begin - load_s1_recoded_special = 1'b1; - end - if(load_s1_isNan) begin - load_s1_recoded_special = 1'b1; - end - end - - assign _zz_load_s1_input_ready = (! load_s1_busy); - assign load_s1_input_ready = (load_s1_output_ready && _zz_load_s1_input_ready); - assign load_s1_output_valid = (load_s1_input_valid && _zz_load_s1_input_ready); - assign load_s1_output_payload_roundMode = load_s1_input_payload_roundMode; - assign load_s1_output_payload_rd = load_s1_input_payload_rd; - always @(*) begin - load_s1_output_payload_value_sign = load_s1_recoded_sign; - if(load_s1_input_payload_i2f) begin - load_s1_output_payload_value_sign = load_s1_fsm_patched; - end - end - - always @(*) begin - load_s1_output_payload_value_exponent = load_s1_recoded_exponent; - if(load_s1_input_payload_i2f) begin - load_s1_output_payload_value_exponent = (9'h11e - _zz_load_s1_output_payload_value_exponent); - if(load_s1_fsm_i2fZero) begin - load_s1_output_payload_value_exponent[1 : 0] = 2'b00; - end - end - end - - always @(*) begin - load_s1_output_payload_value_mantissa = {load_s1_recoded_mantissa,1'b0}; - if(when_FpuCore_l594) begin - load_s1_output_payload_value_mantissa = load_s1_i2fHigh; - end - end - - always @(*) begin - load_s1_output_payload_value_special = load_s1_recoded_special; - if(load_s1_input_payload_i2f) begin - load_s1_output_payload_value_special = 1'b0; - if(load_s1_fsm_i2fZero) begin - load_s1_output_payload_value_special = 1'b1; - end - end - end - - always @(*) begin - load_s1_output_payload_scrap = 1'b0; - if(load_s1_input_payload_i2f) begin - load_s1_output_payload_scrap = load_s1_scrap; - end - end - - assign load_s1_output_payload_NV = 1'b0; - assign load_s1_output_payload_DZ = 1'b0; - assign when_FpuCore_l594 = (load_s1_input_payload_i2f || load_s1_isSubnormal); - always @(*) begin - decode_shortPip_ready = shortPip_input_ready; - if(when_Stream_l368_4) begin - decode_shortPip_ready = 1'b1; - end - end - - assign when_Stream_l368_4 = (! shortPip_input_valid); - assign shortPip_input_valid = decode_shortPip_rValid; - assign shortPip_input_payload_opcode = decode_shortPip_rData_opcode; - assign shortPip_input_payload_rs1_mantissa = decode_shortPip_rData_rs1_mantissa; - assign shortPip_input_payload_rs1_exponent = decode_shortPip_rData_rs1_exponent; - assign shortPip_input_payload_rs1_sign = decode_shortPip_rData_rs1_sign; - assign shortPip_input_payload_rs1_special = decode_shortPip_rData_rs1_special; - assign shortPip_input_payload_rs2_mantissa = decode_shortPip_rData_rs2_mantissa; - assign shortPip_input_payload_rs2_exponent = decode_shortPip_rData_rs2_exponent; - assign shortPip_input_payload_rs2_sign = decode_shortPip_rData_rs2_sign; - assign shortPip_input_payload_rs2_special = decode_shortPip_rData_rs2_special; - assign shortPip_input_payload_rd = decode_shortPip_rData_rd; - assign shortPip_input_payload_value = decode_shortPip_rData_value; - assign shortPip_input_payload_arg = decode_shortPip_rData_arg; - assign shortPip_input_payload_roundMode = decode_shortPip_rData_roundMode; - assign shortPip_toFpuRf = ({(shortPip_input_payload_opcode == FpuOpcode_FCVT_X_X),{(shortPip_input_payload_opcode == FpuOpcode_SGNJ),(shortPip_input_payload_opcode == FpuOpcode_MIN_MAX)}} != 3'b000); - assign shortPip_input_fire = (shortPip_input_valid && shortPip_input_ready); - assign when_FpuCore_l221 = ((shortPip_input_fire && shortPip_toFpuRf) && 1'b1); - assign shortPip_isCommited = commitLogic_0_short_notEmpty; - assign _zz_shortPip_rfOutput_ready = (! (! shortPip_isCommited)); - assign shortPip_output_valid = (shortPip_rfOutput_valid && _zz_shortPip_rfOutput_ready); - assign shortPip_rfOutput_ready = (shortPip_output_ready && _zz_shortPip_rfOutput_ready); - assign shortPip_output_payload_rd = shortPip_rfOutput_payload_rd; - assign shortPip_output_payload_value_mantissa = shortPip_rfOutput_payload_value_mantissa; - assign shortPip_output_payload_value_exponent = shortPip_rfOutput_payload_value_exponent; - assign shortPip_output_payload_value_sign = shortPip_rfOutput_payload_value_sign; - assign shortPip_output_payload_value_special = shortPip_rfOutput_payload_value_special; - assign shortPip_output_payload_scrap = shortPip_rfOutput_payload_scrap; - assign shortPip_output_payload_roundMode = shortPip_rfOutput_payload_roundMode; - assign shortPip_output_payload_NV = shortPip_rfOutput_payload_NV; - assign shortPip_output_payload_DZ = shortPip_rfOutput_payload_DZ; - always @(*) begin - shortPip_result = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - case(shortPip_input_payload_opcode) - FpuOpcode_STORE : begin - shortPip_result = shortPip_recodedResult; - end - FpuOpcode_FMV_X_W : begin - shortPip_result = shortPip_recodedResult; - end - FpuOpcode_F2I : begin - shortPip_result[31 : 0] = shortPip_f2i_result; - end - FpuOpcode_CMP : begin - shortPip_result[31 : 0] = {31'd0, shortPip_cmpResult}; - end - FpuOpcode_FCLASS : begin - shortPip_result[31 : 0] = shortPip_fclassResult; - end - default : begin - end - endcase - end - - always @(*) begin - shortPip_halt = 1'b0; - if(when_FpuCore_l658) begin - shortPip_halt = 1'b1; - end - end - - assign shortPip_f32_exp = _zz_shortPip_f32_exp[7:0]; - assign shortPip_f32_man = shortPip_input_payload_rs1_mantissa[22 : 0]; - always @(*) begin - shortPip_recodedResult = {{shortPip_input_payload_rs1_sign,shortPip_f32_exp},shortPip_f32_man}; - if(shortPip_isSubnormal) begin - shortPip_recodedResult[22 : 0] = shortPip_fsm_shift_output[22 : 0]; - end - if(shortPip_mantissaForced) begin - shortPip_recodedResult[22 : 0] = (shortPip_mantissaForcedValue ? 23'h7fffff : 23'h0); - end - if(shortPip_exponentForced) begin - shortPip_recodedResult[30 : 23] = (shortPip_exponentForcedValue ? 8'hff : 8'h0); - end - if(shortPip_cononicalForced) begin - shortPip_recodedResult[31] = 1'b0; - shortPip_recodedResult[22] = 1'b1; - end - end - - assign shortPip_expSubnormalThreshold = 8'h80; - assign shortPip_expInSubnormalRange = (shortPip_input_payload_rs1_exponent <= _zz_shortPip_expInSubnormalRange); - assign shortPip_isSubnormal = ((! shortPip_input_payload_rs1_special) && shortPip_expInSubnormalRange); - assign shortPip_isNormal = ((! shortPip_input_payload_rs1_special) && (! shortPip_expInSubnormalRange)); - assign shortPip_fsm_f2iShift = (shortPip_input_payload_rs1_exponent - 9'h0ff); - assign shortPip_fsm_isF2i = (shortPip_input_payload_opcode == FpuOpcode_F2I); - assign shortPip_fsm_needRecoding = (({(shortPip_input_payload_opcode == FpuOpcode_STORE),(shortPip_input_payload_opcode == FpuOpcode_FMV_X_W)} != 2'b00) && shortPip_isSubnormal); - assign shortPip_fsm_isZero = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b00)); - always @(*) begin - shortPip_fsm_shift_input = 33'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - shortPip_fsm_shift_input = ({9'd0,{(! shortPip_fsm_isZero),shortPip_input_payload_rs1_mantissa}} <<< 9); - end - - assign when_FpuCore_l646 = (shortPip_fsm_shift_by[5] && (shortPip_fsm_shift_input[31 : 0] != 32'h0)); - assign when_FpuCore_l646_1 = (shortPip_fsm_shift_by[4] && (shortPip_fsm_shift_input_1[15 : 0] != 16'h0)); - assign when_FpuCore_l646_2 = (shortPip_fsm_shift_by[3] && (shortPip_fsm_shift_input_2[7 : 0] != 8'h0)); - assign when_FpuCore_l646_3 = (shortPip_fsm_shift_by[2] && (shortPip_fsm_shift_input_3[3 : 0] != 4'b0000)); - assign when_FpuCore_l646_4 = (shortPip_fsm_shift_by[1] && (shortPip_fsm_shift_input_4[1 : 0] != 2'b00)); - assign when_FpuCore_l646_5 = (shortPip_fsm_shift_by[0] && (shortPip_fsm_shift_input_5[0 : 0] != 1'b0)); - assign when_FpuCore_l652 = (! shortPip_fsm_done); - assign shortPip_fsm_formatShiftOffset = 8'h8a; - assign when_FpuCore_l658 = ((shortPip_input_valid && (shortPip_fsm_needRecoding || shortPip_fsm_isF2i)) && (! shortPip_fsm_done)); - assign _zz_shortPip_fsm_shift_by = (9'h11e - shortPip_input_payload_rs1_exponent); - assign _zz_shortPip_fsm_shift_by_1 = 6'h21; - assign shortPip_input_isStall = (shortPip_input_valid && (! shortPip_input_ready)); - assign when_FpuCore_l672 = (! shortPip_input_isStall); - always @(*) begin - shortPip_mantissaForced = 1'b0; - if(shortPip_input_payload_rs1_special) begin - case(switch_FpuCore_l686) - 2'b00 : begin - shortPip_mantissaForced = 1'b1; - end - 2'b01 : begin - shortPip_mantissaForced = 1'b1; - end - 2'b10 : begin - if(when_FpuCore_l702) begin - shortPip_mantissaForced = 1'b1; - end - end - default : begin - end - endcase - end - end - - always @(*) begin - shortPip_exponentForced = 1'b0; - if(shortPip_input_payload_rs1_special) begin - case(switch_FpuCore_l686) - 2'b00 : begin - shortPip_exponentForced = 1'b1; - end - 2'b01 : begin - shortPip_exponentForced = 1'b1; - end - 2'b10 : begin - shortPip_exponentForced = 1'b1; - end - default : begin - end - endcase - end - if(shortPip_isSubnormal) begin - shortPip_exponentForced = 1'b1; - end - end - - always @(*) begin - shortPip_mantissaForcedValue = 1'bx; - if(shortPip_input_payload_rs1_special) begin - case(switch_FpuCore_l686) - 2'b00 : begin - shortPip_mantissaForcedValue = 1'b0; - end - 2'b01 : begin - shortPip_mantissaForcedValue = 1'b0; - end - 2'b10 : begin - if(when_FpuCore_l702) begin - shortPip_mantissaForcedValue = 1'b0; - end - end - default : begin - end - endcase - end - end - - always @(*) begin - shortPip_exponentForcedValue = 1'bx; - if(shortPip_input_payload_rs1_special) begin - case(switch_FpuCore_l686) - 2'b00 : begin - shortPip_exponentForcedValue = 1'b0; - end - 2'b01 : begin - shortPip_exponentForcedValue = 1'b1; - end - 2'b10 : begin - shortPip_exponentForcedValue = 1'b1; - end - default : begin - end - endcase - end - if(shortPip_isSubnormal) begin - shortPip_exponentForcedValue = 1'b0; - end - end - - always @(*) begin - shortPip_cononicalForced = 1'b0; - if(shortPip_input_payload_rs1_special) begin - case(switch_FpuCore_l686) - 2'b10 : begin - if(when_FpuCore_l702) begin - shortPip_cononicalForced = 1'b1; - end - end - default : begin - end - endcase - end - end - - assign switch_FpuCore_l686 = shortPip_input_payload_rs1_exponent[1 : 0]; - assign when_FpuCore_l702 = shortPip_input_payload_rs1_exponent[2]; - always @(*) begin - shortPip_rspNv = 1'b0; - if(!shortPip_f2i_isZero) begin - if(when_FpuCore_l767) begin - shortPip_rspNv = (((shortPip_input_valid && (shortPip_input_payload_opcode == FpuOpcode_F2I)) && shortPip_fsm_done) && (! shortPip_f2i_isZero)); - end - end - if(shortPip_NV) begin - shortPip_rspNv = 1'b1; - end - end - - always @(*) begin - shortPip_rspNx = 1'b0; - if(!shortPip_f2i_isZero) begin - if(!when_FpuCore_l767) begin - shortPip_rspNx = (((shortPip_input_valid && (shortPip_input_payload_opcode == FpuOpcode_F2I)) && shortPip_fsm_done) && (shortPip_f2i_round != 2'b00)); - end - end - end - - assign shortPip_f2i_unsigned = (shortPip_fsm_shift_output[32 : 0] >>> 1); - assign shortPip_f2i_resign = (shortPip_input_payload_arg[0] && shortPip_input_payload_rs1_sign); - assign shortPip_f2i_round = {shortPip_fsm_shift_output[0],shortPip_fsm_shift_scrap}; - always @(*) begin - case(shortPip_input_payload_roundMode) - FpuRoundMode_RNE : begin - shortPip_f2i_increment = (shortPip_f2i_round[1] && (shortPip_f2i_round[0] || shortPip_f2i_unsigned[0])); - end - FpuRoundMode_RTZ : begin - shortPip_f2i_increment = 1'b0; - end - FpuRoundMode_RDN : begin - shortPip_f2i_increment = ((shortPip_f2i_round != 2'b00) && shortPip_input_payload_rs1_sign); - end - FpuRoundMode_RUP : begin - shortPip_f2i_increment = ((shortPip_f2i_round != 2'b00) && (! shortPip_input_payload_rs1_sign)); - end - default : begin - shortPip_f2i_increment = shortPip_f2i_round[1]; - end - endcase - end - - always @(*) begin - shortPip_f2i_result = ((shortPip_f2i_resign ? (~ shortPip_f2i_unsigned) : shortPip_f2i_unsigned) + _zz_shortPip_f2i_result); - if(shortPip_f2i_isZero) begin - shortPip_f2i_result = 32'h0; - end else begin - if(when_FpuCore_l767) begin - shortPip_f2i_result = (shortPip_f2i_overflow ? 32'hffffffff : 32'h0); - shortPip_f2i_result[31] = (shortPip_input_payload_arg[0] ^ shortPip_f2i_overflow); - end - end - end - - assign shortPip_f2i_overflow = (((((shortPip_input_payload_arg[0] ? 9'h11d : 9'h11e) < shortPip_input_payload_rs1_exponent) || (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b01))) && (! shortPip_input_payload_rs1_sign)) || (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10))); - assign shortPip_f2i_underflow = (((((9'h11e < shortPip_input_payload_rs1_exponent) || ((shortPip_input_payload_arg[0] && shortPip_f2i_unsigned[31]) && ((shortPip_f2i_unsigned[30 : 0] != 31'h0) || shortPip_f2i_increment))) || ((! shortPip_input_payload_arg[0]) && ((shortPip_f2i_unsigned != 32'h0) || shortPip_f2i_increment))) || (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b01))) && shortPip_input_payload_rs1_sign); - assign shortPip_f2i_isZero = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b00)); - assign when_FpuCore_l767 = (shortPip_f2i_underflow || shortPip_f2i_overflow); - assign shortPip_bothZero = ((shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b00)) && (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b00))); - always @(*) begin - shortPip_rs1Equal = ((((shortPip_input_payload_rs1_mantissa == shortPip_input_payload_rs2_mantissa) && (shortPip_input_payload_rs1_exponent == shortPip_input_payload_rs2_exponent)) && (shortPip_input_payload_rs1_sign == shortPip_input_payload_rs2_sign)) && (shortPip_input_payload_rs1_special == shortPip_input_payload_rs2_special)); - if(when_FpuCore_l784) begin - shortPip_rs1Equal = 1'b1; - end - end - - always @(*) begin - shortPip_rs1AbsSmaller = ({shortPip_input_payload_rs1_exponent,shortPip_input_payload_rs1_mantissa} < {shortPip_input_payload_rs2_exponent,shortPip_input_payload_rs2_mantissa}); - if(when_FpuCore_l780) begin - shortPip_rs1AbsSmaller = 1'b1; - end - if(when_FpuCore_l781) begin - shortPip_rs1AbsSmaller = 1'b1; - end - if(when_FpuCore_l782) begin - shortPip_rs1AbsSmaller = 1'b0; - end - if(when_FpuCore_l783) begin - shortPip_rs1AbsSmaller = 1'b0; - end - end - - assign when_FpuCore_l780 = (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b01)); - assign when_FpuCore_l781 = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b00)); - assign when_FpuCore_l782 = (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b00)); - assign when_FpuCore_l783 = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b01)); - assign when_FpuCore_l784 = (((shortPip_input_payload_rs1_sign == shortPip_input_payload_rs2_sign) && (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b01))) && (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b01))); - assign switch_Misc_l210 = {shortPip_input_payload_rs1_sign,shortPip_input_payload_rs2_sign}; - always @(*) begin - case(switch_Misc_l210) - 2'b00 : begin - shortPip_rs1Smaller = shortPip_rs1AbsSmaller; - end - 2'b01 : begin - shortPip_rs1Smaller = 1'b0; - end - 2'b10 : begin - shortPip_rs1Smaller = 1'b1; - end - default : begin - shortPip_rs1Smaller = ((! shortPip_rs1AbsSmaller) && (! shortPip_rs1Equal)); - end - endcase - end - - assign shortPip_minMaxSelectRs2 = (! (((shortPip_rs1Smaller ^ shortPip_input_payload_arg[0]) && (! (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)))) || (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b10)))); - assign shortPip_minMaxSelectNanQuiet = ((shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)) && (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b10))); - always @(*) begin - shortPip_cmpResult = (((shortPip_rs1Smaller && (! shortPip_bothZero)) && (! shortPip_input_payload_arg[1])) || ((shortPip_rs1Equal || shortPip_bothZero) && (! shortPip_input_payload_arg[0]))); - if(when_FpuCore_l796) begin - shortPip_cmpResult = 1'b0; - end - end - - assign when_FpuCore_l796 = ((shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)) || (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b10))); - assign shortPip_sgnjRs1Sign = shortPip_input_payload_rs1_sign; - assign shortPip_sgnjRs2Sign = shortPip_input_payload_rs2_sign; - assign shortPip_sgnjResult = (((shortPip_sgnjRs1Sign && shortPip_input_payload_arg[1]) ^ shortPip_sgnjRs2Sign) ^ shortPip_input_payload_arg[0]); - always @(*) begin - shortPip_fclassResult = 32'h0; - shortPip_fclassResult[0] = (shortPip_input_payload_rs1_sign && shortPip_decoded_isInfinity); - shortPip_fclassResult[1] = (shortPip_input_payload_rs1_sign && shortPip_isNormal); - shortPip_fclassResult[2] = (shortPip_input_payload_rs1_sign && shortPip_isSubnormal); - shortPip_fclassResult[3] = (shortPip_input_payload_rs1_sign && shortPip_decoded_isZero); - shortPip_fclassResult[4] = ((! shortPip_input_payload_rs1_sign) && shortPip_decoded_isZero); - shortPip_fclassResult[5] = ((! shortPip_input_payload_rs1_sign) && shortPip_isSubnormal); - shortPip_fclassResult[6] = ((! shortPip_input_payload_rs1_sign) && shortPip_isNormal); - shortPip_fclassResult[7] = ((! shortPip_input_payload_rs1_sign) && shortPip_decoded_isInfinity); - shortPip_fclassResult[8] = (shortPip_decoded_isNan && (! shortPip_decoded_isQuiet)); - shortPip_fclassResult[9] = (shortPip_decoded_isNan && shortPip_decoded_isQuiet); - end - - assign shortPip_decoded_isZero = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b00)); - assign shortPip_decoded_isNormal = (! shortPip_input_payload_rs1_special); - assign shortPip_decoded_isInfinity = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b01)); - assign shortPip_decoded_isNan = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)); - assign shortPip_decoded_isQuiet = shortPip_input_payload_rs1_mantissa[22]; - assign shortPip_rfOutput_valid = ((shortPip_input_valid && shortPip_toFpuRf) && (! shortPip_halt)); - assign shortPip_rfOutput_payload_rd = shortPip_input_payload_rd; - assign shortPip_rfOutput_payload_roundMode = shortPip_input_payload_roundMode; - assign shortPip_rfOutput_payload_scrap = 1'b0; - always @(*) begin - shortPip_rfOutput_payload_value_sign = shortPip_input_payload_rs1_sign; - case(shortPip_input_payload_opcode) - FpuOpcode_MIN_MAX : begin - if(shortPip_minMaxSelectRs2) begin - shortPip_rfOutput_payload_value_sign = shortPip_input_payload_rs2_sign; - end - end - FpuOpcode_SGNJ : begin - if(when_FpuCore_l850) begin - shortPip_rfOutput_payload_value_sign = shortPip_sgnjResult; - end - end - default : begin - end - endcase - end - - always @(*) begin - shortPip_rfOutput_payload_value_exponent = shortPip_input_payload_rs1_exponent; - case(shortPip_input_payload_opcode) - FpuOpcode_MIN_MAX : begin - if(shortPip_minMaxSelectRs2) begin - shortPip_rfOutput_payload_value_exponent = shortPip_input_payload_rs2_exponent; - end - if(shortPip_minMaxSelectNanQuiet) begin - shortPip_rfOutput_payload_value_exponent[1 : 0] = 2'b10; - shortPip_rfOutput_payload_value_exponent[2] = 1'b1; - end - end - default : begin - end - endcase - end - - always @(*) begin - shortPip_rfOutput_payload_value_mantissa = {shortPip_input_payload_rs1_mantissa,1'b0}; - case(shortPip_input_payload_opcode) - FpuOpcode_MIN_MAX : begin - if(shortPip_minMaxSelectRs2) begin - shortPip_rfOutput_payload_value_mantissa = {shortPip_input_payload_rs2_mantissa,1'b0}; - end - if(shortPip_minMaxSelectNanQuiet) begin - shortPip_rfOutput_payload_value_mantissa[23] = 1'b1; - end - end - default : begin - end - endcase - end - - always @(*) begin - shortPip_rfOutput_payload_value_special = shortPip_input_payload_rs1_special; - case(shortPip_input_payload_opcode) - FpuOpcode_MIN_MAX : begin - if(shortPip_minMaxSelectRs2) begin - shortPip_rfOutput_payload_value_special = shortPip_input_payload_rs2_special; - end - if(shortPip_minMaxSelectNanQuiet) begin - shortPip_rfOutput_payload_value_special = 1'b1; - end - end - default : begin - end - endcase - end - - assign when_FpuCore_l850 = (! (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10))); - assign shortPip_signalQuiet = ((shortPip_input_payload_opcode == FpuOpcode_CMP) && (shortPip_input_payload_arg != 2'b10)); - assign shortPip_rs1Nan = (shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)); - assign shortPip_rs2Nan = (shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b10)); - assign shortPip_rs1NanNv = ((shortPip_input_payload_rs1_special && (shortPip_input_payload_rs1_exponent[1 : 0] == 2'b10)) && ((! shortPip_input_payload_rs1_mantissa[22]) || shortPip_signalQuiet)); - assign shortPip_rs2NanNv = ((shortPip_input_payload_rs2_special && (shortPip_input_payload_rs2_exponent[1 : 0] == 2'b10)) && ((! shortPip_input_payload_rs2_mantissa[22]) || shortPip_signalQuiet)); - assign shortPip_NV = ((({(shortPip_input_payload_opcode == FpuOpcode_FCVT_X_X),{(shortPip_input_payload_opcode == FpuOpcode_MIN_MAX),(shortPip_input_payload_opcode == FpuOpcode_CMP)}} != 3'b000) && shortPip_rs1NanNv) || (({(shortPip_input_payload_opcode == FpuOpcode_MIN_MAX),(shortPip_input_payload_opcode == FpuOpcode_CMP)} != 2'b00) && shortPip_rs2NanNv)); - assign shortPip_input_ready = ((! shortPip_halt) && (shortPip_toFpuRf ? shortPip_rfOutput_ready : shortPip_rspStreams_0_ready)); - assign shortPip_rspStreams_0_valid = (((shortPip_input_valid && 1'b1) && (! shortPip_toFpuRf)) && (! shortPip_halt)); - assign shortPip_rspStreams_0_payload_value = shortPip_result; - assign shortPip_rspStreams_0_payload_NV = shortPip_rspNv; - assign shortPip_rspStreams_0_payload_NX = shortPip_rspNx; - always @(*) begin - shortPip_rspStreams_0_ready = shortPip_rspStreams_0_m2sPipe_ready; - if(when_Stream_l368_5) begin - shortPip_rspStreams_0_ready = 1'b1; - end - end - - assign when_Stream_l368_5 = (! shortPip_rspStreams_0_m2sPipe_valid); - assign shortPip_rspStreams_0_m2sPipe_valid = shortPip_rspStreams_0_rValid; - assign shortPip_rspStreams_0_m2sPipe_payload_value = shortPip_rspStreams_0_rData_value; - assign shortPip_rspStreams_0_m2sPipe_payload_NV = shortPip_rspStreams_0_rData_NV; - assign shortPip_rspStreams_0_m2sPipe_payload_NX = shortPip_rspStreams_0_rData_NX; - assign io_port_0_rsp_valid = shortPip_rspStreams_0_m2sPipe_valid; - assign shortPip_rspStreams_0_m2sPipe_ready = io_port_0_rsp_ready; - assign io_port_0_rsp_payload_value = shortPip_rspStreams_0_m2sPipe_payload_value; - assign io_port_0_rsp_payload_NV = shortPip_rspStreams_0_m2sPipe_payload_NV; - assign io_port_0_rsp_payload_NX = shortPip_rspStreams_0_m2sPipe_payload_NX; - assign shortPip_rfOutput_payload_NV = shortPip_NV; - assign shortPip_rfOutput_payload_DZ = 1'b0; - always @(*) begin - decode_mul_ready = mul_preMul_input_ready; - if(when_Stream_l368_6) begin - decode_mul_ready = 1'b1; - end - end - - assign when_Stream_l368_6 = (! mul_preMul_input_valid); - assign mul_preMul_input_valid = decode_mul_rValid; - assign mul_preMul_input_payload_rs1_mantissa = decode_mul_rData_rs1_mantissa; - assign mul_preMul_input_payload_rs1_exponent = decode_mul_rData_rs1_exponent; - assign mul_preMul_input_payload_rs1_sign = decode_mul_rData_rs1_sign; - assign mul_preMul_input_payload_rs1_special = decode_mul_rData_rs1_special; - assign mul_preMul_input_payload_rs2_mantissa = decode_mul_rData_rs2_mantissa; - assign mul_preMul_input_payload_rs2_exponent = decode_mul_rData_rs2_exponent; - assign mul_preMul_input_payload_rs2_sign = decode_mul_rData_rs2_sign; - assign mul_preMul_input_payload_rs2_special = decode_mul_rData_rs2_special; - assign mul_preMul_input_payload_rs3_mantissa = decode_mul_rData_rs3_mantissa; - assign mul_preMul_input_payload_rs3_exponent = decode_mul_rData_rs3_exponent; - assign mul_preMul_input_payload_rs3_sign = decode_mul_rData_rs3_sign; - assign mul_preMul_input_payload_rs3_special = decode_mul_rData_rs3_special; - assign mul_preMul_input_payload_rd = decode_mul_rData_rd; - assign mul_preMul_input_payload_add = decode_mul_rData_add; - assign mul_preMul_input_payload_divSqrt = decode_mul_rData_divSqrt; - assign mul_preMul_input_payload_msb1 = decode_mul_rData_msb1; - assign mul_preMul_input_payload_msb2 = decode_mul_rData_msb2; - assign mul_preMul_input_payload_roundMode = decode_mul_rData_roundMode; - assign mul_preMul_output_valid = mul_preMul_input_valid; - assign mul_preMul_input_ready = mul_preMul_output_ready; - assign mul_preMul_output_payload_rs1_mantissa = mul_preMul_input_payload_rs1_mantissa; - assign mul_preMul_output_payload_rs1_exponent = mul_preMul_input_payload_rs1_exponent; - assign mul_preMul_output_payload_rs1_sign = mul_preMul_input_payload_rs1_sign; - assign mul_preMul_output_payload_rs1_special = mul_preMul_input_payload_rs1_special; - assign mul_preMul_output_payload_rs2_mantissa = mul_preMul_input_payload_rs2_mantissa; - assign mul_preMul_output_payload_rs2_exponent = mul_preMul_input_payload_rs2_exponent; - assign mul_preMul_output_payload_rs2_sign = mul_preMul_input_payload_rs2_sign; - assign mul_preMul_output_payload_rs2_special = mul_preMul_input_payload_rs2_special; - assign mul_preMul_output_payload_rs3_mantissa = mul_preMul_input_payload_rs3_mantissa; - assign mul_preMul_output_payload_rs3_exponent = mul_preMul_input_payload_rs3_exponent; - assign mul_preMul_output_payload_rs3_sign = mul_preMul_input_payload_rs3_sign; - assign mul_preMul_output_payload_rs3_special = mul_preMul_input_payload_rs3_special; - assign mul_preMul_output_payload_rd = mul_preMul_input_payload_rd; - assign mul_preMul_output_payload_add = mul_preMul_input_payload_add; - assign mul_preMul_output_payload_divSqrt = mul_preMul_input_payload_divSqrt; - assign mul_preMul_output_payload_msb1 = mul_preMul_input_payload_msb1; - assign mul_preMul_output_payload_msb2 = mul_preMul_input_payload_msb2; - assign mul_preMul_output_payload_roundMode = mul_preMul_input_payload_roundMode; - assign mul_preMul_output_payload_exp = ({1'b0,mul_preMul_input_payload_rs1_exponent} + {1'b0,mul_preMul_input_payload_rs2_exponent}); - always @(*) begin - mul_preMul_output_ready = mul_mul_input_ready; - if(when_Stream_l368_7) begin - mul_preMul_output_ready = 1'b1; - end - end - - assign when_Stream_l368_7 = (! mul_mul_input_valid); - assign mul_mul_input_valid = mul_preMul_output_rValid; - assign mul_mul_input_payload_rs1_mantissa = mul_preMul_output_rData_rs1_mantissa; - assign mul_mul_input_payload_rs1_exponent = mul_preMul_output_rData_rs1_exponent; - assign mul_mul_input_payload_rs1_sign = mul_preMul_output_rData_rs1_sign; - assign mul_mul_input_payload_rs1_special = mul_preMul_output_rData_rs1_special; - assign mul_mul_input_payload_rs2_mantissa = mul_preMul_output_rData_rs2_mantissa; - assign mul_mul_input_payload_rs2_exponent = mul_preMul_output_rData_rs2_exponent; - assign mul_mul_input_payload_rs2_sign = mul_preMul_output_rData_rs2_sign; - assign mul_mul_input_payload_rs2_special = mul_preMul_output_rData_rs2_special; - assign mul_mul_input_payload_rs3_mantissa = mul_preMul_output_rData_rs3_mantissa; - assign mul_mul_input_payload_rs3_exponent = mul_preMul_output_rData_rs3_exponent; - assign mul_mul_input_payload_rs3_sign = mul_preMul_output_rData_rs3_sign; - assign mul_mul_input_payload_rs3_special = mul_preMul_output_rData_rs3_special; - assign mul_mul_input_payload_rd = mul_preMul_output_rData_rd; - assign mul_mul_input_payload_add = mul_preMul_output_rData_add; - assign mul_mul_input_payload_divSqrt = mul_preMul_output_rData_divSqrt; - assign mul_mul_input_payload_msb1 = mul_preMul_output_rData_msb1; - assign mul_mul_input_payload_msb2 = mul_preMul_output_rData_msb2; - assign mul_mul_input_payload_roundMode = mul_preMul_output_rData_roundMode; - assign mul_mul_input_payload_exp = mul_preMul_output_rData_exp; - assign mul_mul_output_valid = mul_mul_input_valid; - assign mul_mul_input_ready = mul_mul_output_ready; - assign mul_mul_mulA = {mul_mul_input_payload_msb1,mul_mul_input_payload_rs1_mantissa}; - assign mul_mul_mulB = {mul_mul_input_payload_msb2,mul_mul_input_payload_rs2_mantissa}; - assign mul_mul_output_payload_rs1_mantissa = mul_mul_input_payload_rs1_mantissa; - assign mul_mul_output_payload_rs1_exponent = mul_mul_input_payload_rs1_exponent; - assign mul_mul_output_payload_rs1_sign = mul_mul_input_payload_rs1_sign; - assign mul_mul_output_payload_rs1_special = mul_mul_input_payload_rs1_special; - assign mul_mul_output_payload_rs2_mantissa = mul_mul_input_payload_rs2_mantissa; - assign mul_mul_output_payload_rs2_exponent = mul_mul_input_payload_rs2_exponent; - assign mul_mul_output_payload_rs2_sign = mul_mul_input_payload_rs2_sign; - assign mul_mul_output_payload_rs2_special = mul_mul_input_payload_rs2_special; - assign mul_mul_output_payload_rs3_mantissa = mul_mul_input_payload_rs3_mantissa; - assign mul_mul_output_payload_rs3_exponent = mul_mul_input_payload_rs3_exponent; - assign mul_mul_output_payload_rs3_sign = mul_mul_input_payload_rs3_sign; - assign mul_mul_output_payload_rs3_special = mul_mul_input_payload_rs3_special; - assign mul_mul_output_payload_rd = mul_mul_input_payload_rd; - assign mul_mul_output_payload_add = mul_mul_input_payload_add; - assign mul_mul_output_payload_divSqrt = mul_mul_input_payload_divSqrt; - assign mul_mul_output_payload_msb1 = mul_mul_input_payload_msb1; - assign mul_mul_output_payload_msb2 = mul_mul_input_payload_msb2; - assign mul_mul_output_payload_roundMode = mul_mul_input_payload_roundMode; - assign mul_mul_output_payload_exp = mul_mul_input_payload_exp; - assign mul_mul_output_payload_muls_0 = (mul_mul_mulA[17 : 0] * mul_mul_mulB[17 : 0]); - assign mul_mul_output_payload_muls_1 = (mul_mul_mulA[17 : 0] * mul_mul_mulB[23 : 18]); - assign mul_mul_output_payload_muls_2 = (mul_mul_mulA[23 : 18] * mul_mul_mulB[17 : 0]); - assign mul_mul_output_payload_muls_3 = (mul_mul_mulA[23 : 18] * mul_mul_mulB[23 : 18]); - always @(*) begin - mul_mul_output_ready = mul_sum1_input_ready; - if(when_Stream_l368_8) begin - mul_mul_output_ready = 1'b1; - end - end - - assign when_Stream_l368_8 = (! mul_sum1_input_valid); - assign mul_sum1_input_valid = mul_mul_output_rValid; - assign mul_sum1_input_payload_rs1_mantissa = mul_mul_output_rData_rs1_mantissa; - assign mul_sum1_input_payload_rs1_exponent = mul_mul_output_rData_rs1_exponent; - assign mul_sum1_input_payload_rs1_sign = mul_mul_output_rData_rs1_sign; - assign mul_sum1_input_payload_rs1_special = mul_mul_output_rData_rs1_special; - assign mul_sum1_input_payload_rs2_mantissa = mul_mul_output_rData_rs2_mantissa; - assign mul_sum1_input_payload_rs2_exponent = mul_mul_output_rData_rs2_exponent; - assign mul_sum1_input_payload_rs2_sign = mul_mul_output_rData_rs2_sign; - assign mul_sum1_input_payload_rs2_special = mul_mul_output_rData_rs2_special; - assign mul_sum1_input_payload_rs3_mantissa = mul_mul_output_rData_rs3_mantissa; - assign mul_sum1_input_payload_rs3_exponent = mul_mul_output_rData_rs3_exponent; - assign mul_sum1_input_payload_rs3_sign = mul_mul_output_rData_rs3_sign; - assign mul_sum1_input_payload_rs3_special = mul_mul_output_rData_rs3_special; - assign mul_sum1_input_payload_rd = mul_mul_output_rData_rd; - assign mul_sum1_input_payload_add = mul_mul_output_rData_add; - assign mul_sum1_input_payload_divSqrt = mul_mul_output_rData_divSqrt; - assign mul_sum1_input_payload_msb1 = mul_mul_output_rData_msb1; - assign mul_sum1_input_payload_msb2 = mul_mul_output_rData_msb2; - assign mul_sum1_input_payload_roundMode = mul_mul_output_rData_roundMode; - assign mul_sum1_input_payload_exp = mul_mul_output_rData_exp; - assign mul_sum1_input_payload_muls_0 = mul_mul_output_rData_muls_0; - assign mul_sum1_input_payload_muls_1 = mul_mul_output_rData_muls_1; - assign mul_sum1_input_payload_muls_2 = mul_mul_output_rData_muls_2; - assign mul_sum1_input_payload_muls_3 = mul_mul_output_rData_muls_3; - assign mul_sum1_sum = (_zz_mul_sum1_sum + _zz_mul_sum1_sum_1); - assign mul_sum1_output_valid = mul_sum1_input_valid; - assign mul_sum1_input_ready = mul_sum1_output_ready; - assign mul_sum1_output_payload_rs1_mantissa = mul_sum1_input_payload_rs1_mantissa; - assign mul_sum1_output_payload_rs1_exponent = mul_sum1_input_payload_rs1_exponent; - assign mul_sum1_output_payload_rs1_sign = mul_sum1_input_payload_rs1_sign; - assign mul_sum1_output_payload_rs1_special = mul_sum1_input_payload_rs1_special; - assign mul_sum1_output_payload_rs2_mantissa = mul_sum1_input_payload_rs2_mantissa; - assign mul_sum1_output_payload_rs2_exponent = mul_sum1_input_payload_rs2_exponent; - assign mul_sum1_output_payload_rs2_sign = mul_sum1_input_payload_rs2_sign; - assign mul_sum1_output_payload_rs2_special = mul_sum1_input_payload_rs2_special; - assign mul_sum1_output_payload_rs3_mantissa = mul_sum1_input_payload_rs3_mantissa; - assign mul_sum1_output_payload_rs3_exponent = mul_sum1_input_payload_rs3_exponent; - assign mul_sum1_output_payload_rs3_sign = mul_sum1_input_payload_rs3_sign; - assign mul_sum1_output_payload_rs3_special = mul_sum1_input_payload_rs3_special; - assign mul_sum1_output_payload_rd = mul_sum1_input_payload_rd; - assign mul_sum1_output_payload_add = mul_sum1_input_payload_add; - assign mul_sum1_output_payload_divSqrt = mul_sum1_input_payload_divSqrt; - assign mul_sum1_output_payload_msb1 = mul_sum1_input_payload_msb1; - assign mul_sum1_output_payload_msb2 = mul_sum1_input_payload_msb2; - assign mul_sum1_output_payload_roundMode = mul_sum1_input_payload_roundMode; - assign mul_sum1_output_payload_exp = mul_sum1_input_payload_exp; - assign mul_sum1_output_payload_mulC2 = mul_sum1_sum; - assign mul_sum1_output_payload_muls2_0 = mul_sum1_input_payload_muls_2; - assign mul_sum1_output_payload_muls2_1 = mul_sum1_input_payload_muls_3; - always @(*) begin - mul_sum1_output_ready = mul_sum2_input_ready; - if(when_Stream_l368_9) begin - mul_sum1_output_ready = 1'b1; - end - end - - assign when_Stream_l368_9 = (! mul_sum2_input_valid); - assign mul_sum2_input_valid = mul_sum1_output_rValid; - assign mul_sum2_input_payload_rs1_mantissa = mul_sum1_output_rData_rs1_mantissa; - assign mul_sum2_input_payload_rs1_exponent = mul_sum1_output_rData_rs1_exponent; - assign mul_sum2_input_payload_rs1_sign = mul_sum1_output_rData_rs1_sign; - assign mul_sum2_input_payload_rs1_special = mul_sum1_output_rData_rs1_special; - assign mul_sum2_input_payload_rs2_mantissa = mul_sum1_output_rData_rs2_mantissa; - assign mul_sum2_input_payload_rs2_exponent = mul_sum1_output_rData_rs2_exponent; - assign mul_sum2_input_payload_rs2_sign = mul_sum1_output_rData_rs2_sign; - assign mul_sum2_input_payload_rs2_special = mul_sum1_output_rData_rs2_special; - assign mul_sum2_input_payload_rs3_mantissa = mul_sum1_output_rData_rs3_mantissa; - assign mul_sum2_input_payload_rs3_exponent = mul_sum1_output_rData_rs3_exponent; - assign mul_sum2_input_payload_rs3_sign = mul_sum1_output_rData_rs3_sign; - assign mul_sum2_input_payload_rs3_special = mul_sum1_output_rData_rs3_special; - assign mul_sum2_input_payload_rd = mul_sum1_output_rData_rd; - assign mul_sum2_input_payload_add = mul_sum1_output_rData_add; - assign mul_sum2_input_payload_divSqrt = mul_sum1_output_rData_divSqrt; - assign mul_sum2_input_payload_msb1 = mul_sum1_output_rData_msb1; - assign mul_sum2_input_payload_msb2 = mul_sum1_output_rData_msb2; - assign mul_sum2_input_payload_roundMode = mul_sum1_output_rData_roundMode; - assign mul_sum2_input_payload_exp = mul_sum1_output_rData_exp; - assign mul_sum2_input_payload_muls2_0 = mul_sum1_output_rData_muls2_0; - assign mul_sum2_input_payload_muls2_1 = mul_sum1_output_rData_muls2_1; - assign mul_sum2_input_payload_mulC2 = mul_sum1_output_rData_mulC2; - assign mul_sum2_sum = (mul_sum2_input_payload_mulC2 + _zz_mul_sum2_sum); - assign mul_sum2_input_fire = (mul_sum2_input_valid && mul_sum2_input_ready); - assign when_FpuCore_l221_1 = (mul_sum2_input_fire && 1'b1); - assign mul_sum2_isCommited = commitLogic_0_mul_notEmpty; - assign _zz_mul_sum2_input_ready = (! (! mul_sum2_isCommited)); - assign mul_sum2_input_ready = (mul_sum2_output_ready && _zz_mul_sum2_input_ready); - assign mul_sum2_output_valid = (mul_sum2_input_valid && _zz_mul_sum2_input_ready); - assign mul_sum2_output_payload_rs1_mantissa = mul_sum2_input_payload_rs1_mantissa; - assign mul_sum2_output_payload_rs1_exponent = mul_sum2_input_payload_rs1_exponent; - assign mul_sum2_output_payload_rs1_sign = mul_sum2_input_payload_rs1_sign; - assign mul_sum2_output_payload_rs1_special = mul_sum2_input_payload_rs1_special; - assign mul_sum2_output_payload_rs2_mantissa = mul_sum2_input_payload_rs2_mantissa; - assign mul_sum2_output_payload_rs2_exponent = mul_sum2_input_payload_rs2_exponent; - assign mul_sum2_output_payload_rs2_sign = mul_sum2_input_payload_rs2_sign; - assign mul_sum2_output_payload_rs2_special = mul_sum2_input_payload_rs2_special; - assign mul_sum2_output_payload_rs3_mantissa = mul_sum2_input_payload_rs3_mantissa; - assign mul_sum2_output_payload_rs3_exponent = mul_sum2_input_payload_rs3_exponent; - assign mul_sum2_output_payload_rs3_sign = mul_sum2_input_payload_rs3_sign; - assign mul_sum2_output_payload_rs3_special = mul_sum2_input_payload_rs3_special; - assign mul_sum2_output_payload_rd = mul_sum2_input_payload_rd; - assign mul_sum2_output_payload_add = mul_sum2_input_payload_add; - assign mul_sum2_output_payload_divSqrt = mul_sum2_input_payload_divSqrt; - assign mul_sum2_output_payload_msb1 = mul_sum2_input_payload_msb1; - assign mul_sum2_output_payload_msb2 = mul_sum2_input_payload_msb2; - assign mul_sum2_output_payload_roundMode = mul_sum2_input_payload_roundMode; - assign mul_sum2_output_payload_exp = mul_sum2_input_payload_exp; - assign mul_sum2_output_payload_mulC = mul_sum2_sum; - always @(*) begin - mul_sum2_output_ready = mul_norm_input_ready; - if(when_Stream_l368_10) begin - mul_sum2_output_ready = 1'b1; - end - end - - assign when_Stream_l368_10 = (! mul_norm_input_valid); - assign mul_norm_input_valid = mul_sum2_output_rValid; - assign mul_norm_input_payload_rs1_mantissa = mul_sum2_output_rData_rs1_mantissa; - assign mul_norm_input_payload_rs1_exponent = mul_sum2_output_rData_rs1_exponent; - assign mul_norm_input_payload_rs1_sign = mul_sum2_output_rData_rs1_sign; - assign mul_norm_input_payload_rs1_special = mul_sum2_output_rData_rs1_special; - assign mul_norm_input_payload_rs2_mantissa = mul_sum2_output_rData_rs2_mantissa; - assign mul_norm_input_payload_rs2_exponent = mul_sum2_output_rData_rs2_exponent; - assign mul_norm_input_payload_rs2_sign = mul_sum2_output_rData_rs2_sign; - assign mul_norm_input_payload_rs2_special = mul_sum2_output_rData_rs2_special; - assign mul_norm_input_payload_rs3_mantissa = mul_sum2_output_rData_rs3_mantissa; - assign mul_norm_input_payload_rs3_exponent = mul_sum2_output_rData_rs3_exponent; - assign mul_norm_input_payload_rs3_sign = mul_sum2_output_rData_rs3_sign; - assign mul_norm_input_payload_rs3_special = mul_sum2_output_rData_rs3_special; - assign mul_norm_input_payload_rd = mul_sum2_output_rData_rd; - assign mul_norm_input_payload_add = mul_sum2_output_rData_add; - assign mul_norm_input_payload_divSqrt = mul_sum2_output_rData_divSqrt; - assign mul_norm_input_payload_msb1 = mul_sum2_output_rData_msb1; - assign mul_norm_input_payload_msb2 = mul_sum2_output_rData_msb2; - assign mul_norm_input_payload_roundMode = mul_sum2_output_rData_roundMode; - assign mul_norm_input_payload_exp = mul_sum2_output_rData_exp; - assign mul_norm_input_payload_mulC = mul_sum2_output_rData_mulC; - assign mul_norm_mulHigh = mul_norm_input_payload_mulC[47 : 22]; - assign mul_norm_mulLow = mul_norm_input_payload_mulC[21 : 0]; - always @(*) begin - mul_norm_scrap = (mul_norm_mulLow != 22'h0); - if(when_FpuCore_l967) begin - mul_norm_scrap = 1'b1; - end - end - - assign mul_norm_needShift = mul_norm_mulHigh[25]; - assign mul_norm_exp = (mul_norm_input_payload_exp + _zz_mul_norm_exp); - assign mul_norm_man = (mul_norm_needShift ? mul_norm_mulHigh[24 : 1] : mul_norm_mulHigh[23 : 0]); - assign when_FpuCore_l967 = (mul_norm_needShift && mul_norm_mulHigh[0]); - assign mul_norm_forceZero = ((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b00)) || (mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b00))); - assign mul_norm_underflowThreshold = 9'h167; - assign mul_norm_underflowExp = 7'h67; - assign mul_norm_forceUnderflow = (mul_norm_exp < _zz_mul_norm_forceUnderflow); - assign mul_norm_forceOverflow = ((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b01)) || (mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b01))); - assign mul_norm_infinitynan = (((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b01)) || (mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b01))) && ((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b00)) || (mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b00)))); - assign mul_norm_forceNan = (((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b10)) || (mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b10))) || mul_norm_infinitynan); - assign mul_norm_output_sign = (mul_norm_input_payload_rs1_sign ^ mul_norm_input_payload_rs2_sign); - always @(*) begin - mul_norm_output_exponent = _zz_mul_norm_output_exponent[8:0]; - if(when_FpuCore_l983) begin - mul_norm_output_exponent[8 : 7] = 2'b11; - end - if(mul_norm_forceNan) begin - mul_norm_output_exponent[1 : 0] = 2'b10; - mul_norm_output_exponent[2] = 1'b1; - end else begin - if(mul_norm_forceOverflow) begin - mul_norm_output_exponent[1 : 0] = 2'b01; - end else begin - if(mul_norm_forceZero) begin - mul_norm_output_exponent[1 : 0] = 2'b00; - end else begin - if(mul_norm_forceUnderflow) begin - mul_norm_output_exponent = {2'd0, mul_norm_underflowExp}; - end - end - end - end - end - - always @(*) begin - mul_norm_output_mantissa = mul_norm_man; - if(mul_norm_forceNan) begin - mul_norm_output_mantissa[23] = 1'b1; - end - end - - always @(*) begin - mul_norm_output_special = 1'b0; - if(mul_norm_forceNan) begin - mul_norm_output_special = 1'b1; - end else begin - if(mul_norm_forceOverflow) begin - mul_norm_output_special = 1'b1; - end else begin - if(mul_norm_forceZero) begin - mul_norm_output_special = 1'b1; - end - end - end - end - - always @(*) begin - mul_norm_NV = 1'b0; - if(mul_norm_forceNan) begin - if(when_FpuCore_l987) begin - mul_norm_NV = 1'b1; - end - end - end - - assign when_FpuCore_l983 = (3'b101 <= mul_norm_exp[9 : 7]); - assign when_FpuCore_l987 = ((mul_norm_infinitynan || ((mul_norm_input_payload_rs1_special && (mul_norm_input_payload_rs1_exponent[1 : 0] == 2'b10)) && (! mul_norm_input_payload_rs1_mantissa[22]))) || ((mul_norm_input_payload_rs2_special && (mul_norm_input_payload_rs2_exponent[1 : 0] == 2'b10)) && (! mul_norm_input_payload_rs2_mantissa[22]))); - assign mul_result_notMul_output_valid = (mul_norm_input_valid && mul_norm_input_payload_divSqrt); - assign mul_result_notMul_output_payload = mul_norm_input_payload_mulC[46 : 23]; - assign mul_result_output_valid = ((mul_norm_input_valid && (! mul_norm_input_payload_add)) && (! mul_norm_input_payload_divSqrt)); - assign mul_result_output_payload_rd = mul_norm_input_payload_rd; - assign mul_result_output_payload_roundMode = mul_norm_input_payload_roundMode; - assign mul_result_output_payload_scrap = mul_norm_scrap; - assign mul_result_output_payload_value_mantissa = mul_norm_output_mantissa; - assign mul_result_output_payload_value_exponent = mul_norm_output_exponent; - assign mul_result_output_payload_value_sign = mul_norm_output_sign; - assign mul_result_output_payload_value_special = mul_norm_output_special; - assign mul_result_output_payload_NV = mul_norm_NV; - assign mul_result_output_payload_DZ = 1'b0; - always @(*) begin - mul_result_mulToAdd_ready = mul_result_mulToAdd_m2sPipe_ready; - if(when_Stream_l368_11) begin - mul_result_mulToAdd_ready = 1'b1; - end - end - - assign when_Stream_l368_11 = (! mul_result_mulToAdd_m2sPipe_valid); - assign mul_result_mulToAdd_m2sPipe_valid = mul_result_mulToAdd_rValid; - assign mul_result_mulToAdd_m2sPipe_payload_rs1_mantissa = mul_result_mulToAdd_rData_rs1_mantissa; - assign mul_result_mulToAdd_m2sPipe_payload_rs1_exponent = mul_result_mulToAdd_rData_rs1_exponent; - assign mul_result_mulToAdd_m2sPipe_payload_rs1_sign = mul_result_mulToAdd_rData_rs1_sign; - assign mul_result_mulToAdd_m2sPipe_payload_rs1_special = mul_result_mulToAdd_rData_rs1_special; - assign mul_result_mulToAdd_m2sPipe_payload_rs2_mantissa = mul_result_mulToAdd_rData_rs2_mantissa; - assign mul_result_mulToAdd_m2sPipe_payload_rs2_exponent = mul_result_mulToAdd_rData_rs2_exponent; - assign mul_result_mulToAdd_m2sPipe_payload_rs2_sign = mul_result_mulToAdd_rData_rs2_sign; - assign mul_result_mulToAdd_m2sPipe_payload_rs2_special = mul_result_mulToAdd_rData_rs2_special; - assign mul_result_mulToAdd_m2sPipe_payload_rd = mul_result_mulToAdd_rData_rd; - assign mul_result_mulToAdd_m2sPipe_payload_roundMode = mul_result_mulToAdd_rData_roundMode; - assign mul_result_mulToAdd_m2sPipe_payload_needCommit = mul_result_mulToAdd_rData_needCommit; - assign decode_mulToAdd_valid = mul_result_mulToAdd_m2sPipe_valid; - assign mul_result_mulToAdd_m2sPipe_ready = decode_mulToAdd_ready; - assign decode_mulToAdd_payload_rs1_mantissa = mul_result_mulToAdd_m2sPipe_payload_rs1_mantissa; - assign decode_mulToAdd_payload_rs1_exponent = mul_result_mulToAdd_m2sPipe_payload_rs1_exponent; - assign decode_mulToAdd_payload_rs1_sign = mul_result_mulToAdd_m2sPipe_payload_rs1_sign; - assign decode_mulToAdd_payload_rs1_special = mul_result_mulToAdd_m2sPipe_payload_rs1_special; - assign decode_mulToAdd_payload_rs2_mantissa = mul_result_mulToAdd_m2sPipe_payload_rs2_mantissa; - assign decode_mulToAdd_payload_rs2_exponent = mul_result_mulToAdd_m2sPipe_payload_rs2_exponent; - assign decode_mulToAdd_payload_rs2_sign = mul_result_mulToAdd_m2sPipe_payload_rs2_sign; - assign decode_mulToAdd_payload_rs2_special = mul_result_mulToAdd_m2sPipe_payload_rs2_special; - assign decode_mulToAdd_payload_rd = mul_result_mulToAdd_m2sPipe_payload_rd; - assign decode_mulToAdd_payload_roundMode = mul_result_mulToAdd_m2sPipe_payload_roundMode; - assign decode_mulToAdd_payload_needCommit = mul_result_mulToAdd_m2sPipe_payload_needCommit; - assign mul_result_mulToAdd_valid = (mul_norm_input_valid && mul_norm_input_payload_add); - always @(*) begin - mul_result_mulToAdd_payload_rs1_mantissa = {mul_norm_output_mantissa,mul_norm_scrap}; - if(mul_norm_NV) begin - mul_result_mulToAdd_payload_rs1_mantissa[24] = 1'b0; - end - end - - assign mul_result_mulToAdd_payload_rs1_exponent = mul_norm_output_exponent; - assign mul_result_mulToAdd_payload_rs1_sign = mul_norm_output_sign; - assign mul_result_mulToAdd_payload_rs1_special = mul_norm_output_special; - assign mul_result_mulToAdd_payload_rs2_exponent = mul_norm_input_payload_rs3_exponent; - assign mul_result_mulToAdd_payload_rs2_sign = mul_norm_input_payload_rs3_sign; - assign mul_result_mulToAdd_payload_rs2_special = mul_norm_input_payload_rs3_special; - assign mul_result_mulToAdd_payload_rs2_mantissa = ({2'd0,mul_norm_input_payload_rs3_mantissa} <<< 2); - assign mul_result_mulToAdd_payload_rd = mul_norm_input_payload_rd; - assign mul_result_mulToAdd_payload_roundMode = mul_norm_input_payload_roundMode; - assign mul_result_mulToAdd_payload_needCommit = 1'b0; - assign mul_norm_input_ready = ((mul_norm_input_payload_add ? mul_result_mulToAdd_ready : mul_result_output_ready) || mul_norm_input_payload_divSqrt); - assign div_input_fire = (div_input_valid && div_input_ready); - assign decode_div_ready = (! decode_div_rValid); - assign div_input_valid = decode_div_rValid; - assign div_input_payload_rs1_mantissa = decode_div_rData_rs1_mantissa; - assign div_input_payload_rs1_exponent = decode_div_rData_rs1_exponent; - assign div_input_payload_rs1_sign = decode_div_rData_rs1_sign; - assign div_input_payload_rs1_special = decode_div_rData_rs1_special; - assign div_input_payload_rs2_mantissa = decode_div_rData_rs2_mantissa; - assign div_input_payload_rs2_exponent = decode_div_rData_rs2_exponent; - assign div_input_payload_rs2_sign = decode_div_rData_rs2_sign; - assign div_input_payload_rs2_special = decode_div_rData_rs2_special; - assign div_input_payload_rd = decode_div_rData_rd; - assign div_input_payload_roundMode = decode_div_rData_roundMode; - always @(*) begin - div_haltIt = 1'b1; - if(div_divider_io_output_valid) begin - div_haltIt = 1'b0; - end - end - - assign div_input_fire_1 = (div_input_valid && div_input_ready); - assign when_FpuCore_l221_2 = (div_input_fire_1 && 1'b1); - assign _zz_div_input_ready = (! (div_haltIt || (! div_isCommited))); - assign div_input_ready = (div_output_ready && _zz_div_input_ready); - assign div_output_valid = (div_input_valid && _zz_div_input_ready); - assign div_divider_io_input_payload_a = ({1'd0,div_input_payload_rs1_mantissa} <<< 1); - assign div_divider_io_input_payload_b = ({1'd0,div_input_payload_rs2_mantissa} <<< 1); - assign div_dividerResult = (div_divider_io_output_payload_result >>> 1); - assign div_dividerScrap = ((div_divider_io_output_payload_remain != 25'h0) || (div_divider_io_output_payload_result[0 : 0] != 1'b0)); - assign div_divider_io_input_fire = (div_divider_io_input_valid && div_divider_io_input_ready); - assign when_FpuCore_l1056 = (! div_haltIt); - assign div_divider_io_input_valid = (div_input_valid && (! div_cmdSent)); - assign div_output_payload_rd = div_input_payload_rd; - assign div_output_payload_roundMode = div_input_payload_roundMode; - assign div_needShift = (! div_dividerResult[25]); - assign div_mantissa = (div_needShift ? div_dividerResult[23 : 0] : div_dividerResult[24 : 1]); - assign div_scrap = (div_dividerScrap || ((! div_needShift) && div_dividerResult[0])); - assign div_exponent = (_zz_div_exponent - _zz_div_exponent_4); - always @(*) begin - div_output_payload_value_special = 1'b0; - if(div_forceNan) begin - div_output_payload_value_special = 1'b1; - end else begin - if(div_forceOverflow) begin - div_output_payload_value_special = 1'b1; - end else begin - if(div_forceZero) begin - div_output_payload_value_special = 1'b1; - end - end - end - end - - assign div_output_payload_value_sign = (div_input_payload_rs1_sign ^ div_input_payload_rs2_sign); - always @(*) begin - div_output_payload_value_exponent = div_exponent[8:0]; - if(when_FpuCore_l1072) begin - div_output_payload_value_exponent[8 : 6] = 3'b111; - end - if(when_FpuCore_l1089) begin - div_output_payload_value_exponent[8 : 7] = 2'b11; - end - if(div_forceNan) begin - div_output_payload_value_exponent[1 : 0] = 2'b10; - div_output_payload_value_exponent[2] = 1'b1; - end else begin - if(div_forceOverflow) begin - div_output_payload_value_exponent[1 : 0] = 2'b01; - end else begin - if(div_forceZero) begin - div_output_payload_value_exponent[1 : 0] = 2'b00; - end else begin - if(div_forceUnderflow) begin - div_output_payload_value_exponent = div_underflowExp[8:0]; - end - end - end - end - end - - always @(*) begin - div_output_payload_value_mantissa = div_mantissa; - if(div_forceNan) begin - div_output_payload_value_mantissa[23] = 1'b1; - end - end - - assign div_output_payload_scrap = div_scrap; - assign when_FpuCore_l1072 = (div_exponent[10 : 9] == 2'b11); - assign div_underflowThreshold = 11'h468; - assign div_underflowExp = 11'h467; - assign div_forceUnderflow = (div_exponent < div_underflowThreshold); - assign div_forceOverflow = ((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b01)) || (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b00))); - assign div_infinitynan = (((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b00)) && (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b00))) || ((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b01)) && (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b01)))); - assign div_forceNan = (((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b10)) || (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b10))) || div_infinitynan); - assign div_forceZero = ((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b00)) || (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b01))); - always @(*) begin - div_output_payload_NV = 1'b0; - if(div_forceNan) begin - if(when_FpuCore_l1093) begin - div_output_payload_NV = 1'b1; - end - end - end - - assign div_output_payload_DZ = (((! div_forceNan) && (! (div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b01)))) && (div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b00))); - assign when_FpuCore_l1089 = (div_exponent[10 : 8] == 3'b111); - assign when_FpuCore_l1093 = ((div_infinitynan || ((div_input_payload_rs1_special && (div_input_payload_rs1_exponent[1 : 0] == 2'b10)) && (! div_input_payload_rs1_mantissa[22]))) || ((div_input_payload_rs2_special && (div_input_payload_rs2_exponent[1 : 0] == 2'b10)) && (! div_input_payload_rs2_mantissa[22]))); - assign sqrt_input_fire = (sqrt_input_valid && sqrt_input_ready); - assign decode_sqrt_ready = (! decode_sqrt_rValid); - assign sqrt_input_valid = decode_sqrt_rValid; - assign sqrt_input_payload_rs1_mantissa = decode_sqrt_rData_rs1_mantissa; - assign sqrt_input_payload_rs1_exponent = decode_sqrt_rData_rs1_exponent; - assign sqrt_input_payload_rs1_sign = decode_sqrt_rData_rs1_sign; - assign sqrt_input_payload_rs1_special = decode_sqrt_rData_rs1_special; - assign sqrt_input_payload_rd = decode_sqrt_rData_rd; - assign sqrt_input_payload_roundMode = decode_sqrt_rData_roundMode; - always @(*) begin - sqrt_haltIt = 1'b1; - if(sqrt_sqrt_io_output_valid) begin - sqrt_haltIt = 1'b0; - end - end - - assign sqrt_input_fire_1 = (sqrt_input_valid && sqrt_input_ready); - assign when_FpuCore_l221_3 = (sqrt_input_fire_1 && 1'b1); - assign _zz_sqrt_input_ready = (! (sqrt_haltIt || (! sqrt_isCommited))); - assign sqrt_input_ready = (sqrt_output_ready && _zz_sqrt_input_ready); - assign sqrt_output_valid = (sqrt_input_valid && _zz_sqrt_input_ready); - assign sqrt_needShift = (! sqrt_input_payload_rs1_exponent[0]); - assign sqrt_sqrt_io_input_payload_a = (sqrt_needShift ? {{1'b1,sqrt_input_payload_rs1_mantissa},1'b0} : {2'b01,sqrt_input_payload_rs1_mantissa}); - assign sqrt_sqrt_io_input_fire = (sqrt_sqrt_io_input_valid && sqrt_sqrt_io_input_ready); - assign when_FpuCore_l1118 = (! sqrt_haltIt); - assign sqrt_sqrt_io_input_valid = (sqrt_input_valid && (! sqrt_cmdSent)); - assign sqrt_output_payload_rd = sqrt_input_payload_rd; - assign sqrt_output_payload_roundMode = sqrt_input_payload_roundMode; - assign sqrt_scrap = (sqrt_sqrt_io_output_payload_remain != 28'h0); - always @(*) begin - sqrt_output_payload_value_special = 1'b0; - if(when_FpuCore_l1137) begin - sqrt_output_payload_value_special = 1'b1; - end - if(sqrt_negative) begin - sqrt_output_payload_value_special = 1'b1; - end - if(when_FpuCore_l1144) begin - sqrt_output_payload_value_special = 1'b1; - end - if(when_FpuCore_l1148) begin - sqrt_output_payload_value_special = 1'b1; - end - end - - assign sqrt_output_payload_value_sign = sqrt_input_payload_rs1_sign; - always @(*) begin - sqrt_output_payload_value_exponent = sqrt_exponent; - if(when_FpuCore_l1137) begin - sqrt_output_payload_value_exponent[1 : 0] = 2'b01; - end - if(sqrt_negative) begin - sqrt_output_payload_value_exponent[1 : 0] = 2'b10; - sqrt_output_payload_value_exponent[2] = 1'b1; - end - if(when_FpuCore_l1144) begin - sqrt_output_payload_value_exponent[1 : 0] = 2'b10; - sqrt_output_payload_value_exponent[2] = 1'b1; - end - if(when_FpuCore_l1148) begin - sqrt_output_payload_value_exponent[1 : 0] = 2'b00; - end - end - - always @(*) begin - sqrt_output_payload_value_mantissa = sqrt_sqrt_io_output_payload_result; - if(sqrt_negative) begin - sqrt_output_payload_value_mantissa[23] = 1'b1; - end - if(when_FpuCore_l1144) begin - sqrt_output_payload_value_mantissa[23] = 1'b1; - end - end - - assign sqrt_output_payload_scrap = sqrt_scrap; - always @(*) begin - sqrt_output_payload_NV = 1'b0; - if(sqrt_negative) begin - sqrt_output_payload_NV = 1'b1; - end - if(when_FpuCore_l1144) begin - sqrt_output_payload_NV = (! sqrt_input_payload_rs1_mantissa[22]); - end - end - - assign sqrt_output_payload_DZ = 1'b0; - assign sqrt_negative = (((! (sqrt_input_payload_rs1_special && (sqrt_input_payload_rs1_exponent[1 : 0] == 2'b10))) && (! (sqrt_input_payload_rs1_special && (sqrt_input_payload_rs1_exponent[1 : 0] == 2'b00)))) && sqrt_input_payload_rs1_sign); - assign when_FpuCore_l1137 = (sqrt_input_payload_rs1_special && (sqrt_input_payload_rs1_exponent[1 : 0] == 2'b01)); - assign when_FpuCore_l1144 = (sqrt_input_payload_rs1_special && (sqrt_input_payload_rs1_exponent[1 : 0] == 2'b10)); - assign when_FpuCore_l1148 = (sqrt_input_payload_rs1_special && (sqrt_input_payload_rs1_exponent[1 : 0] == 2'b00)); - assign add_preShifter_input_valid = decode_add_valid; - assign decode_add_ready = add_preShifter_input_ready; - assign add_preShifter_input_payload_rs1_mantissa = decode_add_payload_rs1_mantissa; - assign add_preShifter_input_payload_rs1_exponent = decode_add_payload_rs1_exponent; - assign add_preShifter_input_payload_rs1_sign = decode_add_payload_rs1_sign; - assign add_preShifter_input_payload_rs1_special = decode_add_payload_rs1_special; - assign add_preShifter_input_payload_rs2_mantissa = decode_add_payload_rs2_mantissa; - assign add_preShifter_input_payload_rs2_exponent = decode_add_payload_rs2_exponent; - assign add_preShifter_input_payload_rs2_sign = decode_add_payload_rs2_sign; - assign add_preShifter_input_payload_rs2_special = decode_add_payload_rs2_special; - assign add_preShifter_input_payload_rd = decode_add_payload_rd; - assign add_preShifter_input_payload_roundMode = decode_add_payload_roundMode; - assign add_preShifter_input_payload_needCommit = decode_add_payload_needCommit; - assign add_preShifter_output_valid = add_preShifter_input_valid; - assign add_preShifter_input_ready = add_preShifter_output_ready; - assign add_preShifter_exp21 = ({1'b0,add_preShifter_input_payload_rs2_exponent} - {1'b0,add_preShifter_input_payload_rs1_exponent}); - assign add_preShifter_rs1ExponentBigger = ((add_preShifter_exp21[9] || (add_preShifter_input_payload_rs2_special && (add_preShifter_input_payload_rs2_exponent[1 : 0] == 2'b00))) && (! (add_preShifter_input_payload_rs1_special && (add_preShifter_input_payload_rs1_exponent[1 : 0] == 2'b00)))); - assign add_preShifter_rs1ExponentEqual = (add_preShifter_input_payload_rs1_exponent == add_preShifter_input_payload_rs2_exponent); - assign add_preShifter_rs1MantissaBigger = (add_preShifter_input_payload_rs2_mantissa < add_preShifter_input_payload_rs1_mantissa); - assign add_preShifter_absRs1Bigger = ((((add_preShifter_rs1ExponentBigger || (add_preShifter_rs1ExponentEqual && add_preShifter_rs1MantissaBigger)) && (! (add_preShifter_input_payload_rs1_special && (add_preShifter_input_payload_rs1_exponent[1 : 0] == 2'b00)))) || (add_preShifter_input_payload_rs1_special && (add_preShifter_input_payload_rs1_exponent[1 : 0] == 2'b01))) && (! (add_preShifter_input_payload_rs2_special && (add_preShifter_input_payload_rs2_exponent[1 : 0] == 2'b01)))); - assign add_preShifter_output_payload_rs1_mantissa = add_preShifter_input_payload_rs1_mantissa; - assign add_preShifter_output_payload_rs1_exponent = add_preShifter_input_payload_rs1_exponent; - assign add_preShifter_output_payload_rs1_sign = add_preShifter_input_payload_rs1_sign; - assign add_preShifter_output_payload_rs1_special = add_preShifter_input_payload_rs1_special; - assign add_preShifter_output_payload_rs2_mantissa = add_preShifter_input_payload_rs2_mantissa; - assign add_preShifter_output_payload_rs2_exponent = add_preShifter_input_payload_rs2_exponent; - assign add_preShifter_output_payload_rs2_sign = add_preShifter_input_payload_rs2_sign; - assign add_preShifter_output_payload_rs2_special = add_preShifter_input_payload_rs2_special; - assign add_preShifter_output_payload_rd = add_preShifter_input_payload_rd; - assign add_preShifter_output_payload_roundMode = add_preShifter_input_payload_roundMode; - assign add_preShifter_output_payload_needCommit = add_preShifter_input_payload_needCommit; - assign add_preShifter_output_payload_absRs1Bigger = add_preShifter_absRs1Bigger; - assign add_preShifter_output_payload_rs1ExponentBigger = add_preShifter_rs1ExponentBigger; - always @(*) begin - add_preShifter_output_ready = add_shifter_input_ready; - if(when_Stream_l368_12) begin - add_preShifter_output_ready = 1'b1; - end - end - - assign when_Stream_l368_12 = (! add_shifter_input_valid); - assign add_shifter_input_valid = add_preShifter_output_rValid; - assign add_shifter_input_payload_rs1_mantissa = add_preShifter_output_rData_rs1_mantissa; - assign add_shifter_input_payload_rs1_exponent = add_preShifter_output_rData_rs1_exponent; - assign add_shifter_input_payload_rs1_sign = add_preShifter_output_rData_rs1_sign; - assign add_shifter_input_payload_rs1_special = add_preShifter_output_rData_rs1_special; - assign add_shifter_input_payload_rs2_mantissa = add_preShifter_output_rData_rs2_mantissa; - assign add_shifter_input_payload_rs2_exponent = add_preShifter_output_rData_rs2_exponent; - assign add_shifter_input_payload_rs2_sign = add_preShifter_output_rData_rs2_sign; - assign add_shifter_input_payload_rs2_special = add_preShifter_output_rData_rs2_special; - assign add_shifter_input_payload_rd = add_preShifter_output_rData_rd; - assign add_shifter_input_payload_roundMode = add_preShifter_output_rData_roundMode; - assign add_shifter_input_payload_needCommit = add_preShifter_output_rData_needCommit; - assign add_shifter_input_payload_absRs1Bigger = add_preShifter_output_rData_absRs1Bigger; - assign add_shifter_input_payload_rs1ExponentBigger = add_preShifter_output_rData_rs1ExponentBigger; - assign add_shifter_output_valid = add_shifter_input_valid; - assign add_shifter_input_ready = add_shifter_output_ready; - assign add_shifter_output_payload_rs1_mantissa = add_shifter_input_payload_rs1_mantissa; - assign add_shifter_output_payload_rs1_exponent = add_shifter_input_payload_rs1_exponent; - assign add_shifter_output_payload_rs1_sign = add_shifter_input_payload_rs1_sign; - assign add_shifter_output_payload_rs1_special = add_shifter_input_payload_rs1_special; - assign add_shifter_output_payload_rs2_mantissa = add_shifter_input_payload_rs2_mantissa; - assign add_shifter_output_payload_rs2_exponent = add_shifter_input_payload_rs2_exponent; - assign add_shifter_output_payload_rs2_sign = add_shifter_input_payload_rs2_sign; - assign add_shifter_output_payload_rs2_special = add_shifter_input_payload_rs2_special; - assign add_shifter_output_payload_rd = add_shifter_input_payload_rd; - assign add_shifter_output_payload_roundMode = add_shifter_input_payload_roundMode; - assign add_shifter_output_payload_needCommit = add_shifter_input_payload_needCommit; - assign add_shifter_exp21 = ({1'b0,add_shifter_input_payload_rs2_exponent} - {1'b0,add_shifter_input_payload_rs1_exponent}); - assign _zz_add_shifter_shiftBy = add_shifter_exp21; - assign add_shifter_shiftBy = (_zz_add_shifter_shiftBy_1 + _zz_add_shifter_shiftBy_3); - assign add_shifter_shiftOverflow = (10'h01a <= add_shifter_shiftBy); - assign add_shifter_passThrough = ((add_shifter_shiftOverflow || (add_shifter_input_payload_rs1_special && (add_shifter_input_payload_rs1_exponent[1 : 0] == 2'b00))) || (add_shifter_input_payload_rs2_special && (add_shifter_input_payload_rs2_exponent[1 : 0] == 2'b00))); - assign add_shifter_xySign = (add_shifter_input_payload_absRs1Bigger ? add_shifter_input_payload_rs1_sign : add_shifter_input_payload_rs2_sign); - assign add_shifter_output_payload_xSign = (add_shifter_xySign ^ (add_shifter_input_payload_rs1ExponentBigger ? add_shifter_input_payload_rs1_sign : add_shifter_input_payload_rs2_sign)); - assign add_shifter_output_payload_ySign = (add_shifter_xySign ^ (add_shifter_input_payload_rs1ExponentBigger ? add_shifter_input_payload_rs2_sign : add_shifter_input_payload_rs1_sign)); - assign add_shifter_xMantissa = {1'b1,(add_shifter_input_payload_rs1ExponentBigger ? add_shifter_input_payload_rs1_mantissa : add_shifter_input_payload_rs2_mantissa)}; - assign add_shifter_yMantissaUnshifted = {1'b1,(add_shifter_input_payload_rs1ExponentBigger ? add_shifter_input_payload_rs2_mantissa : add_shifter_input_payload_rs1_mantissa)}; - assign add_shifter_yMantissa = add_shifter_yMantissaUnshifted; - always @(*) begin - add_shifter_roundingScrap = 1'b0; - if(when_FpuCore_l1419) begin - add_shifter_roundingScrap = 1'b1; - end - if(when_FpuCore_l1419_1) begin - add_shifter_roundingScrap = 1'b1; - end - if(when_FpuCore_l1419_2) begin - add_shifter_roundingScrap = 1'b1; - end - if(when_FpuCore_l1419_3) begin - add_shifter_roundingScrap = 1'b1; - end - if(when_FpuCore_l1419_4) begin - add_shifter_roundingScrap = 1'b1; - end - if(add_shifter_shiftOverflow) begin - add_shifter_roundingScrap = 1'b1; - end - if(when_FpuCore_l1424) begin - add_shifter_roundingScrap = 1'b0; - end - end - - assign when_FpuCore_l1419 = (add_shifter_shiftBy[4] && (add_shifter_yMantissa[15 : 0] != 16'h0)); - assign when_FpuCore_l1419_1 = (add_shifter_shiftBy[3] && (add_shifter_yMantissa_1[7 : 0] != 8'h0)); - assign when_FpuCore_l1419_2 = (add_shifter_shiftBy[2] && (add_shifter_yMantissa_2[3 : 0] != 4'b0000)); - assign when_FpuCore_l1419_3 = (add_shifter_shiftBy[1] && (add_shifter_yMantissa_3[1 : 0] != 2'b00)); - assign when_FpuCore_l1419_4 = (add_shifter_shiftBy[0] && (add_shifter_yMantissa_4[0 : 0] != 1'b0)); - assign when_FpuCore_l1424 = (add_shifter_input_payload_rs1_special || add_shifter_input_payload_rs2_special); - assign add_shifter_output_payload_xyExponent = (add_shifter_input_payload_rs1ExponentBigger ? add_shifter_input_payload_rs1_exponent : add_shifter_input_payload_rs2_exponent); - assign add_shifter_output_payload_xMantissa = add_shifter_xMantissa; - assign add_shifter_output_payload_yMantissa = add_shifter_yMantissa_5; - assign add_shifter_output_payload_xySign = add_shifter_xySign; - assign add_shifter_output_payload_roundingScrap = add_shifter_roundingScrap; - always @(*) begin - add_shifter_output_ready = add_math_input_ready; - if(when_Stream_l368_13) begin - add_shifter_output_ready = 1'b1; - end - end - - assign when_Stream_l368_13 = (! add_math_input_valid); - assign add_math_input_valid = add_shifter_output_rValid; - assign add_math_input_payload_rs1_mantissa = add_shifter_output_rData_rs1_mantissa; - assign add_math_input_payload_rs1_exponent = add_shifter_output_rData_rs1_exponent; - assign add_math_input_payload_rs1_sign = add_shifter_output_rData_rs1_sign; - assign add_math_input_payload_rs1_special = add_shifter_output_rData_rs1_special; - assign add_math_input_payload_rs2_mantissa = add_shifter_output_rData_rs2_mantissa; - assign add_math_input_payload_rs2_exponent = add_shifter_output_rData_rs2_exponent; - assign add_math_input_payload_rs2_sign = add_shifter_output_rData_rs2_sign; - assign add_math_input_payload_rs2_special = add_shifter_output_rData_rs2_special; - assign add_math_input_payload_rd = add_shifter_output_rData_rd; - assign add_math_input_payload_roundMode = add_shifter_output_rData_roundMode; - assign add_math_input_payload_needCommit = add_shifter_output_rData_needCommit; - assign add_math_input_payload_xSign = add_shifter_output_rData_xSign; - assign add_math_input_payload_ySign = add_shifter_output_rData_ySign; - assign add_math_input_payload_xMantissa = add_shifter_output_rData_xMantissa; - assign add_math_input_payload_yMantissa = add_shifter_output_rData_yMantissa; - assign add_math_input_payload_xyExponent = add_shifter_output_rData_xyExponent; - assign add_math_input_payload_xySign = add_shifter_output_rData_xySign; - assign add_math_input_payload_roundingScrap = add_shifter_output_rData_roundingScrap; - assign add_math_output_valid = add_math_input_valid; - assign add_math_input_ready = add_math_output_ready; - assign add_math_output_payload_rs1_mantissa = add_math_input_payload_rs1_mantissa; - assign add_math_output_payload_rs1_exponent = add_math_input_payload_rs1_exponent; - assign add_math_output_payload_rs1_sign = add_math_input_payload_rs1_sign; - assign add_math_output_payload_rs1_special = add_math_input_payload_rs1_special; - assign add_math_output_payload_rs2_mantissa = add_math_input_payload_rs2_mantissa; - assign add_math_output_payload_rs2_exponent = add_math_input_payload_rs2_exponent; - assign add_math_output_payload_rs2_sign = add_math_input_payload_rs2_sign; - assign add_math_output_payload_rs2_special = add_math_input_payload_rs2_special; - assign add_math_output_payload_rd = add_math_input_payload_rd; - assign add_math_output_payload_roundMode = add_math_input_payload_roundMode; - assign add_math_output_payload_needCommit = add_math_input_payload_needCommit; - assign add_math_output_payload_xSign = add_math_input_payload_xSign; - assign add_math_output_payload_ySign = add_math_input_payload_ySign; - assign add_math_output_payload_xMantissa = add_math_input_payload_xMantissa; - assign add_math_output_payload_yMantissa = add_math_input_payload_yMantissa; - assign add_math_output_payload_xyExponent = add_math_input_payload_xyExponent; - assign add_math_output_payload_xySign = add_math_input_payload_xySign; - assign add_math_output_payload_roundingScrap = add_math_input_payload_roundingScrap; - assign add_math_xSigned = _zz_add_math_xSigned; - assign add_math_ySigned = _zz_add_math_ySigned; - assign add_math_output_payload_xyMantissa = _zz_add_math_output_payload_xyMantissa[26 : 0]; - always @(*) begin - add_math_output_ready = add_oh_input_ready; - if(when_Stream_l368_14) begin - add_math_output_ready = 1'b1; - end - end - - assign when_Stream_l368_14 = (! add_oh_input_valid); - assign add_oh_input_valid = add_math_output_rValid; - assign add_oh_input_payload_rs1_mantissa = add_math_output_rData_rs1_mantissa; - assign add_oh_input_payload_rs1_exponent = add_math_output_rData_rs1_exponent; - assign add_oh_input_payload_rs1_sign = add_math_output_rData_rs1_sign; - assign add_oh_input_payload_rs1_special = add_math_output_rData_rs1_special; - assign add_oh_input_payload_rs2_mantissa = add_math_output_rData_rs2_mantissa; - assign add_oh_input_payload_rs2_exponent = add_math_output_rData_rs2_exponent; - assign add_oh_input_payload_rs2_sign = add_math_output_rData_rs2_sign; - assign add_oh_input_payload_rs2_special = add_math_output_rData_rs2_special; - assign add_oh_input_payload_rd = add_math_output_rData_rd; - assign add_oh_input_payload_roundMode = add_math_output_rData_roundMode; - assign add_oh_input_payload_needCommit = add_math_output_rData_needCommit; - assign add_oh_input_payload_xSign = add_math_output_rData_xSign; - assign add_oh_input_payload_ySign = add_math_output_rData_ySign; - assign add_oh_input_payload_xMantissa = add_math_output_rData_xMantissa; - assign add_oh_input_payload_yMantissa = add_math_output_rData_yMantissa; - assign add_oh_input_payload_xyExponent = add_math_output_rData_xyExponent; - assign add_oh_input_payload_xySign = add_math_output_rData_xySign; - assign add_oh_input_payload_roundingScrap = add_math_output_rData_roundingScrap; - assign add_oh_input_payload_xyMantissa = add_math_output_rData_xyMantissa; - assign add_oh_input_fire = (add_oh_input_valid && add_oh_input_ready); - assign when_FpuCore_l221_4 = ((add_oh_input_fire && add_oh_input_payload_needCommit) && 1'b1); - assign add_oh_isCommited = commitLogic_0_add_notEmpty; - assign _zz_add_oh_input_ready = (! (add_oh_input_payload_needCommit && (! add_oh_isCommited))); - assign add_oh_input_ready = (add_oh_output_ready && _zz_add_oh_input_ready); - assign add_oh_output_valid = (add_oh_input_valid && _zz_add_oh_input_ready); - assign add_oh_output_payload_rs1_mantissa = add_oh_input_payload_rs1_mantissa; - assign add_oh_output_payload_rs1_exponent = add_oh_input_payload_rs1_exponent; - assign add_oh_output_payload_rs1_sign = add_oh_input_payload_rs1_sign; - assign add_oh_output_payload_rs1_special = add_oh_input_payload_rs1_special; - assign add_oh_output_payload_rs2_mantissa = add_oh_input_payload_rs2_mantissa; - assign add_oh_output_payload_rs2_exponent = add_oh_input_payload_rs2_exponent; - assign add_oh_output_payload_rs2_sign = add_oh_input_payload_rs2_sign; - assign add_oh_output_payload_rs2_special = add_oh_input_payload_rs2_special; - assign add_oh_output_payload_rd = add_oh_input_payload_rd; - assign add_oh_output_payload_roundMode = add_oh_input_payload_roundMode; - assign add_oh_output_payload_needCommit = add_oh_input_payload_needCommit; - assign add_oh_output_payload_xSign = add_oh_input_payload_xSign; - assign add_oh_output_payload_ySign = add_oh_input_payload_ySign; - assign add_oh_output_payload_xMantissa = add_oh_input_payload_xMantissa; - assign add_oh_output_payload_yMantissa = add_oh_input_payload_yMantissa; - assign add_oh_output_payload_xyExponent = add_oh_input_payload_xyExponent; - assign add_oh_output_payload_xySign = add_oh_input_payload_xySign; - assign add_oh_output_payload_roundingScrap = add_oh_input_payload_roundingScrap; - assign add_oh_output_payload_xyMantissa = add_oh_input_payload_xyMantissa; - assign _zz_add_oh_shift = {add_oh_output_payload_xyMantissa[0],{add_oh_output_payload_xyMantissa[1],{add_oh_output_payload_xyMantissa[2],{add_oh_output_payload_xyMantissa[3],{add_oh_output_payload_xyMantissa[4],{add_oh_output_payload_xyMantissa[5],{add_oh_output_payload_xyMantissa[6],{add_oh_output_payload_xyMantissa[7],{add_oh_output_payload_xyMantissa[8],{_zz__zz_add_oh_shift,{_zz__zz_add_oh_shift_1,_zz__zz_add_oh_shift_2}}}}}}}}}}}; - assign _zz_add_oh_shift_1 = (_zz_add_oh_shift & (~ _zz__zz_add_oh_shift_1_1)); - assign _zz_add_oh_shift_2 = _zz_add_oh_shift_1[3]; - assign _zz_add_oh_shift_3 = _zz_add_oh_shift_1[5]; - assign _zz_add_oh_shift_4 = _zz_add_oh_shift_1[6]; - assign _zz_add_oh_shift_5 = _zz_add_oh_shift_1[7]; - assign _zz_add_oh_shift_6 = _zz_add_oh_shift_1[9]; - assign _zz_add_oh_shift_7 = _zz_add_oh_shift_1[10]; - assign _zz_add_oh_shift_8 = _zz_add_oh_shift_1[11]; - assign _zz_add_oh_shift_9 = _zz_add_oh_shift_1[12]; - assign _zz_add_oh_shift_10 = _zz_add_oh_shift_1[13]; - assign _zz_add_oh_shift_11 = _zz_add_oh_shift_1[14]; - assign _zz_add_oh_shift_12 = _zz_add_oh_shift_1[15]; - assign _zz_add_oh_shift_13 = _zz_add_oh_shift_1[17]; - assign _zz_add_oh_shift_14 = _zz_add_oh_shift_1[18]; - assign _zz_add_oh_shift_15 = _zz_add_oh_shift_1[19]; - assign _zz_add_oh_shift_16 = _zz_add_oh_shift_1[20]; - assign _zz_add_oh_shift_17 = _zz_add_oh_shift_1[21]; - assign _zz_add_oh_shift_18 = _zz_add_oh_shift_1[22]; - assign _zz_add_oh_shift_19 = _zz_add_oh_shift_1[23]; - assign _zz_add_oh_shift_20 = _zz_add_oh_shift_1[24]; - assign _zz_add_oh_shift_21 = _zz_add_oh_shift_1[25]; - assign _zz_add_oh_shift_22 = _zz_add_oh_shift_1[26]; - assign _zz_add_oh_shift_23 = ((((((((((((_zz_add_oh_shift_1[1] || _zz_add_oh_shift_2) || _zz_add_oh_shift_3) || _zz_add_oh_shift_5) || _zz_add_oh_shift_6) || _zz_add_oh_shift_8) || _zz_add_oh_shift_10) || _zz_add_oh_shift_12) || _zz_add_oh_shift_13) || _zz_add_oh_shift_15) || _zz_add_oh_shift_17) || _zz_add_oh_shift_19) || _zz_add_oh_shift_21); - assign _zz_add_oh_shift_24 = ((((((((((((_zz_add_oh_shift_1[2] || _zz_add_oh_shift_2) || _zz_add_oh_shift_4) || _zz_add_oh_shift_5) || _zz_add_oh_shift_7) || _zz_add_oh_shift_8) || _zz_add_oh_shift_11) || _zz_add_oh_shift_12) || _zz_add_oh_shift_14) || _zz_add_oh_shift_15) || _zz_add_oh_shift_18) || _zz_add_oh_shift_19) || _zz_add_oh_shift_22); - assign _zz_add_oh_shift_25 = (((((((((((_zz_add_oh_shift_1[4] || _zz_add_oh_shift_3) || _zz_add_oh_shift_4) || _zz_add_oh_shift_5) || _zz_add_oh_shift_9) || _zz_add_oh_shift_10) || _zz_add_oh_shift_11) || _zz_add_oh_shift_12) || _zz_add_oh_shift_16) || _zz_add_oh_shift_17) || _zz_add_oh_shift_18) || _zz_add_oh_shift_19); - assign _zz_add_oh_shift_26 = ((((((((((_zz_add_oh_shift_1[8] || _zz_add_oh_shift_6) || _zz_add_oh_shift_7) || _zz_add_oh_shift_8) || _zz_add_oh_shift_9) || _zz_add_oh_shift_10) || _zz_add_oh_shift_11) || _zz_add_oh_shift_12) || _zz_add_oh_shift_20) || _zz_add_oh_shift_21) || _zz_add_oh_shift_22); - assign _zz_add_oh_shift_27 = ((((((((((_zz_add_oh_shift_1[16] || _zz_add_oh_shift_13) || _zz_add_oh_shift_14) || _zz_add_oh_shift_15) || _zz_add_oh_shift_16) || _zz_add_oh_shift_17) || _zz_add_oh_shift_18) || _zz_add_oh_shift_19) || _zz_add_oh_shift_20) || _zz_add_oh_shift_21) || _zz_add_oh_shift_22); - assign add_oh_shift = {_zz_add_oh_shift_27,{_zz_add_oh_shift_26,{_zz_add_oh_shift_25,{_zz_add_oh_shift_24,_zz_add_oh_shift_23}}}}; - assign add_oh_output_payload_shift = add_oh_shift; - always @(*) begin - add_oh_output_ready = add_norm_input_ready; - if(when_Stream_l368_15) begin - add_oh_output_ready = 1'b1; - end - end - - assign when_Stream_l368_15 = (! add_norm_input_valid); - assign add_norm_input_valid = add_oh_output_rValid; - assign add_norm_input_payload_rs1_mantissa = add_oh_output_rData_rs1_mantissa; - assign add_norm_input_payload_rs1_exponent = add_oh_output_rData_rs1_exponent; - assign add_norm_input_payload_rs1_sign = add_oh_output_rData_rs1_sign; - assign add_norm_input_payload_rs1_special = add_oh_output_rData_rs1_special; - assign add_norm_input_payload_rs2_mantissa = add_oh_output_rData_rs2_mantissa; - assign add_norm_input_payload_rs2_exponent = add_oh_output_rData_rs2_exponent; - assign add_norm_input_payload_rs2_sign = add_oh_output_rData_rs2_sign; - assign add_norm_input_payload_rs2_special = add_oh_output_rData_rs2_special; - assign add_norm_input_payload_rd = add_oh_output_rData_rd; - assign add_norm_input_payload_roundMode = add_oh_output_rData_roundMode; - assign add_norm_input_payload_needCommit = add_oh_output_rData_needCommit; - assign add_norm_input_payload_xSign = add_oh_output_rData_xSign; - assign add_norm_input_payload_ySign = add_oh_output_rData_ySign; - assign add_norm_input_payload_xMantissa = add_oh_output_rData_xMantissa; - assign add_norm_input_payload_yMantissa = add_oh_output_rData_yMantissa; - assign add_norm_input_payload_xyExponent = add_oh_output_rData_xyExponent; - assign add_norm_input_payload_xySign = add_oh_output_rData_xySign; - assign add_norm_input_payload_roundingScrap = add_oh_output_rData_roundingScrap; - assign add_norm_input_payload_xyMantissa = add_oh_output_rData_xyMantissa; - assign add_norm_input_payload_shift = add_oh_output_rData_shift; - assign add_norm_output_valid = add_norm_input_valid; - assign add_norm_input_ready = add_norm_output_ready; - assign add_norm_output_payload_rs1_mantissa = add_norm_input_payload_rs1_mantissa; - assign add_norm_output_payload_rs1_exponent = add_norm_input_payload_rs1_exponent; - assign add_norm_output_payload_rs1_sign = add_norm_input_payload_rs1_sign; - assign add_norm_output_payload_rs1_special = add_norm_input_payload_rs1_special; - assign add_norm_output_payload_rs2_mantissa = add_norm_input_payload_rs2_mantissa; - assign add_norm_output_payload_rs2_exponent = add_norm_input_payload_rs2_exponent; - assign add_norm_output_payload_rs2_sign = add_norm_input_payload_rs2_sign; - assign add_norm_output_payload_rs2_special = add_norm_input_payload_rs2_special; - assign add_norm_output_payload_rd = add_norm_input_payload_rd; - assign add_norm_output_payload_roundMode = add_norm_input_payload_roundMode; - assign add_norm_output_payload_needCommit = add_norm_input_payload_needCommit; - assign add_norm_output_payload_xySign = add_norm_input_payload_xySign; - assign add_norm_output_payload_roundingScrap = add_norm_input_payload_roundingScrap; - assign add_norm_output_payload_mantissa = (add_norm_input_payload_xyMantissa <<< add_norm_input_payload_shift); - assign add_norm_output_payload_exponent = (_zz_add_norm_output_payload_exponent + 10'h001); - assign add_norm_output_payload_forceInfinity = ((add_norm_input_payload_rs1_special && (add_norm_input_payload_rs1_exponent[1 : 0] == 2'b01)) || (add_norm_input_payload_rs2_special && (add_norm_input_payload_rs2_exponent[1 : 0] == 2'b01))); - assign add_norm_output_payload_forceZero = ((add_norm_input_payload_xyMantissa == 27'h0) || ((add_norm_input_payload_rs1_special && (add_norm_input_payload_rs1_exponent[1 : 0] == 2'b00)) && (add_norm_input_payload_rs2_special && (add_norm_input_payload_rs2_exponent[1 : 0] == 2'b00)))); - assign add_norm_output_payload_infinityNan = (((add_norm_input_payload_rs1_special && (add_norm_input_payload_rs1_exponent[1 : 0] == 2'b01)) && (add_norm_input_payload_rs2_special && (add_norm_input_payload_rs2_exponent[1 : 0] == 2'b01))) && (add_norm_input_payload_rs1_sign ^ add_norm_input_payload_rs2_sign)); - assign add_norm_output_payload_forceNan = (((add_norm_input_payload_rs1_special && (add_norm_input_payload_rs1_exponent[1 : 0] == 2'b10)) || (add_norm_input_payload_rs2_special && (add_norm_input_payload_rs2_exponent[1 : 0] == 2'b10))) || add_norm_output_payload_infinityNan); - assign add_norm_output_payload_xyMantissaZero = (add_norm_input_payload_xyMantissa == 27'h0); - assign add_result_input_valid = add_norm_output_valid; - assign add_norm_output_ready = add_result_input_ready; - assign add_result_input_payload_rs1_mantissa = add_norm_output_payload_rs1_mantissa; - assign add_result_input_payload_rs1_exponent = add_norm_output_payload_rs1_exponent; - assign add_result_input_payload_rs1_sign = add_norm_output_payload_rs1_sign; - assign add_result_input_payload_rs1_special = add_norm_output_payload_rs1_special; - assign add_result_input_payload_rs2_mantissa = add_norm_output_payload_rs2_mantissa; - assign add_result_input_payload_rs2_exponent = add_norm_output_payload_rs2_exponent; - assign add_result_input_payload_rs2_sign = add_norm_output_payload_rs2_sign; - assign add_result_input_payload_rs2_special = add_norm_output_payload_rs2_special; - assign add_result_input_payload_rd = add_norm_output_payload_rd; - assign add_result_input_payload_roundMode = add_norm_output_payload_roundMode; - assign add_result_input_payload_needCommit = add_norm_output_payload_needCommit; - assign add_result_input_payload_mantissa = add_norm_output_payload_mantissa; - assign add_result_input_payload_exponent = add_norm_output_payload_exponent; - assign add_result_input_payload_infinityNan = add_norm_output_payload_infinityNan; - assign add_result_input_payload_forceNan = add_norm_output_payload_forceNan; - assign add_result_input_payload_forceZero = add_norm_output_payload_forceZero; - assign add_result_input_payload_forceInfinity = add_norm_output_payload_forceInfinity; - assign add_result_input_payload_xySign = add_norm_output_payload_xySign; - assign add_result_input_payload_roundingScrap = add_norm_output_payload_roundingScrap; - assign add_result_input_payload_xyMantissaZero = add_norm_output_payload_xyMantissaZero; - assign add_result_output_valid = add_result_input_valid; - assign add_result_input_ready = add_result_output_ready; - assign add_result_output_payload_rd = add_result_input_payload_rd; - always @(*) begin - add_result_output_payload_value_sign = add_result_input_payload_xySign; - if(!add_result_input_payload_forceNan) begin - if(!add_result_input_payload_forceInfinity) begin - if(add_result_input_payload_forceZero) begin - if(when_FpuCore_l1513) begin - add_result_output_payload_value_sign = (add_result_input_payload_rs1_sign && add_result_input_payload_rs2_sign); - end - if(when_FpuCore_l1516) begin - add_result_output_payload_value_sign = 1'b1; - end - end - end - end - end - - always @(*) begin - add_result_output_payload_value_mantissa = _zz_add_result_output_payload_value_mantissa[23:0]; - if(add_result_input_payload_forceNan) begin - add_result_output_payload_value_mantissa[23] = 1'b1; - end - end - - always @(*) begin - add_result_output_payload_value_exponent = add_result_input_payload_exponent[8:0]; - if(add_result_input_payload_forceNan) begin - add_result_output_payload_value_exponent[1 : 0] = 2'b10; - add_result_output_payload_value_exponent[2] = 1'b1; - end else begin - if(add_result_input_payload_forceInfinity) begin - add_result_output_payload_value_exponent[1 : 0] = 2'b01; - end else begin - if(add_result_input_payload_forceZero) begin - add_result_output_payload_value_exponent[1 : 0] = 2'b00; - end - end - end - end - - always @(*) begin - add_result_output_payload_value_special = 1'b0; - if(add_result_input_payload_forceNan) begin - add_result_output_payload_value_special = 1'b1; - end else begin - if(add_result_input_payload_forceInfinity) begin - add_result_output_payload_value_special = 1'b1; - end else begin - if(add_result_input_payload_forceZero) begin - add_result_output_payload_value_special = 1'b1; - end - end - end - end - - assign add_result_output_payload_roundMode = add_result_input_payload_roundMode; - assign add_result_output_payload_scrap = ((add_result_input_payload_mantissa[1] || add_result_input_payload_mantissa[0]) || add_result_input_payload_roundingScrap); - assign add_result_output_payload_NV = ((add_result_input_payload_infinityNan || ((add_result_input_payload_rs1_special && (add_result_input_payload_rs1_exponent[1 : 0] == 2'b10)) && (! add_result_input_payload_rs1_mantissa[24]))) || ((add_result_input_payload_rs2_special && (add_result_input_payload_rs2_exponent[1 : 0] == 2'b10)) && (! add_result_input_payload_rs2_mantissa[24]))); - assign add_result_output_payload_DZ = 1'b0; - assign when_FpuCore_l1513 = (add_result_input_payload_xyMantissaZero || ((add_result_input_payload_rs1_special && (add_result_input_payload_rs1_exponent[1 : 0] == 2'b00)) && (add_result_input_payload_rs2_special && (add_result_input_payload_rs2_exponent[1 : 0] == 2'b00)))); - assign when_FpuCore_l1516 = ((add_result_input_payload_rs1_sign || add_result_input_payload_rs2_sign) && (add_result_input_payload_roundMode == FpuRoundMode_RDN)); - always @(*) begin - load_s1_output_ready = load_s1_output_m2sPipe_ready; - if(when_Stream_l368_16) begin - load_s1_output_ready = 1'b1; - end - end - - assign when_Stream_l368_16 = (! load_s1_output_m2sPipe_valid); - assign load_s1_output_m2sPipe_valid = load_s1_output_rValid; - assign load_s1_output_m2sPipe_payload_rd = load_s1_output_rData_rd; - assign load_s1_output_m2sPipe_payload_value_mantissa = load_s1_output_rData_value_mantissa; - assign load_s1_output_m2sPipe_payload_value_exponent = load_s1_output_rData_value_exponent; - assign load_s1_output_m2sPipe_payload_value_sign = load_s1_output_rData_value_sign; - assign load_s1_output_m2sPipe_payload_value_special = load_s1_output_rData_value_special; - assign load_s1_output_m2sPipe_payload_scrap = load_s1_output_rData_scrap; - assign load_s1_output_m2sPipe_payload_roundMode = load_s1_output_rData_roundMode; - assign load_s1_output_m2sPipe_payload_NV = load_s1_output_rData_NV; - assign load_s1_output_m2sPipe_payload_DZ = load_s1_output_rData_DZ; - always @(*) begin - shortPip_output_ready = shortPip_output_m2sPipe_ready; - if(when_Stream_l368_17) begin - shortPip_output_ready = 1'b1; - end - end - - assign when_Stream_l368_17 = (! shortPip_output_m2sPipe_valid); - assign shortPip_output_m2sPipe_valid = shortPip_output_rValid; - assign shortPip_output_m2sPipe_payload_rd = shortPip_output_rData_rd; - assign shortPip_output_m2sPipe_payload_value_mantissa = shortPip_output_rData_value_mantissa; - assign shortPip_output_m2sPipe_payload_value_exponent = shortPip_output_rData_value_exponent; - assign shortPip_output_m2sPipe_payload_value_sign = shortPip_output_rData_value_sign; - assign shortPip_output_m2sPipe_payload_value_special = shortPip_output_rData_value_special; - assign shortPip_output_m2sPipe_payload_scrap = shortPip_output_rData_scrap; - assign shortPip_output_m2sPipe_payload_roundMode = shortPip_output_rData_roundMode; - assign shortPip_output_m2sPipe_payload_NV = shortPip_output_rData_NV; - assign shortPip_output_m2sPipe_payload_DZ = shortPip_output_rData_DZ; - assign load_s1_output_m2sPipe_ready = streamArbiter_2_io_inputs_0_ready; - assign sqrt_output_ready = streamArbiter_2_io_inputs_1_ready; - assign div_output_ready = streamArbiter_2_io_inputs_2_ready; - assign add_result_output_ready = streamArbiter_2_io_inputs_3_ready; - assign mul_result_output_ready = streamArbiter_2_io_inputs_4_ready; - assign shortPip_output_m2sPipe_ready = streamArbiter_2_io_inputs_5_ready; - assign merge_arbitrated_valid = streamArbiter_2_io_output_valid; - assign merge_arbitrated_payload_rd = streamArbiter_2_io_output_payload_rd; - assign merge_arbitrated_payload_value_mantissa = streamArbiter_2_io_output_payload_value_mantissa; - assign merge_arbitrated_payload_value_exponent = streamArbiter_2_io_output_payload_value_exponent; - assign merge_arbitrated_payload_value_sign = streamArbiter_2_io_output_payload_value_sign; - assign merge_arbitrated_payload_value_special = streamArbiter_2_io_output_payload_value_special; - assign merge_arbitrated_payload_scrap = streamArbiter_2_io_output_payload_scrap; - assign merge_arbitrated_payload_roundMode = streamArbiter_2_io_output_payload_roundMode; - assign merge_arbitrated_payload_NV = streamArbiter_2_io_output_payload_NV; - assign merge_arbitrated_payload_DZ = streamArbiter_2_io_output_payload_DZ; - assign roundFront_output_valid = roundFront_input_valid; - assign roundFront_output_payload_rd = roundFront_input_payload_rd; - assign roundFront_output_payload_value_mantissa = roundFront_input_payload_value_mantissa; - assign roundFront_output_payload_value_exponent = roundFront_input_payload_value_exponent; - assign roundFront_output_payload_value_sign = roundFront_input_payload_value_sign; - assign roundFront_output_payload_value_special = roundFront_input_payload_value_special; - assign roundFront_output_payload_scrap = roundFront_input_payload_scrap; - assign roundFront_output_payload_roundMode = roundFront_input_payload_roundMode; - assign roundFront_output_payload_NV = roundFront_input_payload_NV; - assign roundFront_output_payload_DZ = roundFront_input_payload_DZ; - assign roundFront_manAggregate = {roundFront_input_payload_value_mantissa,roundFront_input_payload_scrap}; - assign roundFront_expBase = 8'h81; - assign roundFront_expDif = (_zz_roundFront_expDif - {1'b0,roundFront_input_payload_value_exponent}); - assign roundFront_expSubnormal = (! roundFront_expDif[9]); - assign roundFront_discardCount = (roundFront_expSubnormal ? _zz_roundFront_discardCount : 5'h0); - assign roundFront_exactMask = {(5'h17 < roundFront_discardCount),{(5'h16 < roundFront_discardCount),{(5'h15 < roundFront_discardCount),{(5'h14 < roundFront_discardCount),{(_zz_roundFront_exactMask < roundFront_discardCount),{_zz_roundFront_exactMask_1,{_zz_roundFront_exactMask_2,_zz_roundFront_exactMask_3}}}}}}}; - assign roundFront_roundAdjusted = {_zz_roundFront_roundAdjusted[roundFront_discardCount],((roundFront_manAggregate & roundFront_exactMask) != 25'h0)}; - always @(*) begin - case(roundFront_input_payload_roundMode) - FpuRoundMode_RNE : begin - _zz_roundFront_mantissaIncrement = (roundFront_roundAdjusted[1] && (roundFront_roundAdjusted[0] || _zz__zz_roundFront_mantissaIncrement[roundFront_discardCount])); - end - FpuRoundMode_RTZ : begin - _zz_roundFront_mantissaIncrement = 1'b0; - end - FpuRoundMode_RDN : begin - _zz_roundFront_mantissaIncrement = ((roundFront_roundAdjusted != 2'b00) && roundFront_input_payload_value_sign); - end - FpuRoundMode_RUP : begin - _zz_roundFront_mantissaIncrement = ((roundFront_roundAdjusted != 2'b00) && (! roundFront_input_payload_value_sign)); - end - default : begin - _zz_roundFront_mantissaIncrement = roundFront_roundAdjusted[1]; - end - endcase - end - - assign roundFront_mantissaIncrement = ((! roundFront_input_payload_value_special) && _zz_roundFront_mantissaIncrement); - assign roundFront_output_payload_mantissaIncrement = roundFront_mantissaIncrement; - assign roundFront_output_payload_roundAdjusted = roundFront_roundAdjusted; - assign roundFront_output_payload_exactMask = roundFront_exactMask; - assign roundBack_output_valid = roundBack_input_valid; - assign roundBack_adderMantissa = (roundBack_input_payload_value_mantissa[23 : 1] & (roundBack_input_payload_mantissaIncrement ? (~ _zz_roundBack_adderMantissa) : 23'h7fffff)); - assign roundBack_adderRightOp = _zz_roundBack_adderRightOp[22:0]; - assign _zz_roundBack_adder = {roundBack_input_payload_value_exponent,roundBack_adderMantissa}; - assign _zz_roundBack_adder_1 = roundBack_input_payload_mantissaIncrement; - assign roundBack_adder = (_zz_roundBack_adder_2 + _zz_roundBack_adder_4); - assign roundBack_math_special = roundBack_input_payload_value_special; - assign roundBack_math_sign = roundBack_input_payload_value_sign; - assign roundBack_math_exponent = roundBack_adder[31 : 23]; - assign roundBack_math_mantissa = roundBack_adder[22 : 0]; - always @(*) begin - roundBack_patched_mantissa = roundBack_math_mantissa; - if(when_FpuCore_l1611) begin - if(when_FpuCore_l1621) begin - roundBack_patched_mantissa = 23'h7fffff; - end - end - if(when_FpuCore_l1630) begin - if(when_FpuCore_l1640) begin - roundBack_patched_mantissa = 23'h0; - end - end - end - - always @(*) begin - roundBack_patched_exponent = roundBack_math_exponent; - if(when_FpuCore_l1611) begin - if(when_FpuCore_l1621) begin - roundBack_patched_exponent = roundBack_ofThreshold; - end else begin - roundBack_patched_exponent[1 : 0] = 2'b01; - end - end - if(when_FpuCore_l1630) begin - if(when_FpuCore_l1640) begin - roundBack_patched_exponent = {2'd0, roundBack_ufThreshold}; - end else begin - roundBack_patched_exponent[1 : 0] = 2'b00; - end - end - end - - assign roundBack_patched_sign = roundBack_math_sign; - always @(*) begin - roundBack_patched_special = roundBack_math_special; - if(when_FpuCore_l1611) begin - if(!when_FpuCore_l1621) begin - roundBack_patched_special = 1'b1; - end - end - if(when_FpuCore_l1630) begin - if(!when_FpuCore_l1640) begin - roundBack_patched_special = 1'b1; - end - end - end - - always @(*) begin - roundBack_nx = 1'b0; - if(when_FpuCore_l1611) begin - roundBack_nx = 1'b1; - end - if(when_FpuCore_l1630) begin - roundBack_nx = 1'b1; - end - if(when_FpuCore_l1649) begin - roundBack_nx = 1'b1; - end - end - - always @(*) begin - roundBack_of = 1'b0; - if(when_FpuCore_l1611) begin - roundBack_of = 1'b1; - end - end - - always @(*) begin - roundBack_uf = 1'b0; - if(when_FpuCore_l1608) begin - roundBack_uf = 1'b1; - end - if(when_FpuCore_l1630) begin - roundBack_uf = 1'b1; - end - end - - assign roundBack_ufSubnormalThreshold = 8'h80; - assign roundBack_ufThreshold = 7'h6a; - assign roundBack_ofThreshold = 9'h17e; - always @(*) begin - case(roundBack_input_payload_roundMode) - FpuRoundMode_RNE : begin - roundBack_threshold = 3'b110; - end - FpuRoundMode_RTZ : begin - roundBack_threshold = 3'b110; - end - FpuRoundMode_RDN : begin - roundBack_threshold = (roundBack_input_payload_value_sign ? 3'b101 : 3'b111); - end - FpuRoundMode_RUP : begin - roundBack_threshold = (roundBack_input_payload_value_sign ? 3'b111 : 3'b101); - end - default : begin - roundBack_threshold = 3'b110; - end - endcase - end - - assign roundBack_borringRound = {roundBack_input_payload_value_mantissa[1 : 0],roundBack_input_payload_scrap}; - assign roundBack_borringCase = ((roundBack_input_payload_value_exponent == _zz_roundBack_borringCase) && (roundBack_borringRound < roundBack_threshold)); - assign when_FpuCore_l1608 = (((! roundBack_math_special) && ((roundBack_math_exponent <= _zz_when_FpuCore_l1608) || roundBack_borringCase)) && (roundBack_input_payload_roundAdjusted != 2'b00)); - assign when_FpuCore_l1611 = ((! roundBack_math_special) && (roundBack_ofThreshold < roundBack_math_exponent)); - always @(*) begin - case(roundBack_input_payload_roundMode) - FpuRoundMode_RNE : begin - when_FpuCore_l1621 = 1'b0; - end - FpuRoundMode_RTZ : begin - when_FpuCore_l1621 = 1'b1; - end - FpuRoundMode_RDN : begin - when_FpuCore_l1621 = (! roundBack_math_sign); - end - FpuRoundMode_RUP : begin - when_FpuCore_l1621 = roundBack_math_sign; - end - default : begin - when_FpuCore_l1621 = 1'b0; - end - endcase - end - - assign when_FpuCore_l1630 = ((! roundBack_math_special) && (roundBack_math_exponent < _zz_when_FpuCore_l1630)); - always @(*) begin - case(roundBack_input_payload_roundMode) - FpuRoundMode_RNE : begin - when_FpuCore_l1640 = 1'b0; - end - FpuRoundMode_RTZ : begin - when_FpuCore_l1640 = 1'b0; - end - FpuRoundMode_RDN : begin - when_FpuCore_l1640 = roundBack_math_sign; - end - FpuRoundMode_RUP : begin - when_FpuCore_l1640 = (! roundBack_math_sign); - end - default : begin - when_FpuCore_l1640 = 1'b0; - end - endcase - end - - assign when_FpuCore_l1649 = ((! roundBack_input_payload_value_special) && (roundBack_input_payload_roundAdjusted != 2'b00)); - assign roundBack_writes_0 = _zz_rf_scoreboards_0_writes_port1[0]; - assign roundBack_write = roundBack_writes_0; - assign roundBack_output_payload_NX = (roundBack_nx && roundBack_write); - assign roundBack_output_payload_OF = (roundBack_of && roundBack_write); - assign roundBack_output_payload_UF = (roundBack_uf && roundBack_write); - assign roundBack_output_payload_NV = (roundBack_input_payload_NV && roundBack_write); - assign roundBack_output_payload_DZ = (roundBack_input_payload_DZ && roundBack_write); - assign roundBack_output_payload_rd = roundBack_input_payload_rd; - assign roundBack_output_payload_write = roundBack_write; - assign roundBack_output_payload_value_mantissa = roundBack_patched_mantissa; - assign roundBack_output_payload_value_exponent = roundBack_patched_exponent; - assign roundBack_output_payload_value_sign = roundBack_patched_sign; - assign roundBack_output_payload_value_special = roundBack_patched_special; - assign io_port_0_completion_valid = (writeback_input_valid && 1'b1); - assign io_port_0_completion_payload_flags_NX = writeback_input_payload_NX; - assign io_port_0_completion_payload_flags_OF = writeback_input_payload_OF; - assign io_port_0_completion_payload_flags_UF = writeback_input_payload_UF; - assign io_port_0_completion_payload_flags_NV = writeback_input_payload_NV; - assign io_port_0_completion_payload_flags_DZ = writeback_input_payload_DZ; - assign io_port_0_completion_payload_written = writeback_input_payload_write; - assign when_FpuCore_l1681 = 1'b1; - assign writeback_port_valid = (writeback_input_valid && writeback_input_payload_write); - assign writeback_port_payload_address = writeback_input_payload_rd; - assign writeback_port_payload_data_value_mantissa = writeback_input_payload_value_mantissa; - assign writeback_port_payload_data_value_exponent = writeback_input_payload_value_exponent; - assign writeback_port_payload_data_value_sign = writeback_input_payload_value_sign; - assign writeback_port_payload_data_value_special = writeback_input_payload_value_special; - always @(posedge clk or posedge reset) begin - if(reset) begin - rf_init_counter <= 6'h0; - streamFork_1_io_outputs_1_rValid <= 1'b0; - commitLogic_0_pending_counter <= 4'b0000; - commitLogic_0_add_counter <= 4'b0000; - commitLogic_0_mul_counter <= 4'b0000; - commitLogic_0_div_counter <= 4'b0000; - commitLogic_0_sqrt_counter <= 4'b0000; - commitLogic_0_short_counter <= 4'b0000; - io_port_0_cmd_rValid <= 1'b0; - read_s0_rValid <= 1'b0; - decode_load_rValid <= 1'b0; - decode_load_s2mPipe_rValid <= 1'b0; - decode_load_s2mPipe_m2sPipe_rValid <= 1'b0; - load_s0_output_rValid <= 1'b0; - decode_shortPip_rValid <= 1'b0; - shortPip_rspStreams_0_rValid <= 1'b0; - decode_mul_rValid <= 1'b0; - mul_preMul_output_rValid <= 1'b0; - mul_mul_output_rValid <= 1'b0; - mul_sum1_output_rValid <= 1'b0; - mul_sum2_output_rValid <= 1'b0; - mul_result_mulToAdd_rValid <= 1'b0; - decode_div_rValid <= 1'b0; - div_cmdSent <= 1'b0; - decode_sqrt_rValid <= 1'b0; - sqrt_cmdSent <= 1'b0; - add_preShifter_output_rValid <= 1'b0; - add_shifter_output_rValid <= 1'b0; - add_math_output_rValid <= 1'b0; - add_oh_output_rValid <= 1'b0; - load_s1_output_rValid <= 1'b0; - shortPip_output_rValid <= 1'b0; - roundFront_input_valid <= 1'b0; - roundBack_input_valid <= 1'b0; - writeback_input_valid <= 1'b0; - end else begin - if(when_FpuCore_l163) begin - rf_init_counter <= (rf_init_counter + 6'h01); - end - if(streamFork_1_io_outputs_1_valid) begin - streamFork_1_io_outputs_1_rValid <= 1'b1; - end - if(streamFork_1_io_outputs_1_s2mPipe_ready) begin - streamFork_1_io_outputs_1_rValid <= 1'b0; - end - commitLogic_0_pending_counter <= (_zz_commitLogic_0_pending_counter - _zz_commitLogic_0_pending_counter_3); - commitLogic_0_add_counter <= (_zz_commitLogic_0_add_counter - _zz_commitLogic_0_add_counter_3); - commitLogic_0_mul_counter <= (_zz_commitLogic_0_mul_counter - _zz_commitLogic_0_mul_counter_3); - commitLogic_0_div_counter <= (_zz_commitLogic_0_div_counter - _zz_commitLogic_0_div_counter_3); - commitLogic_0_sqrt_counter <= (_zz_commitLogic_0_sqrt_counter - _zz_commitLogic_0_sqrt_counter_3); - commitLogic_0_short_counter <= (_zz_commitLogic_0_short_counter - _zz_commitLogic_0_short_counter_3); - if(io_port_0_cmd_valid) begin - io_port_0_cmd_rValid <= 1'b1; - end - if(scheduler_0_input_ready) begin - io_port_0_cmd_rValid <= 1'b0; - end - if(read_s0_ready) begin - read_s0_rValid <= read_s0_valid; - end - if(decode_load_valid) begin - decode_load_rValid <= 1'b1; - end - if(decode_load_s2mPipe_ready) begin - decode_load_rValid <= 1'b0; - end - if(decode_load_s2mPipe_ready) begin - decode_load_s2mPipe_rValid <= decode_load_s2mPipe_valid; - end - if(decode_load_s2mPipe_m2sPipe_ready) begin - decode_load_s2mPipe_m2sPipe_rValid <= decode_load_s2mPipe_m2sPipe_valid; - end - if(load_s0_output_ready) begin - load_s0_output_rValid <= load_s0_output_valid; - end - if(decode_shortPip_ready) begin - decode_shortPip_rValid <= decode_shortPip_valid; - end - if(shortPip_rspStreams_0_ready) begin - shortPip_rspStreams_0_rValid <= shortPip_rspStreams_0_valid; - end - if(decode_mul_ready) begin - decode_mul_rValid <= decode_mul_valid; - end - if(mul_preMul_output_ready) begin - mul_preMul_output_rValid <= mul_preMul_output_valid; - end - if(mul_mul_output_ready) begin - mul_mul_output_rValid <= mul_mul_output_valid; - end - if(mul_sum1_output_ready) begin - mul_sum1_output_rValid <= mul_sum1_output_valid; - end - if(mul_sum2_output_ready) begin - mul_sum2_output_rValid <= mul_sum2_output_valid; - end - if(mul_result_mulToAdd_ready) begin - mul_result_mulToAdd_rValid <= mul_result_mulToAdd_valid; - end - if(decode_div_valid) begin - decode_div_rValid <= 1'b1; - end - if(div_input_fire) begin - decode_div_rValid <= 1'b0; - end - if(div_divider_io_input_fire) begin - div_cmdSent <= 1'b1; - end - if(when_FpuCore_l1056) begin - div_cmdSent <= 1'b0; - end - if(decode_sqrt_valid) begin - decode_sqrt_rValid <= 1'b1; - end - if(sqrt_input_fire) begin - decode_sqrt_rValid <= 1'b0; - end - if(sqrt_sqrt_io_input_fire) begin - sqrt_cmdSent <= 1'b1; - end - if(when_FpuCore_l1118) begin - sqrt_cmdSent <= 1'b0; - end - if(add_preShifter_output_ready) begin - add_preShifter_output_rValid <= add_preShifter_output_valid; - end - if(add_shifter_output_ready) begin - add_shifter_output_rValid <= add_shifter_output_valid; - end - if(add_math_output_ready) begin - add_math_output_rValid <= add_math_output_valid; - end - if(add_oh_output_ready) begin - add_oh_output_rValid <= add_oh_output_valid; - end - if(load_s1_output_ready) begin - load_s1_output_rValid <= load_s1_output_valid; - end - if(shortPip_output_ready) begin - shortPip_output_rValid <= shortPip_output_valid; - end - roundFront_input_valid <= merge_arbitrated_valid; - roundBack_input_valid <= roundFront_output_valid; - writeback_input_valid <= roundBack_output_valid; - if(writeback_port_valid) begin - `ifndef SYNTHESIS - `ifdef FORMAL - assert((! ((writeback_port_payload_data_value_exponent == 9'h0) && (! writeback_port_payload_data_value_special)))); // FpuCore.scala:L1705 - `else - if(!(! ((writeback_port_payload_data_value_exponent == 9'h0) && (! writeback_port_payload_data_value_special)))) begin - $display("FAILURE Special violation"); // FpuCore.scala:L1705 - $finish; - end - `endif - `endif - `ifndef SYNTHESIS - `ifdef FORMAL - assert((! ((writeback_port_payload_data_value_exponent == 9'h1ff) && (! writeback_port_payload_data_value_special)))); // FpuCore.scala:L1706 - `else - if(!(! ((writeback_port_payload_data_value_exponent == 9'h1ff) && (! writeback_port_payload_data_value_special)))) begin - $display("FAILURE Special violation"); // FpuCore.scala:L1706 - $finish; - end - `endif - `endif - end - end - end - - always @(posedge clk) begin - if(streamFork_1_io_outputs_1_ready) begin - streamFork_1_io_outputs_1_rData_opcode <= streamFork_1_io_outputs_1_payload_opcode; - streamFork_1_io_outputs_1_rData_rd <= streamFork_1_io_outputs_1_payload_rd; - streamFork_1_io_outputs_1_rData_write <= streamFork_1_io_outputs_1_payload_write; - streamFork_1_io_outputs_1_rData_value <= streamFork_1_io_outputs_1_payload_value; - end - if(io_port_0_cmd_ready) begin - io_port_0_cmd_rData_opcode <= io_port_0_cmd_payload_opcode; - io_port_0_cmd_rData_arg <= io_port_0_cmd_payload_arg; - io_port_0_cmd_rData_rs1 <= io_port_0_cmd_payload_rs1; - io_port_0_cmd_rData_rs2 <= io_port_0_cmd_payload_rs2; - io_port_0_cmd_rData_rs3 <= io_port_0_cmd_payload_rs3; - io_port_0_cmd_rData_rd <= io_port_0_cmd_payload_rd; - io_port_0_cmd_rData_format <= io_port_0_cmd_payload_format; - io_port_0_cmd_rData_roundMode <= io_port_0_cmd_payload_roundMode; - end - if(read_s0_ready) begin - read_s0_rData_opcode <= read_s0_payload_opcode; - read_s0_rData_rs1 <= read_s0_payload_rs1; - read_s0_rData_rs2 <= read_s0_payload_rs2; - read_s0_rData_rs3 <= read_s0_payload_rs3; - read_s0_rData_rd <= read_s0_payload_rd; - read_s0_rData_arg <= read_s0_payload_arg; - read_s0_rData_roundMode <= read_s0_payload_roundMode; - end - if(decode_load_ready) begin - decode_load_rData_rd <= decode_load_payload_rd; - decode_load_rData_i2f <= decode_load_payload_i2f; - decode_load_rData_arg <= decode_load_payload_arg; - decode_load_rData_roundMode <= decode_load_payload_roundMode; - end - if(decode_load_s2mPipe_ready) begin - decode_load_s2mPipe_rData_rd <= decode_load_s2mPipe_payload_rd; - decode_load_s2mPipe_rData_i2f <= decode_load_s2mPipe_payload_i2f; - decode_load_s2mPipe_rData_arg <= decode_load_s2mPipe_payload_arg; - decode_load_s2mPipe_rData_roundMode <= decode_load_s2mPipe_payload_roundMode; - end - if(decode_load_s2mPipe_m2sPipe_ready) begin - decode_load_s2mPipe_m2sPipe_rData_rd <= decode_load_s2mPipe_m2sPipe_payload_rd; - decode_load_s2mPipe_m2sPipe_rData_i2f <= decode_load_s2mPipe_m2sPipe_payload_i2f; - decode_load_s2mPipe_m2sPipe_rData_arg <= decode_load_s2mPipe_m2sPipe_payload_arg; - decode_load_s2mPipe_m2sPipe_rData_roundMode <= decode_load_s2mPipe_m2sPipe_payload_roundMode; - end - if(load_s0_output_ready) begin - load_s0_output_rData_rd <= load_s0_output_payload_rd; - load_s0_output_rData_value <= load_s0_output_payload_value; - load_s0_output_rData_i2f <= load_s0_output_payload_i2f; - load_s0_output_rData_arg <= load_s0_output_payload_arg; - load_s0_output_rData_roundMode <= load_s0_output_payload_roundMode; - end - if(when_FpuCore_l525) begin - load_s1_fsm_shift_output <= load_s1_fsm_shift_input_5; - end - if(when_FpuCore_l529) begin - if(load_s1_fsm_boot) begin - if(when_FpuCore_l532) begin - load_s0_output_rData_value[31 : 0] <= _zz_load_s0_output_rData_value_2; - load_s1_fsm_patched <= 1'b1; - end else begin - load_s1_fsm_shift_by <= {_zz_load_s1_fsm_shift_by_32,{_zz_load_s1_fsm_shift_by_31,{_zz_load_s1_fsm_shift_by_30,{_zz_load_s1_fsm_shift_by_29,_zz_load_s1_fsm_shift_by_28}}}}; - load_s1_fsm_boot <= 1'b0; - load_s1_fsm_i2fZero <= (load_s1_input_payload_value[31 : 0] == 32'h0); - end - end else begin - load_s1_fsm_done <= 1'b1; - end - end - if(when_FpuCore_l551) begin - load_s1_fsm_done <= 1'b0; - load_s1_fsm_boot <= 1'b1; - load_s1_fsm_patched <= 1'b0; - end - if(decode_shortPip_ready) begin - decode_shortPip_rData_opcode <= decode_shortPip_payload_opcode; - decode_shortPip_rData_rs1_mantissa <= decode_shortPip_payload_rs1_mantissa; - decode_shortPip_rData_rs1_exponent <= decode_shortPip_payload_rs1_exponent; - decode_shortPip_rData_rs1_sign <= decode_shortPip_payload_rs1_sign; - decode_shortPip_rData_rs1_special <= decode_shortPip_payload_rs1_special; - decode_shortPip_rData_rs2_mantissa <= decode_shortPip_payload_rs2_mantissa; - decode_shortPip_rData_rs2_exponent <= decode_shortPip_payload_rs2_exponent; - decode_shortPip_rData_rs2_sign <= decode_shortPip_payload_rs2_sign; - decode_shortPip_rData_rs2_special <= decode_shortPip_payload_rs2_special; - decode_shortPip_rData_rd <= decode_shortPip_payload_rd; - decode_shortPip_rData_value <= decode_shortPip_payload_value; - decode_shortPip_rData_arg <= decode_shortPip_payload_arg; - decode_shortPip_rData_roundMode <= decode_shortPip_payload_roundMode; - end - if(when_FpuCore_l646) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(when_FpuCore_l646_1) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(when_FpuCore_l646_2) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(when_FpuCore_l646_3) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(when_FpuCore_l646_4) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(when_FpuCore_l646_5) begin - shortPip_fsm_shift_scrap <= 1'b1; - end - if(shortPip_fsm_boot) begin - shortPip_fsm_shift_scrap <= 1'b0; - end - if(when_FpuCore_l652) begin - shortPip_fsm_shift_output <= shortPip_fsm_shift_input_6; - end - if(when_FpuCore_l658) begin - if(shortPip_fsm_boot) begin - if(shortPip_fsm_isF2i) begin - shortPip_fsm_shift_by <= _zz_shortPip_fsm_shift_by_2[5:0]; - end else begin - shortPip_fsm_shift_by <= _zz_shortPip_fsm_shift_by_5[5:0]; - end - shortPip_fsm_boot <= 1'b0; - end else begin - shortPip_fsm_done <= 1'b1; - end - end - if(when_FpuCore_l672) begin - shortPip_fsm_done <= 1'b0; - shortPip_fsm_boot <= 1'b1; - end - if(shortPip_rspStreams_0_ready) begin - shortPip_rspStreams_0_rData_value <= shortPip_rspStreams_0_payload_value; - shortPip_rspStreams_0_rData_NV <= shortPip_rspStreams_0_payload_NV; - shortPip_rspStreams_0_rData_NX <= shortPip_rspStreams_0_payload_NX; - end - if(decode_mul_ready) begin - decode_mul_rData_rs1_mantissa <= decode_mul_payload_rs1_mantissa; - decode_mul_rData_rs1_exponent <= decode_mul_payload_rs1_exponent; - decode_mul_rData_rs1_sign <= decode_mul_payload_rs1_sign; - decode_mul_rData_rs1_special <= decode_mul_payload_rs1_special; - decode_mul_rData_rs2_mantissa <= decode_mul_payload_rs2_mantissa; - decode_mul_rData_rs2_exponent <= decode_mul_payload_rs2_exponent; - decode_mul_rData_rs2_sign <= decode_mul_payload_rs2_sign; - decode_mul_rData_rs2_special <= decode_mul_payload_rs2_special; - decode_mul_rData_rs3_mantissa <= decode_mul_payload_rs3_mantissa; - decode_mul_rData_rs3_exponent <= decode_mul_payload_rs3_exponent; - decode_mul_rData_rs3_sign <= decode_mul_payload_rs3_sign; - decode_mul_rData_rs3_special <= decode_mul_payload_rs3_special; - decode_mul_rData_rd <= decode_mul_payload_rd; - decode_mul_rData_add <= decode_mul_payload_add; - decode_mul_rData_divSqrt <= decode_mul_payload_divSqrt; - decode_mul_rData_msb1 <= decode_mul_payload_msb1; - decode_mul_rData_msb2 <= decode_mul_payload_msb2; - decode_mul_rData_roundMode <= decode_mul_payload_roundMode; - end - if(mul_preMul_output_ready) begin - mul_preMul_output_rData_rs1_mantissa <= mul_preMul_output_payload_rs1_mantissa; - mul_preMul_output_rData_rs1_exponent <= mul_preMul_output_payload_rs1_exponent; - mul_preMul_output_rData_rs1_sign <= mul_preMul_output_payload_rs1_sign; - mul_preMul_output_rData_rs1_special <= mul_preMul_output_payload_rs1_special; - mul_preMul_output_rData_rs2_mantissa <= mul_preMul_output_payload_rs2_mantissa; - mul_preMul_output_rData_rs2_exponent <= mul_preMul_output_payload_rs2_exponent; - mul_preMul_output_rData_rs2_sign <= mul_preMul_output_payload_rs2_sign; - mul_preMul_output_rData_rs2_special <= mul_preMul_output_payload_rs2_special; - mul_preMul_output_rData_rs3_mantissa <= mul_preMul_output_payload_rs3_mantissa; - mul_preMul_output_rData_rs3_exponent <= mul_preMul_output_payload_rs3_exponent; - mul_preMul_output_rData_rs3_sign <= mul_preMul_output_payload_rs3_sign; - mul_preMul_output_rData_rs3_special <= mul_preMul_output_payload_rs3_special; - mul_preMul_output_rData_rd <= mul_preMul_output_payload_rd; - mul_preMul_output_rData_add <= mul_preMul_output_payload_add; - mul_preMul_output_rData_divSqrt <= mul_preMul_output_payload_divSqrt; - mul_preMul_output_rData_msb1 <= mul_preMul_output_payload_msb1; - mul_preMul_output_rData_msb2 <= mul_preMul_output_payload_msb2; - mul_preMul_output_rData_roundMode <= mul_preMul_output_payload_roundMode; - mul_preMul_output_rData_exp <= mul_preMul_output_payload_exp; - end - if(mul_mul_output_ready) begin - mul_mul_output_rData_rs1_mantissa <= mul_mul_output_payload_rs1_mantissa; - mul_mul_output_rData_rs1_exponent <= mul_mul_output_payload_rs1_exponent; - mul_mul_output_rData_rs1_sign <= mul_mul_output_payload_rs1_sign; - mul_mul_output_rData_rs1_special <= mul_mul_output_payload_rs1_special; - mul_mul_output_rData_rs2_mantissa <= mul_mul_output_payload_rs2_mantissa; - mul_mul_output_rData_rs2_exponent <= mul_mul_output_payload_rs2_exponent; - mul_mul_output_rData_rs2_sign <= mul_mul_output_payload_rs2_sign; - mul_mul_output_rData_rs2_special <= mul_mul_output_payload_rs2_special; - mul_mul_output_rData_rs3_mantissa <= mul_mul_output_payload_rs3_mantissa; - mul_mul_output_rData_rs3_exponent <= mul_mul_output_payload_rs3_exponent; - mul_mul_output_rData_rs3_sign <= mul_mul_output_payload_rs3_sign; - mul_mul_output_rData_rs3_special <= mul_mul_output_payload_rs3_special; - mul_mul_output_rData_rd <= mul_mul_output_payload_rd; - mul_mul_output_rData_add <= mul_mul_output_payload_add; - mul_mul_output_rData_divSqrt <= mul_mul_output_payload_divSqrt; - mul_mul_output_rData_msb1 <= mul_mul_output_payload_msb1; - mul_mul_output_rData_msb2 <= mul_mul_output_payload_msb2; - mul_mul_output_rData_roundMode <= mul_mul_output_payload_roundMode; - mul_mul_output_rData_exp <= mul_mul_output_payload_exp; - mul_mul_output_rData_muls_0 <= mul_mul_output_payload_muls_0; - mul_mul_output_rData_muls_1 <= mul_mul_output_payload_muls_1; - mul_mul_output_rData_muls_2 <= mul_mul_output_payload_muls_2; - mul_mul_output_rData_muls_3 <= mul_mul_output_payload_muls_3; - end - if(mul_sum1_output_ready) begin - mul_sum1_output_rData_rs1_mantissa <= mul_sum1_output_payload_rs1_mantissa; - mul_sum1_output_rData_rs1_exponent <= mul_sum1_output_payload_rs1_exponent; - mul_sum1_output_rData_rs1_sign <= mul_sum1_output_payload_rs1_sign; - mul_sum1_output_rData_rs1_special <= mul_sum1_output_payload_rs1_special; - mul_sum1_output_rData_rs2_mantissa <= mul_sum1_output_payload_rs2_mantissa; - mul_sum1_output_rData_rs2_exponent <= mul_sum1_output_payload_rs2_exponent; - mul_sum1_output_rData_rs2_sign <= mul_sum1_output_payload_rs2_sign; - mul_sum1_output_rData_rs2_special <= mul_sum1_output_payload_rs2_special; - mul_sum1_output_rData_rs3_mantissa <= mul_sum1_output_payload_rs3_mantissa; - mul_sum1_output_rData_rs3_exponent <= mul_sum1_output_payload_rs3_exponent; - mul_sum1_output_rData_rs3_sign <= mul_sum1_output_payload_rs3_sign; - mul_sum1_output_rData_rs3_special <= mul_sum1_output_payload_rs3_special; - mul_sum1_output_rData_rd <= mul_sum1_output_payload_rd; - mul_sum1_output_rData_add <= mul_sum1_output_payload_add; - mul_sum1_output_rData_divSqrt <= mul_sum1_output_payload_divSqrt; - mul_sum1_output_rData_msb1 <= mul_sum1_output_payload_msb1; - mul_sum1_output_rData_msb2 <= mul_sum1_output_payload_msb2; - mul_sum1_output_rData_roundMode <= mul_sum1_output_payload_roundMode; - mul_sum1_output_rData_exp <= mul_sum1_output_payload_exp; - mul_sum1_output_rData_muls2_0 <= mul_sum1_output_payload_muls2_0; - mul_sum1_output_rData_muls2_1 <= mul_sum1_output_payload_muls2_1; - mul_sum1_output_rData_mulC2 <= mul_sum1_output_payload_mulC2; - end - if(mul_sum2_output_ready) begin - mul_sum2_output_rData_rs1_mantissa <= mul_sum2_output_payload_rs1_mantissa; - mul_sum2_output_rData_rs1_exponent <= mul_sum2_output_payload_rs1_exponent; - mul_sum2_output_rData_rs1_sign <= mul_sum2_output_payload_rs1_sign; - mul_sum2_output_rData_rs1_special <= mul_sum2_output_payload_rs1_special; - mul_sum2_output_rData_rs2_mantissa <= mul_sum2_output_payload_rs2_mantissa; - mul_sum2_output_rData_rs2_exponent <= mul_sum2_output_payload_rs2_exponent; - mul_sum2_output_rData_rs2_sign <= mul_sum2_output_payload_rs2_sign; - mul_sum2_output_rData_rs2_special <= mul_sum2_output_payload_rs2_special; - mul_sum2_output_rData_rs3_mantissa <= mul_sum2_output_payload_rs3_mantissa; - mul_sum2_output_rData_rs3_exponent <= mul_sum2_output_payload_rs3_exponent; - mul_sum2_output_rData_rs3_sign <= mul_sum2_output_payload_rs3_sign; - mul_sum2_output_rData_rs3_special <= mul_sum2_output_payload_rs3_special; - mul_sum2_output_rData_rd <= mul_sum2_output_payload_rd; - mul_sum2_output_rData_add <= mul_sum2_output_payload_add; - mul_sum2_output_rData_divSqrt <= mul_sum2_output_payload_divSqrt; - mul_sum2_output_rData_msb1 <= mul_sum2_output_payload_msb1; - mul_sum2_output_rData_msb2 <= mul_sum2_output_payload_msb2; - mul_sum2_output_rData_roundMode <= mul_sum2_output_payload_roundMode; - mul_sum2_output_rData_exp <= mul_sum2_output_payload_exp; - mul_sum2_output_rData_mulC <= mul_sum2_output_payload_mulC; - end - if(mul_result_mulToAdd_ready) begin - mul_result_mulToAdd_rData_rs1_mantissa <= mul_result_mulToAdd_payload_rs1_mantissa; - mul_result_mulToAdd_rData_rs1_exponent <= mul_result_mulToAdd_payload_rs1_exponent; - mul_result_mulToAdd_rData_rs1_sign <= mul_result_mulToAdd_payload_rs1_sign; - mul_result_mulToAdd_rData_rs1_special <= mul_result_mulToAdd_payload_rs1_special; - mul_result_mulToAdd_rData_rs2_mantissa <= mul_result_mulToAdd_payload_rs2_mantissa; - mul_result_mulToAdd_rData_rs2_exponent <= mul_result_mulToAdd_payload_rs2_exponent; - mul_result_mulToAdd_rData_rs2_sign <= mul_result_mulToAdd_payload_rs2_sign; - mul_result_mulToAdd_rData_rs2_special <= mul_result_mulToAdd_payload_rs2_special; - mul_result_mulToAdd_rData_rd <= mul_result_mulToAdd_payload_rd; - mul_result_mulToAdd_rData_roundMode <= mul_result_mulToAdd_payload_roundMode; - mul_result_mulToAdd_rData_needCommit <= mul_result_mulToAdd_payload_needCommit; - end - if(decode_div_ready) begin - decode_div_rData_rs1_mantissa <= decode_div_payload_rs1_mantissa; - decode_div_rData_rs1_exponent <= decode_div_payload_rs1_exponent; - decode_div_rData_rs1_sign <= decode_div_payload_rs1_sign; - decode_div_rData_rs1_special <= decode_div_payload_rs1_special; - decode_div_rData_rs2_mantissa <= decode_div_payload_rs2_mantissa; - decode_div_rData_rs2_exponent <= decode_div_payload_rs2_exponent; - decode_div_rData_rs2_sign <= decode_div_payload_rs2_sign; - decode_div_rData_rs2_special <= decode_div_payload_rs2_special; - decode_div_rData_rd <= decode_div_payload_rd; - decode_div_rData_roundMode <= decode_div_payload_roundMode; - end - div_isCommited <= commitLogic_0_div_notEmpty; - if(decode_sqrt_ready) begin - decode_sqrt_rData_rs1_mantissa <= decode_sqrt_payload_rs1_mantissa; - decode_sqrt_rData_rs1_exponent <= decode_sqrt_payload_rs1_exponent; - decode_sqrt_rData_rs1_sign <= decode_sqrt_payload_rs1_sign; - decode_sqrt_rData_rs1_special <= decode_sqrt_payload_rs1_special; - decode_sqrt_rData_rd <= decode_sqrt_payload_rd; - decode_sqrt_rData_roundMode <= decode_sqrt_payload_roundMode; - end - sqrt_isCommited <= commitLogic_0_sqrt_notEmpty; - sqrt_exponent <= (_zz_sqrt_exponent + _zz_sqrt_exponent_4); - if(add_preShifter_output_ready) begin - add_preShifter_output_rData_rs1_mantissa <= add_preShifter_output_payload_rs1_mantissa; - add_preShifter_output_rData_rs1_exponent <= add_preShifter_output_payload_rs1_exponent; - add_preShifter_output_rData_rs1_sign <= add_preShifter_output_payload_rs1_sign; - add_preShifter_output_rData_rs1_special <= add_preShifter_output_payload_rs1_special; - add_preShifter_output_rData_rs2_mantissa <= add_preShifter_output_payload_rs2_mantissa; - add_preShifter_output_rData_rs2_exponent <= add_preShifter_output_payload_rs2_exponent; - add_preShifter_output_rData_rs2_sign <= add_preShifter_output_payload_rs2_sign; - add_preShifter_output_rData_rs2_special <= add_preShifter_output_payload_rs2_special; - add_preShifter_output_rData_rd <= add_preShifter_output_payload_rd; - add_preShifter_output_rData_roundMode <= add_preShifter_output_payload_roundMode; - add_preShifter_output_rData_needCommit <= add_preShifter_output_payload_needCommit; - add_preShifter_output_rData_absRs1Bigger <= add_preShifter_output_payload_absRs1Bigger; - add_preShifter_output_rData_rs1ExponentBigger <= add_preShifter_output_payload_rs1ExponentBigger; - end - if(add_shifter_output_ready) begin - add_shifter_output_rData_rs1_mantissa <= add_shifter_output_payload_rs1_mantissa; - add_shifter_output_rData_rs1_exponent <= add_shifter_output_payload_rs1_exponent; - add_shifter_output_rData_rs1_sign <= add_shifter_output_payload_rs1_sign; - add_shifter_output_rData_rs1_special <= add_shifter_output_payload_rs1_special; - add_shifter_output_rData_rs2_mantissa <= add_shifter_output_payload_rs2_mantissa; - add_shifter_output_rData_rs2_exponent <= add_shifter_output_payload_rs2_exponent; - add_shifter_output_rData_rs2_sign <= add_shifter_output_payload_rs2_sign; - add_shifter_output_rData_rs2_special <= add_shifter_output_payload_rs2_special; - add_shifter_output_rData_rd <= add_shifter_output_payload_rd; - add_shifter_output_rData_roundMode <= add_shifter_output_payload_roundMode; - add_shifter_output_rData_needCommit <= add_shifter_output_payload_needCommit; - add_shifter_output_rData_xSign <= add_shifter_output_payload_xSign; - add_shifter_output_rData_ySign <= add_shifter_output_payload_ySign; - add_shifter_output_rData_xMantissa <= add_shifter_output_payload_xMantissa; - add_shifter_output_rData_yMantissa <= add_shifter_output_payload_yMantissa; - add_shifter_output_rData_xyExponent <= add_shifter_output_payload_xyExponent; - add_shifter_output_rData_xySign <= add_shifter_output_payload_xySign; - add_shifter_output_rData_roundingScrap <= add_shifter_output_payload_roundingScrap; - end - if(add_math_output_ready) begin - add_math_output_rData_rs1_mantissa <= add_math_output_payload_rs1_mantissa; - add_math_output_rData_rs1_exponent <= add_math_output_payload_rs1_exponent; - add_math_output_rData_rs1_sign <= add_math_output_payload_rs1_sign; - add_math_output_rData_rs1_special <= add_math_output_payload_rs1_special; - add_math_output_rData_rs2_mantissa <= add_math_output_payload_rs2_mantissa; - add_math_output_rData_rs2_exponent <= add_math_output_payload_rs2_exponent; - add_math_output_rData_rs2_sign <= add_math_output_payload_rs2_sign; - add_math_output_rData_rs2_special <= add_math_output_payload_rs2_special; - add_math_output_rData_rd <= add_math_output_payload_rd; - add_math_output_rData_roundMode <= add_math_output_payload_roundMode; - add_math_output_rData_needCommit <= add_math_output_payload_needCommit; - add_math_output_rData_xSign <= add_math_output_payload_xSign; - add_math_output_rData_ySign <= add_math_output_payload_ySign; - add_math_output_rData_xMantissa <= add_math_output_payload_xMantissa; - add_math_output_rData_yMantissa <= add_math_output_payload_yMantissa; - add_math_output_rData_xyExponent <= add_math_output_payload_xyExponent; - add_math_output_rData_xySign <= add_math_output_payload_xySign; - add_math_output_rData_roundingScrap <= add_math_output_payload_roundingScrap; - add_math_output_rData_xyMantissa <= add_math_output_payload_xyMantissa; - end - if(add_oh_output_ready) begin - add_oh_output_rData_rs1_mantissa <= add_oh_output_payload_rs1_mantissa; - add_oh_output_rData_rs1_exponent <= add_oh_output_payload_rs1_exponent; - add_oh_output_rData_rs1_sign <= add_oh_output_payload_rs1_sign; - add_oh_output_rData_rs1_special <= add_oh_output_payload_rs1_special; - add_oh_output_rData_rs2_mantissa <= add_oh_output_payload_rs2_mantissa; - add_oh_output_rData_rs2_exponent <= add_oh_output_payload_rs2_exponent; - add_oh_output_rData_rs2_sign <= add_oh_output_payload_rs2_sign; - add_oh_output_rData_rs2_special <= add_oh_output_payload_rs2_special; - add_oh_output_rData_rd <= add_oh_output_payload_rd; - add_oh_output_rData_roundMode <= add_oh_output_payload_roundMode; - add_oh_output_rData_needCommit <= add_oh_output_payload_needCommit; - add_oh_output_rData_xSign <= add_oh_output_payload_xSign; - add_oh_output_rData_ySign <= add_oh_output_payload_ySign; - add_oh_output_rData_xMantissa <= add_oh_output_payload_xMantissa; - add_oh_output_rData_yMantissa <= add_oh_output_payload_yMantissa; - add_oh_output_rData_xyExponent <= add_oh_output_payload_xyExponent; - add_oh_output_rData_xySign <= add_oh_output_payload_xySign; - add_oh_output_rData_roundingScrap <= add_oh_output_payload_roundingScrap; - add_oh_output_rData_xyMantissa <= add_oh_output_payload_xyMantissa; - add_oh_output_rData_shift <= add_oh_output_payload_shift; - end - if(load_s1_output_ready) begin - load_s1_output_rData_rd <= load_s1_output_payload_rd; - load_s1_output_rData_value_mantissa <= load_s1_output_payload_value_mantissa; - load_s1_output_rData_value_exponent <= load_s1_output_payload_value_exponent; - load_s1_output_rData_value_sign <= load_s1_output_payload_value_sign; - load_s1_output_rData_value_special <= load_s1_output_payload_value_special; - load_s1_output_rData_scrap <= load_s1_output_payload_scrap; - load_s1_output_rData_roundMode <= load_s1_output_payload_roundMode; - load_s1_output_rData_NV <= load_s1_output_payload_NV; - load_s1_output_rData_DZ <= load_s1_output_payload_DZ; - end - if(shortPip_output_ready) begin - shortPip_output_rData_rd <= shortPip_output_payload_rd; - shortPip_output_rData_value_mantissa <= shortPip_output_payload_value_mantissa; - shortPip_output_rData_value_exponent <= shortPip_output_payload_value_exponent; - shortPip_output_rData_value_sign <= shortPip_output_payload_value_sign; - shortPip_output_rData_value_special <= shortPip_output_payload_value_special; - shortPip_output_rData_scrap <= shortPip_output_payload_scrap; - shortPip_output_rData_roundMode <= shortPip_output_payload_roundMode; - shortPip_output_rData_NV <= shortPip_output_payload_NV; - shortPip_output_rData_DZ <= shortPip_output_payload_DZ; - end - roundFront_input_payload_rd <= merge_arbitrated_payload_rd; - roundFront_input_payload_value_mantissa <= merge_arbitrated_payload_value_mantissa; - roundFront_input_payload_value_exponent <= merge_arbitrated_payload_value_exponent; - roundFront_input_payload_value_sign <= merge_arbitrated_payload_value_sign; - roundFront_input_payload_value_special <= merge_arbitrated_payload_value_special; - roundFront_input_payload_scrap <= merge_arbitrated_payload_scrap; - roundFront_input_payload_roundMode <= merge_arbitrated_payload_roundMode; - roundFront_input_payload_NV <= merge_arbitrated_payload_NV; - roundFront_input_payload_DZ <= merge_arbitrated_payload_DZ; - roundBack_input_payload_rd <= roundFront_output_payload_rd; - roundBack_input_payload_value_mantissa <= roundFront_output_payload_value_mantissa; - roundBack_input_payload_value_exponent <= roundFront_output_payload_value_exponent; - roundBack_input_payload_value_sign <= roundFront_output_payload_value_sign; - roundBack_input_payload_value_special <= roundFront_output_payload_value_special; - roundBack_input_payload_scrap <= roundFront_output_payload_scrap; - roundBack_input_payload_roundMode <= roundFront_output_payload_roundMode; - roundBack_input_payload_NV <= roundFront_output_payload_NV; - roundBack_input_payload_DZ <= roundFront_output_payload_DZ; - roundBack_input_payload_mantissaIncrement <= roundFront_output_payload_mantissaIncrement; - roundBack_input_payload_roundAdjusted <= roundFront_output_payload_roundAdjusted; - roundBack_input_payload_exactMask <= roundFront_output_payload_exactMask; - writeback_input_payload_rd <= roundBack_output_payload_rd; - writeback_input_payload_value_mantissa <= roundBack_output_payload_value_mantissa; - writeback_input_payload_value_exponent <= roundBack_output_payload_value_exponent; - writeback_input_payload_value_sign <= roundBack_output_payload_value_sign; - writeback_input_payload_value_special <= roundBack_output_payload_value_special; - writeback_input_payload_NV <= roundBack_output_payload_NV; - writeback_input_payload_NX <= roundBack_output_payload_NX; - writeback_input_payload_OF <= roundBack_output_payload_OF; - writeback_input_payload_UF <= roundBack_output_payload_UF; - writeback_input_payload_DZ <= roundBack_output_payload_DZ; - writeback_input_payload_write <= roundBack_output_payload_write; - end - - -endmodule - -module DataCache ( - input io_cpu_execute_isValid, - input [31:0] io_cpu_execute_address, - output reg io_cpu_execute_haltIt, - input io_cpu_execute_args_wr, - input [1:0] io_cpu_execute_args_size, - input io_cpu_execute_args_totalyConsistent, - output io_cpu_execute_refilling, - input io_cpu_memory_isValid, - input io_cpu_memory_isStuck, - output io_cpu_memory_isWrite, - input [31:0] io_cpu_memory_address, - input [31:0] io_cpu_memory_mmuRsp_physicalAddress, - input io_cpu_memory_mmuRsp_isIoAccess, - input io_cpu_memory_mmuRsp_isPaging, - input io_cpu_memory_mmuRsp_allowRead, - input io_cpu_memory_mmuRsp_allowWrite, - input io_cpu_memory_mmuRsp_allowExecute, - input io_cpu_memory_mmuRsp_exception, - input io_cpu_memory_mmuRsp_refilling, - input io_cpu_memory_mmuRsp_bypassTranslation, - input io_cpu_writeBack_isValid, - input io_cpu_writeBack_isStuck, - input io_cpu_writeBack_isFiring, - input io_cpu_writeBack_isUser, - output reg io_cpu_writeBack_haltIt, - output io_cpu_writeBack_isWrite, - input [31:0] io_cpu_writeBack_storeData, - output reg [31:0] io_cpu_writeBack_data, - input [31:0] io_cpu_writeBack_address, - output io_cpu_writeBack_mmuException, - output io_cpu_writeBack_unalignedAccess, - output reg io_cpu_writeBack_accessError, - output io_cpu_writeBack_keepMemRspData, - input io_cpu_writeBack_fence_SW, - input io_cpu_writeBack_fence_SR, - input io_cpu_writeBack_fence_SO, - input io_cpu_writeBack_fence_SI, - input io_cpu_writeBack_fence_PW, - input io_cpu_writeBack_fence_PR, - input io_cpu_writeBack_fence_PO, - input io_cpu_writeBack_fence_PI, - input [3:0] io_cpu_writeBack_fence_FM, - output io_cpu_writeBack_exclusiveOk, - output reg io_cpu_redo, - input io_cpu_flush_valid, - output io_cpu_flush_ready, - input io_cpu_flush_payload_singleLine, - output reg io_mem_cmd_valid, - input io_mem_cmd_ready, - output reg io_mem_cmd_payload_wr, - output io_mem_cmd_payload_uncached, - output reg [31:0] io_mem_cmd_payload_address, - output [31:0] io_mem_cmd_payload_data, - output [3:0] io_mem_cmd_payload_mask, - output reg [1:0] io_mem_cmd_payload_size, - output io_mem_cmd_payload_last, - input io_mem_rsp_valid, - input io_mem_rsp_payload_last, - input [31:0] io_mem_rsp_payload_data, - input io_mem_rsp_payload_error, - input clk, - input reset -); - - reg [31:0] _zz_ways_0_data_port0; - wire [0:0] _zz_stage0_dataColisions; - wire [0:0] _zz__zz_stageA_dataColisions; - wire [0:0] _zz_when; - wire [1:0] _zz_loader_waysAllocator; - reg _zz_1; - reg when_Phase_l649; - wire haltCpu; - reg tagsReadCmd_valid; - reg tagsWriteCmd_valid; - reg [0:0] tagsWriteCmd_payload_way; - reg tagsWriteCmd_payload_data_valid; - reg tagsWriteCmd_payload_data_error; - reg [28:0] tagsWriteCmd_payload_data_address; - reg tagsWriteLastCmd_valid; - reg [0:0] tagsWriteLastCmd_payload_way; - reg tagsWriteLastCmd_payload_data_valid; - reg tagsWriteLastCmd_payload_data_error; - reg [28:0] tagsWriteLastCmd_payload_data_address; - reg dataReadCmd_valid; - reg [0:0] dataReadCmd_payload; - reg dataWriteCmd_valid; - reg [0:0] dataWriteCmd_payload_way; - reg [0:0] dataWriteCmd_payload_address; - reg [31:0] dataWriteCmd_payload_data; - reg [3:0] dataWriteCmd_payload_mask; - wire when_Phase_l676; - wire ways_0_tagsReadRsp_valid; - wire ways_0_tagsReadRsp_error; - wire [28:0] ways_0_tagsReadRsp_address; - wire [30:0] _zz_ways_0_tagsReadRsp_valid; - wire _zz_ways_0_dataReadRspMem; - wire [31:0] ways_0_dataReadRspMem; - wire [31:0] ways_0_dataReadRsp; - wire when_DataCache_l642; - wire when_DataCache_l645; - wire when_DataCache_l664; - wire rspSync; - wire rspLast; - reg memCmdSent; - wire io_mem_cmd_fire; - wire when_DataCache_l686; - reg [3:0] _zz_stage0_mask; - wire [3:0] stage0_mask; - wire [0:0] stage0_dataColisions; - wire [0:0] stage0_wayInvalidate; - wire stage0_isAmo; - wire when_DataCache_l771; - reg stageA_request_wr; - reg [1:0] stageA_request_size; - reg stageA_request_totalyConsistent; - wire when_DataCache_l771_1; - reg [3:0] stageA_mask; - wire stageA_isAmo; - wire stageA_isLrsc; - wire [0:0] stageA_wayHits; - wire when_DataCache_l771_2; - reg [0:0] stageA_wayInvalidate; - wire when_DataCache_l771_3; - reg [0:0] stage0_dataColisions_regNextWhen; - wire [0:0] _zz_stageA_dataColisions; - wire [0:0] stageA_dataColisions; - wire when_DataCache_l822; - reg stageB_request_wr; - reg [1:0] stageB_request_size; - reg stageB_request_totalyConsistent; - reg stageB_mmuRspFreeze; - wire when_DataCache_l824; - reg [31:0] stageB_mmuRsp_physicalAddress; - reg stageB_mmuRsp_isIoAccess; - reg stageB_mmuRsp_isPaging; - reg stageB_mmuRsp_allowRead; - reg stageB_mmuRsp_allowWrite; - reg stageB_mmuRsp_allowExecute; - reg stageB_mmuRsp_exception; - reg stageB_mmuRsp_refilling; - reg stageB_mmuRsp_bypassTranslation; - wire when_DataCache_l821; - reg stageB_tagsReadRsp_0_valid; - reg stageB_tagsReadRsp_0_error; - reg [28:0] stageB_tagsReadRsp_0_address; - wire when_DataCache_l821_1; - reg [31:0] stageB_dataReadRsp_0; - wire when_DataCache_l820; - reg [0:0] stageB_wayInvalidate; - wire stageB_consistancyHazard; - wire when_DataCache_l820_1; - reg [0:0] stageB_dataColisions; - wire when_DataCache_l820_2; - reg stageB_unaligned; - wire when_DataCache_l820_3; - reg [0:0] stageB_waysHitsBeforeInvalidate; - wire [0:0] stageB_waysHits; - wire stageB_waysHit; - wire [31:0] stageB_dataMux; - wire when_DataCache_l820_4; - reg [3:0] stageB_mask; - reg stageB_loaderValid; - wire [31:0] stageB_ioMemRspMuxed; - reg stageB_flusher_waitDone; - wire stageB_flusher_hold; - reg [0:0] stageB_flusher_counter; - wire when_DataCache_l850; - wire when_DataCache_l856; - reg stageB_flusher_start; - wire stageB_isAmo; - wire stageB_isAmoCached; - wire stageB_isExternalLsrc; - wire stageB_isExternalAmo; - wire [31:0] stageB_requestDataBypass; - reg stageB_cpuWriteToCache; - wire when_DataCache_l926; - wire stageB_badPermissions; - wire stageB_loadStoreFault; - wire stageB_bypassCache; - wire when_DataCache_l995; - wire when_DataCache_l1004; - wire when_DataCache_l1009; - wire when_DataCache_l1020; - wire when_DataCache_l1032; - wire when_DataCache_l991; - wire when_DataCache_l1066; - wire when_DataCache_l1075; - reg loader_valid; - reg loader_counter_willIncrement; - wire loader_counter_willClear; - reg [0:0] loader_counter_valueNext; - reg [0:0] loader_counter_value; - wire loader_counter_willOverflowIfInc; - wire loader_counter_willOverflow; - reg [0:0] loader_waysAllocator; - reg loader_error; - wire loader_kill; - reg loader_killReg; - wire when_DataCache_l1090; - wire loader_done; - wire when_DataCache_l1118; - reg loader_valid_regNext; - wire when_DataCache_l1122; - wire when_DataCache_l1125; - wire [30:0] _zz_ways_0_tagsReadRsp_valid_1; - reg [30:0] _zz_ways_0_tagsReadRsp_valid_2; - reg [30:0] _zz_ways_0_tagsReadRsp_valid_3; - reg [7:0] ways_0_data_symbol0 [0:1]; - reg [7:0] ways_0_data_symbol1 [0:1]; - reg [7:0] ways_0_data_symbol2 [0:1]; - reg [7:0] ways_0_data_symbol3 [0:1]; - reg [7:0] _zz_ways_0_datasymbol_read; - reg [7:0] _zz_ways_0_datasymbol_read_1; - reg [7:0] _zz_ways_0_datasymbol_read_2; - reg [7:0] _zz_ways_0_datasymbol_read_3; - - assign _zz_stage0_dataColisions = (io_cpu_execute_address[2 : 2] >>> 0); - assign _zz__zz_stageA_dataColisions = (io_cpu_memory_address[2 : 2] >>> 0); - assign _zz_when = 1'b1; - assign _zz_loader_waysAllocator = {loader_waysAllocator,loader_waysAllocator[0]}; - always @(*) begin - _zz_ways_0_data_port0 = {_zz_ways_0_datasymbol_read_3, _zz_ways_0_datasymbol_read_2, _zz_ways_0_datasymbol_read_1, _zz_ways_0_datasymbol_read}; - end - always @(posedge clk) begin - if(_zz_ways_0_dataReadRspMem) begin - _zz_ways_0_datasymbol_read <= ways_0_data_symbol0[dataReadCmd_payload]; - _zz_ways_0_datasymbol_read_1 <= ways_0_data_symbol1[dataReadCmd_payload]; - _zz_ways_0_datasymbol_read_2 <= ways_0_data_symbol2[dataReadCmd_payload]; - _zz_ways_0_datasymbol_read_3 <= ways_0_data_symbol3[dataReadCmd_payload]; - end - end - - always @(posedge clk) begin - if(dataWriteCmd_payload_mask[0] && _zz_1) begin - ways_0_data_symbol0[dataWriteCmd_payload_address] <= dataWriteCmd_payload_data[7 : 0]; - end - if(dataWriteCmd_payload_mask[1] && _zz_1) begin - ways_0_data_symbol1[dataWriteCmd_payload_address] <= dataWriteCmd_payload_data[15 : 8]; - end - if(dataWriteCmd_payload_mask[2] && _zz_1) begin - ways_0_data_symbol2[dataWriteCmd_payload_address] <= dataWriteCmd_payload_data[23 : 16]; - end - if(dataWriteCmd_payload_mask[3] && _zz_1) begin - ways_0_data_symbol3[dataWriteCmd_payload_address] <= dataWriteCmd_payload_data[31 : 24]; - end - end - - always @(*) begin - _zz_1 = 1'b0; - if(when_DataCache_l645) begin - _zz_1 = 1'b1; - end - end - - always @(*) begin - when_Phase_l649 = 1'b0; - if(when_DataCache_l642) begin - when_Phase_l649 = 1'b1; - end - end - - assign haltCpu = 1'b0; - assign when_Phase_l676 = (tagsReadCmd_valid && (! io_cpu_memory_isStuck)); - assign _zz_ways_0_tagsReadRsp_valid = _zz_ways_0_tagsReadRsp_valid_2; - assign ways_0_tagsReadRsp_valid = _zz_ways_0_tagsReadRsp_valid[0]; - assign ways_0_tagsReadRsp_error = _zz_ways_0_tagsReadRsp_valid[1]; - assign ways_0_tagsReadRsp_address = _zz_ways_0_tagsReadRsp_valid[30 : 2]; - assign _zz_ways_0_dataReadRspMem = (dataReadCmd_valid && (! io_cpu_memory_isStuck)); - assign ways_0_dataReadRspMem = _zz_ways_0_data_port0; - assign ways_0_dataReadRsp = ways_0_dataReadRspMem[31 : 0]; - assign when_DataCache_l642 = (tagsWriteCmd_valid && tagsWriteCmd_payload_way[0]); - assign when_DataCache_l645 = (dataWriteCmd_valid && dataWriteCmd_payload_way[0]); - always @(*) begin - tagsReadCmd_valid = 1'b0; - if(when_DataCache_l664) begin - tagsReadCmd_valid = 1'b1; - end - end - - always @(*) begin - dataReadCmd_valid = 1'b0; - if(when_DataCache_l664) begin - dataReadCmd_valid = 1'b1; - end - end - - always @(*) begin - dataReadCmd_payload = 1'bx; - if(when_DataCache_l664) begin - dataReadCmd_payload = io_cpu_execute_address[2 : 2]; - end - end - - always @(*) begin - tagsWriteCmd_valid = 1'b0; - if(when_DataCache_l850) begin - tagsWriteCmd_valid = 1'b1; - end - if(when_DataCache_l1066) begin - tagsWriteCmd_valid = 1'b0; - end - if(loader_done) begin - tagsWriteCmd_valid = 1'b1; - end - end - - always @(*) begin - tagsWriteCmd_payload_way = 1'bx; - if(when_DataCache_l850) begin - tagsWriteCmd_payload_way = 1'b1; - end - if(loader_done) begin - tagsWriteCmd_payload_way = loader_waysAllocator; - end - end - - always @(*) begin - tagsWriteCmd_payload_data_valid = 1'bx; - if(when_DataCache_l850) begin - tagsWriteCmd_payload_data_valid = 1'b0; - end - if(loader_done) begin - tagsWriteCmd_payload_data_valid = (! (loader_kill || loader_killReg)); - end - end - - always @(*) begin - tagsWriteCmd_payload_data_error = 1'bx; - if(loader_done) begin - tagsWriteCmd_payload_data_error = (loader_error || (io_mem_rsp_valid && io_mem_rsp_payload_error)); - end - end - - always @(*) begin - tagsWriteCmd_payload_data_address = 29'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - if(loader_done) begin - tagsWriteCmd_payload_data_address = stageB_mmuRsp_physicalAddress[31 : 3]; - end - end - - always @(*) begin - dataWriteCmd_valid = 1'b0; - if(stageB_cpuWriteToCache) begin - if(when_DataCache_l926) begin - dataWriteCmd_valid = 1'b1; - end - end - if(when_DataCache_l1066) begin - dataWriteCmd_valid = 1'b0; - end - if(when_DataCache_l1090) begin - dataWriteCmd_valid = 1'b1; - end - end - - always @(*) begin - dataWriteCmd_payload_way = 1'bx; - if(stageB_cpuWriteToCache) begin - dataWriteCmd_payload_way = stageB_waysHits; - end - if(when_DataCache_l1090) begin - dataWriteCmd_payload_way = loader_waysAllocator; - end - end - - always @(*) begin - dataWriteCmd_payload_address = 1'bx; - if(stageB_cpuWriteToCache) begin - dataWriteCmd_payload_address = stageB_mmuRsp_physicalAddress[2 : 2]; - end - if(when_DataCache_l1090) begin - dataWriteCmd_payload_address = loader_counter_value; - end - end - - always @(*) begin - dataWriteCmd_payload_data = 32'bxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; - if(stageB_cpuWriteToCache) begin - dataWriteCmd_payload_data[31 : 0] = stageB_requestDataBypass; - end - if(when_DataCache_l1090) begin - dataWriteCmd_payload_data = io_mem_rsp_payload_data; - end - end - - always @(*) begin - dataWriteCmd_payload_mask = 4'bxxxx; - if(stageB_cpuWriteToCache) begin - dataWriteCmd_payload_mask = 4'b0000; - if(_zz_when[0]) begin - dataWriteCmd_payload_mask[3 : 0] = stageB_mask; - end - end - if(when_DataCache_l1090) begin - dataWriteCmd_payload_mask = 4'b1111; - end - end - - assign when_DataCache_l664 = (io_cpu_execute_isValid && (! io_cpu_memory_isStuck)); - always @(*) begin - io_cpu_execute_haltIt = 1'b0; - if(when_DataCache_l850) begin - io_cpu_execute_haltIt = 1'b1; - end - end - - assign rspSync = 1'b1; - assign rspLast = 1'b1; - assign io_mem_cmd_fire = (io_mem_cmd_valid && io_mem_cmd_ready); - assign when_DataCache_l686 = (! io_cpu_writeBack_isStuck); - always @(*) begin - _zz_stage0_mask = 4'bxxxx; - case(io_cpu_execute_args_size) - 2'b00 : begin - _zz_stage0_mask = 4'b0001; - end - 2'b01 : begin - _zz_stage0_mask = 4'b0011; - end - 2'b10 : begin - _zz_stage0_mask = 4'b1111; - end - default : begin - end - endcase - end - - assign stage0_mask = (_zz_stage0_mask <<< io_cpu_execute_address[1 : 0]); - assign stage0_dataColisions[0] = (((dataWriteCmd_valid && dataWriteCmd_payload_way[0]) && (dataWriteCmd_payload_address == _zz_stage0_dataColisions)) && ((stage0_mask & dataWriteCmd_payload_mask[3 : 0]) != 4'b0000)); - assign stage0_wayInvalidate = 1'b0; - assign stage0_isAmo = 1'b0; - assign when_DataCache_l771 = (! io_cpu_memory_isStuck); - assign when_DataCache_l771_1 = (! io_cpu_memory_isStuck); - assign io_cpu_memory_isWrite = stageA_request_wr; - assign stageA_isAmo = 1'b0; - assign stageA_isLrsc = 1'b0; - assign stageA_wayHits = ((io_cpu_memory_mmuRsp_physicalAddress[31 : 3] == ways_0_tagsReadRsp_address) && ways_0_tagsReadRsp_valid); - assign when_DataCache_l771_2 = (! io_cpu_memory_isStuck); - assign when_DataCache_l771_3 = (! io_cpu_memory_isStuck); - assign _zz_stageA_dataColisions[0] = (((dataWriteCmd_valid && dataWriteCmd_payload_way[0]) && (dataWriteCmd_payload_address == _zz__zz_stageA_dataColisions)) && ((stageA_mask & dataWriteCmd_payload_mask[3 : 0]) != 4'b0000)); - assign stageA_dataColisions = (stage0_dataColisions_regNextWhen | _zz_stageA_dataColisions); - assign when_DataCache_l822 = (! io_cpu_writeBack_isStuck); - always @(*) begin - stageB_mmuRspFreeze = 1'b0; - if(when_DataCache_l1125) begin - stageB_mmuRspFreeze = 1'b1; - end - end - - assign when_DataCache_l824 = ((! io_cpu_writeBack_isStuck) && (! stageB_mmuRspFreeze)); - assign when_DataCache_l821 = (! io_cpu_writeBack_isStuck); - assign when_DataCache_l821_1 = (! io_cpu_writeBack_isStuck); - assign when_DataCache_l820 = (! io_cpu_writeBack_isStuck); - assign stageB_consistancyHazard = 1'b0; - assign when_DataCache_l820_1 = (! io_cpu_writeBack_isStuck); - assign when_DataCache_l820_2 = (! io_cpu_writeBack_isStuck); - assign when_DataCache_l820_3 = (! io_cpu_writeBack_isStuck); - assign stageB_waysHits = (stageB_waysHitsBeforeInvalidate & (~ stageB_wayInvalidate)); - assign stageB_waysHit = (|stageB_waysHits); - assign stageB_dataMux = stageB_dataReadRsp_0; - assign when_DataCache_l820_4 = (! io_cpu_writeBack_isStuck); - always @(*) begin - stageB_loaderValid = 1'b0; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(!when_DataCache_l1004) begin - if(io_mem_cmd_ready) begin - stageB_loaderValid = 1'b1; - end - end - end - end - end - if(when_DataCache_l1066) begin - stageB_loaderValid = 1'b0; - end - end - - assign stageB_ioMemRspMuxed = io_mem_rsp_payload_data[31 : 0]; - always @(*) begin - io_cpu_writeBack_haltIt = 1'b1; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(when_DataCache_l991) begin - if(when_DataCache_l995) begin - io_cpu_writeBack_haltIt = 1'b0; - end - end else begin - if(when_DataCache_l1004) begin - if(when_DataCache_l1009) begin - io_cpu_writeBack_haltIt = 1'b0; - end - end - end - end - end - if(when_DataCache_l1066) begin - io_cpu_writeBack_haltIt = 1'b0; - end - end - - assign stageB_flusher_hold = 1'b0; - assign when_DataCache_l850 = (! stageB_flusher_counter[0]); - assign when_DataCache_l856 = (! stageB_flusher_hold); - assign io_cpu_flush_ready = (stageB_flusher_waitDone && stageB_flusher_counter[0]); - assign stageB_isAmo = 1'b0; - assign stageB_isAmoCached = 1'b0; - assign stageB_isExternalLsrc = 1'b0; - assign stageB_isExternalAmo = 1'b0; - assign stageB_requestDataBypass = io_cpu_writeBack_storeData; - always @(*) begin - stageB_cpuWriteToCache = 1'b0; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(when_DataCache_l1004) begin - stageB_cpuWriteToCache = 1'b1; - end - end - end - end - end - - assign when_DataCache_l926 = (stageB_request_wr && stageB_waysHit); - assign stageB_badPermissions = (((! stageB_mmuRsp_allowWrite) && stageB_request_wr) || ((! stageB_mmuRsp_allowRead) && ((! stageB_request_wr) || stageB_isAmo))); - assign stageB_loadStoreFault = (io_cpu_writeBack_isValid && (stageB_mmuRsp_exception || stageB_badPermissions)); - always @(*) begin - io_cpu_redo = 1'b0; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(when_DataCache_l1004) begin - if(when_DataCache_l1020) begin - io_cpu_redo = 1'b1; - end - end - end - end - end - if(when_DataCache_l1075) begin - io_cpu_redo = 1'b1; - end - if(when_DataCache_l1122) begin - io_cpu_redo = 1'b1; - end - end - - always @(*) begin - io_cpu_writeBack_accessError = 1'b0; - if(stageB_bypassCache) begin - io_cpu_writeBack_accessError = ((((! stageB_request_wr) && 1'b1) && io_mem_rsp_valid) && io_mem_rsp_payload_error); - end else begin - io_cpu_writeBack_accessError = (((stageB_waysHits & stageB_tagsReadRsp_0_error) != 1'b0) || (stageB_loadStoreFault && (! stageB_mmuRsp_isPaging))); - end - end - - assign io_cpu_writeBack_mmuException = (stageB_loadStoreFault && stageB_mmuRsp_isPaging); - assign io_cpu_writeBack_unalignedAccess = (io_cpu_writeBack_isValid && stageB_unaligned); - assign io_cpu_writeBack_isWrite = stageB_request_wr; - always @(*) begin - io_mem_cmd_valid = 1'b0; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(when_DataCache_l991) begin - io_mem_cmd_valid = (! memCmdSent); - end else begin - if(when_DataCache_l1004) begin - if(stageB_request_wr) begin - io_mem_cmd_valid = 1'b1; - end - end else begin - if(when_DataCache_l1032) begin - io_mem_cmd_valid = 1'b1; - end - end - end - end - end - if(when_DataCache_l1066) begin - io_mem_cmd_valid = 1'b0; - end - end - - always @(*) begin - io_mem_cmd_payload_address = stageB_mmuRsp_physicalAddress; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(!when_DataCache_l1004) begin - io_mem_cmd_payload_address[2 : 0] = 3'b000; - end - end - end - end - end - - assign io_mem_cmd_payload_last = 1'b1; - always @(*) begin - io_mem_cmd_payload_wr = stageB_request_wr; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(!when_DataCache_l1004) begin - io_mem_cmd_payload_wr = 1'b0; - end - end - end - end - end - - assign io_mem_cmd_payload_mask = stageB_mask; - assign io_mem_cmd_payload_data = stageB_requestDataBypass; - assign io_mem_cmd_payload_uncached = stageB_mmuRsp_isIoAccess; - always @(*) begin - io_mem_cmd_payload_size = stageB_request_size; - if(io_cpu_writeBack_isValid) begin - if(!stageB_isExternalAmo) begin - if(!when_DataCache_l991) begin - if(!when_DataCache_l1004) begin - io_mem_cmd_payload_size = 2'b11; - end - end - end - end - end - - assign stageB_bypassCache = ((stageB_mmuRsp_isIoAccess || stageB_isExternalLsrc) || stageB_isExternalAmo); - assign io_cpu_writeBack_keepMemRspData = 1'b0; - assign when_DataCache_l995 = ((! stageB_request_wr) ? (io_mem_rsp_valid && rspSync) : io_mem_cmd_ready); - assign when_DataCache_l1004 = (stageB_waysHit || (stageB_request_wr && (! stageB_isAmoCached))); - assign when_DataCache_l1009 = ((! stageB_request_wr) || io_mem_cmd_ready); - assign when_DataCache_l1020 = (((! stageB_request_wr) || stageB_isAmoCached) && ((stageB_dataColisions & stageB_waysHits) != 1'b0)); - assign when_DataCache_l1032 = (! memCmdSent); - assign when_DataCache_l991 = (stageB_mmuRsp_isIoAccess || stageB_isExternalLsrc); - always @(*) begin - if(stageB_bypassCache) begin - io_cpu_writeBack_data = stageB_ioMemRspMuxed; - end else begin - io_cpu_writeBack_data = stageB_dataMux; - end - end - - assign when_DataCache_l1066 = ((((stageB_consistancyHazard || stageB_mmuRsp_refilling) || io_cpu_writeBack_accessError) || io_cpu_writeBack_mmuException) || io_cpu_writeBack_unalignedAccess); - assign when_DataCache_l1075 = (io_cpu_writeBack_isValid && (stageB_mmuRsp_refilling || stageB_consistancyHazard)); - always @(*) begin - loader_counter_willIncrement = 1'b0; - if(when_DataCache_l1090) begin - loader_counter_willIncrement = 1'b1; - end - end - - assign loader_counter_willClear = 1'b0; - assign loader_counter_willOverflowIfInc = (loader_counter_value == 1'b1); - assign loader_counter_willOverflow = (loader_counter_willOverflowIfInc && loader_counter_willIncrement); - always @(*) begin - loader_counter_valueNext = (loader_counter_value + loader_counter_willIncrement); - if(loader_counter_willClear) begin - loader_counter_valueNext = 1'b0; - end - end - - assign loader_kill = 1'b0; - assign when_DataCache_l1090 = ((loader_valid && io_mem_rsp_valid) && rspLast); - assign loader_done = loader_counter_willOverflow; - assign when_DataCache_l1118 = (! loader_valid); - assign when_DataCache_l1122 = (loader_valid && (! loader_valid_regNext)); - assign io_cpu_execute_refilling = loader_valid; - assign when_DataCache_l1125 = (stageB_loaderValid || loader_valid); - assign _zz_ways_0_tagsReadRsp_valid_1 = _zz_ways_0_tagsReadRsp_valid_3; - always @(posedge clk) begin - tagsWriteLastCmd_valid <= tagsWriteCmd_valid; - tagsWriteLastCmd_payload_way <= tagsWriteCmd_payload_way; - tagsWriteLastCmd_payload_data_valid <= tagsWriteCmd_payload_data_valid; - tagsWriteLastCmd_payload_data_error <= tagsWriteCmd_payload_data_error; - tagsWriteLastCmd_payload_data_address <= tagsWriteCmd_payload_data_address; - if(when_DataCache_l771) begin - stageA_request_wr <= io_cpu_execute_args_wr; - stageA_request_size <= io_cpu_execute_args_size; - stageA_request_totalyConsistent <= io_cpu_execute_args_totalyConsistent; - end - if(when_DataCache_l771_1) begin - stageA_mask <= stage0_mask; - end - if(when_DataCache_l771_2) begin - stageA_wayInvalidate <= stage0_wayInvalidate; - end - if(when_DataCache_l771_3) begin - stage0_dataColisions_regNextWhen <= stage0_dataColisions; - end - if(when_DataCache_l822) begin - stageB_request_wr <= stageA_request_wr; - stageB_request_size <= stageA_request_size; - stageB_request_totalyConsistent <= stageA_request_totalyConsistent; - end - if(when_DataCache_l824) begin - stageB_mmuRsp_physicalAddress <= io_cpu_memory_mmuRsp_physicalAddress; - stageB_mmuRsp_isIoAccess <= io_cpu_memory_mmuRsp_isIoAccess; - stageB_mmuRsp_isPaging <= io_cpu_memory_mmuRsp_isPaging; - stageB_mmuRsp_allowRead <= io_cpu_memory_mmuRsp_allowRead; - stageB_mmuRsp_allowWrite <= io_cpu_memory_mmuRsp_allowWrite; - stageB_mmuRsp_allowExecute <= io_cpu_memory_mmuRsp_allowExecute; - stageB_mmuRsp_exception <= io_cpu_memory_mmuRsp_exception; - stageB_mmuRsp_refilling <= io_cpu_memory_mmuRsp_refilling; - stageB_mmuRsp_bypassTranslation <= io_cpu_memory_mmuRsp_bypassTranslation; - end - if(when_DataCache_l821) begin - stageB_tagsReadRsp_0_valid <= ways_0_tagsReadRsp_valid; - stageB_tagsReadRsp_0_error <= ways_0_tagsReadRsp_error; - stageB_tagsReadRsp_0_address <= ways_0_tagsReadRsp_address; - end - if(when_DataCache_l821_1) begin - stageB_dataReadRsp_0 <= ways_0_dataReadRsp; - end - if(when_DataCache_l820) begin - stageB_wayInvalidate <= stageA_wayInvalidate; - end - if(when_DataCache_l820_1) begin - stageB_dataColisions <= stageA_dataColisions; - end - if(when_DataCache_l820_2) begin - stageB_unaligned <= ({((stageA_request_size == 2'b10) && (io_cpu_memory_address[1 : 0] != 2'b00)),((stageA_request_size == 2'b01) && (io_cpu_memory_address[0 : 0] != 1'b0))} != 2'b00); - end - if(when_DataCache_l820_3) begin - stageB_waysHitsBeforeInvalidate <= stageA_wayHits; - end - if(when_DataCache_l820_4) begin - stageB_mask <= stageA_mask; - end - loader_valid_regNext <= loader_valid; - if(when_Phase_l676) begin - _zz_ways_0_tagsReadRsp_valid_2 <= _zz_ways_0_tagsReadRsp_valid_1; - end - if(when_Phase_l649) begin - _zz_ways_0_tagsReadRsp_valid_3 <= {tagsWriteCmd_payload_data_address,{tagsWriteCmd_payload_data_error,tagsWriteCmd_payload_data_valid}}; - end - end - - always @(posedge clk or posedge reset) begin - if(reset) begin - memCmdSent <= 1'b0; - stageB_flusher_waitDone <= 1'b0; - stageB_flusher_counter <= 1'b0; - stageB_flusher_start <= 1'b1; - loader_valid <= 1'b0; - loader_counter_value <= 1'b0; - loader_waysAllocator <= 1'b1; - loader_error <= 1'b0; - loader_killReg <= 1'b0; - end else begin - if(io_mem_cmd_fire) begin - memCmdSent <= 1'b1; - end - if(when_DataCache_l686) begin - memCmdSent <= 1'b0; - end - if(io_cpu_flush_ready) begin - stageB_flusher_waitDone <= 1'b0; - end - if(when_DataCache_l850) begin - if(when_DataCache_l856) begin - stageB_flusher_counter <= (stageB_flusher_counter + 1'b1); - if(io_cpu_flush_payload_singleLine) begin - stageB_flusher_counter[0] <= 1'b1; - end - end - end - stageB_flusher_start <= (((((((! stageB_flusher_waitDone) && (! stageB_flusher_start)) && io_cpu_flush_valid) && (! io_cpu_execute_isValid)) && (! io_cpu_memory_isValid)) && (! io_cpu_writeBack_isValid)) && (! io_cpu_redo)); - if(stageB_flusher_start) begin - stageB_flusher_waitDone <= 1'b1; - stageB_flusher_counter <= 1'b0; - if(io_cpu_flush_payload_singleLine) begin - stageB_flusher_counter <= 1'b0; - end - end - `ifndef SYNTHESIS - `ifdef FORMAL - assert((! ((io_cpu_writeBack_isValid && (! io_cpu_writeBack_haltIt)) && io_cpu_writeBack_isStuck))); // DataCache.scala:L1077 - `else - if(!(! ((io_cpu_writeBack_isValid && (! io_cpu_writeBack_haltIt)) && io_cpu_writeBack_isStuck))) begin - $display("ERROR writeBack stuck by another plugin is not allowed"); // DataCache.scala:L1077 - end - `endif - `endif - if(stageB_loaderValid) begin - loader_valid <= 1'b1; - end - loader_counter_value <= loader_counter_valueNext; - if(loader_kill) begin - loader_killReg <= 1'b1; - end - if(when_DataCache_l1090) begin - loader_error <= (loader_error || io_mem_rsp_payload_error); - end - if(loader_done) begin - loader_valid <= 1'b0; - loader_error <= 1'b0; - loader_killReg <= 1'b0; - end - if(when_DataCache_l1118) begin - loader_waysAllocator <= _zz_loader_waysAllocator[0:0]; - end - end + + always @(negedge io_jtag_tck) begin + jtag_tap_tdoUnbufferd_regNext <= jtag_tap_tdoUnbufferd; end @@ -14298,924 +6002,100 @@ module StreamFifoLowLatency ( endmodule -module StreamArbiter_1 ( - input io_inputs_0_valid, - output io_inputs_0_ready, - input [4:0] io_inputs_0_payload_rd, - input [23:0] io_inputs_0_payload_value_mantissa, - input [8:0] io_inputs_0_payload_value_exponent, - input io_inputs_0_payload_value_sign, - input io_inputs_0_payload_value_special, - input io_inputs_0_payload_scrap, - input [2:0] io_inputs_0_payload_roundMode, - input io_inputs_0_payload_NV, - input io_inputs_0_payload_DZ, - input io_inputs_1_valid, - output io_inputs_1_ready, - input [4:0] io_inputs_1_payload_rd, - input [23:0] io_inputs_1_payload_value_mantissa, - input [8:0] io_inputs_1_payload_value_exponent, - input io_inputs_1_payload_value_sign, - input io_inputs_1_payload_value_special, - input io_inputs_1_payload_scrap, - input [2:0] io_inputs_1_payload_roundMode, - input io_inputs_1_payload_NV, - input io_inputs_1_payload_DZ, - input io_inputs_2_valid, - output io_inputs_2_ready, - input [4:0] io_inputs_2_payload_rd, - input [23:0] io_inputs_2_payload_value_mantissa, - input [8:0] io_inputs_2_payload_value_exponent, - input io_inputs_2_payload_value_sign, - input io_inputs_2_payload_value_special, - input io_inputs_2_payload_scrap, - input [2:0] io_inputs_2_payload_roundMode, - input io_inputs_2_payload_NV, - input io_inputs_2_payload_DZ, - input io_inputs_3_valid, - output io_inputs_3_ready, - input [4:0] io_inputs_3_payload_rd, - input [23:0] io_inputs_3_payload_value_mantissa, - input [8:0] io_inputs_3_payload_value_exponent, - input io_inputs_3_payload_value_sign, - input io_inputs_3_payload_value_special, - input io_inputs_3_payload_scrap, - input [2:0] io_inputs_3_payload_roundMode, - input io_inputs_3_payload_NV, - input io_inputs_3_payload_DZ, - input io_inputs_4_valid, - output io_inputs_4_ready, - input [4:0] io_inputs_4_payload_rd, - input [23:0] io_inputs_4_payload_value_mantissa, - input [8:0] io_inputs_4_payload_value_exponent, - input io_inputs_4_payload_value_sign, - input io_inputs_4_payload_value_special, - input io_inputs_4_payload_scrap, - input [2:0] io_inputs_4_payload_roundMode, - input io_inputs_4_payload_NV, - input io_inputs_4_payload_DZ, - input io_inputs_5_valid, - output io_inputs_5_ready, - input [4:0] io_inputs_5_payload_rd, - input [23:0] io_inputs_5_payload_value_mantissa, - input [8:0] io_inputs_5_payload_value_exponent, - input io_inputs_5_payload_value_sign, - input io_inputs_5_payload_value_special, - input io_inputs_5_payload_scrap, - input [2:0] io_inputs_5_payload_roundMode, - input io_inputs_5_payload_NV, - input io_inputs_5_payload_DZ, +module FlowCCByToggle ( + input io_input_valid, + input io_input_payload_last, + input [0:0] io_input_payload_fragment, output io_output_valid, - input io_output_ready, - output [4:0] io_output_payload_rd, - output [23:0] io_output_payload_value_mantissa, - output [8:0] io_output_payload_value_exponent, - output io_output_payload_value_sign, - output io_output_payload_value_special, - output io_output_payload_scrap, - output [2:0] io_output_payload_roundMode, - output io_output_payload_NV, - output io_output_payload_DZ, - output [2:0] io_chosen, - output [5:0] io_chosenOH, + output io_output_payload_last, + output [0:0] io_output_payload_fragment, + input io_jtag_tck, input clk, input reset ); - localparam FpuRoundMode_RNE = 3'd0; - localparam FpuRoundMode_RTZ = 3'd1; - localparam FpuRoundMode_RDN = 3'd2; - localparam FpuRoundMode_RUP = 3'd3; - localparam FpuRoundMode_RMM = 3'd4; - - wire [5:0] _zz__zz_maskProposal_1_1; - reg [2:0] _zz__zz_io_output_payload_roundMode; - reg [4:0] _zz_io_output_payload_rd_4; - reg [23:0] _zz_io_output_payload_value_mantissa; - reg [8:0] _zz_io_output_payload_value_exponent; - reg _zz_io_output_payload_value_sign; - reg _zz_io_output_payload_value_special; - reg _zz_io_output_payload_scrap; - reg _zz_io_output_payload_NV; - reg _zz_io_output_payload_DZ; - wire locked; - wire maskProposal_0; - wire maskProposal_1; - wire maskProposal_2; - wire maskProposal_3; - wire maskProposal_4; - wire maskProposal_5; - reg maskLocked_0; - reg maskLocked_1; - reg maskLocked_2; - reg maskLocked_3; - reg maskLocked_4; - reg maskLocked_5; - wire maskRouted_0; - wire maskRouted_1; - wire maskRouted_2; - wire maskRouted_3; - wire maskRouted_4; - wire maskRouted_5; - wire [5:0] _zz_maskProposal_1; - wire [5:0] _zz_maskProposal_1_1; - wire _zz_io_output_payload_rd; - wire _zz_io_output_payload_rd_1; - wire _zz_io_output_payload_rd_2; - wire [2:0] _zz_io_output_payload_rd_3; - wire [2:0] _zz_io_output_payload_roundMode; - wire _zz_io_chosen; - wire _zz_io_chosen_1; - wire _zz_io_chosen_2; - wire _zz_io_chosen_3; - wire _zz_io_chosen_4; - `ifndef SYNTHESIS - reg [23:0] io_inputs_0_payload_roundMode_string; - reg [23:0] io_inputs_1_payload_roundMode_string; - reg [23:0] io_inputs_2_payload_roundMode_string; - reg [23:0] io_inputs_3_payload_roundMode_string; - reg [23:0] io_inputs_4_payload_roundMode_string; - reg [23:0] io_inputs_5_payload_roundMode_string; - reg [23:0] io_output_payload_roundMode_string; - reg [23:0] _zz_io_output_payload_roundMode_string; - `endif - - - assign _zz__zz_maskProposal_1_1 = (_zz_maskProposal_1 - 6'h01); - always @(*) begin - case(_zz_io_output_payload_rd_3) - 3'b000 : begin - _zz__zz_io_output_payload_roundMode = io_inputs_0_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_0_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_0_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_0_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_0_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_0_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_0_payload_scrap; - _zz_io_output_payload_NV = io_inputs_0_payload_NV; - _zz_io_output_payload_DZ = io_inputs_0_payload_DZ; - end - 3'b001 : begin - _zz__zz_io_output_payload_roundMode = io_inputs_1_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_1_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_1_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_1_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_1_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_1_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_1_payload_scrap; - _zz_io_output_payload_NV = io_inputs_1_payload_NV; - _zz_io_output_payload_DZ = io_inputs_1_payload_DZ; - end - 3'b010 : begin - _zz__zz_io_output_payload_roundMode = io_inputs_2_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_2_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_2_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_2_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_2_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_2_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_2_payload_scrap; - _zz_io_output_payload_NV = io_inputs_2_payload_NV; - _zz_io_output_payload_DZ = io_inputs_2_payload_DZ; - end - 3'b011 : begin - _zz__zz_io_output_payload_roundMode = io_inputs_3_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_3_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_3_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_3_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_3_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_3_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_3_payload_scrap; - _zz_io_output_payload_NV = io_inputs_3_payload_NV; - _zz_io_output_payload_DZ = io_inputs_3_payload_DZ; - end - 3'b100 : begin - _zz__zz_io_output_payload_roundMode = io_inputs_4_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_4_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_4_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_4_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_4_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_4_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_4_payload_scrap; - _zz_io_output_payload_NV = io_inputs_4_payload_NV; - _zz_io_output_payload_DZ = io_inputs_4_payload_DZ; - end - default : begin - _zz__zz_io_output_payload_roundMode = io_inputs_5_payload_roundMode; - _zz_io_output_payload_rd_4 = io_inputs_5_payload_rd; - _zz_io_output_payload_value_mantissa = io_inputs_5_payload_value_mantissa; - _zz_io_output_payload_value_exponent = io_inputs_5_payload_value_exponent; - _zz_io_output_payload_value_sign = io_inputs_5_payload_value_sign; - _zz_io_output_payload_value_special = io_inputs_5_payload_value_special; - _zz_io_output_payload_scrap = io_inputs_5_payload_scrap; - _zz_io_output_payload_NV = io_inputs_5_payload_NV; - _zz_io_output_payload_DZ = io_inputs_5_payload_DZ; - end - endcase - end + wire inputArea_target_buffercc_io_dataOut; + reg inputArea_target; + reg inputArea_data_last; + reg [0:0] inputArea_data_fragment; + wire outputArea_target; + reg outputArea_hit; + wire outputArea_flow_valid; + wire outputArea_flow_payload_last; + wire [0:0] outputArea_flow_payload_fragment; + reg outputArea_flow_m2sPipe_valid; + reg outputArea_flow_m2sPipe_payload_last; + reg [0:0] outputArea_flow_m2sPipe_payload_fragment; + + BufferCC inputArea_target_buffercc ( + .io_dataIn (inputArea_target ), //i + .io_dataOut (inputArea_target_buffercc_io_dataOut), //o + .clk (clk ), //i + .reset (reset ) //i + ); + initial begin `ifndef SYNTHESIS - always @(*) begin - case(io_inputs_0_payload_roundMode) - FpuRoundMode_RNE : io_inputs_0_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_0_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_0_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_0_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_0_payload_roundMode_string = "RMM"; - default : io_inputs_0_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_inputs_1_payload_roundMode) - FpuRoundMode_RNE : io_inputs_1_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_1_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_1_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_1_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_1_payload_roundMode_string = "RMM"; - default : io_inputs_1_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_inputs_2_payload_roundMode) - FpuRoundMode_RNE : io_inputs_2_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_2_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_2_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_2_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_2_payload_roundMode_string = "RMM"; - default : io_inputs_2_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_inputs_3_payload_roundMode) - FpuRoundMode_RNE : io_inputs_3_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_3_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_3_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_3_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_3_payload_roundMode_string = "RMM"; - default : io_inputs_3_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_inputs_4_payload_roundMode) - FpuRoundMode_RNE : io_inputs_4_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_4_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_4_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_4_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_4_payload_roundMode_string = "RMM"; - default : io_inputs_4_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_inputs_5_payload_roundMode) - FpuRoundMode_RNE : io_inputs_5_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_5_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_5_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_5_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_5_payload_roundMode_string = "RMM"; - default : io_inputs_5_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_output_payload_roundMode) - FpuRoundMode_RNE : io_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_output_payload_roundMode_string = "RMM"; - default : io_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_io_output_payload_roundMode) - FpuRoundMode_RNE : _zz_io_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_io_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_io_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_io_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_io_output_payload_roundMode_string = "RMM"; - default : _zz_io_output_payload_roundMode_string = "???"; - endcase - end + inputArea_target = $urandom; + outputArea_hit = $urandom; `endif - - assign locked = 1'b0; - assign maskRouted_0 = (locked ? maskLocked_0 : maskProposal_0); - assign maskRouted_1 = (locked ? maskLocked_1 : maskProposal_1); - assign maskRouted_2 = (locked ? maskLocked_2 : maskProposal_2); - assign maskRouted_3 = (locked ? maskLocked_3 : maskProposal_3); - assign maskRouted_4 = (locked ? maskLocked_4 : maskProposal_4); - assign maskRouted_5 = (locked ? maskLocked_5 : maskProposal_5); - assign _zz_maskProposal_1 = {io_inputs_5_valid,{io_inputs_4_valid,{io_inputs_3_valid,{io_inputs_2_valid,{io_inputs_1_valid,io_inputs_0_valid}}}}}; - assign _zz_maskProposal_1_1 = (_zz_maskProposal_1 & (~ _zz__zz_maskProposal_1_1)); - assign maskProposal_0 = io_inputs_0_valid; - assign maskProposal_1 = _zz_maskProposal_1_1[1]; - assign maskProposal_2 = _zz_maskProposal_1_1[2]; - assign maskProposal_3 = _zz_maskProposal_1_1[3]; - assign maskProposal_4 = _zz_maskProposal_1_1[4]; - assign maskProposal_5 = _zz_maskProposal_1_1[5]; - assign io_output_valid = ((((((io_inputs_0_valid && maskRouted_0) || (io_inputs_1_valid && maskRouted_1)) || (io_inputs_2_valid && maskRouted_2)) || (io_inputs_3_valid && maskRouted_3)) || (io_inputs_4_valid && maskRouted_4)) || (io_inputs_5_valid && maskRouted_5)); - assign _zz_io_output_payload_rd = ((maskRouted_1 || maskRouted_3) || maskRouted_5); - assign _zz_io_output_payload_rd_1 = (maskRouted_2 || maskRouted_3); - assign _zz_io_output_payload_rd_2 = (maskRouted_4 || maskRouted_5); - assign _zz_io_output_payload_rd_3 = {_zz_io_output_payload_rd_2,{_zz_io_output_payload_rd_1,_zz_io_output_payload_rd}}; - assign _zz_io_output_payload_roundMode = _zz__zz_io_output_payload_roundMode; - assign io_output_payload_rd = _zz_io_output_payload_rd_4; - assign io_output_payload_value_mantissa = _zz_io_output_payload_value_mantissa; - assign io_output_payload_value_exponent = _zz_io_output_payload_value_exponent; - assign io_output_payload_value_sign = _zz_io_output_payload_value_sign; - assign io_output_payload_value_special = _zz_io_output_payload_value_special; - assign io_output_payload_scrap = _zz_io_output_payload_scrap; - assign io_output_payload_roundMode = _zz_io_output_payload_roundMode; - assign io_output_payload_NV = _zz_io_output_payload_NV; - assign io_output_payload_DZ = _zz_io_output_payload_DZ; - assign io_inputs_0_ready = (maskRouted_0 && io_output_ready); - assign io_inputs_1_ready = (maskRouted_1 && io_output_ready); - assign io_inputs_2_ready = (maskRouted_2 && io_output_ready); - assign io_inputs_3_ready = (maskRouted_3 && io_output_ready); - assign io_inputs_4_ready = (maskRouted_4 && io_output_ready); - assign io_inputs_5_ready = (maskRouted_5 && io_output_ready); - assign io_chosenOH = {maskRouted_5,{maskRouted_4,{maskRouted_3,{maskRouted_2,{maskRouted_1,maskRouted_0}}}}}; - assign _zz_io_chosen = io_chosenOH[3]; - assign _zz_io_chosen_1 = io_chosenOH[5]; - assign _zz_io_chosen_2 = ((io_chosenOH[1] || _zz_io_chosen) || _zz_io_chosen_1); - assign _zz_io_chosen_3 = (io_chosenOH[2] || _zz_io_chosen); - assign _zz_io_chosen_4 = (io_chosenOH[4] || _zz_io_chosen_1); - assign io_chosen = {_zz_io_chosen_4,{_zz_io_chosen_3,_zz_io_chosen_2}}; - always @(posedge clk) begin - if(io_output_valid) begin - maskLocked_0 <= maskRouted_0; - maskLocked_1 <= maskRouted_1; - maskLocked_2 <= maskRouted_2; - maskLocked_3 <= maskRouted_3; - maskLocked_4 <= maskRouted_4; - maskLocked_5 <= maskRouted_5; - end end - -endmodule - -module FpuSqrt ( - input io_input_valid, - output io_input_ready, - input [24:0] io_input_payload_a, - output io_output_valid, - input io_output_ready, - output [23:0] io_output_payload_result, - output [27:0] io_output_payload_remain, - input clk, - input reset -); - - wire [27:0] _zz_t; - wire [25:0] _zz_t_1; - wire [24:0] _zz_q; - wire [29:0] _zz_a_1; - wire [1:0] _zz_a_2; - reg [4:0] counter; - reg busy; - wire io_output_fire; - reg done; - wire when_FpuSqrt_l28; - wire io_output_fire_1; - reg [27:0] a; - reg [22:0] x; - reg [23:0] q; - wire [27:0] t; - wire when_FpuSqrt_l41; - reg [27:0] _zz_a; - wire when_FpuSqrt_l44; - wire when_FpuSqrt_l52; - - assign _zz_t_1 = {q,2'b01}; - assign _zz_t = {2'd0, _zz_t_1}; - assign _zz_q = {q,(! t[27])}; - assign _zz_a_1 = {_zz_a,x[22 : 21]}; - assign _zz_a_2 = io_input_payload_a[24 : 23]; - assign io_output_fire = (io_output_valid && io_output_ready); - assign when_FpuSqrt_l28 = (busy && (counter == 5'h18)); - assign io_output_fire_1 = (io_output_valid && io_output_ready); - assign t = (a - _zz_t); - assign io_output_valid = done; - assign io_output_payload_result = q; - assign io_output_payload_remain = a; - assign io_input_ready = (! busy); - assign when_FpuSqrt_l41 = (! done); - always @(*) begin - _zz_a = a; - if(when_FpuSqrt_l44) begin - _zz_a = t; - end - end - - assign when_FpuSqrt_l44 = (! t[27]); - assign when_FpuSqrt_l52 = (! busy); - always @(posedge clk or posedge reset) begin - if(reset) begin - busy <= 1'b0; - done <= 1'b0; - end else begin - if(io_output_fire) begin - busy <= 1'b0; - end - if(when_FpuSqrt_l28) begin - done <= 1'b1; - end - if(io_output_fire_1) begin - done <= 1'b0; - end - if(when_FpuSqrt_l52) begin - if(io_input_valid) begin - busy <= 1'b1; - end - end + assign outputArea_target = inputArea_target_buffercc_io_dataOut; + assign outputArea_flow_valid = (outputArea_target != outputArea_hit); + assign outputArea_flow_payload_last = inputArea_data_last; + assign outputArea_flow_payload_fragment = inputArea_data_fragment; + assign io_output_valid = outputArea_flow_m2sPipe_valid; + assign io_output_payload_last = outputArea_flow_m2sPipe_payload_last; + assign io_output_payload_fragment = outputArea_flow_m2sPipe_payload_fragment; + always @(posedge io_jtag_tck) begin + if(io_input_valid) begin + inputArea_target <= (! inputArea_target); + inputArea_data_last <= io_input_payload_last; + inputArea_data_fragment <= io_input_payload_fragment; end end always @(posedge clk) begin - if(when_FpuSqrt_l41) begin - counter <= (counter + 5'h01); - q <= _zz_q[23:0]; - a <= _zz_a_1[27:0]; - x <= (x <<< 2); - end - if(when_FpuSqrt_l52) begin - q <= 24'h0; - a <= {26'd0, _zz_a_2}; - x <= io_input_payload_a[22:0]; - counter <= 5'h0; + outputArea_hit <= outputArea_target; + if(outputArea_flow_valid) begin + outputArea_flow_m2sPipe_payload_last <= outputArea_flow_payload_last; + outputArea_flow_m2sPipe_payload_fragment <= outputArea_flow_payload_fragment; end end - -endmodule - -module FpuDiv ( - input io_input_valid, - output io_input_ready, - input [23:0] io_input_payload_a, - input [23:0] io_input_payload_b, - output io_output_valid, - input io_output_ready, - output [26:0] io_output_payload_result, - output [24:0] io_output_payload_remain, - input clk, - input reset -); - - wire [24:0] _zz_shifter_1; - wire [24:0] _zz_div1; - wire [26:0] _zz_div3; - wire [25:0] _zz_div3_1; - wire [25:0] _zz_div3_2; - reg [3:0] counter; - reg busy; - wire io_output_fire; - reg done; - wire when_FpuDiv_l31; - wire io_output_fire_1; - reg [26:0] shifter; - reg [26:0] result; - reg [26:0] div1; - reg [26:0] div3; - wire [26:0] div2; - wire [27:0] sub1; - wire [27:0] sub2; - wire [27:0] sub3; - wire when_FpuDiv_l48; - reg [26:0] _zz_shifter; - wire when_FpuDiv_l52; - wire when_FpuDiv_l56; - wire when_FpuDiv_l60; - wire when_FpuDiv_l67; - - assign _zz_shifter_1 = {1'b1,io_input_payload_a}; - assign _zz_div1 = {1'b1,io_input_payload_b}; - assign _zz_div3_1 = {1'b0,{1'b1,io_input_payload_b}}; - assign _zz_div3 = {1'd0, _zz_div3_1}; - assign _zz_div3_2 = ({1'd0,{1'b1,io_input_payload_b}} <<< 1); - assign io_output_fire = (io_output_valid && io_output_ready); - assign when_FpuDiv_l31 = (busy && (counter == 4'b1101)); - assign io_output_fire_1 = (io_output_valid && io_output_ready); - assign div2 = (div1 <<< 1); - assign sub1 = ({1'b0,shifter} - {1'b0,div1}); - assign sub2 = ({1'b0,shifter} - {1'b0,div2}); - assign sub3 = ({1'b0,shifter} - {1'b0,div3}); - assign io_output_valid = done; - assign io_output_payload_result = result; - assign io_output_payload_remain = (shifter >>> 2); - assign io_input_ready = (! busy); - assign when_FpuDiv_l48 = (! done); - always @(*) begin - _zz_shifter = shifter; - if(when_FpuDiv_l52) begin - _zz_shifter = sub1[26:0]; - end - if(when_FpuDiv_l56) begin - _zz_shifter = sub2[26:0]; - end - if(when_FpuDiv_l60) begin - _zz_shifter = sub3[26:0]; - end - end - - assign when_FpuDiv_l52 = (! sub1[27]); - assign when_FpuDiv_l56 = (! sub2[27]); - assign when_FpuDiv_l60 = (! sub3[27]); - assign when_FpuDiv_l67 = (! busy); always @(posedge clk or posedge reset) begin if(reset) begin - busy <= 1'b0; - done <= 1'b0; + outputArea_flow_m2sPipe_valid <= 1'b0; end else begin - if(io_output_fire) begin - busy <= 1'b0; - end - if(when_FpuDiv_l31) begin - done <= 1'b1; - end - if(io_output_fire_1) begin - done <= 1'b0; - end - if(when_FpuDiv_l67) begin - busy <= io_input_valid; - end - end - end - - always @(posedge clk) begin - if(when_FpuDiv_l48) begin - counter <= (counter + 4'b0001); - result <= (result <<< 2); - if(when_FpuDiv_l52) begin - result[1 : 0] <= 2'b01; - end - if(when_FpuDiv_l56) begin - result[1 : 0] <= 2'b10; - end - if(when_FpuDiv_l60) begin - result[1 : 0] <= 2'b11; - end - shifter <= (_zz_shifter <<< 2); - end - if(when_FpuDiv_l67) begin - counter <= 4'b0000; - shifter <= {2'd0, _zz_shifter_1}; - div1 <= {2'd0, _zz_div1}; - div3 <= (_zz_div3 + {1'b0,_zz_div3_2}); + outputArea_flow_m2sPipe_valid <= outputArea_flow_valid; end end endmodule -module StreamArbiter ( - input io_inputs_0_valid, - output io_inputs_0_ready, - input [3:0] io_inputs_0_payload_opcode, - input [1:0] io_inputs_0_payload_arg, - input [4:0] io_inputs_0_payload_rs1, - input [4:0] io_inputs_0_payload_rs2, - input [4:0] io_inputs_0_payload_rs3, - input [4:0] io_inputs_0_payload_rd, - input [0:0] io_inputs_0_payload_format, - input [2:0] io_inputs_0_payload_roundMode, - output io_output_valid, - input io_output_ready, - output [3:0] io_output_payload_opcode, - output [1:0] io_output_payload_arg, - output [4:0] io_output_payload_rs1, - output [4:0] io_output_payload_rs2, - output [4:0] io_output_payload_rs3, - output [4:0] io_output_payload_rd, - output [0:0] io_output_payload_format, - output [2:0] io_output_payload_roundMode, - output [0:0] io_chosenOH, +module BufferCC ( + input io_dataIn, + output io_dataOut, input clk, input reset ); - localparam FpuOpcode_LOAD = 4'd0; - localparam FpuOpcode_STORE = 4'd1; - localparam FpuOpcode_MUL = 4'd2; - localparam FpuOpcode_ADD = 4'd3; - localparam FpuOpcode_FMA = 4'd4; - localparam FpuOpcode_I2F = 4'd5; - localparam FpuOpcode_F2I = 4'd6; - localparam FpuOpcode_CMP = 4'd7; - localparam FpuOpcode_DIV = 4'd8; - localparam FpuOpcode_SQRT = 4'd9; - localparam FpuOpcode_MIN_MAX = 4'd10; - localparam FpuOpcode_SGNJ = 4'd11; - localparam FpuOpcode_FMV_X_W = 4'd12; - localparam FpuOpcode_FMV_W_X = 4'd13; - localparam FpuOpcode_FCLASS = 4'd14; - localparam FpuOpcode_FCVT_X_X = 4'd15; - localparam FpuFormat_FLOAT = 1'd0; - localparam FpuFormat_DOUBLE = 1'd1; - localparam FpuRoundMode_RNE = 3'd0; - localparam FpuRoundMode_RTZ = 3'd1; - localparam FpuRoundMode_RDN = 3'd2; - localparam FpuRoundMode_RUP = 3'd3; - localparam FpuRoundMode_RMM = 3'd4; - - wire [1:0] _zz__zz_maskProposal_0_2; - wire [1:0] _zz__zz_maskProposal_0_2_1; - wire [0:0] _zz__zz_maskProposal_0_2_2; - wire [0:0] _zz_maskProposal_0_3; - wire locked; - wire maskProposal_0; - reg maskLocked_0; - wire maskRouted_0; - wire [0:0] _zz_maskProposal_0; - wire [1:0] _zz_maskProposal_0_1; - wire [1:0] _zz_maskProposal_0_2; - wire [3:0] _zz_io_output_payload_opcode; - wire [0:0] _zz_io_output_payload_format; - wire [2:0] _zz_io_output_payload_roundMode; - `ifndef SYNTHESIS - reg [63:0] io_inputs_0_payload_opcode_string; - reg [47:0] io_inputs_0_payload_format_string; - reg [23:0] io_inputs_0_payload_roundMode_string; - reg [63:0] io_output_payload_opcode_string; - reg [47:0] io_output_payload_format_string; - reg [23:0] io_output_payload_roundMode_string; - reg [63:0] _zz_io_output_payload_opcode_string; - reg [47:0] _zz_io_output_payload_format_string; - reg [23:0] _zz_io_output_payload_roundMode_string; - `endif + (* async_reg = "true" *) reg buffers_0; + (* async_reg = "true" *) reg buffers_1; - assign _zz__zz_maskProposal_0_2 = (_zz_maskProposal_0_1 - _zz__zz_maskProposal_0_2_1); - assign _zz__zz_maskProposal_0_2_2 = maskLocked_0; - assign _zz__zz_maskProposal_0_2_1 = {1'd0, _zz__zz_maskProposal_0_2_2}; - assign _zz_maskProposal_0_3 = (_zz_maskProposal_0_2[1 : 1] | _zz_maskProposal_0_2[0 : 0]); + initial begin `ifndef SYNTHESIS - always @(*) begin - case(io_inputs_0_payload_opcode) - FpuOpcode_LOAD : io_inputs_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_inputs_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_inputs_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_inputs_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_inputs_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_inputs_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_inputs_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_inputs_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_inputs_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_inputs_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_inputs_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_inputs_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_inputs_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_inputs_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_inputs_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_inputs_0_payload_opcode_string = "FCVT_X_X"; - default : io_inputs_0_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_inputs_0_payload_format) - FpuFormat_FLOAT : io_inputs_0_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : io_inputs_0_payload_format_string = "DOUBLE"; - default : io_inputs_0_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(io_inputs_0_payload_roundMode) - FpuRoundMode_RNE : io_inputs_0_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_inputs_0_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_inputs_0_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_inputs_0_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_inputs_0_payload_roundMode_string = "RMM"; - default : io_inputs_0_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(io_output_payload_opcode) - FpuOpcode_LOAD : io_output_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_output_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_output_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_output_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_output_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_output_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_output_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_output_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_output_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_output_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_output_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_output_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_output_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_output_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_output_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_output_payload_opcode_string = "FCVT_X_X"; - default : io_output_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_output_payload_format) - FpuFormat_FLOAT : io_output_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : io_output_payload_format_string = "DOUBLE"; - default : io_output_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(io_output_payload_roundMode) - FpuRoundMode_RNE : io_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : io_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : io_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : io_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : io_output_payload_roundMode_string = "RMM"; - default : io_output_payload_roundMode_string = "???"; - endcase - end - always @(*) begin - case(_zz_io_output_payload_opcode) - FpuOpcode_LOAD : _zz_io_output_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : _zz_io_output_payload_opcode_string = "STORE "; - FpuOpcode_MUL : _zz_io_output_payload_opcode_string = "MUL "; - FpuOpcode_ADD : _zz_io_output_payload_opcode_string = "ADD "; - FpuOpcode_FMA : _zz_io_output_payload_opcode_string = "FMA "; - FpuOpcode_I2F : _zz_io_output_payload_opcode_string = "I2F "; - FpuOpcode_F2I : _zz_io_output_payload_opcode_string = "F2I "; - FpuOpcode_CMP : _zz_io_output_payload_opcode_string = "CMP "; - FpuOpcode_DIV : _zz_io_output_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : _zz_io_output_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : _zz_io_output_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : _zz_io_output_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : _zz_io_output_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : _zz_io_output_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : _zz_io_output_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : _zz_io_output_payload_opcode_string = "FCVT_X_X"; - default : _zz_io_output_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(_zz_io_output_payload_format) - FpuFormat_FLOAT : _zz_io_output_payload_format_string = "FLOAT "; - FpuFormat_DOUBLE : _zz_io_output_payload_format_string = "DOUBLE"; - default : _zz_io_output_payload_format_string = "??????"; - endcase - end - always @(*) begin - case(_zz_io_output_payload_roundMode) - FpuRoundMode_RNE : _zz_io_output_payload_roundMode_string = "RNE"; - FpuRoundMode_RTZ : _zz_io_output_payload_roundMode_string = "RTZ"; - FpuRoundMode_RDN : _zz_io_output_payload_roundMode_string = "RDN"; - FpuRoundMode_RUP : _zz_io_output_payload_roundMode_string = "RUP"; - FpuRoundMode_RMM : _zz_io_output_payload_roundMode_string = "RMM"; - default : _zz_io_output_payload_roundMode_string = "???"; - endcase - end + buffers_0 = $urandom; + buffers_1 = $urandom; `endif - - assign locked = 1'b0; - assign maskRouted_0 = (locked ? maskLocked_0 : maskProposal_0); - assign _zz_maskProposal_0 = io_inputs_0_valid; - assign _zz_maskProposal_0_1 = {_zz_maskProposal_0,_zz_maskProposal_0}; - assign _zz_maskProposal_0_2 = (_zz_maskProposal_0_1 & (~ _zz__zz_maskProposal_0_2)); - assign maskProposal_0 = _zz_maskProposal_0_3[0]; - assign io_output_valid = (io_inputs_0_valid && maskRouted_0); - assign _zz_io_output_payload_opcode = io_inputs_0_payload_opcode; - assign _zz_io_output_payload_format = io_inputs_0_payload_format; - assign _zz_io_output_payload_roundMode = io_inputs_0_payload_roundMode; - assign io_output_payload_opcode = _zz_io_output_payload_opcode; - assign io_output_payload_arg = io_inputs_0_payload_arg; - assign io_output_payload_rs1 = io_inputs_0_payload_rs1; - assign io_output_payload_rs2 = io_inputs_0_payload_rs2; - assign io_output_payload_rs3 = io_inputs_0_payload_rs3; - assign io_output_payload_rd = io_inputs_0_payload_rd; - assign io_output_payload_format = _zz_io_output_payload_format; - assign io_output_payload_roundMode = _zz_io_output_payload_roundMode; - assign io_inputs_0_ready = (maskRouted_0 && io_output_ready); - assign io_chosenOH = maskRouted_0; - always @(posedge clk or posedge reset) begin - if(reset) begin - maskLocked_0 <= 1'b1; - end else begin - if(io_output_valid) begin - maskLocked_0 <= maskRouted_0; - end - end end - -endmodule - -module StreamFork ( - input io_input_valid, - output io_input_ready, - input [3:0] io_input_payload_opcode, - input [4:0] io_input_payload_rd, - input io_input_payload_write, - input [31:0] io_input_payload_value, - output io_outputs_0_valid, - input io_outputs_0_ready, - output [3:0] io_outputs_0_payload_opcode, - output [4:0] io_outputs_0_payload_rd, - output io_outputs_0_payload_write, - output [31:0] io_outputs_0_payload_value, - output io_outputs_1_valid, - input io_outputs_1_ready, - output [3:0] io_outputs_1_payload_opcode, - output [4:0] io_outputs_1_payload_rd, - output io_outputs_1_payload_write, - output [31:0] io_outputs_1_payload_value -); - localparam FpuOpcode_LOAD = 4'd0; - localparam FpuOpcode_STORE = 4'd1; - localparam FpuOpcode_MUL = 4'd2; - localparam FpuOpcode_ADD = 4'd3; - localparam FpuOpcode_FMA = 4'd4; - localparam FpuOpcode_I2F = 4'd5; - localparam FpuOpcode_F2I = 4'd6; - localparam FpuOpcode_CMP = 4'd7; - localparam FpuOpcode_DIV = 4'd8; - localparam FpuOpcode_SQRT = 4'd9; - localparam FpuOpcode_MIN_MAX = 4'd10; - localparam FpuOpcode_SGNJ = 4'd11; - localparam FpuOpcode_FMV_X_W = 4'd12; - localparam FpuOpcode_FMV_W_X = 4'd13; - localparam FpuOpcode_FCLASS = 4'd14; - localparam FpuOpcode_FCVT_X_X = 4'd15; - - `ifndef SYNTHESIS - reg [63:0] io_input_payload_opcode_string; - reg [63:0] io_outputs_0_payload_opcode_string; - reg [63:0] io_outputs_1_payload_opcode_string; - `endif - - - `ifndef SYNTHESIS - always @(*) begin - case(io_input_payload_opcode) - FpuOpcode_LOAD : io_input_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_input_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_input_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_input_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_input_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_input_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_input_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_input_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_input_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_input_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_input_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_input_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_input_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_input_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_input_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_input_payload_opcode_string = "FCVT_X_X"; - default : io_input_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_outputs_0_payload_opcode) - FpuOpcode_LOAD : io_outputs_0_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_outputs_0_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_outputs_0_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_outputs_0_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_outputs_0_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_outputs_0_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_outputs_0_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_outputs_0_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_outputs_0_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_outputs_0_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_outputs_0_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_outputs_0_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_outputs_0_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_outputs_0_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_outputs_0_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_outputs_0_payload_opcode_string = "FCVT_X_X"; - default : io_outputs_0_payload_opcode_string = "????????"; - endcase - end - always @(*) begin - case(io_outputs_1_payload_opcode) - FpuOpcode_LOAD : io_outputs_1_payload_opcode_string = "LOAD "; - FpuOpcode_STORE : io_outputs_1_payload_opcode_string = "STORE "; - FpuOpcode_MUL : io_outputs_1_payload_opcode_string = "MUL "; - FpuOpcode_ADD : io_outputs_1_payload_opcode_string = "ADD "; - FpuOpcode_FMA : io_outputs_1_payload_opcode_string = "FMA "; - FpuOpcode_I2F : io_outputs_1_payload_opcode_string = "I2F "; - FpuOpcode_F2I : io_outputs_1_payload_opcode_string = "F2I "; - FpuOpcode_CMP : io_outputs_1_payload_opcode_string = "CMP "; - FpuOpcode_DIV : io_outputs_1_payload_opcode_string = "DIV "; - FpuOpcode_SQRT : io_outputs_1_payload_opcode_string = "SQRT "; - FpuOpcode_MIN_MAX : io_outputs_1_payload_opcode_string = "MIN_MAX "; - FpuOpcode_SGNJ : io_outputs_1_payload_opcode_string = "SGNJ "; - FpuOpcode_FMV_X_W : io_outputs_1_payload_opcode_string = "FMV_X_W "; - FpuOpcode_FMV_W_X : io_outputs_1_payload_opcode_string = "FMV_W_X "; - FpuOpcode_FCLASS : io_outputs_1_payload_opcode_string = "FCLASS "; - FpuOpcode_FCVT_X_X : io_outputs_1_payload_opcode_string = "FCVT_X_X"; - default : io_outputs_1_payload_opcode_string = "????????"; - endcase + assign io_dataOut = buffers_1; + always @(posedge clk) begin + buffers_0 <= io_dataIn; + buffers_1 <= buffers_0; end - `endif - assign io_input_ready = (io_outputs_0_ready && io_outputs_1_ready); - assign io_outputs_0_valid = (io_input_valid && io_input_ready); - assign io_outputs_1_valid = (io_input_valid && io_input_ready); - assign io_outputs_0_payload_opcode = io_input_payload_opcode; - assign io_outputs_0_payload_rd = io_input_payload_rd; - assign io_outputs_0_payload_write = io_input_payload_write; - assign io_outputs_0_payload_value = io_input_payload_value; - assign io_outputs_1_payload_opcode = io_input_payload_opcode; - assign io_outputs_1_payload_rd = io_input_payload_rd; - assign io_outputs_1_payload_write = io_input_payload_write; - assign io_outputs_1_payload_value = io_input_payload_value; endmodule diff --git a/clash-vexriscv/example-cpu/VexRiscvWithDebug.yaml b/clash-vexriscv/example-cpu/VexRiscvWithDebug.yaml new file mode 100644 index 0000000..3eeb252 --- /dev/null +++ b/clash-vexriscv/example-cpu/VexRiscvWithDebug.yaml @@ -0,0 +1 @@ +debug: !!vexriscv.DebugReport {hardwareBreakpointCount: 0} diff --git a/clash-vexriscv/example-cpu/build.sbt b/clash-vexriscv/example-cpu/build.sbt index 9dd4bc8..0321f5f 100644 --- a/clash-vexriscv/example-cpu/build.sbt +++ b/clash-vexriscv/example-cpu/build.sbt @@ -17,7 +17,8 @@ lazy val root = (project in file(".")) libraryDependencies ++= Seq( "com.github.spinalhdl" % "spinalhdl-core_2.11" % spinalVersion, "com.github.spinalhdl" % "spinalhdl-lib_2.11" % spinalVersion, - compilerPlugin("com.github.spinalhdl" % "spinalhdl-idsl-plugin_2.11" % spinalVersion) + compilerPlugin("com.github.spinalhdl" % "spinalhdl-idsl-plugin_2.11" % spinalVersion), + "org.yaml" % "snakeyaml" % "1.8" ) ) diff --git a/clash-vexriscv/example-cpu/src/main/scala/example/ExampleCpu.scala b/clash-vexriscv/example-cpu/src/main/scala/example/ExampleCpu.scala index 0516325..15c58c6 100644 --- a/clash-vexriscv/example-cpu/src/main/scala/example/ExampleCpu.scala +++ b/clash-vexriscv/example-cpu/src/main/scala/example/ExampleCpu.scala @@ -6,6 +6,9 @@ package example import spinal.core._ import spinal.lib._ +import spinal.lib.com.jtag.Jtag +import spinal.lib.bus.wishbone.{Wishbone, WishboneConfig} + import vexriscv.plugin._ import vexriscv.{VexRiscv, VexRiscvConfig, plugin} import vexriscv.ip.{DataCacheConfig} @@ -13,95 +16,85 @@ import vexriscv.ip.fpu.FpuParameter object ExampleCpu extends App { def cpu() : VexRiscv = { - val config = VexRiscvConfig( - plugins = List( - new IBusSimplePlugin( - resetVector = 0x20000000l, - cmdForkOnSecondStage = false, - cmdForkPersistence = false, - prediction = NONE, - catchAccessFault = true, - compressedGen = true // C extension - ), - - // new DBusSimplePlugin( - // catchAddressMisaligned = true, - // catchAccessFault = true - // ), - - new DBusCachedPlugin( - /* - config = new DataCacheConfig( - cacheSize = 2048, - bytePerLine = 32, - wayCount = 1, - addressWidth = 32, - cpuDataWidth = 32, - memDataWidth = 32, - catchAccessError = true, - catchIllegal = true, - catchUnaligned = true - ) - */ - config = new DataCacheConfig( - cacheSize = 8, - bytePerLine = 8, - wayCount = 1, - addressWidth = 32, - cpuDataWidth = 32, - memDataWidth = 32, - catchAccessError = true, - catchIllegal = true, - catchUnaligned = true - ) - ), - - new StaticMemoryTranslatorPlugin( - ioRange = _ => True - ), - new CsrPlugin( - CsrPluginConfig.smallest.copy(ebreakGen = true, mtvecAccess = CsrAccess.READ_WRITE) - ), - new DecoderSimplePlugin( - catchIllegalInstruction = true - ), - new RegFilePlugin( - regFileReadyKind = plugin.SYNC, - zeroBoot = false - ), - new IntAluPlugin, - new SrcPlugin( - separatedAddSub = false, - executeInsertion = false - ), + val config = VexRiscvConfig( + plugins = List( + new IBusSimplePlugin( + resetVector = 0x20000000l, + cmdForkOnSecondStage = false, + cmdForkPersistence = false, + prediction = STATIC, + // Trap when an iBus access returns an error. + catchAccessFault = true, + compressedGen = true + ), + new DBusSimplePlugin( + // Trap when a load or store access is misaligned. + catchAddressMisaligned = true, + // Trap when a load or store access results in a bus error + catchAccessFault = true + ), - // M extension - new MulPlugin, - new DivPlugin, + new CsrPlugin( + // CsrPluginConfig.smallest.copy(ebreakGen = true, mtvecAccess = CsrAccess.READ_WRITE) + CsrPluginConfig( + catchIllegalAccess = false, + mvendorid = null, + marchid = null, + mimpid = null, + mhartid = null, + misaExtensionsInit = 66, + misaAccess = CsrAccess.NONE, + mtvecAccess = CsrAccess.READ_WRITE, + mtvecInit = 0x00000020, + mepcAccess = CsrAccess.READ_WRITE, + mscratchGen = false, + mcauseAccess = CsrAccess.READ_ONLY, + mbadaddrAccess = CsrAccess.READ_ONLY, + mcycleAccess = CsrAccess.NONE, + minstretAccess = CsrAccess.NONE, + ecallGen = false, + ebreakGen = true, + wfiGenAsWait = false, + ucycleAccess = CsrAccess.READ_ONLY, + uinstretAccess = CsrAccess.NONE + ) + ), + new DecoderSimplePlugin( + catchIllegalInstruction = true + ), + new RegFilePlugin( + regFileReadyKind = plugin.SYNC, + zeroBoot = false + ), + new IntAluPlugin, + new SrcPlugin( + separatedAddSub = false, + executeInsertion = false + ), - // F extension - new FpuPlugin( - p = FpuParameter( - withDouble = false // enable for D extension - ) - ), + // M extension + new MulPlugin, + new DivPlugin, - new LightShifterPlugin, - new HazardSimplePlugin( - bypassExecute = false, - bypassMemory = false, - bypassWriteBack = false, - bypassWriteBackBuffer = false, - pessimisticUseSrc = false, - pessimisticWriteRegFile = false, - pessimisticAddressMatch = false - ), - new BranchPlugin( - earlyBranch = false, - catchAddressMisaligned = true + new LightShifterPlugin, + new HazardSimplePlugin( + bypassExecute = true, + bypassMemory = true, + bypassWriteBack = true, + bypassWriteBackBuffer = true, + pessimisticUseSrc = false, + pessimisticWriteRegFile = false, + pessimisticAddressMatch = false + ), + new BranchPlugin( + earlyBranch = false, + catchAddressMisaligned = true + ), + new DebugPlugin(ClockDomain.current), + new YamlPlugin("ExampleCpu.yaml") ) - ) + ) val cpu = new VexRiscv(config) @@ -121,6 +114,12 @@ object ExampleCpu extends App { plugin.dBus.setAsDirectionLess() master(plugin.dBus.toWishbone()).setName("dBusWishbone") } + + case plugin: DebugPlugin => plugin.debugClockDomain { + plugin.io.bus.setAsDirectionLess() + val jtag = slave(new Jtag()).setName("jtag") + jtag <> plugin.io.bus.fromJtag() + } case _ => } } diff --git a/clash-vexriscv/src/VexRiscv.hs b/clash-vexriscv/src/VexRiscv.hs index adf4ba7..366fa7b 100644 --- a/clash-vexriscv/src/VexRiscv.hs +++ b/clash-vexriscv/src/VexRiscv.hs @@ -7,6 +7,7 @@ {-# LANGUAGE MagicHash #-} {-# LANGUAGE TemplateHaskellQuotes #-} {-# LANGUAGE QuasiQuotes #-} +-- {-# LANGUAGE AllowAmbiguousTypes #-} {-# OPTIONS_GHC -fconstraint-solver-iterations=10 #-} @@ -25,6 +26,7 @@ import Foreign.Storable import GHC.IO (unsafePerformIO, unsafeInterleaveIO) import GHC.Stack (HasCallStack) import Language.Haskell.TH.Syntax +import Protocols import Protocols.Wishbone import VexRiscv.ClockTicks @@ -34,7 +36,20 @@ import VexRiscv.VecToTuple import qualified VexRiscv.FFI as FFI -data Input = Input +data JtagIn = JtagIn + { testClock :: "TCK" ::: Bit + , testModeSelect :: "TMS" ::: Bit + , testDataIn :: "TDI" ::: Bit + } + deriving (Generic, Eq, NFDataX, ShowX, BitPack) + +data JtagOut = JtagOut + { testDataOut :: "TDO" ::: Bit + , debugReset :: "RST" ::: Bit + } + deriving (Generic, NFDataX, ShowX, Eq, BitPack) + +data CpuIn = CpuIn { timerInterrupt :: "TIMER_INTERRUPT" ::: Bit , externalInterrupt :: "EXTERNAL_INTERRUPT" ::: Bit , softwareInterrupt :: "SOFTWARE_INTERRUPT" ::: Bit @@ -43,12 +58,20 @@ data Input = Input } deriving (Generic, NFDataX, ShowX, Eq, BitPack) -data Output = Output +data CpuOut = CpuOut { iBusWbM2S :: "IBUS_OUT_" ::: WishboneM2S 30 4 (BitVector 32) , dBusWbM2S :: "DBUS_OUT_" ::: WishboneM2S 30 4 (BitVector 32) } deriving (Generic, NFDataX, ShowX, Eq, BitPack) + +data Jtag (dom :: Domain) + +instance Protocol (Jtag dom) where + type Fwd (Jtag dom) = Signal dom JtagOut + type Bwd (Jtag dom) = Signal dom JtagIn + + -- When passing S2M values from Haskell to VexRiscv over the FFI, undefined -- bits/values cause errors when forcing their evaluation to something that can -- be passed through the FFI. @@ -62,9 +85,19 @@ defaultX dflt val | hasUndefined val = dflt | otherwise = val -vexRiscv :: (HasCallStack, HiddenClockResetEnable dom) => Signal dom Input -> Signal dom Output -vexRiscv input = - Output <$> +vexRiscv :: + forall dom . + ( HasCallStack + , KnownDomain dom) => + Clock dom -> + Reset dom -> + Signal dom CpuIn -> + Signal dom JtagIn -> + ( Signal dom CpuOut + , Signal dom JtagOut + ) +vexRiscv clk rst cpuInput jtagInput = + ( CpuOut <$> (WishboneM2S <$> iBus_ADR <*> iBus_DAT_MOSI @@ -88,10 +121,19 @@ vexRiscv input = <*> (unpack <$> dBus_CTI) <*> (unpack <$> dBus_BTE) ) + , JtagOut <$> jtag_TDO1 <*> debug_resetOut1 + ) where + + jtag_TDO1 = + jtag_TDO + + debug_resetOut1 = + debug_resetOut + (unbundle -> (timerInterrupt, externalInterrupt, softwareInterrupt, iBusS2M, dBusS2M)) - = (\(Input a b c d e) -> (a, b, c, d, e)) <$> input + = (\(CpuIn a b c d e) -> (a, b, c, d, e)) <$> cpuInput (unbundle -> (iBus_DAT_MISO, iBus_ACK, iBus_ERR)) = (\(WishboneS2M a b c _ _) -> (a, b, c)) @@ -105,11 +147,16 @@ vexRiscv input = . (if clashSimulation then makeDefined else id) <$> dBusS2M + (unbundle -> (jtag_TCK, jtag_TMS, jtag_TDI)) + = bitCoerce <$> jtagInput + sourcePath = $(do cpuSrcPath <- runIO $ getPackageRelFilePath "example-cpu/VexRiscv.v" pure $ LitE $ StringL cpuSrcPath ) + -- TODO: Remove need for 'vexRiscv#' by doing construction / deconstruction of + -- product types in HDL using BlackBoxHaskell functions. ( iBus_CYC , iBus_STB , iBus_WE @@ -126,7 +173,9 @@ vexRiscv input = , dBus_SEL , dBus_CTI , dBus_BTE - ) = vexRiscv# sourcePath hasClock hasReset + , debug_resetOut + , jtag_TDO + ) = vexRiscv# sourcePath clk rst timerInterrupt externalInterrupt softwareInterrupt @@ -139,8 +188,9 @@ vexRiscv input = dBus_ERR dBus_DAT_MISO - - + jtag_TCK + jtag_TMS + jtag_TDI vexRiscv# @@ -161,6 +211,11 @@ vexRiscv# -> Signal dom Bool -- ^ dBus_ERR -> Signal dom (BitVector 32) -- ^ dBus_DAT_MISO + -> Signal dom Bit -- ^ jtag_TCK + -> Signal dom Bit -- ^ jtag_TMS + -> Signal dom Bit -- ^ jtag_TDI + + -- output signals -> ( @@ -183,6 +238,9 @@ vexRiscv# , Signal dom (BitVector 4) -- ^ dBus_SEL , Signal dom (BitVector 3) -- ^ dBus_CTI , Signal dom (BitVector 2) -- ^ dBus_BTE + + , Signal dom Bit -- ^ debug_resetOut + , Signal dom Bit -- ^ jtag_TDO ) vexRiscv# !_sourcePath clk rst0 timerInterrupt @@ -194,7 +252,11 @@ vexRiscv# !_sourcePath clk rst0 dBus_ACK dBus_ERR - dBus_DAT_MISO = unsafePerformIO $ do + dBus_DAT_MISO + + jtag_TCK + jtag_TMS + jtag_TDI = unsafePerformIO $ do (v, initStage1, initStage2, stepRising, stepFalling, _shutDown) <- vexCPU let @@ -211,6 +273,9 @@ vexRiscv# !_sourcePath clk rst0 <*> (boolToBit <$> dBus_ACK) <*> (unpack <$> dBus_DAT_MISO) <*> (boolToBit <$> dBus_ERR) + <*> jtag_TCK + <*> jtag_TMS + <*> jtag_TDI simInitThenCycles :: Signal dom NON_COMB_INPUT -> @@ -286,12 +351,20 @@ vexRiscv# !_sourcePath clk rst0 , truncateB . pack <$> dBus_SEL , truncateB . pack <$> dBus_CTI , truncateB . pack <$> dBus_BTE + + -- JTAG + , FFI.jtag_debug_resetOut <$> output + , FFI.jtag_TDO <$> output ) {-# NOINLINE vexRiscv# #-} {-# ANN vexRiscv# ( let primName = 'vexRiscv# - ( _ + + + ( + -- ARGs + _ , srcPath , clk , rst @@ -304,9 +377,12 @@ vexRiscv# !_sourcePath clk rst0 , dBus_ACK , dBus_ERR , dBus_DAT_MISO - ) = vecToTuple (indicesI @13) + , jtag_TCK + , jtag_TMS + , jtag_TDI - ( iBus_CYC + -- GENSYMs + , iBus_CYC , iBus_STB , iBus_WE , iBus_ADR @@ -322,9 +398,11 @@ vexRiscv# !_sourcePath clk rst0 , dBus_SEL , dBus_CTI , dBus_BTE - ) = vecToTuple $ (\x -> extend @_ @16 @13 x + 1) <$> indicesI @16 + , debug_resetOut + , jtag_TDO - cpu = extend @_ @_ @1 dBus_BTE + 1 + , cpu + ) = vecToTuple $ indicesI @35 in InlineYamlPrimitive [Verilog] [__i| BlackBox: @@ -353,6 +431,9 @@ vexRiscv# !_sourcePath clk rst0 wire [2:0] ~GENSYM[dBus_CTI][#{dBus_CTI}]; wire [1:0] ~GENSYM[dBus_BTE][#{dBus_BTE}]; + wire ~GENSYM[debug_resetOut][#{debug_resetOut}]; + wire ~GENSYM[jtag_TDO][#{jtag_TDO}]; + VexRiscv ~GENSYM[cpu][#{cpu}] ( .timerInterrupt ( ~ARG[#{timerInterrupt}] ), .externalInterrupt ( ~ARG[#{externalInterrupt}] ), @@ -382,6 +463,13 @@ vexRiscv# !_sourcePath clk rst0 .dBusWishbone_CTI ( ~SYM[#{dBus_CTI}] ), .dBusWishbone_BTE ( ~SYM[#{dBus_BTE}] ), + .jtag_tms ( ~ARG[#{jtag_TMS}]), + .jtag_tdi ( ~ARG[#{jtag_TDI}]), + .jtag_tck ( ~ARG[#{jtag_TCK}]), + .jtag_tdo ( ~SYM[#{jtag_TDO}] ), + + .debug_resetOut ( ~SYM[#{debug_resetOut}] ), + .clk ( ~ARG[#{clk}] ), .reset ( ~ARG[#{rst}] ) ); @@ -402,7 +490,9 @@ vexRiscv# !_sourcePath clk rst0 ~SYM[#{dBus_DAT_MOSI}], ~SYM[#{dBus_SEL}], ~SYM[#{dBus_CTI}], - ~SYM[#{dBus_BTE}] + ~SYM[#{dBus_BTE}], + ~SYM[#{debug_resetOut}], + ~SYM[#{jtag_TDO}] }; // vexRiscv end diff --git a/clash-vexriscv/src/VexRiscv/FFI.hsc b/clash-vexriscv/src/VexRiscv/FFI.hsc index 9fd456c..572cad8 100644 --- a/clash-vexriscv/src/VexRiscv/FFI.hsc +++ b/clash-vexriscv/src/VexRiscv/FFI.hsc @@ -18,6 +18,8 @@ import Data.Word data VexRiscv +data VexRiscvJtagBridge + foreign import ccall unsafe "vexr_init" vexrInit :: IO (Ptr VexRiscv) foreign import ccall unsafe "vexr_shutdown" vexrShutdown :: Ptr VexRiscv -> IO () @@ -26,6 +28,10 @@ foreign import ccall unsafe "vexr_init_stage2" vexrInitStage2 :: Ptr VexRiscv -> foreign import ccall unsafe "vexr_step_rising_edge" vexrStepRisingEdge :: Ptr VexRiscv -> Word64 -> Ptr NON_COMB_INPUT -> Ptr OUTPUT -> IO () foreign import ccall unsafe "vexr_step_falling_edge" vexrStepFallingEdge :: Ptr VexRiscv -> Word64 -> Ptr COMB_INPUT -> IO () +foreign import ccall unsafe "vexr_jtag_bridge_init" vexrJtagBridgeInit :: Word16 -> IO (Ptr VexRiscvJtagBridge) +foreign import ccall unsafe "vexr_jtag_bridge_step" vexrJtagBridgeStep :: Ptr VexRiscvJtagBridge -> Ptr JTAG_OUTPUT -> Ptr JTAG_INPUT -> IO () +foreign import ccall unsafe "vexr_jtag_bridge_shutdown" vexrJtagBridgeShutdown :: Ptr VexRiscvJtagBridge -> IO () + -- | CPU input that cannot combinatorially depend on the CPU output data NON_COMB_INPUT = NON_COMB_INPUT { reset :: Bit @@ -43,6 +49,10 @@ data COMB_INPUT = COMB_INPUT , dBusWishbone_ACK :: Bit , dBusWishbone_DAT_MISO :: Word32 , dBusWishbone_ERR :: Bit + + , jtag_TCK :: Bit + , jtag_TMS :: Bit + , jtag_TDI :: Bit } deriving (Show) @@ -64,6 +74,22 @@ data OUTPUT = OUTPUT , dBusWishbone_SEL :: Word8 , dBusWishbone_CTI :: Word8 , dBusWishbone_BTE :: Word8 + + , jtag_debug_resetOut :: Bit + , jtag_TDO :: Bit + } + deriving (Show) + +data JTAG_INPUT = JTAG_INPUT + { tck :: Bit + , tms :: Bit + , tdi :: Bit + } + deriving (Show) + +data JTAG_OUTPUT = JTAG_OUTPUT + { debug_resetOut :: Bit + , tdo :: Bit } deriving (Show) @@ -102,6 +128,9 @@ instance Storable COMB_INPUT where <*> (#peek COMB_INPUT, dBusWishbone_ACK) ptr <*> (#peek COMB_INPUT, dBusWishbone_DAT_MISO) ptr <*> (#peek COMB_INPUT, dBusWishbone_ERR) ptr + <*> (#peek COMB_INPUT, jtag_TCK) ptr + <*> (#peek COMB_INPUT, jtag_TMS) ptr + <*> (#peek COMB_INPUT, jtag_TDI) ptr {-# INLINE poke #-} poke ptr this = do @@ -112,6 +141,10 @@ instance Storable COMB_INPUT where (#poke COMB_INPUT, dBusWishbone_ACK) ptr (dBusWishbone_ACK this) (#poke COMB_INPUT, dBusWishbone_DAT_MISO) ptr (dBusWishbone_DAT_MISO this) (#poke COMB_INPUT, dBusWishbone_ERR) ptr (dBusWishbone_ERR this) + + (#poke COMB_INPUT, jtag_TCK) ptr (jtag_TCK this) + (#poke COMB_INPUT, jtag_TMS) ptr (jtag_TMS this) + (#poke COMB_INPUT, jtag_TDI) ptr (jtag_TDI this) return () instance Storable OUTPUT where @@ -137,6 +170,9 @@ instance Storable OUTPUT where <*> (#peek OUTPUT, dBusWishbone_CTI) ptr <*> (#peek OUTPUT, dBusWishbone_BTE) ptr + <*> (#peek OUTPUT, jtag_debug_resetOut) ptr + <*> (#peek OUTPUT, jtag_TDO) ptr + {-# INLINE poke #-} poke ptr this = do (#poke OUTPUT, iBusWishbone_CYC) ptr (iBusWishbone_CYC this) @@ -156,4 +192,36 @@ instance Storable OUTPUT where (#poke OUTPUT, dBusWishbone_SEL) ptr (dBusWishbone_SEL this) (#poke OUTPUT, dBusWishbone_CTI) ptr (dBusWishbone_CTI this) (#poke OUTPUT, dBusWishbone_BTE) ptr (dBusWishbone_BTE this) + + (#poke OUTPUT, jtag_debug_resetOut) ptr (jtag_debug_resetOut this) + (#poke OUTPUT, jtag_TDO) ptr (jtag_TDO this) + return () + +instance Storable JTAG_OUTPUT where + alignment _ = #alignment JTAG_OUTPUT + sizeOf _ = #size JTAG_OUTPUT + {-# INLINE peek #-} + peek ptr = const JTAG_OUTPUT <$> pure () + <*> (#peek JTAG_OUTPUT, debug_resetOut) ptr + <*> (#peek JTAG_OUTPUT, tdo) ptr + + {-# INLINE poke #-} + poke ptr this = do + (#poke JTAG_OUTPUT, debug_resetOut) ptr (debug_resetOut this) + (#poke JTAG_OUTPUT, tdo) ptr (tdo this) + +instance Storable JTAG_INPUT where + alignment _ = #alignment JTAG_INPUT + sizeOf _ = #size JTAG_INPUT + {-# INLINE peek #-} + peek ptr = const JTAG_INPUT <$> pure () + <*> (#peek JTAG_INPUT, tck) ptr + <*> (#peek JTAG_INPUT, tms) ptr + <*> (#peek JTAG_INPUT, tdi) ptr + + {-# INLINE poke #-} + poke ptr this = do + (#poke JTAG_INPUT, tck) ptr (tck this) + (#poke JTAG_INPUT, tms) ptr (tms this) + (#poke JTAG_INPUT, tdi) ptr (tdi this) return () diff --git a/clash-vexriscv/src/VexRiscv/JtagTcpBridge.hs b/clash-vexriscv/src/VexRiscv/JtagTcpBridge.hs new file mode 100644 index 0000000..eb0f011 --- /dev/null +++ b/clash-vexriscv/src/VexRiscv/JtagTcpBridge.hs @@ -0,0 +1,50 @@ +-- SPDX-FileCopyrightText: 2023 Google LLC +-- +-- SPDX-License-Identifier: Apache-2.0 + +{-# LANGUAGE RecordWildCards #-} +module VexRiscv.JtagTcpBridge (vexrJtagBridge, defaultIn) where + +import Clash.Prelude + +import Clash.Signal.Internal + +import VexRiscv +import VexRiscv.FFI + +import Foreign +import System.IO.Unsafe (unsafePerformIO) +import Network.Socket (PortNumber) + +defaultIn :: JtagIn +defaultIn = JtagIn { testClock = low, testModeSelect = low, testDataIn = low } + +{-# NOINLINE inner #-} +inner :: (t -> IO JtagIn) -> Signal dom t -> Signal dom JtagIn +inner jtagBridgeStep (o :- outs) = unsafePerformIO $ do + in' <- jtagBridgeStep o + let ins' = inner jtagBridgeStep outs + pure $ in' :- (in' `deepseqX` ins') + +vexrJtagBridge :: PortNumber -> Signal dom JtagOut -> Signal dom JtagIn +vexrJtagBridge port out = inner jtagBridgeStep out + where + (_, jtagBridgeStep) = unsafePerformIO $ vexrJtagBridge' port + +vexrJtagBridge' :: + PortNumber -> + IO ( IO () -- ^ delete function + , JtagOut -> IO JtagIn -- ^ step function + ) +vexrJtagBridge' port = do + bridge <- vexrJtagBridgeInit (fromIntegral port) + let + shutDown = vexrJtagBridgeShutdown bridge + + step JtagOut{..} = alloca $ \outFFI -> alloca $ \inFFI -> do + poke outFFI (JTAG_OUTPUT debugReset testDataOut) + vexrJtagBridgeStep bridge outFFI inFFI + JTAG_INPUT{..} <- peek inFFI + let input = JtagIn { testClock = tck, testModeSelect = tms, testDataIn = tdi } + pure input + pure (shutDown, step) diff --git a/clash-vexriscv/src/VexRiscv/JtagTcpBridgeHaskell.hs b/clash-vexriscv/src/VexRiscv/JtagTcpBridgeHaskell.hs new file mode 100644 index 0000000..3c6092d --- /dev/null +++ b/clash-vexriscv/src/VexRiscv/JtagTcpBridgeHaskell.hs @@ -0,0 +1,186 @@ +-- SPDX-FileCopyrightText: 2023 Google LLC +-- +-- SPDX-License-Identifier: Apache-2.0 + +module VexRiscv.JtagTcpBridge where + +import Clash.Prelude + +import Clash.Signal.Internal +import Network.Socket +import Protocols +import Protocols.Internal (CSignal(..), Reverse) +import VexRiscv (JtagIn(..), JtagOut(..), Jtag) +import Control.Concurrent (MVar, forkIO, newEmptyMVar, putMVar, takeMVar, tryTakeMVar) +import Control.Monad (when) +import Network.Socket.ByteString (sendAll, recv) + +import qualified Data.ByteString as BS +import System.IO.Unsafe (unsafePerformIO) +import Debug.Trace (trace) + +data NetworkThreadToMainMsg + = Connected + | Disconnected + | DataReceived [BitVector 8] + +data MainToNetworkThreadMsg + = ReadMore + | Send (BitVector 8) + +data NetworkThreadState + = NoClient + | PerformRead Socket + | WaitForNextRead Socket + deriving (Show) + +data MainThreadState + = MDisconnected + | MWaitForRead + | MProcessing (BitVector 2) [BitVector 8] + deriving (Show) + +jtagTcpBridge :: + (HiddenClockResetEnable dom) => + PortNumber -> + Circuit + (Jtag dom, Reverse (CSignal dom Bool)) + () +jtagTcpBridge port = + Circuit $ \((jtagOut, _), ()) -> unsafePerformIO $ do + (enable, jtagIn) <- jtagTcpBridge' port jtagOut + pure ((jtagIn, CSignal $ fromEnable enable), ()) + +jtagTcpBridge' :: + (KnownDomain dom) => + PortNumber -> + Signal dom JtagOut -> + IO (Enable dom, Signal dom JtagIn) +jtagTcpBridge' port jtagOut = do + + (n2m, m2n) <- server port + + (unbundle -> (enable, jtagIn)) <- client n2m m2n MDisconnected jtagOut + + pure (toEnable enable, jtagIn) + +{-# NOINLINE jtagTcpBridge' #-} + +server :: PortNumber -> IO (MVar NetworkThreadToMainMsg, MVar MainToNetworkThreadMsg) +server port = withSocketsDo $ do + sock <- setup + + threadToMainChan <- newEmptyMVar + mainToThreadChan <- newEmptyMVar + + let + thread NoClient = do + (clientSock, _) <- accept sock + putMVar threadToMainChan Connected + thread (PerformRead clientSock) + thread (PerformRead clientSock) = do + buf <- recv clientSock 100 + if BS.null buf then do + putMVar threadToMainChan Disconnected + thread NoClient + else do + let dat = pack <$> BS.unpack buf + putMVar threadToMainChan (DataReceived dat) + thread (WaitForNextRead clientSock) + + thread (WaitForNextRead clientSock) = do + msg <- takeMVar mainToThreadChan + case msg of + ReadMore -> thread (PerformRead clientSock) + Send byte -> do + sendAll clientSock (BS.singleton $ unpack byte) + thread (WaitForNextRead clientSock) + + _ <- forkIO $ thread NoClient + + pure (threadToMainChan, mainToThreadChan) + + where + setup = do + sock <- socket AF_INET Stream 0 + + setSocketOption sock NoDelay 0 + + bind sock (SockAddrInet port (tupleToHostAddress (127, 0, 0, 1))) + + listen sock 1 + + pure sock + +defaultIn :: JtagIn +defaultIn = JtagIn { testModeSelect = low, testDataIn = low } + +dbg :: Show a => a -> a +dbg x = + trace (show x) + x + +clientSleep :: BitVector 2 +clientSleep = 4 + +client :: + (KnownDomain dom) => + MVar NetworkThreadToMainMsg -> + MVar MainToNetworkThreadMsg -> + MainThreadState -> + Signal dom JtagOut -> + IO (Signal dom (Bool, JtagIn)) +client n2m m2n MDisconnected (_out :- outs) = do + msg <- tryTakeMVar n2m + case msg of + Nothing -> + pure $ _out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n MDisconnected outs) + Just Connected -> do + pure $ _out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n MWaitForRead outs) + Just Disconnected -> do + errorX "????" + Just (DataReceived _xs) -> do + errorX "????" + +client n2m m2n MWaitForRead (out :- outs) = do + msg <- tryTakeMVar n2m + case msg of + Nothing -> + pure $ out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n MWaitForRead outs) + Just Disconnected -> + pure $ out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n MDisconnected outs) + Just (DataReceived xs) -> + client n2m m2n (MProcessing 0 xs) (out :- outs) + Just Connected -> + errorX "????" + +client n2m m2n (MProcessing _ []) (out :- outs) = do + putMVar m2n ReadMore + pure $ out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n MWaitForRead outs) +client n2m m2n (MProcessing 0 (x:xs)) (out :- outs) = do + let tms = x ! (0 :: Int) + tdi = x ! (1 :: Int) + tck = x ! (3 :: Int) + + sendTdo = bitToBool $ x ! (2 :: Int) + + enable = bitToBool tck + + when sendTdo $ do + let tdo = bitToBool $ testDataOut out + -- putStrLn $ "send TDO " <> show tdo + putMVar m2n $ Send $ boolToBV tdo + + let inDat = JtagIn { testModeSelect = tms, testDataIn = tdi } + + when enable $ do + -- putStrLn "Enable" + -- putStrLn $ "IN " <> showX inDat + pure () + + pure $ (enable, inDat) :- unsafePerformIO (client n2m m2n (MProcessing clientSleep xs) outs) +client n2m m2n (MProcessing n xs) (out :- outs) = do + pure $ out `deepseqX` (False, defaultIn) :- unsafePerformIO (client n2m m2n (MProcessing (n - 1) xs) outs) + + +{-# NOINLINE client #-} diff --git a/clash-vexriscv/src/ffi/impl.cpp b/clash-vexriscv/src/ffi/impl.cpp index 230e2c6..e305f3c 100644 --- a/clash-vexriscv/src/ffi/impl.cpp +++ b/clash-vexriscv/src/ffi/impl.cpp @@ -6,6 +6,31 @@ #include "verilated.h" #include "interface.h" +#include +#include +#include +#include +#include +#include +#include + +typedef struct { + int server_socket, client_handle; + struct sockaddr_in server_addr; + struct sockaddr_storage server_storage; + + uint32_t timer; + socklen_t addr_size; + uint32_t self_sleep; + uint32_t check_new_connections_timer; + uint8_t rx_buffer[100]; + int32_t rx_buffer_size; + int32_t rx_buffer_remaining; + JTAG_INPUT prev_input; + + uint64_t tck_change_counter; +} vexr_jtag_bridge_data; + extern "C" { VVexRiscv* vexr_init(); void vexr_shutdown(VVexRiscv *top); @@ -14,9 +39,15 @@ extern "C" { void vexr_init_stage2(VVexRiscv *top, const COMB_INPUT *input); void vexr_step_rising_edge(VVexRiscv *top, uint64_t time_add, const NON_COMB_INPUT *input, OUTPUT *output); void vexr_step_falling_edge(VVexRiscv *top, uint64_t time_add, const COMB_INPUT *input); + + vexr_jtag_bridge_data *vexr_jtag_bridge_init(uint16_t port); + void vexr_jtag_bridge_step(vexr_jtag_bridge_data *d, const JTAG_OUTPUT *output, JTAG_INPUT *input); + void vexr_jtag_bridge_shutdown(vexr_jtag_bridge_data *bridge_data); } static VerilatedContext* contextp = 0; +static bool set_socket_blocking_enabled(int fd, bool blocking); +static void connection_reset(vexr_jtag_bridge_data *bridge_data); VVexRiscv* vexr_init() { @@ -47,6 +78,10 @@ void set_comb_inputs(VVexRiscv *top, const COMB_INPUT *input) top->dBusWishbone_ACK = input->dBusWishbone_ACK; top->dBusWishbone_DAT_MISO = input->dBusWishbone_DAT_MISO; top->dBusWishbone_ERR = input->dBusWishbone_ERR; + + top->jtag_tck = input->jtag_TCK; + top->jtag_tms = input->jtag_TMS; + top->jtag_tdi = input->jtag_TDI; } // Set all outputs @@ -68,6 +103,9 @@ void set_ouputs(VVexRiscv *top, OUTPUT *output) output->dBusWishbone_SEL = top->dBusWishbone_SEL; output->dBusWishbone_CTI = top->dBusWishbone_CTI; output->dBusWishbone_BTE = top->dBusWishbone_BTE; + + output->jtag_debug_resetOut = top->debug_resetOut; + output->jtag_TDO = top->jtag_tdo; } void vexr_init_stage1(VVexRiscv *top, const NON_COMB_INPUT *input, OUTPUT *output) @@ -127,3 +165,172 @@ void vexr_step_falling_edge(VVexRiscv *top, uint64_t time_add, const COMB_INPUT // Evaluate the simulation top->eval(); } + +vexr_jtag_bridge_data *vexr_jtag_bridge_init(uint16_t port) +{ + vexr_jtag_bridge_data *d = new vexr_jtag_bridge_data; + + d->prev_input = { 0, 0, 0 }; + + d->tck_change_counter = 0; + + d->timer = 0; + d->self_sleep = 0; + d->check_new_connections_timer = 0; + d->rx_buffer_size = 0; + d->rx_buffer_remaining = 0; + + d->server_socket = socket(PF_INET, SOCK_STREAM, 0); + assert(d->server_socket != -1); + int flag = 1; + setsockopt( + d->server_socket, /* socket affected */ + IPPROTO_TCP, /* set option at TCP level */ + TCP_NODELAY, /* name of option */ + (char *) &flag, /* the cast is historical cruft */ + sizeof(int) /* length of option value */ + ); + + set_socket_blocking_enabled(d->server_socket, 0); + + d->server_addr.sin_family = AF_INET; + d->server_addr.sin_port = htons(port); + d->server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); + memset(d->server_addr.sin_zero, '\0', sizeof(d->server_addr.sin_zero)); + + bind( + d->server_socket, + (struct sockaddr *) &d->server_addr, + sizeof(d->server_addr) + ); + + listen(d->server_socket, 1); + + d->client_handle = -1; + d->addr_size = sizeof(d->server_storage); + + return d; +} + +void vexr_jtag_bridge_step(vexr_jtag_bridge_data *d, const JTAG_OUTPUT *output, JTAG_INPUT *input) +{ + const int WAIT_PERIOD = 83333; + // We set the input values to their last here + // so that only the "successful" path has to update them + + *input = d->prev_input; + + if(d->timer != 0) { + d->timer -= 1; + return; + } + d->check_new_connections_timer++; + if (d->check_new_connections_timer == 200) { + d->check_new_connections_timer = 0; + int new_client_handle = accept( + d->server_socket, + (struct sockaddr *) &d->server_storage, + &d->addr_size + ); + if (new_client_handle != -1) { + if(d->client_handle != -1){ + connection_reset(d); + } + d->client_handle = new_client_handle; + printf("\n[JTAG BRIDGE] got new connection\n"); + } else { + if(d->client_handle == -1) + d->self_sleep = 200; + } + } + if (d->self_sleep) { + d->self_sleep--; + } else if (d->client_handle != -1) { + int n; + + if (d->rx_buffer_remaining == 0) { + if (ioctl(d->client_handle, FIONREAD, &n) != 0) { + connection_reset(d); + } else if (n >= 1) { + d->rx_buffer_size = read( + d->client_handle, + &d->rx_buffer, + 100 + ); + if (d->rx_buffer_size < 0) { + connection_reset(d); + } else { + d->rx_buffer_remaining = d->rx_buffer_size; + } + } else { + d->self_sleep = 30; + } + } + + if (d->rx_buffer_remaining != 0){ + uint8_t buffer = d->rx_buffer[d->rx_buffer_size - (d->rx_buffer_remaining--)]; + input->tms = (buffer & 1) != 0; + input->tdi = (buffer & 2) != 0; + input->tck = (buffer & 8) != 0; + + // printf("\n[JTAG_BRIDGE] "); + // printf("%d %d %d %d\n", + // d->tck_change_counter, + // input->jtag_TCK, + // input->jtag_TMS, + // input->jtag_TDI + // ); + + if (input->tck != d->prev_input.tck) { + d->tck_change_counter++; + } + + + + d->prev_input = *input; + if(buffer & 4){ + buffer = (output->tdo != 0); + // printf("\n[JTAG_BRIDGE] [TDO] %d\n", buffer); + if (-1 == send(d->client_handle, &buffer, 1, 0)) { + connection_reset(d); + } + } + } + } + d->timer = 27; // 3; value used by VexRiscv regression test +} + +void vexr_jtag_bridge_shutdown(vexr_jtag_bridge_data *bridge_data) +{ + if (bridge_data->client_handle != -1) { + shutdown(bridge_data->client_handle, SHUT_RDWR); + usleep(100); + } + if (bridge_data->server_socket != -1) { + close(bridge_data->server_socket); + usleep(100); + } +} + + +/** Returns true on success, or false if there was an error */ +static bool set_socket_blocking_enabled(int fd, bool blocking) +{ + if (fd < 0) return false; + +#ifdef WIN32 + unsigned long mode = blocking ? 0 : 1; + return (ioctlsocket(fd, FIONBIO, &mode) == 0) ? true : false; +#else + int flags = fcntl(fd, F_GETFL, 0); + if (flags < 0) return false; + flags = blocking ? (flags&~O_NONBLOCK) : (flags|O_NONBLOCK); + return (fcntl(fd, F_SETFL, flags) == 0) ? true : false; +#endif +} + +static void connection_reset(vexr_jtag_bridge_data *bridge_data) { + printf("[JTAG BRIDGE] closed connection\n"); + shutdown(bridge_data->client_handle, SHUT_RDWR); + bridge_data->client_handle = -1; +} diff --git a/clash-vexriscv/src/ffi/interface.h b/clash-vexriscv/src/ffi/interface.h index e82759a..5cd543e 100644 --- a/clash-vexriscv/src/ffi/interface.h +++ b/clash-vexriscv/src/ffi/interface.h @@ -24,6 +24,10 @@ typedef struct { bit dBusWishbone_ACK; uint32_t dBusWishbone_DAT_MISO; bit dBusWishbone_ERR; + + bit jtag_TCK; + bit jtag_TMS; + bit jtag_TDI; } COMB_INPUT; typedef struct { @@ -44,6 +48,20 @@ typedef struct { uint8_t dBusWishbone_SEL; uint8_t dBusWishbone_CTI; uint8_t dBusWishbone_BTE; + + bit jtag_debug_resetOut; + bit jtag_TDO; } OUTPUT; +typedef struct { + bit tck; + bit tms; + bit tdi; +} JTAG_INPUT; + +typedef struct { + bit debug_resetOut; + bit tdo; +} JTAG_OUTPUT; + #endif diff --git a/debug-test/Cargo.toml b/debug-test/Cargo.toml new file mode 100644 index 0000000..65c1785 --- /dev/null +++ b/debug-test/Cargo.toml @@ -0,0 +1,18 @@ +# SPDX-FileCopyrightText: 2022 Google LLC +# +# SPDX-License-Identifier: CC0-1.0 + +[package] +name = "debug-test" +version = "0.1.0" +edition = "2021" +license = "Apache-2.0" +authors = ["Google LLC"] + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +riscv-rt = "0.11.0" +riscv = "^0.10" +heapless = { version = "0.7", default-features = false } +panic-halt = "0.2.0" diff --git a/debug-test/build.rs b/debug-test/build.rs new file mode 100644 index 0000000..0d6ad00 --- /dev/null +++ b/debug-test/build.rs @@ -0,0 +1,23 @@ +// SPDX-FileCopyrightText: 2022 Google LLC +// +// SPDX-License-Identifier: Apache-2.0 + +use std::env; +use std::fs; +use std::path::Path; + +/// Put the linker script somewhere the linker can find it. +fn main() { + let out_dir = env::var("OUT_DIR").expect("No out dir"); + let dest_path = Path::new(&out_dir).join("memory.x"); + fs::write(dest_path, include_bytes!("memory.x")).expect("Could not write file"); + + if env::var("CARGO_CFG_TARGET_ARCH").unwrap() == "riscv32" { + println!("cargo:rustc-link-arg=-Tmemory.x"); + println!("cargo:rustc-link-arg=-Tlink.x"); // linker script from riscv-rt + } + println!("cargo:rustc-link-search={out_dir}"); + + println!("cargo:rerun-if-changed=memory.x"); + println!("cargo:rerun-if-changed=build.rs"); +} diff --git a/debug-test/memory.x b/debug-test/memory.x new file mode 100644 index 0000000..211d12c --- /dev/null +++ b/debug-test/memory.x @@ -0,0 +1,18 @@ +/* +SPDX-FileCopyrightText: 2022 Google LLC + +SPDX-License-Identifier: CC0-1.0 +*/ + +MEMORY +{ + DATA : ORIGIN = 0x40000000, LENGTH = 512K + INSTR : ORIGIN = 0x20000000, LENGTH = 512K +} + +REGION_ALIAS("REGION_TEXT", INSTR); +REGION_ALIAS("REGION_RODATA", DATA); +REGION_ALIAS("REGION_DATA", DATA); +REGION_ALIAS("REGION_BSS", DATA); +REGION_ALIAS("REGION_HEAP", DATA); +REGION_ALIAS("REGION_STACK", DATA); diff --git a/debug-test/src/bin/print_a.rs b/debug-test/src/bin/print_a.rs new file mode 100644 index 0000000..9e42bc7 --- /dev/null +++ b/debug-test/src/bin/print_a.rs @@ -0,0 +1,28 @@ +// SPDX-FileCopyrightText: 2022 Google LLC +// +// SPDX-License-Identifier: Apache-2.0 + +#![no_std] +#![cfg_attr(not(test), no_main)] + +#[cfg(not(test))] +use riscv_rt::entry; + +#[cfg(not(test))] +extern crate panic_halt; + +const ADDR: *mut u8 = 0x0000_1000 as *mut u8; + +fn print(s: &str) { + for b in s.bytes() { + unsafe { + ADDR.write_volatile(b); + } + } +} + +#[cfg_attr(not(test), entry)] +fn main() -> ! { + print("[CPU] a\n"); + loop {} +} diff --git a/debug-test/src/bin/print_b.rs b/debug-test/src/bin/print_b.rs new file mode 100644 index 0000000..a1437bb --- /dev/null +++ b/debug-test/src/bin/print_b.rs @@ -0,0 +1,28 @@ +// SPDX-FileCopyrightText: 2022 Google LLC +// +// SPDX-License-Identifier: Apache-2.0 + +#![no_std] +#![cfg_attr(not(test), no_main)] + +#[cfg(not(test))] +use riscv_rt::entry; + +#[cfg(not(test))] +extern crate panic_halt; + +const ADDR: *mut u8 = 0x0000_1000 as *mut u8; + +fn print(s: &str) { + for b in s.bytes() { + unsafe { + ADDR.write_volatile(b); + } + } +} + +#[cfg_attr(not(test), entry)] +fn main() -> ! { + print("[CPU] b\n"); + loop {} +} diff --git a/debug-test/src/main.rs b/debug-test/src/main.rs new file mode 100644 index 0000000..de1d685 --- /dev/null +++ b/debug-test/src/main.rs @@ -0,0 +1,106 @@ +// SPDX-FileCopyrightText: 2022 Google LLC +// +// SPDX-License-Identifier: Apache-2.0 + +#![no_std] +#![cfg_attr(not(test), no_main)] + +use core::fmt::Write; + +use heapless::String; +#[cfg(not(test))] +use riscv_rt::entry; + +#[cfg(not(test))] +extern crate panic_halt; + +const ADDR: *mut u8 = 0x0000_1000 as *mut u8; + +fn print(s: &str) { + for b in s.bytes() { + unsafe { + ADDR.write_volatile(b); + } + } +} + +#[cfg_attr(not(test), entry)] +fn main() -> ! { + print("hello, world.\n"); + + print("I am here to be debugged!\n"); + + loop { + for i in 0..30 { + let mut s = String::<16>::new(); + let _ = writeln!(s, "Hey! {i}"); + print(&s); + } + + print("wheeeey!\n"); + + // unsafe { + // riscv::asm::ebreak(); + // } + } +} + +#[export_name = "UserSoft"] +fn user_soft_handler() { + loop { + print("INTERRUPT UserSoft"); + } +} + +#[export_name = "MachineSoft"] +fn machine_soft_handler() { + loop { + print("INTERRUPT MachineSoft"); + } +} + +#[export_name = "UserTimer"] +fn user_timer_handler() { + loop { + print("INTERRUPT UserTimer"); + } +} + +#[export_name = "MachineTimer"] +fn machine_timer_handler() { + loop { + print("INTERRUPT MachineTimer"); + } +} + +#[export_name = "UserExternal"] +fn user_ext_handler() { + loop { + print("INTERRUPT UserExternal"); + } +} + +#[export_name = "MachineExternal"] +fn machine_ext_handler() { + loop { + print("INTERRUPT MachineExternal"); + } +} + +#[export_name = "DefaultHandler"] +fn default_handler() { + loop { + print("INTERRUPT default handler"); + } +} + +#[export_name = "ExceptionHandler"] +fn exception_handler(_trap_frame: &riscv_rt::TrapFrame) -> ! { + riscv::interrupt::free(|| { + print("... caught an exception. Looping forever now.\n"); + }); + loop { + // print(""); + continue; + } +} diff --git a/rust-toolchain.toml b/rust-toolchain.toml index feb678b..22968aa 100644 --- a/rust-toolchain.toml +++ b/rust-toolchain.toml @@ -1,5 +1,5 @@ # SPDX-FileCopyrightText: 2022-2023 Google LLC -# +# # SPDX-License-Identifier: CC0-1.0 [toolchain] diff --git a/shell.nix b/shell.nix index 22dfb2d..714afdd 100644 --- a/shell.nix +++ b/shell.nix @@ -24,6 +24,7 @@ pkgs.mkShell { # VexRiscV needs a special openocd pkgs.openocd-vexriscv + pkgs.gdb # For Cabal to clone git repos pkgs.git diff --git a/vexriscv_gdb.cfg b/vexriscv_gdb.cfg new file mode 100644 index 0000000..623a169 --- /dev/null +++ b/vexriscv_gdb.cfg @@ -0,0 +1,25 @@ +# Assume "print_a" is running on the CPU +file "target/riscv32imc-unknown-none-elf/release/print_a" + +# Work around issues where simulation is too slow to respond to keep-alive messages, +# confusing either OpenOCD or GDB. Note that it will still complain about "missed" +# deadlines, but it won't fail.. +set remotetimeout unlimited + +# Connect to OpenOCD +target extended-remote :3333 + +# List registers +i r + +# Jump to start address, should output "a" +jump *0x20000000 + +# Load program +load "target/riscv32imc-unknown-none-elf/release/print_b" + +# Jump to start address. Should now output "b". +jump *0x20000000 + +# Stop running GDB +quit diff --git a/vexriscv_sim.cfg b/vexriscv_sim.cfg new file mode 100644 index 0000000..1e37791 --- /dev/null +++ b/vexriscv_sim.cfg @@ -0,0 +1,61 @@ +adapter driver jtag_tcp +adapter speed 64000 +transport select jtag + + +set _ENDIAN little +set _TAP_TYPE 1234 + +if { [info exists CPUTAPID] } { + set _CPUTAPID $CPUTAPID +} else { + # set useful default + set _CPUTAPID 0x10001fff +} + +set _CHIPNAME vexrisc_ocd + +# The JTAG TAP itself is given the name "bridge", because it refers to the +# JtagBridge that's part of the VexRiscv/SpinalHDL debug infrastructure. +# In the example design, there is the JtagBridge controls a single CPU, but +# the capability is there for 1 JTAG TAP + JtagBridge to control multiple +# VexRiscv CPUs. +jtag newtap $_CHIPNAME bridge -expected-id $_CPUTAPID -irlen 4 -ircapture 0x1 -irmask 0xF + +# There is 1 CPU controlled by the "bridge" JTAG TAP, "cpu0" +target create $_CHIPNAME.cpu0 vexriscv -endian $_ENDIAN -chain-position $_CHIPNAME.bridge + +# The JtagBridge/SystemDebugger receives commands in a serialized way. It gets synchronized into +# a parallel bus, and a response is received. Along the way, there may be various clock domain +# crossings or pipeline delays. +# readWaitCycles instructs OpenOCD to insert idle JTAG clock cycles before shifting out +# the response. +# There aren't many transactions where read-back throughput is important, so there's little +# points in lowballing this number. +vexriscv readWaitCycles 10 + +# When the Verilog of a SpinalHDL design with one or more VexRiscv CPUs is created, the system +# also creates a .yaml file with information that's sideband information that's important for +# OpenOCD to control the CPU correctly. +# A good example of this are the number of hardware breakpoints that are supported by the CPU. +vexriscv cpuConfigFile clash-vexriscv/example-cpu/ExampleCpu.yaml + +# The rate at which OpenOCD polls active JTAG TAPs to check if there has been a notable +# event. (E.g. to check if the CPU has hit a breakpoint.) +# For some reason, making this number really low has an impact on the CPU while semihosting is +# enabled? +poll_period 50 + +# Initialize all JTAG TAPs and targets. +init + +echo "Halting processor" + +# Halts the CPU and issue a soft reset. +# The DebugPlugin has a resetOut signal that can be used reset external logic. It is not +# used to reset anything inside the VexRiscv itself though. In our small example, +# resetOut is not connected to anything, so we could have used "halt" instead. +# soft_reset_halt +halt + +sleep 1000