ACRN Shell Commands¶
The ACRN shell is a text-based terminal for the hypervisor, accessible via the target system’s serial port. It is only available when the hypervisor build type is debug, the serial console port is configured, and a terminal emulator on your development computer is connected, typically via a serial-to-USB cable.
The ACRN shell provides useful debugging commands for displaying internal system states, environment settings, and hypervisor statistics as well as reading and writing CPU model-specific registers (MSR).
A short command history is maintained that lets you use the UP and DOWN keys to browse the command history and HOME, END, LEFT, and RIGHT keys to select an edit point within the command.
Here’s the list of commands supported by the ACRN shell, followed by example uses of these commands:
Command (and parameters) |
Description |
---|---|
help |
Display information about supported hypervisor shell commands. |
version |
Display the hypervisor version information. |
vm_list |
List all VMs, displaying the VM UUID, ID, name, and state (“Started”=running). |
vcpu_list |
List all vCPUs in all VMs. |
vcpu_dumpreg <vm_id> <vcpu_id> |
Dump registers for a specific vCPU. |
dump_host_mem <hva> <length> |
Dump the host memory region as specified by the start of the region |
dump_guest_mem <vm_id> <gva> <length> |
Dump a User VM (guest) memory region based on the VM ID ( |
vm_console <vm_id> |
Switch to the VM’s console. Use Ctrl + Alt + Space to return to the ACRN shell console. |
int |
List interrupt information per CPU. |
pt |
Show passthrough device information. |
vioapic <vm_id> |
Show virtual IOAPIC (vIOAPIC) information for a specific VM. |
dump_ioapic |
Show native IOAPIC information. |
loglevel <console_loglevel> <mem_loglevel> <npk_loglevel> |
|
cpuid <leaf> [subleaf] |
Display the CPUID leaf [subleaf], in hexadecimal. |
rdmsr [-p<pcpu_id>] <msr_index> |
Read the model-specific register (MSR) at index |
wrmsr [-p<pcpu_id>] <msr_index> <value> |
Write |
Command Examples¶
The following sections provide further details and examples for some of these commands.
vm_list¶
The vm_list
command provides the name of each virtual machine and its corresponding ID and
state.
data:image/s3,"s3://crabby-images/dfdf2/dfdf2f5565961367b7c3aeeb525ae43a6a5b899e" alt="../_images/shell_image8.png"
Figure 56 vm_list information¶
vcpu_list¶
The vcpu_list
command provides information about virtual CPUs (vCPU), including
the VM ID, pCPU ID, vCPU ID, vCPU role (primary or secondary), and vCPU
state (init, paused, running, zombie, or unknown).
data:image/s3,"s3://crabby-images/03d07/03d072ac3c5cf6543f0acc4da0a2b19cec4a4c21" alt="../_images/shell_image7.png"
Figure 57 vcpu_list information¶
vcpu_dumpreg¶
The vcpu_dumpreg <vm_id> <vcpu_id>
command provides vCPU-related
information such as register values.
In the following example, we dump the vCPU0 RIP register value and get into the Service VM to search for the running function, using these commands:
cat /proc/kallsyms | grep RIP_value
As you can see, vCPU0 is running in
function acpi_idle_do_entry
.
data:image/s3,"s3://crabby-images/22c26/22c26bd0da7530d7c257970c09ac490afd2e7e3e" alt="../_images/shell_image10.png"
Figure 58 vcpu_dumpreg information¶
data:image/s3,"s3://crabby-images/a7c2e/a7c2e60cf646e0a1d91d14e302e4e956cd5f8c6b" alt="../_images/shell_image9.png"
Figure 59 system map information¶
dump_host_mem¶
The dump_host_mem <hva> <length>
command provides the specified memory
target data such as the physical CPU (pCPU) number.
In this example, we know the pCPU active bitmap and physical CPU number
physical memory address through
build/hypervisor/acrn.map
. (Note that the path for
acrn.map
depends on how we build the hypervisor.)
Then we can dump the memory address of the pCPU active bitmap and CPU number. The pCPU active bitmap is 0x000000000000000f and pCPU number is 0x0000000000000004.
data:image/s3,"s3://crabby-images/c1258/c12580bd69499714da51a15b11d5b02844552a22" alt="../_images/shell_image12.png"
Figure 60 dumpmem information¶
data:image/s3,"s3://crabby-images/7f9ea/7f9ea75cd8a4c662fb0c21c6310bb0c962fbd9c1" alt="../_images/shell_image11.png"
Figure 61 acrn map information¶
dump_guest_mem¶
The dump_guest_mem <vm_id> <gva> <length>
command dumps guest memory
information according to the given VM ID and guest virtual address (gva
).
In this example, we know the starting address of the kernel text segment
in the guest console or through the system.map
. (Note that the path for
system.map
depends on how we build the kernel.)
data:image/s3,"s3://crabby-images/7f4ee/7f4eec6dfeb3c0f5b24d64ebf69b5f5a4deb1490" alt="../_images/shell_image19.png"
Figure 62 guest virtual address¶
data:image/s3,"s3://crabby-images/dee88/dee88848e330614ac42f80999a4aa94a1a440ec7" alt="../_images/shell_image20.png"
Figure 63 guest memory information¶
vm_console¶
The vm_console <vm_id>
command switches the ACRN’s console to become the
VM’s console.
Send a BREAK character to enter escaping mode and a character e to return to
the ACRN shell console. For details on how the hypervisor console works,
refer to Hypervisor Console.
vioapic¶
The vioapic <vm_id>
command shows the virtual IOAPIC information for a specific
VM. In the following figure, we show the virtual IOAPIC information for
VM1:
data:image/s3,"s3://crabby-images/af6f5/af6f584f540f7274c4a3e16b3a4293bee1d6d836" alt="../_images/shell_image6.png"
Figure 64 vioapic information¶
dump_ioapic¶
The dump_ioapic
command provides IOAPIC information and we can get IRQ number,
IRQ vector number, etc.
data:image/s3,"s3://crabby-images/17941/17941266e333dd17f4ba6cb8734414fcf46ed6ef" alt="../_images/shell_image14.png"
Figure 65 dump_ioapic information¶
pt¶
The pt
command provides passthrough detailed information, such as the
virtual machine number, interrupt type, interrupt request, interrupt vector,
and trigger mode.
data:image/s3,"s3://crabby-images/e774b/e774bc2926d78b276de6bfcbdc103f952bbd6ec0" alt="../_images/shell_image13.png"
Figure 66 pt information¶
int¶
The int
command provides interrupt information on all CPUs and their
corresponding interrupt vector.
data:image/s3,"s3://crabby-images/f3694/f36942532be9bf39a9936a7e4be187afea743a0f" alt="../_images/shell_image17.png"
Figure 67 int information¶
cpuid¶
The cpuid <leaf> [subleaf]
command provides the CPUID leaf [subleaf] in
hexadecimal.
data:image/s3,"s3://crabby-images/05018/05018c3faee8c79607e420bce0963d1310d4a087" alt="../_images/shell_image15.png"
Figure 68 cpuid information¶
rdmsr¶
We can read a model-specific register (MSR) to get register
values through rdmsr [-p<pcpu_id>] <msr_index>
.
In the following example, we can get the IA32_APIC_BASE value of pCPU 0 through the command:
rdmsr -p0 1b
and see that 1B (Hexadecimal) is the IA32_APIC_BASE MSR address.
data:image/s3,"s3://crabby-images/b8c58/b8c5860874f2c8cef0b9060ed4edde7b1ec0c117" alt="../_images/shell_image16.png"
Figure 69 IA32_APIC_BASE register information¶
data:image/s3,"s3://crabby-images/d8f56/d8f569d9f65824c998fb58acbbeb1c8df958a655" alt="../_images/shell_image18.png"
Figure 70 rdmsr information¶
wrmsr¶
We can write to a model-specific register (MSR) to set register
values through wrmsr [-p<pcpu_id>] <msr_index> <value>
.
In the following example, we can set the IA32_APIC_BASE value of pCPU 1 through the command:
wrmsr -p1 1b 0xfee00c00