Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Sat, 2 Feb 2013 12:01:45 +0000 (13:01 +0100)
committerMichael Niedermayer <michaelni@gmx.at>
Sat, 2 Feb 2013 12:18:01 +0000 (13:18 +0100)
* qatar/master:
  vf_hqdn3d: x86: Add proper arch optimization initialization

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
libavfilter/vf_hqdn3d.c

  #include "formats.h"
  #include "internal.h"
  #include "video.h"
- typedef struct {
-     int16_t *coefs[4];
-     uint16_t *line;
-     uint16_t *frame_prev[3];
-     double strength[4];
-     int hsub, vsub;
-     int depth;
-     void (*denoise_row[17])(uint8_t *src, uint8_t *dst, uint16_t *line_ant, uint16_t *frame_ant, ptrdiff_t w, int16_t *spatial, int16_t *temporal);
- } HQDN3DContext;
- void ff_hqdn3d_row_8_x86(uint8_t *src, uint8_t *dst, uint16_t *line_ant, uint16_t *frame_ant, ptrdiff_t w, int16_t *spatial, int16_t *temporal);
- void ff_hqdn3d_row_9_x86(uint8_t *src, uint8_t *dst, uint16_t *line_ant, uint16_t *frame_ant, ptrdiff_t w, int16_t *spatial, int16_t *temporal);
- void ff_hqdn3d_row_10_x86(uint8_t *src, uint8_t *dst, uint16_t *line_ant, uint16_t *frame_ant, ptrdiff_t w, int16_t *spatial, int16_t *temporal);
- void ff_hqdn3d_row_16_x86(uint8_t *src, uint8_t *dst, uint16_t *line_ant, uint16_t *frame_ant, ptrdiff_t w, int16_t *spatial, int16_t *temporal);
+ #include "vf_hqdn3d.h"
  
  #define LUT_BITS (depth==16 ? 8 : 4)
 -#define RIGHTSHIFT(a,b) (((a)+(((1<<(b))-1)>>1))>>(b))
 -#define LOAD(x) ((depth==8 ? src[x] : AV_RN16A(src+(x)*2)) << (16-depth))
 -#define STORE(x,val) (depth==8 ? dst[x] = RIGHTSHIFT(val, 16-depth)\
 -                    : AV_WN16A(dst+(x)*2, RIGHTSHIFT(val, 16-depth)))
 +#define LOAD(x) (((depth==8 ? src[x] : AV_RN16A(src+(x)*2)) << (16-depth)) + (((1<<(16-depth))-1)>>1))
 +#define STORE(x,val) (depth==8 ? dst[x] = (val) >> (16-depth)\
 +                    : AV_WN16A(dst+(x)*2, (val) >> (16-depth)))
  
  av_always_inline
  static uint32_t lowpass(int prev, int cur, int16_t *coef, int depth)