softmmu: Use uintptr_t for physaddr and rename it
Variable physaddr is a host address which should be represented by data type 'uintptr_t'. This is needed for w64 and changes nothing for other hosts. v2: Rename physaddr -> hostaddr (suggested by Blue Swirl). Signed-off-by: Stefan Weil <sw@weilnetz.de>
This commit is contained in:
parent
3b2992e42f
commit
23ddbf08bf
|
@ -99,7 +99,6 @@ glue(glue(glue(CPU_PREFIX, ld), USUFFIX), MEMSUFFIX)(ENV_PARAM
|
||||||
int page_index;
|
int page_index;
|
||||||
RES_TYPE res;
|
RES_TYPE res;
|
||||||
target_ulong addr;
|
target_ulong addr;
|
||||||
unsigned long physaddr;
|
|
||||||
int mmu_idx;
|
int mmu_idx;
|
||||||
|
|
||||||
addr = ptr;
|
addr = ptr;
|
||||||
|
@ -111,8 +110,8 @@ glue(glue(glue(CPU_PREFIX, ld), USUFFIX), MEMSUFFIX)(ENV_PARAM
|
||||||
addr,
|
addr,
|
||||||
mmu_idx);
|
mmu_idx);
|
||||||
} else {
|
} else {
|
||||||
physaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
uintptr_t hostaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
||||||
res = glue(glue(ld, USUFFIX), _raw)((uint8_t *)physaddr);
|
res = glue(glue(ld, USUFFIX), _raw)((uint8_t *)hostaddr);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -124,7 +123,6 @@ glue(glue(glue(CPU_PREFIX, lds), SUFFIX), MEMSUFFIX)(ENV_PARAM
|
||||||
{
|
{
|
||||||
int res, page_index;
|
int res, page_index;
|
||||||
target_ulong addr;
|
target_ulong addr;
|
||||||
unsigned long physaddr;
|
|
||||||
int mmu_idx;
|
int mmu_idx;
|
||||||
|
|
||||||
addr = ptr;
|
addr = ptr;
|
||||||
|
@ -135,8 +133,8 @@ glue(glue(glue(CPU_PREFIX, lds), SUFFIX), MEMSUFFIX)(ENV_PARAM
|
||||||
res = (DATA_STYPE)glue(glue(glue(HELPER_PREFIX, ld), SUFFIX),
|
res = (DATA_STYPE)glue(glue(glue(HELPER_PREFIX, ld), SUFFIX),
|
||||||
MMUSUFFIX)(ENV_VAR addr, mmu_idx);
|
MMUSUFFIX)(ENV_VAR addr, mmu_idx);
|
||||||
} else {
|
} else {
|
||||||
physaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
uintptr_t hostaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
||||||
res = glue(glue(lds, SUFFIX), _raw)((uint8_t *)physaddr);
|
res = glue(glue(lds, SUFFIX), _raw)((uint8_t *)hostaddr);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -152,7 +150,6 @@ glue(glue(glue(CPU_PREFIX, st), SUFFIX), MEMSUFFIX)(ENV_PARAM target_ulong ptr,
|
||||||
{
|
{
|
||||||
int page_index;
|
int page_index;
|
||||||
target_ulong addr;
|
target_ulong addr;
|
||||||
unsigned long physaddr;
|
|
||||||
int mmu_idx;
|
int mmu_idx;
|
||||||
|
|
||||||
addr = ptr;
|
addr = ptr;
|
||||||
|
@ -163,8 +160,8 @@ glue(glue(glue(CPU_PREFIX, st), SUFFIX), MEMSUFFIX)(ENV_PARAM target_ulong ptr,
|
||||||
glue(glue(glue(HELPER_PREFIX, st), SUFFIX), MMUSUFFIX)(ENV_VAR addr, v,
|
glue(glue(glue(HELPER_PREFIX, st), SUFFIX), MMUSUFFIX)(ENV_VAR addr, v,
|
||||||
mmu_idx);
|
mmu_idx);
|
||||||
} else {
|
} else {
|
||||||
physaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
uintptr_t hostaddr = addr + env->tlb_table[mmu_idx][page_index].addend;
|
||||||
glue(glue(st, SUFFIX), _raw)((uint8_t *)physaddr, v);
|
glue(glue(st, SUFFIX), _raw)((uint8_t *)hostaddr, v);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue