aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2011-11-26 16:10:18 -0800
committerRichard Henderson <rth@gcc.gnu.org>2011-11-26 16:10:18 -0800
commit2b894715ba76dc0e8ca8d73adc814d68deeacfda (patch)
tree01dacf29ef3b1b931a0f9ef419e373c31f31998d
parent022c0cd11d277b3e6b76c060f7f8d3f1dc675127 (diff)
downloadgcc-2b894715ba76dc0e8ca8d73adc814d68deeacfda.zip
gcc-2b894715ba76dc0e8ca8d73adc814d68deeacfda.tar.gz
gcc-2b894715ba76dc0e8ca8d73adc814d68deeacfda.tar.bz2
Fix expand_atomic_fetch_op wrt unused_result.
* optabs.c (expand_atomic_fetch_op): Always return result. From-SVN: r181750
-rw-r--r--gcc/ChangeLog2
-rw-r--r--gcc/optabs.c6
2 files changed, 4 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 41b3b9b..c16f1d8 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,7 @@
2011-11-26 Richard Henderson <rth@redhat.com>
+ * optabs.c (expand_atomic_fetch_op): Always return result.
+
* optabs.c (init_sync_libfuncs_1): Include max in iteration.
* omp-low.c (expand_omp_atomic): Assume anything aligned to
diff --git a/gcc/optabs.c b/gcc/optabs.c
index 0ce21e9..a1917cc 100644
--- a/gcc/optabs.c
+++ b/gcc/optabs.c
@@ -8068,7 +8068,7 @@ expand_atomic_fetch_op (rtx target, rtx mem, rtx val, enum rtx_code code,
{
/* If the result isn't used, no need to do compensation code. */
if (unused_result)
- return target;
+ return result;
/* Issue compensation code. Fetch_after == fetch_before OP val.
Fetch_before == after REVERSE_OP val. */
@@ -8110,9 +8110,7 @@ expand_atomic_fetch_op (rtx target, rtx mem, rtx val, enum rtx_code code,
result = emit_library_call_value (libfunc, NULL, LCT_NORMAL, mode,
2, addr, ptr_mode, val, mode);
- if (unused_result)
- return target;
- if (fixup)
+ if (!unused_result && fixup)
result = expand_simple_binop (mode, code, result, val, target,
true, OPTAB_LIB_WIDEN);
return result;