aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <rth@gcc.gnu.org>2004-08-26 17:55:38 -0700
committerRichard Henderson <rth@gcc.gnu.org>2004-08-26 17:55:38 -0700
commitdc700f497caaf7c36db7220ab6f827b8dcf6a7e6 (patch)
tree6c427b8f84f25b3a3314f74ca5ce1571788772a7
parentee8a6a3ee5d35c2e188225c2bbb58c2cca69a2ab (diff)
downloadgcc-dc700f497caaf7c36db7220ab6f827b8dcf6a7e6.zip
gcc-dc700f497caaf7c36db7220ab6f827b8dcf6a7e6.tar.gz
gcc-dc700f497caaf7c36db7220ab6f827b8dcf6a7e6.tar.bz2
Update comment for staticp.
From-SVN: r86652
-rw-r--r--gcc/tree.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/gcc/tree.c b/gcc/tree.c
index 27efff1..1c5060e 100644
--- a/gcc/tree.c
+++ b/gcc/tree.c
@@ -1363,8 +1363,9 @@ array_type_nelts (tree type)
: fold (build2 (MINUS_EXPR, TREE_TYPE (max), max, min)));
}
-/* Return true if arg is static -- a reference to an object in
- static storage. This is not the same as the C meaning of `static'. */
+/* If arg is static -- a reference to an object in static storage -- then
+ return the object. This is not the same as the C meaning of `static'.
+ If arg isn't static, return NULL. */
tree
staticp (tree arg)
@@ -2270,7 +2271,11 @@ do { tree _node = (NODE); \
address of a volatile variable is not volatile.) If it's a constant,
the address is both invariant and constant. Otherwise it's neither. */
if (TREE_CODE (node) == INDIRECT_REF)
- UPDATE_TITCSE (node);
+ {
+ /* If this is &((T*)0)->field, then this is a form of addition. */
+ if (TREE_CODE (TREE_OPERAND (node, 0)) != INTEGER_CST)
+ UPDATE_TITCSE (node);
+ }
else if (DECL_P (node))
{
if (staticp (node))