efa_main.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706
  1. // SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause
  2. /*
  3. * Copyright 2018-2025 Amazon.com, Inc. or its affiliates. All rights reserved.
  4. */
  5. #include <linux/module.h>
  6. #include <linux/pci.h>
  7. #include <linux/utsname.h>
  8. #include <linux/version.h>
  9. #include <rdma/ib_user_verbs.h>
  10. #include <rdma/uverbs_ioctl.h>
  11. #include "efa.h"
  12. #define PCI_DEV_ID_EFA0_VF 0xefa0
  13. #define PCI_DEV_ID_EFA1_VF 0xefa1
  14. #define PCI_DEV_ID_EFA2_VF 0xefa2
  15. #define PCI_DEV_ID_EFA3_VF 0xefa3
  16. static const struct pci_device_id efa_pci_tbl[] = {
  17. { PCI_VDEVICE(AMAZON, PCI_DEV_ID_EFA0_VF) },
  18. { PCI_VDEVICE(AMAZON, PCI_DEV_ID_EFA1_VF) },
  19. { PCI_VDEVICE(AMAZON, PCI_DEV_ID_EFA2_VF) },
  20. { PCI_VDEVICE(AMAZON, PCI_DEV_ID_EFA3_VF) },
  21. { }
  22. };
  23. MODULE_AUTHOR("Amazon.com, Inc. or its affiliates");
  24. MODULE_LICENSE("Dual BSD/GPL");
  25. MODULE_DESCRIPTION(DEVICE_NAME);
  26. MODULE_DEVICE_TABLE(pci, efa_pci_tbl);
  27. #define EFA_REG_BAR 0
  28. #define EFA_MEM_BAR 2
  29. #define EFA_BASE_BAR_MASK (BIT(EFA_REG_BAR) | BIT(EFA_MEM_BAR))
  30. #define EFA_AENQ_ENABLED_GROUPS \
  31. (BIT(EFA_ADMIN_FATAL_ERROR) | BIT(EFA_ADMIN_WARNING) | \
  32. BIT(EFA_ADMIN_NOTIFICATION) | BIT(EFA_ADMIN_KEEP_ALIVE))
  33. extern const struct uapi_definition efa_uapi_defs[];
  34. /* This handler will called for unknown event group or unimplemented handlers */
  35. static void unimplemented_aenq_handler(void *data,
  36. struct efa_admin_aenq_entry *aenq_e)
  37. {
  38. struct efa_dev *dev = (struct efa_dev *)data;
  39. ibdev_err(&dev->ibdev,
  40. "Unknown event was received or event with unimplemented handler\n");
  41. }
  42. static void efa_keep_alive(void *data, struct efa_admin_aenq_entry *aenq_e)
  43. {
  44. struct efa_dev *dev = (struct efa_dev *)data;
  45. atomic64_inc(&dev->stats.keep_alive_rcvd);
  46. }
  47. static struct efa_aenq_handlers aenq_handlers = {
  48. .handlers = {
  49. [EFA_ADMIN_KEEP_ALIVE] = efa_keep_alive,
  50. },
  51. .unimplemented_handler = unimplemented_aenq_handler
  52. };
  53. static void efa_release_bars(struct efa_dev *dev, int bars_mask)
  54. {
  55. struct pci_dev *pdev = dev->pdev;
  56. int release_bars;
  57. release_bars = pci_select_bars(pdev, IORESOURCE_MEM) & bars_mask;
  58. pci_release_selected_regions(pdev, release_bars);
  59. }
  60. static void efa_process_comp_eqe(struct efa_dev *dev, struct efa_admin_eqe *eqe)
  61. {
  62. u16 cqn = eqe->u.comp_event.cqn;
  63. struct efa_cq *cq;
  64. /* Safe to load as we're in irq and removal calls synchronize_irq() */
  65. cq = xa_load(&dev->cqs_xa, cqn);
  66. if (unlikely(!cq)) {
  67. ibdev_err_ratelimited(&dev->ibdev,
  68. "Completion event on non-existent CQ[%u]",
  69. cqn);
  70. return;
  71. }
  72. cq->ibcq.comp_handler(&cq->ibcq, cq->ibcq.cq_context);
  73. }
  74. static void efa_process_eqe(struct efa_com_eq *eeq, struct efa_admin_eqe *eqe)
  75. {
  76. struct efa_dev *dev = container_of(eeq->edev, struct efa_dev, edev);
  77. if (likely(EFA_GET(&eqe->common, EFA_ADMIN_EQE_EVENT_TYPE) ==
  78. EFA_ADMIN_EQE_EVENT_TYPE_COMPLETION))
  79. efa_process_comp_eqe(dev, eqe);
  80. else
  81. ibdev_err_ratelimited(&dev->ibdev,
  82. "Unknown event type received %lu",
  83. EFA_GET(&eqe->common,
  84. EFA_ADMIN_EQE_EVENT_TYPE));
  85. }
  86. static irqreturn_t efa_intr_msix_comp(int irq, void *data)
  87. {
  88. struct efa_eq *eq = data;
  89. struct efa_com_dev *edev = eq->eeq.edev;
  90. efa_com_eq_comp_intr_handler(edev, &eq->eeq);
  91. return IRQ_HANDLED;
  92. }
  93. static irqreturn_t efa_intr_msix_mgmnt(int irq, void *data)
  94. {
  95. struct efa_dev *dev = data;
  96. efa_com_admin_q_comp_intr_handler(&dev->edev);
  97. efa_com_aenq_intr_handler(&dev->edev, data);
  98. return IRQ_HANDLED;
  99. }
  100. static int efa_request_irq(struct efa_dev *dev, struct efa_irq *irq)
  101. {
  102. int err;
  103. err = request_irq(irq->irqn, irq->handler, 0, irq->name, irq->data);
  104. if (err) {
  105. dev_err(&dev->pdev->dev, "Failed to request irq %s (%d)\n",
  106. irq->name, err);
  107. return err;
  108. }
  109. irq_set_affinity_hint(irq->irqn, &irq->affinity_hint_mask);
  110. return 0;
  111. }
  112. static void efa_setup_comp_irq(struct efa_dev *dev, struct efa_eq *eq, u32 vector)
  113. {
  114. u32 cpu;
  115. cpu = vector - EFA_COMP_EQS_VEC_BASE;
  116. snprintf(eq->irq.name, EFA_IRQNAME_SIZE, "efa-comp%d@pci:%s", cpu,
  117. pci_name(dev->pdev));
  118. eq->irq.handler = efa_intr_msix_comp;
  119. eq->irq.data = eq;
  120. eq->irq.vector = vector;
  121. eq->irq.irqn = pci_irq_vector(dev->pdev, vector);
  122. cpumask_set_cpu(cpu, &eq->irq.affinity_hint_mask);
  123. }
  124. static void efa_free_irq(struct efa_dev *dev, struct efa_irq *irq)
  125. {
  126. irq_set_affinity_hint(irq->irqn, NULL);
  127. free_irq(irq->irqn, irq->data);
  128. }
  129. static void efa_setup_mgmnt_irq(struct efa_dev *dev)
  130. {
  131. u32 cpu;
  132. snprintf(dev->admin_irq.name, EFA_IRQNAME_SIZE,
  133. "efa-mgmnt@pci:%s", pci_name(dev->pdev));
  134. dev->admin_irq.handler = efa_intr_msix_mgmnt;
  135. dev->admin_irq.data = dev;
  136. dev->admin_irq.vector = dev->admin_msix_vector_idx;
  137. dev->admin_irq.irqn = pci_irq_vector(dev->pdev,
  138. dev->admin_msix_vector_idx);
  139. cpu = cpumask_first(cpu_online_mask);
  140. cpumask_set_cpu(cpu,
  141. &dev->admin_irq.affinity_hint_mask);
  142. dev_info(&dev->pdev->dev, "Setup irq:%d name:%s\n",
  143. dev->admin_irq.irqn,
  144. dev->admin_irq.name);
  145. }
  146. static int efa_set_mgmnt_irq(struct efa_dev *dev)
  147. {
  148. efa_setup_mgmnt_irq(dev);
  149. return efa_request_irq(dev, &dev->admin_irq);
  150. }
  151. static int efa_request_doorbell_bar(struct efa_dev *dev)
  152. {
  153. u8 db_bar_idx = dev->dev_attr.db_bar;
  154. struct pci_dev *pdev = dev->pdev;
  155. int pci_mem_bars;
  156. int db_bar;
  157. int err;
  158. db_bar = BIT(db_bar_idx);
  159. if (!(db_bar & EFA_BASE_BAR_MASK)) {
  160. pci_mem_bars = pci_select_bars(pdev, IORESOURCE_MEM);
  161. if (db_bar & ~pci_mem_bars) {
  162. dev_err(&pdev->dev,
  163. "Doorbells BAR unavailable. Requested %#x, available %#x\n",
  164. db_bar, pci_mem_bars);
  165. return -ENODEV;
  166. }
  167. err = pci_request_selected_regions(pdev, db_bar, DRV_MODULE_NAME);
  168. if (err) {
  169. dev_err(&pdev->dev,
  170. "pci_request_selected_regions for bar %d failed %d\n",
  171. db_bar_idx, err);
  172. return err;
  173. }
  174. }
  175. dev->db_bar_addr = pci_resource_start(dev->pdev, db_bar_idx);
  176. dev->db_bar_len = pci_resource_len(dev->pdev, db_bar_idx);
  177. return 0;
  178. }
  179. static void efa_release_doorbell_bar(struct efa_dev *dev)
  180. {
  181. if (!(BIT(dev->dev_attr.db_bar) & EFA_BASE_BAR_MASK))
  182. efa_release_bars(dev, BIT(dev->dev_attr.db_bar));
  183. }
  184. static void efa_update_hw_hints(struct efa_dev *dev,
  185. struct efa_com_get_hw_hints_result *hw_hints)
  186. {
  187. struct efa_com_dev *edev = &dev->edev;
  188. if (hw_hints->mmio_read_timeout)
  189. edev->mmio_read.mmio_read_timeout =
  190. hw_hints->mmio_read_timeout * 1000;
  191. if (hw_hints->poll_interval)
  192. edev->aq.poll_interval = hw_hints->poll_interval;
  193. if (hw_hints->admin_completion_timeout)
  194. edev->aq.completion_timeout =
  195. hw_hints->admin_completion_timeout;
  196. }
  197. static void efa_stats_init(struct efa_dev *dev)
  198. {
  199. atomic64_t *s = (atomic64_t *)&dev->stats;
  200. int i;
  201. for (i = 0; i < sizeof(dev->stats) / sizeof(*s); i++, s++)
  202. atomic64_set(s, 0);
  203. }
  204. static void efa_set_host_info(struct efa_dev *dev)
  205. {
  206. struct efa_admin_set_feature_resp resp = {};
  207. struct efa_admin_set_feature_cmd cmd = {};
  208. struct efa_admin_host_info *hinf;
  209. u32 bufsz = sizeof(*hinf);
  210. dma_addr_t hinf_dma;
  211. if (!efa_com_check_supported_feature_id(&dev->edev,
  212. EFA_ADMIN_HOST_INFO))
  213. return;
  214. /* Failures in host info set shall not disturb probe */
  215. hinf = dma_alloc_coherent(&dev->pdev->dev, bufsz, &hinf_dma,
  216. GFP_KERNEL);
  217. if (!hinf)
  218. return;
  219. strscpy(hinf->os_dist_str, utsname()->release,
  220. sizeof(hinf->os_dist_str));
  221. hinf->os_type = EFA_ADMIN_OS_LINUX;
  222. strscpy(hinf->kernel_ver_str, utsname()->version,
  223. sizeof(hinf->kernel_ver_str));
  224. hinf->kernel_ver = LINUX_VERSION_CODE;
  225. EFA_SET(&hinf->driver_ver, EFA_ADMIN_HOST_INFO_DRIVER_MAJOR, 0);
  226. EFA_SET(&hinf->driver_ver, EFA_ADMIN_HOST_INFO_DRIVER_MINOR, 0);
  227. EFA_SET(&hinf->driver_ver, EFA_ADMIN_HOST_INFO_DRIVER_SUB_MINOR, 0);
  228. EFA_SET(&hinf->driver_ver, EFA_ADMIN_HOST_INFO_DRIVER_MODULE_TYPE, 0);
  229. EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_BUS, dev->pdev->bus->number);
  230. EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_DEVICE,
  231. PCI_SLOT(dev->pdev->devfn));
  232. EFA_SET(&hinf->bdf, EFA_ADMIN_HOST_INFO_FUNCTION,
  233. PCI_FUNC(dev->pdev->devfn));
  234. EFA_SET(&hinf->spec_ver, EFA_ADMIN_HOST_INFO_SPEC_MAJOR,
  235. EFA_COMMON_SPEC_VERSION_MAJOR);
  236. EFA_SET(&hinf->spec_ver, EFA_ADMIN_HOST_INFO_SPEC_MINOR,
  237. EFA_COMMON_SPEC_VERSION_MINOR);
  238. EFA_SET(&hinf->flags, EFA_ADMIN_HOST_INFO_INTREE, 1);
  239. EFA_SET(&hinf->flags, EFA_ADMIN_HOST_INFO_GDR, 0);
  240. efa_com_set_feature_ex(&dev->edev, &resp, &cmd, EFA_ADMIN_HOST_INFO,
  241. hinf_dma, bufsz);
  242. dma_free_coherent(&dev->pdev->dev, bufsz, hinf, hinf_dma);
  243. }
  244. static void efa_destroy_eq(struct efa_dev *dev, struct efa_eq *eq)
  245. {
  246. efa_com_eq_destroy(&dev->edev, &eq->eeq);
  247. efa_free_irq(dev, &eq->irq);
  248. }
  249. static int efa_create_eq(struct efa_dev *dev, struct efa_eq *eq, u32 msix_vec)
  250. {
  251. int err;
  252. efa_setup_comp_irq(dev, eq, msix_vec);
  253. err = efa_request_irq(dev, &eq->irq);
  254. if (err)
  255. return err;
  256. err = efa_com_eq_init(&dev->edev, &eq->eeq, efa_process_eqe,
  257. dev->dev_attr.max_eq_depth, msix_vec);
  258. if (err)
  259. goto err_free_comp_irq;
  260. return 0;
  261. err_free_comp_irq:
  262. efa_free_irq(dev, &eq->irq);
  263. return err;
  264. }
  265. static int efa_create_eqs(struct efa_dev *dev)
  266. {
  267. u32 neqs = dev->dev_attr.max_eq;
  268. int err, i;
  269. neqs = min_t(u32, neqs, dev->num_irq_vectors - EFA_COMP_EQS_VEC_BASE);
  270. dev->neqs = neqs;
  271. dev->eqs = kzalloc_objs(*dev->eqs, neqs);
  272. if (!dev->eqs)
  273. return -ENOMEM;
  274. for (i = 0; i < neqs; i++) {
  275. err = efa_create_eq(dev, &dev->eqs[i], i + EFA_COMP_EQS_VEC_BASE);
  276. if (err)
  277. goto err_destroy_eqs;
  278. }
  279. return 0;
  280. err_destroy_eqs:
  281. for (i--; i >= 0; i--)
  282. efa_destroy_eq(dev, &dev->eqs[i]);
  283. kfree(dev->eqs);
  284. return err;
  285. }
  286. static void efa_destroy_eqs(struct efa_dev *dev)
  287. {
  288. int i;
  289. for (i = 0; i < dev->neqs; i++)
  290. efa_destroy_eq(dev, &dev->eqs[i]);
  291. kfree(dev->eqs);
  292. }
  293. static const struct ib_device_ops efa_dev_ops = {
  294. .owner = THIS_MODULE,
  295. .driver_id = RDMA_DRIVER_EFA,
  296. .uverbs_abi_ver = EFA_UVERBS_ABI_VERSION,
  297. .alloc_hw_port_stats = efa_alloc_hw_port_stats,
  298. .alloc_hw_device_stats = efa_alloc_hw_device_stats,
  299. .alloc_pd = efa_alloc_pd,
  300. .alloc_ucontext = efa_alloc_ucontext,
  301. .create_cq = efa_create_cq,
  302. .create_cq_umem = efa_create_cq_umem,
  303. .create_qp = efa_create_qp,
  304. .create_user_ah = efa_create_ah,
  305. .dealloc_pd = efa_dealloc_pd,
  306. .dealloc_ucontext = efa_dealloc_ucontext,
  307. .dereg_mr = efa_dereg_mr,
  308. .destroy_ah = efa_destroy_ah,
  309. .destroy_cq = efa_destroy_cq,
  310. .destroy_qp = efa_destroy_qp,
  311. .get_hw_stats = efa_get_hw_stats,
  312. .get_link_layer = efa_port_link_layer,
  313. .get_port_immutable = efa_get_port_immutable,
  314. .mmap = efa_mmap,
  315. .mmap_free = efa_mmap_free,
  316. .modify_qp = efa_modify_qp,
  317. .query_device = efa_query_device,
  318. .query_gid = efa_query_gid,
  319. .query_pkey = efa_query_pkey,
  320. .query_port = efa_query_port,
  321. .query_qp = efa_query_qp,
  322. .reg_user_mr = efa_reg_mr,
  323. .reg_user_mr_dmabuf = efa_reg_user_mr_dmabuf,
  324. INIT_RDMA_OBJ_SIZE(ib_ah, efa_ah, ibah),
  325. INIT_RDMA_OBJ_SIZE(ib_cq, efa_cq, ibcq),
  326. INIT_RDMA_OBJ_SIZE(ib_pd, efa_pd, ibpd),
  327. INIT_RDMA_OBJ_SIZE(ib_qp, efa_qp, ibqp),
  328. INIT_RDMA_OBJ_SIZE(ib_ucontext, efa_ucontext, ibucontext),
  329. };
  330. static int efa_ib_device_add(struct efa_dev *dev)
  331. {
  332. struct efa_com_get_hw_hints_result hw_hints;
  333. struct pci_dev *pdev = dev->pdev;
  334. int err;
  335. efa_stats_init(dev);
  336. err = efa_com_get_device_attr(&dev->edev, &dev->dev_attr);
  337. if (err)
  338. return err;
  339. dev_dbg(&dev->pdev->dev, "Doorbells bar (%d)\n", dev->dev_attr.db_bar);
  340. err = efa_request_doorbell_bar(dev);
  341. if (err)
  342. return err;
  343. err = efa_com_get_hw_hints(&dev->edev, &hw_hints);
  344. if (err)
  345. goto err_release_doorbell_bar;
  346. efa_update_hw_hints(dev, &hw_hints);
  347. /* Try to enable all the available aenq groups */
  348. err = efa_com_set_aenq_config(&dev->edev, EFA_AENQ_ENABLED_GROUPS);
  349. if (err)
  350. goto err_release_doorbell_bar;
  351. err = efa_create_eqs(dev);
  352. if (err)
  353. goto err_release_doorbell_bar;
  354. efa_set_host_info(dev);
  355. dev->ibdev.node_type = RDMA_NODE_UNSPECIFIED;
  356. dev->ibdev.node_guid = dev->dev_attr.guid;
  357. dev->ibdev.phys_port_cnt = 1;
  358. dev->ibdev.num_comp_vectors = dev->neqs ?: 1;
  359. dev->ibdev.dev.parent = &pdev->dev;
  360. ib_set_device_ops(&dev->ibdev, &efa_dev_ops);
  361. dev->ibdev.driver_def = efa_uapi_defs;
  362. err = ib_register_device(&dev->ibdev, "efa_%d", &pdev->dev);
  363. if (err)
  364. goto err_destroy_eqs;
  365. ibdev_info(&dev->ibdev, "IB device registered\n");
  366. return 0;
  367. err_destroy_eqs:
  368. efa_destroy_eqs(dev);
  369. err_release_doorbell_bar:
  370. efa_release_doorbell_bar(dev);
  371. return err;
  372. }
  373. static void efa_ib_device_remove(struct efa_dev *dev)
  374. {
  375. ibdev_info(&dev->ibdev, "Unregister ib device\n");
  376. ib_unregister_device(&dev->ibdev);
  377. efa_destroy_eqs(dev);
  378. efa_release_doorbell_bar(dev);
  379. }
  380. static void efa_disable_msix(struct efa_dev *dev)
  381. {
  382. pci_free_irq_vectors(dev->pdev);
  383. }
  384. static int efa_enable_msix(struct efa_dev *dev)
  385. {
  386. int max_vecs, num_vecs;
  387. /*
  388. * Reserve the max msix vectors we might need, one vector is reserved
  389. * for admin.
  390. */
  391. max_vecs = min_t(int, pci_msix_vec_count(dev->pdev),
  392. num_online_cpus() + 1);
  393. dev_dbg(&dev->pdev->dev, "Trying to enable MSI-X, vectors %d\n",
  394. max_vecs);
  395. dev->admin_msix_vector_idx = EFA_MGMNT_MSIX_VEC_IDX;
  396. num_vecs = pci_alloc_irq_vectors(dev->pdev, 1,
  397. max_vecs, PCI_IRQ_MSIX);
  398. if (num_vecs < 0) {
  399. dev_err(&dev->pdev->dev, "Failed to enable MSI-X. error %d\n",
  400. num_vecs);
  401. return -ENOSPC;
  402. }
  403. dev_dbg(&dev->pdev->dev, "Allocated %d MSI-X vectors\n", num_vecs);
  404. dev->num_irq_vectors = num_vecs;
  405. return 0;
  406. }
  407. static int efa_device_init(struct efa_com_dev *edev, struct pci_dev *pdev)
  408. {
  409. int dma_width;
  410. int err;
  411. err = efa_com_dev_reset(edev, EFA_REGS_RESET_NORMAL);
  412. if (err)
  413. return err;
  414. err = efa_com_validate_version(edev);
  415. if (err)
  416. return err;
  417. dma_width = efa_com_get_dma_width(edev);
  418. if (dma_width < 0) {
  419. err = dma_width;
  420. return err;
  421. }
  422. err = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(dma_width));
  423. if (err) {
  424. dev_err(&pdev->dev, "dma_set_mask_and_coherent failed %d\n", err);
  425. return err;
  426. }
  427. dma_set_max_seg_size(&pdev->dev, UINT_MAX);
  428. return 0;
  429. }
  430. static struct efa_dev *efa_probe_device(struct pci_dev *pdev)
  431. {
  432. struct efa_com_dev *edev;
  433. struct efa_dev *dev;
  434. int pci_mem_bars;
  435. int err;
  436. err = pci_enable_device_mem(pdev);
  437. if (err) {
  438. dev_err(&pdev->dev, "pci_enable_device_mem() failed!\n");
  439. return ERR_PTR(err);
  440. }
  441. pci_set_master(pdev);
  442. dev = ib_alloc_device(efa_dev, ibdev);
  443. if (!dev) {
  444. dev_err(&pdev->dev, "Device alloc failed\n");
  445. err = -ENOMEM;
  446. goto err_disable_device;
  447. }
  448. pci_set_drvdata(pdev, dev);
  449. edev = &dev->edev;
  450. edev->efa_dev = dev;
  451. edev->dmadev = &pdev->dev;
  452. dev->pdev = pdev;
  453. xa_init(&dev->cqs_xa);
  454. pci_mem_bars = pci_select_bars(pdev, IORESOURCE_MEM);
  455. if (EFA_BASE_BAR_MASK & ~pci_mem_bars) {
  456. dev_err(&pdev->dev, "BARs unavailable. Requested %#x, available %#x\n",
  457. (int)EFA_BASE_BAR_MASK, pci_mem_bars);
  458. err = -ENODEV;
  459. goto err_ibdev_destroy;
  460. }
  461. err = pci_request_selected_regions(pdev, EFA_BASE_BAR_MASK, DRV_MODULE_NAME);
  462. if (err) {
  463. dev_err(&pdev->dev, "pci_request_selected_regions failed %d\n",
  464. err);
  465. goto err_ibdev_destroy;
  466. }
  467. dev->reg_bar_addr = pci_resource_start(pdev, EFA_REG_BAR);
  468. dev->reg_bar_len = pci_resource_len(pdev, EFA_REG_BAR);
  469. dev->mem_bar_addr = pci_resource_start(pdev, EFA_MEM_BAR);
  470. dev->mem_bar_len = pci_resource_len(pdev, EFA_MEM_BAR);
  471. edev->reg_bar = devm_ioremap(&pdev->dev,
  472. dev->reg_bar_addr,
  473. dev->reg_bar_len);
  474. if (!edev->reg_bar) {
  475. dev_err(&pdev->dev, "Failed to remap register bar\n");
  476. err = -EFAULT;
  477. goto err_release_bars;
  478. }
  479. err = efa_com_mmio_reg_read_init(edev);
  480. if (err) {
  481. dev_err(&pdev->dev, "Failed to init readless MMIO\n");
  482. goto err_iounmap;
  483. }
  484. err = efa_device_init(edev, pdev);
  485. if (err) {
  486. dev_err(&pdev->dev, "EFA device init failed\n");
  487. if (err == -ETIME)
  488. err = -EPROBE_DEFER;
  489. goto err_reg_read_destroy;
  490. }
  491. err = efa_enable_msix(dev);
  492. if (err)
  493. goto err_reg_read_destroy;
  494. edev->aq.msix_vector_idx = dev->admin_msix_vector_idx;
  495. edev->aenq.msix_vector_idx = dev->admin_msix_vector_idx;
  496. err = efa_set_mgmnt_irq(dev);
  497. if (err)
  498. goto err_disable_msix;
  499. err = efa_com_admin_init(edev, &aenq_handlers);
  500. if (err)
  501. goto err_free_mgmnt_irq;
  502. return dev;
  503. err_free_mgmnt_irq:
  504. efa_free_irq(dev, &dev->admin_irq);
  505. err_disable_msix:
  506. efa_disable_msix(dev);
  507. err_reg_read_destroy:
  508. efa_com_mmio_reg_read_destroy(edev);
  509. err_iounmap:
  510. devm_iounmap(&pdev->dev, edev->reg_bar);
  511. err_release_bars:
  512. efa_release_bars(dev, EFA_BASE_BAR_MASK);
  513. err_ibdev_destroy:
  514. ib_dealloc_device(&dev->ibdev);
  515. err_disable_device:
  516. pci_disable_device(pdev);
  517. return ERR_PTR(err);
  518. }
  519. static void efa_remove_device(struct pci_dev *pdev,
  520. enum efa_regs_reset_reason_types reset_reason)
  521. {
  522. struct efa_dev *dev = pci_get_drvdata(pdev);
  523. struct efa_com_dev *edev;
  524. edev = &dev->edev;
  525. efa_com_dev_reset(edev, reset_reason);
  526. efa_com_admin_destroy(edev);
  527. efa_free_irq(dev, &dev->admin_irq);
  528. efa_disable_msix(dev);
  529. efa_com_mmio_reg_read_destroy(edev);
  530. devm_iounmap(&pdev->dev, edev->reg_bar);
  531. efa_release_bars(dev, EFA_BASE_BAR_MASK);
  532. xa_destroy(&dev->cqs_xa);
  533. ib_dealloc_device(&dev->ibdev);
  534. pci_disable_device(pdev);
  535. }
  536. static int efa_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
  537. {
  538. struct efa_dev *dev;
  539. int err;
  540. dev = efa_probe_device(pdev);
  541. if (IS_ERR(dev))
  542. return PTR_ERR(dev);
  543. err = efa_ib_device_add(dev);
  544. if (err)
  545. goto err_remove_device;
  546. return 0;
  547. err_remove_device:
  548. efa_remove_device(pdev, EFA_REGS_RESET_INIT_ERR);
  549. return err;
  550. }
  551. static void efa_remove(struct pci_dev *pdev)
  552. {
  553. struct efa_dev *dev = pci_get_drvdata(pdev);
  554. efa_ib_device_remove(dev);
  555. efa_remove_device(pdev, EFA_REGS_RESET_NORMAL);
  556. }
  557. static void efa_shutdown(struct pci_dev *pdev)
  558. {
  559. struct efa_dev *dev = pci_get_drvdata(pdev);
  560. efa_destroy_eqs(dev);
  561. efa_com_dev_reset(&dev->edev, EFA_REGS_RESET_SHUTDOWN);
  562. efa_free_irq(dev, &dev->admin_irq);
  563. efa_disable_msix(dev);
  564. }
  565. static struct pci_driver efa_pci_driver = {
  566. .name = DRV_MODULE_NAME,
  567. .id_table = efa_pci_tbl,
  568. .probe = efa_probe,
  569. .remove = efa_remove,
  570. .shutdown = efa_shutdown,
  571. };
  572. module_pci_driver(efa_pci_driver);