forked from OSchip/llvm-project
28 lines
1.3 KiB
LLVM
28 lines
1.3 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
|
; RUN: opt < %s -instcombine -S -verify | FileCheck %s
|
|
|
|
define <2 x i8> @constprop_load_bitcast(<vscale x 16 x i1>* %ptr) {
|
|
; CHECK-LABEL: @constprop_load_bitcast(
|
|
; CHECK-NEXT: store <vscale x 16 x i1> zeroinitializer, <vscale x 16 x i1>* [[PTR:%.*]], align 16
|
|
; CHECK-NEXT: ret <2 x i8> zeroinitializer
|
|
;
|
|
store <vscale x 16 x i1> zeroinitializer, <vscale x 16 x i1>* %ptr, align 16
|
|
%cast_to_fixed = bitcast <vscale x 16 x i1>* %ptr to <2 x i8>*
|
|
%a = load <2 x i8>, <2 x i8>* %cast_to_fixed, align 16
|
|
ret <2 x i8> %a
|
|
}
|
|
|
|
; vscale-sized vec not guaranteed to fill destination.
|
|
define <8 x i8> @constprop_load_bitcast_neg(<vscale x 16 x i1>* %ptr) {
|
|
; CHECK-LABEL: @constprop_load_bitcast_neg(
|
|
; CHECK-NEXT: store <vscale x 16 x i1> zeroinitializer, <vscale x 16 x i1>* [[PTR:%.*]], align 16
|
|
; CHECK-NEXT: [[CAST_TO_FIXED:%.*]] = bitcast <vscale x 16 x i1>* [[PTR]] to <8 x i8>*
|
|
; CHECK-NEXT: [[A:%.*]] = load <8 x i8>, <8 x i8>* [[CAST_TO_FIXED]], align 16
|
|
; CHECK-NEXT: ret <8 x i8> [[A]]
|
|
;
|
|
store <vscale x 16 x i1> zeroinitializer, <vscale x 16 x i1>* %ptr, align 16
|
|
%cast_to_fixed = bitcast <vscale x 16 x i1>* %ptr to <8 x i8>*
|
|
%a = load <8 x i8>, <8 x i8>* %cast_to_fixed, align 16
|
|
ret <8 x i8> %a
|
|
}
|