Re: [PATCH 07/17] nvme-fc: use nr_phys_segments to determine existence of sgl

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




From: James Smart <jsmart2021@xxxxxxxxx>

For some nvme command, when issued by the nvme core layer, there
is an internal buffer which can cause blk_rq_payload_bytes() to
return a non-zero value yet there is no actual/real command payload
and sg list.  An example is the WRITE ZEROES command.

To address this, when making choices on whether to dma map an sgl,
use blk_rq_nr_phys_segments() instead of blk_rq_payload_bytes().
When there is a sgl, blk_rq_payload_bytes() will return the amount
of data to be transferred by the sgl.

Signed-off-by: Chaitanya Kulkarni <chaitanya.kulkarni@xxxxxxx>
Signed-off-by: James Smart <jsmart2021@xxxxxxxxx>
Signed-off-by: Christoph Hellwig <hch@xxxxxx>


I guess we'll need it for all transport.

I saw that pci is covered, RDMA isn't.

RDMA patch is already in AFAIR...

Also IMO tcp should be fixed (didn't dive into it yet, just high level check for blk_rq_payload_bytes).

tcp already looks into RQF_SPECIAL_PAYLOAD so the issue does not apply to it.



[Index of Archives]     [Linux RAID]     [Linux SCSI]     [Linux ATA RAID]     [IDE]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Device Mapper]

  Powered by Linux