logical: Only do output inversion for OP_AND, OP_OR and OP_XOR

It's not needed for the other ops (popcnt, parity, etc.) and the
logical unit shows up as a critical path from time to time.

Signed-off-by: Paul Mackerras <paulus@ozlabs.org>
pull/216/head
Paul Mackerras 5 years ago
parent c2da82764f
commit 9b40b5a77b

@ -86,13 +86,20 @@ begin
rb_adj := not rb; rb_adj := not rb;
end if; end if;


case op is
when OP_AND | OP_OR | OP_XOR =>
case op is case op is
when OP_AND => when OP_AND =>
tmp := rs and rb_adj; tmp := rs and rb_adj;
when OP_OR => when OP_OR =>
tmp := rs or rb_adj; tmp := rs or rb_adj;
when OP_XOR => when others =>
tmp := rs xor rb_adj; tmp := rs xor rb_adj;
end case;
if invert_out = '1' then
tmp := not tmp;
end if;

when OP_POPCNT => when OP_POPCNT =>
tmp := popcnt; tmp := popcnt;
when OP_PRTY => when OP_PRTY =>
@ -115,9 +122,6 @@ begin
tmp(7 downto 0) := rs(7 downto 0); tmp(7 downto 0) := rs(7 downto 0);
end case; end case;


if invert_out = '1' then
tmp := not tmp;
end if;
result <= tmp; result <= tmp;


end process; end process;

Loading…
Cancel
Save