lmk04821.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. #include "lmk04821.h"
  2. #include "pci.h"
  3. const uint32_t lmk04821regs_b[LMK_COUNT] = {
  4. 0x000090,
  5. 0x000010,
  6. 0x000200,
  7. 0x000306,
  8. 0x0004D0,
  9. 0x00055B,
  10. 0x000600,
  11. 0x000C51,
  12. 0x000D04,
  13. 0x010001,
  14. 0x010197,
  15. 0x010255,
  16. 0x010302,
  17. 0x010402,
  18. 0x010500,
  19. 0x0106F1,
  20. 0x010790,
  21. 0x010801,
  22. 0x010955,
  23. 0x010A55,
  24. 0x010B02,
  25. 0x010C02,
  26. 0x010D00,
  27. 0x010EB1,
  28. 0x010F15,
  29. 0x011001,
  30. 0x011155,
  31. 0x011255,
  32. 0x011302,
  33. 0x011402,
  34. 0x011500,
  35. 0x0116F1,
  36. 0x011705,
  37. 0x011801,
  38. 0x011955,
  39. 0x011A55,
  40. 0x011B02,
  41. 0x011C02,
  42. 0x011D00,
  43. 0x011EF1,
  44. 0x011F05,
  45. 0x012001,
  46. 0x012155,
  47. 0x012255,
  48. 0x012302,
  49. 0x012402,
  50. 0x012500,
  51. 0x0126F1,
  52. 0x012715,
  53. 0x012801,
  54. 0x012955,
  55. 0x012A55,
  56. 0x012B02,
  57. 0x012C02,
  58. 0x012D00,
  59. 0x012EF1,
  60. 0x012F95,
  61. 0x013001,
  62. 0x013155,
  63. 0x013255,
  64. 0x013302,
  65. 0x013402,
  66. 0x013500,
  67. 0x013671,
  68. 0x013710,
  69. 0x013840,
  70. 0x013900,
  71. 0x013A00,
  72. 0x013B01,
  73. 0x013C00,
  74. 0x013D01,
  75. 0x013E00,
  76. 0x013F06,
  77. 0x0140E3,
  78. 0x014100,
  79. 0x014200,
  80. 0x014310,
  81. 0x0144FF,
  82. 0x01457F,
  83. 0x014611,
  84. 0x014713,
  85. 0x014802,
  86. 0x014942,
  87. 0x014A02,
  88. 0x014B16,
  89. 0x014C00,
  90. 0x014D00,
  91. 0x014EC0,
  92. 0x014F7F,
  93. 0x015003,
  94. 0x015102,
  95. 0x015200,
  96. 0x015300,
  97. 0x015464,
  98. 0x015500,
  99. 0x015678,
  100. 0x015700,
  101. 0x01580A,
  102. 0x015900,
  103. 0x015A78,
  104. 0x015BD4,
  105. 0x015C20,
  106. 0x015D00,
  107. 0x015E00,
  108. 0x015F0B,
  109. 0x016000,
  110. 0x016101,
  111. 0x016224,
  112. 0x016300,
  113. 0x016400,
  114. 0x016501,
  115. 0x0171AA,
  116. 0x017202,
  117. 0x017300,
  118. 0x017400,
  119. 0x017C15,
  120. 0x017D33,
  121. 0x016600,
  122. 0x016700,
  123. 0x01680A,
  124. 0x016959,
  125. 0x016A20,
  126. 0x016B00,
  127. 0x016C00,
  128. 0x016D20,
  129. 0x016E13,
  130. 0x1FFD00,
  131. 0x1FFE00,
  132. 0x1FFF53
  133. };
  134. const uint32_t lmk04821regs_a[LMK_COUNT] = {
  135. 0x000090,
  136. 0x000010,
  137. 0x000200,
  138. 0x000306,
  139. 0x0004D0,
  140. 0x00055B,
  141. 0x000600,
  142. 0x000C51,
  143. 0x000D04,
  144. 0x010001,
  145. 0x010197,
  146. 0x010255,
  147. 0x010302,
  148. 0x010402,
  149. 0x010500,
  150. 0x0106F1,
  151. 0x010707,
  152. 0x010801,
  153. 0x010955,
  154. 0x010A55,
  155. 0x010B02,
  156. 0x010C02,
  157. 0x010D00,
  158. 0x010EB1,
  159. 0x010F07,
  160. 0x011001,
  161. 0x011155,
  162. 0x011255,
  163. 0x011302,
  164. 0x011402,
  165. 0x011500,
  166. 0x0116F1,
  167. 0x011707,
  168. 0x011801,
  169. 0x011955,
  170. 0x011A55,
  171. 0x011B02,
  172. 0x011C02,
  173. 0x011D00,
  174. 0x011EF1,
  175. 0x011F07,
  176. 0x012001,
  177. 0x012155,
  178. 0x012255,
  179. 0x012302,
  180. 0x012402,
  181. 0x012500,
  182. 0x0126F1,
  183. 0x012707,
  184. 0x012801,
  185. 0x012955,
  186. 0x012A55,
  187. 0x012B02,
  188. 0x012C02,
  189. 0x012D00,
  190. 0x012EF1,
  191. 0x012F0F,
  192. 0x013001,
  193. 0x013155,
  194. 0x013255,
  195. 0x013302,
  196. 0x013402,
  197. 0x013500,
  198. 0x013679,
  199. 0x013783,
  200. 0x013840,
  201. 0x013901,
  202. 0x013A00,
  203. 0x013B01,
  204. 0x013C00,
  205. 0x013D01,
  206. 0x013E00,
  207. 0x013F06,
  208. 0x0140F2,
  209. 0x014100,
  210. 0x014200,
  211. 0x014311,
  212. 0x0144FF,
  213. 0x01457F,
  214. 0x014611,
  215. 0x014713,
  216. 0x014802,
  217. 0x014942,
  218. 0x014A02,
  219. 0x014B16,
  220. 0x014C00,
  221. 0x014D00,
  222. 0x014EC0,
  223. 0x014F7F,
  224. 0x015003,
  225. 0x015102,
  226. 0x015200,
  227. 0x015300,
  228. 0x015464,
  229. 0x015500,
  230. 0x015678,
  231. 0x015700,
  232. 0x01580A,
  233. 0x015900,
  234. 0x015A78,
  235. 0x015BD4,
  236. 0x015C20,
  237. 0x015D00,
  238. 0x015E00,
  239. 0x015F0B,
  240. 0x016000,
  241. 0x016101,
  242. 0x016224,
  243. 0x016300,
  244. 0x016400,
  245. 0x016501,
  246. 0x0171AA,
  247. 0x017202,
  248. 0x017360,
  249. 0x017400,
  250. 0x017C15,
  251. 0x017D33,
  252. 0x016600,
  253. 0x016700,
  254. 0x016801,
  255. 0x016959,
  256. 0x016A20,
  257. 0x016B00,
  258. 0x016C00,
  259. 0x016D20,
  260. 0x016E13,
  261. 0x1FFD00,
  262. 0x1FFE00,
  263. 0x1FFF53
  264. };
  265. const uint32_t lmk04821_rst_a[] = {
  266. 0x000090,
  267. 0x000010
  268. };
  269. const uint32_t lmk04821_rst_b[] = {
  270. 0x000090,
  271. 0x000010
  272. };
  273. void lmk04821_a_init(reg_addr_pci* pce_bar_1) {
  274. //Rst for Lmk_a
  275. for (int i = 0; i < 2; i++) {
  276. pce_bar_1->lmk_a_addr = lmk04821_rst_a[i];
  277. }
  278. //Init for Lmk_a
  279. for (int j = 0; j < LMK_COUNT; j++) {
  280. pce_bar_1->lmk_a_addr = lmk04821regs_a[j];
  281. }
  282. }
  283. void lmk04821_b_init(void *bar1) {
  284. //Rst for Lmk_a
  285. for (int i = 0; i < 2; i++) {
  286. uint32_t *ptr = bar1 + LMK_B_BASE_ADDR;
  287. *ptr = lmk04821_rst_b[i];
  288. }
  289. //Init for Lmk_a
  290. for (int j = 0; j < LMK_COUNT; j++) {
  291. uint32_t *ptr = bar1 + LMK_B_BASE_ADDR;
  292. *ptr = lmk04821regs_b[j];
  293. }
  294. }