summaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorAravind Gopalakrishnan <Aravind.Gopalakrishnan@amd.com>2013-08-24 10:47:48 -0500
committerBorislav Petkov <bp@suse.de>2013-08-27 15:00:22 +0200
commit4fc06b3171f4de92cd21bf7ab1cb0bf62f05769d (patch)
tree9f95e7ce272ba34b68d19c6fb42798e3c04c1863 /block
parent3f0aba4fc0ec789634c29a8265b90b8b0d1a4e29 (diff)
downloadlinux-4fc06b3171f4de92cd21bf7ab1cb0bf62f05769d.tar.bz2
amd64_edac: Fix incorrect wraparounds
dct_base and dct_limit obtain 32 bit register values when they read their respective pci config space registers. A left shift beyond 32 bits will cause them to wrap around. Similar case for chan_addr as can be seen from the bug report (link below). In the patch, we rectify this by casting chan_addr to u64 and by comparing dct_base and dct_limit against properly shifted sys_addr in order to compare the correct bits. Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Aravind Gopalakrishnan <Aravind.Gopalakrishnan@amd.com> Link: http://lkml.kernel.org/r/20130819132302.GA12171@elgon.mountain Signed-off-by: Borislav Petkov <bp@suse.de>
Diffstat (limited to 'block')
0 files changed, 0 insertions, 0 deletions