81 ht[
i].bits, ht[
i].values,
82 ht[
i].class == 1,
s->avctx);
86 if (ht[
i].
class < 2) {
87 memcpy(
s->raw_huffman_lengths[ht[
i].class][ht[
i].index],
89 memcpy(
s->raw_huffman_values[ht[
i].class][ht[
i].index],
90 ht[
i].values, ht[
i].length);
100 if (
len > 14 && buf[12] == 1)
101 s->interlace_polarity = 1;
102 if (
len > 14 && buf[12] == 2)
103 s->interlace_polarity = 0;
122 if (!
s->picture_ptr) {
126 s->picture_ptr =
s->picture;
140 s->first_picture = 1;
156 "error using external huffman table, switching back to internal\n");
162 s->interlace_polarity = 1;
166 s->interlace_polarity = 1;
173 if (
s->smv_frames_per_jpeg <= 0) {
217 for (
i = 0;
i < 64;
i++) {
219 if (
s->quant_matrixes[
index][
i] == 0) {
227 s->quant_matrixes[
index][8]) >> 1;
230 len -= 1 + 64 * (1+pr);
260 for (
i = 1;
i <= 16;
i++) {
265 if (len < n || n > 256)
268 for (
i = 0;
i < n;
i++) {
279 val_table,
class > 0,
s->avctx)) < 0)
285 val_table, 0,
s->avctx)) < 0)
289 for (
i = 0;
i < 16;
i++)
290 s->raw_huffman_lengths[
class][
index][
i] = bits_table[
i + 1];
292 s->raw_huffman_values[
class][
index][
i] = val_table[
i];
305 memset(
s->upscale_h, 0,
sizeof(
s->upscale_h));
306 memset(
s->upscale_v, 0,
sizeof(
s->upscale_v));
316 if (
s->avctx->bits_per_raw_sample !=
bits) {
318 s->avctx->bits_per_raw_sample =
bits;
323 if (
bits == 9 && !
s->pegasus_rct)
326 if(
s->lossless &&
s->avctx->lowres){
335 if (
s->interlaced &&
s->width ==
width &&
s->height ==
height + 1)
342 if (!
s->progressive && !
s->ls) {
344 if (
s->buf_size && (
width + 7) / 8 * ((
height + 7) / 8) >
s->buf_size * 4LL)
349 if (nb_components <= 0 ||
352 if (
s->interlaced && (
s->bottom_field == !
s->interlace_polarity)) {
353 if (nb_components !=
s->nb_components) {
355 "nb_components changing in interlaced picture\n");
359 if (
s->ls && !(
bits <= 8 || nb_components == 1)) {
361 "JPEG-LS that is not <= 8 "
362 "bits/component or 16-bit gray");
365 if (
len != 8 + 3 * nb_components) {
366 av_log(
s->avctx,
AV_LOG_ERROR,
"decode_sof0: error, len(%d) mismatch %d components\n",
len, nb_components);
370 s->nb_components = nb_components;
373 for (
i = 0;
i < nb_components;
i++) {
379 if (h_count[
i] >
s->h_max)
380 s->h_max = h_count[
i];
381 if (v_count[
i] >
s->v_max)
382 s->v_max = v_count[
i];
384 if (
s->quant_index[
i] >= 4) {
388 if (!h_count[
i] || !v_count[
i]) {
390 "Invalid sampling factor in component %d %d:%d\n",
391 i, h_count[
i], v_count[
i]);
396 i, h_count[
i], v_count[
i],
397 s->component_id[
i],
s->quant_index[
i]);
399 if ( nb_components == 4
400 &&
s->component_id[0] ==
'C' - 1
401 &&
s->component_id[1] ==
'M' - 1
402 &&
s->component_id[2] ==
'Y' - 1
403 &&
s->component_id[3] ==
'K' - 1)
404 s->adobe_transform = 0;
406 if (
s->ls && (
s->h_max > 1 ||
s->v_max > 1)) {
412 if (nb_components == 2) {
426 memcmp(
s->h_count, h_count,
sizeof(h_count)) ||
427 memcmp(
s->v_count, v_count,
sizeof(v_count))) {
433 memcpy(
s->h_count, h_count,
sizeof(h_count));
434 memcpy(
s->v_count, v_count,
sizeof(v_count));
439 if (
s->first_picture &&
440 (
s->multiscope != 2 ||
s->avctx->time_base.den >= 25 *
s->avctx->time_base.num) &&
441 s->orig_height != 0 &&
442 s->height < ((
s->orig_height * 3) / 4)) {
444 s->bottom_field =
s->interlace_polarity;
445 s->picture_ptr->interlaced_frame = 1;
446 s->picture_ptr->top_field_first = !
s->interlace_polarity;
454 if ((
s->avctx->codec_tag ==
MKTAG(
'A',
'V',
'R',
'n') ||
455 s->avctx->codec_tag ==
MKTAG(
'A',
'V',
'D',
'J')) &&
459 s->first_picture = 0;
465 s->avctx->height =
s->avctx->coded_height /
s->smv_frames_per_jpeg;
466 if (
s->avctx->height <= 0)
469 if (
s->bayer &&
s->progressive) {
474 if (
s->got_picture &&
s->interlaced && (
s->bottom_field == !
s->interlace_polarity)) {
475 if (
s->progressive) {
480 if (
s->v_max == 1 &&
s->h_max == 1 &&
s->lossless==1 && (nb_components==3 || nb_components==4))
482 else if (!
s->lossless)
485 pix_fmt_id = ((unsigned)
s->h_count[0] << 28) | (
s->v_count[0] << 24) |
486 (
s->h_count[1] << 20) | (
s->v_count[1] << 16) |
487 (
s->h_count[2] << 12) | (
s->v_count[2] << 8) |
488 (
s->h_count[3] << 4) |
s->v_count[3];
492 if (!(pix_fmt_id & 0xD0D0D0D0))
493 pix_fmt_id -= (pix_fmt_id & 0xF0F0F0F0) >> 1;
494 if (!(pix_fmt_id & 0x0D0D0D0D))
495 pix_fmt_id -= (pix_fmt_id & 0x0F0F0F0F) >> 1;
497 for (
i = 0;
i < 8;
i++) {
498 int j = 6 + (
i&1) - (
i&6);
499 int is = (pix_fmt_id >> (4*
i)) & 0xF;
500 int js = (pix_fmt_id >> (4*j)) & 0xF;
502 if (
is == 1 && js != 2 && (i < 2 || i > 5))
503 js = (pix_fmt_id >> ( 8 + 4*(
i&1))) & 0xF;
504 if (
is == 1 && js != 2 && (i < 2 || i > 5))
505 js = (pix_fmt_id >> (16 + 4*(
i&1))) & 0xF;
507 if (
is == 1 && js == 2) {
508 if (
i & 1)
s->upscale_h[j/2] = 1;
509 else s->upscale_v[j/2] = 1;
514 if (pix_fmt_id != 0x11110000 && pix_fmt_id != 0x11000000)
518 switch (pix_fmt_id) {
528 if (
s->adobe_transform == 0
529 ||
s->component_id[0] ==
'R' - 1 &&
s->component_id[1] ==
'G' - 1 &&
s->component_id[2] ==
'B' - 1) {
543 if (
s->adobe_transform == 0 &&
s->bits <= 8) {
554 if (
s->adobe_transform == 0 &&
s->bits <= 8) {
556 s->upscale_v[1] =
s->upscale_v[2] = 1;
557 s->upscale_h[1] =
s->upscale_h[2] = 1;
558 }
else if (
s->adobe_transform == 2 &&
s->bits <= 8) {
560 s->upscale_v[1] =
s->upscale_v[2] = 1;
561 s->upscale_h[1] =
s->upscale_h[2] = 1;
601 if (
s->component_id[0] ==
'Q' &&
s->component_id[1] ==
'F' &&
s->component_id[2] ==
'A') {
605 s->upscale_v[0] =
s->upscale_v[1] = 1;
607 if (pix_fmt_id == 0x14111100)
608 s->upscale_v[1] =
s->upscale_v[2] = 1;
616 if (
s->component_id[0] ==
'Q' &&
s->component_id[1] ==
'F' &&
s->component_id[2] ==
'A') {
620 s->upscale_h[0] =
s->upscale_h[1] = 1;
632 s->upscale_h[1] =
s->upscale_h[2] = 2;
648 if (pix_fmt_id == 0x42111100) {
651 s->upscale_h[1] =
s->upscale_h[2] = 1;
652 }
else if (pix_fmt_id == 0x24111100) {
655 s->upscale_v[1] =
s->upscale_v[2] = 1;
656 }
else if (pix_fmt_id == 0x23111100) {
659 s->upscale_v[1] =
s->upscale_v[2] = 2;
671 memset(
s->upscale_h, 0,
sizeof(
s->upscale_h));
672 memset(
s->upscale_v, 0,
sizeof(
s->upscale_v));
684 memset(
s->upscale_h, 0,
sizeof(
s->upscale_h));
685 memset(
s->upscale_v, 0,
sizeof(
s->upscale_v));
686 if (
s->nb_components == 3) {
688 }
else if (
s->nb_components != 1) {
691 }
else if (
s->palette_index &&
s->bits <= 8)
693 else if (
s->bits <= 8)
705 if (
s->avctx->pix_fmt ==
s->hwaccel_sw_pix_fmt && !size_change) {
706 s->avctx->pix_fmt =
s->hwaccel_pix_fmt;
709 #if CONFIG_MJPEG_NVDEC_HWACCEL
712 #if CONFIG_MJPEG_VAAPI_HWACCEL
719 if (
s->hwaccel_pix_fmt < 0)
722 s->hwaccel_sw_pix_fmt =
s->avctx->pix_fmt;
723 s->avctx->pix_fmt =
s->hwaccel_pix_fmt;
728 s->picture_ptr->key_frame = 1;
737 s->picture_ptr->key_frame = 1;
740 for (
i = 0;
i < 4;
i++)
741 s->linesize[
i] =
s->picture_ptr->linesize[
i] <<
s->interlaced;
743 ff_dlog(
s->avctx,
"%d %d %d %d %d %d\n",
744 s->width,
s->height,
s->linesize[0],
s->linesize[1],
745 s->interlaced,
s->avctx->height);
749 if ((
s->rgb && !
s->lossless && !
s->ls) ||
750 (!
s->rgb &&
s->ls &&
s->nb_components > 1) ||
758 if (
s->progressive) {
759 int bw = (
width +
s->h_max * 8 - 1) / (
s->h_max * 8);
760 int bh = (
height +
s->v_max * 8 - 1) / (
s->v_max * 8);
761 for (
i = 0;
i <
s->nb_components;
i++) {
762 int size = bw * bh *
s->h_count[
i] *
s->v_count[
i];
767 if (!
s->blocks[
i] || !
s->last_nnz[
i])
769 s->block_stride[
i] = bw *
s->h_count[
i];
771 memset(
s->coefs_finished, 0,
sizeof(
s->coefs_finished));
774 if (
s->avctx->hwaccel) {
775 s->hwaccel_picture_private =
776 av_mallocz(
s->avctx->hwaccel->frame_priv_data_size);
777 if (!
s->hwaccel_picture_private)
780 ret =
s->avctx->hwaccel->start_frame(
s->avctx,
s->raw_image_buffer,
781 s->raw_image_buffer_size);
793 if (code < 0 || code > 16) {
795 "mjpeg_decode_dc: bad vlc: %d:%d (%p)\n",
796 0, dc_index, &
s->vlcs[0][dc_index]);
808 int dc_index,
int ac_index, uint16_t *quant_matrix)
814 if (
val == 0xfffff) {
818 val =
val * (unsigned)quant_matrix[0] +
s->last_dc[component];
820 s->last_dc[component] =
val;
829 i += ((unsigned)
code) >> 4;
837 int sign = (~cache) >> 31;
847 j =
s->scantable.permutated[
i];
857 int component,
int dc_index,
858 uint16_t *quant_matrix,
int Al)
861 s->bdsp.clear_block(
block);
863 if (
val == 0xfffff) {
867 val = (
val * (quant_matrix[0] << Al)) +
s->last_dc[component];
868 s->last_dc[component] =
val;
875 uint8_t *last_nnz,
int ac_index,
876 uint16_t *quant_matrix,
877 int ss,
int se,
int Al,
int *EOBRUN)
889 for (
i =
ss; ;
i++) {
902 int sign = (~cache) >> 31;
910 j =
s->scantable.permutated[
se];
917 j =
s->scantable.permutated[
i];
947 #define REFINE_BIT(j) { \
948 UPDATE_CACHE(re, &s->gb); \
949 sign = block[j] >> 15; \
950 block[j] += SHOW_UBITS(re, &s->gb, 1) * \
951 ((quant_matrix[i] ^ sign) - sign) << Al; \
952 LAST_SKIP_BITS(re, &s->gb, 1); \
960 av_log(s->avctx, AV_LOG_ERROR, "error count: %d\n", i); \
965 j = s->scantable.permutated[i]; \
968 else if (run-- == 0) \
975 int ac_index, uint16_t *quant_matrix,
976 int ss,
int se,
int Al,
int *EOBRUN)
979 int last =
FFMIN(
se, *last_nnz);
995 j =
s->scantable.permutated[
i];
1026 for (;
i <= last;
i++) {
1027 j =
s->scantable.permutated[
i];
1043 if (
s->restart_interval) {
1047 for (
i = 0;
i < nb_components;
i++)
1048 s->last_dc[
i] = (4 <<
s->bits);
1053 if (
s->restart_count == 0) {
1061 for (
i = 0;
i < nb_components;
i++)
1062 s->last_dc[
i] = (4 <<
s->bits);
1078 int left[4], top[4], topleft[4];
1079 const int linesize =
s->linesize[0];
1080 const int mask = ((1 <<
s->bits) - 1) << point_transform;
1081 int resync_mb_y = 0;
1082 int resync_mb_x = 0;
1085 if (!
s->bayer &&
s->nb_components < 3)
1087 if (
s->bayer &&
s->nb_components > 2)
1089 if (
s->nb_components <= 0 ||
s->nb_components > 4)
1091 if (
s->v_max != 1 ||
s->h_max != 1 || !
s->lossless)
1094 if (
s->rct ||
s->pegasus_rct)
1099 s->restart_count =
s->restart_interval;
1101 if (
s->restart_interval == 0)
1102 s->restart_interval = INT_MAX;
1105 width =
s->mb_width / nb_components;
1110 if (!
s->ljpeg_buffer)
1115 for (
i = 0;
i < 4;
i++)
1118 for (mb_y = 0; mb_y <
s->mb_height; mb_y++) {
1119 uint8_t *ptr =
s->picture_ptr->data[0] + (linesize * mb_y);
1121 if (
s->interlaced &&
s->bottom_field)
1122 ptr += linesize >> 1;
1124 for (
i = 0;
i < 4;
i++)
1125 top[
i] = left[
i] = topleft[
i] =
buffer[0][
i];
1127 if ((mb_y *
s->width) %
s->restart_interval == 0) {
1128 for (
i = 0;
i < 6;
i++)
1129 vpred[
i] = 1 << (
s->bits-1);
1132 for (mb_x = 0; mb_x <
width; mb_x++) {
1140 if (
s->restart_interval && !
s->restart_count){
1141 s->restart_count =
s->restart_interval;
1145 top[
i] = left[
i]= topleft[
i]= 1 << (
s->bits - 1);
1147 if (mb_y == resync_mb_y || mb_y == resync_mb_y+1 && mb_x < resync_mb_x || !mb_x)
1148 modified_predictor = 1;
1150 for (
i=0;
i<nb_components;
i++) {
1153 topleft[
i] = top[
i];
1160 if (!
s->bayer || mb_x) {
1170 mask & (
pred + (unsigned)(
dc * (1 << point_transform)));
1173 if (
s->restart_interval && !--
s->restart_count) {
1178 if (
s->rct &&
s->nb_components == 4) {
1179 for (mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1180 ptr[4*mb_x + 2] =
buffer[mb_x][0] - ((
buffer[mb_x][1] +
buffer[mb_x][2] - 0x200) >> 2);
1181 ptr[4*mb_x + 1] =
buffer[mb_x][1] + ptr[4*mb_x + 2];
1182 ptr[4*mb_x + 3] =
buffer[mb_x][2] + ptr[4*mb_x + 2];
1183 ptr[4*mb_x + 0] =
buffer[mb_x][3];
1185 }
else if (
s->nb_components == 4) {
1186 for(
i=0;
i<nb_components;
i++) {
1187 int c=
s->comp_index[
i];
1189 for(mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1192 }
else if(
s->bits == 9) {
1195 for(mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1196 ((uint16_t*)ptr)[4*mb_x+
c] =
buffer[mb_x][
i];
1200 }
else if (
s->rct) {
1201 for (mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1202 ptr[3*mb_x + 1] =
buffer[mb_x][0] - ((
buffer[mb_x][1] +
buffer[mb_x][2] - 0x200) >> 2);
1203 ptr[3*mb_x + 0] =
buffer[mb_x][1] + ptr[3*mb_x + 1];
1204 ptr[3*mb_x + 2] =
buffer[mb_x][2] + ptr[3*mb_x + 1];
1206 }
else if (
s->pegasus_rct) {
1207 for (mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1209 ptr[3*mb_x + 0] =
buffer[mb_x][1] + ptr[3*mb_x + 1];
1210 ptr[3*mb_x + 2] =
buffer[mb_x][2] + ptr[3*mb_x + 1];
1212 }
else if (
s->bayer) {
1215 if (nb_components == 1) {
1217 for (mb_x = 0; mb_x <
width; mb_x++)
1218 ((uint16_t*)ptr)[mb_x] =
buffer[mb_x][0];
1219 }
else if (nb_components == 2) {
1220 for (mb_x = 0; mb_x <
width; mb_x++) {
1221 ((uint16_t*)ptr)[2*mb_x + 0] =
buffer[mb_x][0];
1222 ((uint16_t*)ptr)[2*mb_x + 1] =
buffer[mb_x][1];
1226 for(
i=0;
i<nb_components;
i++) {
1227 int c=
s->comp_index[
i];
1229 for(mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1232 }
else if(
s->bits == 9) {
1235 for(mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1236 ((uint16_t*)ptr)[3*mb_x+2-
c] =
buffer[mb_x][
i];
1246 int point_transform,
int nb_components)
1248 int i, mb_x, mb_y,
mask;
1249 int bits= (
s->bits+7)&~7;
1250 int resync_mb_y = 0;
1251 int resync_mb_x = 0;
1253 point_transform +=
bits -
s->bits;
1254 mask = ((1 <<
s->bits) - 1) << point_transform;
1256 av_assert0(nb_components>=1 && nb_components<=4);
1258 for (mb_y = 0; mb_y <
s->mb_height; mb_y++) {
1259 for (mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1264 if (
s->restart_interval && !
s->restart_count){
1265 s->restart_count =
s->restart_interval;
1270 if(!mb_x || mb_y == resync_mb_y || mb_y == resync_mb_y+1 && mb_x < resync_mb_x || s->
interlaced){
1271 int toprow = mb_y == resync_mb_y || mb_y == resync_mb_y+1 && mb_x < resync_mb_x;
1272 int leftcol = !mb_x || mb_y == resync_mb_y && mb_x == resync_mb_x;
1273 for (
i = 0;
i < nb_components;
i++) {
1276 int n,
h, v, x, y,
c, j, linesize;
1277 n =
s->nb_blocks[
i];
1278 c =
s->comp_index[
i];
1283 linesize=
s->linesize[
c];
1285 if(
bits>8) linesize /= 2;
1287 for(j=0; j<n; j++) {
1293 if (
h * mb_x + x >=
s->width
1294 || v * mb_y + y >=
s->height) {
1296 }
else if (
bits<=8) {
1297 ptr =
s->picture_ptr->data[
c] + (linesize * (v * mb_y + y)) + (
h * mb_x + x);
1299 if(x==0 && leftcol){
1305 if(x==0 && leftcol){
1306 pred= ptr[-linesize];
1312 if (
s->interlaced &&
s->bottom_field)
1313 ptr += linesize >> 1;
1315 *ptr=
pred + ((unsigned)
dc << point_transform);
1317 ptr16 = (uint16_t*)(
s->picture_ptr->data[
c] + 2*(linesize * (v * mb_y + y)) + 2*(
h * mb_x + x));
1319 if(x==0 && leftcol){
1325 if(x==0 && leftcol){
1326 pred= ptr16[-linesize];
1332 if (
s->interlaced &&
s->bottom_field)
1333 ptr16 += linesize >> 1;
1335 *ptr16=
pred + ((unsigned)
dc << point_transform);
1344 for (
i = 0;
i < nb_components;
i++) {
1347 int n,
h, v, x, y,
c, j, linesize,
dc;
1348 n =
s->nb_blocks[
i];
1349 c =
s->comp_index[
i];
1354 linesize =
s->linesize[
c];
1356 if(
bits>8) linesize /= 2;
1358 for (j = 0; j < n; j++) {
1364 if (
h * mb_x + x >=
s->width
1365 || v * mb_y + y >=
s->height) {
1367 }
else if (
bits<=8) {
1368 ptr =
s->picture_ptr->data[
c] +
1369 (linesize * (v * mb_y + y)) +
1374 *ptr =
pred + ((unsigned)
dc << point_transform);
1376 ptr16 = (uint16_t*)(
s->picture_ptr->data[
c] + 2*(linesize * (v * mb_y + y)) + 2*(
h * mb_x + x));
1380 *ptr16=
pred + ((unsigned)
dc << point_transform);
1390 if (
s->restart_interval && !--
s->restart_count) {
1401 int linesize,
int lowres)
1404 case 0:
s->hdsp.put_pixels_tab[1][0](dst,
src, linesize, 8);
1410 case 3: *dst = *
src;
1417 int block_x, block_y;
1418 int size = 8 >>
s->avctx->lowres;
1420 for (block_y=0; block_y<
size; block_y++)
1421 for (block_x=0; block_x<
size; block_x++)
1422 *(uint16_t*)(ptr + 2*block_x + block_y*linesize) <<= 16 -
s->bits;
1424 for (block_y=0; block_y<
size; block_y++)
1425 for (block_x=0; block_x<
size; block_x++)
1426 *(ptr + block_x + block_y*linesize) <<= 8 -
s->bits;
1431 int Al,
const uint8_t *mb_bitmask,
1432 int mb_bitmask_size,
1435 int i, mb_x, mb_y, chroma_h_shift, chroma_v_shift, chroma_width, chroma_height;
1440 int bytes_per_pixel = 1 + (
s->bits > 8);
1443 if (mb_bitmask_size != (
s->mb_width *
s->mb_height + 7)>>3) {
1447 init_get_bits(&mb_bitmask_gb, mb_bitmask,
s->mb_width *
s->mb_height);
1450 s->restart_count = 0;
1457 for (
i = 0;
i < nb_components;
i++) {
1458 int c =
s->comp_index[
i];
1459 data[
c] =
s->picture_ptr->data[
c];
1460 reference_data[
c] = reference ? reference->
data[
c] :
NULL;
1461 linesize[
c] =
s->linesize[
c];
1462 s->coefs_finished[
c] |= 1;
1465 for (mb_y = 0; mb_y <
s->mb_height; mb_y++) {
1466 for (mb_x = 0; mb_x <
s->mb_width; mb_x++) {
1469 if (
s->restart_interval && !
s->restart_count)
1470 s->restart_count =
s->restart_interval;
1477 for (
i = 0;
i < nb_components;
i++) {
1479 int n,
h, v, x, y,
c, j;
1481 n =
s->nb_blocks[
i];
1482 c =
s->comp_index[
i];
1487 for (j = 0; j < n; j++) {
1488 block_offset = (((linesize[
c] * (v * mb_y + y) * 8) +
1489 (
h * mb_x + x) * 8 * bytes_per_pixel) >>
s->avctx->lowres);
1491 if (
s->interlaced &&
s->bottom_field)
1492 block_offset += linesize[
c] >> 1;
1493 if ( 8*(
h * mb_x + x) < ((
c == 1) || (
c == 2) ? chroma_width :
s->width)
1494 && 8*(v * mb_y + y) < ((
c == 1) || (
c == 2) ? chroma_height :
s->height)) {
1495 ptr =
data[
c] + block_offset;
1498 if (!
s->progressive) {
1502 linesize[
c],
s->avctx->lowres);
1505 s->bdsp.clear_block(
s->block);
1507 s->dc_index[
i],
s->ac_index[
i],
1508 s->quant_matrixes[
s->quant_sindex[
i]]) < 0) {
1510 "error y=%d x=%d\n", mb_y, mb_x);
1514 s->idsp.idct_put(ptr, linesize[
c],
s->block);
1520 int block_idx =
s->block_stride[
c] * (v * mb_y + y) +
1522 int16_t *
block =
s->blocks[
c][block_idx];
1525 s->quant_matrixes[
s->quant_sindex[
i]][0] << Al;
1527 s->quant_matrixes[
s->quant_sindex[
i]],
1530 "error y=%d x=%d\n", mb_y, mb_x);
1534 ff_dlog(
s->avctx,
"mb: %d %d processed\n", mb_y, mb_x);
1535 ff_dlog(
s->avctx,
"%d %d %d %d %d %d %d %d \n",
1536 mb_x, mb_y, x, y,
c,
s->bottom_field,
1537 (v * mb_y + y) * 8, (
h * mb_x + x) * 8);
1552 int se,
int Ah,
int Al)
1556 int c =
s->comp_index[0];
1557 uint16_t *quant_matrix =
s->quant_matrixes[
s->quant_sindex[0]];
1560 if (se < ss || se > 63) {
1567 s->coefs_finished[
c] |= (2ULL <<
se) - (1ULL <<
ss);
1569 s->restart_count = 0;
1571 for (mb_y = 0; mb_y <
s->mb_height; mb_y++) {
1572 int block_idx = mb_y *
s->block_stride[
c];
1573 int16_t (*
block)[64] = &
s->blocks[
c][block_idx];
1574 uint8_t *last_nnz = &
s->last_nnz[
c][block_idx];
1576 av_log(
s->avctx,
AV_LOG_ERROR,
"bitstream truncated in mjpeg_decode_scan_progressive_ac\n");
1579 for (mb_x = 0; mb_x <
s->mb_width; mb_x++,
block++, last_nnz++) {
1581 if (
s->restart_interval && !
s->restart_count)
1582 s->restart_count =
s->restart_interval;
1586 quant_matrix,
ss,
se, Al, &EOBRUN);
1589 quant_matrix,
ss,
se, Al, &EOBRUN);
1595 "error y=%d x=%d\n", mb_y, mb_x);
1610 const int bytes_per_pixel = 1 + (
s->bits > 8);
1611 const int block_size =
s->lossless ? 1 : 8;
1613 for (
c = 0;
c <
s->nb_components;
c++) {
1615 int linesize =
s->linesize[
c];
1616 int h =
s->h_max /
s->h_count[
c];
1617 int v =
s->v_max /
s->v_count[
c];
1618 int mb_width = (
s->width +
h * block_size - 1) / (
h * block_size);
1619 int mb_height = (
s->height + v * block_size - 1) / (v * block_size);
1621 if (~
s->coefs_finished[
c])
1624 if (
s->interlaced &&
s->bottom_field)
1625 data += linesize >> 1;
1627 for (mb_y = 0; mb_y < mb_height; mb_y++) {
1628 uint8_t *ptr =
data + (mb_y * linesize * 8 >>
s->avctx->lowres);
1629 int block_idx = mb_y *
s->block_stride[
c];
1630 int16_t (*
block)[64] = &
s->blocks[
c][block_idx];
1631 for (mb_x = 0; mb_x < mb_width; mb_x++,
block++) {
1632 s->idsp.idct_put(ptr, linesize, *
block);
1635 ptr += bytes_per_pixel*8 >>
s->avctx->lowres;
1642 int mb_bitmask_size,
const AVFrame *reference)
1646 const int block_size =
s->lossless ? 1 : 8;
1647 int ilv, prev_shift;
1649 if (!
s->got_picture) {
1651 "Can not process SOS before SOF, skipping\n");
1656 if (reference->
width !=
s->picture_ptr->width ||
1657 reference->
height !=
s->picture_ptr->height ||
1658 reference->
format !=
s->picture_ptr->format) {
1669 "decode_sos: nb_components (%d)",
1673 if (
len != 6 + 2 * nb_components) {
1677 for (
i = 0;
i < nb_components;
i++) {
1682 if (
id ==
s->component_id[
index])
1684 if (
index ==
s->nb_components) {
1686 "decode_sos: index(%d) out of components\n",
index);
1690 if (
s->avctx->codec_tag ==
MKTAG(
'M',
'T',
'S',
'J')
1691 && nb_components == 3 &&
s->nb_components == 3 &&
i)
1694 s->quant_sindex[
i] =
s->quant_index[
index];
1696 s->h_scount[
i] =
s->h_count[
index];
1697 s->v_scount[
i] =
s->v_count[
index];
1699 if((nb_components == 1 || nb_components == 3) &&
s->nb_components == 3 &&
s->avctx->pix_fmt ==
AV_PIX_FMT_GBR24P)
1707 if (
s->dc_index[
i] < 0 ||
s->ac_index[
i] < 0 ||
1708 s->dc_index[
i] >= 4 ||
s->ac_index[
i] >= 4)
1710 if (!
s->vlcs[0][
s->dc_index[
i]].table || !(
s->progressive ?
s->vlcs[2][
s->ac_index[0]].table :
s->vlcs[1][
s->ac_index[
i]].table))
1716 if(
s->avctx->codec_tag !=
AV_RL32(
"CJPG")){
1720 prev_shift = point_transform = 0;
1722 if (nb_components > 1) {
1724 s->mb_width = (
s->width +
s->h_max * block_size - 1) / (
s->h_max * block_size);
1725 s->mb_height = (
s->height +
s->v_max * block_size - 1) / (
s->v_max * block_size);
1726 }
else if (!
s->ls) {
1727 h =
s->h_max /
s->h_scount[0];
1728 v =
s->v_max /
s->v_scount[0];
1729 s->mb_width = (
s->width +
h * block_size - 1) / (
h * block_size);
1730 s->mb_height = (
s->height + v * block_size - 1) / (v * block_size);
1731 s->nb_blocks[0] = 1;
1738 s->lossless ?
"lossless" :
"sequential DCT",
s->rgb ?
"RGB" :
"",
1739 predictor, point_transform, ilv,
s->bits,
s->mjpb_skiptosod,
1740 s->pegasus_rct ?
"PRCT" : (
s->rct ?
"RCT" :
""), nb_components);
1744 for (
i =
s->mjpb_skiptosod;
i > 0;
i--)
1748 for (
i = 0;
i < nb_components;
i++)
1749 s->last_dc[
i] = (4 <<
s->bits);
1751 if (
s->avctx->hwaccel) {
1754 s->raw_scan_buffer_size >= bytes_to_start);
1756 ret =
s->avctx->hwaccel->decode_slice(
s->avctx,
1757 s->raw_scan_buffer + bytes_to_start,
1758 s->raw_scan_buffer_size - bytes_to_start);
1762 }
else if (
s->lossless) {
1769 point_transform, ilv)) < 0)
1772 if (
s->rgb ||
s->bayer) {
1778 nb_components)) < 0)
1787 point_transform)) < 0)
1791 prev_shift, point_transform,
1792 mb_bitmask, mb_bitmask_size, reference)) < 0)
1797 if (
s->interlaced &&
1806 s->bottom_field ^= 1;
1824 s->restart_count = 0;
1826 s->restart_interval);
1873 int t_w, t_h, v1, v2;
1881 s->avctx->sample_aspect_ratio.num =
get_bits(&
s->gb, 16);
1882 s->avctx->sample_aspect_ratio.den =
get_bits(&
s->gb, 16);
1883 if (
s->avctx->sample_aspect_ratio.num <= 0
1884 ||
s->avctx->sample_aspect_ratio.den <= 0) {
1885 s->avctx->sample_aspect_ratio.num = 0;
1886 s->avctx->sample_aspect_ratio.den = 1;
1891 "mjpeg: JFIF header found (version: %x.%x) SAR=%d/%d\n",
1893 s->avctx->sample_aspect_ratio.num,
1894 s->avctx->sample_aspect_ratio.den);
1902 if (
len -10 - (t_w * t_h * 3) > 0)
1903 len -= t_w * t_h * 3;
1920 av_log(
s->avctx,
AV_LOG_INFO,
"mjpeg: Adobe header found, transform=%d\n",
s->adobe_transform);
1927 int pegasus_rct =
s->pegasus_rct;
1930 "Pegasus lossless jpeg header found\n");
1952 if (
rgb !=
s->rgb || pegasus_rct !=
s->pegasus_rct) {
1958 s->pegasus_rct = pegasus_rct;
1998 }
else if (
type == 1) {
2010 if (!(
flags & 0x04)) {
2020 int ret, le, ifd_offset, bytes_read;
2053 if ((
s->start_code ==
APP1) && (
len > (0x28 - 8))) {
2076 unsigned nummarkers;
2096 if (nummarkers == 0) {
2099 }
else if (
s->iccnum != 0 && nummarkers !=
s->iccnum) {
2102 }
else if (seqno > nummarkers) {
2108 if (
s->iccnum == 0) {
2113 s->iccnum = nummarkers;
2116 if (
s->iccentries[seqno - 1].data) {
2121 s->iccentries[seqno - 1].length =
len;
2123 if (!
s->iccentries[seqno - 1].data) {
2133 if (
s->iccread >
s->iccnum)
2141 "mjpeg: error, decode_app parser read over the end\n");
2157 for (
i = 0;
i <
len - 2;
i++)
2159 if (
i > 0 && cbuf[
i - 1] ==
'\n')
2168 if (!strncmp(cbuf,
"AVID", 4)) {
2170 }
else if (!strcmp(cbuf,
"CS=ITU601"))
2172 else if ((!strncmp(cbuf,
"Intel(R) JPEG Library, version 1", 32) &&
s->avctx->codec_tag) ||
2173 (!strncmp(cbuf,
"Metasoft MJPEG Codec", 20)))
2175 else if (!strcmp(cbuf,
"MULTISCOPE II")) {
2176 s->avctx->sample_aspect_ratio = (
AVRational) { 1, 2 };
2195 buf_ptr = *pbuf_ptr;
2196 while (buf_end - buf_ptr > 1) {
2199 if ((v == 0xff) && (v2 >=
SOF0) && (v2 <=
COM) && buf_ptr < buf_end) {
2208 ff_dlog(
NULL,
"find_marker skipped %d bytes\n", skipped);
2209 *pbuf_ptr = buf_ptr;
2215 const uint8_t **unescaped_buf_ptr,
2216 int *unescaped_buf_size)
2231 #define copy_data_segment(skip) do { \
2232 ptrdiff_t length = (ptr - src) - (skip); \
2234 memcpy(dst, src, length); \
2244 while (ptr < buf_end) {
2249 while (ptr < buf_end && x == 0xff) {
2264 if (x < RST0 || x >
RST7) {
2274 #undef copy_data_segment
2276 *unescaped_buf_ptr =
s->buffer;
2277 *unescaped_buf_size = dst -
s->buffer;
2278 memset(
s->buffer + *unescaped_buf_size, 0,
2282 (buf_end - *buf_ptr) - (dst -
s->buffer));
2291 while (
src + t < buf_end) {
2294 while ((
src + t < buf_end) && x == 0xff)
2309 if (x == 0xFF &&
b < t) {
2321 *unescaped_buf_ptr = dst;
2322 *unescaped_buf_size = (bit_count + 7) >> 3;
2323 memset(
s->buffer + *unescaped_buf_size, 0,
2326 *unescaped_buf_ptr = *buf_ptr;
2327 *unescaped_buf_size = buf_end - *buf_ptr;
2337 if (
s->iccentries) {
2338 for (
i = 0;
i <
s->iccnum;
i++)
2354 if (
s->smv_next_frame > 0) {
2375 s->smv_next_frame = (
s->smv_next_frame + 1) %
s->smv_frames_per_jpeg;
2377 if (
s->smv_next_frame == 0)
2393 #if CONFIG_SP5X_DECODER || CONFIG_AMV_DECODER
2402 s->buf_size =
s->pkt->size;
2410 const uint8_t *buf_end, *buf_ptr;
2411 const uint8_t *unescaped_buf_ptr;
2413 int unescaped_buf_size;
2424 s->adobe_transform = -1;
2433 buf_ptr =
s->pkt->data;
2434 buf_end =
s->pkt->data +
s->pkt->size;
2435 while (buf_ptr < buf_end) {
2439 &unescaped_buf_size);
2443 }
else if (unescaped_buf_size > INT_MAX / 8) {
2445 "MJPEG packet 0x%x too big (%d/%d), corrupt data?\n",
2509 s->restart_interval = 0;
2510 s->restart_count = 0;
2511 s->raw_image_buffer = buf_ptr;
2512 s->raw_image_buffer_size = buf_end - buf_ptr;
2567 s->progressive &&
s->cur_scan &&
s->got_picture)
2570 if (!
s->got_picture) {
2572 "Found EOI before any SOF, ignoring\n");
2575 if (
s->interlaced) {
2576 s->bottom_field ^= 1;
2578 if (
s->bottom_field == !
s->interlace_polarity)
2584 goto the_end_no_picture;
2586 if (
s->avctx->hwaccel) {
2587 ret =
s->avctx->hwaccel->end_frame(
s->avctx);
2609 s->raw_scan_buffer = buf_ptr;
2610 s->raw_scan_buffer_size = buf_end - buf_ptr;
2637 "mjpeg: unsupported coding type (%x)\n",
start_code);
2645 "marker parser used %d bytes (%d bits)\n",
2648 if (
s->got_picture &&
s->cur_scan) {
2681 for (p = 0; p<
s->nb_components; p++) {
2685 if (!
s->upscale_h[p])
2691 if (
s->upscale_v[p] == 1)
2694 for (
i = 0;
i <
h;
i++) {
2695 if (
s->upscale_h[p] == 1) {
2696 if (is16bit) ((uint16_t*)
line)[
w - 1] = ((uint16_t*)
line)[(
w - 1) / 2];
2704 }
else if (
s->upscale_h[p] == 2) {
2706 ((uint16_t*)
line)[
w - 1] = ((uint16_t*)
line)[(
w - 1) / 3];
2708 ((uint16_t*)
line)[
w - 2] = ((uint16_t*)
line)[
w - 1];
2718 line +=
s->linesize[p];
2743 for (p = 0; p <
s->nb_components; p++) {
2747 if (!
s->upscale_v[p])
2753 dst = &((
uint8_t *)
s->picture_ptr->data[p])[(
h - 1) *
s->linesize[p]];
2755 uint8_t *
src1 = &((
uint8_t *)
s->picture_ptr->data[p])[
i *
s->upscale_v[p] / (
s->upscale_v[p] + 1) *
s->linesize[p]];
2756 uint8_t *src2 = &((
uint8_t *)
s->picture_ptr->data[p])[(
i + 1) *
s->upscale_v[p] / (
s->upscale_v[p] + 1) *
s->linesize[p]];
2757 if (
s->upscale_v[p] != 2 && (
src1 == src2 ||
i ==
h - 1)) {
2758 memcpy(dst,
src1,
w);
2763 dst -=
s->linesize[p];
2767 if (
s->flipped && !
s->rgb) {
2776 int w =
s->picture_ptr->width;
2777 int h =
s->picture_ptr->height;
2784 for (
i=0;
i<
h/2;
i++) {
2786 FFSWAP(
int, dst[j], dst2[j]);
2787 dst +=
s->picture_ptr->linesize[
index];
2788 dst2 -=
s->picture_ptr->linesize[
index];
2794 int w =
s->picture_ptr->width;
2795 int h =
s->picture_ptr->height;
2797 for (
i=0;
i<
h;
i++) {
2802 +
s->picture_ptr->linesize[
index]*
i;
2804 for (j=0; j<
w; j++) {
2806 int r = dst[0][j] * k;
2807 int g = dst[1][j] * k;
2808 int b = dst[2][j] * k;
2809 dst[0][j] =
g*257 >> 16;
2810 dst[1][j] =
b*257 >> 16;
2811 dst[2][j] =
r*257 >> 16;
2817 int w =
s->picture_ptr->width;
2818 int h =
s->picture_ptr->height;
2820 for (
i=0;
i<
h;
i++) {
2825 +
s->picture_ptr->linesize[
index]*
i;
2827 for (j=0; j<
w; j++) {
2829 int r = (255 - dst[0][j]) * k;
2830 int g = (128 - dst[1][j]) * k;
2831 int b = (128 - dst[2][j]) * k;
2832 dst[0][j] =
r*257 >> 16;
2833 dst[1][j] = (
g*257 >> 16) + 128;
2834 dst[2][j] = (
b*257 >> 16) + 128;
2843 stereo->
type =
s->stereo3d->type;
2844 stereo->
flags =
s->stereo3d->flags;
2849 if (
s->iccnum != 0 &&
s->iccnum ==
s->iccread) {
2856 for (
i = 0;
i <
s->iccnum;
i++)
2857 total_size +=
s->iccentries[
i].length;
2866 for (
i = 0;
i <
s->iccnum;
i++) {
2867 memcpy(sd->
data +
offset,
s->iccentries[
i].data,
s->iccentries[
i].length);
2905 if (
s->interlaced &&
s->bottom_field == !
s->interlace_polarity &&
s->got_picture && !avctx->
frame_number) {
2911 s->picture_ptr =
NULL;
2912 }
else if (
s->picture_ptr)
2922 s->ljpeg_buffer_size = 0;
2924 for (
i = 0;
i < 3;
i++) {
2925 for (j = 0; j < 4; j++)
2946 s->smv_next_frame = 0;
2950 #if CONFIG_MJPEG_DECODER
2951 #define OFFSET(x) offsetof(MJpegDecodeContext, x)
2952 #define VD AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_DECODING_PARAM
2954 {
"extern_huff",
"Use external huffman table.",
2959 static const AVClass mjpegdec_class = {
2978 .priv_class = &mjpegdec_class,
2983 #if CONFIG_MJPEG_NVDEC_HWACCEL
2986 #if CONFIG_MJPEG_VAAPI_HWACCEL
2993 #if CONFIG_THP_DECODER
3011 #if CONFIG_SMVJPEG_DECODER
static void flush(AVCodecContext *avctx)
static double val(void *priv, double ch)
AVCodec ff_smvjpeg_decoder
uint8_t pi<< 24) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8, uint8_t,(*(const uint8_t *) pi - 0x80) *(1.0f/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8, uint8_t,(*(const uint8_t *) pi - 0x80) *(1.0/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16, int16_t,(*(const int16_t *) pi >> 8)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, int16_t, *(const int16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, int16_t, *(const int16_t *) pi *(1.0/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32, int32_t,(*(const int32_t *) pi >> 24)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, int32_t, *(const int32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, int32_t, *(const int32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, float, av_clip_uint8(lrintf(*(const float *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, float, av_clip_int16(lrintf(*(const float *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, float, av_clipl_int32(llrintf(*(const float *) pi *(1U<< 31)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, double, av_clip_uint8(lrint(*(const double *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, double, av_clip_int16(lrint(*(const double *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, double, av_clipl_int32(llrint(*(const double *) pi *(1U<< 31)))) #define SET_CONV_FUNC_GROUP(ofmt, ifmt) static void set_generic_function(AudioConvert *ac) { } void ff_audio_convert_free(AudioConvert **ac) { if(! *ac) return;ff_dither_free(&(*ac) ->dc);av_freep(ac);} AudioConvert *ff_audio_convert_alloc(AVAudioResampleContext *avr, enum AVSampleFormat out_fmt, enum AVSampleFormat in_fmt, int channels, int sample_rate, int apply_map) { AudioConvert *ac;int in_planar, out_planar;ac=av_mallocz(sizeof(*ac));if(!ac) return NULL;ac->avr=avr;ac->out_fmt=out_fmt;ac->in_fmt=in_fmt;ac->channels=channels;ac->apply_map=apply_map;if(avr->dither_method !=AV_RESAMPLE_DITHER_NONE &&av_get_packed_sample_fmt(out_fmt)==AV_SAMPLE_FMT_S16 &&av_get_bytes_per_sample(in_fmt) > 2) { ac->dc=ff_dither_alloc(avr, out_fmt, in_fmt, channels, sample_rate, apply_map);if(!ac->dc) { av_free(ac);return NULL;} return ac;} in_planar=ff_sample_fmt_is_planar(in_fmt, channels);out_planar=ff_sample_fmt_is_planar(out_fmt, channels);if(in_planar==out_planar) { ac->func_type=CONV_FUNC_TYPE_FLAT;ac->planes=in_planar ? ac->channels :1;} else if(in_planar) ac->func_type=CONV_FUNC_TYPE_INTERLEAVE;else ac->func_type=CONV_FUNC_TYPE_DEINTERLEAVE;set_generic_function(ac);if(ARCH_AARCH64) ff_audio_convert_init_aarch64(ac);if(ARCH_ARM) ff_audio_convert_init_arm(ac);if(ARCH_X86) ff_audio_convert_init_x86(ac);return ac;} int ff_audio_convert(AudioConvert *ac, AudioData *out, AudioData *in) { int use_generic=1;int len=in->nb_samples;int p;if(ac->dc) { av_log(ac->avr, AV_LOG_TRACE, "%d samples - audio_convert: %s to %s (dithered)\n", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt));return ff_convert_dither(ac-> dc
simple assert() macros that are a bit more flexible than ISO C assert().
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Libavcodec external API header.
#define FF_DEBUG_STARTCODE
#define FF_PROFILE_MJPEG_HUFFMAN_EXTENDED_SEQUENTIAL_DCT
#define FF_DEBUG_PICT_INFO
#define AV_EF_EXPLODE
abort decoding on minor error detection
#define FF_PROFILE_MJPEG_HUFFMAN_BASELINE_DCT
#define FF_PROFILE_MJPEG_HUFFMAN_LOSSLESS
#define FF_CODEC_PROPERTY_LOSSLESS
#define FF_PROFILE_MJPEG_JPEG_LS
#define FF_PROFILE_MJPEG_HUFFMAN_PROGRESSIVE_DCT
static av_cold int init(AVCodecContext *avctx)
void ff_free_vlc(VLC *vlc)
static av_always_inline void bytestream2_init(GetByteContext *g, const uint8_t *buf, int buf_size)
static av_always_inline int bytestream2_seek(GetByteContext *g, int offset, int whence)
static av_always_inline int bytestream2_tell(GetByteContext *g)
#define flags(name, subs,...)
#define is(width, name, range_min, range_max, subs,...)
#define se(name, range_min, range_max)
#define ss(width, name, subs,...)
static void copy_mb(CinepakEncContext *s, uint8_t *a_data[4], int a_linesize[4], uint8_t *b_data[4], int b_linesize[4])
#define FFSWAP(type, a, b)
#define MKTAG(a, b, c, d)
#define AV_CEIL_RSHIFT(a, b)
#define CONFIG_JPEGLS_DECODER
static void copy_block2(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride, int h)
static void copy_block4(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride, int h)
static CopyRet receive_frame(AVCodecContext *avctx, AVFrame *frame, int *got_frame)
static int aligned(int val)
int ff_get_buffer(AVCodecContext *avctx, AVFrame *frame, int flags)
Get a buffer for a frame.
int ff_decode_get_packet(AVCodecContext *avctx, AVPacket *pkt)
Called by decoders to get the next packet for decoding.
int ff_get_format(AVCodecContext *avctx, const enum AVPixelFormat *fmt)
Select the (possibly hardware accelerated) pixel format.
int ff_exif_decode_ifd(void *logctx, GetByteContext *gbytes, int le, int depth, AVDictionary **metadata)
static void predictor(uint8_t *src, ptrdiff_t size)
const OptionDef options[]
#define GET_VLC(code, name, gb, table, bits, max_depth)
If the vlc code is invalid and max_depth=1, then no bits will be removed.
static unsigned int show_bits_long(GetBitContext *s, int n)
Show 0-32 bits.
static unsigned int get_bits_long(GetBitContext *s, int n)
Read 0-32 bits.
#define GET_CACHE(name, gb)
static av_always_inline int get_vlc2(GetBitContext *s, VLC_TYPE(*table)[2], int bits, int max_depth)
Parse a vlc code.
#define CLOSE_READER(name, gb)
static int get_bits_left(GetBitContext *gb)
static void skip_bits_long(GetBitContext *s, int n)
Skips the specified number of bits.
#define SHOW_UBITS(name, gb, num)
static unsigned int get_bits1(GetBitContext *s)
#define OPEN_READER(name, gb)
static void skip_bits(GetBitContext *s, int n)
#define UPDATE_CACHE(name, gb)
static int init_get_bits8(GetBitContext *s, const uint8_t *buffer, int byte_size)
Initialize GetBitContext.
#define LAST_SKIP_BITS(name, gb, num)
static int get_bits_count(const GetBitContext *s)
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
static const uint8_t * align_get_bits(GetBitContext *s)
static unsigned int show_bits(GetBitContext *s, int n)
Show 1-25 bits.
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
static int get_xbits(GetBitContext *s, int n)
Read MPEG-1 dc-style VLC (sign bit + mantissa with no MSB).
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() or get_encode_buffer() for allocating buffers and supports custom allocators.
#define AV_GET_BUFFER_FLAG_REF
The decoder will keep a reference to the frame and may reuse it later.
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding.
@ AVDISCARD_ALL
discard all
void av_fast_padded_malloc(void *ptr, unsigned int *size, size_t min_size)
Same behaviour av_fast_malloc but the buffer has additional AV_INPUT_BUFFER_PADDING_SIZE at the end w...
void av_packet_free(AVPacket **pkt)
Free the packet, if the packet is reference counted, it will be unreferenced first.
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
AVPacket * av_packet_alloc(void)
Allocate an AVPacket and set its fields to default values.
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values.
int av_dict_copy(AVDictionary **dst, const AVDictionary *src, int flags)
Copy entries from one AVDictionary struct into another.
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
void av_frame_unref(AVFrame *frame)
Unreference all the buffers referenced by frame and reset the frame fields.
int av_frame_ref(AVFrame *dst, const AVFrame *src)
Set up a new reference to the data described by the source frame.
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
AVFrameSideData * av_frame_new_side_data(AVFrame *frame, enum AVFrameSideDataType type, buffer_size_t size)
Add a new side data to a frame.
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
@ AV_FRAME_DATA_ICC_PROFILE
The data contains an ICC profile as an opaque octet buffer following the format described by ISO 1507...
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
#define AV_LOG_WARNING
Something somehow does not look correct.
#define AV_LOG_FATAL
Something went wrong and recovery is not possible.
#define AV_LOG_INFO
Standard information.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
const char * av_default_item_name(void *ptr)
Return the context name.
void av_fast_malloc(void *ptr, unsigned int *size, size_t min_size)
Allocate a buffer, reusing the given one if large enough.
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
void * av_mallocz_array(size_t nmemb, size_t size)
Allocate a memory block for an array with av_mallocz().
#define av_fourcc2str(fourcc)
int av_image_check_size(unsigned int w, unsigned int h, int log_offset, void *log_ctx)
Check if the given dimension of an image is valid, meaning that all bytes of the image can be address...
@ AV_PICTURE_TYPE_I
Intra.
#define LIBAVUTIL_VERSION_INT
AVStereo3D * av_stereo3d_alloc(void)
Allocate an AVStereo3D structure and set its fields to default values.
#define AV_STEREO3D_FLAG_INVERT
Inverted views, Right/Bottom represents the left view.
AVStereo3D * av_stereo3d_create_side_data(AVFrame *frame)
Allocate a complete AVFrameSideData and add it to the frame.
@ AV_STEREO3D_LINES
Views are packed per line, as if interlaced.
@ AV_STEREO3D_2D
Video is not stereoscopic (and metadata has to be there).
@ AV_STEREO3D_TOPBOTTOM
Views are on top of each other.
@ AV_STEREO3D_SIDEBYSIDE
Views are next to each other.
av_cold void ff_hpeldsp_init(HpelDSPContext *c, int flags)
#define HWACCEL_NVDEC(codec)
#define HWACCEL_VAAPI(codec)
av_cold void ff_idctdsp_init(IDCTDSPContext *c, AVCodecContext *avctx)
av_cold void ff_init_scantable(uint8_t *permutation, ScanTable *st, const uint8_t *src_scantable)
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
int ff_jpegls_decode_lse(MJpegDecodeContext *s)
Decode LSE block with initialization parameters.
int ff_jpegls_decode_picture(MJpegDecodeContext *s, int near, int point_transform, int ilv)
const uint8_t avpriv_mjpeg_val_dc[12]
const uint8_t avpriv_mjpeg_bits_ac_chrominance[17]
const uint8_t avpriv_mjpeg_val_ac_chrominance[]
const uint8_t avpriv_mjpeg_bits_dc_luminance[17]
const uint8_t avpriv_mjpeg_val_ac_luminance[]
const uint8_t avpriv_mjpeg_bits_dc_chrominance[17]
const uint8_t avpriv_mjpeg_bits_ac_luminance[17]
av_cold void ff_blockdsp_init(BlockDSPContext *c, AVCodecContext *avctx)
#define FF_CODEC_CAP_SETS_PKT_DTS
Decoders marked with FF_CODEC_CAP_SETS_PKT_DTS want to set AVFrame.pkt_dts manually.
#define FF_CODEC_CAP_EXPORTS_CROPPING
The decoder sets the cropping fields in the output frames manually.
#define FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM
The decoder extracts and fills its parameters even if the frame is skipped due to the skip_frame sett...
#define FF_CODEC_CAP_INIT_THREADSAFE
The codec does not modify any global variables in the init function, allowing to call the init functi...
#define FF_CODEC_CAP_INIT_CLEANUP
The codec allows calling the close function for deallocation even if the init function returned a fai...
int ff_set_dimensions(AVCodecContext *s, int width, int height)
Check that the provided frame dimensions are valid and set them on the codec context.
common internal API header
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
#define PTRDIFF_SPECIFIER
void avpriv_report_missing_feature(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message about a missing feature.
#define FF_ALLOCZ_TYPED_ARRAY(p, nelem)
static const AVProfile profiles[]
static enum AVPixelFormat pix_fmts[]
static const uint16_t mask[17]
const uint8_t ff_zigzag_direct[64]
MJPEG encoder and decoder.
#define PREDICT(ret, topleft, top, left, predictor)
@ LSE
JPEG-LS extension parameters.
static int mjpeg_get_packet(AVCodecContext *avctx)
static void init_idct(AVCodecContext *avctx)
int ff_mjpeg_find_marker(MJpegDecodeContext *s, const uint8_t **buf_ptr, const uint8_t *buf_end, const uint8_t **unescaped_buf_ptr, int *unescaped_buf_size)
static void reset_icc_profile(MJpegDecodeContext *s)
av_cold int ff_mjpeg_decode_init(AVCodecContext *avctx)
static void parse_avid(MJpegDecodeContext *s, uint8_t *buf, int len)
#define copy_data_segment(skip)
static int mjpeg_decode_com(MJpegDecodeContext *s)
static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int nb_components, int predictor, int point_transform)
static int ljpeg_decode_yuv_scan(MJpegDecodeContext *s, int predictor, int point_transform, int nb_components)
int ff_mjpeg_decode_dqt(MJpegDecodeContext *s)
static av_always_inline void mjpeg_copy_block(MJpegDecodeContext *s, uint8_t *dst, const uint8_t *src, int linesize, int lowres)
av_cold int ff_mjpeg_decode_end(AVCodecContext *avctx)
static int mjpeg_decode_scan(MJpegDecodeContext *s, int nb_components, int Ah, int Al, const uint8_t *mb_bitmask, int mb_bitmask_size, const AVFrame *reference)
static void shift_output(MJpegDecodeContext *s, uint8_t *ptr, int linesize)
int ff_mjpeg_receive_frame(AVCodecContext *avctx, AVFrame *frame)
int ff_mjpeg_decode_sos(MJpegDecodeContext *s, const uint8_t *mb_bitmask, int mb_bitmask_size, const AVFrame *reference)
static int mjpeg_decode_dc(MJpegDecodeContext *s, int dc_index)
static int mjpeg_decode_scan_progressive_ac(MJpegDecodeContext *s, int ss, int se, int Ah, int Al)
static void decode_flush(AVCodecContext *avctx)
static int find_marker(const uint8_t **pbuf_ptr, const uint8_t *buf_end)
static int handle_rstn(MJpegDecodeContext *s, int nb_components)
static int mjpeg_decode_dri(MJpegDecodeContext *s)
static int smv_process_frame(AVCodecContext *avctx, AVFrame *frame)
static int decode_block_refinement(MJpegDecodeContext *s, int16_t *block, uint8_t *last_nnz, int ac_index, uint16_t *quant_matrix, int ss, int se, int Al, int *EOBRUN)
int ff_mjpeg_decode_sof(MJpegDecodeContext *s)
static int mjpeg_decode_app(MJpegDecodeContext *s)
static void mjpeg_idct_scan_progressive_ac(MJpegDecodeContext *s)
static int init_default_huffman_tables(MJpegDecodeContext *s)
static int decode_block(MJpegDecodeContext *s, int16_t *block, int component, int dc_index, int ac_index, uint16_t *quant_matrix)
static int decode_dc_progressive(MJpegDecodeContext *s, int16_t *block, int component, int dc_index, uint16_t *quant_matrix, int Al)
int ff_mjpeg_decode_dht(MJpegDecodeContext *s)
static int decode_block_progressive(MJpegDecodeContext *s, int16_t *block, uint8_t *last_nnz, int ac_index, uint16_t *quant_matrix, int ss, int se, int Al, int *EOBRUN)
int ff_sp5x_process_packet(AVCodecContext *avctx, AVPacket *avpkt)
int ff_mjpeg_build_vlc(VLC *vlc, const uint8_t *bits_table, const uint8_t *val_table, int is_ac, void *logctx)
int av_pix_fmt_count_planes(enum AVPixelFormat pix_fmt)
int av_pix_fmt_get_chroma_sub_sample(enum AVPixelFormat pix_fmt, int *h_shift, int *v_shift)
Utility function to access log2_chroma_w log2_chroma_h from the pixel format AVPixFmtDescriptor.
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
#define AV_PIX_FMT_YUV420P16
@ AVCHROMA_LOC_CENTER
MPEG-1 4:2:0, JPEG 4:2:0, H.263 4:2:0.
@ AVCOL_RANGE_MPEG
Narrow or limited range content.
@ AVCOL_RANGE_JPEG
Full range content.
#define AV_PIX_FMT_YUVA420P16
#define AV_PIX_FMT_RGBA64
AVPixelFormat
Pixel format.
@ AV_PIX_FMT_RGB24
packed RGB 8:8:8, 24bpp, RGBRGB...
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
@ AV_PIX_FMT_YUV422P
planar YUV 4:2:2, 16bpp, (1 Cr & Cb sample per 2x1 Y samples)
@ AV_PIX_FMT_GRAY8
Y , 8bpp.
@ AV_PIX_FMT_ABGR
packed ABGR 8:8:8:8, 32bpp, ABGRABGR...
@ AV_PIX_FMT_YUVA420P
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
@ AV_PIX_FMT_CUDA
HW acceleration through CUDA.
@ AV_PIX_FMT_YUVJ440P
planar YUV 4:4:0 full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV440P and setting color_range
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
@ AV_PIX_FMT_YUVA444P
planar YUV 4:4:4 32bpp, (1 Cr & Cb sample per 1x1 Y & A samples)
@ AV_PIX_FMT_YUVJ411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples) full scale (JPEG), deprecated in favor ...
@ AV_PIX_FMT_GBRAP
planar GBRA 4:4:4:4 32bpp
@ AV_PIX_FMT_YUVJ422P
planar YUV 4:2:2, 16bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV422P and setting col...
@ AV_PIX_FMT_GRAY16LE
Y , 16bpp, little-endian.
@ AV_PIX_FMT_PAL8
8 bits with AV_PIX_FMT_RGB32 palette
@ AV_PIX_FMT_BGR24
packed RGB 8:8:8, 24bpp, BGRBGR...
@ AV_PIX_FMT_GBRP
planar GBR 4:4:4 24bpp
@ AV_PIX_FMT_YUVJ444P
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
@ AV_PIX_FMT_YUVJ420P
planar YUV 4:2:0, 12bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV420P and setting col...
#define AV_PIX_FMT_YUV422P16
#define AV_PIX_FMT_GRAY16
#define AV_PIX_FMT_YUVA444P16
#define AV_PIX_FMT_GBRP16
#define AV_PIX_FMT_YUV444P16
@ AVCOL_SPC_BT470BG
also ITU-R BT601-6 625 / ITU-R BT1358 625 / ITU-R BT1700 625 PAL & SECAM / IEC 61966-2-4 xvYCC601
const AVProfile ff_mjpeg_profiles[]
static void init_put_bits(PutBitContext *s, uint8_t *buffer, int buffer_size)
Initialize the PutBitContext s.
static void flush_put_bits(PutBitContext *s)
Pad the end of the output stream with zeros.
static const SheerTable rgb[2]
#define FF_ARRAY_ELEMS(a)
static const float pred[4]
Describe the class of an AVClass context structure.
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
main external API structure.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
enum AVFieldOrder field_order
Field order.
const struct AVHWAccel * hwaccel
Hardware accelerator in use.
const struct AVCodec * codec
enum AVColorSpace colorspace
YUV colorspace type.
int frame_number
Frame counter, set by libavcodec.
int flags
AV_CODEC_FLAG_*.
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
enum AVChromaLocation chroma_sample_location
This defines the location of chroma samples.
int coded_width
Bitstream width / height, may be different from width/height e.g.
int lowres
low resolution decoding, 1-> 1/2 size, 2->1/4 size
enum AVDiscard skip_frame
Skip decoding for selected frames.
int err_recognition
Error recognition; may misdetect some more or less valid parts as errors.
const char * name
Name of the codec implementation.
int step
Number of elements between 2 horizontally consecutive pixels.
Structure to hold side data for an AVFrame.
This structure describes decoded (raw) audio or video data.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
AVBufferRef * buf[AV_NUM_DATA_POINTERS]
AVBuffer references backing the data for this frame.
AVDictionary * metadata
metadata.
int64_t pkt_dts
DTS copied from the AVPacket that triggered returning this frame.
int format
format of the frame, -1 if unknown or unset Values correspond to enum AVPixelFormat for video frames,...
AVComponentDescriptor comp[4]
Parameters that describe how pixels are packed.
Rational number (pair of numerator and denominator).
Stereo 3D type: this structure describes how two videos are packed within a single video surface,...
enum AVStereo3DType type
How views are packed within the video.
int flags
Additional information about the frame packing.
#define avpriv_request_sample(...)
TIFF constants & data structures.
int ff_tdecode_header(GetByteContext *gb, int *le, int *ifd_offset)
Decodes a TIFF header from the input bytestream and sets the endianness in *le and the offset to the ...
static const uint8_t offset[127][2]