FPGA.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641
  1. using NIFPGA.lvbitx;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Diagnostics;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Threading.Tasks.Dataflow;
  9. using FxpConvert.Common;
  10. namespace NIFPGA
  11. {
  12. public sealed class FPGA
  13. {
  14. private List<Fifo> fifos= new List<Fifo>();
  15. private IFxpConvert _FXPConvert;
  16. private List<FPGABaseProperty> properties= new List<FPGABaseProperty>();
  17. public IReadOnlyDictionary<String,Fifo> Fifos => fifos.ToDictionary(x=>x.Name);
  18. public IReadOnlyDictionary<String,FPGABaseProperty> Properties=> properties.ToDictionary(x=>x.Name);
  19. private FPGASession session;
  20. public Boolean Error=> session.Error;
  21. public string Message=>session.Message;
  22. public FPGA(IFxpConvert convert)
  23. {
  24. _FXPConvert = convert;
  25. session = new FPGASession();
  26. Irq = new Irq(session);
  27. }
  28. public T CreateProperty<T>(string name) where T :FPGABaseProperty
  29. {
  30. var pro = properties.FirstOrDefault(x => x.Name == name);
  31. if (pro == null) throw new Exception($"Property {name} not found");
  32. return (T)pro;
  33. }
  34. public T CreateFifo<T>(string name) where T:Fifo
  35. {
  36. var fifo = fifos.FirstOrDefault(x => x.Name == name);
  37. if (fifo == null) throw new Exception($"Fifo {name} not found");
  38. return (T)fifo;
  39. }
  40. public void Parse(string path)
  41. {
  42. var val = lvbitx.Parse.ParseFile(path);
  43. InitProperies(val.VI.Registers);
  44. InitFifo(val.Project.DMA);
  45. }
  46. private void InitFifo(List<DMA> dma)
  47. {
  48. if (dma == null || dma.Count == 0) return;
  49. dma.ForEach(x =>
  50. {
  51. switch(x.Direction)
  52. {
  53. case "TargetToHost"://read
  54. switch (x.Datatype)
  55. {
  56. case Datatype.Boolean:
  57. fifos.Add(new ReadFifo<bool>(session, x.ControlSet)
  58. {
  59. Name = x.Name,
  60. });
  61. break;
  62. case Datatype.Int8:
  63. fifos.Add(new ReadFifo<sbyte>(session, x.ControlSet)
  64. {
  65. Name = x.Name,
  66. });
  67. break;
  68. case Datatype.Uint8:
  69. fifos.Add(new ReadFifo<byte>(session, x.ControlSet) { Name = x.Name });
  70. break;
  71. case Datatype.Int16:
  72. fifos.Add(new ReadFifo<short>(session, x.ControlSet) { Name = x.Name });
  73. break;
  74. case Datatype.Uint16:
  75. fifos.Add(new ReadFifo<ushort>(session, x.ControlSet) { Name = x.Name });
  76. break;
  77. case Datatype.Int32:
  78. fifos.Add(new ReadFifo<int>(session, x.ControlSet) { Name = x.Name });
  79. break;
  80. case Datatype.Uint32:
  81. fifos.Add(new ReadFifo<uint>(session, x.ControlSet) { Name = x.Name });
  82. break;
  83. case Datatype.Int64:
  84. fifos.Add(new ReadFifo<long>(session, x.ControlSet) { Name = x.Name });
  85. break;
  86. case Datatype.Uint64:
  87. fifos.Add(new ReadFifo<ulong>(session, x.ControlSet) { Name = x.Name });
  88. break;
  89. case Datatype.Float:
  90. fifos.Add(new ReadFifo<float>(session, x.ControlSet) { Name = x.Name });
  91. break;
  92. case Datatype.Double:
  93. fifos.Add(new ReadFifo<double>(session, x.ControlSet) { Name = x.Name });
  94. break;
  95. case Datatype.FXP:
  96. fifos.Add(new ReadFXPFifo(session, x.ControlSet,x.FxpTypeInfo, _FXPConvert)
  97. {
  98. Name = x.Name,
  99. });
  100. break;
  101. case Datatype.Array:
  102. break;
  103. }
  104. break;
  105. case "HostToTarget"://write
  106. switch (x.Datatype)
  107. {
  108. case Datatype.Boolean:
  109. fifos.Add(new WriteFifo<bool>(session, x.ControlSet) { Name = x.Name });
  110. break;
  111. case Datatype.Int8:
  112. fifos.Add(new WriteFifo<sbyte>(session, x.ControlSet) { Name = x.Name });
  113. break;
  114. case Datatype.Uint8:
  115. fifos.Add(new WriteFifo<byte>(session, x.ControlSet) { Name = x.Name });
  116. break;
  117. case Datatype.Int16:
  118. fifos.Add(new WriteFifo<short>(session, x.ControlSet) { Name = x.Name });
  119. break;
  120. case Datatype.Uint16:
  121. fifos.Add(new WriteFifo<ushort>(session, x.ControlSet) { Name = x.Name });
  122. break;
  123. case Datatype.Int32:
  124. fifos.Add(new WriteFifo<int>(session, x.ControlSet) { Name = x.Name });
  125. break;
  126. case Datatype.Uint32:
  127. fifos.Add(new WriteFifo<uint>(session, x.ControlSet) { Name = x.Name });
  128. break;
  129. case Datatype.Int64:
  130. fifos.Add(new WriteFifo<long>(session, x.ControlSet) { Name = x.Name });
  131. break;
  132. case Datatype.Uint64:
  133. fifos.Add(new WriteFifo<ulong>(session, x.ControlSet) { Name = x.Name });
  134. break;
  135. case Datatype.Float:
  136. fifos.Add(new WriteFifo<float>(session, x.ControlSet) { Name = x.Name });
  137. break;
  138. case Datatype.Double:
  139. fifos.Add(new WriteFifo<double>(session, x.ControlSet) { Name = x.Name });
  140. break;
  141. case Datatype.FXP:
  142. fifos.Add(new WriteFXPFifo(session, x.ControlSet, x.FxpTypeInfo, _FXPConvert) { Name = x.Name });
  143. break;
  144. case Datatype.Array:
  145. break;
  146. }
  147. break;
  148. }
  149. });
  150. }
  151. public Irq Irq { get; }
  152. public void Open(string bitfile, string resource, NiFpga_OpenAttribute attribute)
  153. {
  154. var lv = lvbitx.Parse.ParseFile(bitfile);
  155. InitProperies(lv.VI.Registers);
  156. InitFifo(lv.Project.DMA);
  157. session.Open(bitfile, lv.SignatureRegister, resource, attribute);
  158. }
  159. private void InitProperies(List<lvbitx.Register> registers)
  160. {
  161. if (registers == null || registers.Count == 0) return;
  162. foreach (var reg in registers)
  163. {
  164. switch (reg.Datatype)
  165. {
  166. case lvbitx.Datatype.Int16:
  167. if (!reg.Indicator)
  168. {
  169. properties.Add(new FPGAWriteProperty<short>(session, reg.Offset)
  170. {
  171. Name = reg.Name,
  172. SizeInBits = reg.SizeInBits,
  173. });
  174. }
  175. else
  176. {
  177. properties.Add(new FPGAReadProperty<short>(session, reg.Offset)
  178. {
  179. Name = reg.Name,
  180. SizeInBits = reg.SizeInBits,
  181. });
  182. }
  183. break;
  184. case lvbitx.Datatype.Boolean:
  185. if (!reg.Indicator)
  186. {
  187. properties.Add(new FPGAWriteProperty<bool>(session, reg.Offset)
  188. {
  189. Name = reg.Name,
  190. SizeInBits = reg.SizeInBits,
  191. });
  192. }
  193. else
  194. {
  195. properties.Add(new FPGAReadProperty<bool>(session, reg.Offset)
  196. {
  197. Name = reg.Name,
  198. SizeInBits = reg.SizeInBits,
  199. });
  200. }
  201. break;
  202. case lvbitx.Datatype.Int8:
  203. if (!reg.Indicator)
  204. {
  205. properties.Add(new FPGAWriteProperty<sbyte>(session, reg.Offset)
  206. {
  207. Name = reg.Name,
  208. SizeInBits = reg.SizeInBits,
  209. });
  210. }
  211. else
  212. {
  213. properties.Add(new FPGAReadProperty<sbyte>(session, reg.Offset)
  214. {
  215. Name = reg.Name,
  216. SizeInBits = reg.SizeInBits,
  217. });
  218. }
  219. break;
  220. case lvbitx.Datatype.Uint8:
  221. if (!reg.Indicator)
  222. {
  223. properties.Add(new FPGAWriteProperty<byte>(session, reg.Offset)
  224. {
  225. Name = reg.Name,
  226. SizeInBits = reg.SizeInBits,
  227. });
  228. }
  229. else
  230. {
  231. properties.Add(new FPGAReadProperty<byte>(session, reg.Offset)
  232. {
  233. Name = reg.Name,
  234. SizeInBits = reg.SizeInBits,
  235. });
  236. }
  237. break;
  238. case lvbitx.Datatype.Uint16:
  239. if (!reg.Indicator)
  240. {
  241. properties.Add(new FPGAWriteProperty<ushort>(session, reg.Offset)
  242. {
  243. Name = reg.Name,
  244. SizeInBits = reg.SizeInBits,
  245. });
  246. }
  247. else
  248. {
  249. properties.Add(new FPGAReadProperty<ushort>(session, reg.Offset)
  250. {
  251. Name = reg.Name,
  252. SizeInBits = reg.SizeInBits,
  253. });
  254. }
  255. break;
  256. case lvbitx.Datatype.Int32:
  257. if (!reg.Indicator)
  258. {
  259. properties.Add(new FPGAWriteProperty<int>(session, reg.Offset)
  260. {
  261. Name = reg.Name,
  262. SizeInBits = reg.SizeInBits,
  263. });
  264. }
  265. else
  266. {
  267. properties.Add(new FPGAReadProperty<int>(session, reg.Offset)
  268. {
  269. Name = reg.Name,
  270. SizeInBits = reg.SizeInBits,
  271. });
  272. }
  273. break;
  274. case lvbitx.Datatype.Uint32:
  275. if (!reg.Indicator)
  276. {
  277. properties.Add(new FPGAWriteProperty<uint>(session, reg.Offset)
  278. {
  279. Name = reg.Name,
  280. SizeInBits = reg.SizeInBits,
  281. });
  282. }
  283. else
  284. {
  285. properties.Add(new FPGAReadProperty<uint>(session, reg.Offset)
  286. {
  287. Name = reg.Name,
  288. SizeInBits = reg.SizeInBits,
  289. });
  290. }
  291. break;
  292. case lvbitx.Datatype.Int64:
  293. if (!reg.Indicator)
  294. {
  295. properties.Add(new FPGAWriteProperty<long>(session, reg.Offset)
  296. {
  297. Name = reg.Name,
  298. SizeInBits = reg.SizeInBits,
  299. });
  300. }
  301. else
  302. {
  303. properties.Add(new FPGAReadProperty<long>(session, reg.Offset)
  304. {
  305. Name = reg.Name,
  306. SizeInBits = reg.SizeInBits,
  307. });
  308. }
  309. break;
  310. case lvbitx.Datatype.Uint64:
  311. if (!reg.Indicator)
  312. {
  313. properties.Add(new FPGAWriteProperty<ulong>(session, reg.Offset)
  314. {
  315. Name = reg.Name,
  316. SizeInBits = reg.SizeInBits,
  317. });
  318. }
  319. else
  320. {
  321. properties.Add(new FPGAReadProperty<ulong>(session, reg.Offset)
  322. {
  323. Name = reg.Name,
  324. SizeInBits = reg.SizeInBits,
  325. });
  326. }
  327. break;
  328. case lvbitx.Datatype.Float:
  329. if (!reg.Indicator)
  330. {
  331. properties.Add(new FPGAWriteProperty<float>(session, reg.Offset)
  332. {
  333. Name = reg.Name,
  334. SizeInBits = reg.SizeInBits,
  335. });
  336. }
  337. else
  338. {
  339. properties.Add(new FPGAReadProperty<float>(session, reg.Offset)
  340. {
  341. Name = reg.Name,
  342. SizeInBits = reg.SizeInBits,
  343. });
  344. }
  345. break;
  346. case lvbitx.Datatype.Double:
  347. if (!reg.Indicator)
  348. {
  349. properties.Add(new FPGAWriteProperty<double>(session, reg.Offset)
  350. {
  351. Name = reg.Name,
  352. SizeInBits = reg.SizeInBits,
  353. });
  354. }
  355. else
  356. {
  357. properties.Add(new FPGAReadProperty<double>(session, reg.Offset)
  358. {
  359. Name = reg.Name,
  360. SizeInBits = reg.SizeInBits,
  361. });
  362. }
  363. break;
  364. case lvbitx.Datatype.FXP:
  365. if (!reg.Indicator)
  366. {
  367. properties.Add(new FPGAFXPWriteProperty(session, reg.Offset, reg.FxpTypeInfo, _FXPConvert)
  368. {
  369. Name = reg.Name,
  370. SizeInBits = reg.SizeInBits,
  371. });
  372. }
  373. else
  374. {
  375. properties.Add(new FPGAFXPReadProperty(session, reg.Offset, reg.FxpTypeInfo, _FXPConvert)
  376. {
  377. Name = reg.Name,
  378. SizeInBits = reg.SizeInBits,
  379. });
  380. }
  381. break;
  382. case lvbitx.Datatype.Array:
  383. switch (reg.ArrayValueType)
  384. {
  385. case lvbitx.Datatype.Boolean:
  386. if (!reg.Indicator)
  387. {
  388. properties.Add(new FPGAArrayWriteProperty<bool>(session, reg.Offset, reg.Size)
  389. {
  390. Name = reg.Name,
  391. SizeInBits = reg.SizeInBits,
  392. });
  393. }
  394. else
  395. {
  396. properties.Add(new FPGAArrayReadProperty<bool>(session, reg.Offset, reg.Size)
  397. {
  398. Name = reg.Name,
  399. SizeInBits = reg.SizeInBits,
  400. });
  401. }
  402. break;
  403. case lvbitx.Datatype.Int8:
  404. if (!reg.Indicator)
  405. {
  406. properties.Add(new FPGAArrayWriteProperty<sbyte>(session, reg.Offset, reg.Size)
  407. {
  408. Name = reg.Name,
  409. SizeInBits = reg.SizeInBits,
  410. });
  411. }
  412. else
  413. {
  414. properties.Add(new FPGAArrayReadProperty<sbyte>(session, reg.Offset, reg.Size)
  415. {
  416. Name = reg.Name,
  417. SizeInBits = reg.SizeInBits,
  418. });
  419. }
  420. break;
  421. case lvbitx.Datatype.Uint8:
  422. if (!reg.Indicator)
  423. {
  424. properties.Add(new FPGAArrayWriteProperty<byte>(session, reg.Offset, reg.Size)
  425. {
  426. Name = reg.Name,
  427. SizeInBits = reg.SizeInBits,
  428. });
  429. }
  430. else
  431. {
  432. properties.Add(new FPGAArrayReadProperty<byte>(session, reg.Offset, reg.Size)
  433. {
  434. Name = reg.Name,
  435. SizeInBits = reg.SizeInBits,
  436. });
  437. }
  438. break;
  439. case lvbitx.Datatype.Int16:
  440. if (!reg.Indicator)
  441. {
  442. properties.Add(new FPGAArrayWriteProperty<short>(session, reg.Offset, reg.Size)
  443. {
  444. Name = reg.Name,
  445. SizeInBits = reg.SizeInBits,
  446. });
  447. }
  448. else
  449. {
  450. properties.Add(new FPGAArrayReadProperty<short>(session, reg.Offset, reg.Size)
  451. {
  452. Name = reg.Name,
  453. SizeInBits = reg.SizeInBits,
  454. });
  455. }
  456. break;
  457. case lvbitx.Datatype.Uint16:
  458. if (!reg.Indicator)
  459. {
  460. properties.Add(new FPGAArrayWriteProperty<ushort>(session, reg.Offset, reg.Size)
  461. {
  462. Name = reg.Name,
  463. SizeInBits = reg.SizeInBits,
  464. });
  465. }
  466. else
  467. {
  468. properties.Add(new FPGAArrayReadProperty<ushort>(session, reg.Offset, reg.Size)
  469. {
  470. Name = reg.Name,
  471. SizeInBits = reg.SizeInBits,
  472. });
  473. }
  474. break;
  475. case lvbitx.Datatype.Int32:
  476. if (!reg.Indicator)
  477. {
  478. properties.Add(new FPGAArrayWriteProperty<int>(session, reg.Offset, reg.Size)
  479. {
  480. Name = reg.Name,
  481. SizeInBits = reg.SizeInBits,
  482. });
  483. }
  484. else
  485. {
  486. properties.Add(new FPGAArrayReadProperty<int>(session, reg.Offset, reg.Size)
  487. {
  488. Name = reg.Name,
  489. SizeInBits = reg.SizeInBits,
  490. });
  491. }
  492. break;
  493. case lvbitx.Datatype.Uint32:
  494. if (!reg.Indicator)
  495. {
  496. properties.Add(new FPGAArrayWriteProperty<uint>(session, reg.Offset, reg.Size)
  497. {
  498. Name = reg.Name,
  499. SizeInBits = reg.SizeInBits,
  500. });
  501. }
  502. else
  503. {
  504. properties.Add(new FPGAArrayReadProperty<uint>(session, reg.Offset, reg.Size)
  505. {
  506. Name = reg.Name,
  507. SizeInBits = reg.SizeInBits,
  508. });
  509. }
  510. break;
  511. case lvbitx.Datatype.Int64:
  512. if (!reg.Indicator)
  513. {
  514. properties.Add(new FPGAArrayWriteProperty<long>(session, reg.Offset, reg.Size)
  515. {
  516. Name = reg.Name,
  517. SizeInBits = reg.SizeInBits,
  518. });
  519. }
  520. else
  521. {
  522. properties.Add(new FPGAArrayReadProperty<long>(session, reg.Offset, reg.Size)
  523. {
  524. Name = reg.Name,
  525. SizeInBits = reg.SizeInBits,
  526. });
  527. }
  528. break;
  529. case lvbitx.Datatype.Uint64:
  530. if (!reg.Indicator)
  531. {
  532. properties.Add(new FPGAArrayWriteProperty<ulong>(session, reg.Offset, reg.Size)
  533. {
  534. Name = reg.Name,
  535. SizeInBits = reg.SizeInBits,
  536. });
  537. }
  538. else
  539. {
  540. properties.Add(new FPGAArrayReadProperty<ulong>(session, reg.Offset, reg.Size)
  541. {
  542. Name = reg.Name,
  543. SizeInBits = reg.SizeInBits,
  544. });
  545. }
  546. break;
  547. case lvbitx.Datatype.Float:
  548. if (!reg.Indicator)
  549. {
  550. properties.Add(new FPGAArrayWriteProperty<float>(session, reg.Offset, reg.Size)
  551. {
  552. Name = reg.Name,
  553. SizeInBits = reg.SizeInBits,
  554. });
  555. }
  556. else
  557. {
  558. properties.Add(new FPGAArrayReadProperty<float>(session, reg.Offset, reg.Size)
  559. {
  560. Name = reg.Name,
  561. SizeInBits = reg.SizeInBits,
  562. });
  563. }
  564. break;
  565. case lvbitx.Datatype.Double:
  566. if (!reg.Indicator)
  567. {
  568. properties.Add(new FPGAArrayWriteProperty<double>(session, reg.Offset, reg.Size)
  569. {
  570. Name = reg.Name,
  571. SizeInBits = reg.SizeInBits,
  572. });
  573. }
  574. else
  575. {
  576. properties.Add(new FPGAArrayReadProperty<double>(session, reg.Offset, reg.Size)
  577. {
  578. Name = reg.Name,
  579. SizeInBits = reg.SizeInBits,
  580. });
  581. }
  582. break;
  583. case lvbitx.Datatype.FXP:
  584. if (!reg.Indicator)
  585. {
  586. properties.Add(new FPGAArrayFXPWriteProperty(session, reg.Offset, reg.Size, reg.FxpTypeInfo, _FXPConvert)
  587. {
  588. Name = reg.Name,
  589. SizeInBits = reg.SizeInBits,
  590. });
  591. }
  592. else
  593. {
  594. properties.Add(new FPGAArrayFXPReadProperty(session, reg.Offset, reg.Size, reg.FxpTypeInfo, _FXPConvert)
  595. {
  596. Name = reg.Name,
  597. SizeInBits = reg.SizeInBits,
  598. });
  599. }
  600. break;
  601. case lvbitx.Datatype.Array:
  602. break;
  603. }
  604. break;
  605. }
  606. }
  607. }
  608. public void Close()=>session.Close();
  609. public void Run()
  610. {
  611. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Run>()(session.Session, Interop.NiFpga_RunAttribute.NiFpga_RunAttribute_None));
  612. }
  613. public void Abort()
  614. {
  615. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Abort>()(session.Session));
  616. }
  617. public void Reset()
  618. {
  619. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Reset>()(session.Session));
  620. }
  621. public void Download()
  622. {
  623. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Download>()(session.Session));
  624. }
  625. }
  626. }