mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-04-01 20:04:37 +00:00
Revert "vmm: Move MemoryManager from I/O ports to MMIO region"
This reverts commit 03108fb88b0ae1afd9b6b0f65f92e4b424c89c3e.
This commit is contained in:
parent
57ed006992
commit
a34893a402
@ -523,15 +523,16 @@ impl DeviceManager {
|
||||
#[cfg(feature = "acpi")]
|
||||
let memory_manager_clone = memory_manager.clone();
|
||||
|
||||
let memory_manager_device_base = memory_manager.lock().unwrap().device_base();
|
||||
address_manager
|
||||
.allocator
|
||||
.lock()
|
||||
.unwrap()
|
||||
.allocate_io_addresses(Some(GuestAddress(0x0a00)), 0x18, None)
|
||||
.ok_or(DeviceManagerError::AllocateIOPort)?;
|
||||
|
||||
address_manager
|
||||
.mmio_bus
|
||||
.insert(
|
||||
memory_manager,
|
||||
memory_manager_device_base.0,
|
||||
MemoryManager::DEVICE_SIZE,
|
||||
)
|
||||
.io_bus
|
||||
.insert(memory_manager, 0xa00, 0x18)
|
||||
.map_err(DeviceManagerError::BusError)?;
|
||||
|
||||
Ok(DeviceManager {
|
||||
|
@ -48,7 +48,6 @@ pub struct MemoryManager {
|
||||
allocator: Arc<Mutex<SystemAllocator>>,
|
||||
current_ram: u64,
|
||||
next_hotplug_slot: usize,
|
||||
device_base: GuestAddress,
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
@ -190,8 +189,6 @@ impl BusDevice for MemoryManager {
|
||||
}
|
||||
|
||||
impl MemoryManager {
|
||||
pub const DEVICE_SIZE: u64 = 0x18;
|
||||
|
||||
pub fn new(
|
||||
allocator: Arc<Mutex<SystemAllocator>>,
|
||||
fd: Arc<VmFd>,
|
||||
@ -238,13 +235,6 @@ impl MemoryManager {
|
||||
let mut hotplug_slots = Vec::with_capacity(HOTPLUG_COUNT);
|
||||
hotplug_slots.resize_with(HOTPLUG_COUNT, HotPlugState::default);
|
||||
|
||||
// Allocate some MMIO space for the device to be acessible from
|
||||
let device_base = allocator
|
||||
.lock()
|
||||
.unwrap()
|
||||
.allocate_mmio_addresses(None, MemoryManager::DEVICE_SIZE, None)
|
||||
.ok_or(Error::MemoryRangeAllocation)?;
|
||||
|
||||
let memory_manager = Arc::new(Mutex::new(MemoryManager {
|
||||
guest_memory: guest_memory.clone(),
|
||||
next_kvm_memory_slot: 0,
|
||||
@ -259,7 +249,6 @@ impl MemoryManager {
|
||||
allocator: allocator.clone(),
|
||||
current_ram: boot_ram,
|
||||
next_hotplug_slot: 0,
|
||||
device_base,
|
||||
}));
|
||||
|
||||
guest_memory.load().with_regions(|_, region| {
|
||||
@ -369,7 +358,7 @@ impl MemoryManager {
|
||||
.allocate_mmio_addresses(Some(start_addr), size as GuestUsize, None)
|
||||
.ok_or(Error::MemoryRangeAllocation)?;
|
||||
|
||||
// Update the slot so that it can be queried via the MMIO region
|
||||
// Update the slot so that it can be queried via the I/O port
|
||||
let mut slot = &mut self.hotplug_slots[self.next_hotplug_slot];
|
||||
slot.active = true;
|
||||
slot.inserting = true;
|
||||
@ -471,10 +460,6 @@ impl MemoryManager {
|
||||
Ok(false)
|
||||
}
|
||||
}
|
||||
|
||||
pub fn device_base(&self) -> GuestAddress {
|
||||
self.device_base
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(feature = "acpi")]
|
||||
@ -606,7 +591,7 @@ impl Aml for MemoryMethods {
|
||||
&aml::While::new(
|
||||
&aml::LessThan::new(&aml::Local(0), &self.slots),
|
||||
vec![
|
||||
// Write slot number (in first argument) to MMIO region via field
|
||||
// Write slot number (in first argument) to I/O port via field
|
||||
&aml::Store::new(&aml::Path::new("\\_SB_.MHPC.MSEL"), &aml::Local(0)),
|
||||
// Check if MINS bit is set (inserting)
|
||||
&aml::If::new(
|
||||
@ -659,7 +644,7 @@ impl Aml for MemoryMethods {
|
||||
vec![
|
||||
// Take lock defined above
|
||||
&aml::Acquire::new("MLCK".into(), 0xfff),
|
||||
// Write slot number (in first argument) to MMIO region via field
|
||||
// Write slot number (in first argument) to I/O port via field
|
||||
&aml::Store::new(&aml::Path::new("\\_SB_.MHPC.MSEL"), &aml::Arg(0)),
|
||||
&aml::Store::new(&aml::Local(0), &aml::ZERO),
|
||||
// Check if MEN_ bit is set, if so make the local variable 0xf (see _STA for details of meaning)
|
||||
@ -685,7 +670,7 @@ impl Aml for MemoryMethods {
|
||||
vec![
|
||||
// Take lock defined above
|
||||
&aml::Acquire::new("MLCK".into(), 0xfff),
|
||||
// Write slot number (in first argument) to MMIO region via field
|
||||
// Write slot number (in first argument) to I/O port via field
|
||||
&aml::Store::new(&aml::Path::new("\\_SB_.MHPC.MSEL"), &aml::Arg(0)),
|
||||
&aml::Name::new(
|
||||
"MR64".into(),
|
||||
@ -748,20 +733,12 @@ impl Aml for MemoryManager {
|
||||
// I/O port for memory controller
|
||||
&aml::Name::new(
|
||||
"_CRS".into(),
|
||||
&aml::ResourceTemplate::new(vec![&aml::AddressSpace::new_memory(
|
||||
aml::AddressSpaceCachable::NotCacheable,
|
||||
true,
|
||||
self.device_base.0,
|
||||
self.device_base.0 + MemoryManager::DEVICE_SIZE - 1,
|
||||
&aml::ResourceTemplate::new(vec![&aml::IO::new(
|
||||
0x0a00, 0x0a00, 0x01, 0x18,
|
||||
)]),
|
||||
),
|
||||
// OpRegion and Fields map MMIO data into individual field values
|
||||
&aml::OpRegion::new(
|
||||
"MHPR".into(),
|
||||
aml::OpRegionSpace::SystemMemory,
|
||||
self.device_base.0 as usize,
|
||||
MemoryManager::DEVICE_SIZE as usize,
|
||||
),
|
||||
// OpRegion and Fields map I/O port into individual field values
|
||||
&aml::OpRegion::new("MHPR".into(), aml::OpRegionSpace::SystemIO, 0xa00, 0x18),
|
||||
&aml::Field::new(
|
||||
"MHPR".into(),
|
||||
aml::FieldAccessType::DWord,
|
||||
|
Loading…
x
Reference in New Issue
Block a user