--- image.h 2002/10/05 21:31:07 1.8.2.2 +++ image.h 2002/12/12 12:40:19 1.8.2.6 @@ -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, @@ -52,12 +51,18 @@ uint16_t height); +void +image_chroma_optimize(IMAGE * img, int width, int height, int edged_width); + + int image_input(IMAGE * image, uint32_t width, 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 +70,8 @@ uint32_t edged_width, uint8_t * dst, uint32_t dst_stride, - int csp); + int csp, + int interlaced); @@ -84,4 +90,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_ */