mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 12:23:53 -06:00
rust: pl011: only leave embedded object initialization in instance_init
Leave IRQ and MMIO initialization to instance_post_init. In Rust the two callbacks are more distinct, because only instance_post_init has a fully initialized object available. While at it, add a wrapper for sysbus_init_mmio so that accesses to the SysBusDevice correctly use shared references. Reviewed-by: Zhao Liu <zhao1.liu@intel.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
d9434f29ca
commit
af68b41d40
2 changed files with 22 additions and 8 deletions
|
@ -38,6 +38,18 @@ impl SysBusDevice {
|
|||
addr_of!(*self) as *mut _
|
||||
}
|
||||
|
||||
/// Expose a memory region to the board so that it can give it an address
|
||||
/// in guest memory. Note that the ordering of calls to `init_mmio` is
|
||||
/// important, since whoever creates the sysbus device will refer to the
|
||||
/// region with a number that corresponds to the order of calls to
|
||||
/// `init_mmio`.
|
||||
pub fn init_mmio(&self, iomem: &bindings::MemoryRegion) {
|
||||
assert!(bql_locked());
|
||||
unsafe {
|
||||
bindings::sysbus_init_mmio(self.as_mut_ptr(), addr_of!(*iomem) as *mut _);
|
||||
}
|
||||
}
|
||||
|
||||
/// Expose an interrupt source outside the device as a qdev GPIO output.
|
||||
/// Note that the ordering of calls to `init_irq` is important, since
|
||||
/// whoever creates the sysbus device will refer to the interrupts with
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue