Implement RL r instruction
Some groundwork on rotation operations
This commit is contained in:
@@ -11,6 +11,9 @@ module alu (
|
||||
input logic [7:0] operand_i,
|
||||
input logic [2:0] inx8_i, // Only used for bit/set/res
|
||||
|
||||
input logic rot_op_valid_i,
|
||||
input rot_op_t rot_op_i,
|
||||
|
||||
input alu16_op_t alu16_op_i,
|
||||
input logic [15:0] inx16_i,
|
||||
input logic [15:0] iny16_i,
|
||||
@@ -18,7 +21,7 @@ module alu (
|
||||
output logic [ 7:0] a_o,
|
||||
output logic [ 7:0] f_o,
|
||||
|
||||
output logic [ 7:0] out8_o, // Only used for inc/dec reg8
|
||||
output logic [ 7:0] out8_o, // Only used for inc/dec reg8 and rot
|
||||
output logic [15:0] out16_o
|
||||
);
|
||||
|
||||
@@ -39,8 +42,12 @@ module alu (
|
||||
logic [ 7:0] a_bit; // Never written, only to test
|
||||
logic [ 7:0] f_bit;
|
||||
|
||||
|
||||
logic [ 7:0] out8_incr;
|
||||
logic [ 7:0] f_incr;
|
||||
logic [ 7:0] out8_inc;
|
||||
|
||||
logic [ 7:0] out8_rl;
|
||||
logic [ 7:0] f_rl;
|
||||
|
||||
logic [15:0] out16_inc;
|
||||
logic [15:0] out16_dec;
|
||||
@@ -49,17 +56,18 @@ module alu (
|
||||
`DEF_FF(f_r, f_next, f_we, '0);
|
||||
|
||||
assign a_we = alu_op_valid_i;
|
||||
assign a_next = (alu_op_i == ALU_OP_XOR) ? a_xor :
|
||||
(alu_op_i == ALU_OP_NOP) ? operand_i :
|
||||
(alu_op_i == ALU_OP_INC) ? a_inc :
|
||||
a_r;
|
||||
assign a_next = (alu_op_valid_i & (alu_op_i == ALU_OP_XOR)) ? a_xor :
|
||||
(alu_op_valid_i & (alu_op_i == ALU_OP_NOP)) ? operand_i :
|
||||
(alu_op_valid_i & (alu_op_i == ALU_OP_INC)) ? a_inc :
|
||||
a_r;
|
||||
|
||||
assign f_we = alu_op_valid_i;
|
||||
assign f_next = (alu_op_i == ALU_OP_XOR) ? f_xor :
|
||||
(alu_op_i == ALU_OP_BIT) ? f_bit :
|
||||
(alu_op_i == ALU_OP_INC) ? f_inc :
|
||||
(alu_op_i == ALU_OP_INCR) ? f_incr :
|
||||
f_r;
|
||||
assign f_we = alu_op_valid_i | rot_op_valid_i;
|
||||
assign f_next = (alu_op_valid_i & (alu_op_i == ALU_OP_XOR)) ? f_xor :
|
||||
(alu_op_valid_i & (alu_op_i == ALU_OP_BIT)) ? f_bit :
|
||||
(alu_op_valid_i & (alu_op_i == ALU_OP_INC)) ? f_inc :
|
||||
(alu_op_valid_i & (alu_op_i == ALU_OP_INCR)) ? f_incr :
|
||||
(rot_op_valid_i & (rot_op_i == ROT_OP_RL)) ? f_rl :
|
||||
f_r;
|
||||
|
||||
assign a_xor = (a_r ^ operand_i);
|
||||
assign f_xor = {~(|a_xor), 3'b0, f_r[3:0]};
|
||||
@@ -70,16 +78,19 @@ module alu (
|
||||
assign a_bit = (operand_i - {4'b0, inx8_i});
|
||||
assign f_bit = {~(|a_bit), 2'b10, f_r[4:0]};
|
||||
|
||||
assign f_incr = {~(|out8_inc), 1'b0, out8_inc[4], f_r[3:0]};
|
||||
assign out8_rl = {operand_i[6:0], f_r[4]};
|
||||
assign f_rl = {~(|out8_rl), 2'b0, operand_i[7], f_r[3:0]};
|
||||
|
||||
assign out8_inc = (operand_i + 8'h01);
|
||||
|
||||
assign out8_incr = (operand_i + 8'h01);
|
||||
assign f_incr = {~(|out8_incr), 1'b0, out8_incr[4], f_r[3:0]};
|
||||
|
||||
assign out16_dec = (inx16_i - 16'h01);
|
||||
|
||||
assign a_o = a_r;
|
||||
assign f_o = f_r;
|
||||
|
||||
assign out8_o = out8_inc;
|
||||
assign out8_o = ({8{alu_op_valid_i}} & out8_incr) | {8{rot_op_valid_i}} & out8_rl;
|
||||
assign out16_o = out16_dec;
|
||||
|
||||
endmodule : alu
|
||||
Reference in New Issue
Block a user