]> git.sesse.net Git - x264/blob - common/frame.h
SSE2 pixel comparison functions
[x264] / common / frame.h
1 /*****************************************************************************
2  * frame.h: h264 encoder library
3  *****************************************************************************
4  * Copyright (C) 2003 Laurent Aimar
5  * $Id: frame.h,v 1.1 2004/06/03 19:27:06 fenrir Exp $
6  *
7  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
22  *****************************************************************************/
23
24 #ifndef _FRAME_H
25 #define _FRAME_H 1
26
27 typedef struct
28 {
29     /* */
30     int     i_poc;
31     int     i_type;
32     int     i_qpplus1;
33     int64_t i_pts;
34     int     i_frame;    /* Presentation frame number */
35     int     i_frame_num; /* Coded frame number */
36     int     b_kept_as_ref;
37
38     /* YUV buffer */
39     int     i_plane;
40     int     i_stride[4];
41     int     i_lines[4];
42     int     i_stride_lowres;
43     int     i_lines_lowres;
44     uint8_t *plane[4];
45     uint8_t *filtered[4]; /* plane[0], H, V, HV */
46     uint8_t *lowres[4]; /* half-size copy of input frame: Orig, H, V, HV */
47
48     /* for unrestricted mv we allocate more data than needed
49      * allocated data are stored in buffer */
50     void    *buffer[11];
51
52     /* motion data */
53     int8_t  *mb_type;
54     int16_t (*mv[2])[2];
55     int8_t  *ref[2];
56     int     i_ref[2];
57     int     ref_poc[2][16];
58
59     /* for adaptive B-frame decision.
60      * contains the SATD cost of the lowres frame encoded in various modes
61      * FIXME: how big an array do we need? */
62     int     i_cost_est[16][16];
63     int     i_intra_mbs[16];
64
65 } x264_frame_t;
66
67 x264_frame_t *x264_frame_new( x264_t *h );
68 void          x264_frame_delete( x264_frame_t *frame );
69
70 void          x264_frame_copy_picture( x264_t *h, x264_frame_t *dst, x264_picture_t *src );
71
72 void          x264_frame_expand_border( x264_frame_t *frame );
73 void          x264_frame_expand_border_filtered( x264_frame_t *frame );
74 void          x264_frame_expand_border_lowres( x264_frame_t *frame );
75
76 void          x264_frame_deblocking_filter( x264_t *h, int i_slice_type );
77
78 void          x264_frame_filter( int cpu, x264_frame_t *frame );
79 void          x264_frame_init_lowres( int cpu, x264_frame_t *frame );
80
81 #endif