summary refs log tree commit diff stats
path: root/results/classifier/118/architecture-arm/1938
diff options
context:
space:
mode:
authorChristian Krinitsin <mail@krinitsin.com>2025-06-16 16:59:00 +0000
committerChristian Krinitsin <mail@krinitsin.com>2025-06-16 16:59:33 +0000
commit9aba81d8eb048db908c94a3c40c25a5fde0caee6 (patch)
treeb765e7fb5e9a3c2143c68b0414e0055adb70e785 /results/classifier/118/architecture-arm/1938
parentb89a938452613061c0f1f23e710281cf5c83cb29 (diff)
downloadqemu-analysis-9aba81d8eb048db908c94a3c40c25a5fde0caee6.tar.gz
qemu-analysis-9aba81d8eb048db908c94a3c40c25a5fde0caee6.zip
add 18th iteration of classifier
Diffstat (limited to 'results/classifier/118/architecture-arm/1938')
-rw-r--r--results/classifier/118/architecture-arm/193896
1 files changed, 96 insertions, 0 deletions
diff --git a/results/classifier/118/architecture-arm/1938 b/results/classifier/118/architecture-arm/1938
new file mode 100644
index 000000000..b5cce8bbd
--- /dev/null
+++ b/results/classifier/118/architecture-arm/1938
@@ -0,0 +1,96 @@
+architecture: 0.970
+arm: 0.948
+graphic: 0.858
+device: 0.845
+peripherals: 0.824
+debug: 0.801
+register: 0.744
+semantic: 0.724
+user-level: 0.678
+performance: 0.651
+mistranslation: 0.592
+ppc: 0.462
+socket: 0.405
+network: 0.368
+files: 0.366
+x86: 0.354
+PID: 0.350
+boot: 0.321
+VMM: 0.302
+risc-v: 0.284
+kernel: 0.257
+assembly: 0.249
+TCG: 0.201
+virtual: 0.188
+vnc: 0.164
+i386: 0.161
+hypervisor: 0.154
+KVM: 0.074
+permissions: 0.048
+--------------------
+arm: 0.905
+kernel: 0.351
+hypervisor: 0.308
+peripherals: 0.300
+debug: 0.281
+architecture: 0.192
+virtual: 0.187
+files: 0.081
+register: 0.077
+device: 0.046
+semantic: 0.040
+VMM: 0.030
+user-level: 0.027
+assembly: 0.023
+TCG: 0.018
+boot: 0.017
+socket: 0.013
+vnc: 0.010
+network: 0.009
+PID: 0.008
+KVM: 0.005
+performance: 0.005
+permissions: 0.004
+graphic: 0.003
+mistranslation: 0.003
+risc-v: 0.003
+ppc: 0.001
+x86: 0.000
+i386: 0.000
+
+[ARM/PL011] Wrong UART register spacing reported in DBG2/SPCR
+Description of problem:
+QEMU reports the UART address on aarch64 (for PL011 UART) via the ACPI DBG2 and SPCR tables using the ACPI GAS structure. According to MSFT documentation at https://learn.microsoft.com/en-us/windows-hardware/drivers/bringup/acpi-debug-port-table:
+
+> * The Register Bit Width field contains the register stride and must be a power of 2 that is at least as large as the access size. On 32-bit platforms this value cannot exceed 32. On 64-bit platforms this value cannot exceed 64.
+> * The Access Size field is used to determine whether byte, WORD, DWORD, or QWORD accesses are to be used. QWORD accesses are only valid on 64-bit architectures.
+
+For the PL011, the MMIO registers are:
+* spaced 4 bytes apart; therefore the reported bit width should be 32 instead of 8.
+* 16 bits wide; therefore the access width should be 2 instead of 1.
+
+In other words:
+```
+diff --git a/hw/arm/virt-acpi-build.c b/hw/arm/virt-acpi-build.c
+index 6b674231c2..cd284676d7 100644
+--- a/hw/arm/virt-acpi-build.c
++++ b/hw/arm/virt-acpi-build.c
+@@ -482,7 +482,7 @@ build_spcr(GArray *table_data, BIOSLinker *linker, VirtMachineState *vms)
+     build_append_int_noprefix(table_data, 3, 1); /* ARM PL011 UART */
+     build_append_int_noprefix(table_data, 0, 3); /* Reserved */
+     /* Base Address */
+-    build_append_gas(table_data, AML_AS_SYSTEM_MEMORY, 8, 0, 1,
++    build_append_gas(table_data, AML_AS_SYSTEM_MEMORY, 32, 0, 2,
+                      vms->memmap[VIRT_UART].base);
+     /* Interrupt Type */
+     build_append_int_noprefix(table_data,
+@@ -673,7 +673,7 @@ build_dbg2(GArray *table_data, BIOSLinker *linker, VirtMachineState *vms)
+     build_append_int_noprefix(table_data, 34, 2);
+ 
+     /* BaseAddressRegister[] */
+-    build_append_gas(table_data, AML_AS_SYSTEM_MEMORY, 8, 0, 1,
++    build_append_gas(table_data, AML_AS_SYSTEM_MEMORY, 32, 0, 2,
+                      vms->memmap[VIRT_UART].base);
+ 
+     /* AddressSize[] */
+```