FPGA.cs 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521
  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. });
  173. }
  174. else
  175. {
  176. properties.Add(new FPGAReadProperty<short>(session, reg.Offset)
  177. {
  178. Name = reg.Name,
  179. });
  180. }
  181. break;
  182. case lvbitx.Datatype.Boolean:
  183. if (!reg.Indicator)
  184. {
  185. properties.Add(new FPGAWriteProperty<bool>(session, reg.Offset)
  186. {
  187. Name = reg.Name,
  188. });
  189. }
  190. else
  191. {
  192. properties.Add(new FPGAReadProperty<bool>(session, reg.Offset)
  193. {
  194. Name = reg.Name,
  195. });
  196. }
  197. break;
  198. case lvbitx.Datatype.Int8:
  199. if (!reg.Indicator)
  200. {
  201. properties.Add(new FPGAWriteProperty<sbyte>(session, reg.Offset)
  202. {
  203. Name = reg.Name,
  204. });
  205. }
  206. else
  207. {
  208. properties.Add(new FPGAReadProperty<sbyte>(session, reg.Offset)
  209. {
  210. Name = reg.Name,
  211. });
  212. }
  213. break;
  214. case lvbitx.Datatype.Uint8:
  215. if (!reg.Indicator)
  216. {
  217. properties.Add(new FPGAWriteProperty<byte>(session, reg.Offset)
  218. {
  219. Name = reg.Name,
  220. });
  221. }
  222. else
  223. {
  224. properties.Add(new FPGAReadProperty<byte>(session, reg.Offset)
  225. {
  226. Name = reg.Name,
  227. });
  228. }
  229. break;
  230. case lvbitx.Datatype.Uint16:
  231. if (!reg.Indicator)
  232. {
  233. properties.Add(new FPGAWriteProperty<ushort>(session, reg.Offset)
  234. {
  235. Name = reg.Name,
  236. });
  237. }
  238. else
  239. {
  240. properties.Add(new FPGAReadProperty<ushort>(session, reg.Offset)
  241. {
  242. Name = reg.Name,
  243. });
  244. }
  245. break;
  246. case lvbitx.Datatype.Int32:
  247. if (!reg.Indicator)
  248. {
  249. properties.Add(new FPGAWriteProperty<int>(session, reg.Offset)
  250. {
  251. Name = reg.Name,
  252. });
  253. }
  254. else
  255. {
  256. properties.Add(new FPGAReadProperty<int>(session, reg.Offset)
  257. {
  258. Name = reg.Name,
  259. });
  260. }
  261. break;
  262. case lvbitx.Datatype.Uint32:
  263. if (!reg.Indicator)
  264. {
  265. properties.Add(new FPGAWriteProperty<uint>(session, reg.Offset)
  266. {
  267. Name = reg.Name,
  268. });
  269. }
  270. else
  271. {
  272. properties.Add(new FPGAReadProperty<uint>(session, reg.Offset)
  273. {
  274. Name = reg.Name,
  275. });
  276. }
  277. break;
  278. case lvbitx.Datatype.Int64:
  279. if (!reg.Indicator)
  280. {
  281. properties.Add(new FPGAWriteProperty<long>(session, reg.Offset)
  282. {
  283. Name = reg.Name,
  284. });
  285. }
  286. else
  287. {
  288. properties.Add(new FPGAReadProperty<long>(session, reg.Offset)
  289. {
  290. Name = reg.Name,
  291. });
  292. }
  293. break;
  294. case lvbitx.Datatype.Uint64:
  295. if (!reg.Indicator)
  296. {
  297. properties.Add(new FPGAWriteProperty<ulong>(session, reg.Offset)
  298. {
  299. Name = reg.Name,
  300. });
  301. }
  302. else
  303. {
  304. properties.Add(new FPGAReadProperty<ulong>(session, reg.Offset)
  305. {
  306. Name = reg.Name,
  307. });
  308. }
  309. break;
  310. case lvbitx.Datatype.Float:
  311. if (!reg.Indicator)
  312. {
  313. properties.Add(new FPGAWriteProperty<float>(session, reg.Offset)
  314. {
  315. Name = reg.Name,
  316. });
  317. }
  318. else
  319. {
  320. properties.Add(new FPGAReadProperty<float>(session, reg.Offset)
  321. {
  322. Name = reg.Name,
  323. });
  324. }
  325. break;
  326. case lvbitx.Datatype.Double:
  327. if (!reg.Indicator)
  328. {
  329. properties.Add(new FPGAWriteProperty<double>(session, reg.Offset)
  330. {
  331. Name = reg.Name,
  332. });
  333. }
  334. else
  335. {
  336. properties.Add(new FPGAReadProperty<double>(session, reg.Offset)
  337. {
  338. Name = reg.Name,
  339. });
  340. }
  341. break;
  342. case lvbitx.Datatype.FXP:
  343. if (!reg.Indicator)
  344. {
  345. properties.Add(new FPGAFXPWriteProperty(session, reg.Offset, reg.FxpTypeInfo, _FXPConvert)
  346. {
  347. Name = reg.Name,
  348. });
  349. }
  350. else
  351. {
  352. properties.Add(new FPGAFXPReadProperty(session, reg.Offset, reg.FxpTypeInfo, _FXPConvert)
  353. {
  354. Name = reg.Name,
  355. });
  356. }
  357. break;
  358. case lvbitx.Datatype.Array:
  359. switch (reg.ArrayValueType)
  360. {
  361. case lvbitx.Datatype.Boolean:
  362. if(!reg.Indicator)
  363. {
  364. properties.Add(new FPGAArrayWriteProperty<bool>(session, reg.Offset, reg.Size) { Name = reg.Name });
  365. }
  366. else
  367. {
  368. properties.Add(new FPGAArrayReadProperty<bool>(session, reg.Offset, reg.Size) { Name = reg.Name });
  369. }
  370. break;
  371. case lvbitx.Datatype.Int8:
  372. if (!reg.Indicator)
  373. {
  374. properties.Add(new FPGAArrayWriteProperty<sbyte>(session, reg.Offset, reg.Size) { Name = reg.Name });
  375. }
  376. else
  377. {
  378. properties.Add(new FPGAArrayReadProperty<sbyte>(session, reg.Offset, reg.Size) { Name = reg.Name });
  379. }
  380. break;
  381. case lvbitx.Datatype.Uint8:
  382. if (!reg.Indicator)
  383. {
  384. properties.Add(new FPGAArrayWriteProperty<byte>(session, reg.Offset, reg.Size) { Name = reg.Name });
  385. }
  386. else
  387. {
  388. properties.Add(new FPGAArrayReadProperty<byte>(session, reg.Offset, reg.Size) { Name = reg.Name });
  389. }
  390. break;
  391. case lvbitx.Datatype.Int16:
  392. if (!reg.Indicator)
  393. {
  394. properties.Add(new FPGAArrayWriteProperty<short>(session, reg.Offset, reg.Size) { Name = reg.Name });
  395. }
  396. else
  397. {
  398. properties.Add(new FPGAArrayReadProperty<short>(session, reg.Offset, reg.Size) { Name = reg.Name });
  399. }
  400. break;
  401. case lvbitx.Datatype.Uint16:
  402. if (!reg.Indicator)
  403. {
  404. properties.Add(new FPGAArrayWriteProperty<ushort>(session, reg.Offset, reg.Size) { Name = reg.Name });
  405. }
  406. else
  407. {
  408. properties.Add(new FPGAArrayReadProperty<ushort>(session, reg.Offset, reg.Size) { Name = reg.Name });
  409. }
  410. break;
  411. case lvbitx.Datatype.Int32:
  412. if (!reg.Indicator)
  413. {
  414. properties.Add(new FPGAArrayWriteProperty<int>(session, reg.Offset, reg.Size) { Name = reg.Name });
  415. }
  416. else
  417. {
  418. properties.Add(new FPGAArrayReadProperty<int>(session, reg.Offset, reg.Size) { Name = reg.Name });
  419. }
  420. break;
  421. case lvbitx.Datatype.Uint32:
  422. if (!reg.Indicator)
  423. {
  424. properties.Add(new FPGAArrayWriteProperty<uint>(session, reg.Offset, reg.Size) { Name = reg.Name });
  425. }
  426. else
  427. {
  428. properties.Add(new FPGAArrayReadProperty<uint>(session, reg.Offset, reg.Size) { Name = reg.Name });
  429. }
  430. break;
  431. case lvbitx.Datatype.Int64:
  432. if (!reg.Indicator)
  433. {
  434. properties.Add(new FPGAArrayWriteProperty<long>(session, reg.Offset, reg.Size) { Name = reg.Name });
  435. }
  436. else
  437. {
  438. properties.Add(new FPGAArrayReadProperty<long>(session, reg.Offset, reg.Size) { Name = reg.Name });
  439. }
  440. break;
  441. case lvbitx.Datatype.Uint64:
  442. if (!reg.Indicator)
  443. {
  444. properties.Add(new FPGAArrayWriteProperty<ulong>(session, reg.Offset, reg.Size) { Name = reg.Name });
  445. }
  446. else
  447. {
  448. properties.Add(new FPGAArrayReadProperty<ulong>(session, reg.Offset, reg.Size) { Name = reg.Name });
  449. }
  450. break;
  451. case lvbitx.Datatype.Float:
  452. if (!reg.Indicator)
  453. {
  454. properties.Add(new FPGAArrayWriteProperty<float>(session, reg.Offset, reg.Size) { Name = reg.Name });
  455. }
  456. else
  457. {
  458. properties.Add(new FPGAArrayReadProperty<float>(session, reg.Offset, reg.Size) { Name = reg.Name });
  459. }
  460. break;
  461. case lvbitx.Datatype.Double:
  462. if (!reg.Indicator)
  463. {
  464. properties.Add(new FPGAArrayWriteProperty<double>(session, reg.Offset, reg.Size) { Name = reg.Name });
  465. }
  466. else
  467. {
  468. properties.Add(new FPGAArrayReadProperty<double>(session, reg.Offset, reg.Size) { Name = reg.Name });
  469. }
  470. break;
  471. case lvbitx.Datatype.FXP:
  472. if (!reg.Indicator)
  473. {
  474. properties.Add(new FPGAArrayFXPWriteProperty(session, reg.Offset, reg.Size, reg.FxpTypeInfo, _FXPConvert) { Name = reg.Name });
  475. }
  476. else
  477. {
  478. properties.Add(new FPGAArrayFXPReadProperty(session, reg.Offset, reg.Size, reg.FxpTypeInfo, _FXPConvert) { Name = reg.Name });
  479. }
  480. break;
  481. case lvbitx.Datatype.Array:
  482. break;
  483. }
  484. break;
  485. }
  486. }
  487. }
  488. public void Close()=>session.Close();
  489. public void Run()
  490. {
  491. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Run>()(session.Session, Interop.NiFpga_RunAttribute.NiFpga_RunAttribute_None));
  492. }
  493. public void Abort()
  494. {
  495. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Abort>()(session.Session));
  496. }
  497. public void Reset()
  498. {
  499. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Reset>()(session.Session));
  500. }
  501. public void Download()
  502. {
  503. session.CheckResult(session.GetDelegate<Interop.NiFpgaDll_Download>()(session.Session));
  504. }
  505. }
  506. }