Line 42... |
Line 42... |
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
//
|
//
|
// CVS Revision History
|
// CVS Revision History
|
//
|
//
|
// $Log: not supported by cvs2svn $
|
// $Log: not supported by cvs2svn $
|
|
// Revision 1.7 2001/10/14 13:12:10 lampret
|
|
// MP3 version.
|
|
//
|
// Revision 1.1.1.1 2001/10/06 10:18:36 igorm
|
// Revision 1.1.1.1 2001/10/06 10:18:36 igorm
|
// no message
|
// no message
|
//
|
//
|
// Revision 1.2 2001/08/09 13:39:33 lampret
|
// Revision 1.2 2001/08/09 13:39:33 lampret
|
// Major clean-up.
|
// Major clean-up.
|
Line 73... |
Line 76... |
output [width-1:0] memdata;
|
output [width-1:0] memdata;
|
|
|
//
|
//
|
// Internal regs and wires
|
// Internal regs and wires
|
//
|
//
|
reg [width-1:0] memdata;
|
reg [7:0] memdata_hh;
|
|
reg [7:0] memdata_hl;
|
|
reg [7:0] memdata_lh;
|
|
reg [7:0] memdata_ll;
|
|
|
|
assign memdata = {memdata_hh, memdata_hl, memdata_lh, memdata_ll};
|
|
|
//
|
//
|
// Mux to memdata[31:24]
|
// Mux to memdata[31:24]
|
//
|
//
|
always @(lsu_op or addr or regdata) begin
|
always @(lsu_op or addr or regdata) begin
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
{`LSUOP_SB, 2'b00} : memdata[31:24] = regdata[7:0];
|
{`LSUOP_SB, 2'b00} : memdata_hh = regdata[7:0];
|
{`LSUOP_SH, 2'b00} : memdata[31:24] = regdata[15:8];
|
{`LSUOP_SH, 2'b00} : memdata_hh = regdata[15:8];
|
default : memdata[31:24] = regdata[31:24];
|
default : memdata_hh = regdata[31:24];
|
endcase
|
endcase
|
end
|
end
|
|
|
//
|
//
|
// Mux to memdata[23:16]
|
// Mux to memdata[23:16]
|
//
|
//
|
always @(lsu_op or addr or regdata) begin
|
always @(lsu_op or addr or regdata) begin
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
{`LSUOP_SW, 2'b00} : memdata[23:16] = regdata[23:16];
|
{`LSUOP_SW, 2'b00} : memdata_hl = regdata[23:16];
|
default : memdata[23:16] = regdata[7:0];
|
default : memdata_hl = regdata[7:0];
|
endcase
|
endcase
|
end
|
end
|
|
|
//
|
//
|
// Mux to memdata[15:8]
|
// Mux to memdata[15:8]
|
//
|
//
|
always @(lsu_op or addr or regdata) begin
|
always @(lsu_op or addr or regdata) begin
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
casex({lsu_op, addr[1:0]}) // synopsys full_case parallel_case
|
{`LSUOP_SB, 2'b10} : memdata[15:8] = regdata[7:0];
|
{`LSUOP_SB, 2'b10} : memdata_lh = regdata[7:0];
|
default : memdata[15:8] = regdata[15:8];
|
default : memdata_lh = regdata[15:8];
|
endcase
|
endcase
|
end
|
end
|
|
|
//
|
//
|
// Mux to memdata[7:0]
|
// Mux to memdata[7:0]
|
//
|
//
|
always @(regdata)
|
always @(regdata)
|
memdata[7:0] = regdata[7:0];
|
memdata_ll = regdata[7:0];
|
|
|
endmodule
|
endmodule
|
|
|
No newline at end of file
|
No newline at end of file
|