From: Michael Halcrow Date: Wed, 26 Nov 2014 17:09:16 +0000 (-0800) Subject: eCryptfs: Remove buggy and unnecessary write in file name decode routine X-Git-Tag: v3.12.36~8 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=8ffea99d6f2be99790611282f326da95a84a8cab;p=platform%2Fkernel%2Flinux-stable.git eCryptfs: Remove buggy and unnecessary write in file name decode routine commit 942080643bce061c3dd9d5718d3b745dcb39a8bc upstream. Dmitry Chernenkov used KASAN to discover that eCryptfs writes past the end of the allocated buffer during encrypted filename decoding. This fix corrects the issue by getting rid of the unnecessary 0 write when the current bit offset is 2. Signed-off-by: Michael Halcrow Reported-by: Dmitry Chernenkov Suggested-by: Kees Cook Signed-off-by: Tyler Hicks Signed-off-by: Jiri Slaby --- diff --git a/fs/ecryptfs/crypto.c b/fs/ecryptfs/crypto.c index 000eae2782b6..bf926f7a5f0c 100644 --- a/fs/ecryptfs/crypto.c +++ b/fs/ecryptfs/crypto.c @@ -1917,7 +1917,6 @@ ecryptfs_decode_from_filename(unsigned char *dst, size_t *dst_size, break; case 2: dst[dst_byte_offset++] |= (src_byte); - dst[dst_byte_offset] = 0; current_bit_offset = 0; break; }