diff options
author | NeilBrown <neilb@suse.de> | 2006-06-25 05:48:02 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-25 10:01:09 -0700 |
commit | 7c12d81134b130ccd4c286b434ca48c4cda71a2f (patch) | |
tree | 32f1451ef52d568d57c75da28313069dc675a206 /kernel/acct.c | |
parent | 01408c4939479ec46c15aa7ef6e2406be50eeeca (diff) | |
download | talos-op-linux-7c12d81134b130ccd4c286b434ca48c4cda71a2f.tar.gz talos-op-linux-7c12d81134b130ccd4c286b434ca48c4cda71a2f.zip |
[PATCH] Make copy_from_user_inatomic NOT zero the tail on i386
As described in a previous patch and documented in mm/filemap.h,
copy_from_user_inatomic* shouldn't zero out the tail of the buffer after an
incomplete copy.
This patch implements that change for i386.
For the _nocache version, a new __copy_user_intel_nocache is defined similar
to copy_user_zeroio_intel_nocache, and this is ultimately used for the copy.
For the regular version, __copy_from_user_ll_nozero is defined which uses
__copy_user and __copy_user_intel - the later needs casts to reposition the
__user annotations.
If copy_from_user_atomic is given a constant length of 1, 2, or 4, then we do
still zero the destintion on failure. This didn't seem worth the effort of
fixing as the places where it is used really don't care.
Signed-off-by: Neil Brown <neilb@suse.de>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: William Lee Irwin III <wli@holomorphy.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel/acct.c')
0 files changed, 0 insertions, 0 deletions