aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2005-04-16 16:19:35 -0700
committerRichard Henderson <rth@gcc.gnu.org>2005-04-16 16:19:35 -0700
commit5b5513d00e50d605b486a2b5b986f4170ae285f1 (patch)
treeb80f5434c2ea87f68dfe101bb2a04913e75cab2b /gcc
parent92750a3929a3974cd0d4baa6c2da3258a2d43b2b (diff)
downloadgcc-5b5513d00e50d605b486a2b5b986f4170ae285f1.zip
gcc-5b5513d00e50d605b486a2b5b986f4170ae285f1.tar.gz
gcc-5b5513d00e50d605b486a2b5b986f4170ae285f1.tar.bz2
re PR target/21051 (sync tests ICE on ia64)
PR target/21051 * builtins.c (expand_builtin) <BUILT_IN_BOOL_COMPARE_AND_SWAP_*>: Use the mode of boolean_type_node when the user doesn't provide one. * config/ia64/sync.md (sync_lock_release<I48MODE>): Use operand 1. From-SVN: r98239
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/builtins.c2
-rw-r--r--gcc/config/ia64/sync.md2
3 files changed, 10 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 9bba2c5..d068542 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2005-04-16 Richard Henderson <rth@redhat.com>
+
+ PR target/21051
+ * builtins.c (expand_builtin) <BUILT_IN_BOOL_COMPARE_AND_SWAP_*>:
+ Use the mode of boolean_type_node when the user doesn't provide one.
+ * config/ia64/sync.md (sync_lock_release<I48MODE>): Use operand 1.
+
2005-04-16 Alexandre Oliva <aoliva@redhat.com>
PR target/20126
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 78a577f..f39a073 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -6178,6 +6178,8 @@ expand_builtin (tree exp, rtx target, rtx subtarget, enum machine_mode mode,
case BUILT_IN_BOOL_COMPARE_AND_SWAP_2:
case BUILT_IN_BOOL_COMPARE_AND_SWAP_4:
case BUILT_IN_BOOL_COMPARE_AND_SWAP_8:
+ if (mode == VOIDmode)
+ mode = TYPE_MODE (boolean_type_node);
if (!target || !register_operand (target, mode))
target = gen_reg_rtx (mode);
target = expand_builtin_compare_and_swap (arglist, true, target);
diff --git a/gcc/config/ia64/sync.md b/gcc/config/ia64/sync.md
index ed3304a..bca52b0 100644
--- a/gcc/config/ia64/sync.md
+++ b/gcc/config/ia64/sync.md
@@ -114,7 +114,7 @@
(define_expand "sync_lock_release<mode>"
[(set (match_operand:I48MODE 0 "memory_operand" "")
- (const_int 0))]
+ (match_operand:I48MODE 1 "gr_reg_or_0_operand" ""))]
""
{
gcc_assert (MEM_VOLATILE_P (operands[0]));