1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-22 18:54:02 +01:00
llvm-mirror/test/Other/cgscc-disconnected-invalidation.ll
Bjorn Pettersson 8be96b95c4 [NewPM] Consistently use 'simplifycfg' rather than 'simplify-cfg'
There was an alias between 'simplifycfg' and 'simplify-cfg' in the
PassRegistry. That was the original reason for this patch, which
effectively removes the alias.

This patch also replaces all occurrances of 'simplify-cfg'
by 'simplifycfg'. Reason for choosing that form for the name is
that it matches the DEBUG_TYPE for the pass, and the legacy PM name
and also how it is spelled out in other passes such as
'loop-simplifycfg', and in other options such as
'simplifycfg-merge-cond-stores'.

I for some reason the name should be changed to 'simplify-cfg' in
the future, then I think such a renaming should be more widely done
and not only impacting the PassRegistry.

Reviewed By: aeubanks

Differential Revision: https://reviews.llvm.org/D105627
2021-07-09 09:47:03 +02:00

55 lines
1.2 KiB
LLVM

; Test that patterns of transformations which disconnect a region of the call
; graph mid-traversal and then invalidate it function correctly.
;
; RUN: opt -S -passes='cgscc(inline,function(simplifycfg))' < %s | FileCheck %s
define internal void @test_scc_internal(i1 %flag) {
; CHECK-NOT: @test_scc_internal
entry:
br i1 %flag, label %then, label %else
then:
call void @test_scc_internal(i1 false)
call void @test_scc_external()
br label %else
else:
ret void
}
define void @test_scc_external() {
; CHECK-LABEL: define void @test_scc_external()
entry:
call void @test_scc_internal(i1 false)
ret void
}
define internal void @test_refscc_internal(i1 %flag, i8* %ptr) {
; CHECK-NOT: @test_refscc_internal
entry:
br i1 %flag, label %then, label %else
then:
call void @test_refscc_internal(i1 false, i8* bitcast (i8* ()* @test_refscc_external to i8*))
br label %else
else:
ret void
}
define i8* @test_refscc_external() {
; CHECK-LABEL: define i8* @test_refscc_external()
entry:
br i1 true, label %then, label %else
; CHECK-NEXT: entry:
; CHECK-NEXT: ret i8* null
; CHECK-NEXT: }
; CHECK-NOT: @test_refscc_internal
then:
ret i8* null
else:
ret i8* bitcast (void (i1, i8*)* @test_refscc_internal to i8*)
}