]> git.ipfire.org Git - thirdparty/qemu.git/commit
target/ppc: Move setting of patb_entry on hash table init
authorSuraj Jitindar Singh <sjitindarsingh@gmail.com>
Fri, 24 Nov 2017 04:23:24 +0000 (15:23 +1100)
committerDavid Gibson <david@gibson.dropbear.id.au>
Mon, 27 Nov 2017 01:20:11 +0000 (12:20 +1100)
commitee4d9ecc3675af1e68a9c00a8b338641898d613e
tree41785c4b06d673f68a884540fcb862bc5796ca40
parente7b47c22e2df14d55e3e4426688c929bf8e3f7fb
target/ppc: Move setting of patb_entry on hash table init

The patb_entry is used to store the location of the process table in
guest memory. The msb is also used to indicate the mmu mode of the
guest, that is patb_entry & 1 << 63 ? radix_mode : hash_mode.

Currently we set this to zero in spapr_setup_hpt_and_vrma() since if
this function gets called then we know we're hash. However some code
paths, such as setting up the hpt on incoming migration of a hash guest,
call spapr_reallocate_hpt() directly bypassing this higher level
function. Since we assume radix if the host is capable this results in
the msb in patb_entry being left set so in spapr_post_load() we call
kvmppc_configure_v3_mmu() and tell the host we're radix which as
expected means addresses cannot be translated once we actually run the cpu.

To fix this move the zeroing of patb_entry into spapr_reallocate_hpt().

Signed-off-by: Suraj Jitindar Singh <sjitindarsingh@gmail.com>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
hw/ppc/spapr.c