summary refs log tree commit diff stats
path: root/results/classifier/semantic-bugs/instruction/1062
diff options
context:
space:
mode:
Diffstat (limited to 'results/classifier/semantic-bugs/instruction/1062')
-rw-r--r--results/classifier/semantic-bugs/instruction/106229
1 files changed, 29 insertions, 0 deletions
diff --git a/results/classifier/semantic-bugs/instruction/1062 b/results/classifier/semantic-bugs/instruction/1062
new file mode 100644
index 000000000..67d2da1cb
--- /dev/null
+++ b/results/classifier/semantic-bugs/instruction/1062
@@ -0,0 +1,29 @@
+instruction: 0.925
+graphic: 0.906
+assembly: 0.851
+device: 0.826
+mistranslation: 0.798
+socket: 0.727
+network: 0.651
+semantic: 0.646
+vnc: 0.606
+other: 0.562
+boot: 0.478
+KVM: 0.082
+
+AArch64: SCR_EL3.RW behaves incorrectly for CPUs with no AArch32
+Description of problem:
+In the ARM DDI 0487G.a, D13-3572, the SCR_EL3.RW bit is defined as RAO/WI if both EL2 and EL1 don't support Aarch32. However, the function `scr_write` in `target/arm/helper.c` does not reflect this behavior, even though it checks for Aarch32 EL1 support.
+
+This would break this EL3 code, which should run on cpu reset to attempt to return to EL1:
+```asm
+mov x1, #((1<<0)|(1<<2)|(1<<6)|(1<<7)|(1<<8)|(1<<9)) ; EL1h, DAIF masked
+mov SPSR_EL3, x1
+adr x1, 1f
+msr ELR_EL3, x1
+eret
+1:
+; something something
+```
+Additional information:
+