diff options
| author | Wilfred Mallawa <wilfred.mallawa@wdc.com> | 2025-10-10 17:19:42 +1000 | 
|---|---|---|
| committer | Keith Busch <kbusch@kernel.org> | 2025-10-16 11:32:04 -0700 | 
| commit | 5a869d017793399fd1d2609ff27e900534173eb3 (patch) | |
| tree | 28d73bb305501bbc4557e34d458dcc53bc3bbae5 /scripts/bpf_doc.py | |
| parent | 7e091add9c433bab6912228799bf508e2414acc3 (diff) | |
nvme/tcp: handle tls partially sent records in write_space()
With TLS enabled, records that are encrypted and appended to TLS TX
list can fail to see a retry if the underlying TCP socket is busy, for
example, hitting an EAGAIN from tcp_sendmsg_locked(). This is not known
to the NVMe TCP driver, as the TLS layer successfully generated a record.
Typically, the TLS write_space() callback would ensure such records are
retried, but in the NVMe TCP Host driver, write_space() invokes
nvme_tcp_write_space(). This causes a partially sent record in the TLS TX
list to timeout after not being retried.
This patch fixes the above by calling queue->write_space(), which calls
into the TLS layer to retry any pending records.
Fixes: be8e82caa685 ("nvme-tcp: enable TLS handshake upcall")
Signed-off-by: Wilfred Mallawa <wilfred.mallawa@wdc.com>
Reviewed-by: Hannes Reinecke <hare@suse.de>
Signed-off-by: Keith Busch <kbusch@kernel.org>
Diffstat (limited to 'scripts/bpf_doc.py')
0 files changed, 0 insertions, 0 deletions
