URL
https://opencores.org/ocsvn/instruction_list_pipelined_processor_with_peripherals/instruction_list_pipelined_processor_with_peripherals/trunk
Subversion Repositories instruction_list_pipelined_processor_with_peripherals
[/] [instruction_list_pipelined_processor_with_peripherals/] [trunk/] [hdl/] [alu.v] - Rev 10
Go to most recent revision | Compare with Previous | Blame | View Log
//////////////////////////////////////////////////////////////////////////////////////////////// //// //// //// //// //// This file is part of the project //// //// "instruction_list_pipelined_processor_with_peripherals" //// //// //// //// http://opencores.org/project,instruction_list_pipelined_processor_with_peripherals //// //// //// //// //// //// Author: //// //// - Mahesh Sukhdeo Palve //// //// //// //////////////////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////////////////// //// //// //// //// //// //// //// This source file may be used and distributed without //// //// restriction provided that this copyright statement is not //// //// removed from the file and that any derivative work contains //// //// the original copyright notice and the associated disclaimer. //// //// //// //// This source file is free software; you can redistribute it //// //// and/or modify it under the terms of the GNU Lesser General //// //// Public License as published by the Free Software Foundation; //// //// either version 2.1 of the License, or (at your option) any //// //// later version. //// //// //// //// This source is distributed in the hope that it will be //// //// useful, but WITHOUT ANY WARRANTY; without even the implied //// //// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR //// //// PURPOSE. See the GNU Lesser General Public License for more //// //// details. //// //// //// //// You should have received a copy of the GNU Lesser General //// //// Public License along with this source; if not, download it //// //// from http://www.opencores.org/lgpl.shtml //// //// //// //////////////////////////////////////////////////////////////////////////////////////////////// `include "timescale.v" `include "defines.v" module alu (input [`aluOpcodeLen-1:0] aluOpcode, input [7:0] op1, input [7:0] op2, input aluEn, output [7:0] aluOut, output carryOut); wire [8:0] operand1 = {1'b0, op1}; wire [8:0] operand2 = {1'b0, op2}; wire [8:0] addRes = operand1 + operand2; wire [8:0] subRes = operand1 - operand2; reg [8:0] aluOut = 0; reg carryOut = 0; always @ (aluEn or addRes or subRes or op1 or op2 or aluOpcode) begin if (aluEn) begin case (aluOpcode) `AND_alu : begin aluOut = op1 & op2; end `OR_alu : begin aluOut = op1 | op2; end `XOR_alu : begin aluOut = op1^op2; end `GT_alu : begin aluOut = op1>op2 ? 1'b1 : 1'b0; end `GE_alu : begin aluOut = op1>=op2 ? 1'b1 : 1'b0; end `EQ_alu : begin aluOut = op1==op2 ? 1'b1 : 1'b0; end `LE_alu : begin aluOut = op1<=op2 ? 1'b1 : 1'b0; end `LT_alu : begin aluOut = op1<op2 ? 1'b1 : 1'b0; end `ADD_alu : begin aluOut = addRes[7:0]; carryOut = addRes[8]; end `SUB_alu : begin aluOut = subRes[7:0]; carryOut = subRes[8]; end `LD_data : begin aluOut = op2; end default : begin aluOut = 16'b0; $write ("\nUnknown operation. \tmodule : ALU"); end endcase end else begin aluOut = aluOut; end end endmodule
Go to most recent revision | Compare with Previous | Blame | View Log