29 #define CLIP(v) av_clip(v, 4, 1019)
30 #define CLIP8(v) av_clip(v, 1, 254)
32 #define WRITE_PIXELS(a, b, c) \
35 val |= (CLIP(*b++) << 10) | \
41 #define WRITE_PIXELS8(a, b, c) \
43 val = (CLIP8(*a++) << 2); \
44 val |= (CLIP8(*b++) << 12) | \
45 (CLIP8(*c++) << 22); \
58 for (i = 0; i < width - 11; i += 12) {
77 for (i = 0; i < width - 5; i += 6) {
89 if (avctx->
width & 1) {
110 const AVFrame *pic,
int *got_packet)
113 int aligned_width = ((avctx->
width + 47) / 48) * 48;
114 int stride = aligned_width * 8 / 3;
115 int line_padding = stride - ((avctx->
width * 8 + 11) / 12) * 4;
127 const uint16_t *
y = (
const uint16_t *)pic->
data[0];
128 const uint16_t *
u = (
const uint16_t *)pic->
data[1];
129 const uint16_t *
v = (
const uint16_t *)pic->
data[2];
132 w = (avctx->
width / 6) * 6;
139 if (w < avctx->
width - 1) {
143 if (w == avctx->
width - 2) {
148 if (w < avctx->
width - 3) {
149 val |= (
CLIP(*
u++) << 10) | (
CLIP(*y++) << 20);
153 val =
CLIP(*v++) | (
CLIP(*y++) << 10);
158 memset(dst, 0, line_padding);
168 for (h = 0; h < avctx->
height; h++) {
170 w = (avctx->
width / 12) * 12;
176 dst += (w / 12) * 32;
178 for (; w < avctx->
width - 5; w += 6) {
184 if (w < avctx->
width - 1) {
187 val =
CLIP8(*y++) << 2;
188 if (w == avctx->
width - 2) {
193 if (w < avctx->
width - 3) {
194 val |= (
CLIP8(*u++) << 12) | (
CLIP8(*y++) << 22);
198 val = (
CLIP8(*v++) << 2) | (
CLIP8(*y++) << 12);
202 memset(dst, 0, line_padding);