eCryptfs: Infinite loop due to overflow in ecryptfs_write()
authorLi Wang <liwang@nudt.edu.cn>
Thu, 19 Jan 2012 01:44:36 +0000 (09:44 +0800)
committerTyler Hicks <tyhicks@canonical.com>
Wed, 25 Jan 2012 20:43:40 +0000 (14:43 -0600)
commit684a3ff7e69acc7c678d1a1394fe9e757993fd34
tree733157a7c6ad606799fd2692f882da14aae2fd0b
parent48399c0b0e6172888a2e2e36df1595ab1e049ba8
eCryptfs: Infinite loop due to overflow in ecryptfs_write()

ecryptfs_write() can enter an infinite loop when truncating a file to a
size larger than 4G. This only happens on architectures where size_t is
represented by 32 bits.

This was caused by a size_t overflow due to it incorrectly being used to
store the result of a calculation which uses potentially large values of
type loff_t.

[tyhicks@canonical.com: rewrite subject and commit message]
Signed-off-by: Li Wang <liwang@nudt.edu.cn>
Signed-off-by: Yunchuan Wen <wenyunchuan@kylinos.com.cn>
Reviewed-by: Cong Wang <xiyou.wangcong@gmail.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Tyler Hicks <tyhicks@canonical.com>
fs/ecryptfs/read_write.c