summaryrefslogtreecommitdiffstats
path: root/drivers/nvme/host/tcp.c
diff options
context:
space:
mode:
authorMikhail Skorzhinskii <mskorzhinskiy@solarflare.com>2019-07-08 12:31:29 +0200
committerChristoph Hellwig <hch@lst.de>2019-07-09 23:18:09 +0200
commit37c15219599f7a4baa73f6e3432afc69ba7cc530 (patch)
tree611be0f9375e9b7982bc1ccc42fd0e76ae5f21d7 /drivers/nvme/host/tcp.c
parentnvme-tcp: set the STABLE_WRITES flag when data digests are enabled (diff)
downloadlinux-37c15219599f7a4baa73f6e3432afc69ba7cc530.tar.xz
linux-37c15219599f7a4baa73f6e3432afc69ba7cc530.zip
nvme-tcp: don't use sendpage for SLAB pages
According to commit a10674bf2406 ("tcp: detecting the misuse of .sendpage for Slab objects") and previous discussion, tcp_sendpage should not be used for pages that is managed by SLAB, as SLAB is not taking page reference counters into consideration. Signed-off-by: Mikhail Skorzhinskii <mskorzhinskiy@solarflare.com> Reviewed-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers/nvme/host/tcp.c')
-rw-r--r--drivers/nvme/host/tcp.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/nvme/host/tcp.c b/drivers/nvme/host/tcp.c
index 08a2501b9357..606b13d35d16 100644
--- a/drivers/nvme/host/tcp.c
+++ b/drivers/nvme/host/tcp.c
@@ -860,7 +860,14 @@ static int nvme_tcp_try_send_data(struct nvme_tcp_request *req)
else
flags |= MSG_MORE;
- ret = kernel_sendpage(queue->sock, page, offset, len, flags);
+ /* can't zcopy slab pages */
+ if (unlikely(PageSlab(page))) {
+ ret = sock_no_sendpage(queue->sock, page, offset, len,
+ flags);
+ } else {
+ ret = kernel_sendpage(queue->sock, page, offset, len,
+ flags);
+ }
if (ret <= 0)
return ret;