diff --git a/common.vhdl b/common.vhdl index 46db202..7d31b67 100644 --- a/common.vhdl +++ b/common.vhdl @@ -440,6 +440,11 @@ package common is illegal_form : std_ulogic; uses_tar : std_ulogic; uses_dscr : std_ulogic; + right_shift : std_ulogic; + rot_clear_left : std_ulogic; + rot_clear_right : std_ulogic; + rot_sign_ext : std_ulogic; + do_popcnt : std_ulogic; end record; constant Decode2ToExecute1Init : Decode2ToExecute1Type := (valid => '0', unit => ALU, fac => NONE, insn_type => OP_ILLEGAL, instr_tag => instr_tag_init, @@ -462,6 +467,8 @@ package common is dec_ctr => '0', prefixed => '0', prefix => (others => '0'), illegal_suffix => '0', misaligned_prefix => '0', illegal_form => '0', uses_tar => '0', uses_dscr => '0', + right_shift => '0', rot_clear_left => '0', rot_clear_right => '0', rot_sign_ext => '0', + do_popcnt => '0', others => (others => '0')); type MultiplyInputType is record diff --git a/decode2.vhdl b/decode2.vhdl index 432426d..da2fbb3 100644 --- a/decode2.vhdl +++ b/decode2.vhdl @@ -673,6 +673,14 @@ begin v.e.illegal_suffix := d_in.illegal_suffix; v.e.misaligned_prefix := d_in.misaligned_prefix; + -- rotator control signals + v.e.right_shift := '1' when op = OP_SHR else '0'; + v.e.rot_clear_left := '1' when op = OP_RLC or op = OP_RLCL else '0'; + v.e.rot_clear_right := '1' when op = OP_RLC or op = OP_RLCR else '0'; + v.e.rot_sign_ext := '1' when op = OP_EXTSWSLI else '0'; + + v.e.do_popcnt := '1' when op = OP_COUNTB and d_in.insn(7 downto 6) = "11" else '0'; + -- check for invalid forms that cause an illegal instruction interrupt -- Does RA = RT for a load quadword instr, or RB = RT for lqarx? if d_in.decode.repeat = DRTP and diff --git a/execute1.vhdl b/execute1.vhdl index c5b2dc4..b9ad9ad 100644 --- a/execute1.vhdl +++ b/execute1.vhdl @@ -210,12 +210,9 @@ architecture behaviour of execute1 is signal valid_in : std_ulogic; signal ctrl: ctrl_t := ctrl_t_init; signal ctrl_tmp: ctrl_t := ctrl_t_init; - signal right_shift, rot_clear_left, rot_clear_right: std_ulogic; - signal rot_sign_ext: std_ulogic; signal rotator_result: std_ulogic_vector(63 downto 0); signal rotator_carry: std_ulogic; signal logical_result: std_ulogic_vector(63 downto 0); - signal do_popcnt: std_ulogic; signal countbits_result: std_ulogic_vector(63 downto 0); signal alu_result: std_ulogic_vector(63 downto 0); signal adder_result: std_ulogic_vector(63 downto 0); @@ -454,11 +451,11 @@ begin shift => b_in(6 downto 0), insn => e_in.insn, is_32bit => e_in.is_32bit, - right_shift => right_shift, + right_shift => e_in.right_shift, arith => e_in.is_signed, - clear_left => rot_clear_left, - clear_right => rot_clear_right, - sign_ext_rs => rot_sign_ext, + clear_left => e_in.rot_clear_left, + clear_right => e_in.rot_clear_right, + sign_ext_rs => e_in.rot_sign_ext, result => rotator_result, carry_out => rotator_carry ); @@ -482,7 +479,7 @@ begin stall => stage2_stall, count_right => e_in.insn(10), is_32bit => e_in.is_32bit, - do_popcnt => do_popcnt, + do_popcnt => e_in.do_popcnt, datalen => e_in.data_len, result => countbits_result ); @@ -1648,14 +1645,6 @@ begin irq_valid := ex1.msr(MSR_EE) and (pmu_to_x.intr or ctrl.dec(63) or ext_irq_in); - -- rotator control signals - right_shift <= '1' when e_in.insn_type = OP_SHR else '0'; - rot_clear_left <= '1' when e_in.insn_type = OP_RLC or e_in.insn_type = OP_RLCL else '0'; - rot_clear_right <= '1' when e_in.insn_type = OP_RLC or e_in.insn_type = OP_RLCR else '0'; - rot_sign_ext <= '1' when e_in.insn_type = OP_EXTSWSLI else '0'; - - do_popcnt <= '1' when e_in.insn_type = OP_COUNTB and e_in.insn(7 downto 6) = "11" else '0'; - if valid_in = '1' then v.prev_op := e_in.insn_type; v.prev_prefixed := e_in.prefixed;