Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Fri, 16 Aug 2013 12:21:34 +0000 (14:21 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Fri, 16 Aug 2013 12:21:40 +0000 (14:21 +0200)
* qatar/master:
  altivec: perform an explicit unaligned load

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
libavcodec/ppc/int_altivec.c

@@@ -1,20 -1,20 +1,20 @@@
  /*
   * Copyright (c) 2007 Luca Barbato <lu_zero@gentoo.org>
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
@@@ -84,14 -84,12 +84,12 @@@ static int32_t scalarproduct_int16_alti
  {
      int i;
      LOAD_ZERO;
-     const vec_s16 *pv;
      register vec_s16 vec1;
      register vec_s32 res = vec_splat_s32(0), t;
      int32_t ires;
  
      for(i = 0; i < order; i += 8){
-         pv = (const vec_s16*)v1;
-         vec1 = vec_perm(pv[0], pv[1], vec_lvsl(0, v1));
+         vec1 = vec_unaligned_load(v1);
          t = vec_msum(vec1, vec_ld(0, v2), zero_s32v);
          res = vec_sums(t, res);
          v1 += 8;