1
0
mirror of https://github.com/aolofsson/oh.git synced 2025-01-30 02:32:53 +08:00
oh/elink/hdl/erx_disty.v
Andreas Olofsson d45439b43e Changing emesh/elink transaction order
Our "standard packet" order should be followed everywhere to ease verification and integration (standards are good fir reuse...):
[0]=access
[1]=write
[3:2]=datamode
[7:4]=ctrlmode
[39:8]=dstaddr
[71:40]=data
[103:72]=upper-data (or srcaddr)
2015-04-12 08:59:53 -04:00

165 lines
4.6 KiB
Verilog

/*
########################################################################
EPIPHANY eMesh Filter / Distributor
########################################################################
This block takes one eMesh input, selected from two available
(MMU or direct), and distributes the transactions based on type
(write, read request, read response).
*/
module erx_disty (/*AUTOARG*/
// Outputs
emesh_rd_wait, emesh_wr_wait, emwr_wr_data, emwr_wr_en,
emrq_wr_data, emrq_wr_en, emrr_wr_data, emrr_wr_en,
// Inputs
clk, mmu_en, emmu_access, emmu_write, emmu_datamode, emmu_ctrlmode,
emmu_dstaddr, emmu_srcaddr, emmu_data, emwr_full, emwr_progfull,
emrq_full, emrq_progfull, emrr_full, emrr_progfull, ecfg_rx_enable
);
parameter [11:0] C_READ_TAG_ADDR = 12'h810;
parameter C_REMAP_BITS = 7;
parameter [31:0] C_REMAP_ADDR = 32'h3E000000;
// RX clock
input clk;
// MMU enable
input mmu_en;
//Inputs from MMU
input emmu_access;
input emmu_write;
input [1:0] emmu_datamode;
input [3:0] emmu_ctrlmode;
input [31:0] emmu_dstaddr;
input [31:0] emmu_srcaddr;
input [31:0] emmu_data;
output emesh_rd_wait;
output emesh_wr_wait;
// Master FIFO port, writes
output [103:0] emwr_wr_data;
output emwr_wr_en;
input emwr_full; // full flags for debug only
input emwr_progfull;
// Master FIFO port, read requests
output [103:0] emrq_wr_data;
output emrq_wr_en;
input emrq_full;
input emrq_progfull;
// Master FIFO port, read responses
output [103:0] emrr_wr_data;
output emrr_wr_en;
input emrr_full;
input emrr_progfull;
// Control bits inputs
input ecfg_rx_enable;
//############
//# REGS
//############
reg in_write;
reg [1:0] in_datamode;
reg [3:0] in_ctrlmode;
reg [31:0] in_dstaddr;
reg [31:0] in_srcaddr;
reg [31:0] in_data;
reg emwr_wr_en;
reg emrq_wr_en;
reg emrr_wr_en;
reg [1:0] rxmmu_sync;
//############
//# WIRES
//############
wire rxmmu = rxmmu_sync[0];
wire [103:0] fifo_din;
wire [103:0] emwr_wr_data;
wire [103:0] emrq_wr_data;
wire [103:0] emrr_wr_data;
//############
//# PIPELINE AND DISTRIBUTE
//############
always @ (posedge clk)
begin
in_write <= emmu_write;
in_datamode[1:0] <= emmu_datamode[1:0];
in_ctrlmode[3:0] <= emmu_ctrlmode[3:0];
in_dstaddr[31:0] <= mmu_en ? emmu_dstaddr[31:0] : {C_REMAP_ADDR[31:(32-C_REMAP_BITS)],
emmu_dstaddr[(31-C_REMAP_BITS):0]};
in_srcaddr[31:0] <= emmu_srcaddr[31:0];
in_data[31:0] <= emmu_data[31:0];
end
always @ (posedge clk)
if(emmu_access)
begin
emrq_wr_en <= ~emmu_write;
emrr_wr_en <= emmu_write & (emmu_dstaddr[31:20] == C_READ_TAG_ADDR);
emwr_wr_en <= emmu_write & (emmu_dstaddr[31:20] != C_READ_TAG_ADDR);
end
else
begin
emrq_wr_en <= 1'b0;
emrr_wr_en <= 1'b0;
emwr_wr_en <= 1'b0;
end
assign fifo_din[103:0] = {in_srcaddr[31:0],
in_data[31:0],
in_dstaddr[31:0],
in_ctrlmode[3:0],
in_datamode[1:0],
in_write,
1'b0
};
assign emwr_wr_data[103:0] = fifo_din[103:0];
assign emrq_wr_data[103:0] = fifo_din[103:0];
assign emrr_wr_data[103:0] = fifo_din[103:0];
//#############################
//# Wait signal passthroughs
//#############################
assign emesh_rd_wait = emrq_progfull;
assign emesh_wr_wait = emwr_progfull | emrr_progfull;
endmodule // erx_disty
/*
This file is part of the Parallella Project.
Copyright (C) 2014 Adapteva, Inc.
Contributed by Fred Huettig <fred@adapteva.com>
Contributed by Andreas Olofsson <andreas@adapteva.com>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program (see the file COPYING). If not, see
<http://www.gnu.org/licenses/>.
*/