
instructions - instead of bitcasting and extract element lets use trunc or trunc and logical shift right to split. - fixes #139020
19 lines
731 B
LLVM
19 lines
731 B
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
|
|
; RUN: opt -S -passes='dxil-legalize' -mtriple=dxil-pc-shadermodel6.3-library %s | FileCheck %s
|
|
|
|
define void @split_via_extract(i64 noundef %a) {
|
|
; CHECK-LABEL: define void @split_via_extract(
|
|
; CHECK-SAME: i64 noundef [[A:%.*]]) {
|
|
; CHECK-NEXT: [[ENTRY:.*:]]
|
|
; CHECK-NEXT: [[TMP0:%.*]] = trunc i64 [[A]] to i32
|
|
; CHECK-NEXT: [[TMP1:%.*]] = lshr i64 [[A]], 32
|
|
; CHECK-NEXT: [[TMP2:%.*]] = trunc i64 [[TMP1]] to i32
|
|
; CHECK-NEXT: ret void
|
|
;
|
|
entry:
|
|
%vecA = bitcast i64 %a to <2 x i32>
|
|
%low = extractelement <2 x i32> %vecA, i32 0 ; low 32 bits
|
|
%high = extractelement <2 x i32> %vecA, i32 1 ; high 32 bits
|
|
ret void
|
|
}
|