mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	pulled swbbytemask out of subword write.
This commit is contained in:
		
							parent
							
								
									1ee613ae6c
								
							
						
					
					
						commit
						3612db2d70
					
				| @ -49,7 +49,6 @@ module ahblite ( | ||||
|   input logic [2:0]    IFUBurstType, | ||||
|   input logic [1:0]    IFUTransType, | ||||
|   input logic          IFUTransComplete, | ||||
|   input logic [(`XLEN-1)/8:0]     ByteMaskM, | ||||
| 
 | ||||
|   // Signals from Data Cache
 | ||||
|   input logic [`PA_BITS-1:0] LSUBusAdr, | ||||
| @ -157,7 +156,6 @@ module ahblite ( | ||||
|   assign HTRANS = (GrantData) ? LSUTransType : IFUTransType; // SEQ if not first read or write, NONSEQ if first read or write, IDLE otherwise
 | ||||
|   assign HMASTLOCK = 0; // no locking supported
 | ||||
|   assign HWRITE = (NextBusState == MEMWRITE); | ||||
|   //assign HWSTRB = ByteMaskM;
 | ||||
|   // Byte mask for HWSTRB
 | ||||
|   swbytemask swbytemask(.Size(HSIZED[1:0]), .Adr(HADDRD[2:0]), .ByteMask(HWSTRB)); | ||||
| 
 | ||||
|  | ||||
| @ -77,8 +77,6 @@ module lsu ( | ||||
|    (* mark_debug = "true" *)   output logic [2:0] LSUBurstType, | ||||
|    (* mark_debug = "true" *)   output logic [1:0] LSUTransType, | ||||
|    (* mark_debug = "true" *)   output logic LSUTransComplete, | ||||
|    output logic [(`XLEN-1)/8:0]     ByteMaskM, | ||||
| 
 | ||||
|             // page table walker
 | ||||
|    input logic [`XLEN-1:0]  SATP_REGW, // from csr
 | ||||
|    input logic              STATUS_MXR, STATUS_SUM, STATUS_MPRV, | ||||
| @ -116,6 +114,7 @@ module lsu ( | ||||
|   logic [`XLEN-1:0]         LSUWriteDataM; | ||||
|   logic [`XLEN-1:0]         WriteDataM; | ||||
|   logic [`LLEN-1:0]         ReadDataM; | ||||
|   logic [(`XLEN-1)/8:0]     ByteMaskM; | ||||
|    | ||||
|   // *** TO DO: Burst mode
 | ||||
| 
 | ||||
| @ -277,7 +276,14 @@ module lsu ( | ||||
|   subwordread subwordread(.ReadDataWordMuxM, .LSUPAdrM(LSUPAdrM[2:0]), | ||||
| 		.FpLoadStoreM, .Funct3M(LSUFunct3M), .ReadDataM); | ||||
|   subwordwrite subwordwrite(.LSUPAdrM(LSUPAdrM[2:0]), | ||||
|     .LSUFunct3M, .AMOWriteDataM, .LittleEndianWriteDataM, .ByteMaskM); | ||||
|     .LSUFunct3M, .AMOWriteDataM, .LittleEndianWriteDataM); | ||||
| 
 | ||||
|   // Compute byte masks
 | ||||
|   //swbytemask swbytemask(.Size(LSUFunct3M[1:0]), .Adr(LSUPAdrM[2:0]), .ByteMask(ByteMaskM));
 | ||||
|   swbytemaskword #(`XLEN) swbytemask(.Size(LSUFunct3M), .Adr(LSUPAdrM[$clog2(`XLEN/8)-1:0]), .ByteMask(ByteMaskM)); | ||||
|   // *** fix me.
 | ||||
|   //swbytemaskword #(.WORDLEN(`XLEN)) 
 | ||||
|   //swbytemaskword (.Size(LSUFunct3M[2:0]), .Adr(LSUPAdrM), .ByteMask(ByteMaskM));  
 | ||||
| 
 | ||||
|   /////////////////////////////////////////////////////////////////////////////////////////////
 | ||||
|   // MW Pipeline Register
 | ||||
|  | ||||
| @ -34,15 +34,7 @@ module subwordwrite ( | ||||
|   input logic [2:0]          LSUPAdrM, | ||||
|   input logic [2:0]          LSUFunct3M, | ||||
|   input logic [`XLEN-1:0]    AMOWriteDataM, | ||||
|   output logic [`XLEN-1:0]   LittleEndianWriteDataM, | ||||
|   output logic [`XLEN/8-1:0] ByteMaskM | ||||
| ); | ||||
| 
 | ||||
|   // Compute byte masks
 | ||||
|   //swbytemask swbytemask(.Size(LSUFunct3M[1:0]), .Adr(LSUPAdrM), .ByteMask(ByteMaskM));
 | ||||
|   // *** fix me.
 | ||||
|   swbytemaskword #(.WORDLEN(`XLEN))  | ||||
|   swbytemaskword (.Size(LSUFunct3M[2:0]), .Adr(LSUPAdrM), .ByteMask(ByteMaskM));   | ||||
|   output logic [`XLEN-1:0]   LittleEndianWriteDataM); | ||||
| 
 | ||||
|   // Replicate data for subword writes
 | ||||
|   if (`XLEN == 64) begin:sww | ||||
|  | ||||
| @ -116,7 +116,6 @@ module wallypipelinedcore ( | ||||
|   logic [1:0]             PageType; | ||||
|   logic              sfencevmaM, wfiM, IntPendingM; | ||||
|   logic             SelHPTW; | ||||
|   logic [`XLEN/8-1:0] ByteMaskM; | ||||
| 
 | ||||
| 
 | ||||
|   // PMA checker signals
 | ||||
| @ -266,7 +265,6 @@ module wallypipelinedcore ( | ||||
|   // connected to ahb (all stay the same)
 | ||||
|   .LSUBusAdr, .LSUBusRead, .LSUBusWrite, .LSUBusAck, .LSUBusInit, | ||||
|   .LSUBusHRDATA, .LSUBusHWDATA, .LSUBusSize, .LSUBurstType, .LSUTransType, .LSUTransComplete, | ||||
|   .ByteMaskM, | ||||
| 
 | ||||
|     // connect to csr or privilege and stay the same.
 | ||||
|     .PrivilegeModeW, .BigEndianM,          // connects to csr
 | ||||
| @ -313,7 +311,6 @@ module wallypipelinedcore ( | ||||
|      .LSUTransComplete, | ||||
|      .LSUBusAck, | ||||
|      .LSUBusInit, | ||||
|      .ByteMaskM, | ||||
|   | ||||
|      .HRDATA, .HREADY, .HRESP, .HCLK, .HRESETn, | ||||
|      .HADDR, .HWDATA, .HWSTRB, .HWRITE, .HSIZE, .HBURST, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user