1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-26 12:43:36 +01:00
llvm-mirror/test/Transforms/SCCP/apint-ipsccp3.ll
Florian Hahn 61a834b1e0 Recommit "[SCCP] Remove forcedconstant, go to overdefined instead"
This includes a fix for cases where things get marked as overdefined in
ResolvedUndefsIn, but we later discover a constant. To avoid crashing,
we consistently bail out on overdefined values in the visitors. This is
similar to the previous behavior with forcedconstant.

This reverts the revert commit 02b72f564c8be0b4f4337d5c4a3fcf7e8018a818.
2020-02-15 18:36:44 +01:00

40 lines
910 B
LLVM

; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -ipsccp -S | FileCheck %s
@G = internal global i66 undef
define void @foo() {
; CHECK-LABEL: @foo(
; CHECK-NEXT: [[X:%.*]] = load i66, i66* @G
; CHECK-NEXT: store i66 [[X]], i66* @G
; CHECK-NEXT: ret void
;
%X = load i66, i66* @G
store i66 %X, i66* @G
ret void
}
define i66 @bar() {
; CHECK-LABEL: @bar(
; CHECK-NEXT: [[V:%.*]] = load i66, i66* @G
; CHECK-NEXT: [[C:%.*]] = icmp eq i66 [[V]], 17
; CHECK-NEXT: br i1 [[C]], label [[T:%.*]], label [[F:%.*]]
; CHECK: T:
; CHECK-NEXT: store i66 17, i66* @G
; CHECK-NEXT: ret i66 17
; CHECK: F:
; CHECK-NEXT: store i66 123, i66* @G
; CHECK-NEXT: ret i66 0
;
%V = load i66, i66* @G
%C = icmp eq i66 %V, 17
br i1 %C, label %T, label %F
T:
store i66 17, i66* @G
ret i66 %V
F:
store i66 123, i66* @G
ret i66 0
}