mirror of https://gitlab.com/qemu-project/qemu
Fix ARM fine pagetables.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2742 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
cf2d385c43
commit
c73c3aa081
|
@ -372,7 +372,13 @@ static int get_phys_addr(CPUState *env, uint32_t address, int access_type,
|
||||||
code = 13;
|
code = 13;
|
||||||
} else {
|
} else {
|
||||||
/* Lookup l2 entry. */
|
/* Lookup l2 entry. */
|
||||||
table = (desc & 0xfffffc00) | ((address >> 10) & 0x3fc);
|
if (type == 1) {
|
||||||
|
/* Coarse pagetable. */
|
||||||
|
table = (desc & 0xfffffc00) | ((address >> 10) & 0x3fc);
|
||||||
|
} else {
|
||||||
|
/* Fine pagetable. */
|
||||||
|
table = (desc & 0xfffff000) | ((address >> 8) & 0xffc);
|
||||||
|
}
|
||||||
desc = ldl_phys(table);
|
desc = ldl_phys(table);
|
||||||
switch (desc & 3) {
|
switch (desc & 3) {
|
||||||
case 0: /* Page translation fault. */
|
case 0: /* Page translation fault. */
|
||||||
|
|
Loading…
Reference in New Issue