diff options
author | Paolo Bonzini <pbonzini@redhat.com> | 2013-06-28 17:29:27 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2013-07-04 17:42:46 +0200 |
commit | e3127ae0cdcde6b10a8643836f5bec197f2eff1a (patch) | |
tree | 19bee73e7abca174637bb7633ecad259a4cac8c1 /target-openrisc/interrupt.c | |
parent | 1b5ec2346703c060d26ada7d95fe9aaf476b1947 (diff) | |
download | qemu-e3127ae0cdcde6b10a8643836f5bec197f2eff1a.zip qemu-e3127ae0cdcde6b10a8643836f5bec197f2eff1a.tar.gz qemu-e3127ae0cdcde6b10a8643836f5bec197f2eff1a.tar.bz2 |
exec: reorganize address_space_map
First of all, rename "todo" to "done".
Second, clearly separate the case of done == 0 with the case of done != 0.
This will help handling reference counting in the next patch.
Third, this test:
if (memory_region_get_ram_addr(mr) + xlat != raddr + todo) {
does not guarantee that the memory region is the same across two iterations
of the while loop. For example, you could have two blocks:
A) size 640 K, mapped at physical address 0, ram_addr_t 0
B) size 64 K, mapped at physical address 0xa0000, ram_addr_t 0xa0000
then mapping 1 M starting at physical address zero will erroneously treat
B as the continuation of block A. qemu_ram_ptr_length ensures that no
invalid memory is accessed, but it is still a pointless complication of
the algorithm. The patch makes the logic clearer with an explicit test
that the memory region is the same.
Reviewed-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'target-openrisc/interrupt.c')
0 files changed, 0 insertions, 0 deletions