2019-05-19 20:07:45 +08:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
2007-05-24 05:21:22 +08:00
|
|
|
menuconfig INFINIBAND
|
2005-04-17 06:20:36 +08:00
|
|
|
tristate "InfiniBand support"
|
2017-11-20 02:58:30 +08:00
|
|
|
depends on HAS_IOMEM && HAS_DMA
|
2011-05-21 02:46:11 +08:00
|
|
|
depends on NET
|
2014-01-16 23:16:47 +08:00
|
|
|
depends on INET
|
|
|
|
depends on m || IPV6 != m
|
2017-11-28 01:04:22 +08:00
|
|
|
depends on !ALPHA
|
2015-12-12 03:53:03 +08:00
|
|
|
select IRQ_POLL
|
2019-07-08 18:59:04 +08:00
|
|
|
select DIMLIB
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2005-04-17 06:20:36 +08:00
|
|
|
Core support for InfiniBand (IB). Make sure to also select
|
|
|
|
any protocols you wish to use as well as drivers for your
|
|
|
|
InfiniBand hardware.
|
|
|
|
|
2007-05-24 05:21:22 +08:00
|
|
|
if INFINIBAND
|
|
|
|
|
2005-09-08 03:43:08 +08:00
|
|
|
config INFINIBAND_USER_MAD
|
|
|
|
tristate "InfiniBand userspace MAD support"
|
2005-07-08 08:57:14 +08:00
|
|
|
depends on INFINIBAND
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2005-09-08 03:43:08 +08:00
|
|
|
Userspace InfiniBand Management Datagram (MAD) support. This
|
|
|
|
is the kernel side of the userspace MAD support, which allows
|
2006-09-23 06:22:46 +08:00
|
|
|
userspace processes to send and receive MADs. You will also
|
2018-02-03 05:35:29 +08:00
|
|
|
need libibumad from rdma-core
|
|
|
|
<https://github.com/linux-rdma/rdma-core>.
|
2005-09-08 03:43:08 +08:00
|
|
|
|
|
|
|
config INFINIBAND_USER_ACCESS
|
|
|
|
tristate "InfiniBand userspace access (verbs and CM)"
|
2018-09-29 05:20:23 +08:00
|
|
|
depends on MMU
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2005-09-08 03:43:08 +08:00
|
|
|
Userspace InfiniBand access support. This enables the
|
|
|
|
kernel side of userspace verbs and the userspace
|
|
|
|
communication manager (CM). This allows userspace processes
|
|
|
|
to set up connections and directly access InfiniBand
|
|
|
|
hardware for fast-path operations. You will also need
|
|
|
|
libibverbs, libibcm and a hardware driver library from
|
2018-02-03 05:35:29 +08:00
|
|
|
rdma-core <https://github.com/linux-rdma/rdma-core>.
|
2005-07-08 08:57:14 +08:00
|
|
|
|
2007-03-05 08:15:11 +08:00
|
|
|
config INFINIBAND_USER_MEM
|
|
|
|
bool
|
|
|
|
depends on INFINIBAND_USER_ACCESS != n
|
2017-10-06 15:13:46 +08:00
|
|
|
depends on MMU
|
2020-12-16 05:27:13 +08:00
|
|
|
select DMA_SHARED_BUFFER
|
2007-03-05 08:15:11 +08:00
|
|
|
default y
|
|
|
|
|
2014-12-11 23:04:16 +08:00
|
|
|
config INFINIBAND_ON_DEMAND_PAGING
|
|
|
|
bool "InfiniBand on-demand paging support"
|
|
|
|
depends on INFINIBAND_USER_MEM
|
2014-12-11 23:04:18 +08:00
|
|
|
select MMU_NOTIFIER
|
2019-08-19 19:16:59 +08:00
|
|
|
select INTERVAL_TREE
|
2020-10-01 00:38:25 +08:00
|
|
|
select HMM_MIRROR
|
2014-12-11 23:04:16 +08:00
|
|
|
default y
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2014-12-11 23:04:16 +08:00
|
|
|
On demand paging support for the InfiniBand subsystem.
|
|
|
|
Together with driver support this allows registration of
|
|
|
|
memory regions without pinning their pages, fetching the
|
|
|
|
pages on demand instead.
|
|
|
|
|
2006-06-18 11:37:28 +08:00
|
|
|
config INFINIBAND_ADDR_TRANS
|
2018-04-27 02:19:35 +08:00
|
|
|
bool "RDMA/CM"
|
2014-01-16 23:16:47 +08:00
|
|
|
depends on INFINIBAND
|
2006-06-18 11:37:28 +08:00
|
|
|
default y
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2018-04-27 02:19:35 +08:00
|
|
|
Support for RDMA communication manager (CM).
|
|
|
|
This allows for a generic connection abstraction over RDMA.
|
2006-06-18 11:37:28 +08:00
|
|
|
|
2015-12-23 20:56:55 +08:00
|
|
|
config INFINIBAND_ADDR_TRANS_CONFIGFS
|
|
|
|
bool
|
|
|
|
depends on INFINIBAND_ADDR_TRANS && CONFIGFS_FS && !(INFINIBAND=y && CONFIGFS_FS=m)
|
|
|
|
default y
|
2020-06-14 00:50:22 +08:00
|
|
|
help
|
2015-12-23 20:56:55 +08:00
|
|
|
ConfigFS support for RDMA communication manager (CM).
|
|
|
|
This allows the user to config the default GID type that the CM
|
|
|
|
uses for each device, when initiaing new connections.
|
|
|
|
|
2020-11-07 02:19:32 +08:00
|
|
|
config INFINIBAND_VIRT_DMA
|
|
|
|
def_bool !HIGHMEM
|
|
|
|
|
2019-01-09 17:15:15 +08:00
|
|
|
if INFINIBAND_USER_ACCESS || !INFINIBAND_USER_ACCESS
|
2022-07-27 09:49:27 +08:00
|
|
|
source "drivers/infiniband/hw/bnxt_re/Kconfig"
|
2010-04-22 06:30:06 +08:00
|
|
|
source "drivers/infiniband/hw/cxgb4/Kconfig"
|
2019-05-06 01:59:31 +08:00
|
|
|
source "drivers/infiniband/hw/efa/Kconfig"
|
2022-07-27 09:49:27 +08:00
|
|
|
source "drivers/infiniband/hw/erdma/Kconfig"
|
|
|
|
source "drivers/infiniband/hw/hfi1/Kconfig"
|
|
|
|
source "drivers/infiniband/hw/hns/Kconfig"
|
2021-06-03 04:51:37 +08:00
|
|
|
source "drivers/infiniband/hw/irdma/Kconfig"
|
2007-05-09 09:00:38 +08:00
|
|
|
source "drivers/infiniband/hw/mlx4/Kconfig"
|
2013-07-07 22:25:49 +08:00
|
|
|
source "drivers/infiniband/hw/mlx5/Kconfig"
|
2022-07-27 09:49:27 +08:00
|
|
|
source "drivers/infiniband/hw/mthca/Kconfig"
|
2012-03-21 06:39:06 +08:00
|
|
|
source "drivers/infiniband/hw/ocrdma/Kconfig"
|
2019-01-09 17:15:15 +08:00
|
|
|
source "drivers/infiniband/hw/qedr/Kconfig"
|
2022-07-27 09:49:27 +08:00
|
|
|
source "drivers/infiniband/hw/qib/Kconfig"
|
|
|
|
source "drivers/infiniband/hw/usnic/Kconfig"
|
|
|
|
source "drivers/infiniband/hw/vmw_pvrdma/Kconfig"
|
2019-01-09 17:15:15 +08:00
|
|
|
source "drivers/infiniband/sw/rdmavt/Kconfig"
|
|
|
|
source "drivers/infiniband/sw/rxe/Kconfig"
|
2019-06-21 00:21:33 +08:00
|
|
|
source "drivers/infiniband/sw/siw/Kconfig"
|
2019-01-09 17:15:15 +08:00
|
|
|
endif
|
2007-05-09 09:00:38 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
source "drivers/infiniband/ulp/ipoib/Kconfig"
|
|
|
|
|
2005-11-03 06:07:13 +08:00
|
|
|
source "drivers/infiniband/ulp/srp/Kconfig"
|
2011-10-14 09:30:46 +08:00
|
|
|
source "drivers/infiniband/ulp/srpt/Kconfig"
|
2005-11-03 06:07:13 +08:00
|
|
|
|
2006-05-11 15:03:30 +08:00
|
|
|
source "drivers/infiniband/ulp/iser/Kconfig"
|
iser-target: Add iSCSI Extensions for RDMA (iSER) target driver
This patch adds support for iSCSI Extensions for RDMA target mode,
and includes CQ pooling per isert_device context distributed across
multiple active iser target sessions.
It also uses cmwq process context for RX / TX ib_post_cq() polling
via isert_cq_desc->cq_[rx,tx]_work invoked by isert_cq_[rx,tx]_callback()
hardIRQ context callbacks.
v5 changes:
- Use ISER_RECV_DATA_SEG_LEN instead of hardcoded value in ISER_RX_PAD_SIZE (Or)
- Fix make W=1 warnings (Or)
- Add missing depends on NET && INFINIBAND_ADDR_TRANS in Kconfig (Randy + Or)
- Make isert_device_find_by_ib_dev() return proper ERR_PTR (Wei Yongjun)
- Properly setup iscsi_np->np_sockaddr in isert_setup_np() (Shlomi + nab)
- Add special case for early ISCSI_OP_SCSI_CMD exception handling (nab)
v4 changes:
- Mark isert_cq_rx_work as static (Or)
- Drop unnecessary ib_dma_sync_single_for_cpu + ib_dma_sync_single_for_device
calls for isert_cmd->sense_buf_dma from isert_put_response (Or)
- Use 12288 for ISER_RX_PAD_SIZE base to save extra page per
struct iser_rx_desc (Or + nab)
- Drop now unnecessary isert_rx_desc usage, and convert RX users to
iser_rx_desc (Or + nab)
- Move isert_[alloc,free]_rx_descriptors() ahead of
isert_create_device_ib_res() usage (nab)
- Mark isert_cq_[rx,tx]_callback() + prototypes as static
- Fix 'warning: 'ret' may be used uninitialized' warning for
isert_create_device_ib_res on powerpc allmodconfig (fengguang + nab)
- Fix 'warning: 'ret' may be used uninitialized' warning for
isert_connect_request on i386 allyesconfig (fengguang + nab)
- Fix pr_debug conversion specification in isert_rx_completion()
(fengguang + nab)
- Drop unnecessary isert_conn->conn_cm_id != NULL check in
isert_connect_release causing the build warning:
"variable dereferenced before check 'isert_conn->conn_cm_id'"
- Fix isert_lid + isert_np leak in isert_setup_np failure path
- Add isert_conn->conn_wait_comp_err usage in isert_free_conn()
for isert_cq_comp_err completion path
- Add isert_conn->logout_posted bit to determine decrement of
isert_conn->post_send_buf_count from logout response completion
- Always set ISER_CONN_DOWN from isert_disconnect_work() callback
v3 changes:
- Convert to use per isert_cq_desc->cq_[rx,tx]_work + drop tasklets (Or + nab)
- Move IB_EVENT_QP_LAST_WQE_REACHED warn into correct
isert_qp_event_callback (Or)
- Drop unnecessary IB_ACCESS_REMOTE_* access flag usage in
isert_create_device_ib_res (Or)
- Add common isert_init_send_wr(), and convert isert_put_* calls (Or)
- Move to verbs+core logic to single ib_isert.[c,h] (Or + nab)
- Add kmem_cache isert_cmd_cache usage for descriptor allocation (nab)
- Move common ib_post_send() logic used by isert_put_*() to
isert_post_response() (nab)
- Add isert_put_reject call in isert_response_queue() for posting
ISCSI_REJECT response. (nab)
- Add ISTATE_SEND_REJECT checking in isert_do_control_comp. (nab)
v2 changes:
- Drop unused ISERT_ADDR_ROUTE_TIMEOUT define
- Add rdma_notify() call for IB_EVENT_COMM_EST in isert_qp_event_callback()
- Make isert_query_device() less verbose
- Drop unused RDMA_CM_EVENT_ADDR_ERROR and RDMA_CM_EVENT_ROUTE_ERROR
cases from isert_cma_handler()
- Drop unused rdma/ib_fmr_pool.h include
- Update isert_conn_setup_qp() to assign cq based upon least used
- Add isert_create_device_ib_res() to setup PD, CQs and MRs for each
underlying struct ib_device, instead of using per isert_conn resources.
- Add isert_free_device_ib_res() to release PD, CQs and MRs for each
underlying struct ib_device.
- Add isert_device_find_by_ib_dev()
- Change isert_connect_request() to drop PD, CQs and MRs allocation,
and use isert_device_find_by_ib_dev() instead.
- Add isert_device_try_release()
- Change isert_connect_release() to decrement cq_active_qps, and drop
PD, CQs and MRs resource release.
- Update isert_connect_release() to call isert_device_try_release()
- Make isert_create_device_ib_res() determine device->cqs_used based
upon num_online_cpus()
- Drop misleading isert_dump_ib_wc() usage
- Drop unused rdma/ib_fmr_pool.h include
- Use proper xfer_len for login PDUs in isert_rx_completion()
- Add isert_release_cmd() usage
- Change isert_alloc_cmd() to setup iscsi_cmd.release_cmd() pointer
- Change isert_put_cmd() to perform per iscsi_opcode specific release
logic
- Add isert_unmap_cmd() call for ISCSI_OP_SCSI_CMD from isert_put_cmd()
- Change isert_send_completion() to call
atomic_dec(&isert_conn->post_send_buf_count)
based upon per iscsi_opcode logic
- Drop ISTATE_REMOVE processing from isert_immediate_queue()
- Drop ISTATE_SEND_DATAIN processing from isert_response_queue()
- Drop ISTATE_SEND_STATUS processing from isert_response_queue()
- Drop iscsit_transport->iscsit_unmap_cmd() and ->iscsit_free_cmd()
- Convert iser_cq_tx_tasklet() to use struct isert_cq_desc pooling logic
- Convert isert_cq_tx_callback() to use struct isert_cq_desc pooling
logic
- Convert iser_cq_rx_tasklet() to use struct isert_cq_desc pooling logic
- Convert isert_cq_rx_callback() to use struct isert_cq_desc pooling
logic
- Add explict iscsit_stop_dataout_timer() call to
isert_do_rdma_read_comp()
- Use isert_get_dataout() for iscsit_transport->iscsit_get_dataout()
caller
- Drop ISTATE_SEND_R2T processing from isert_immediate_queue()
- Drop unused rdma/ib_fmr_pool.h include
- Drop isert_cmd->cmd_kref in favor of se_cmd->cmd_kref usage
- Add struct isert_device in order to support multiple EQs + CQ pooling
- Add struct isert_cq_desc
- Drop tasklets and cqs from isert_conn
- Bump ISERT_MAX_CQ to 64
- Various minor checkpatch fixes
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
2013-03-07 16:56:19 +08:00
|
|
|
source "drivers/infiniband/ulp/isert/Kconfig"
|
2020-05-11 21:51:19 +08:00
|
|
|
source "drivers/infiniband/ulp/rtrs/Kconfig"
|
2006-05-11 15:03:30 +08:00
|
|
|
|
2017-04-13 11:29:22 +08:00
|
|
|
source "drivers/infiniband/ulp/opa_vnic/Kconfig"
|
2017-02-10 19:19:53 +08:00
|
|
|
|
2007-05-24 05:21:22 +08:00
|
|
|
endif # INFINIBAND
|