diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 8da7a7f88e9e0d07a747d3f04bc2e53856f5b50c..bd51a3c8945ecfa59866727b17287648a6fbfb64 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2012-05-10  Nick Clifton  <nickc@redhat.com>
+
+	PR target/53120
+	* config/m32c/bitops.md (bset_qi): Change operand 2 from having
+	a "0" constraint to being a (match_dup 0).
+
 2012-05-10  Richard Guenther  <rguenther@suse.de>
 
 	* stor-layout.c (byte_from_pos): Amend comment.
diff --git a/gcc/config/m32c/bitops.md b/gcc/config/m32c/bitops.md
index 3c8e8427b28753414884c152da4dd83892d39afd..060362de71e360c58d82cefa45a0bdc52dacd850 100644
--- a/gcc/config/m32c/bitops.md
+++ b/gcc/config/m32c/bitops.md
@@ -43,11 +43,11 @@
   [(set (match_operand:QI 0 "memsym_operand" "+Si")
 	(ior:QI (subreg:QI (ashift:HI (const_int 1)
 				      (subreg:QI (match_operand:HI 1 "a_qi_operand" "Raa") 0)) 0)
-		(match_operand:QI 2 "memsym_operand" "0")))]
+		(match_dup 0)))]
   "TARGET_A16"
   "bset\t%0[%1]"
   [(set_attr "flags" "n")]
-  )  
+  )
 
 (define_insn "bset_hi"
   [(set (zero_extract:HI (match_operand:QI 0 "memsym_operand" "+Si")