[PATCH] D121433: [MTE] Add test that stack tagging does not mess up stack coloring.
Florian Mayer via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Mar 14 13:36:46 PDT 2022
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rG628c537b3203: [MTE] Add test that stack tagging does not mess up stack coloring. (authored by fmayer).
Changed prior to commit:
https://reviews.llvm.org/D121433?vs=414544&id=415203#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D121433/new/
https://reviews.llvm.org/D121433
Files:
llvm/test/CodeGen/AArch64/stack-tagging-stack-coloring.ll
Index: llvm/test/CodeGen/AArch64/stack-tagging-stack-coloring.ll
===================================================================
--- /dev/null
+++ llvm/test/CodeGen/AArch64/stack-tagging-stack-coloring.ll
@@ -0,0 +1,41 @@
+; Test that storage for allocas with disjoint lifetimes is reused with stack
+; tagging.
+
+; RUN: opt -S -aarch64-stack-tagging %s -o - | \
+; RUN: llc -no-stack-coloring=false -o - | \
+; RUN: FileCheck %s --check-prefix=COLOR
+; RUN: opt -S -aarch64-stack-tagging %s -o - | \
+; RUN: llc -no-stack-coloring=true -o - | \
+; RUN: FileCheck %s --check-prefix=NOCOLOR
+
+target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
+target triple = "aarch64-unknown-linux-android29"
+
+; COLOR: sub sp, sp, #192
+; NOCOLOR: sub sp, sp, #320
+
+define i32 @myCall_w2(i32 %in) sanitize_hwaddress {
+entry:
+ %a = alloca [17 x i8*], align 8
+ %a2 = alloca [16 x i8*], align 8
+ %b = bitcast [17 x i8*]* %a to i8*
+ %b2 = bitcast [16 x i8*]* %a2 to i8*
+ call void @llvm.lifetime.start.p0i8(i64 136, i8* %b)
+ %t1 = call i32 @foo(i32 %in, i8* %b)
+ %t2 = call i32 @foo(i32 %in, i8* %b)
+ call void @llvm.lifetime.end.p0i8(i64 136, i8* %b)
+ call void @llvm.lifetime.start.p0i8(i64 128, i8* %b2)
+ %t3 = call i32 @foo(i32 %in, i8* %b2)
+ %t4 = call i32 @foo(i32 %in, i8* %b2)
+ call void @llvm.lifetime.end.p0i8(i64 128, i8* %b2)
+ %t5 = add i32 %t1, %t2
+ %t6 = add i32 %t3, %t4
+ %t7 = add i32 %t5, %t6
+ ret i32 %t7
+}
+
+declare void @llvm.lifetime.start.p0i8(i64, i8* nocapture) nounwind
+
+declare void @llvm.lifetime.end.p0i8(i64, i8* nocapture) nounwind
+
+declare i32 @foo(i32, i8*)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D121433.415203.patch
Type: text/x-patch
Size: 1651 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220314/11f24ef3/attachment.bin>
More information about the llvm-commits
mailing list