annotate h264_loopfilter.c @ 10904:b30aef0c693f libavcodec

Comment for() ; out ~200 bytes smaller ff_h264_filter_mb() please everyone, NEVER add code with the assumtation that gcc will remove it without checking gcc actually does. Chances are it does not.
author michael
date Sat, 16 Jan 2010 17:41:40 +0000
parents 8c8321b94c35
children 1b5fba731e24
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 #if ARCH_X86
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
37 #include "x86/h264_i386.h"
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
38 #endif
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
39
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
40 //#undef NDEBUG
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
41 #include <assert.h>
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
42
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
43 /* Deblocking filter (p153) */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
44 static const uint8_t alpha_table[52*3] = {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
45 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
46 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
47 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
48 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
49 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
50 0, 0, 0, 0, 0, 0, 4, 4, 5, 6,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
51 7, 8, 9, 10, 12, 13, 15, 17, 20, 22,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
52 25, 28, 32, 36, 40, 45, 50, 56, 63, 71,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
53 80, 90,101,113,127,144,162,182,203,226,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
54 255,255,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
55 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
56 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
57 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
58 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
59 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
60 static const uint8_t beta_table[52*3] = {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
61 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
62 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
63 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
64 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
65 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
66 0, 0, 0, 0, 0, 0, 2, 2, 2, 3,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
67 3, 3, 3, 4, 4, 4, 6, 6, 7, 7,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
68 8, 8, 9, 9, 10, 10, 11, 11, 12, 12,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
69 13, 13, 14, 14, 15, 15, 16, 16, 17, 17,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
70 18, 18,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
71 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
72 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
73 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
74 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
75 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
76 static const uint8_t tc0_table[52*3][4] = {
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 }, {-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, 0 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
85 {-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
86 {-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
87 {-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
88 {-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
89 {-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
90 {-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
91 {-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
92 {-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
93 {-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
94 {-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
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 }, {-1,13,17,25 }, {-1,13,17,25 },
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
100 {-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
101 {-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
102 {-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
103 {-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
104 };
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
105
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
106 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
107 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
108 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
109 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
110 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
111
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
112 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
113 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
114 tc[0] = (tc0_table+52)[index_a][bS[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
115 tc[1] = (tc0_table+52)[index_a][bS[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
116 tc[2] = (tc0_table+52)[index_a][bS[2]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
117 tc[3] = (tc0_table+52)[index_a][bS[3]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
118 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
119 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
120 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
121 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
122 }
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
123 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
124 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
125 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
126 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
127 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
128
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
129 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
130 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
131 tc[0] = (tc0_table+52)[index_a][bS[0]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
132 tc[1] = (tc0_table+52)[index_a][bS[1]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
133 tc[2] = (tc0_table+52)[index_a][bS[2]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
134 tc[3] = (tc0_table+52)[index_a][bS[3]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
135 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
136 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
137 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
138 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
139 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
140
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
141 static void filter_mb_mbaff_edgev( H264Context *h, uint8_t *pix, int stride, int16_t bS[8], int qp[2] ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
142 int i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
143 for( i = 0; i < 16; i++, pix += stride) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
144 int index_a;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
145 int alpha;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
146 int beta;
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 int qp_index;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
149 int bS_index = (i >> 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
150 if (!MB_FIELD) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
151 bS_index &= ~1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
152 bS_index |= (i & 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
153 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
154
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
155 if( bS[bS_index] == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
156 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
157 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
158
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
159 qp_index = MB_FIELD ? (i >> 3) : (i & 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
160 index_a = qp[qp_index] + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
161 alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
162 beta = (beta_table+52)[qp[qp_index] + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
163
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
164 if( bS[bS_index] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
165 const int tc0 = (tc0_table+52)[index_a][bS[bS_index]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
166 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
167 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
168 const int p2 = pix[-3];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
169 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
170 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
171 const int q2 = pix[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
172
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
173 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
174 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
175 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
176 int tc = tc0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
177 int i_delta;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
178
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
179 if( FFABS( p2 - p0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
180 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
181 tc++;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
182 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
183 if( FFABS( q2 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
184 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
185 tc++;
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
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
188 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
189 pix[-1] = av_clip_uint8( p0 + i_delta ); /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
190 pix[0] = av_clip_uint8( q0 - i_delta ); /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
191 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
192 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
193 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
194 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
195 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
196 const int p2 = pix[-3];
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 q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
199 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
200 const int q2 = pix[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
201
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
202 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
203 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
204 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
205
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
206 if(FFABS( p0 - q0 ) < (( alpha >> 2 ) + 2 )){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
207 if( FFABS( p2 - p0 ) < 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 p3 = pix[-4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
210 /* p0', p1', p2' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
211 pix[-1] = ( p2 + 2*p1 + 2*p0 + 2*q0 + q1 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
212 pix[-2] = ( p2 + p1 + p0 + q0 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
213 pix[-3] = ( 2*p3 + 3*p2 + p1 + p0 + q0 + 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 /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
216 pix[-1] = ( 2*p1 + p0 + q1 + 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 if( FFABS( q2 - q0 ) < beta)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
219 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
220 const int q3 = pix[3];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
221 /* q0', q1', q2' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
222 pix[0] = ( p1 + 2*p0 + 2*q0 + 2*q1 + q2 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
223 pix[1] = ( p0 + q0 + q1 + q2 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
224 pix[2] = ( 2*q3 + 3*q2 + q1 + q0 + p0 + 4 ) >> 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
225 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
226 /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
227 pix[0] = ( 2*q1 + q0 + p1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
228 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
229 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
230 /* p0', q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
231 pix[-1] = ( 2*p1 + p0 + q1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
232 pix[ 0] = ( 2*q1 + q0 + p1 + 2 ) >> 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
233 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
234 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
235 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
236 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
237 }
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 static void filter_mb_mbaff_edgecv( H264Context *h, uint8_t *pix, int stride, int16_t bS[8], int qp[2] ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
240 int i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
241 for( i = 0; i < 8; i++, pix += stride) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
242 int index_a;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
243 int alpha;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
244 int beta;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
245
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
246 int qp_index;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
247 int bS_index = i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
248
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
249 if( bS[bS_index] == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
250 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
251 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
252
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
253 qp_index = MB_FIELD ? (i >> 2) : (i & 1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
254 index_a = qp[qp_index] + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
255 alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
256 beta = (beta_table+52)[qp[qp_index] + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
257
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
258 if( bS[bS_index] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
259 const int tc = (tc0_table+52)[index_a][bS[bS_index]] + 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
260 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
261 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
262 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
263 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
264
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
265 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
266 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
267 FFABS( q1 - q0 ) < beta ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
268 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
269
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
270 pix[-1] = av_clip_uint8( p0 + i_delta ); /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
271 pix[0] = av_clip_uint8( q0 - i_delta ); /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
272 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
273 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
274 }else{
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
275 const int p0 = pix[-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
276 const int p1 = pix[-2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
277 const int q0 = pix[0];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
278 const int q1 = pix[1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
279
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
280 if( FFABS( p0 - q0 ) < alpha &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
281 FFABS( p1 - p0 ) < beta &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
282 FFABS( q1 - q0 ) < beta ) {
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 pix[-1] = ( 2*p1 + p0 + q1 + 2 ) >> 2; /* p0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
285 pix[0] = ( 2*q1 + q0 + p1 + 2 ) >> 2; /* q0' */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
286 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
287 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
288 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
289 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
290 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
291
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
292 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
293 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
294 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
295 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
296 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
297
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
298 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
299 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
300 tc[0] = (tc0_table+52)[index_a][bS[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
301 tc[1] = (tc0_table+52)[index_a][bS[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
302 tc[2] = (tc0_table+52)[index_a][bS[2]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
303 tc[3] = (tc0_table+52)[index_a][bS[3]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
304 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
305 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
306 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
307 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
308 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
309
10903
8c8321b94c35 Mark a few functions as noinline, this makes ff_h264_filter_mb() a bit smaller
michael
parents: 10902
diff changeset
310 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
311 const int index_a = qp + h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
312 const int alpha = (alpha_table+52)[index_a];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
313 const int beta = (beta_table+52)[qp + h->slice_beta_offset];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
314 if (alpha ==0 || beta == 0) return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
315
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
316 if( bS[0] < 4 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
317 int8_t tc[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
318 tc[0] = (tc0_table+52)[index_a][bS[0]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
319 tc[1] = (tc0_table+52)[index_a][bS[1]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
320 tc[2] = (tc0_table+52)[index_a][bS[2]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
321 tc[3] = (tc0_table+52)[index_a][bS[3]]+1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
322 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
323 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
324 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
325 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
326 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
327
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
328 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
329 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
330 int mb_y_firstrow = s->picture_structure == PICT_BOTTOM_FIELD;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
331 int mb_xy, mb_type;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
332 int qp, qp0, qp1, qpc, qpc0, qpc1, qp_thresh;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
333
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
334 mb_xy = h->mb_xy;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
335
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
336 if(mb_x==0 || mb_y==mb_y_firstrow || !s->dsp.h264_loop_filter_strength || h->pps.chroma_qp_diff ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
337 !(s->flags2 & CODEC_FLAG2_FAST) || //FIXME filter_mb_fast is broken, thus hasto be, but should not under CODEC_FLAG2_FAST
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
338 (h->deblocking_filter == 2 && (h->slice_table[mb_xy] != h->slice_table[h->top_mb_xy] ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
339 h->slice_table[mb_xy] != h->slice_table[mb_xy - 1]))) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
340 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
341 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
342 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
343 assert(!FRAME_MBAFF);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
344
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
345 mb_type = s->current_picture.mb_type[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
346 qp = s->current_picture.qscale_table[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
347 qp0 = s->current_picture.qscale_table[mb_xy-1];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
348 qp1 = s->current_picture.qscale_table[h->top_mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
349 qpc = get_chroma_qp( h, 0, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
350 qpc0 = get_chroma_qp( h, 0, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
351 qpc1 = get_chroma_qp( h, 0, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
352 qp0 = (qp + qp0 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
353 qp1 = (qp + qp1 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
354 qpc0 = (qpc + qpc0 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
355 qpc1 = (qpc + qpc1 + 1) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
356 qp_thresh = 15 - h->slice_alpha_c0_offset;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
357 if(qp <= qp_thresh && qp0 <= qp_thresh && qp1 <= qp_thresh &&
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
358 qpc <= qp_thresh && qpc0 <= qp_thresh && qpc1 <= qp_thresh)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
359 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
360
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
361 if( IS_INTRA(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
362 int16_t bS4[4] = {4,4,4,4};
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
363 int16_t bS3[4] = {3,3,3,3};
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
364 int16_t *bSH = FIELD_PICTURE ? bS3 : bS4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
365 if( IS_8x8DCT(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
366 filter_mb_edgev( h, &img_y[4*0], linesize, bS4, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
367 filter_mb_edgev( h, &img_y[4*2], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
368 filter_mb_edgeh( h, &img_y[4*0*linesize], linesize, bSH, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
369 filter_mb_edgeh( h, &img_y[4*2*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
370 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
371 filter_mb_edgev( h, &img_y[4*0], linesize, bS4, qp0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
372 filter_mb_edgev( h, &img_y[4*1], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
373 filter_mb_edgev( h, &img_y[4*2], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
374 filter_mb_edgev( h, &img_y[4*3], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
375 filter_mb_edgeh( h, &img_y[4*0*linesize], linesize, bSH, qp1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
376 filter_mb_edgeh( h, &img_y[4*1*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
377 filter_mb_edgeh( h, &img_y[4*2*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
378 filter_mb_edgeh( h, &img_y[4*3*linesize], linesize, bS3, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
379 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
380 filter_mb_edgecv( h, &img_cb[2*0], uvlinesize, bS4, qpc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
381 filter_mb_edgecv( h, &img_cb[2*2], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
382 filter_mb_edgecv( h, &img_cr[2*0], uvlinesize, bS4, qpc0 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
383 filter_mb_edgecv( h, &img_cr[2*2], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
384 filter_mb_edgech( h, &img_cb[2*0*uvlinesize], uvlinesize, bSH, qpc1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
385 filter_mb_edgech( h, &img_cb[2*2*uvlinesize], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
386 filter_mb_edgech( h, &img_cr[2*0*uvlinesize], uvlinesize, bSH, qpc1 );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
387 filter_mb_edgech( h, &img_cr[2*2*uvlinesize], uvlinesize, bS3, qpc );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
388 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
389 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
390 DECLARE_ALIGNED_8(int16_t, bS[2][4][4]);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
391 uint64_t (*bSv)[4] = (uint64_t(*)[4])bS;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
392 int edges;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
393 if( IS_8x8DCT(mb_type) && (h->cbp&7) == 7 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
394 edges = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
395 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
396 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
397 int mask_edge1 = (mb_type & (MB_TYPE_16x16 | MB_TYPE_8x16)) ? 3 :
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
398 (mb_type & MB_TYPE_16x8) ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
399 int mask_edge0 = (mb_type & (MB_TYPE_16x16 | MB_TYPE_8x16))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
400 && (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
401 ? 3 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
402 int step = IS_8x8DCT(mb_type) ? 2 : 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
403 edges = (mb_type & MB_TYPE_16x16) && !(h->cbp & 15) ? 1 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
404 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
405 (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
406 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
407 if( IS_INTRA(s->current_picture.mb_type[mb_xy-1]) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
408 bSv[0][0] = 0x0004000400040004ULL;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
409 if( IS_INTRA(s->current_picture.mb_type[h->top_mb_xy]) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
410 bSv[1][0] = FIELD_PICTURE ? 0x0003000300030003ULL : 0x0004000400040004ULL;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
411
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
412 #define FILTER(hv,dir,edge)\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
413 if(bSv[dir][edge]) {\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
414 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
415 if(!(edge&1)) {\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
416 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
417 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
418 }\
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
419 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
420 if( edges == 1 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
421 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
422 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
423 } else if( IS_8x8DCT(mb_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
424 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
425 FILTER(v,0,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
426 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
427 FILTER(h,1,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
428 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
429 FILTER(v,0,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
430 FILTER(v,0,1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
431 FILTER(v,0,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
432 FILTER(v,0,3);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
433 FILTER(h,1,0);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
434 FILTER(h,1,1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
435 FILTER(h,1,2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
436 FILTER(h,1,3);
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 #undef FILTER
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
439 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
440 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
441
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
442
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
443 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
444 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
445 int edge;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
446 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
447 const int mbm_type = s->current_picture.mb_type[mbm_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
448 int (*ref2frm) [64] = h->ref2frm[ h->slice_num &(MAX_SLICES-1) ][0] + (MB_MBAFF ? 20 : 2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
449 int (*ref2frmm)[64] = h->ref2frm[ h->slice_table[mbm_xy]&(MAX_SLICES-1) ][0] + (MB_MBAFF ? 20 : 2);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
450 int start = h->slice_table[mbm_xy] == 0xFFFF ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
451
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
452 const int edges = (mb_type & (MB_TYPE_16x16|MB_TYPE_SKIP))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
453 == (MB_TYPE_16x16|MB_TYPE_SKIP) ? 1 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
454 // how often to recheck mv-based bS when iterating between edges
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
455 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
456 (mb_type & (MB_TYPE_8x16 >> dir)) ? 1 : 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
457 // how often to recheck mv-based bS when iterating along each edge
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
458 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
459
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
460 if (first_vertical_edge_done) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
461 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
462 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
463
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
464 if (h->deblocking_filter==2 && h->slice_table[mbm_xy] != h->slice_table[mb_xy])
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
465 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
466
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
467 if (FRAME_MBAFF && (dir == 1) && ((mb_y&1) == 0) && start == 0
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
468 && !IS_INTERLACED(mb_type)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
469 && IS_INTERLACED(mbm_type)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
470 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
471 // This is a special case in the norm where the filtering must
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
472 // 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
473 // frame macroblock.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
474 //
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
475 static const int nnz_idx[4] = {4,5,6,3};
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
476 unsigned int tmp_linesize = 2 * linesize;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
477 unsigned int tmp_uvlinesize = 2 * uvlinesize;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
478 int mbn_xy = mb_xy - 2 * s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
479 int qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
480 int i, j;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
481 int16_t bS[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
482
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
483 for(j=0; j<2; j++, mbn_xy += s->mb_stride){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
484 if( IS_INTRA(mb_type) ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
485 IS_INTRA(s->current_picture.mb_type[mbn_xy]) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
486 bS[0] = bS[1] = bS[2] = bS[3] = 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
487 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
488 const uint8_t *mbn_nnz = h->non_zero_count[mbn_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
489 for( i = 0; i < 4; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
490 if( h->non_zero_count_cache[scan8[0]+i] != 0 ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
491 mbn_nnz[nnz_idx[i]] != 0 )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
492 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
493 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
494 bS[i] = 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 // 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
498 // value in IPCM macroblocks.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
499 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
500 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
501 { 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
502 filter_mb_edgeh( h, &img_y[j*linesize], tmp_linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
503 filter_mb_edgech( h, &img_cb[j*uvlinesize], tmp_uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
504 ( 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
505 filter_mb_edgech( h, &img_cr[j*uvlinesize], tmp_uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
506 ( 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
507 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
508
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
509 start = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
510 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
511
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
512 /* Calculate bS */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
513 for( edge = start; edge < edges; edge++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
514 /* mbn_xy: neighbor macroblock */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
515 const int mbn_xy = edge > 0 ? mb_xy : mbm_xy;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
516 const int mbn_type = s->current_picture.mb_type[mbn_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
517 int (*ref2frmn)[64] = edge > 0 ? ref2frm : ref2frmm;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
518 int16_t bS[4];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
519 int qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
520
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
521 if( (edge&1) && IS_8x8DCT(mb_type) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
522 continue;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
523
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
524 if( IS_INTRA(mb_type) ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
525 IS_INTRA(mbn_type) ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
526 int value;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
527 if (edge == 0) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
528 if ( (!IS_INTERLACED(mb_type) && !IS_INTERLACED(mbm_type))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
529 || ((FRAME_MBAFF || (s->picture_structure != PICT_FRAME)) && (dir == 0))
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 value = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
532 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
533 value = 3;
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 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
536 value = 3;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
537 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
538 bS[0] = bS[1] = bS[2] = bS[3] = value;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
539 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
540 int i, l;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
541 int mv_done;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
542
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
543 if( edge & mask_edge ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
544 bS[0] = bS[1] = bS[2] = bS[3] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
545 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
546 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
547 else if( FRAME_MBAFF && IS_INTERLACED(mb_type ^ mbn_type)) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
548 bS[0] = bS[1] = bS[2] = bS[3] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
549 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
550 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
551 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
552 int b_idx= 8 + 4 + edge * (dir ? 8:1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
553 int bn_idx= b_idx - (dir ? 8:1);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
554 int v = 0;
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 for( l = 0; !v && l < 1 + (h->slice_type_nos == FF_B_TYPE); l++ ) {
10899
28ac79270704 Minor (2 cpu cycles) optimization ||->|.
michael
parents: 10896
diff changeset
557 v |= ref2frm[l][h->ref_cache[l][b_idx]] != ref2frmn[l][h->ref_cache[l][bn_idx]] |
10901
2a5c3d89201d Another microopt, 4 cpu cycles for avoidance of FFABS().
michael
parents: 10899
diff changeset
558 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
559 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
560 }
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 if(h->slice_type_nos == FF_B_TYPE && v){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
563 v=0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
564 for( l = 0; !v && l < 2; l++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
565 int ln= 1-l;
10899
28ac79270704 Minor (2 cpu cycles) optimization ||->|.
michael
parents: 10896
diff changeset
566 v |= ref2frm[l][h->ref_cache[l][b_idx]] != ref2frmn[ln][h->ref_cache[ln][bn_idx]] |
10901
2a5c3d89201d Another microopt, 4 cpu cycles for avoidance of FFABS().
michael
parents: 10899
diff changeset
567 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
568 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
569 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
570 }
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 bS[0] = bS[1] = bS[2] = bS[3] = v;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
573 mv_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
574 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
575 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
576 mv_done = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
577
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
578 for( i = 0; i < 4; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
579 int x = dir == 0 ? edge : i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
580 int y = dir == 0 ? i : edge;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
581 int b_idx= 8 + 4 + x + 8*y;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
582 int bn_idx= b_idx - (dir ? 8:1);
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->non_zero_count_cache[b_idx] |
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
585 h->non_zero_count_cache[bn_idx] ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
586 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
587 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
588 else if(!mv_done)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
589 {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
590 bS[i] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
591 for( l = 0; l < 1 + (h->slice_type_nos == FF_B_TYPE); l++ ) {
10902
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
592 if( ref2frm[l][h->ref_cache[l][b_idx]] != ref2frmn[l][h->ref_cache[l][bn_idx]] |
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
593 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
594 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
595 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
596 break;
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
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
600 if(h->slice_type_nos == FF_B_TYPE && bS[i]){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
601 bS[i] = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
602 for( l = 0; l < 2; l++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
603 int ln= 1-l;
10902
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
604 if( ref2frm[l][h->ref_cache[l][b_idx]] != ref2frmn[ln][h->ref_cache[ln][bn_idx]] |
1e41e6ab9a18 Apply last 2 optimizations to similar code i forgot.
michael
parents: 10901
diff changeset
605 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
606 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
607 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
608 break;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
609 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
610 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
611 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
612 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
613 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
614
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
615 if(bS[0]+bS[1]+bS[2]+bS[3] == 0)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
616 continue;
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
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
619 /* Filter edge */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
620 // 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
621 // value in IPCM macroblocks.
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
622 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
623 //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, s->current_picture.qscale_table[mbn_xy]);
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
624 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
625 //{ 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
626 if( dir == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
627 filter_mb_edgev( h, &img_y[4*edge], linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
628 if( (edge&1) == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
629 filter_mb_edgecv( h, &img_cb[2*edge], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
630 ( 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
631 filter_mb_edgecv( h, &img_cr[2*edge], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
632 ( 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
633 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
634 } else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
635 filter_mb_edgeh( h, &img_y[4*edge*linesize], linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
636 if( (edge&1) == 0 ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
637 filter_mb_edgech( h, &img_cb[2*edge*uvlinesize], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
638 ( 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
639 filter_mb_edgech( h, &img_cr[2*edge*uvlinesize], uvlinesize, bS,
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
640 ( 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
641 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
642 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
643 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
644 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
645
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
646 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
647 MpegEncContext * const s = &h->s;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
648 const int mb_xy= mb_x + mb_y*s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
649 const int mb_type = s->current_picture.mb_type[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
650 const int mvy_limit = IS_INTERLACED(mb_type) ? 2 : 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
651 int first_vertical_edge_done = 0;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
652 av_unused int dir;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
653
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
654 //for sufficiently low qp, filtering wouldn't do anything
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
655 //this is a conservative estimate: could also check beta_offset and more accurate chroma_qp
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
656 if(!FRAME_MBAFF){
10896
f112b4d030fa Avoid wasting 4 cpu cycles per MB in redundantly calculating qp_thresh.
michael
parents: 10854
diff changeset
657 int qp_thresh = h->qp_thresh;
10854
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
658 int qp = s->current_picture.qscale_table[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
659 if(qp <= qp_thresh
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
660 && (mb_x == 0 || ((qp + s->current_picture.qscale_table[mb_xy-1] + 1)>>1) <= qp_thresh)
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
661 && (h->top_mb_xy < 0 || ((qp + s->current_picture.qscale_table[h->top_mb_xy] + 1)>>1) <= qp_thresh)){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
662 return;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
663 }
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
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
666 // CAVLC 8x8dct requires NNZ values for residual decoding that differ from what the loop filter needs
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
667 if(!h->pps.cabac && h->pps.transform_8x8_mode){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
668 int top_type, left_type[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
669 top_type = s->current_picture.mb_type[h->top_mb_xy] ;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
670 left_type[0] = s->current_picture.mb_type[h->left_mb_xy[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
671 left_type[1] = s->current_picture.mb_type[h->left_mb_xy[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
672
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
673 if(IS_8x8DCT(top_type)){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
674 h->non_zero_count_cache[4+8*0]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
675 h->non_zero_count_cache[5+8*0]= h->cbp_table[h->top_mb_xy] & 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
676 h->non_zero_count_cache[6+8*0]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
677 h->non_zero_count_cache[7+8*0]= h->cbp_table[h->top_mb_xy] & 8;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
678 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
679 if(IS_8x8DCT(left_type[0])){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
680 h->non_zero_count_cache[3+8*1]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
681 h->non_zero_count_cache[3+8*2]= h->cbp_table[h->left_mb_xy[0]]&2; //FIXME check MBAFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
682 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
683 if(IS_8x8DCT(left_type[1])){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
684 h->non_zero_count_cache[3+8*3]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
685 h->non_zero_count_cache[3+8*4]= h->cbp_table[h->left_mb_xy[1]]&8; //FIXME check MBAFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
686 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
687
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
688 if(IS_8x8DCT(mb_type)){
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
689 h->non_zero_count_cache[scan8[0 ]]= h->non_zero_count_cache[scan8[1 ]]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
690 h->non_zero_count_cache[scan8[2 ]]= h->non_zero_count_cache[scan8[3 ]]= h->cbp & 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 h->non_zero_count_cache[scan8[0+ 4]]= h->non_zero_count_cache[scan8[1+ 4]]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
693 h->non_zero_count_cache[scan8[2+ 4]]= h->non_zero_count_cache[scan8[3+ 4]]= h->cbp & 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
694
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
695 h->non_zero_count_cache[scan8[0+ 8]]= h->non_zero_count_cache[scan8[1+ 8]]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
696 h->non_zero_count_cache[scan8[2+ 8]]= h->non_zero_count_cache[scan8[3+ 8]]= h->cbp & 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
697
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
698 h->non_zero_count_cache[scan8[0+12]]= h->non_zero_count_cache[scan8[1+12]]=
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
699 h->non_zero_count_cache[scan8[2+12]]= h->non_zero_count_cache[scan8[3+12]]= h->cbp & 8;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
700 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
701 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
702
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
703 if (FRAME_MBAFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
704 // left mb is in picture
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
705 && h->slice_table[mb_xy-1] != 0xFFFF
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
706 // and current and left pair do not have the same interlaced type
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
707 && (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
708 // and left mb is in the same slice if deblocking_filter == 2
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
709 && (h->deblocking_filter!=2 || h->slice_table[mb_xy-1] == h->slice_table[mb_xy])) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
710 /* First vertical edge is different in MBAFF frames
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
711 * There are 8 different bS to compute and 2 different Qp
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
712 */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
713 const int pair_xy = mb_x + (mb_y&~1)*s->mb_stride;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
714 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
715 int16_t bS[8];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
716 int qp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
717 int bqp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
718 int rqp[2];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
719 int mb_qp, mbn0_qp, mbn1_qp;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
720 int i;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
721 first_vertical_edge_done = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
722
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
723 if( IS_INTRA(mb_type) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
724 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
725 else {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
726 for( i = 0; i < 8; i++ ) {
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
727 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
728
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
729 if( IS_INTRA( s->current_picture.mb_type[mbn_xy] ) )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
730 bS[i] = 4;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
731 else if( h->non_zero_count_cache[12+8*(i>>1)] != 0 ||
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
732 ((!h->pps.cabac && IS_8x8DCT(s->current_picture.mb_type[mbn_xy])) ?
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
733 (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
734 :
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
735 h->non_zero_count[mbn_xy][MB_FIELD ? i&3 : (i>>2)+(mb_y&1)*2]))
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
736 bS[i] = 2;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
737 else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
738 bS[i] = 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
739 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
740 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
741
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
742 mb_qp = s->current_picture.qscale_table[mb_xy];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
743 mbn0_qp = s->current_picture.qscale_table[left_mb_xy[0]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
744 mbn1_qp = s->current_picture.qscale_table[left_mb_xy[1]];
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
745 qp[0] = ( mb_qp + mbn0_qp + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
746 bqp[0] = ( get_chroma_qp( h, 0, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
747 get_chroma_qp( h, 0, mbn0_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
748 rqp[0] = ( get_chroma_qp( h, 1, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
749 get_chroma_qp( h, 1, mbn0_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
750 qp[1] = ( mb_qp + mbn1_qp + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
751 bqp[1] = ( get_chroma_qp( h, 0, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
752 get_chroma_qp( h, 0, mbn1_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
753 rqp[1] = ( get_chroma_qp( h, 1, mb_qp ) +
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
754 get_chroma_qp( h, 1, mbn1_qp ) + 1 ) >> 1;
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
755
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
756 /* Filter edge */
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
757 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
758 { int i; for (i = 0; i < 8; 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
759 filter_mb_mbaff_edgev ( h, &img_y [0], linesize, bS, qp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
760 filter_mb_mbaff_edgecv( h, &img_cb[0], uvlinesize, bS, bqp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
761 filter_mb_mbaff_edgecv( h, &img_cr[0], uvlinesize, bS, rqp );
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
762 }
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
763
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
764 #if CONFIG_SMALL
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
765 for( dir = 0; dir < 2; dir++ )
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
766 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
767 #else
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
768 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
769 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
770 #endif
f6fc6ace95e3 Split h264 loop filter off h264.c.
michael
parents:
diff changeset
771 }