File: unaligned-vec-store.ll

package info (click to toggle)
llvm-toolchain-21 1%3A21.1.6-2
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 2,245,044 kB
  • sloc: cpp: 7,619,726; ansic: 1,434,018; asm: 1,058,748; python: 252,740; f90: 94,671; objc: 70,685; lisp: 42,813; pascal: 18,401; sh: 8,601; ml: 5,111; perl: 4,720; makefile: 3,666; awk: 3,523; javascript: 2,409; xml: 892; fortran: 770
file content (23 lines) | stat: -rw-r--r-- 870 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
; RUN: llc -march=hexagon -mcpu=hexagonv68 -mattr=+hvxv68,+hvx-length128B < %s | FileCheck %s
; REQUIRES: asserts

; Check that the test does not assert when unaligned vector store V6_vS32Ub_npred_ai is generated.
; CHECK: if (!p{{[0-3]}}) vmemu

target triple = "hexagon-unknown-unknown-elf"

define fastcc void @test(i1 %cmp.i.i) {
entry:
  %call.i.i.i172 = load ptr, ptr null, align 4
  %add.ptr = getelementptr i8, ptr %call.i.i.i172, i32 1
  store <32 x i32> zeroinitializer, ptr %add.ptr, align 128
  %add.ptr4.i4 = getelementptr i8, ptr %call.i.i.i172, i32 129
  br i1 %cmp.i.i, label %common.ret, label %if.end.i.i

common.ret:                                       ; preds = %if.end.i.i, %entry
  ret void

if.end.i.i:                                       ; preds = %entry
  store <32 x i32> zeroinitializer, ptr %add.ptr4.i4, align 1
  br label %common.ret
}