aboutsummaryrefslogtreecommitdiff
path: root/memory_mapping.c
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2015-07-21 15:19:38 +1000
committerRichard Henderson <rth@twiddle.net>2015-08-24 11:10:54 -0700
commit68d45bb61c5bbfb3999486f78cf026c1e79eb301 (patch)
tree92d3035743e62c45d4824fa4c652178b473c132f /memory_mapping.c
parent8cc580f6a0d8c0e2f590c1472cf5cd8e51761760 (diff)
downloadqemu-68d45bb61c5bbfb3999486f78cf026c1e79eb301.zip
qemu-68d45bb61c5bbfb3999486f78cf026c1e79eb301.tar.gz
qemu-68d45bb61c5bbfb3999486f78cf026c1e79eb301.tar.bz2
tcg/ppc: Improve unaligned load/store handling on 64-bit backend
Currently, we get to the slow path for any unaligned access in the backend, because we effectively preserve the bottom address bits below the alignment requirement when comparing with the TLB entry, so any non-0 bit there will cause the compare to fail. For the same number of instructions, we can instead add the access size - 1 to the address and stick to clearing all the bottom bits. That means that normal unaligned accesses will not fallback (the HW will handle them fine). Only when crossing a page boundary well we end up having a mismatch because we'll end up pointing to the next page which cannot possibly be in that same TLB entry. Reviewed-by: Aurelien Jarno <aurelien@aurel32.net> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Message-Id: <1437455978.5809.2.camel@kernel.crashing.org> Signed-off-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'memory_mapping.c')
0 files changed, 0 insertions, 0 deletions