summaryrefslogtreecommitdiffstats
path: root/fs/ext4/ext4.h
diff options
context:
space:
mode:
authorTheodore Ts'o2018-08-27 15:22:45 +0200
committerTheodore Ts'o2018-08-27 15:22:45 +0200
commit4d982e25d0bdc83d8c64e66fdeca0b89240b3b85 (patch)
treef1775363ff05e10010530d4fc5a2201f7fae02d6 /fs/ext4/ext4.h
parentext4: check to make sure the rename(2)'s destination is not freed (diff)
downloadkernel-qcow2-linux-4d982e25d0bdc83d8c64e66fdeca0b89240b3b85.tar.gz
kernel-qcow2-linux-4d982e25d0bdc83d8c64e66fdeca0b89240b3b85.tar.xz
kernel-qcow2-linux-4d982e25d0bdc83d8c64e66fdeca0b89240b3b85.zip
ext4: avoid divide by zero fault when deleting corrupted inline directories
A specially crafted file system can trick empty_inline_dir() into reading past the last valid entry in a inline directory, and then run into the end of xattr marker. This will trigger a divide by zero fault. Fix this by using the size of the inline directory instead of dir->i_size. Also clean up error reporting in __ext4_check_dir_entry so that the message is clearer and more understandable --- and avoids the division by zero trap if the size passed in is zero. (I'm not sure why we coded it that way in the first place; printing offset % size is actually more confusing and less useful.) https://bugzilla.kernel.org/show_bug.cgi?id=200933 Signed-off-by: Theodore Ts'o <tytso@mit.edu> Reported-by: Wen Xu <wen.xu@gatech.edu> Cc: stable@vger.kernel.org
Diffstat (limited to 'fs/ext4/ext4.h')
0 files changed, 0 insertions, 0 deletions