54 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Scala
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Scala
		
	
	
	
	
	
| package FiveStage
 | |
| import chisel3._
 | |
| import chisel3.experimental.MultiIOModule
 | |
| 
 | |
| 
 | |
| /**
 | |
|   * This module is already done. Have one on me
 | |
|   */
 | |
| class DMEM extends MultiIOModule {
 | |
| 
 | |
| 
 | |
|   // Don't touch the test harness
 | |
|   val testHarness = IO(
 | |
|     new Bundle {
 | |
|       val setup = Input(new DMEMsetupSignals)
 | |
|       val testUpdates = Output(new MemUpdates)
 | |
|     })
 | |
| 
 | |
| 
 | |
|   val io = IO(
 | |
|     new Bundle {
 | |
|       val writeEnable = Input(Bool())
 | |
|       val dataIn      = Input(UInt(32.W))
 | |
|       val dataAddress = Input(UInt(12.W))
 | |
| 
 | |
|       val dataOut     = Output(UInt(32.W))
 | |
|     })
 | |
| 
 | |
|   val data = SyncReadMem(4096, UInt(32.W))
 | |
| 
 | |
|   val addressSource = Wire(UInt(32.W))
 | |
|   val dataSource = Wire(UInt(32.W))
 | |
|   val writeEnableSource = Wire(Bool())
 | |
| 
 | |
|   // For loading data
 | |
|   when(testHarness.setup.setup){
 | |
|     addressSource     := testHarness.setup.dataAddress
 | |
|     dataSource        := testHarness.setup.dataIn
 | |
|     writeEnableSource := testHarness.setup.writeEnable
 | |
|   }.otherwise {
 | |
|     addressSource     := io.dataAddress
 | |
|     dataSource        := io.dataIn
 | |
|     writeEnableSource := io.writeEnable
 | |
|   }
 | |
| 
 | |
|   testHarness.testUpdates.writeEnable  := writeEnableSource
 | |
|   testHarness.testUpdates.writeData    := dataSource
 | |
|   testHarness.testUpdates.writeAddress := addressSource
 | |
| 
 | |
|   io.dataOut := data(addressSource)
 | |
|   when(writeEnableSource){
 | |
|     data(addressSource) := dataSource
 | |
|   }
 | |
| }
 | 
