From 6381b143f6cc3607a1a96442aa06dc469ea1fc79 Mon Sep 17 00:00:00 2001 From: Hideto Ueno Date: Fri, 30 Aug 2019 10:00:32 +0000 Subject: [PATCH] [Attributor] Implement AANoAliasCallSiteArgument initialization Summary: This patch adds an appropriate `initialize` method for `AANoAliasCallSiteArgument`. Reviewers: jdoerfert, sstefan1 Reviewed By: jdoerfert Subscribers: hiraditya, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D66927 llvm-svn: 370456 --- llvm/lib/Transforms/IPO/Attributor.cpp | 6 ++++-- .../Transforms/FunctionAttrs/noalias_returned.ll | 15 ++++++++++----- 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/llvm/lib/Transforms/IPO/Attributor.cpp b/llvm/lib/Transforms/IPO/Attributor.cpp index dff7011061a4..05686921a65a 100644 --- a/llvm/lib/Transforms/IPO/Attributor.cpp +++ b/llvm/lib/Transforms/IPO/Attributor.cpp @@ -1592,8 +1592,10 @@ struct AANoAliasCallSiteArgument final : AANoAliasImpl { /// See AbstractAttribute::initialize(...). void initialize(Attributor &A) override { - // TODO: It isn't sound to initialize as the same with `AANoAliasImpl` - // because `noalias` may not be valid in the current position. + // See callsite argument attribute and callee argument attribute. + ImmutableCallSite ICS(&getAnchorValue()); + if (ICS.paramHasAttr(getArgNo(), Attribute::NoAlias)) + indicateOptimisticFixpoint(); } /// See AbstractAttribute::updateImpl(...). diff --git a/llvm/test/Transforms/FunctionAttrs/noalias_returned.ll b/llvm/test/Transforms/FunctionAttrs/noalias_returned.ll index d7c4eadb9836..ce28ed3f29a6 100644 --- a/llvm/test/Transforms/FunctionAttrs/noalias_returned.ll +++ b/llvm/test/Transforms/FunctionAttrs/noalias_returned.ll @@ -142,8 +142,7 @@ define i8* @test8(i32* %0) nounwind uwtable { ; TEST 9 ; Simple Argument Test define internal void @test9(i8* %a, i8* %b) { -; FIXME: missing noalias -; CHECK: define internal void @test9(i8* %a, i8* %b) +; CHECK: define internal void @test9(i8* noalias %a, i8* %b) ret void } define void @test9_helper(i8* %a, i8* %b) { @@ -156,12 +155,18 @@ define void @test9_helper(i8* %a, i8* %b) { ; TEST 10 ; Simple CallSite Test -declare void @test10_helper(i8* %a) +declare void @test10_helper_1(i8* %a) +define void @test10_helper_2(i8* noalias %a) { + ret void +} define void @test10(i8* noalias %a) { ; CHECK: define void @test10(i8* noalias %a) ; FIXME: missing noalias -; CHECK-NEXT: tail call void @test10_helper(i8* %a) - tail call void @test10_helper(i8* %a) +; CHECK-NEXT: tail call void @test10_helper_1(i8* %a) + tail call void @test10_helper_1(i8* %a) + +; CHECK-NEXT: tail call void @test10_helper_2(i8* noalias %a) + tail call void @test10_helper_2(i8* %a) ret void }