diff options
| author | Sagi Grimberg <sagi@grimberg.me> | 2017-11-23 17:35:22 +0200 | 
|---|---|---|
| committer | Christoph Hellwig <hch@lst.de> | 2017-11-26 15:33:32 +0100 | 
| commit | 4af7f7ff92a42b6c713293c99e7982bcfcf51a70 (patch) | |
| tree | 49ab3f97188e32b101fd008db4205024ff8109fd /scripts/gcc-plugins/randomize_layout_plugin.c | |
| parent | b4b591c87f2b0f4ebaf3a68d4f13873b241aa584 (diff) | |
nvme-rdma: don't complete requests before a send work request has completed
In order to guarantee that the HCA will never get an access violation
(either from invalidated rkey or from iommu) when retrying a send
operation we must complete a request only when both send completion and
the nvme cqe has arrived. We need to set the send/recv completions flags
atomically because we might have more than a single context accessing the
request concurrently (one is cq irq-poll context and the other is
user-polling used in IOCB_HIPRI).
Only then we are safe to invalidate the rkey (if needed), unmap the host
buffers, and complete the IO.
Signed-off-by: Sagi Grimberg <sagi@grimberg.me>
Reviewed-by: Max Gurtovoy <maxg@mellanox.com>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'scripts/gcc-plugins/randomize_layout_plugin.c')
0 files changed, 0 insertions, 0 deletions
