This is the mail archive of the gcc-patches@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [PATCH] Fix AltiVec mergel RTL patterns


>>>>> "Daniel" == Daniel Egger <degger@fhm.edu> writes:

 > this patch fixed the wrong patterns for all mergel insns
 > which were wrongly cutted'n'pasted from the mergeh pattern.

 > This fixes one of the problems with wrong assembly being generated
 > in the last of my testcases.

 > Bootstrapped and regtested on powerpc-linux. Please apply.

[found patch.  GNUS had eated it.]

Yes this is ok.  Thanks.

Applied.

P.S. Try to do context diffs next time (-cp).

2002-02-26  Daniel Egger  <degger@fhm.edu>

        * config/rs6000/rs6000.md: Swap define_insn attributes to
        fix incorrect generation of merge high instructions instead
        of merge low.

Index: config/rs6000/rs6000.md
===================================================================
RCS file: /cvs/uberbaum/gcc/config/rs6000/rs6000.md,v
retrieving revision 1.171
diff -c -p -r1.171 rs6000.md
*** rs6000.md	2002/02/26 06:20:48	1.171
--- rs6000.md	2002/02/26 06:45:55
***************
*** 14551,14572 ****
  (define_insn "altivec_vmrglb"
    [(set (match_operand:V16QI 0 "register_operand" "=v")
          (vec_merge:V16QI (vec_select:V16QI (match_operand:V16QI 2 "register_operand" "v")
! 					   (parallel [(const_int 8)
! 					   	      (const_int 9)
! 					   	      (const_int 10)
! 					   	      (const_int 11)
! 					   	      (const_int 12)
! 					   	      (const_int 13)
! 						      (const_int 14)
! 						      (const_int 15)
! 					   	      (const_int 0)
  					   	      (const_int 1)
  					   	      (const_int 2)
  					   	      (const_int 3)
  					   	      (const_int 4)
  					   	      (const_int 5)
! 					   	      (const_int 6)
! 						      (const_int 7)]))
                        (match_operand:V16QI 1 "register_operand" "v")
  		      (const_int 255)))]
    "TARGET_ALTIVEC"
--- 14551,14573 ----
  (define_insn "altivec_vmrglb"
    [(set (match_operand:V16QI 0 "register_operand" "=v")
          (vec_merge:V16QI (vec_select:V16QI (match_operand:V16QI 2 "register_operand" "v")
! 					   
! 					   (parallel [(const_int 0)
  					   	      (const_int 1)
  					   	      (const_int 2)
  					   	      (const_int 3)
  					   	      (const_int 4)
  					   	      (const_int 5)
! 						      (const_int 6)
! 						      (const_int 7)
! 					   	      (const_int 8)
! 					   	      (const_int 9)
! 					   	      (const_int 10)
! 					   	      (const_int 11)
! 					   	      (const_int 12)
! 					   	      (const_int 13)
! 					   	      (const_int 14)
! 						      (const_int 15)]))
                        (match_operand:V16QI 1 "register_operand" "v")
  		      (const_int 255)))]
    "TARGET_ALTIVEC"
***************
*** 14576,14589 ****
  (define_insn "altivec_vmrglh"
    [(set (match_operand:V8HI 0 "register_operand" "=v")
          (vec_merge:V8HI (vec_select:V8HI (match_operand:V8HI 2 "register_operand" "v")
! 					   (parallel [(const_int 4)
! 					   	      (const_int 5)
! 					   	      (const_int 6)
! 					   	      (const_int 7)
! 					   	      (const_int 0)
  					   	      (const_int 1)
  					   	      (const_int 2)
! 					   	      (const_int 3)]))
                        (match_operand:V8HI 1 "register_operand" "v")
  		      (const_int 15)))]
    "TARGET_ALTIVEC"
--- 14577,14590 ----
  (define_insn "altivec_vmrglh"
    [(set (match_operand:V8HI 0 "register_operand" "=v")
          (vec_merge:V8HI (vec_select:V8HI (match_operand:V8HI 2 "register_operand" "v")
! 					   (parallel [(const_int 0)
  					   	      (const_int 1)
  					   	      (const_int 2)
! 					   	      (const_int 3)
! 					   	      (const_int 4)
! 					   	      (const_int 5)
! 					   	      (const_int 6)
! 					   	      (const_int 7)]))
                        (match_operand:V8HI 1 "register_operand" "v")
  		      (const_int 15)))]
    "TARGET_ALTIVEC"
***************
*** 14593,14602 ****
  (define_insn "altivec_vmrglw"
    [(set (match_operand:V4SI 0 "register_operand" "=v")
          (vec_merge:V4SI (vec_select:V4SI (match_operand:V4SI 2 "register_operand" "v")
! 					 (parallel [(const_int 2)
! 					 	    (const_int 3)
! 						    (const_int 0)
! 						    (const_int 1)]))
                        (match_operand:V4SI 1 "register_operand" "v")
  		      (const_int 12)))]
    "TARGET_ALTIVEC"
--- 14594,14603 ----
  (define_insn "altivec_vmrglw"
    [(set (match_operand:V4SI 0 "register_operand" "=v")
          (vec_merge:V4SI (vec_select:V4SI (match_operand:V4SI 2 "register_operand" "v")
! 					 (parallel [(const_int 0)
! 					 	    (const_int 1)
! 						    (const_int 2)
! 						    (const_int 3)]))
                        (match_operand:V4SI 1 "register_operand" "v")
  		      (const_int 12)))]
    "TARGET_ALTIVEC"


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]