提交 88715657 编写于 作者: A aliguori

qemu: add cpu_unregister_io_memory and make io mem table index dynamic (Marcelo Tosatti)

So drivers can clear their mem io table entries on exit back to unassigned
state.

Also make the io mem index allocation dynamic.
Signed-off-by: NMarcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6601 c046a42c-6fe2-441c-8c8c-71466251a162
上级 8b13c4a7
...@@ -909,6 +909,7 @@ int cpu_register_io_memory(int io_index, ...@@ -909,6 +909,7 @@ int cpu_register_io_memory(int io_index,
CPUReadMemoryFunc **mem_read, CPUReadMemoryFunc **mem_read,
CPUWriteMemoryFunc **mem_write, CPUWriteMemoryFunc **mem_write,
void *opaque); void *opaque);
void cpu_unregister_io_memory(int table_address);
CPUWriteMemoryFunc **cpu_get_io_memory_write(int io_index); CPUWriteMemoryFunc **cpu_get_io_memory_write(int io_index);
CPUReadMemoryFunc **cpu_get_io_memory_read(int io_index); CPUReadMemoryFunc **cpu_get_io_memory_read(int io_index);
......
...@@ -179,7 +179,7 @@ static void io_mem_init(void); ...@@ -179,7 +179,7 @@ static void io_mem_init(void);
CPUWriteMemoryFunc *io_mem_write[IO_MEM_NB_ENTRIES][4]; CPUWriteMemoryFunc *io_mem_write[IO_MEM_NB_ENTRIES][4];
CPUReadMemoryFunc *io_mem_read[IO_MEM_NB_ENTRIES][4]; CPUReadMemoryFunc *io_mem_read[IO_MEM_NB_ENTRIES][4];
void *io_mem_opaque[IO_MEM_NB_ENTRIES]; void *io_mem_opaque[IO_MEM_NB_ENTRIES];
static int io_mem_nb; char io_mem_used[IO_MEM_NB_ENTRIES];
static int io_mem_watch; static int io_mem_watch;
#endif #endif
...@@ -2799,12 +2799,28 @@ static void *subpage_init (target_phys_addr_t base, ram_addr_t *phys, ...@@ -2799,12 +2799,28 @@ static void *subpage_init (target_phys_addr_t base, ram_addr_t *phys,
return mmio; return mmio;
} }
static int get_free_io_mem_idx(void)
{
int i;
for (i = 0; i<IO_MEM_NB_ENTRIES; i++)
if (!io_mem_used[i]) {
io_mem_used[i] = 1;
return i;
}
return -1;
}
static void io_mem_init(void) static void io_mem_init(void)
{ {
int i;
cpu_register_io_memory(IO_MEM_ROM >> IO_MEM_SHIFT, error_mem_read, unassigned_mem_write, NULL); cpu_register_io_memory(IO_MEM_ROM >> IO_MEM_SHIFT, error_mem_read, unassigned_mem_write, NULL);
cpu_register_io_memory(IO_MEM_UNASSIGNED >> IO_MEM_SHIFT, unassigned_mem_read, unassigned_mem_write, NULL); cpu_register_io_memory(IO_MEM_UNASSIGNED >> IO_MEM_SHIFT, unassigned_mem_read, unassigned_mem_write, NULL);
cpu_register_io_memory(IO_MEM_NOTDIRTY >> IO_MEM_SHIFT, error_mem_read, notdirty_mem_write, NULL); cpu_register_io_memory(IO_MEM_NOTDIRTY >> IO_MEM_SHIFT, error_mem_read, notdirty_mem_write, NULL);
io_mem_nb = 5; for (i=0; i<5; i++)
io_mem_used[i] = 1;
io_mem_watch = cpu_register_io_memory(0, watch_mem_read, io_mem_watch = cpu_register_io_memory(0, watch_mem_read,
watch_mem_write, NULL); watch_mem_write, NULL);
...@@ -2829,9 +2845,9 @@ int cpu_register_io_memory(int io_index, ...@@ -2829,9 +2845,9 @@ int cpu_register_io_memory(int io_index,
int i, subwidth = 0; int i, subwidth = 0;
if (io_index <= 0) { if (io_index <= 0) {
if (io_mem_nb >= IO_MEM_NB_ENTRIES) io_index = get_free_io_mem_idx();
return -1; if (io_index == -1)
io_index = io_mem_nb++; return io_index;
} else { } else {
if (io_index >= IO_MEM_NB_ENTRIES) if (io_index >= IO_MEM_NB_ENTRIES)
return -1; return -1;
...@@ -2847,6 +2863,19 @@ int cpu_register_io_memory(int io_index, ...@@ -2847,6 +2863,19 @@ int cpu_register_io_memory(int io_index,
return (io_index << IO_MEM_SHIFT) | subwidth; return (io_index << IO_MEM_SHIFT) | subwidth;
} }
void cpu_unregister_io_memory(int io_table_address)
{
int i;
int io_index = io_table_address >> IO_MEM_SHIFT;
for (i=0;i < 3; i++) {
io_mem_read[io_index][i] = unassigned_mem_read[i];
io_mem_write[io_index][i] = unassigned_mem_write[i];
}
io_mem_opaque[io_index] = NULL;
io_mem_used[io_index] = 0;
}
CPUWriteMemoryFunc **cpu_get_io_memory_write(int io_index) CPUWriteMemoryFunc **cpu_get_io_memory_write(int io_index)
{ {
return io_mem_write[io_index >> IO_MEM_SHIFT]; return io_mem_write[io_index >> IO_MEM_SHIFT];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册