From 6ef9395f10c07d30233b0f32585f16f2baca427e Mon Sep 17 00:00:00 2001 From: Paul Mackerras Date: Fri, 20 Dec 2024 17:38:59 +1100 Subject: [PATCH] Remove vestiges of the short (16-bit) multiplier option (#432) These aren't needed, and should have been removed in d1e8e62feee3 ("Remove option for "short" 16x16 bit multiplier", 2022-07-19), but were missed. Signed-off-by: Paul Mackerras --- decode2.vhdl | 1 - execute1.vhdl | 7 +------ 2 files changed, 1 insertion(+), 7 deletions(-) diff --git a/decode2.vhdl b/decode2.vhdl index 80dfabdc..a68bc8bb 100644 --- a/decode2.vhdl +++ b/decode2.vhdl @@ -220,7 +220,6 @@ architecture behaviour of decode2 is OP_SHL => "010", OP_SHR => "010", OP_EXTSWSLI => "010", - OP_MUL_L64 => "011", -- muldiv_result OP_BCREG => "101", -- ramspr_result OP_RFID => "101", OP_ADDG6S => "111", -- misc_result diff --git a/execute1.vhdl b/execute1.vhdl index dacd66c7..cf73de54 100644 --- a/execute1.vhdl +++ b/execute1.vhdl @@ -176,7 +176,6 @@ architecture behaviour of execute1 is signal a_in, b_in, c_in : std_ulogic_vector(63 downto 0); signal cr_in : std_ulogic_vector(31 downto 0); signal xerc_in : xer_common_t; - signal mshort_p : std_ulogic_vector(31 downto 0) := (others => '0'); signal valid_in : std_ulogic; signal ctrl: ctrl_t := ctrl_t_init; @@ -192,7 +191,6 @@ architecture behaviour of execute1 is signal adder_result: std_ulogic_vector(63 downto 0); signal misc_result: std_ulogic_vector(63 downto 0); signal muldiv_result: std_ulogic_vector(63 downto 0); - signal shortmul_result: std_ulogic_vector(63 downto 0); signal spr_result: std_ulogic_vector(63 downto 0); signal next_nia : std_ulogic_vector(63 downto 0); signal s1_sel : std_ulogic_vector(2 downto 0); @@ -601,7 +599,6 @@ begin adder_result when "000", logical_result when "001", rotator_result when "010", - shortmul_result when "011", muldiv_result when "100", ramspr_result when "101", misc_result when others; @@ -772,7 +769,6 @@ begin x_to_mult_32s.subtract <= '0'; x_to_mult_32s.addend <= (others => '0'); - shortmul_result <= std_ulogic_vector(resize(signed(mshort_p), 64)); case ex1.mul_select is when "00" => muldiv_result <= multiply_to_x.result(63 downto 0); @@ -1301,13 +1297,12 @@ begin if e_in.is_32bit = '1' then v.se.mult_32s := '1'; v.res2_sel := "00"; - slow_op := '1'; else -- Use standard multiplier v.start_mul := '1'; - slow_op := '1'; owait := '1'; end if; + slow_op := '1'; when OP_MUL_H64 => v.start_mul := '1';