<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/62709>62709</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            Compiling a C program using Clang for the RISC-V architecture and simulating it using Spike causes a segmentation fault
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            new issue
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          eric900115
      </td>
    </tr>
</table>

<pre>
    I compiled a C program with a vectorized loop using Clang for the RISC-V architecture and simulated it using Spike. However, this resulted in a segmentation fault.

The failing case (test.c):
```c
#include <stdio.h>
#include <time.h>
#include <riscv_vector.h>
#include <string.h>

int main(){
    float a __attribute__((__vector_size__(4)));
    float b __attribute__((__vector_size__(4)));
    float c __attribute__((__vector_size__(4)));

    _Pragma("clang loop vectorize(enable)")
    for(int i = 0; i < 4; i++){
        c[i] = a[i] * b[i]; 
    }
    
    for(int j = 0; j < 4; j++){
 printf("%f\n", c[j]);
    }
}
```
The compile command was : ```/mnt/c/llvm-project/install/bin/clang-17  --target=riscv64-unknown-elf --sysroot=/opt/riscv/riscv64-unknown-elf --gcc-toolchain=/opt/riscv -march=rv64gcv1_zfh_zvfh0p1 -menable-experimental-extensions -mrvv-vector-bits=128 -O1 -v -g test.c -o test.elf```

Simulating using spike : ```/opt/riscv/bin/spike /opt/riscv/riscv64-unknown-elf/bin/pk test.elf```

The result of simulation : 
```
bbl loader
0.000000
0.000000
0.000000
0.000000
z  0000000000000000 ra 0000000000000000 sp 0000003ffffffb50 gp 000000000001f110
tp 0000000000000000 t0 00000000000102dc t1 0000000000000000 t2 0000000000000000
s0 0000000000000000 s1 0000000000000000 a0 0000000000000000 a1 000000000001f920
a2 0000000000000009 a3 0000000000000009 a4 0000000000000001 a5 0000000000000000
a6 0000000000000000 a7 0000000000000040 s2 0000000000000000 s3 0000000000000000
s4 0000000000000000 s5 0000000000000000 s6 0000000000000000 s7 0000000000000000
s8 0000000000000000 s9 0000000000000000 sA 0000000000000000 sB 0000000000000000
t3 ffffffffffffffff t4 0000003ffffff580 t5 000000000001d000 t6 0000000000000000
pc 0000000000000000 va/inst 0000000000000000 sr 8000000200006620
User fetch segfault @ 0x0000000000000000
make: *** [Makefile:32: run] Error 255
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJysVtGOqzYTfhrnZkRkDCRwkYtNcqL_XPxq1W17GxlnAO8ajGyT3bNPX9lkN5vAVu1RLWTs8cw3n80wHm6trDvEDcm2JNsv-OAabTZopCgojeNsUerTj813ELrtpcITcNhBb3RteAsv0jXA4YzCaSPf8ARK6x4GK7sadop3NVTagGsQfvv-uIv-BG5EIx0KNxgE3p3AynZQ3OEJpLsYPvbyGZfwP_2CZzSE7cA10oJBO6ig2AEHi3WLneNO6g4qPii3JHRP6MPY_94gVFwqjye4RSAsd2jdUhBWkOSiRVZ0fMRlzhLZCTWcEEiys-4k9bIhybe5VSdb_HLRSCvOx_FcvlSyzsiu_rwcetk5aLnsCMs91_V2FAMAVEpzBxyOR-6ckeXg8HgMevnx4u1o5dsoTL31-CQTjPI_wBA_jXFFOv5qeN3yYMtEiJgQQh8hRViOHS8VBgjm-ysNbQjL_XlJIMkeKEm2YbiDNAwJ24bn9hR9EyTbSpLtgx3_mLAHKC8TD3C1Iev9p8kMg6crg6crg6cZBr2RnavGHROWVSTbdWG4C6yevO-78_7wfh28R-413C9_qH-3_s964RZI8gBXVXZoO0fYQRB2UOrcRr3RTyi8SHbWcaUIO5Q-8g7hU0TxGiCKHDc1OpLsQ1Sv0mjonjv90kWoKogi-8Marf06YQfde7Sg-P6eGNRCRE5rJRof5fdmELU-SXh351Vai3N8fKua49u5amgfQ9SO4RDha49GhhygInx12FmpOwtRa87naIyfqJTOkmQfsxyiX2KIzhDVMOYBiPQ4QlXdnebYP46ZyWeQMS9Zn5cmR3q74_H0Lpr_4Dg-TPrnv2fjv_CYAUFX71nT577AZy4mylKB0vyEZpzTJQ3t387eAOhdA8OnMttfZEkVWplRqPvPenEVxxdQ108BHL1RpuwkwMUzemwiG0EtnWE1A8Bn9Hh8y7RgF1A-8VYAT2Zk6b0sBp59wZSvZhis72QpBTvdKtiJ8_ftTxhQsFMGYGec23vnH6D5jHIxI3uYkW2_AHUJVHcNXHobPllOwd2wj0_h60_Zj6C9mDI480tumyFnIB-HzHer1fsH_8OigQqdaHyREUoLICkF-jrvt-XPGH5C9jA-QLLt__kzVlL5hYT5VTN0_ob5Zow2wLLs7pddnDbJqUgKvsBNvMrTmCXxmi6aTboWVUkTxIqWVYosrtYZVjmLkyKnsaALuWGUJTSLM5pkRUKXWJQir3hSFVXBkiwjKcWWS7X0KX-pTb2Q1g64WbE1LRaKl6hsKP8Y6_AFwqK_j7L9wmzCNVEOtSUpVdI6e0Vx0inc7MKt49Pj58LwJypAb3BbAoLgg0U7W-wtBqM2jXO99cUcOxB2qKVrhnIpdHu53mZuOb83S9gh7P2vAAAA___EjALU">