CPLD_Transmitter - 副本 (5).v 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  1. `timescale 1ns / 1ps
  2. //////////////////////////////////////////////////////////////////////////////////
  3. // Company:
  4. // Engineer:
  5. //
  6. // Create Date: 2022/05/17 23:16:57
  7. // Design Name:
  8. // Module Name: CounterTest
  9. // Project Name:
  10. // Target Devices:
  11. // Tool Versions:
  12. // Description:
  13. //
  14. // Dependencies:
  15. //
  16. // Revision:
  17. // Revision 0.01 - File Created
  18. // Additional Comments:
  19. //
  20. //////////////////////////////////////////////////////////////////////////////////
  21. module CPLD_Transmitter(
  22. Clk, BckIn, LrckIn, DataIn,
  23. BckOut, LrckOut, DataOut, StartFlag,
  24. DinStateOut0,DinStateOut1,RegDataInOut,DinWenDelayOut
  25. );
  26. input Clk, BckIn, LrckIn, DataIn;
  27. input StartFlag;
  28. output BckOut, LrckOut, DataOut;
  29. output DinStateOut0,DinStateOut1,RegDataInOut,DinWenDelayOut;
  30. ///// In Part
  31. reg RegLrckIn = 0;
  32. reg RegDataIn = 0;
  33. reg PreRegLrckIn = 0;
  34. reg PreRegDataIn = 0;
  35. reg DinWen = 0;
  36. reg DinWenDelay = 0;
  37. reg [15:0] DinStateCounter = 0;
  38. reg [1:0] DinState = 0;
  39. reg [5:0] DinInnerCounter = 0;
  40. reg [1:0] DinStateNeg = 0;
  41. ///// Out Part
  42. reg [1:0] BckOutCounter = 0;
  43. reg [5:0] LrckOutCounter = 0;
  44. reg FifoRen = 0;
  45. reg FifoRenPos = 0;
  46. reg DataOut = 0;
  47. reg [6:0] InnerInputCounter=0;
  48. reg [4:0] DoutReadCounter = 0;
  49. reg [1:0] ReadState = 0;
  50. reg [4:0] DoutReadCounterPos = 0;
  51. reg [1:0] ReadStatePos = 0;
  52. reg [31:0] FifoShifter = 0;
  53. reg [15:0] FifiReadOutterCounter = 0;
  54. // reg ReadStart = 0;
  55. wire [5:0] FifoWord;
  56. wire FifoEmp;
  57. wire FifoReadOut;
  58. assign BckOut = BckOutCounter[1];
  59. assign LrckOut = LrckOutCounter[5];
  60. //测试端口赋值
  61. assign DinStateOut0 = DinState[0];
  62. assign DinStateOut1 = DinState[1];
  63. assign RegDataInOut = RegDataIn;
  64. assign DinWenDelayOut = DinWenDelay;
  65. ///// In Part Logic
  66. always@(posedge BckIn)
  67. begin
  68. if(StartFlag == 1'b0)
  69. begin
  70. PreRegLrckIn <= 1'b0;
  71. PreRegDataIn <= 1'b0;
  72. end
  73. else
  74. begin
  75. PreRegLrckIn <= LrckIn;
  76. PreRegDataIn <= DataIn;
  77. end
  78. end
  79. always@(negedge BckIn)
  80. begin
  81. if(StartFlag == 1'b0)
  82. begin
  83. RegLrckIn <= 1'b0;
  84. RegDataIn <= 1'b0;
  85. end
  86. else
  87. begin
  88. RegLrckIn <= PreRegLrckIn;
  89. RegDataIn <= PreRegDataIn;
  90. end
  91. end
  92. always@(posedge BckIn)
  93. begin
  94. if(StartFlag == 1'b0)
  95. begin
  96. InnerInputCounter <= 7'd62;
  97. end
  98. else
  99. begin
  100. if((DinStateNeg==2'd2)||(DinStateNeg==2'd0))
  101. begin
  102. if(InnerInputCounter < 7'd62)
  103. begin
  104. InnerInputCounter <= InnerInputCounter + 7'd1;
  105. end
  106. else
  107. begin
  108. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  109. InnerInputCounter <= 7'd0;
  110. end
  111. end
  112. else
  113. InnerInputCounter <= 7'd62;
  114. end
  115. end
  116. always@(posedge BckIn)
  117. begin
  118. if(StartFlag == 1'b0)
  119. begin
  120. DinInnerCounter <= 6'd0;
  121. end
  122. else
  123. begin
  124. if(DinStateNeg==2'd2)
  125. begin
  126. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  127. DinInnerCounter <= 6'd0;
  128. else
  129. DinInnerCounter <= DinInnerCounter + 5'd1;
  130. end
  131. else
  132. DinInnerCounter <= 6'd0;
  133. end
  134. end
  135. always@(negedge BckIn)
  136. begin
  137. if(StartFlag == 1'b0)
  138. begin
  139. DinWenDelay <= 5'd0;
  140. end
  141. else
  142. begin
  143. DinWenDelay <= DinWen;
  144. end
  145. end
  146. always@(negedge BckIn)
  147. begin
  148. if(StartFlag == 1'b0)
  149. begin
  150. DinStateNeg <= 2'd0;
  151. end
  152. else
  153. begin
  154. DinStateNeg <= DinState;
  155. end
  156. end
  157. always@(posedge BckIn)
  158. begin
  159. if(StartFlag == 1'b0)
  160. begin
  161. DinState <= 2'd0;
  162. end
  163. else
  164. begin
  165. case(DinStateNeg)
  166. 2'd0:
  167. begin
  168. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  169. begin
  170. DinState <= 2'd2;
  171. end
  172. end
  173. 2'd1:
  174. begin
  175. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  176. begin
  177. DinState <= 2'd2;
  178. end
  179. end
  180. 2'd2:
  181. begin
  182. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) && ( DinStateCounter == 16'd45998 ) )
  183. begin
  184. DinState <= 2'd3;
  185. end
  186. end
  187. 2'd3:
  188. begin
  189. if( DinStateCounter == 16'd46000 )
  190. begin
  191. DinState <= 2'd1;
  192. end
  193. end
  194. endcase
  195. end
  196. end
  197. always@(posedge BckIn)
  198. begin
  199. if(StartFlag == 1'b0)
  200. begin
  201. DinStateCounter <= 16'd0;
  202. end
  203. else
  204. begin
  205. if(DinStateNeg == 2'd2 || DinStateNeg == 2'd3)
  206. begin
  207. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) && (InnerInputCounter == 7'd62))
  208. begin
  209. DinStateCounter <= DinStateCounter + 16'd1;
  210. end
  211. else
  212. DinStateCounter <= DinStateCounter;
  213. end
  214. else
  215. DinStateCounter <= 16'd0;
  216. end
  217. end
  218. always@(posedge BckIn)
  219. begin
  220. if(StartFlag == 1'b0)
  221. begin
  222. DinWen <= 1'd0;
  223. end
  224. else
  225. begin
  226. case(DinStateNeg)
  227. 2'd0:
  228. begin
  229. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  230. begin
  231. DinWen <= 1'd1;
  232. end
  233. else if( (DinStateCounter >= 16'd45998) )
  234. begin
  235. DinWen <= 1'd0;
  236. end
  237. end
  238. 2'd1:
  239. begin
  240. if( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) )
  241. begin
  242. DinWen <= 1'd1;
  243. end
  244. else if( (DinStateCounter >= 16'd45998) )
  245. begin
  246. DinWen <= 1'd0;
  247. end
  248. end
  249. 2'd2:
  250. begin
  251. if( (DinStateCounter >= 16'd45998) || (DinInnerCounter == 5'd24))
  252. begin
  253. DinWen <= 1'd0;
  254. end
  255. else if((DinStateCounter <= 16'd45998) && ( (RegLrckIn == 1'b1) && (LrckIn == 1'b0) ) )
  256. DinWen <= 1'd1;
  257. end
  258. 2'd3:
  259. begin
  260. if( (DinStateCounter >= 16'd45998) )
  261. begin
  262. DinWen <= 1'd0;
  263. end
  264. end
  265. endcase
  266. end
  267. end
  268. IP_FIFO IP_FIFO(
  269. .aclr(!StartFlag),
  270. .data(RegDataIn),
  271. .rdclk(BckOut),
  272. .rdreq(FifoRen),
  273. .wrclk(BckIn),
  274. .wrreq(DinWenDelay),
  275. .q(FifoReadOut),
  276. // .rdempty(FifoEmp),
  277. .rdusedw(FifoWord)
  278. );
  279. ///// Out Part Logic
  280. always@(posedge Clk)
  281. begin
  282. BckOutCounter <= BckOutCounter + 2'd1;
  283. end
  284. always@(negedge BckOut)
  285. begin
  286. LrckOutCounter <= LrckOutCounter + 6'd1;
  287. end
  288. always@(posedge BckOut)
  289. begin
  290. DoutReadCounterPos <= DoutReadCounter;
  291. end
  292. always@(negedge BckOut)
  293. begin
  294. if((LrckOutCounter==6'd63) || (LrckOutCounter==6'd31))
  295. DoutReadCounter <= 5'd0;
  296. else
  297. DoutReadCounter <= DoutReadCounterPos + 5'd1;
  298. end
  299. always@(posedge BckOut)
  300. begin
  301. FifoRenPos <= FifoRen;
  302. end
  303. always@(negedge BckOut)
  304. begin
  305. if( (LrckOutCounter == 6'd62) && (FifoWord >= 6'd6) && (ReadStatePos == 2'd0) )
  306. FifoRen <= 1'd1;
  307. else if( (LrckOutCounter == 6'd62) && (ReadStatePos == 2'd1) )
  308. FifoRen <= 1'd1;
  309. else if( (LrckOutCounter == 6'd23) && (FifoRenPos == 1'd1) ) // && (ReadStatePos == 2'd1)
  310. FifoRen <= 1'd0;
  311. end
  312. always@(posedge BckOut)
  313. begin
  314. if(StartFlag == 1'b0)
  315. begin
  316. ReadStatePos <= 2'd0;
  317. end
  318. else
  319. begin
  320. ReadStatePos <= ReadState;
  321. end
  322. end
  323. always@(posedge BckOut)
  324. begin
  325. if(StartFlag == 1'b0)
  326. begin
  327. FifiReadOutterCounter <= 16'd0;
  328. end
  329. else
  330. begin
  331. if(ReadStatePos == 1'b0)
  332. FifiReadOutterCounter <= 16'd0;
  333. else
  334. begin
  335. if( (LrckOutCounter == 6'd62) && (FifiReadOutterCounter < 16'd45999))
  336. FifiReadOutterCounter <= FifiReadOutterCounter + 16'd1;
  337. else
  338. FifiReadOutterCounter <= FifiReadOutterCounter;
  339. end
  340. end
  341. end
  342. always@(negedge BckOut)
  343. begin
  344. if(StartFlag == 1'b0)
  345. begin
  346. ReadState <= 2'd0;
  347. end
  348. begin
  349. if( (LrckOutCounter == 6'd62) && (FifoWord >= 6'd6) )
  350. ReadState <= 2'd1;
  351. else if( (FifoWord <= 6'd1) && (ReadState == 2'd1) && (FifiReadOutterCounter == 16'd45999 ) )
  352. ReadState <= 2'd0;
  353. end
  354. end
  355. always@(negedge BckOut)
  356. begin
  357. FifoShifter <= {FifoShifter[29:0], DataOut};
  358. end
  359. always@(negedge BckOut)
  360. begin
  361. if(ReadStatePos == 1'b0)
  362. DataOut <= 1'b0;
  363. else
  364. begin
  365. if(FifoRenPos == 1'b1)
  366. DataOut <= FifoReadOut;
  367. else
  368. DataOut <= FifoShifter[30];
  369. end
  370. end
  371. endmodule