cpu之Data_memory

24 篇文章 1 订阅
`include "defines.v"

module Data_memory(
	input [31:0] DmemAddr,//操作的地址
	input DmemWrite,//写有效
	input [31:0] DmemWrData,//要写的数据
	input wire[5:0] ALUCtra,
	input wire DmemRead,//读有效
	
	output reg [31:0] DmemRdData //读出的数据
);

reg [31:0] DataMem[0:255];
wire[31:0] temp_data;
assign temp_data=(DmemAddr>>2);

initial begin  //读数据,采用大端模式
	$readmemh("Data",DataMem);
end

always @(DmemAddr,DmemWrite,DmemWrData,ALUCtra) begin
	if (DmemWrite==1'b0 && DmemRead==1'b1) begin
		case (ALUCtra)
			`lb : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<={{24{DataMem[temp_data][31]}},
						DataMem[temp_data][31:24]};
					end
					
					2'b01 :begin
						DmemRdData<={{24{DataMem[temp_data][23]}},
						DataMem[temp_data][23:16]};
					end
					
					2'b10 :begin
						DmemRdData<={{24{DataMem[temp_data][15]}},
						DataMem[temp_data][15:8]};
					end
					
					2'b11 :begin
						DmemRdData<={{24{DataMem[temp_data][7]}},
						DataMem[temp_data][7:0]};
					end
					
				endcase
			end
			
			`lbu : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<={{24{1'b0}},DataMem[temp_data][31:24]};
					end
					
					2'b01 :begin
						DmemRdData<={{24{1'b0}},DataMem[temp_data][23:16]};
					end
					
					2'b10 :begin
						DmemRdData<={{24{1'b0}},DataMem[temp_data][15:8]};
					end
					
					2'b11 :begin
						DmemRdData<={{24{1'b0}},DataMem[temp_data][7:0]};
					end
					
				endcase
			end
			
			`lh : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<={{16{DataMem[temp_data][31]}},
						DataMem[temp_data][31:16]};
					end
					
					
					2'b10 :begin
						DmemRdData<={{16{DataMem[temp_data][15]}},
						DataMem[temp_data][15:0]};
					end
					
				endcase
			end
			
			`lhu : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<={{16{1'b0}},
						DataMem[temp_data][31:16]};
					end
					
					
					2'b10 :begin
						DmemRdData<={{16{1'b0}},
						DataMem[temp_data][15:0]};
					end
					
				endcase
			end
			
			
			`lw : begin
				DmemRdData<=DataMem[temp_data];
			end
			
			`lwl : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<=DataMem[temp_data][31:0];
					end
					
					2'b01 :begin
						DmemRdData<={DataMem[temp_data][23:0],DmemWrData[7:0]};
					end
					
					2'b10 :begin
						DmemRdData<={DataMem[temp_data][15:0],DmemWrData[15:0]};
					end
					
					2'b11 :begin
						DmemRdData<={DataMem[temp_data][7:0],DmemWrData[23:0]};
					end
					
				endcase
			end
			
			`lwr : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DmemRdData<={DmemWrData[31:8],DataMem[temp_data][31:24]};
					end
					
					2'b01 :begin
						DmemRdData<={DmemWrData[31:16],DataMem[temp_data][31:16]};
					end
					
					2'b10 :begin
						DmemRdData<={DmemWrData[31:24],DataMem[temp_data][31:8]};
					end
					
					2'b11 :begin
						DmemRdData<=DataMem[temp_data];
					end
					
				endcase
			end
		
			
		endcase
	end else begin
		case (ALUCtra)
			`sb : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DataMem[temp_data][31:24]<=DmemWrData[7:0];
					end
					
					2'b01 :begin
					  DataMem[temp_data][23:16]<=DmemWrData[7:0];
					end
					
					2'b10 :begin
						DataMem[temp_data][15:8]<=DmemWrData[7:0];
					end
					
					2'b11 :begin
						DataMem[temp_data][7:0]<=DmemWrData[7:0];
					end
					
				endcase
			end
			
			`sh : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DataMem[temp_data][31:16]<=DmemWrData[15:0];
					end
					
					
					2'b10 :begin
						DataMem[temp_data][15:0]<=DmemWrData[15:0];
					end
					
				endcase
			end
			
			`sw : begin
						DataMem[temp_data]<=DmemWrData;
					end
			
			`swl : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DataMem[temp_data]<=DmemWrData;
					end
					
					2'b01 :begin
						DataMem[temp_data][23:0]<=DmemWrData[31:8];
					end
					
					2'b10 :begin
						DataMem[temp_data][15:0]<=DmemWrData[31:16];
					end
					
					2'b11 :begin
						DataMem[temp_data][7:0]<=DmemWrData[31:24];
					end
					
				endcase
			end
			
			`swr : begin
				case (DmemAddr[1:0])
					2'b00 :begin
						DataMem[temp_data][31:24]<=DmemWrData[7:0];
					end
					
					2'b01 :begin
						DataMem[temp_data][31:16]<=DmemWrData[15:0];
					end
					
					2'b10 :begin
						DataMem[temp_data][31:8]<=DmemWrData[23:0];
					end
					
					2'b11 :begin
						DataMem[temp_data]<=DmemWrData;
					end
				endcase
			end
			
			endcase
			DmemRdData<=0;
			end
end
	

endmodule

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误是由于文件路径中包含空格而导致的。为了解决这个错误,你需要在文件路径中的包含空格的地方添加双引号。例如,将 "C:/Program Files/Xilinx/verilog/src/glbl.v" 改为 "C:/Program Files/Xilinx/verilog/src/glbl.v"。\[1\] 另外,你提到了一个关于使用ModelSim进行仿真时出现的错误。这个错误是由于在do文件中指定的设计单元文件路径中包含了空格,导致无法以读取模式打开文件。为了解决这个问题,你需要在文件路径中的包含空格的地方添加双引号。例如,将 "D:/diamond" 改为 "D:/diamond projects/cpu_if/src/cpu_if.v"。\[3\] 至于你提到的另一个错误,"Error: (vlog-7) Failed to open design unit file "C:/Xilinx/Vivado/2018.3/data/ip/xpm/xpm_memory/hdl/xpm_memory.sv" in read mode.",这个错误是由于无法以读取模式打开指定的设计单元文件。可能的原因是文件路径不正确或文件不存在。请确保文件路径正确,并检查文件是否存在。如果文件存在并且路径正确,那么可能是文件权限或其他问题导致无法打开文件。你可以尝试更改文件权限或使用其他方法来打开文件。 #### 引用[.reference_title] - *1* [Failed to open design unit file "%XILINX%/verilog/src/glbl.v](https://blog.csdn.net/alan5555/article/details/9378009)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [modelsim10.4仿真错误Error: (vlog-7) Failed to open design unit file "XXXXX" in read mode解决办法](https://blog.csdn.net/llf021421/article/details/79181118)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值