[PATCH] D17611: NFC. Introduce Value::isPointerDereferenceable
Artur Pilipenko via llvm-commits
llvm-commits at lists.llvm.org
Wed May 11 07:49:34 PDT 2016
This revision was automatically updated to reflect the committed changes.
Closed by commit rL269190: NFC. Introduce Value::isPointerDereferenceable (authored by apilipenko).
Changed prior to commit:
http://reviews.llvm.org/D17611?vs=55203&id=56914#toc
Repository:
rL LLVM
http://reviews.llvm.org/D17611
Files:
llvm/trunk/include/llvm/IR/Value.h
llvm/trunk/lib/Analysis/Loads.cpp
llvm/trunk/lib/IR/Value.cpp
Index: llvm/trunk/lib/Analysis/Loads.cpp
===================================================================
--- llvm/trunk/lib/Analysis/Loads.cpp
+++ llvm/trunk/lib/Analysis/Loads.cpp
@@ -91,9 +91,12 @@
// Note that it is not safe to speculate into a malloc'd region because
// malloc may return null.
- // These are obviously ok if aligned.
- if (isa<AllocaInst>(V))
+ bool CheckForNonNull;
+ if (V->isPointerDereferenceable(CheckForNonNull)) {
+ if (CheckForNonNull && !isKnownNonNullAt(V, CtxI, DT, TLI))
+ return false;
return isAligned(V, Align, DL);
+ }
// It's not always safe to follow a bitcast, for example:
// bitcast i8* (alloca i8) to i32*
@@ -112,16 +115,6 @@
CtxI, DT, TLI, Visited);
}
- // Global variables which can't collapse to null are ok.
- if (const GlobalVariable *GV = dyn_cast<GlobalVariable>(V))
- if (!GV->hasExternalWeakLinkage())
- return isAligned(V, Align, DL);
-
- // byval arguments are okay.
- if (const Argument *A = dyn_cast<Argument>(V))
- if (A->hasByValAttr())
- return isAligned(V, Align, DL);
-
if (isDereferenceableFromAttribute(V, DL, CtxI, DT, TLI))
return isAligned(V, Align, DL);
Index: llvm/trunk/lib/IR/Value.cpp
===================================================================
--- llvm/trunk/lib/IR/Value.cpp
+++ llvm/trunk/lib/IR/Value.cpp
@@ -559,6 +559,29 @@
return DerefBytes;
}
+bool Value::isPointerDereferenceable(bool &CanBeNull) const {
+ assert(getType()->isPointerTy() && "must be pointer");
+
+ CanBeNull = false;
+
+ // These are obviously ok.
+ if (isa<AllocaInst>(this))
+ return true;
+
+ // Global variables which can't collapse to null are ok.
+ // TODO: return true for those but set CanBeNull flag
+ if (const GlobalVariable *GV = dyn_cast<GlobalVariable>(this))
+ if (!GV->hasExternalWeakLinkage())
+ return true;
+
+ // byval arguments are okay.
+ if (const Argument *A = dyn_cast<Argument>(this))
+ if (A->hasByValAttr())
+ return true;
+
+ return false;
+}
+
unsigned Value::getPointerAlignment(const DataLayout &DL) const {
assert(getType()->isPointerTy() && "must be pointer");
Index: llvm/trunk/include/llvm/IR/Value.h
===================================================================
--- llvm/trunk/include/llvm/IR/Value.h
+++ llvm/trunk/include/llvm/IR/Value.h
@@ -511,6 +511,12 @@
/// dereferenceable up to the returned number of bytes.
unsigned getPointerDereferenceableBytes(bool &CanBeNull) const;
+ /// \brief Returns true if the pointer value is fully dereferenceable.
+ ///
+ /// Sets CanBeNull to true if the pointer is either null or can be fully
+ /// dereferenceable.
+ bool isPointerDereferenceable(bool &CanBeNull) const;
+
/// \brief Returns an alignment of the pointer value.
///
/// Returns an alignment which is either specified explicitly, e.g. via
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D17611.56914.patch
Type: text/x-patch
Size: 2934 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160511/7b0d15a2/attachment.bin>
More information about the llvm-commits
mailing list