mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 12:41:49 +01:00
[FuncAttrs] Remove "access range attributes" for read-none functions
The presence of readnone and an access range attribute (argmemonly, inaccessiblememonly, inaccessiblemem_or_argmemonly) is considered an error by the verifier. This seems strict but also not wrong. This patch makes sure function attribute detection will remove all access range attributes for readnone functions. llvm-svn: 341927
This commit is contained in:
parent
218cfa8be2
commit
90b862b76c
@ -281,6 +281,13 @@ static bool addReadAttrs(const SCCNodeSet &SCCNodes, AARGetterT &&AARGetter) {
|
||||
F->removeFnAttr(Attribute::ReadNone);
|
||||
F->removeFnAttr(Attribute::WriteOnly);
|
||||
|
||||
if (!WritesMemory && !ReadsMemory) {
|
||||
// Clear out any "access range attributes" if readnone was deduced.
|
||||
F->removeFnAttr(Attribute::ArgMemOnly);
|
||||
F->removeFnAttr(Attribute::InaccessibleMemOnly);
|
||||
F->removeFnAttr(Attribute::InaccessibleMemOrArgMemOnly);
|
||||
}
|
||||
|
||||
// Add in the new attribute.
|
||||
if (WritesMemory && !ReadsMemory)
|
||||
F->addFnAttr(Attribute::WriteOnly);
|
||||
|
32
test/Transforms/FunctionAttrs/incompatible_fn_attrs.ll
Normal file
32
test/Transforms/FunctionAttrs/incompatible_fn_attrs.ll
Normal file
@ -0,0 +1,32 @@
|
||||
; RUN: opt -S -o - -functionattrs %s | FileCheck %s
|
||||
; RUN: opt -S -o - -passes=function-attrs %s | FileCheck %s
|
||||
|
||||
; Verify we remove argmemonly/inaccessiblememonly/inaccessiblemem_or_argmemonly
|
||||
; function attributes when we derive readnone.
|
||||
|
||||
; Function Attrs: argmemonly
|
||||
define i32* @given_argmem_infer_readnone(i32* %p) #0 {
|
||||
; CHECK: define i32* @given_argmem_infer_readnone(i32* readnone returned %p) #0 {
|
||||
entry:
|
||||
ret i32* %p
|
||||
}
|
||||
|
||||
; Function Attrs: inaccessiblememonly
|
||||
define i32* @given_inaccessible_infer_readnone(i32* %p) #1 {
|
||||
; CHECK: define i32* @given_inaccessible_infer_readnone(i32* readnone returned %p) #0 {
|
||||
entry:
|
||||
ret i32* %p
|
||||
}
|
||||
|
||||
; Function Attrs: inaccessiblemem_or_argmemonly
|
||||
define i32* @given_inaccessible_or_argmem_infer_readnone(i32* %p) #2 {
|
||||
; CHECK: define i32* @given_inaccessible_or_argmem_infer_readnone(i32* readnone returned %p) #0 {
|
||||
entry:
|
||||
ret i32* %p
|
||||
}
|
||||
|
||||
attributes #0 = { argmemonly }
|
||||
attributes #1 = { inaccessiblememonly }
|
||||
attributes #2 = { inaccessiblemem_or_argmemonly }
|
||||
; CHECK: attributes #0 = { norecurse nounwind readnone }
|
||||
; CHECK-NOT: attributes
|
Loading…
x
Reference in New Issue
Block a user