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 47 48 49 50 51 52 53 54 55 56 57 58 59 60
|
;=========================== begin_copyright_notice ============================
;
; Copyright (C) 2017-2021 Intel Corporation
;
; SPDX-License-Identifier: MIT
;
;============================ end_copyright_notice =============================
; RUN: igc_opt -igc-replace-unsupported-intrinsics -verify -S %s -o %t
; RUN: FileCheck %s < %t
target triple = "igil_32_GEN8"
define void @A(i8 addrspace(1)* %B, i32 %S, <8 x i32> %r0, <8 x i32> %payloadHeader) #0 {
entry:
; CHECK-LABEL: define void @A
; CHECK: %pIV = alloca i32
; CHECK: %0 = icmp ugt i32 %S, 1
; CHECK: %umax = select i1 %0, i32 %S, i32 1
; CHECK: store i32 0, i32* %pIV
; CHECK: [[CMP0:%[a-zA-Z0-9]+]] = icmp ult i32 0, %umax
; CHECK: br i1 [[CMP0]], label %memset.body, label %memset.post
; CHECK: memset.body:
; CHECK: %IV = load i32, i32* %pIV
; CHECK: [[GEP0:%[a-zA-Z0-9]+]] = getelementptr i8, i8 addrspace(1)* %B, i32 %IV
; CHECK: store i8 42, i8 addrspace(1)* [[GEP0]], align 1
; CHECK: [[INC0:%[a-zA-Z0-9]+]] = add i32 %IV, 1
; CHECK: store i32 [[INC0]], i32* %pIV
; CHECK: [[CMP1:%[a-zA-Z0-9]+]] = icmp ult i32 [[INC0]], %umax
; CHECK: br i1 [[CMP1]], label %memset.body, label %memset.post
; CHECK: memset.post:
; CHECK: ret
%0 = icmp ugt i32 %S, 1
%umax = select i1 %0, i32 %S, i32 1
call void @llvm.memset.p1i8.i32(i8 addrspace(1)* %B, i8 42, i32 %umax, i32 1, i1 false)
ret void
}
define void @B(i8 addrspace(1)* %B, i32 %S, <8 x i32> %r0, <8 x i32> %payloadHeader) #0 {
entry:
; CHECK-LABEL: define void @B
; CHECK-NOT: call
; CHECK: ret
call void @llvm.memset.p1i8.i32(i8 addrspace(1)* %B, i8 42, i32 %S, i32 1, i1 false)
ret void
}
define void @C(i8 addrspace(1)* %B, <8 x i32> %r0, <8 x i32> %payloadHeader) #0 {
entry:
; CHECK-LABEL: define void @C
; CHECK-NOT: call
; CHECK: ret
call void @llvm.memset.p1i8.i32(i8 addrspace(1)* %B, i8 42, i32 1, i32 1, i1 false)
ret void
}
declare void @llvm.memset.p1i8.i32(i8 addrspace(1)* nocapture, i8, i32, i32, i1) #1
attributes #0 = { alwaysinline nounwind }
attributes #1 = { nounwind }
|