Word-precise imm for BEQ and BNEQ

This commit is contained in:
Paul Mathieu
2021-02-22 20:33:05 -08:00
parent f59b3efb9f
commit 64d440c94b
2 changed files with 4 additions and 4 deletions

View File

@@ -167,14 +167,14 @@ begin
when "1101" => -- BEQ [rn, imm] (jump to [rn, imm] if flag is set, imm is signed 8 bits) when "1101" => -- BEQ [rn, imm] (jump to [rn, imm] if flag is set, imm is signed 8 bits)
if reg_q(15)(0) = '1' then if reg_q(15)(0) = '1' then
reg_d(14) <= std_logic_vector(signed(reg_q(regn_0)) + signed(inst(7 downto 0))); reg_d(14) <= std_logic_vector(signed(reg_q(regn_0)) + signed(inst(7 downto 0) & '0'));
cpu_state_next <= BRANCH; cpu_state_next <= BRANCH;
end if; end if;
when "1110" => -- SET rd, imm (rd := imm, imm is 8 bit) when "1110" => -- SET rd, imm (rd := imm, imm is 8 bit)
reg_d(regn_0) <= x"00" & inst(7 downto 0); reg_d(regn_0) <= x"00" & inst(7 downto 0);
when "1111" => -- BNEQ [rn, imm] when "1111" => -- BNEQ [rn, imm]
if reg_q(15)(0) = '0' then if reg_q(15)(0) = '0' then
reg_d(14) <= std_logic_vector(signed(reg_q(regn_0)) + signed(inst(7 downto 0))); reg_d(14) <= std_logic_vector(signed(reg_q(regn_0)) + signed(inst(7 downto 0) & '0'));
cpu_state_next <= BRANCH; cpu_state_next <= BRANCH;
end if; end if;

View File

@@ -22,9 +22,9 @@ opcodes = {
'shr' : lambda p0, p1, p2: f'a{p0:x}{p1:x}{p2:x}', 'shr' : lambda p0, p1, p2: f'a{p0:x}{p1:x}{p2:x}',
'mul' : lambda p0, p1, p2: f'b{p0:x}{p1:x}{p2:x}', 'mul' : lambda p0, p1, p2: f'b{p0:x}{p1:x}{p2:x}',
'cmp' : lambda p0, p1: f'c{p0:x}{p1:x}0', 'cmp' : lambda p0, p1: f'c{p0:x}{p1:x}0',
'beq' : lambda p0, p1: f'd{p0:x}{p1&0xff:02x}', 'beq' : lambda p0, p1: f'd{p0:x}{(p1 >> 1)&0xff:02x}',
'set' : lambda p0, p1: f'e{p0:x}{p1&0xff:02x}', 'set' : lambda p0, p1: f'e{p0:x}{p1&0xff:02x}',
'bneq' : lambda p0, p1: f'f{p0:x}{p1&0xff:02x}', 'bneq' : lambda p0, p1: f'f{p0:x}{(p1 >> 1)&0xff:02x}',
'.word': lambda p0: f'{p0:04x}', '.word': lambda p0: f'{p0:04x}',
} }