; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py ; RUN: llc -mtriple=riscv64 -mattr=+m,+experimental-v -O2 < %s \ ; RUN: | FileCheck %s -check-prefix=RV64IV define @access_fixed_object(i64 *%val) { ; RV64IV-LABEL: access_fixed_object: ; RV64IV: # %bb.0: ; RV64IV-NEXT: addi sp, sp, -528 ; RV64IV-NEXT: .cfi_def_cfa_offset 528 ; RV64IV-NEXT: addi a1, sp, 8 ; RV64IV-NEXT: vl1re64.v v8, (a1) ; RV64IV-NEXT: ld a1, 520(sp) ; RV64IV-NEXT: sd a1, 0(a0) ; RV64IV-NEXT: addi sp, sp, 528 ; RV64IV-NEXT: ret %local = alloca i64 %array = alloca [64 x i64] %vptr = bitcast [64 x i64]* %array to * %v = load , * %vptr %len = load i64, i64* %local store i64 %len, i64* %val ret %v } declare @llvm.riscv.vadd.nxv1i64.nxv1i64( , , i64); define @access_fixed_and_vector_objects(i64 *%val) { ; RV64IV-LABEL: access_fixed_and_vector_objects: ; RV64IV: # %bb.0: ; RV64IV-NEXT: addi sp, sp, -544 ; RV64IV-NEXT: .cfi_def_cfa_offset 544 ; RV64IV-NEXT: csrr a0, vlenb ; RV64IV-NEXT: sub sp, sp, a0 ; RV64IV-NEXT: addi a0, sp, 24 ; RV64IV-NEXT: vl1re64.v v25, (a0) ; RV64IV-NEXT: ld a0, 536(sp) ; RV64IV-NEXT: addi a1, sp, 544 ; RV64IV-NEXT: vl1re64.v v26, (a1) ; RV64IV-NEXT: vsetvli zero, a0, e64, m1, ta, mu ; RV64IV-NEXT: vadd.vv v8, v25, v26 ; RV64IV-NEXT: csrr a0, vlenb ; RV64IV-NEXT: add sp, sp, a0 ; RV64IV-NEXT: addi sp, sp, 544 ; RV64IV-NEXT: ret %local = alloca i64 %vector = alloca %array = alloca [64 x i64] %vptr = bitcast [64 x i64]* %array to * %v1 = load , * %vptr %v2 = load , * %vector %len = load i64, i64* %local %a = call @llvm.riscv.vadd.nxv1i64.nxv1i64( %v1, %v2, i64 %len) ret %a }