InputMuxTb.sv 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. module InputMuxTb #(
  2. parameter AXI_DATA_WIDTH = 64,
  3. parameter SPI_NUM = 7,
  4. parameter FIFO_TX1_ADDR = 64'h0000000000001028,
  5. parameter FIFO_TX2_ADDR = 64'h0000000000002028,
  6. parameter FIFO_TX3_ADDR = 64'h0000000000003028,
  7. parameter FIFO_TX4_ADDR = 64'h0000000000004028,
  8. parameter FIFO_TX5_ADDR = 64'h0000000000005028,
  9. parameter FIFO_TX6_ADDR = 64'h0000000000006028,
  10. parameter FIFO_TX7_ADDR = 64'h0000000000007028,
  11. parameter REGMAP_ADDR = 64'h0000000000001024,
  12. parameter REGMAP_ADDR1 = 64'h0000000000002008,
  13. parameter REGMAP_ADDR2 = 64'h0000000000003022
  14. )
  15. ();
  16. //================================================================================
  17. // LOCALPARAMS
  18. //================================================================================
  19. //================================================================================
  20. // REG/WIRE
  21. //================================================================================
  22. reg Clk_i;
  23. reg RstN_i;
  24. reg Val_i;
  25. reg [AXI_DATA_WIDTH-1:0] Data_i;
  26. reg [AXI_DATA_WIDTH-1:0] Addr_i;
  27. reg [31:0] tbCnt;
  28. //================================================================================
  29. // CODING
  30. //================================================================================
  31. always #(10/2) Clk_i = ~Clk_i;
  32. initial begin
  33. Clk_i = 1'b1;
  34. RstN_i = 1'b0;
  35. Val_i = 1'b0;
  36. Data_i = 64'h0;
  37. Addr_i = 0;
  38. #100
  39. RstN_i = 1'b1;
  40. end
  41. always @(posedge Clk_i) begin
  42. if (!RstN_i) begin
  43. tbCnt <= 0;
  44. end else begin
  45. tbCnt <= tbCnt+1;
  46. end
  47. end
  48. always @(posedge Clk_i) begin
  49. if (!RstN_i) begin
  50. Data_i <= 0;
  51. Addr_i <= 0;
  52. Val_i <= 0;
  53. end else begin
  54. case(tbCnt)
  55. 30: begin
  56. Data_i <= 64'h1;
  57. Addr_i <= FIFO_TX1_ADDR;
  58. Val_i <= 1;
  59. end
  60. 35: begin
  61. Data_i <= 64'h1;
  62. Addr_i <= FIFO_TX2_ADDR;
  63. Val_i <= 1;
  64. end
  65. 40: begin
  66. Data_i <= 64'h1;
  67. Addr_i <= FIFO_TX3_ADDR;
  68. Val_i <= 1;
  69. end
  70. 45: begin
  71. Data_i <= 64'h1;
  72. Addr_i <= REGMAP_ADDR;
  73. Val_i <= 1;
  74. end
  75. 50: begin
  76. Data_i <= 64'h1;
  77. Addr_i <= REGMAP_ADDR;
  78. Val_i <= 1;
  79. end
  80. 55: begin
  81. Data_i <= 64'h1;
  82. Addr_i <= REGMAP_ADDR1;
  83. Val_i <= 1;
  84. end
  85. 60: begin
  86. Data_i <= 64'h1;
  87. Addr_i <= REGMAP_ADDR2;
  88. Val_i <= 1;
  89. end
  90. default: begin
  91. Val_i <= 0;
  92. end
  93. endcase
  94. end
  95. end
  96. InputMux InputMux
  97. (
  98. .Clk_i (Clk_i),
  99. .RstN_i (RstN_i),
  100. .Val_i (Val_i),
  101. .Data_i (Data_i),
  102. .Addr_i (Addr_i),
  103. .ToRegMapAddr_o (),
  104. .Val_o (),
  105. .Data_o ()
  106. );
  107. endmodule