File: vec4-to-scalar-insert.ll

package info (click to toggle)
intel-graphics-compiler2 2.16.0-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 106,644 kB
  • sloc: cpp: 805,640; lisp: 287,672; ansic: 16,414; python: 3,952; yacc: 2,588; lex: 1,666; pascal: 313; sh: 186; makefile: 35
file content (37 lines) | stat: -rw-r--r-- 1,726 bytes parent folder | download
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
;=========================== begin_copyright_notice ============================
;
; Copyright (C) 2025 Intel Corporation
;
; SPDX-License-Identifier: MIT
;
;============================ end_copyright_notice =============================

; RUN: igc_opt --typed-pointers %s -S --shrink-array-alloca | FileCheck %s
;

define float @f0(i32 %index, float %data0) #1 {
Label-0:
  %alloca = alloca [64 x <4 x float>], align 16
  %addr = getelementptr [64 x <4 x float>], [64 x <4 x float>]* %alloca, i32 0, i32 %index
  %vec0 = load <4 x float>, <4 x float>* %addr
  %data1 = insertelement <4 x float> %vec0, float %data0, i64 2
  store <4 x float> %data1, <4 x float>* %addr, align 16
  %addr1 = getelementptr [64 x <4 x float>], [64 x <4 x float>]* %alloca, i32 0, i32 %index
  %vec1 = load <4 x float>, <4 x float>* %addr1
  %a = extractelement <4 x float> %vec1, i64 2
  ret float %a
}

; CHECK:        [[ALLOCA:%[A-z0-9]*]] = alloca [64 x float], align 4
; CHECK:        [[ADDR:%[A-z0-9]*]] = getelementptr [64 x float], [64 x float]* [[ALLOCA]], i32 0, i32 %index
; CHECK:        [[Z:%[A-z0-9]*]] = load float, float* [[ADDR]], align 4
; CHECK:        [[VEC0:%[A-z0-9]*]] = insertelement <4 x float> undef, float [[Z]], i64 2
; CHECK:        [[VEC1:%[A-z0-9]*]] = insertelement <4 x float> [[VEC0]], float %data0, i64 2
; CHECK:        [[Z:%[A-z0-9]*]] = extractelement <4 x float> [[VEC1]], i64 2
; CHECK-NEXT:   store float [[Z]], float* [[ADDR]], align 4
; CHECK:        [[ADDR:%[A-z0-9]*]] = getelementptr [64 x float], [64 x float]* [[ALLOCA]], i32 0, i32 %index
; CHECK:        [[A:%[A-z0-9]*]] = load float, float* [[ADDR]], align 4
; CHECK:        ret float [[A]]

attributes #1 = { "null-pointer-is-valid"="true" }