diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2015-07-21 15:19:38 +1000 |
---|---|---|
committer | Richard Henderson <rth@twiddle.net> | 2015-08-24 11:10:54 -0700 |
commit | 68d45bb61c5bbfb3999486f78cf026c1e79eb301 (patch) | |
tree | 92d3035743e62c45d4824fa4c652178b473c132f /memory_mapping.c | |
parent | 8cc580f6a0d8c0e2f590c1472cf5cd8e51761760 (diff) | |
download | qemu-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