Only expand strlen to Pmode.
authorH.J. Lu <hongjiu.lu@intel.com>
Thu, 28 Jul 2011 12:32:23 +0000 (12:32 +0000)
committerH.J. Lu <hjl@gcc.gnu.org>
Thu, 28 Jul 2011 12:32:23 +0000 (05:32 -0700)
2011-07-28  H.J. Lu  <hongjiu.lu@intel.com>

PR target/47364
* config/i386/i386.md (strlen<mode>): Replace SWI48x with P.

From-SVN: r176868

gcc/ChangeLog
gcc/config/i386/i386.md

index 8016e51d9c7620edac4a00e63f9c55814f9998e7..cd54848866e6bc2674dfac4513df381c18ee0d46 100644 (file)
@@ -1,3 +1,8 @@
+2011-07-28  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/47364
+       * config/i386/i386.md (strlen<mode>): Replace SWI48x with P.
+
 2011-07-28  Ramana Radhakrishnan  <ramana.radhakrishnan@linaro.org>
 
        * config/arm/vfp.md ("*movdf_vfp"): Handle the VFP constraints
index a4435c2d232df4e36a1cefb4dbca5b2e2715c659..fce426868beb46f060f1075d56773a297e1d5bfb 100644 (file)
    (set_attr "prefix_rep" "1")])
 
 (define_expand "strlen<mode>"
-  [(set (match_operand:SWI48x 0 "register_operand" "")
-       (unspec:SWI48x [(match_operand:BLK 1 "general_operand" "")
-                       (match_operand:QI 2 "immediate_operand" "")
-                       (match_operand 3 "immediate_operand" "")]
-                      UNSPEC_SCAS))]
+  [(set (match_operand:P 0 "register_operand" "")
+       (unspec:P [(match_operand:BLK 1 "general_operand" "")
+                  (match_operand:QI 2 "immediate_operand" "")
+                  (match_operand 3 "immediate_operand" "")]
+                 UNSPEC_SCAS))]
   ""
 {
  if (ix86_expand_strlen (operands[0], operands[1], operands[2], operands[3]))