From b3bad0ab318d6c60d82142e4b69144935b98e169 Mon Sep 17 00:00:00 2001 From: Nikita Popov Date: Fri, 6 Jan 2023 12:07:06 +0100 Subject: [PATCH] [GlobalSplit] Convert test to opaque pointers (NFC) --- llvm/test/Transforms/GlobalSplit/basic.ll | 56 +++++++++++++++---------------- 1 file changed, 28 insertions(+), 28 deletions(-) diff --git a/llvm/test/Transforms/GlobalSplit/basic.ll b/llvm/test/Transforms/GlobalSplit/basic.ll index 735ddb9..c47bdd6 100644 --- a/llvm/test/Transforms/GlobalSplit/basic.ll +++ b/llvm/test/Transforms/GlobalSplit/basic.ll @@ -3,52 +3,52 @@ target datalayout = "e-p:64:64" target triple = "x86_64-unknown-linux-gnu" -; CHECK: @vtt = constant [3 x i8*] [i8* bitcast ([2 x i8* ()*]* @global.0 to i8*), i8* bitcast (i8* ()** getelementptr inbounds ([2 x i8* ()*], [2 x i8* ()*]* @global.0, i32 0, i32 1) to i8*), i8* bitcast ([1 x i8* ()*]* @global.1 to i8*)] -@vtt = constant [3 x i8*] [ - i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 0, i32 0) to i8*), - i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 0, i32 1) to i8*), - i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 1, i32 0) to i8*) +; CHECK: @vtt = constant [3 x ptr] [ptr @global.0, ptr getelementptr inbounds ([2 x ptr], ptr @global.0, i32 0, i32 1), ptr @global.1] +@vtt = constant [3 x ptr] [ + ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 0, i32 0), + ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 0, i32 1), + ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 1, i32 0) ] ; CHECK-NOT: @global = -; CHECK: @global.0 = private constant [2 x i8* ()*] [i8* ()* @f1, i8* ()* @f2], !type [[T1:![0-9]+]], !type [[T2:![0-9]+]], !type [[T3:![0-9]+]], !vcall_visibility [[VIS:![0-9]+]]{{$}} -; CHECK: @global.1 = private constant [1 x i8* ()*] [i8* ()* @f3], !type [[T4:![0-9]+]], !type [[T5:![0-9]+]], !vcall_visibility [[VIS]]{{$}} +; CHECK: @global.0 = private constant [2 x ptr] [ptr @f1, ptr @f2], !type [[T1:![0-9]+]], !type [[T2:![0-9]+]], !type [[T3:![0-9]+]], !vcall_visibility [[VIS:![0-9]+]]{{$}} +; CHECK: @global.1 = private constant [1 x ptr] [ptr @f3], !type [[T4:![0-9]+]], !type [[T5:![0-9]+]], !vcall_visibility [[VIS]]{{$}} ; CHECK-NOT: @global = -@global = internal constant { [2 x i8* ()*], [1 x i8* ()*] } { - [2 x i8* ()*] [i8* ()* @f1, i8* ()* @f2], - [1 x i8* ()*] [i8* ()* @f3] +@global = internal constant { [2 x ptr], [1 x ptr] } { + [2 x ptr] [ptr @f1, ptr @f2], + [1 x ptr] [ptr @f3] }, !type !0, !type !1, !type !2, !type !3, !type !4, !vcall_visibility !5 -; CHECK: define i8* @f1() -define i8* @f1() { - ; CHECK-NEXT: ret i8* bitcast ([2 x i8* ()*]* @global.0 to i8*) - ret i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 0, i32 0) to i8*) +; CHECK: define ptr @f1() +define ptr @f1() { + ; CHECK-NEXT: ret ptr @global.0 + ret ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 0, i32 0) } -; CHECK: define i8* @f2() -define i8* @f2() { - ; CHECK-NEXT: ret i8* bitcast (i8* ()** getelementptr inbounds ([2 x i8* ()*], [2 x i8* ()*]* @global.0, i32 0, i32 1) to i8*) - ret i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 0, i32 1) to i8*) +; CHECK: define ptr @f2() +define ptr @f2() { + ; CHECK-NEXT: ret ptr getelementptr inbounds ([2 x ptr], ptr @global.0, i32 0, i32 1) + ret ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 0, i32 1) } -; CHECK: define i8* @f3() -define i8* @f3() { - ; CHECK-NEXT: ret i8* bitcast (i8* ()** getelementptr inbounds ([2 x i8* ()*], [2 x i8* ()*]* @global.0, i64 1, i32 0) to i8*) - ret i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 0, i32 2) to i8*) +; CHECK: define ptr @f3() +define ptr @f3() { + ; CHECK-NEXT: ret ptr getelementptr inbounds ([2 x ptr], ptr @global.0, i64 1, i32 0) + ret ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 0, i32 2) } -; CHECK: define i8* @f4() -define i8* @f4() { - ; CHECK-NEXT: ret i8* bitcast ([1 x i8* ()*]* @global.1 to i8*) - ret i8* bitcast (i8* ()** getelementptr ({ [2 x i8* ()*], [1 x i8* ()*] }, { [2 x i8* ()*], [1 x i8* ()*] }* @global, i32 0, inrange i32 1, i32 0) to i8*) +; CHECK: define ptr @f4() +define ptr @f4() { + ; CHECK-NEXT: ret ptr @global.1 + ret ptr getelementptr ({ [2 x ptr], [1 x ptr] }, ptr @global, i32 0, inrange i32 1, i32 0) } define void @foo() { - %p = call i1 @llvm.type.test(i8* null, metadata !"") + %p = call i1 @llvm.type.test(ptr null, metadata !"") ret void } -declare i1 @llvm.type.test(i8*, metadata) nounwind readnone +declare i1 @llvm.type.test(ptr, metadata) nounwind readnone ; CHECK: [[T1]] = !{i32 0, !"foo"} ; CHECK: [[T2]] = !{i32 15, !"bar"} -- 2.7.4