File: basic.ll

package info (click to toggle)
intel-graphics-compiler 1.0.17791.18-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 102,312 kB
  • sloc: cpp: 935,343; lisp: 286,143; ansic: 16,196; python: 3,279; yacc: 2,487; lex: 1,642; pascal: 300; sh: 174; makefile: 27
file content (46 lines) | stat: -rw-r--r-- 1,981 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
38
39
40
41
42
43
44
45
46
;=========================== begin_copyright_notice ============================
;
; Copyright (C) 2022 Intel Corporation
;
; SPDX-License-Identifier: MIT
;
;============================ end_copyright_notice =============================
;
; RUN: igc_opt -enable-debugify --igc-scalarizer-in-codegen -S < %s 2>&1 | FileCheck %s
; ------------------------------------------------
; ScalarizerCodeGen
; ------------------------------------------------

; Debug-info related check
;
; CHECK-NOT: WARNING
; CHECK: CheckModuleDebugify: PASS

define void @test_scalarcg(<4 x i8> %src1, <3 x i32> %src2) {
; CHECK-LABEL: @test_scalarcg(
; CHECK:    [[TMP1:%.*]] = alloca <4 x i8>, align 1
; CHECK:    [[TMP2:%.*]] = alloca <3 x i32>, align 4
; CHECK:    [[TMP3:%.*]] = bitcast <4 x i8> [[SRC1:%.*]] to i32
; CHECK:    [[TMP4:%.*]] = and i32 bitcast (<4 x i8> <i8 1, i8 2, i8 3, i8 4> to i32), [[TMP3]]
; CHECK:    [[TMP5:%.*]] = bitcast i32 [[TMP4]] to <4 x i8>
; CHECK:    [[TMP6:%.*]] = extractelement <3 x i32> [[SRC2:%.*]], i32 0
; CHECK:    [[TMP7:%.*]] = or i32 13, [[TMP6]]
; CHECK:    [[TMP8:%.*]] = insertelement <3 x i32> undef, i32 [[TMP7]], i32 0
; CHECK:    [[TMP9:%.*]] = extractelement <3 x i32> [[SRC2]], i32 1
; CHECK:    [[TMP10:%.*]] = or i32 42, [[TMP9]]
; CHECK:    [[TMP11:%.*]] = insertelement <3 x i32> [[TMP8]], i32 [[TMP10]], i32 1
; CHECK:    [[TMP12:%.*]] = extractelement <3 x i32> [[SRC2]], i32 2
; CHECK:    [[TMP13:%.*]] = or i32 17, [[TMP12]]
; CHECK:    [[TMP14:%.*]] = insertelement <3 x i32> [[TMP11]], i32 [[TMP13]], i32 2
; CHECK:    store <4 x i8> [[TMP5]], <4 x i8>* [[TMP1]], align 4
; CHECK:    store <3 x i32> [[TMP14]], <3 x i32>* [[TMP2]], align 16
; CHECK:    ret void
;
  %1 = alloca <4 x i8>, align 1
  %2 = alloca <3 x i32>, align 4
  %3 = and <4 x i8> <i8 1, i8 2, i8 3, i8 4>, %src1
  %4 = or <3 x i32> <i32 13, i32 42, i32 17>, %src2
  store <4 x i8> %3, <4 x i8>* %1, align 4
  store <3 x i32> %4, <3 x i32>* %2, align 16
  ret void
}