--- image.h 2002/07/21 03:30:25 1.8 +++ image.h 2002/12/10 11:13:50 1.8.2.5 @@ -2,21 +2,20 @@ #define _IMAGE_H_ #include "../portab.h" +#include "../global.h" #include "colorspace.h" #include "../xvid.h" -#define EDGE_SIZE 32 +#define EDGE_SIZE 64 + +void init_image(uint32_t cpu_flags); -typedef struct +static void __inline +image_null(IMAGE * image) { - uint8_t *y; - uint8_t *u; - uint8_t *v; + image->y = image->u = image->v = NULL; } -IMAGE; - -void init_image(uint32_t cpu_flags); int32_t image_create(IMAGE * image, uint32_t edged_width, @@ -35,14 +34,14 @@ uint32_t edged_width, uint32_t edged_height, uint32_t width, - uint32_t height, - uint32_t interlacing); + uint32_t height); void image_interpolate(const IMAGE * refn, IMAGE * refh, IMAGE * refv, IMAGE * refhv, uint32_t edged_width, uint32_t edged_height, + uint32_t quarterpel, uint32_t rounding); float image_psnr(IMAGE * orig_image, @@ -57,7 +56,9 @@ int height, uint32_t edged_width, uint8_t * src, - int csp); + int src_stride, + int csp, + int interlaced); int image_output(IMAGE * image, uint32_t width, @@ -65,7 +66,8 @@ uint32_t edged_width, uint8_t * dst, uint32_t dst_stride, - int csp); + int csp, + int interlaced); @@ -84,4 +86,10 @@ void output_slice(IMAGE * cur, int edged_width, int width, XVID_DEC_PICTURE* out_frm, int mbx, int mby,int mbl); + +void +image_deblock_rrv(IMAGE * img, int edgeg_width, + const MACROBLOCK * mbs, int mb_width, int mb_height, int mb_stride); + + #endif /* _IMAGE_H_ */