Update beh_lib.scala
This commit is contained in:
		
							parent
							
								
									f60e035eeb
								
							
						
					
					
						commit
						698c0fc1a1
					
				|  | @ -3,7 +3,6 @@ import chisel3._ | ||||||
| import chisel3.util._ | import chisel3.util._ | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| class rvdff(WIDTH:Int=1,SHORT:Int=0) extends Module{ | class rvdff(WIDTH:Int=1,SHORT:Int=0) extends Module{ | ||||||
|   val io = IO(new Bundle{ |   val io = IO(new Bundle{ | ||||||
|     val din  = Input(UInt(WIDTH.W)) |     val din  = Input(UInt(WIDTH.W)) | ||||||
|  | @ -17,9 +16,11 @@ if(SHORT == 1) | ||||||
|   else |   else | ||||||
|   {io.dout := flop} |   {io.dout := flop} | ||||||
| } | } | ||||||
|  | //println(getVerilog(new rvdff)) | ||||||
|  | //rvdff => use regnext. with Asynchronous | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class rvsyncss(WIDTH:Int = 251,SHORT:Int = 0) extends Module with RequireAsyncReset{  //Done for verification and testing | class rvsyncss(WIDTH:Int = 251,SHORT:Int = 0) extends Module{  //Done for verification and testing | ||||||
|   val io = IO(new Bundle{ |   val io = IO(new Bundle{ | ||||||
|     val din   = Input(UInt(WIDTH.W)) |     val din   = Input(UInt(WIDTH.W)) | ||||||
|     val dout  = Output(UInt(WIDTH.W)) |     val dout  = Output(UInt(WIDTH.W)) | ||||||
|  | @ -34,6 +35,9 @@ class rvsyncss(WIDTH:Int = 251,SHORT:Int = 0) extends Module with RequireAsyncRe | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| class rvlsadder extends Module{  //Done for verification and testing | class rvlsadder extends Module{  //Done for verification and testing | ||||||
|   val io = IO(new Bundle{ |   val io = IO(new Bundle{ | ||||||
|     val rs1     = Input(UInt(32.W)) |     val rs1     = Input(UInt(32.W)) | ||||||
|  | @ -49,9 +53,6 @@ class rvlsadder extends Module{  //Done for verification and testing | ||||||
|   io.dout := Cat(dout_upper,w1(11,0)) |   io.dout := Cat(dout_upper,w1(11,0)) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| class rvbsadder extends Module{   //Done for verification and testing | class rvbsadder extends Module{   //Done for verification and testing | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val pc     = Input(UInt(32.W)) // lsb is not using in code |       val pc     = Input(UInt(32.W)) // lsb is not using in code | ||||||
|  | @ -59,7 +60,6 @@ class rvbsadder extends Module{   //Done for verification and testing | ||||||
|       val dout   = Output(UInt(31.W)) |       val dout   = Output(UInt(31.W)) | ||||||
|     }) |     }) | ||||||
|     val w1 =  Cat("b0".U,io.pc(12,1)) + Cat("b0".U,io.offset(12,1))  //w1[12] =cout  offset[12]=sign |     val w1 =  Cat("b0".U,io.pc(12,1)) + Cat("b0".U,io.offset(12,1))  //w1[12] =cout  offset[12]=sign | ||||||
| 
 |  | ||||||
|     val dout_upper = ((Fill(19, ~(io.offset(12) ^ w1(12))))&  io.pc(31,13))       | |     val dout_upper = ((Fill(19, ~(io.offset(12) ^ w1(12))))&  io.pc(31,13))       | | ||||||
|       ((Fill(19, ~io.offset(12) ^  w1(12))) & (io.pc(31,13)+1.U)) | |       ((Fill(19, ~io.offset(12) ^  w1(12))) & (io.pc(31,13)+1.U)) | | ||||||
|       ((Fill(19, io.offset(12) ^  ~w1(12))) & (io.pc(31,13)-1.U)) |       ((Fill(19, io.offset(12) ^  ~w1(12))) & (io.pc(31,13)-1.U)) | ||||||
|  | @ -67,18 +67,13 @@ class rvbsadder extends Module{   //Done for verification and testing | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvtwoscomp(WIDTH:Int=32) extends Module{   //Done for verification and testing |   class rvtwoscomp(WIDTH:Int=32) extends Module{   //Done for verification and testing | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val din   = Input(UInt(WIDTH.W)) |       val din   = Input(UInt(WIDTH.W)) | ||||||
|       val dout  = Output(UInt(WIDTH.W)) |       val dout  = Output(UInt(WIDTH.W)) | ||||||
|     }) |     }) | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     val temp = Wire(Vec(WIDTH-1,UInt(1.W))) |     val temp = Wire(Vec(WIDTH-1,UInt(1.W))) | ||||||
|     val i:Int = 1 |     val i:Int = 1 | ||||||
| 
 |  | ||||||
|     for(i <- 1 to WIDTH-1){ |     for(i <- 1 to WIDTH-1){ | ||||||
|       val done  = io.din(i-1,0).orR |       val done  = io.din(i-1,0).orR | ||||||
|       temp(i-1) := Mux(done ,~io.din(i),io.din(i)) |       temp(i-1) := Mux(done ,~io.din(i),io.din(i)) | ||||||
|  | @ -86,7 +81,6 @@ class rvtwoscomp(WIDTH:Int=32) extends Module{   //Done for verification and tes | ||||||
|     io.dout := Cat(temp.asUInt,io.din(0)) |     io.dout := Cat(temp.asUInt,io.din(0)) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|   class rvmaskandmatch(WIDTH:Int=32) extends Module{     //Done for verification and testing |   class rvmaskandmatch(WIDTH:Int=32) extends Module{     //Done for verification and testing | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val mask       = Input(UInt(WIDTH.W)) |       val mask       = Input(UInt(WIDTH.W)) | ||||||
|  | @ -105,9 +99,6 @@ class rvmaskandmatch(WIDTH:Int=32) extends Module{     //Done for verification a | ||||||
|     io.match_out := matchvec.asUInt |     io.match_out := matchvec.asUInt | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvrangecheck(CCM_SADR:Int=0, CCM_SIZE:Int=128) extends Module{ |   class rvrangecheck(CCM_SADR:Int=0, CCM_SIZE:Int=128) extends Module{ | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val addr       =  Input(UInt(32.W)) |       val addr       =  Input(UInt(32.W)) | ||||||
|  | @ -128,9 +119,6 @@ class rvrangecheck(CCM_SADR:Int=0, CCM_SIZE:Int=128) extends Module{ | ||||||
|       io.in_range := (io.addr(31,MASK_BITS) === start_addr(31,MASK_BITS)).asUInt |       io.in_range := (io.addr(31,MASK_BITS) === start_addr(31,MASK_BITS)).asUInt | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rveven_paritygen(WIDTH:Int= 16) extends Module{    //Done for verification and testing |   class rveven_paritygen(WIDTH:Int= 16) extends Module{    //Done for verification and testing | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val data_in        =  Input (UInt(WIDTH.W)) |       val data_in        =  Input (UInt(WIDTH.W)) | ||||||
|  | @ -139,8 +127,6 @@ class rveven_paritygen(WIDTH:Int= 16) extends Module{    //Done for verification | ||||||
|     io.parity_out := io.data_in.xorR.asUInt |     io.parity_out := io.data_in.xorR.asUInt | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rveven_paritycheck(WIDTH:Int= 16) extends Module{    //Done for verification and testing |   class rveven_paritycheck(WIDTH:Int= 16) extends Module{    //Done for verification and testing | ||||||
|     val io = IO(new Bundle{ |     val io = IO(new Bundle{ | ||||||
|       val data_in        =  Input (UInt(WIDTH.W)) |       val data_in        =  Input (UInt(WIDTH.W)) | ||||||
|  | @ -150,8 +136,6 @@ class rveven_paritycheck(WIDTH:Int= 16) extends Module{    //Done for verificati | ||||||
|     io.parity_err := (io.data_in.xorR.asUInt) ^ io.parity_in |     io.parity_err := (io.data_in.xorR.asUInt) ^ io.parity_in | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvecc_encode extends Module{   //Done for verification and testing |   class rvecc_encode extends Module{   //Done for verification and testing | ||||||
|     val io      =  IO(new Bundle{ |     val io      =  IO(new Bundle{ | ||||||
|       val din     =  Input(UInt(32.W)) |       val din     =  Input(UInt(32.W)) | ||||||
|  | @ -185,8 +169,6 @@ class rvecc_encode extends Module{   //Done for verification and testing | ||||||
|     io.ecc_out := Cat(io.din.xorR ^ w6.xorR, w6) |     io.ecc_out := Cat(io.din.xorR ^ w6.xorR, w6) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvecc_decode extends Module{  //Done for verification and testing |   class rvecc_decode extends Module{  //Done for verification and testing | ||||||
|     val io      =  IO(new Bundle{ |     val io      =  IO(new Bundle{ | ||||||
|       val en      =  Input(UInt(1.W)) |       val en      =  Input(UInt(1.W)) | ||||||
|  | @ -226,7 +208,7 @@ class rvecc_decode extends Module{  //Done for verification and testing | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     val ecc_check = Cat((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded ,io.ecc_in(5)^(w5.asUInt.xorR),io.ecc_in(4)^(w4.asUInt.xorR),io.ecc_in(3)^(w3.asUInt.xorR),io.ecc_in(2)^(w2.asUInt.xorR),io.ecc_in(1)^(w1.asUInt.xorR),io.ecc_in(0)^(w0.asUInt.xorR)) |     val ecc_check = Cat((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded ,io.ecc_in(5)^(w5.asUInt.xorR),io.ecc_in(4)^(w4.asUInt.xorR),io.ecc_in(3)^(w3.asUInt.xorR),io.ecc_in(2)^(w2.asUInt.xorR),io.ecc_in(1)^(w1.asUInt.xorR),io.ecc_in(0)^(w0.asUInt.xorR)) | ||||||
|   io.ecc_out := ecc_check | 
 | ||||||
| 
 | 
 | ||||||
|     io.single_ecc_error :=  io.en & (ecc_check!= 0.U) & ((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded) |     io.single_ecc_error :=  io.en & (ecc_check!= 0.U) & ((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded) | ||||||
|     io.double_ecc_error :=  io.en & (ecc_check!= 0.U) & ((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded) |     io.double_ecc_error :=  io.en & (ecc_check!= 0.U) & ((io.din.xorR ^ io.ecc_in.xorR) & ~io.sed_ded) | ||||||
|  | @ -242,11 +224,6 @@ class rvecc_decode extends Module{  //Done for verification and testing | ||||||
|     io.ecc_out := Cat(dout_plus_parity(38) ^ (ecc_check(6,0) === "b1000000".U), dout_plus_parity(31), dout_plus_parity(15), dout_plus_parity(7), dout_plus_parity(3), dout_plus_parity(1,0)) |     io.ecc_out := Cat(dout_plus_parity(38) ^ (ecc_check(6,0) === "b1000000".U), dout_plus_parity(31), dout_plus_parity(15), dout_plus_parity(7), dout_plus_parity(3), dout_plus_parity(1,0)) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvecc_encode_64 extends Module{    //Done for verification and testing |   class rvecc_encode_64 extends Module{    //Done for verification and testing | ||||||
|     val io      =  IO(new Bundle{ |     val io      =  IO(new Bundle{ | ||||||
|       val din     =  Input(UInt(64.W)) |       val din     =  Input(UInt(64.W)) | ||||||
|  | @ -284,10 +261,6 @@ class rvecc_encode_64 extends Module{    //Done for verification and testing | ||||||
|     io.ecc_out := Cat((w0.asUInt.xorR),(w1.asUInt.xorR),(w2.asUInt.xorR),(w3.asUInt.xorR),(w4.asUInt.xorR),(w5.asUInt.xorR),(w6.asUInt.xorR)) |     io.ecc_out := Cat((w0.asUInt.xorR),(w1.asUInt.xorR),(w2.asUInt.xorR),(w3.asUInt.xorR),(w4.asUInt.xorR),(w5.asUInt.xorR),(w6.asUInt.xorR)) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   class rvecc_decode_64 extends Module{     //Done for verification and testing |   class rvecc_decode_64 extends Module{     //Done for verification and testing | ||||||
|     val io        =  IO(new Bundle{ |     val io        =  IO(new Bundle{ | ||||||
|       val en        =  Input(UInt(1.W)) |       val en        =  Input(UInt(1.W)) | ||||||
|  | @ -329,6 +302,68 @@ class rvecc_decode_64 extends Module{     //Done for verification and testing | ||||||
|     io.ecc_error := io.en & (ecc_check(6,0) != 0.U) |     io.ecc_error := io.en & (ecc_check(6,0) != 0.U) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |   ////////////////////////////TEC_RV_ICG//////////////////////// | ||||||
|  |   class TEC_RV_ICG extends BlackBox with HasBlackBoxResource { | ||||||
|  |     val io = IO(new Bundle { | ||||||
|  |       val Q = Output(Clock()) | ||||||
|  |       val CK  = Input(Clock()) | ||||||
|  |       val EN  = Input(Bool()) | ||||||
|  |       val SE = Input(Bool()) | ||||||
|  |     }) | ||||||
|  |     addResource("/vsrc/TEC_RV_ICG.v") | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   class rvclkhdr extends Module { | ||||||
|  |     val io = IO(new Bundle { | ||||||
|  |       val l1clk = Output(Clock()) | ||||||
|  |       val clk  = Input(Clock()) | ||||||
|  |       val en  = Input(Bool()) | ||||||
|  |       val scan_mode = Input(Bool()) | ||||||
|  |     }) | ||||||
|  |     val clkhdr = { Module(new TEC_RV_ICG) } | ||||||
|  |     io.l1clk := clkhdr.io.Q | ||||||
|  |     clkhdr.io.CK := io.clk | ||||||
|  |     clkhdr.io.EN := io.en | ||||||
|  |     clkhdr.io.SE := io.scan_mode | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   object rvclkhdr { | ||||||
|  |   def apply(clk: Clock, en: Bool, scan_mode: Bool): Clock = { | ||||||
|  |     val cg = Module(new rvclkhdr) | ||||||
|  |     cg.io.clk := clk | ||||||
|  |     cg.io.en := en | ||||||
|  |     cg.io.scan_mode := scan_mode | ||||||
|  |     cg.io.l1clk | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |   ////Instantiation example///////////////Can be use if using class instead of function rvdffe | ||||||
|  |   class my_class extends Module{ | ||||||
|  |     val io = IO(new Bundle { | ||||||
|  |       val l1clk = Output(Clock()) | ||||||
|  |       val clk  = Input(Clock()) | ||||||
|  |       val en  = Input(Bool()) | ||||||
|  |       val scan_mode = Input(Bool()) | ||||||
|  |     }) | ||||||
|  |     val obj = Module(new rvclkhdr()) | ||||||
|  |     io.l1clk := obj.io.l1clk | ||||||
|  |     obj.io.clk := io.clk | ||||||
|  |     obj.io.en := io.en | ||||||
|  |     obj.io.scan_mode := io.scan_mode | ||||||
|  |   } | ||||||
|  | /* | ||||||
|  | object main extends App{ | ||||||
|  |   chisel3.Driver.execute(args,()=> new my_class) | ||||||
|  | }*/ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue