add unit test for some modules
This commit is contained in:
		
							
								
								
									
										97
									
								
								groundtest/src/main/scala/unittest.scala
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								groundtest/src/main/scala/unittest.scala
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | ||||
| package groundtest | ||||
|  | ||||
| import Chisel._ | ||||
| import junctions._ | ||||
| import cde.Parameters | ||||
|  | ||||
| abstract class UnitTest extends Module { | ||||
|   val io = new Bundle { | ||||
|     val finished = Bool(OUTPUT) | ||||
|     val start = Bool(INPUT) | ||||
|   } | ||||
| } | ||||
|  | ||||
| class MultiWidthFifoTest extends UnitTest { | ||||
|   val big2little = Module(new MultiWidthFifo(16, 8, 8)) | ||||
|   val little2big = Module(new MultiWidthFifo(8, 16, 4)) | ||||
|  | ||||
|   val bl_send = Reg(init = Bool(false)) | ||||
|   val lb_send = Reg(init = Bool(false)) | ||||
|   val bl_recv = Reg(init = Bool(false)) | ||||
|   val lb_recv = Reg(init = Bool(false)) | ||||
|   val bl_finished = Reg(init = Bool(false)) | ||||
|   val lb_finished = Reg(init = Bool(false)) | ||||
|  | ||||
|   val bl_data = Vec.tabulate(4){i => UInt((2 * i + 1) * 256 + 2 * i, 16)} | ||||
|   val lb_data = Vec.tabulate(8){i => UInt(i, 8)} | ||||
|  | ||||
|   val (bl_send_cnt, bl_send_done) = Counter(big2little.io.in.fire(), 4) | ||||
|   val (lb_send_cnt, lb_send_done) = Counter(little2big.io.in.fire(), 8) | ||||
|  | ||||
|   val (bl_recv_cnt, bl_recv_done) = Counter(big2little.io.out.fire(), 8) | ||||
|   val (lb_recv_cnt, lb_recv_done) = Counter(little2big.io.out.fire(), 4) | ||||
|  | ||||
|   big2little.io.in.valid := bl_send | ||||
|   big2little.io.in.bits := bl_data(bl_send_cnt) | ||||
|   big2little.io.out.ready := bl_recv | ||||
|  | ||||
|   little2big.io.in.valid := lb_send | ||||
|   little2big.io.in.bits := lb_data(lb_send_cnt) | ||||
|   little2big.io.out.ready := lb_recv | ||||
|  | ||||
|   val bl_recv_data_idx = bl_recv_cnt >> UInt(1) | ||||
|   val bl_recv_data = Mux(bl_recv_cnt(0), | ||||
|     bl_data(bl_recv_data_idx)(15, 8), | ||||
|     bl_data(bl_recv_data_idx)(7, 0)) | ||||
|  | ||||
|   val lb_recv_data = Cat( | ||||
|     lb_data(Cat(lb_recv_cnt, UInt(1, 1))), | ||||
|     lb_data(Cat(lb_recv_cnt, UInt(0, 1)))) | ||||
|  | ||||
|   when (io.start) { | ||||
|     bl_send := Bool(true) | ||||
|     lb_send := Bool(true) | ||||
|   } | ||||
|  | ||||
|   when (bl_send_done) { | ||||
|     bl_send := Bool(false) | ||||
|     bl_recv := Bool(true) | ||||
|   } | ||||
|  | ||||
|   when (lb_send_done) { | ||||
|     lb_send := Bool(false) | ||||
|     lb_recv := Bool(true) | ||||
|   } | ||||
|  | ||||
|   when (bl_recv_done) { | ||||
|     bl_recv := Bool(false) | ||||
|     bl_finished := Bool(true) | ||||
|   } | ||||
|  | ||||
|   when (lb_recv_done) { | ||||
|     lb_recv := Bool(false) | ||||
|     lb_finished := Bool(true) | ||||
|   } | ||||
|  | ||||
|   io.finished := bl_finished && lb_finished | ||||
|  | ||||
|   assert(!little2big.io.out.valid || little2big.io.out.bits === lb_recv_data, | ||||
|     "Little to Big data mismatch") | ||||
|   assert(!big2little.io.out.valid || big2little.io.out.bits === bl_recv_data, | ||||
|     "Bit to Little data mismatch") | ||||
| } | ||||
|  | ||||
| class UnitTestSuite(implicit p: Parameters) extends GroundTest()(p) { | ||||
|   disablePorts() | ||||
|  | ||||
|   val tests = Seq(Module(new MultiWidthFifoTest)) | ||||
|  | ||||
|   val s_idle :: s_start :: s_wait :: Nil = Enum(Bits(), 3) | ||||
|   val state = Reg(init = s_idle) | ||||
|  | ||||
|   when (state === s_idle) { state := s_start } | ||||
|   when (state === s_start) { state := s_wait } | ||||
|  | ||||
|   tests.foreach { mod => mod.io.start := (state === s_start) } | ||||
|   io.finished := tests.map(_.io.finished).reduce(_ && _) | ||||
| } | ||||
		Reference in New Issue
	
	Block a user