diff options
author | John Wehle <john@feith.com> | 2000-09-10 18:25:49 +0000 |
---|---|---|
committer | John Wehle <wehle@gcc.gnu.org> | 2000-09-10 18:25:49 +0000 |
commit | d982e46e1c8ec6ed6ab7afc51c7390788edaa0e6 (patch) | |
tree | 7eefe19dc8865370e7ecf0dc3bfec84f34941058 /gcc/alias.c | |
parent | 212d447c7fbeed4cf515089d5c67fc6caaa34c45 (diff) | |
download | gcc-d982e46e1c8ec6ed6ab7afc51c7390788edaa0e6.zip gcc-d982e46e1c8ec6ed6ab7afc51c7390788edaa0e6.tar.gz gcc-d982e46e1c8ec6ed6ab7afc51c7390788edaa0e6.tar.bz2 |
alias.c (find_base_term): Handle ADDRESSOF.
* alias.c (find_base_term): Handle ADDRESSOF.
(memrefs_conflict_p): An ADDRESSOF doesn't conflict.
From-SVN: r36300
Diffstat (limited to 'gcc/alias.c')
-rw-r--r-- | gcc/alias.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/gcc/alias.c b/gcc/alias.c index cb5a636..b17296b 100644 --- a/gcc/alias.c +++ b/gcc/alias.c @@ -1131,6 +1131,9 @@ find_base_term (x) case LABEL_REF: return x; + case ADDRESSOF: + return REG_BASE_VALUE (stack_pointer_rtx); + default: return 0; } @@ -1454,6 +1457,9 @@ memrefs_conflict_p (xsize, x, ysize, y, c) return memrefs_conflict_p (xsize, x, ysize, XEXP (y, 0), c); } + if (GET_CODE (x) == ADDRESSOF || GET_CODE (y) == ADDRESSOF) + return xsize <= 0 || ysize <= 0; + if (CONSTANT_P (x)) { if (GET_CODE (x) == CONST_INT && GET_CODE (y) == CONST_INT) |