]> www.infradead.org Git - users/jedix/linux-maple.git/commit
x86, mtrr: Fix a type overflow in range_to_mtrr func
authorzhenzhong.duan <zhenzhong.duan@oracle.com>
Wed, 30 May 2012 04:52:15 +0000 (12:52 +0800)
committerMaxim Uvarov <maxim.uvarov@oracle.com>
Thu, 16 Aug 2012 09:17:44 +0000 (02:17 -0700)
commit3344de8419b3427a8d4cd57b2489a686c1b3dc5f
tree807aa1eb11acd9cfc1edaaf88fcfefab250b6a8a
parentfcad214379cc915183d00cb028ec2aad16f5b57b
x86, mtrr: Fix a type overflow in range_to_mtrr func

Orabug: 14073173
When boot on sun G5+ with 4T mem, see an overflow in mtrr cleanup as below.

*BAD*gran_size: 2G      chunk_size: 2G  num_reg: 10     lose cover RAM:
-18014398505283592M

This is because 1<<31 sign extended. Use an unsigned long constant to
fix it.  Useful for mem larger than or equal to 4T.

-v2: Use 64bit constant instead of explicit type conversion as suggested
by Yinghai. Description updated too.

Signed-off-by: Zhenzhong Duan <zhenzhong.duan@oracle.com>
Link: http://lkml.kernel.org/r/4FC5A77F.6060505@oracle.com
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
arch/x86/kernel/cpu/mtrr/cleanup.c