X86: Truncate addresses to 32 bits except in 64 bit mode, not long mode.
authorGabe Black <gblack@eecs.umich.edu>
Mon, 28 May 2012 02:01:04 +0000 (19:01 -0700)
committerGabe Black <gblack@eecs.umich.edu>
Mon, 28 May 2012 02:01:04 +0000 (19:01 -0700)
commit1d96135087be27b43ddfb5f2f508fbed8e0b7ebb
treee82ea77a041b510681f1c326c56e8c699233af6b
parent19df4e94ee4f2323e5fe1b915f7e81a6034cfc56
X86: Truncate addresses to 32 bits except in 64 bit mode, not long mode.

A small change was added a while ago to keep addresses from overflowing 32
bits when larger addresses shouldn't be accessible to software. That change
truncated when not in long mode, but really it should have truncated when not
in 64 bit mode. The difference is whether compatibility mode is included, a
mode that's supposed to act like a legacy 32 bit mode.
src/arch/x86/tlb.cc