DataOutMux.v 4.2 KB

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