1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
|
; 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
}
|