annotate h264_loopfilter.c @ 10936:b2ea6b0d17bf libavcodec

Update libx264.c to use new libx264 features With b_keyframe instead of IDR for detecting keyframes, ffmpeg should now support periodic encoding with periodic intra refresh (although there is no interface option for it yet). Set the new timebase values for full VFR input support. Bump configure to check for API version 83.
author darkshikari
date Tue, 19 Jan 2010 04:00:08 +0000
parents b847f02d5b03
children 5660eac25fb4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
1 /*
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
2 * H.26L/H.264/AVC/JVT/14496-10/... loop filter
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
3 * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
4 *
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
5 * This file is part of FFmpeg.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
6 *
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
11 *
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
15 * Lesser General Public License for more details.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
16 *
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
20 */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
21
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
22 /**
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
23 * @file libavcodec/h264_loopfilter.c
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
24 * H.264 / AVC / MPEG4 part10 loop filter.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
25 * @author Michael Niedermayer <michaelni@gmx.at>
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
26 */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
27
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
28 #include "internal.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
29 #include "dsputil.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
30 #include "avcodec.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
31 #include "mpegvideo.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
32 #include "h264.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
33 #include "mathops.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
34 #include "rectangle.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
35
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
36 //#undef NDEBUG
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
37 #include <assert.h>
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
38
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
39 /* Deblocking filter (p153) */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
40 static const uint8_t alpha_table[52*3] = {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
41 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
42 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
43 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
44 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
45 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
46 0, 0, 0, 0, 0, 0, 4, 4, 5, 6,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
47 7, 8, 9, 10, 12, 13, 15, 17, 20, 22,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
48 25, 28, 32, 36, 40, 45, 50, 56, 63, 71,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
49 80, 90,101,113,127,144,162,182,203,226,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
50 255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
51 255,255,255,255,255,255,255,255,255,255,255,255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
52 255,255,255,255,255,255,255,255,255,255,255,255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
53 255,255,255,255,255,255,255,255,255,255,255,255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
54 255,255,255,255,255,255,255,255,255,255,255,255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
55 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
56 static const uint8_t beta_table[52*3] = {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
57 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
58 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
59 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
60 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
61 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
62 0, 0, 0, 0, 0, 0, 2, 2, 2, 3,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
63 3, 3, 3, 4, 4, 4, 6, 6, 7, 7,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
64 8, 8, 9, 9, 10, 10, 11, 11, 12, 12,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
65 13, 13, 14, 14, 15, 15, 16, 16, 17, 17,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
66 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
67 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
68 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
69 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
70 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
71 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
72 static const uint8_t tc0_table[52*3][4] = {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
73 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
74 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
75 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
76 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
77 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
78 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
79 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
80 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
81 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
82 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
83 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
84 {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 0 }, {-1, 0, 0, 1 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
85 {-1, 0, 0, 1 }, {-1, 0, 0, 1 }, {-1, 0, 0, 1 }, {-1, 0, 1, 1 }, {-1, 0, 1, 1 }, {-1, 1, 1, 1 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
86 {-1, 1, 1, 1 }, {-1, 1, 1, 1 }, {-1, 1, 1, 1 }, {-1, 1, 1, 2 }, {-1, 1, 1, 2 }, {-1, 1, 1, 2 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
87 {-1, 1, 1, 2 }, {-1, 1, 2, 3 }, {-1, 1, 2, 3 }, {-1, 2, 2, 3 }, {-1, 2, 2, 4 }, {-1, 2, 3, 4 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
88 {-1, 2, 3, 4 }, {-1, 3, 3, 5 }, {-1, 3, 4, 6 }, {-1, 3, 4, 6 }, {-1, 4, 5, 7 }, {-1, 4, 5, 8 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
89 {-1, 4, 6, 9 }, {-1, 5, 7,10 }, {-1, 6, 8,11 }, {-1, 6, 8,13 }, {-1, 7,10,14 }, {-1, 8,11,16 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
90 {-1, 9,12,18 }, {-1,10,13,20 }, {-1,11,15,23 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
91 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
92 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
93 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
94 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
95 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
96 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
97 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
98 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
99 {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
100 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
101
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
102 static void av_noinline filter_mb_edgev( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
103 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
104 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
105 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
106 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
107
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
108 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
109 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
110 tc[0] = (tc0_table+52)[index_a][bS[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
111 tc[1] = (tc0_table+52)[index_a][bS[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
112 tc[2] = (tc0_table+52)[index_a][bS[2]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
113 tc[3] = (tc0_table+52)[index_a][bS[3]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
114 h->s.dsp.h264_h_loop_filter_luma(pix, stride, alpha, beta, tc);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
115 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
116 h->s.dsp.h264_h_loop_filter_luma_intra(pix, stride, alpha, beta);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
117 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
118 }
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
119 static void av_noinline filter_mb_edgecv( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
120 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
121 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
122 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
123 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
124
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
125 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
126 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
127 tc[0] = (tc0_table+52)[index_a][bS[0]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
128 tc[1] = (tc0_table+52)[index_a][bS[1]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
129 tc[2] = (tc0_table+52)[index_a][bS[2]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
130 tc[3] = (tc0_table+52)[index_a][bS[3]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
131 h->s.dsp.h264_h_loop_filter_chroma(pix, stride, alpha, beta, tc);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
132 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
133 h->s.dsp.h264_h_loop_filter_chroma_intra(pix, stride, alpha, beta);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
134 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
135 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
136
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
137 static void filter_mb_mbaff_edgev( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int bsi, int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
138 int i;
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
139 for( i = 0; i < 8; i++, pix += stride) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
140 int index_a;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
141 int alpha;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
142 int beta;
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
143 const int bS_index = (i >> 1) * bsi;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
144
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
145 if( bS[bS_index] == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
146 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
147 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
148
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
149 index_a = qp + h->slice_alpha_c0_offset;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
150 alpha = (alpha_table+52)[index_a];
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
151 beta = (beta_table+52)[qp + h->slice_beta_offset];
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
152
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
153 if( bS[bS_index] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
154 const int tc0 = (tc0_table+52)[index_a][bS[bS_index]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
155 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
156 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
157 const int p2 = pix[-3];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
158 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
159 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
160 const int q2 = pix[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
161
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
162 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
163 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
164 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
165 int tc = tc0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
166 int i_delta;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
167
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
168 if( FFABS( p2 - p0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
169 pix[-2] = p1 + av_clip( ( p2 + ( ( p0 + q0 + 1 ) >> 1 ) - ( p1 << 1 ) ) >> 1, -tc0, tc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
170 tc++;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
171 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
172 if( FFABS( q2 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
173 pix[1] = q1 + av_clip( ( q2 + ( ( p0 + q0 + 1 ) >> 1 ) - ( q1 << 1 ) ) >> 1, -tc0, tc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
174 tc++;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
175 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
176
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
177 i_delta = av_clip( (((q0 - p0 ) << 2) + (p1 - q1) + 4) >> 3, -tc, tc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
178 pix[-1] = av_clip_uint8( p0 + i_delta ); /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
179 pix[0] = av_clip_uint8( q0 - i_delta ); /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
180 tprintf(h->s.avctx, "filter_mb_mbaff_edgev i:%d, qp:%d, indexA:%d, alpha:%d, beta:%d, tc:%d\n# bS:%d -> [%02x, %02x, %02x, %02x, %02x, %02x] =>[%02x, %02x, %02x, %02x]\n", i, qp[qp_index], index_a, alpha, beta, tc, bS[bS_index], pix[-3], p1, p0, q0, q1, pix[2], p1, pix[-1], pix[0], q1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
181 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
182 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
183 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
184 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
185 const int p2 = pix[-3];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
186
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
187 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
188 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
189 const int q2 = pix[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
190
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
191 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
192 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
193 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
194
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
195 if(FFABS( p0 - q0 ) < (( alpha >> 2 ) + 2 )){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
196 if( FFABS( p2 - p0 ) < beta)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
197 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
198 const int p3 = pix[-4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
199 /* p0', p1', p2' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
200 pix[-1] = ( p2 + 2*p1 + 2*p0 + 2*q0 + q1 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
201 pix[-2] = ( p2 + p1 + p0 + q0 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
202 pix[-3] = ( 2*p3 + 3*p2 + p1 + p0 + q0 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
203 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
204 /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
205 pix[-1] = ( 2*p1 + p0 + q1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
206 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
207 if( FFABS( q2 - q0 ) < beta)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
208 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
209 const int q3 = pix[3];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
210 /* q0', q1', q2' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
211 pix[0] = ( p1 + 2*p0 + 2*q0 + 2*q1 + q2 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
212 pix[1] = ( p0 + q0 + q1 + q2 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
213 pix[2] = ( 2*q3 + 3*q2 + q1 + q0 + p0 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
214 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
215 /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
216 pix[0] = ( 2*q1 + q0 + p1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
217 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
218 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
219 /* p0', q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
220 pix[-1] = ( 2*p1 + p0 + q1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
221 pix[ 0] = ( 2*q1 + q0 + p1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
222 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
223 tprintf(h->s.avctx, "filter_mb_mbaff_edgev i:%d, qp:%d, indexA:%d, alpha:%d, beta:%d\n# bS:4 -> [%02x, %02x, %02x, %02x, %02x, %02x] =>[%02x, %02x, %02x, %02x, %02x, %02x]\n", i, qp[qp_index], index_a, alpha, beta, p2, p1, p0, q0, q1, q2, pix[-3], pix[-2], pix[-1], pix[0], pix[1], pix[2]);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
224 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
225 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
226 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
227 }
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
228 static void filter_mb_mbaff_edgecv( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int bsi, int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
229 int i;
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
230 for( i = 0; i < 4; i++, pix += stride) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
231 int index_a;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
232 int alpha;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
233 int beta;
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
234 const int bS_index = i*bsi;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
235
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
236 if( bS[bS_index] == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
237 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
238 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
239
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
240 index_a = qp + h->slice_alpha_c0_offset;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
241 alpha = (alpha_table+52)[index_a];
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
242 beta = (beta_table+52)[qp + h->slice_beta_offset];
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
243
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
244 if( bS[bS_index] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
245 const int tc = (tc0_table+52)[index_a][bS[bS_index]] + 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
246 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
247 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
248 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
249 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
250
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
251 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
252 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
253 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
254 const int i_delta = av_clip( (((q0 - p0 ) << 2) + (p1 - q1) + 4) >> 3, -tc, tc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
255
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
256 pix[-1] = av_clip_uint8( p0 + i_delta ); /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
257 pix[0] = av_clip_uint8( q0 - i_delta ); /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
258 tprintf(h->s.avctx, "filter_mb_mbaff_edgecv i:%d, qp:%d, indexA:%d, alpha:%d, beta:%d, tc:%d\n# bS:%d -> [%02x, %02x, %02x, %02x, %02x, %02x] =>[%02x, %02x, %02x, %02x]\n", i, qp[qp_index], index_a, alpha, beta, tc, bS[bS_index], pix[-3], p1, p0, q0, q1, pix[2], p1, pix[-1], pix[0], q1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
259 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
260 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
261 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
262 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
263 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
264 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
265
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
266 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
267 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
268 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
269
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
270 pix[-1] = ( 2*p1 + p0 + q1 + 2 ) >> 2; /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
271 pix[0] = ( 2*q1 + q0 + p1 + 2 ) >> 2; /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
272 tprintf(h->s.avctx, "filter_mb_mbaff_edgecv i:%d\n# bS:4 -> [%02x, %02x, %02x, %02x, %02x, %02x] =>[%02x, %02x, %02x, %02x, %02x, %02x]\n", i, pix[-3], p1, p0, q0, q1, pix[2], pix[-3], pix[-2], pix[-1], pix[0], pix[1], pix[2]);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
273 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
274 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
275 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
276 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
277
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
278 static void av_noinline filter_mb_edgeh( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
279 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
280 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
281 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
282 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
283
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
284 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
285 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
286 tc[0] = (tc0_table+52)[index_a][bS[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
287 tc[1] = (tc0_table+52)[index_a][bS[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
288 tc[2] = (tc0_table+52)[index_a][bS[2]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
289 tc[3] = (tc0_table+52)[index_a][bS[3]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
290 h->s.dsp.h264_v_loop_filter_luma(pix, stride, alpha, beta, tc);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
291 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
292 h->s.dsp.h264_v_loop_filter_luma_intra(pix, stride, alpha, beta);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
293 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
294 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
295
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
296 static void av_noinline filter_mb_edgech( H264Context *h, uint8_t *pix, int stride, int16_t bS[4], int qp ) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
297 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
298 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
299 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
300 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
301
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
302 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
303 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
304 tc[0] = (tc0_table+52)[index_a][bS[0]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
305 tc[1] = (tc0_table+52)[index_a][bS[1]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
306 tc[2] = (tc0_table+52)[index_a][bS[2]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
307 tc[3] = (tc0_table+52)[index_a][bS[3]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
308 h->s.dsp.h264_v_loop_filter_chroma(pix, stride, alpha, beta, tc);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
309 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
310 h->s.dsp.h264_v_loop_filter_chroma_intra(pix, stride, alpha, beta);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
311 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
312 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
313
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
314 void ff_h264_filter_mb_fast( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
315 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
316 int mb_y_firstrow = s->picture_structure == PICT_BOTTOM_FIELD;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
317 int mb_xy, mb_type;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
318 int qp, qp0, qp1, qpc, qpc0, qpc1, qp_thresh;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
319
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
320 mb_xy = h->mb_xy;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
321
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
322 if(mb_x==0 || mb_y==mb_y_firstrow || !s->dsp.h264_loop_filter_strength || h->pps.chroma_qp_diff ||
10918
f36f33e673b4 Reenable filter_mb_fast for I slices and progressive CABAC P slices.
michael
parents: 10914
diff changeset
323 !(h->slice_type_nos == FF_I_TYPE ||
10921
6d4f65057d0d Enable filter_mb_fast for CAVLC P slices.
michael
parents: 10919
diff changeset
324 h->slice_type_nos == FF_P_TYPE ||
10918
f36f33e673b4 Reenable filter_mb_fast for I slices and progressive CABAC P slices.
michael
parents: 10914
diff changeset
325 (s->flags2 & CODEC_FLAG2_FAST)) ||
10922
8945125b5ae6 Use h->slice_num where possible.
michael
parents: 10921
diff changeset
326 (h->deblocking_filter == 2 && (h->slice_num != h->slice_table[h->top_mb_xy] ||
8945125b5ae6 Use h->slice_num where possible.
michael
parents: 10921
diff changeset
327 h->slice_num != h->slice_table[mb_xy - 1]))) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
328 ff_h264_filter_mb(h, mb_x, mb_y, img_y, img_cb, img_cr, linesize, uvlinesize);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
329 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
330 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
331 assert(!FRAME_MBAFF);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
332
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
333 mb_type = s->current_picture.mb_type[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
334 qp = s->current_picture.qscale_table[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
335 qp0 = s->current_picture.qscale_table[mb_xy-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
336 qp1 = s->current_picture.qscale_table[h->top_mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
337 qpc = get_chroma_qp( h, 0, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
338 qpc0 = get_chroma_qp( h, 0, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
339 qpc1 = get_chroma_qp( h, 0, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
340 qp0 = (qp + qp0 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
341 qp1 = (qp + qp1 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
342 qpc0 = (qpc + qpc0 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
343 qpc1 = (qpc + qpc1 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
344 qp_thresh = 15 - h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
345 if(qp <= qp_thresh && qp0 <= qp_thresh && qp1 <= qp_thresh &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
346 qpc <= qp_thresh && qpc0 <= qp_thresh && qpc1 <= qp_thresh)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
347 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
348
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
349 if( IS_INTRA(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
350 int16_t bS4[4] = {4,4,4,4};
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
351 int16_t bS3[4] = {3,3,3,3};
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
352 int16_t *bSH = FIELD_PICTURE ? bS3 : bS4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
353 if( IS_8x8DCT(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
354 filter_mb_edgev( h, &img_y[4*0], linesize, bS4, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
355 filter_mb_edgev( h, &img_y[4*2], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
356 filter_mb_edgeh( h, &img_y[4*0*linesize], linesize, bSH, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
357 filter_mb_edgeh( h, &img_y[4*2*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
358 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
359 filter_mb_edgev( h, &img_y[4*0], linesize, bS4, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
360 filter_mb_edgev( h, &img_y[4*1], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
361 filter_mb_edgev( h, &img_y[4*2], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
362 filter_mb_edgev( h, &img_y[4*3], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
363 filter_mb_edgeh( h, &img_y[4*0*linesize], linesize, bSH, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
364 filter_mb_edgeh( h, &img_y[4*1*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
365 filter_mb_edgeh( h, &img_y[4*2*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
366 filter_mb_edgeh( h, &img_y[4*3*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
367 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
368 filter_mb_edgecv( h, &img_cb[2*0], uvlinesize, bS4, qpc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
369 filter_mb_edgecv( h, &img_cb[2*2], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
370 filter_mb_edgecv( h, &img_cr[2*0], uvlinesize, bS4, qpc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
371 filter_mb_edgecv( h, &img_cr[2*2], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
372 filter_mb_edgech( h, &img_cb[2*0*uvlinesize], uvlinesize, bSH, qpc1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
373 filter_mb_edgech( h, &img_cb[2*2*uvlinesize], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
374 filter_mb_edgech( h, &img_cr[2*0*uvlinesize], uvlinesize, bSH, qpc1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
375 filter_mb_edgech( h, &img_cr[2*2*uvlinesize], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
376 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
377 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
378 DECLARE_ALIGNED_8(int16_t, bS[2][4][4]);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
379 uint64_t (*bSv)[4] = (uint64_t(*)[4])bS;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
380 int edges;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
381 if( IS_8x8DCT(mb_type) && (h->cbp&7) == 7 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
382 edges = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
383 bSv[0][0] = bSv[0][2] = bSv[1][0] = bSv[1][2] = 0x0002000200020002ULL;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
384 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
385 int mask_edge1 = (mb_type & (MB_TYPE_16x16 | MB_TYPE_8x16)) ? 3 :
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
386 (mb_type & MB_TYPE_16x8) ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
387 int mask_edge0 = (mb_type & (MB_TYPE_16x16 | MB_TYPE_8x16))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
388 && (s->current_picture.mb_type[mb_xy-1] & (MB_TYPE_16x16 | MB_TYPE_8x16))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
389 ? 3 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
390 int step = IS_8x8DCT(mb_type) ? 2 : 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
391 edges = (mb_type & MB_TYPE_16x16) && !(h->cbp & 15) ? 1 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
392 s->dsp.h264_loop_filter_strength( bS, h->non_zero_count_cache, h->ref_cache, h->mv_cache,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
393 (h->slice_type_nos == FF_B_TYPE), edges, step, mask_edge0, mask_edge1, FIELD_PICTURE);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
394 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
395 if( IS_INTRA(s->current_picture.mb_type[mb_xy-1]) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
396 bSv[0][0] = 0x0004000400040004ULL;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
397 if( IS_INTRA(s->current_picture.mb_type[h->top_mb_xy]) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
398 bSv[1][0] = FIELD_PICTURE ? 0x0003000300030003ULL : 0x0004000400040004ULL;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
399
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
400 #define FILTER(hv,dir,edge)\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
401 if(bSv[dir][edge]) {\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
402 filter_mb_edge##hv( h, &img_y[4*edge*(dir?linesize:1)], linesize, bS[dir][edge], edge ? qp : qp##dir );\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
403 if(!(edge&1)) {\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
404 filter_mb_edgec##hv( h, &img_cb[2*edge*(dir?uvlinesize:1)], uvlinesize, bS[dir][edge], edge ? qpc : qpc##dir );\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
405 filter_mb_edgec##hv( h, &img_cr[2*edge*(dir?uvlinesize:1)], uvlinesize, bS[dir][edge], edge ? qpc : qpc##dir );\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
406 }\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
407 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
408 if( edges == 1 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
409 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
410 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
411 } else if( IS_8x8DCT(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
412 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
413 FILTER(v,0,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
414 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
415 FILTER(h,1,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
416 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
417 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
418 FILTER(v,0,1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
419 FILTER(v,0,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
420 FILTER(v,0,3);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
421 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
422 FILTER(h,1,1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
423 FILTER(h,1,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
424 FILTER(h,1,3);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
425 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
426 #undef FILTER
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
427 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
428 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
429
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
430
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
431 static av_always_inline void filter_mb_dir(H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize, int mb_xy, int mb_type, int mvy_limit, int first_vertical_edge_done, int dir) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
432 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
433 int edge;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
434 const int mbm_xy = dir == 0 ? mb_xy -1 : h->top_mb_xy;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
435 const int mbm_type = s->current_picture.mb_type[mbm_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
436 int start = h->slice_table[mbm_xy] == 0xFFFF ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
437
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
438 const int edges = (mb_type & (MB_TYPE_16x16|MB_TYPE_SKIP))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
439 == (MB_TYPE_16x16|MB_TYPE_SKIP) ? 1 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
440 // how often to recheck mv-based bS when iterating between edges
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
441 const int mask_edge = (mb_type & (MB_TYPE_16x16 | (MB_TYPE_16x8 << dir))) ? 3 :
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
442 (mb_type & (MB_TYPE_8x16 >> dir)) ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
443 // how often to recheck mv-based bS when iterating along each edge
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
444 const int mask_par0 = mb_type & (MB_TYPE_16x16 | (MB_TYPE_8x16 >> dir));
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
445
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
446 if (first_vertical_edge_done) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
447 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
448 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
449
10922
8945125b5ae6 Use h->slice_num where possible.
michael
parents: 10921
diff changeset
450 if (h->deblocking_filter==2 && h->slice_table[mbm_xy] != h->slice_num)
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
451 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
452
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
453 if (FRAME_MBAFF && (dir == 1) && ((mb_y&1) == 0) && start == 0
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
454 && !IS_INTERLACED(mb_type)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
455 && IS_INTERLACED(mbm_type)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
456 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
457 // This is a special case in the norm where the filtering must
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
458 // be done twice (one each of the field) even if we are in a
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
459 // frame macroblock.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
460 //
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
461 unsigned int tmp_linesize = 2 * linesize;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
462 unsigned int tmp_uvlinesize = 2 * uvlinesize;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
463 int mbn_xy = mb_xy - 2 * s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
464 int qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
465 int i, j;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
466 int16_t bS[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
467
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
468 for(j=0; j<2; j++, mbn_xy += s->mb_stride){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
469 if( IS_INTRA(mb_type) ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
470 IS_INTRA(s->current_picture.mb_type[mbn_xy]) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
471 bS[0] = bS[1] = bS[2] = bS[3] = 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
472 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
473 const uint8_t *mbn_nnz = h->non_zero_count[mbn_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
474 for( i = 0; i < 4; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
475 if( h->non_zero_count_cache[scan8[0]+i] != 0 ||
10909
f4cf3960b8c6 Reorganize how values are stored in h->non_zero_count.
michael
parents: 10906
diff changeset
476 mbn_nnz[i+4+3*8] != 0 )
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
477 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
478 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
479 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
480 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
481 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
482 // Do not use s->qscale as luma quantizer because it has not the same
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
483 // value in IPCM macroblocks.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
484 qp = ( s->current_picture.qscale_table[mb_xy] + s->current_picture.qscale_table[mbn_xy] + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
485 tprintf(s->avctx, "filter mb:%d/%d dir:%d edge:%d, QPy:%d ls:%d uvls:%d", mb_x, mb_y, dir, edge, qp, tmp_linesize, tmp_uvlinesize);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
486 { int i; for (i = 0; i < 4; i++) tprintf(s->avctx, " bS[%d]:%d", i, bS[i]); tprintf(s->avctx, "\n"); }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
487 filter_mb_edgeh( h, &img_y[j*linesize], tmp_linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
488 filter_mb_edgech( h, &img_cb[j*uvlinesize], tmp_uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
489 ( h->chroma_qp[0] + get_chroma_qp( h, 0, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
490 filter_mb_edgech( h, &img_cr[j*uvlinesize], tmp_uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
491 ( h->chroma_qp[1] + get_chroma_qp( h, 1, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
492 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
493
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
494 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
495 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
496
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
497 /* Calculate bS */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
498 for( edge = start; edge < edges; edge++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
499 /* mbn_xy: neighbor macroblock */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
500 const int mbn_xy = edge > 0 ? mb_xy : mbm_xy;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
501 const int mbn_type = s->current_picture.mb_type[mbn_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
502 int16_t bS[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
503 int qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
504
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
505 if( (edge&1) && IS_8x8DCT(mb_type) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
506 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
507
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
508 if( IS_INTRA(mb_type) ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
509 IS_INTRA(mbn_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
510 int value;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
511 if (edge == 0) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
512 if ( (!IS_INTERLACED(mb_type) && !IS_INTERLACED(mbm_type))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
513 || ((FRAME_MBAFF || (s->picture_structure != PICT_FRAME)) && (dir == 0))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
514 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
515 value = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
516 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
517 value = 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
518 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
519 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
520 value = 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
521 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
522 bS[0] = bS[1] = bS[2] = bS[3] = value;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
523 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
524 int i, l;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
525 int mv_done;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
526
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
527 if( edge & mask_edge ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
528 bS[0] = bS[1] = bS[2] = bS[3] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
529 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
530 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
531 else if( FRAME_MBAFF && IS_INTERLACED(mb_type ^ mbn_type)) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
532 bS[0] = bS[1] = bS[2] = bS[3] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
533 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
534 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
535 else if( mask_par0 && (edge || (mbn_type & (MB_TYPE_16x16 | (MB_TYPE_8x16 >> dir)))) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
536 int b_idx= 8 + 4 + edge * (dir ? 8:1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
537 int bn_idx= b_idx - (dir ? 8:1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
538 int v = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
539
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
540 for( l = 0; !v && l < 1 + (h->slice_type_nos == FF_B_TYPE); l++ ) {
10913
497929e9d912 Perform reference remapping at fill_cache() time instead of in the
michael
parents: 10910
diff changeset
541 v |= h->ref_cache[l][b_idx] != h->ref_cache[l][bn_idx] |
10901
2a5c3d89201d Another microopt, 4 cpu cycles for avoidance of FFABS().
michael
parents: 10899
diff changeset
542 h->mv_cache[l][b_idx][0] - h->mv_cache[l][bn_idx][0] + 3 >= 7U |
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
543 FFABS( h->mv_cache[l][b_idx][1] - h->mv_cache[l][bn_idx][1] ) >= mvy_limit;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
544 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
545
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
546 if(h->slice_type_nos == FF_B_TYPE && v){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
547 v=0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
548 for( l = 0; !v && l < 2; l++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
549 int ln= 1-l;
10913
497929e9d912 Perform reference remapping at fill_cache() time instead of in the
michael
parents: 10910
diff changeset
550 v |= h->ref_cache[l][b_idx] != h->ref_cache[ln][bn_idx] |
10901
2a5c3d89201d Another microopt, 4 cpu cycles for avoidance of FFABS().
michael
parents: 10899
diff changeset
551 h->mv_cache[l][b_idx][0] - h->mv_cache[ln][bn_idx][0] + 3 >= 7U |
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
552 FFABS( h->mv_cache[l][b_idx][1] - h->mv_cache[ln][bn_idx][1] ) >= mvy_limit;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
553 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
554 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
555
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
556 bS[0] = bS[1] = bS[2] = bS[3] = v;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
557 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
558 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
559 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
560 mv_done = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
561
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
562 for( i = 0; i < 4; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
563 int x = dir == 0 ? edge : i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
564 int y = dir == 0 ? i : edge;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
565 int b_idx= 8 + 4 + x + 8*y;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
566 int bn_idx= b_idx - (dir ? 8:1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
567
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
568 if( h->non_zero_count_cache[b_idx] |
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
569 h->non_zero_count_cache[bn_idx] ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
570 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
571 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
572 else if(!mv_done)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
573 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
574 bS[i] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
575 for( l = 0; l < 1 + (h->slice_type_nos == FF_B_TYPE); l++ ) {
10913
497929e9d912 Perform reference remapping at fill_cache() time instead of in the
michael
parents: 10910
diff changeset
576 if( h->ref_cache[l][b_idx] != h->ref_cache[l][bn_idx] |
10902
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
577 h->mv_cache[l][b_idx][0] - h->mv_cache[l][bn_idx][0] + 3 >= 7U |
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
578 FFABS( h->mv_cache[l][b_idx][1] - h->mv_cache[l][bn_idx][1] ) >= mvy_limit ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
579 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
580 break;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
581 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
582 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
583
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
584 if(h->slice_type_nos == FF_B_TYPE && bS[i]){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
585 bS[i] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
586 for( l = 0; l < 2; l++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
587 int ln= 1-l;
10913
497929e9d912 Perform reference remapping at fill_cache() time instead of in the
michael
parents: 10910
diff changeset
588 if( h->ref_cache[l][b_idx] != h->ref_cache[ln][bn_idx] |
10902
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
589 h->mv_cache[l][b_idx][0] - h->mv_cache[ln][bn_idx][0] + 3 >= 7U |
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
590 FFABS( h->mv_cache[l][b_idx][1] - h->mv_cache[ln][bn_idx][1] ) >= mvy_limit ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
591 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
592 break;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
593 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
594 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
595 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
596 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
597 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
598
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
599 if(bS[0]+bS[1]+bS[2]+bS[3] == 0)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
600 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
601 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
602
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
603 /* Filter edge */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
604 // Do not use s->qscale as luma quantizer because it has not the same
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
605 // value in IPCM macroblocks.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
606 qp = ( s->current_picture.qscale_table[mb_xy] + s->current_picture.qscale_table[mbn_xy] + 1 ) >> 1;
10906
1b5fba731e24 Rearchitecturing the stiched up goose part 1
michael
parents: 10904
diff changeset
607 //tprintf(s->avctx, "filter mb:%d/%d dir:%d edge:%d, QPy:%d, QPc:%d, QPcn:%d\n", mb_x, mb_y, dir, edge, qp, h->chroma_qp[0], s->current_picture.qscale_table[mbn_xy]);
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
608 tprintf(s->avctx, "filter mb:%d/%d dir:%d edge:%d, QPy:%d ls:%d uvls:%d", mb_x, mb_y, dir, edge, qp, linesize, uvlinesize);
10904
b30aef0c693f Comment for() ; out
michael
parents: 10903
diff changeset
609 //{ int i; for (i = 0; i < 4; i++) tprintf(s->avctx, " bS[%d]:%d", i, bS[i]); tprintf(s->avctx, "\n"); }
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
610 if( dir == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
611 filter_mb_edgev( h, &img_y[4*edge], linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
612 if( (edge&1) == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
613 filter_mb_edgecv( h, &img_cb[2*edge], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
614 ( h->chroma_qp[0] + get_chroma_qp( h, 0, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
615 filter_mb_edgecv( h, &img_cr[2*edge], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
616 ( h->chroma_qp[1] + get_chroma_qp( h, 1, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
617 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
618 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
619 filter_mb_edgeh( h, &img_y[4*edge*linesize], linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
620 if( (edge&1) == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
621 filter_mb_edgech( h, &img_cb[2*edge*uvlinesize], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
622 ( h->chroma_qp[0] + get_chroma_qp( h, 0, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
623 filter_mb_edgech( h, &img_cr[2*edge*uvlinesize], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
624 ( h->chroma_qp[1] + get_chroma_qp( h, 1, s->current_picture.qscale_table[mbn_xy] ) + 1 ) >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
625 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
626 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
627 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
628 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
629
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
630 void ff_h264_filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
631 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
632 const int mb_xy= mb_x + mb_y*s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
633 const int mb_type = s->current_picture.mb_type[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
634 const int mvy_limit = IS_INTERLACED(mb_type) ? 2 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
635 int first_vertical_edge_done = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
636 av_unused int dir;
10906
1b5fba731e24 Rearchitecturing the stiched up goose part 1
michael
parents: 10904
diff changeset
637 int list;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
638
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
639 if (FRAME_MBAFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
640 // left mb is in picture
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
641 && h->slice_table[mb_xy-1] != 0xFFFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
642 // and current and left pair do not have the same interlaced type
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
643 && (IS_INTERLACED(mb_type) != IS_INTERLACED(s->current_picture.mb_type[mb_xy-1]))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
644 // and left mb is in the same slice if deblocking_filter == 2
10922
8945125b5ae6 Use h->slice_num where possible.
michael
parents: 10921
diff changeset
645 && (h->deblocking_filter!=2 || h->slice_table[mb_xy-1] == h->slice_num)) {
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
646 /* First vertical edge is different in MBAFF frames
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
647 * There are 8 different bS to compute and 2 different Qp
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
648 */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
649 const int pair_xy = mb_x + (mb_y&~1)*s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
650 const int left_mb_xy[2] = { pair_xy-1, pair_xy-1+s->mb_stride };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
651 int16_t bS[8];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
652 int qp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
653 int bqp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
654 int rqp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
655 int mb_qp, mbn0_qp, mbn1_qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
656 int i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
657 first_vertical_edge_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
658
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
659 if( IS_INTRA(mb_type) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
660 bS[0] = bS[1] = bS[2] = bS[3] = bS[4] = bS[5] = bS[6] = bS[7] = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
661 else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
662 for( i = 0; i < 8; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
663 int mbn_xy = MB_FIELD ? left_mb_xy[i>>2] : left_mb_xy[i&1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
664
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
665 if( IS_INTRA( s->current_picture.mb_type[mbn_xy] ) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
666 bS[i] = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
667 else if( h->non_zero_count_cache[12+8*(i>>1)] != 0 ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
668 ((!h->pps.cabac && IS_8x8DCT(s->current_picture.mb_type[mbn_xy])) ?
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
669 (h->cbp_table[mbn_xy] & ((MB_FIELD ? (i&2) : (mb_y&1)) ? 8 : 2))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
670 :
10909
f4cf3960b8c6 Reorganize how values are stored in h->non_zero_count.
michael
parents: 10906
diff changeset
671 h->non_zero_count[mbn_xy][7+(MB_FIELD ? (i&3) : (i>>2)+(mb_y&1)*2)*8]))
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
672 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
673 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
674 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
675 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
676 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
677
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
678 mb_qp = s->current_picture.qscale_table[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
679 mbn0_qp = s->current_picture.qscale_table[left_mb_xy[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
680 mbn1_qp = s->current_picture.qscale_table[left_mb_xy[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
681 qp[0] = ( mb_qp + mbn0_qp + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
682 bqp[0] = ( get_chroma_qp( h, 0, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
683 get_chroma_qp( h, 0, mbn0_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
684 rqp[0] = ( get_chroma_qp( h, 1, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
685 get_chroma_qp( h, 1, mbn0_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
686 qp[1] = ( mb_qp + mbn1_qp + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
687 bqp[1] = ( get_chroma_qp( h, 0, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
688 get_chroma_qp( h, 0, mbn1_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
689 rqp[1] = ( get_chroma_qp( h, 1, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
690 get_chroma_qp( h, 1, mbn1_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
691
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
692 /* Filter edge */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
693 tprintf(s->avctx, "filter mb:%d/%d MBAFF, QPy:%d/%d, QPb:%d/%d QPr:%d/%d ls:%d uvls:%d", mb_x, mb_y, qp[0], qp[1], bqp[0], bqp[1], rqp[0], rqp[1], linesize, uvlinesize);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
694 { int i; for (i = 0; i < 8; i++) tprintf(s->avctx, " bS[%d]:%d", i, bS[i]); tprintf(s->avctx, "\n"); }
10924
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
695 if(MB_FIELD){
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
696 filter_mb_mbaff_edgev ( h, img_y , linesize, bS , 1, qp [0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
697 filter_mb_mbaff_edgev ( h, img_y + 8* linesize, linesize, bS+4, 1, qp [1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
698 filter_mb_mbaff_edgecv( h, img_cb, uvlinesize, bS , 1, bqp[0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
699 filter_mb_mbaff_edgecv( h, img_cb + 4*uvlinesize, uvlinesize, bS+4, 1, bqp[1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
700 filter_mb_mbaff_edgecv( h, img_cr, uvlinesize, bS , 1, rqp[0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
701 filter_mb_mbaff_edgecv( h, img_cr + 4*uvlinesize, uvlinesize, bS+4, 1, rqp[1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
702 }else{
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
703 filter_mb_mbaff_edgev ( h, img_y , 2* linesize, bS , 2, qp [0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
704 filter_mb_mbaff_edgev ( h, img_y + linesize, 2* linesize, bS+1, 2, qp [1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
705 filter_mb_mbaff_edgecv( h, img_cb, 2*uvlinesize, bS , 2, bqp[0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
706 filter_mb_mbaff_edgecv( h, img_cb + uvlinesize, 2*uvlinesize, bS+1, 2, bqp[1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
707 filter_mb_mbaff_edgecv( h, img_cr, 2*uvlinesize, bS , 2, rqp[0] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
708 filter_mb_mbaff_edgecv( h, img_cr + uvlinesize, 2*uvlinesize, bS+1, 2, rqp[1] );
fb0307a3355e Rather call filter_mb_mbaff_edge*v() more often than do extra calculations
michael
parents: 10922
diff changeset
709 }
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
710 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
711
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
712 #if CONFIG_SMALL
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
713 for( dir = 0; dir < 2; dir++ )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
714 filter_mb_dir(h, mb_x, mb_y, img_y, img_cb, img_cr, linesize, uvlinesize, mb_xy, mb_type, mvy_limit, dir ? 0 : first_vertical_edge_done, dir);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
715 #else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
716 filter_mb_dir(h, mb_x, mb_y, img_y, img_cb, img_cr, linesize, uvlinesize, mb_xy, mb_type, mvy_limit, first_vertical_edge_done, 0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
717 filter_mb_dir(h, mb_x, mb_y, img_y, img_cb, img_cr, linesize, uvlinesize, mb_xy, mb_type, mvy_limit, 0, 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
718 #endif
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
719 }