DataOutMux.v 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. module DataOutMux#(
  2. parameter CmdRegWidth = 32,
  3. parameter AddrRegWidth= 12
  4. ) (
  5. input Rst_i,
  6. input Clk_i,
  7. input SmcAre_i,
  8. input [AddrRegWidth-1:0] Addr_i,
  9. input [AddrRegWidth-1:0] ToRegMapAddr_i,
  10. input [CmdRegWidth/2-1:0] DataFromRegMap_i,
  11. input [CmdRegWidth-1:0] DataFromRxFifo1_i,
  12. input [CmdRegWidth-1:0] DataFromRxFifo2_i,
  13. input [CmdRegWidth-1:0] DataFromRxFifo3_i,
  14. input [CmdRegWidth-1:0] DataFromRxFifo4_i,
  15. input [CmdRegWidth-1:0] DataFromRxFifo5_i,
  16. input [CmdRegWidth-1:0] DataFromRxFifo6_i,
  17. input [CmdRegWidth-1:0] DataFromRxFifo7_i,
  18. output [CmdRegWidth/2-1:0] AnsData_o
  19. );
  20. wire [0:31] dataFromRxFifo [6:0];
  21. wire [15:0] dataFromRegMap;
  22. reg [15:0] dataFromRxFifoR;
  23. (* dont_touch = "true" *)reg [CmdRegWidth/2-1:0] dataFromRxFifoR1;
  24. reg [CmdRegWidth-1:0] dataFromRxFifoR2;
  25. reg [CmdRegWidth-1:0] dataFromRxFifoR3;
  26. reg [CmdRegWidth-1:0] dataFromRxFifoR4;
  27. reg [CmdRegWidth-1:0] dataFromRxFifoR5;
  28. reg [CmdRegWidth-1:0] dataFromRxFifoR6;
  29. reg [CmdRegWidth-1:0] dataFromRxFifoR7;
  30. assign dataFromRxFifo[0] = DataFromRxFifo1_i;
  31. assign dataFromRxFifo[1] = DataFromRxFifo2_i;
  32. assign dataFromRxFifo[2] = DataFromRxFifo3_i;
  33. assign dataFromRxFifo[3] = DataFromRxFifo4_i;
  34. assign dataFromRxFifo[4] = DataFromRxFifo5_i;
  35. assign dataFromRxFifo[5] = DataFromRxFifo6_i;
  36. assign dataFromRxFifo[6] = DataFromRxFifo7_i;
  37. assign dataFromRegMap = DataFromRegMap_i;
  38. assign AnsData_o = (ToRegMapAddr_i)?dataFromRegMap:dataFromRxFifoR;
  39. always @(*) begin
  40. if (Rst_i) begin
  41. dataFromRxFifoR1 = 0;
  42. dataFromRxFifoR2 = 0;
  43. dataFromRxFifoR3 = 0;
  44. dataFromRxFifoR4 = 0;
  45. dataFromRxFifoR5 = 0;
  46. dataFromRxFifoR6 = 0;
  47. dataFromRxFifoR7 = 0;
  48. end
  49. else begin
  50. if (!SmcAre_i) begin
  51. case(Addr_i)
  52. 12'h1c : begin
  53. dataFromRxFifoR1 = DataFromRxFifo1_i[31:16];
  54. end
  55. 12'h6c : begin
  56. dataFromRxFifoR2 = DataFromRxFifo2_i;
  57. end
  58. 12'h10c : begin
  59. dataFromRxFifoR3 = DataFromRxFifo3_i;
  60. end
  61. 12'h15c : begin
  62. dataFromRxFifoR4 = DataFromRxFifo4_i;
  63. end
  64. 12'h1ac : begin
  65. dataFromRxFifoR5 = DataFromRxFifo5_i;
  66. end
  67. 12'h1fc : begin
  68. dataFromRxFifoR6 = DataFromRxFifo6_i;
  69. end
  70. 12'h24c : begin
  71. dataFromRxFifoR7 = DataFromRxFifo7_i;
  72. end
  73. endcase
  74. end
  75. end
  76. end
  77. always @(*) begin
  78. case (Addr_i)
  79. 12'h1c: begin
  80. dataFromRxFifoR = DataFromRxFifo1_i[15:0];
  81. end
  82. 12'h1e: begin
  83. dataFromRxFifoR = dataFromRxFifoR1;
  84. end
  85. 12'h6c: begin
  86. dataFromRxFifoR = DataFromRxFifo2_i[15:0];
  87. end
  88. 12'h6e: begin
  89. dataFromRxFifoR = dataFromRxFifoR2[31:16];
  90. end
  91. 12'h10c: begin
  92. dataFromRxFifoR = DataFromRxFifo3_i[15:0];
  93. end
  94. 12'h10e: begin
  95. dataFromRxFifoR = dataFromRxFifoR3[31:16];
  96. end
  97. 12'h15c: begin
  98. dataFromRxFifoR = DataFromRxFifo4_i[15:0];
  99. end
  100. 12'h15e: begin
  101. dataFromRxFifoR = dataFromRxFifoR4[31:16];
  102. end
  103. 12'h1ac: begin
  104. dataFromRxFifoR = DataFromRxFifo5_i[15:0];
  105. end
  106. 12'h1ae: begin
  107. dataFromRxFifoR = dataFromRxFifoR5[31:16];
  108. end
  109. 12'h1fc: begin
  110. dataFromRxFifoR = DataFromRxFifo6_i[15:0];
  111. end
  112. 12'h1fe: begin
  113. dataFromRxFifoR = dataFromRxFifoR6[31:16];
  114. end
  115. 12'h24c: begin
  116. dataFromRxFifoR = DataFromRxFifo7_i[15:0];
  117. end
  118. 12'h24e: begin
  119. dataFromRxFifoR = dataFromRxFifoR7[31:16];
  120. end
  121. default: begin
  122. dataFromRxFifoR = 16'h0;
  123. end
  124. endcase
  125. end
  126. endmodule