2010-05-18 11:58:33 -04:00
|
|
|
/*
|
2010-09-09 08:16:39 -04:00
|
|
|
* Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
2010-06-18 12:39:21 -04:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
2010-06-04 16:19:40 -04:00
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
2010-06-18 12:39:21 -04:00
|
|
|
* in the file PATENTS. All contributing project authors may
|
2010-06-04 16:19:40 -04:00
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2010-05-18 11:58:33 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef POSTPROC_H
|
|
|
|
#define POSTPROC_H
|
|
|
|
|
|
|
|
#define prototype_postproc_inplace(sym)\
|
|
|
|
void sym (unsigned char *dst, int pitch, int rows, int cols,int flimit)
|
|
|
|
|
|
|
|
#define prototype_postproc(sym)\
|
|
|
|
void sym (unsigned char *src, unsigned char *dst, int src_pitch,\
|
|
|
|
int dst_pitch, int rows, int cols, int flimit)
|
|
|
|
|
|
|
|
#define prototype_postproc_addnoise(sym) \
|
|
|
|
void sym (unsigned char *s, char *noise, char blackclamp[16],\
|
|
|
|
char whiteclamp[16], char bothclamp[16],\
|
|
|
|
unsigned int w, unsigned int h, int pitch)
|
|
|
|
|
2010-11-04 10:35:02 -07:00
|
|
|
#define prototype_postproc_blend_mb_inner(sym)\
|
|
|
|
void sym (unsigned char *y, unsigned char *u, unsigned char *v,\
|
|
|
|
int y1, int u1, int v1, int alpha, int stride)
|
|
|
|
|
|
|
|
#define prototype_postproc_blend_mb_outer(sym)\
|
|
|
|
void sym (unsigned char *y, unsigned char *u, unsigned char *v,\
|
|
|
|
int y1, int u1, int v1, int alpha, int stride)
|
|
|
|
|
|
|
|
#define prototype_postproc_blend_b(sym)\
|
2010-10-27 12:50:16 -07:00
|
|
|
void sym (unsigned char *y, unsigned char *u, unsigned char *v,\
|
|
|
|
int y1, int u1, int v1, int alpha, int stride)
|
|
|
|
|
2010-05-18 11:58:33 -04:00
|
|
|
#if ARCH_X86 || ARCH_X86_64
|
|
|
|
#include "x86/postproc_x86.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_down
|
|
|
|
#define vp8_postproc_down vp8_mbpost_proc_down_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc_inplace(vp8_postproc_down);
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_across
|
|
|
|
#define vp8_postproc_across vp8_mbpost_proc_across_ip_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc_inplace(vp8_postproc_across);
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_downacross
|
|
|
|
#define vp8_postproc_downacross vp8_post_proc_down_and_across_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc(vp8_postproc_downacross);
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_addnoise
|
|
|
|
#define vp8_postproc_addnoise vp8_plane_add_noise_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc_addnoise(vp8_postproc_addnoise);
|
|
|
|
|
2010-11-04 10:35:02 -07:00
|
|
|
#ifndef vp8_postproc_blend_mb_inner
|
|
|
|
#define vp8_postproc_blend_mb_inner vp8_blend_mb_inner_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc_blend_mb_inner(vp8_postproc_blend_mb_inner);
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_blend_mb_outer
|
|
|
|
#define vp8_postproc_blend_mb_outer vp8_blend_mb_outer_c
|
|
|
|
#endif
|
|
|
|
extern prototype_postproc_blend_mb_outer(vp8_postproc_blend_mb_outer);
|
|
|
|
|
|
|
|
#ifndef vp8_postproc_blend_b
|
|
|
|
#define vp8_postproc_blend_b vp8_blend_b_c
|
2010-10-27 12:50:16 -07:00
|
|
|
#endif
|
2010-11-04 10:35:02 -07:00
|
|
|
extern prototype_postproc_blend_b(vp8_postproc_blend_b);
|
2010-05-18 11:58:33 -04:00
|
|
|
|
|
|
|
typedef prototype_postproc((*vp8_postproc_fn_t));
|
|
|
|
typedef prototype_postproc_inplace((*vp8_postproc_inplace_fn_t));
|
|
|
|
typedef prototype_postproc_addnoise((*vp8_postproc_addnoise_fn_t));
|
2010-11-04 10:35:02 -07:00
|
|
|
typedef prototype_postproc_blend_mb_inner((*vp8_postproc_blend_mb_inner_fn_t));
|
|
|
|
typedef prototype_postproc_blend_mb_outer((*vp8_postproc_blend_mb_outer_fn_t));
|
|
|
|
typedef prototype_postproc_blend_b((*vp8_postproc_blend_b_fn_t));
|
2010-05-18 11:58:33 -04:00
|
|
|
typedef struct
|
|
|
|
{
|
2010-11-04 10:35:02 -07:00
|
|
|
vp8_postproc_inplace_fn_t down;
|
|
|
|
vp8_postproc_inplace_fn_t across;
|
|
|
|
vp8_postproc_fn_t downacross;
|
|
|
|
vp8_postproc_addnoise_fn_t addnoise;
|
|
|
|
vp8_postproc_blend_mb_inner_fn_t blend_mb_inner;
|
|
|
|
vp8_postproc_blend_mb_outer_fn_t blend_mb_outer;
|
|
|
|
vp8_postproc_blend_b_fn_t blend_b;
|
2010-05-18 11:58:33 -04:00
|
|
|
} vp8_postproc_rtcd_vtable_t;
|
|
|
|
|
|
|
|
#if CONFIG_RUNTIME_CPU_DETECT
|
|
|
|
#define POSTPROC_INVOKE(ctx,fn) (ctx)->fn
|
|
|
|
#else
|
|
|
|
#define POSTPROC_INVOKE(ctx,fn) vp8_postproc_##fn
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "vpx_ports/mem.h"
|
|
|
|
struct postproc_state
|
|
|
|
{
|
|
|
|
int last_q;
|
|
|
|
int last_noise;
|
|
|
|
char noise[3072];
|
|
|
|
DECLARE_ALIGNED(16, char, blackclamp[16]);
|
|
|
|
DECLARE_ALIGNED(16, char, whiteclamp[16]);
|
|
|
|
DECLARE_ALIGNED(16, char, bothclamp[16]);
|
|
|
|
};
|
|
|
|
#include "onyxc_int.h"
|
|
|
|
#include "ppflags.h"
|
|
|
|
int vp8_post_proc_frame(struct VP8Common *oci, YV12_BUFFER_CONFIG *dest,
|
2010-11-04 16:03:36 -07:00
|
|
|
vp8_ppflags_t *flags);
|
2010-05-18 11:58:33 -04:00
|
|
|
|
|
|
|
|
|
|
|
void vp8_de_noise(YV12_BUFFER_CONFIG *source,
|
|
|
|
YV12_BUFFER_CONFIG *post,
|
|
|
|
int q,
|
|
|
|
int low_var_thresh,
|
|
|
|
int flag,
|
|
|
|
vp8_postproc_rtcd_vtable_t *rtcd);
|
2010-05-28 10:37:43 +02:00
|
|
|
|
|
|
|
void vp8_deblock(YV12_BUFFER_CONFIG *source,
|
|
|
|
YV12_BUFFER_CONFIG *post,
|
|
|
|
int q,
|
|
|
|
int low_var_thresh,
|
|
|
|
int flag,
|
|
|
|
vp8_postproc_rtcd_vtable_t *rtcd);
|
2010-05-18 11:58:33 -04:00
|
|
|
#endif
|