1 /*
2 * y41p encoder
3 *
4 * Copyright (c) 2012 Paul B Mahol
5 *
6 * This file is part of FFmpeg.
7 *
8 * FFmpeg is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public
10 * License as published by the Free Software Foundation; either
11 * version 2.1 of the License, or (at your option) any later version.
12 *
13 * FFmpeg is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
17 *
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with FFmpeg; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
25
27 {
28 if (avctx->
width & 7) {
31 }
32
35
39 }
40
41 return 0;
42 }
43
45 const AVFrame *pic,
int *got_packet)
46 {
50
53
57
58 for (i = avctx->
height - 1; i >= 0; i--) {
62 for (j = 0; j < avctx->
width; j += 8) {
63 *(dst++) = *(u++);
64 *(dst++) = *(y++);
65 *(dst++) = *(v++);
66 *(dst++) = *(y++);
67
68 *(dst++) = *(u++);
69 *(dst++) = *(y++);
70 *(dst++) = *(v++);
71 *(dst++) = *(y++);
72
73 *(dst++) = *(y++);
74 *(dst++) = *(y++);
75 *(dst++) = *(y++);
76 *(dst++) = *(y++);
77 }
78 }
79
81 *got_packet = 1;
82 return 0;
83 }
84
86 {
88
89 return 0;
90 }
91
102 };