URL
https://opencores.org/ocsvn/mesi_isc/mesi_isc/trunk
Subversion Repositories mesi_isc
[/] [mesi_isc/] [trunk/] [src/] [rtl/] [mesi_isc_broad.v] - Rev 5
Go to most recent revision | Compare with Previous | Blame | View Log
////////////////////////////////////////////////////////////////////// //// //// //// Copyright (C) 2009 Authors and OPENCORES.ORG //// //// //// //// 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 //// //// //// ////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////// //// //// //// MESI_ISC Project //// //// //// //// Author(s): //// //// - Yair Amitay yair.amitay@yahoo.com //// //// www.linkedin.com/in/yairamitay //// //// //// //// Description //// //// mesi_isc_broad //// //// ------------------- //// //// //// //// //// //// To Do: //// //// - //// //// //// ////////////////////////////////////////////////////////////////////// `include "mesi_isc_define.v" module mesi_isc_broad ( // Inputs clk, rst, cbus_ack_array_i, broad_fifo_wr_i, broad_addr_i, broad_type_i, broad_cpu_id_i, broad_id_i, // Outputs cbus_addr_o, cbus_cmd_array_o, fifo_status_full_o ); parameter CBUS_CMD_WIDTH = 3, ADDR_WIDTH = 32, BROAD_TYPE_WIDTH = 2, BROAD_ID_WIDTH = 5, BROAD_REQ_FIFO_SIZE = 4, BROAD_REQ_FIFO_SIZE_LOG2 = 2; // Inputs //================================ // System input clk; // System clock input rst; // Active high system reset // Coherence bus input [3:0] cbus_ack_array_i; input broad_fifo_wr_i; // Write the broadcast request input [ADDR_WIDTH-1:0] broad_addr_i; // Broad addresses input [BROAD_TYPE_WIDTH-1:0] broad_type_i; // Broad type input [1:0] broad_cpu_id_i; // Initiators // CPU id array input [BROAD_ID_WIDTH-1:0] broad_id_i; // Broadcast request ID array // Outputs //================================ output [ADDR_WIDTH-1:0] cbus_addr_o; // Coherence bus address. All busses have // the same address output [4*CBUS_CMD_WIDTH-1:0] cbus_cmd_array_o; // See broad_addr_i output fifo_status_full_o; // The broad fifo is full // Regs & wires //================================ wire broad_fifo_rd; // Read broadcast wire fifo_status_empty; // Status empty wire fifo_status_full; // The broad fifo is full wire [ADDR_WIDTH-1:0] broad_snoop_addr; // Address of broadcast snooping wire [BROAD_TYPE_WIDTH-1:0] broad_snoop_type; // Type of broadcast snooping wire [1:0] broad_snoop_cpu_id; // ID of initiator of broadcast // snooping wire [BROAD_ID_WIDTH-1:0] broad_snoop_id; // Broadcast snooping ID \ // assign //================================ assign cbus_addr_o[ADDR_WIDTH-1:0] = broad_snoop_addr[ADDR_WIDTH-1:0]; assign fifo_status_full_o = fifo_status_full; // Breq fifo control //================================ mesi_isc_broad_cntl #(CBUS_CMD_WIDTH, BROAD_TYPE_WIDTH, BROAD_ID_WIDTH) mesi_isc_broad_cntl ( // Inputs .clk (clk), .rst (rst), // Coherence buses .cbus_ack_array_i (cbus_ack_array_i[3:0]), // broad_fifo .fifo_status_empty_i (fifo_status_empty), .fifo_status_full_i (fifo_status_full), // broad_fifo .broad_snoop_type_i (broad_snoop_type[BROAD_TYPE_WIDTH-1:0]), .broad_snoop_cpu_id_i (broad_snoop_cpu_id[1:0]), .broad_snoop_id_i (broad_snoop_id[BROAD_ID_WIDTH-1:0]), // Outputs // Coherence buses .cbus_cmd_array_o (cbus_cmd_array_o[4*CBUS_CMD_WIDTH-1:0]), // fifo .broad_fifo_rd_o (broad_fifo_rd) ); // broad fifo //================================ mesi_isc_basic_fifo #(ADDR_WIDTH + // DATA_WIDTH BROAD_TYPE_WIDTH + 2 + // BROAD_CPU_ID_WIDTH BROAD_ID_WIDTH, BROAD_REQ_FIFO_SIZE, // FIFO_SIZE BROAD_REQ_FIFO_SIZE_LOG2) // FIFO_SIZE_LOG2 // \ / (\ / marks the fifo ID) broad_fifo ( // Inputs .clk (clk), .rst (rst), .wr_i (broad_fifo_wr_i), .rd_i (broad_fifo_rd), .data_i ({broad_addr_i[ADDR_WIDTH-1:0], broad_type_i[BROAD_TYPE_WIDTH-1:0], broad_cpu_id_i[1:0], broad_id_i[BROAD_ID_WIDTH-1:0] }), // Outputs .data_o ({broad_snoop_addr[ADDR_WIDTH-1:0], broad_snoop_type[BROAD_TYPE_WIDTH-1:0], broad_snoop_cpu_id[1:0], broad_snoop_id[BROAD_ID_WIDTH-1:0] }), .status_empty_o (fifo_status_empty), .status_full_o (fifo_status_full) ); endmodule
Go to most recent revision | Compare with Previous | Blame | View Log