1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
risc-v: 0.884
vnc: 0.812
graphic: 0.732
device: 0.715
architecture: 0.651
network: 0.594
PID: 0.548
files: 0.540
ppc: 0.537
TCG: 0.526
arm: 0.504
register: 0.490
socket: 0.471
debug: 0.436
permissions: 0.428
semantic: 0.412
performance: 0.403
virtual: 0.401
boot: 0.340
VMM: 0.269
kernel: 0.254
user-level: 0.248
peripherals: 0.221
hypervisor: 0.188
assembly: 0.166
mistranslation: 0.152
x86: 0.127
KVM: 0.074
i386: 0.073
Assertion failure when executing RISC-V vfncvt.rtz.x.f.w instruction
Description of problem:
When emulating the `vfncvt.rtz.x.f.w` instruction, QEMU crashes with an assertion failure at `target/riscv/translate.c:211`, complaining that ```decode_save_opc: Assertion `ctx->insn_start != NULL' failed.```
It appears this problem first emerged with https://gitlab.com/qemu-project/qemu/-/commit/a9814e3e08d2aacbd9018c36c77c2fb652537848
Steps to reproduce:
The following C program triggers the assertion failure when built a sufficiently recent version of the Clang cross compiler (in my case 15.0.6):
```
/* test.c */
#include <riscv_vector.h>
#define LEN 4
int main(int argc, char *argv[]) {
double in[LEN];
int out[LEN];
vfloat64m1_t vf = vle64_v_f64m1(in, LEN);
vint32mf2_t vi = vfncvt_rtz_x_f_w_i32mf2(vf, LEN);
vse32_v_i32mf2(out, vi, LEN);
return 0;
}
```
The above `test.c` can be compiled and run as follows:
```
clang -O3 -march=rv64gcv -static test.c
qemu-riscv64 -cpu "rv64,zba=true,zbb=true,zbc=true,zbs=true,v=true,vlen=512,elen=64,vext_spec=v1.0" a.out
qemu-riscv64: ../target/riscv/translate.c:211: decode_save_opc: Assertion `ctx->insn_start != NULL' failed.
Segmentation fault (core dumped)
```
Additional information:
|