2001-10-11 00:13:27 +02:00
|
|
|
/*
|
|
|
|
Copyright (C) 2001 Michael Niedermayer (michaelni@gmx.at)
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef POSTPROCESS_H
|
|
|
|
#define POSTPROCESS_H
|
|
|
|
|
|
|
|
#define BLOCK_SIZE 8
|
|
|
|
#define TEMP_STRIDE 8
|
2001-10-11 00:21:19 +02:00
|
|
|
|
|
|
|
#define V_DEBLOCK 0x01
|
|
|
|
#define H_DEBLOCK 0x02
|
|
|
|
#define DERING 0x04
|
2001-10-12 00:35:45 +02:00
|
|
|
#define LEVEL_FIX 0x08 /* Brightness & Contrast */
|
2001-10-11 00:21:19 +02:00
|
|
|
|
2001-10-13 04:31:15 +02:00
|
|
|
#define LUM_V_DEBLOCK V_DEBLOCK // 1
|
|
|
|
#define LUM_H_DEBLOCK H_DEBLOCK // 2
|
|
|
|
#define CHROM_V_DEBLOCK (V_DEBLOCK<<4) // 16
|
|
|
|
#define CHROM_H_DEBLOCK (H_DEBLOCK<<4) // 32
|
|
|
|
#define LUM_DERING DERING // 4
|
|
|
|
#define CHROM_DERING (DERING<<4) // 64
|
|
|
|
#define LUM_LEVEL_FIX LEVEL_FIX // 8
|
2001-10-12 00:35:45 +02:00
|
|
|
//not supported currently
|
2001-10-13 04:31:15 +02:00
|
|
|
#define CHROM_LEVEL_FIX (LEVEL_FIX<<4) // 128
|
2001-10-11 00:21:19 +02:00
|
|
|
|
2001-10-13 04:31:15 +02:00
|
|
|
// Experimental vertical filters
|
|
|
|
#define V_RK1_FILTER 0x0100 // 256
|
|
|
|
#define V_X1_FILTER 0x0200 // 512
|
2001-10-11 00:21:19 +02:00
|
|
|
|
2001-10-13 04:31:15 +02:00
|
|
|
// Experimental horizontal filters
|
|
|
|
#define H_RK1_FILTER 0x1000 // 4096
|
|
|
|
#define H_X1_FILTER 0x2000 // 8192
|
2001-10-12 00:35:45 +02:00
|
|
|
|
2001-10-11 00:21:19 +02:00
|
|
|
|
2001-10-11 00:13:27 +02:00
|
|
|
#define TIMEING
|
|
|
|
#define MORE_TIMEING
|
|
|
|
|
|
|
|
#define MIN(a,b) ((a) > (b) ? (b) : (a))
|
|
|
|
#define MAX(a,b) ((a) < (b) ? (b) : (a))
|
|
|
|
#define ABS(a) ((a) > 0 ? (a) : (-(a)))
|
|
|
|
#define SIGN(a) ((a) > 0 ? 1 : -1)
|
|
|
|
|
|
|
|
#define QP_STORE_T int
|
|
|
|
|
2001-10-11 00:21:19 +02:00
|
|
|
#ifdef HAVE_MMX2
|
|
|
|
#define PAVGB(a,b) "pavgb " #a ", " #b " \n\t"
|
|
|
|
#elif defined (HAVE_3DNOW)
|
|
|
|
#define PAVGB(a,b) "pavgusb " #a ", " #b " \n\t"
|
|
|
|
#endif
|
|
|
|
|
2001-10-12 01:28:58 +02:00
|
|
|
//#ifdef __cplusplus
|
2001-10-11 00:13:27 +02:00
|
|
|
//#include <inttypes.h>
|
|
|
|
|
|
|
|
void postProcess(uint8_t src[], int srcStride, uint8_t dst[], int dstStride, int width, int height,
|
2001-10-12 00:35:45 +02:00
|
|
|
QP_STORE_T QPs[], int QPStride, int isColor, int mode);
|
2001-10-12 01:28:58 +02:00
|
|
|
//#endif
|
2001-10-11 00:13:27 +02:00
|
|
|
|
2001-10-12 01:28:58 +02:00
|
|
|
//#ifdef __cplusplus
|
|
|
|
//extern "C"
|
|
|
|
//{
|
|
|
|
//#endif
|
2001-10-11 00:13:27 +02:00
|
|
|
void postprocess(unsigned char * src[], int src_stride,
|
|
|
|
unsigned char * dst[], int dst_stride,
|
|
|
|
int horizontal_size, int vertical_size,
|
|
|
|
QP_STORE_T *QP_store, int QP_stride,
|
|
|
|
int mode);
|
2001-10-11 00:21:19 +02:00
|
|
|
|
|
|
|
int getModeForQuality(int quality);
|
2001-10-12 01:28:58 +02:00
|
|
|
//#ifdef __cplusplus
|
|
|
|
//}
|
|
|
|
//#endif
|
2001-10-11 00:13:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
#endif
|