mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2024-12-22 21:55:20 +00:00
acpi_tables: aml: Implement Aml::append_aml_bytes() for Method
For now it still relies on Aml::to_aml_bytes() for the children as not all structures have been ported. Signed-off-by: Rob Bradford <robert.bradford@intel.com>
This commit is contained in:
parent
95e63d5f44
commit
1a35d5a017
@ -618,23 +618,20 @@ impl<'a> Method<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> Aml for Method<'a> {
|
impl<'a> Aml for Method<'a> {
|
||||||
fn to_aml_bytes(&self) -> Vec<u8> {
|
fn append_aml_bytes(&self, bytes: &mut Vec<u8>) {
|
||||||
let mut bytes = Vec::new();
|
let mut tmp = Vec::new();
|
||||||
bytes.append(&mut self.path.to_aml_bytes());
|
tmp.append(&mut self.path.to_aml_bytes());
|
||||||
let flags: u8 = (self.args & 0x7) | (self.serialized as u8) << 3;
|
let flags: u8 = (self.args & 0x7) | (self.serialized as u8) << 3;
|
||||||
bytes.push(flags);
|
tmp.push(flags);
|
||||||
for child in &self.children {
|
for child in &self.children {
|
||||||
bytes.append(&mut child.to_aml_bytes());
|
tmp.append(&mut child.to_aml_bytes());
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut pkg_length = create_pkg_length(&bytes, true);
|
let mut pkg_length = create_pkg_length(&tmp, true);
|
||||||
pkg_length.reverse();
|
|
||||||
for byte in pkg_length {
|
|
||||||
bytes.insert(0, byte);
|
|
||||||
}
|
|
||||||
|
|
||||||
bytes.insert(0, 0x14); /* MethodOp */
|
bytes.push(0x14); /* MethodOp */
|
||||||
bytes
|
bytes.append(&mut pkg_length);
|
||||||
|
bytes.append(&mut tmp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user