You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457
  1. /*
  2. This software is available to you under a choice of one of two
  3. licenses. You may choose to be licensed under the terms of the GNU
  4. General Public License (GPL) Version 2, available at
  5. <http://www.fsf.org/copyleft/gpl.html>, or the OpenIB.org BSD
  6. license, available in the LICENSE.TXT file accompanying this
  7. software. These details are also available at
  8. <http://openib.org/license.html>.
  9. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  10. EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  11. MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  12. NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  13. BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  14. ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  15. CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  16. SOFTWARE.
  17. Copyright (c) 2004 Mellanox Technologies Ltd. All rights reserved.
  18. */
  19. #include "cmdif.h"
  20. #include "cmdif_priv.h"
  21. #include "mt25218.h"
  22. /*
  23. * cmd_sys_dis
  24. */
  25. static int cmd_sys_dis(void)
  26. {
  27. return 0;
  28. }
  29. /*
  30. * cmd_write_mgm
  31. */
  32. static int cmd_write_mgm(void *mg, __u16 index)
  33. {
  34. int rc;
  35. command_fields_t cmd_desc;
  36. memset(&cmd_desc, 0, sizeof cmd_desc);
  37. cmd_desc.opcode = MEMFREE_CMD_WRITE_MGM;
  38. cmd_desc.in_trans = TRANS_MAILBOX;
  39. cmd_desc.in_param_size = MT_STRUCT_SIZE(arbelprm_mgm_entry_st);
  40. cmd_desc.in_param = (__u32 *) mg;
  41. cmd_desc.input_modifier = index;
  42. rc = cmd_invoke(&cmd_desc);
  43. return rc;
  44. }
  45. /*
  46. * cmd_mod_stat_cfg
  47. */
  48. static int cmd_mod_stat_cfg(void)
  49. {
  50. int rc;
  51. command_fields_t cmd_desc;
  52. memset(&cmd_desc, 0, sizeof cmd_desc);
  53. cmd_desc.opcode = MEMFREE_CMD_MOD_STAT_CFG;
  54. cmd_desc.in_trans = TRANS_MAILBOX;
  55. cmd_desc.in_param_size = MT_STRUCT_SIZE(arbelprm_mod_stat_cfg_st);
  56. cmd_desc.in_param = get_inprm_buf();
  57. memset(cmd_desc.in_param, 0, cmd_desc.in_param_size);
  58. rc = cmd_invoke(&cmd_desc);
  59. return rc;
  60. }
  61. /*
  62. * cmd_query_fw
  63. */
  64. static int cmd_query_fw(struct query_fw_st *qfw)
  65. {
  66. int rc;
  67. command_fields_t cmd_desc;
  68. memset(&cmd_desc, 0, sizeof cmd_desc);
  69. cmd_desc.opcode = MEMFREE_CMD_QUERY_FW;
  70. cmd_desc.out_trans = TRANS_MAILBOX;
  71. cmd_desc.out_param = get_outprm_buf();
  72. cmd_desc.out_param_size = MT_STRUCT_SIZE(arbelprm_query_fw_st);
  73. rc = cmd_invoke(&cmd_desc);
  74. if (!rc) {
  75. qfw->fw_rev_major =
  76. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, fw_rev_major);
  77. qfw->fw_rev_minor =
  78. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, fw_rev_minor);
  79. qfw->fw_rev_subminor =
  80. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, fw_rev_subminor);
  81. qfw->error_buf_start_h =
  82. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, error_buf_start_h);
  83. qfw->error_buf_start_l =
  84. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, error_buf_start_l);
  85. qfw->error_buf_size =
  86. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, error_buf_size);
  87. qfw->fw_pages =
  88. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st, fw_pages);
  89. qfw->eq_ci_table.addr_h =
  90. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st,
  91. eq_set_ci_base_addr_h);
  92. qfw->eq_ci_table.addr_l =
  93. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st,
  94. eq_set_ci_base_addr_l);
  95. qfw->clear_int_addr.addr_h =
  96. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st,
  97. clr_int_base_addr_h);
  98. qfw->clear_int_addr.addr_l =
  99. EX_FLD(cmd_desc.out_param, arbelprm_query_fw_st,
  100. clr_int_base_addr_l);
  101. }
  102. return rc;
  103. }
  104. /*
  105. * cmd_query_adapter
  106. */
  107. static int cmd_query_adapter(struct query_adapter_st *qa)
  108. {
  109. int rc;
  110. command_fields_t cmd_desc;
  111. memset(&cmd_desc, 0, sizeof cmd_desc);
  112. cmd_desc.opcode = MEMFREE_CMD_QUERY_ADAPTER;
  113. cmd_desc.out_trans = TRANS_MAILBOX;
  114. cmd_desc.out_param = get_outprm_buf();
  115. cmd_desc.out_param_size = MT_STRUCT_SIZE(arbelprm_query_adapter_st);
  116. rc = cmd_invoke(&cmd_desc);
  117. if (!rc) {
  118. qa->intapin =
  119. EX_FLD(cmd_desc.out_param, arbelprm_query_adapter_st,
  120. intapin);
  121. }
  122. return rc;
  123. }
  124. /*
  125. * cmd_enable_lam
  126. */
  127. static int cmd_enable_lam(void)
  128. {
  129. int rc;
  130. command_fields_t cmd_desc;
  131. memset(&cmd_desc, 0, sizeof cmd_desc);
  132. cmd_desc.opcode = MEMFREE_CMD_ENABLE_LAM;
  133. cmd_desc.opcode_modifier = 1; /* zero locally attached memory */
  134. cmd_desc.input_modifier = 0; /* disable fast refresh */
  135. cmd_desc.out_trans = TRANS_MAILBOX;
  136. cmd_desc.out_param = get_outprm_buf();
  137. cmd_desc.out_param_size = MT_STRUCT_SIZE(arbelprm_enable_lam_st);
  138. rc = cmd_invoke(&cmd_desc);
  139. if (rc) {
  140. }
  141. return rc;
  142. }
  143. /*
  144. * cmd_map_fa
  145. */
  146. static int cmd_map_fa(struct map_icm_st *map_fa_p)
  147. {
  148. int rc;
  149. command_fields_t cmd_desc;
  150. unsigned int in_param_size, i;
  151. unsigned long off;
  152. if (map_fa_p->num_vpm > MAX_VPM_PER_CALL) {
  153. return -1;
  154. }
  155. memset(&cmd_desc, 0, sizeof cmd_desc);
  156. cmd_desc.opcode = MEMFREE_CMD_MAP_FA;
  157. cmd_desc.input_modifier = map_fa_p->num_vpm;
  158. cmd_desc.in_trans = TRANS_MAILBOX;
  159. cmd_desc.in_param = get_inprm_buf();
  160. in_param_size =
  161. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) *
  162. map_fa_p->num_vpm;
  163. cmd_desc.in_param_size = in_param_size;
  164. memset(cmd_desc.in_param, 0, in_param_size);
  165. for (i = 0; i < map_fa_p->num_vpm; ++i) {
  166. off = (unsigned long)(cmd_desc.in_param) +
  167. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) * i;
  168. INS_FLD(map_fa_p->vpm_arr[i].va_h, off,
  169. arbelprm_virtual_physical_mapping_st, va_h);
  170. INS_FLD(map_fa_p->vpm_arr[i].va_l >> 12, off,
  171. arbelprm_virtual_physical_mapping_st, va_l);
  172. INS_FLD(map_fa_p->vpm_arr[i].pa_h, off,
  173. arbelprm_virtual_physical_mapping_st, pa_h);
  174. INS_FLD(map_fa_p->vpm_arr[i].pa_l >> 12, off,
  175. arbelprm_virtual_physical_mapping_st, pa_l);
  176. INS_FLD(map_fa_p->vpm_arr[i].log2_size, off,
  177. arbelprm_virtual_physical_mapping_st, log2size);
  178. }
  179. rc = cmd_invoke(&cmd_desc);
  180. return rc;
  181. }
  182. /*
  183. * cmd_unmap_fa
  184. */
  185. static int cmd_unmap_fa(void)
  186. {
  187. int rc;
  188. command_fields_t cmd_desc;
  189. memset(&cmd_desc, 0, sizeof cmd_desc);
  190. cmd_desc.opcode = MEMFREE_CMD_UNMAP_FA;
  191. rc = cmd_invoke(&cmd_desc);
  192. return rc;
  193. }
  194. /*
  195. * cmd_run_fw
  196. */
  197. static int cmd_run_fw(void)
  198. {
  199. int rc;
  200. command_fields_t cmd_desc;
  201. memset(&cmd_desc, 0, sizeof cmd_desc);
  202. cmd_desc.opcode = MEMFREE_CMD_RUN_FW;
  203. rc = cmd_invoke(&cmd_desc);
  204. return rc;
  205. }
  206. /*
  207. * cmd_set_icm_size
  208. */
  209. static int cmd_set_icm_size(__u32 icm_size, __u32 * aux_pages_p)
  210. {
  211. int rc;
  212. command_fields_t cmd_desc;
  213. __u32 iprm[2], oprm[2];
  214. memset(&cmd_desc, 0, sizeof cmd_desc);
  215. cmd_desc.opcode = MEMFREE_CMD_SET_ICM_SIZE;
  216. iprm[1] = icm_size;
  217. iprm[0] = 0;
  218. cmd_desc.in_trans = TRANS_IMMEDIATE;
  219. cmd_desc.in_param = iprm;
  220. cmd_desc.out_trans = TRANS_IMMEDIATE;
  221. cmd_desc.out_param = oprm;
  222. rc = cmd_invoke(&cmd_desc);
  223. if (!rc) {
  224. if (oprm[0]) {
  225. /* too many pages required */
  226. return -1;
  227. }
  228. *aux_pages_p = oprm[1];
  229. }
  230. return rc;
  231. }
  232. /*
  233. * cmd_map_icm_aux
  234. */
  235. static int cmd_map_icm_aux(struct map_icm_st *map_icm_aux_p)
  236. {
  237. int rc;
  238. command_fields_t cmd_desc;
  239. unsigned int in_param_size, i;
  240. unsigned long off;
  241. if (map_icm_aux_p->num_vpm > MAX_VPM_PER_CALL) {
  242. return -1;
  243. }
  244. memset(&cmd_desc, 0, sizeof cmd_desc);
  245. cmd_desc.opcode = MEMFREE_CMD_MAP_ICM_AUX;
  246. cmd_desc.input_modifier = map_icm_aux_p->num_vpm;
  247. cmd_desc.in_trans = TRANS_MAILBOX;
  248. cmd_desc.in_param = get_inprm_buf();
  249. in_param_size =
  250. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) *
  251. map_icm_aux_p->num_vpm;
  252. cmd_desc.in_param_size = in_param_size;
  253. memset(cmd_desc.in_param, 0, in_param_size);
  254. for (i = 0; i < map_icm_aux_p->num_vpm; ++i) {
  255. off = (unsigned long)(cmd_desc.in_param) +
  256. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) * i;
  257. INS_FLD(map_icm_aux_p->vpm_arr[i].va_h, off,
  258. arbelprm_virtual_physical_mapping_st, va_h);
  259. INS_FLD(map_icm_aux_p->vpm_arr[i].va_l >> 12, off,
  260. arbelprm_virtual_physical_mapping_st, va_l);
  261. INS_FLD(map_icm_aux_p->vpm_arr[i].pa_h, off,
  262. arbelprm_virtual_physical_mapping_st, pa_h);
  263. INS_FLD(map_icm_aux_p->vpm_arr[i].pa_l >> 12, off,
  264. arbelprm_virtual_physical_mapping_st, pa_l);
  265. INS_FLD(map_icm_aux_p->vpm_arr[i].log2_size, off,
  266. arbelprm_virtual_physical_mapping_st, log2size);
  267. }
  268. rc = cmd_invoke(&cmd_desc);
  269. return rc;
  270. }
  271. /*
  272. * cmd_map_icm
  273. */
  274. static int cmd_map_icm(struct map_icm_st *map_icm_p)
  275. {
  276. int rc;
  277. command_fields_t cmd_desc;
  278. unsigned int in_param_size, i;
  279. unsigned long off;
  280. if (map_icm_p->num_vpm > MAX_VPM_PER_CALL) {
  281. return -1;
  282. }
  283. memset(&cmd_desc, 0, sizeof cmd_desc);
  284. cmd_desc.opcode = MEMFREE_CMD_MAP_ICM;
  285. cmd_desc.input_modifier = map_icm_p->num_vpm;
  286. cmd_desc.in_trans = TRANS_MAILBOX;
  287. cmd_desc.in_param = get_inprm_buf();
  288. in_param_size =
  289. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) *
  290. map_icm_p->num_vpm;
  291. cmd_desc.in_param_size = in_param_size;
  292. memset(cmd_desc.in_param, 0, in_param_size);
  293. for (i = 0; i < map_icm_p->num_vpm; ++i) {
  294. off = (unsigned long)(cmd_desc.in_param) +
  295. MT_STRUCT_SIZE(arbelprm_virtual_physical_mapping_st) * i;
  296. INS_FLD(map_icm_p->vpm_arr[i].va_h, off,
  297. arbelprm_virtual_physical_mapping_st, va_h);
  298. INS_FLD(map_icm_p->vpm_arr[i].va_l >> 12, off,
  299. arbelprm_virtual_physical_mapping_st, va_l);
  300. INS_FLD(map_icm_p->vpm_arr[i].pa_h, off,
  301. arbelprm_virtual_physical_mapping_st, pa_h);
  302. INS_FLD(map_icm_p->vpm_arr[i].pa_l >> 12, off,
  303. arbelprm_virtual_physical_mapping_st, pa_l);
  304. INS_FLD(map_icm_p->vpm_arr[i].log2_size, off,
  305. arbelprm_virtual_physical_mapping_st, log2size);
  306. }
  307. rc = cmd_invoke(&cmd_desc);
  308. return rc;
  309. }
  310. /*
  311. * cmd_query_dev_lim
  312. */
  313. static int cmd_query_dev_lim(struct dev_lim_st *dev_lim_p)
  314. {
  315. int rc;
  316. command_fields_t cmd_desc;
  317. memset(&cmd_desc, 0, sizeof cmd_desc);
  318. cmd_desc.opcode = MEMFREE_CMD_QUERY_DEV_LIM;
  319. cmd_desc.out_trans = TRANS_MAILBOX;
  320. cmd_desc.out_param = get_outprm_buf();
  321. cmd_desc.out_param_size = MT_STRUCT_SIZE(arbelprm_query_dev_lim_st);
  322. rc = cmd_invoke(&cmd_desc);
  323. if (!rc) {
  324. dev_lim_p->log2_rsvd_qps =
  325. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  326. log2_rsvd_qps);
  327. dev_lim_p->qpc_entry_sz =
  328. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  329. qpc_entry_sz);
  330. dev_lim_p->log2_rsvd_srqs =
  331. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  332. log2_rsvd_srqs);
  333. dev_lim_p->srq_entry_sz =
  334. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  335. srq_entry_sz);
  336. dev_lim_p->log2_rsvd_ees =
  337. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  338. log2_rsvd_ees);
  339. dev_lim_p->eec_entry_sz =
  340. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  341. eec_entry_sz);
  342. dev_lim_p->log2_rsvd_cqs =
  343. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  344. log2_rsvd_cqs);
  345. dev_lim_p->cqc_entry_sz =
  346. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  347. cqc_entry_sz);
  348. dev_lim_p->log2_rsvd_mtts =
  349. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  350. log2_rsvd_mtts);
  351. dev_lim_p->mtt_entry_sz =
  352. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  353. mtt_entry_sz);
  354. dev_lim_p->log2_rsvd_mrws =
  355. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  356. log2_rsvd_mrws);
  357. dev_lim_p->mpt_entry_sz =
  358. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  359. mpt_entry_sz);
  360. dev_lim_p->log2_rsvd_rdbs =
  361. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  362. log2_rsvd_rdbs);
  363. dev_lim_p->eqc_entry_sz =
  364. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  365. eqc_entry_sz);
  366. dev_lim_p->max_icm_size_l =
  367. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  368. max_icm_size_l);
  369. dev_lim_p->max_icm_size_h =
  370. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  371. max_icm_size_h);
  372. dev_lim_p->num_rsvd_uars =
  373. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  374. num_rsvd_uars);
  375. dev_lim_p->uar_sz =
  376. EX_FLD(cmd_desc.out_param, arbelprm_query_dev_lim_st,
  377. uar_sz);
  378. }
  379. return rc;
  380. }