qede_rdma.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /* QLogic qedr NIC Driver
  2. * Copyright (c) 2015-2017 QLogic Corporation
  3. *
  4. * This software is available to you under a choice of one of two
  5. * licenses. You may choose to be licensed under the terms of the GNU
  6. * General Public License (GPL) Version 2, available from the file
  7. * COPYING in the main directory of this source tree, or the
  8. * OpenIB.org BSD license below:
  9. *
  10. * Redistribution and use in source and binary forms, with or
  11. * without modification, are permitted provided that the following
  12. * conditions are met:
  13. *
  14. * - Redistributions of source code must retain the above
  15. * copyright notice, this list of conditions and the following
  16. * disclaimer.
  17. *
  18. * - Redistributions in binary form must reproduce the above
  19. * copyright notice, this list of conditions and the following
  20. * disclaimer in the documentation and /or other materials
  21. * provided with the distribution.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  27. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  28. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  29. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  30. * SOFTWARE.
  31. */
  32. #ifndef QEDE_ROCE_H
  33. #define QEDE_ROCE_H
  34. #include <linux/pci.h>
  35. #include <linux/netdevice.h>
  36. #include <linux/types.h>
  37. #include <linux/workqueue.h>
  38. struct qedr_dev;
  39. struct qed_dev;
  40. struct qede_dev;
  41. enum qede_rdma_event {
  42. QEDE_UP,
  43. QEDE_DOWN,
  44. QEDE_CHANGE_ADDR,
  45. QEDE_CLOSE
  46. };
  47. struct qede_rdma_event_work {
  48. struct list_head list;
  49. struct work_struct work;
  50. void *ptr;
  51. enum qede_rdma_event event;
  52. };
  53. struct qedr_driver {
  54. unsigned char name[32];
  55. struct qedr_dev* (*add)(struct qed_dev *, struct pci_dev *,
  56. struct net_device *);
  57. void (*remove)(struct qedr_dev *);
  58. void (*notify)(struct qedr_dev *, enum qede_rdma_event);
  59. };
  60. /* APIs for RDMA driver to register callback handlers,
  61. * which will be invoked when device is added, removed, ifup, ifdown
  62. */
  63. int qede_rdma_register_driver(struct qedr_driver *drv);
  64. void qede_rdma_unregister_driver(struct qedr_driver *drv);
  65. bool qede_rdma_supported(struct qede_dev *dev);
  66. #if IS_ENABLED(CONFIG_QED_RDMA)
  67. int qede_rdma_dev_add(struct qede_dev *dev);
  68. void qede_rdma_dev_event_open(struct qede_dev *dev);
  69. void qede_rdma_dev_event_close(struct qede_dev *dev);
  70. void qede_rdma_dev_remove(struct qede_dev *dev);
  71. void qede_rdma_event_changeaddr(struct qede_dev *edr);
  72. #else
  73. static inline int qede_rdma_dev_add(struct qede_dev *dev)
  74. {
  75. return 0;
  76. }
  77. static inline void qede_rdma_dev_event_open(struct qede_dev *dev) {}
  78. static inline void qede_rdma_dev_event_close(struct qede_dev *dev) {}
  79. static inline void qede_rdma_dev_remove(struct qede_dev *dev) {}
  80. static inline void qede_rdma_event_changeaddr(struct qede_dev *edr) {}
  81. #endif
  82. #endif