| lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
|
Open Source and information security mailing list archives
| ||
|
Message-ID: <1310738489.4381.20.camel@lade.trondhjem.org> Date: Fri, 15 Jul 2011 10:01:29 -0400 From: Trond Myklebust <Trond.Myklebust@...app.com> To: Ian Campbell <ian.campbell@...rix.com> Cc: netdev@...r.kernel.org, linux-nfs@...r.kernel.org Subject: Re: [PATCH 09/10] nfs: use sk fragment destructors to delay I/O completion until page is released by network stack. On Fri, 2011-07-15 at 12:07 +0100, Ian Campbell wrote: > Thos prevents an issue where an ACK is delayed, a retransmit is queued (either > at the RPC or TCP level) and the ACK arrives before the retransmission hits the > wire. If this happens then the write() system call and the userspace process > can continue potentially modifying the data before the retransmission occurs. > > NB: this only covers the O_DIRECT write() case. I expect other cases to need > handling as well. That is why this belongs entirely in the RPC layer, and really should not touch the NFS layer. If you move your callback to the RPC layer and have it notify the rpc_task when the pages have been sent, then it should be possible to achieve the same thing. IOW: Add an extra state machine step after call_decode() which checks if all the page data has been transmitted and if not, puts the rpc_task on a wait queue, and has it wait for the fragment destructor callback before calling rpc_exit_task(). Cheers Trond -- Trond Myklebust Linux NFS client maintainer NetApp Trond.Myklebust@...app.com www.netapp.com -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@...r.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists