Go to the documentation of this file.
   45 #define BITSTREAM_READER_LE 
   54 #define VP8X_FLAG_ANIMATION             0x02 
   55 #define VP8X_FLAG_XMP_METADATA          0x04 
   56 #define VP8X_FLAG_EXIF_METADATA         0x08 
   57 #define VP8X_FLAG_ALPHA                 0x10 
   58 #define VP8X_FLAG_ICC                   0x20 
   60 #define MAX_PALETTE_SIZE                256 
   61 #define MAX_CACHE_BITS                  11 
   62 #define NUM_CODE_LENGTH_CODES           19 
   63 #define HUFFMAN_CODES_PER_META_CODE     5 
   64 #define NUM_LITERAL_CODES               256 
   65 #define NUM_LENGTH_CODES                24 
   66 #define NUM_DISTANCE_CODES              40 
   67 #define NUM_SHORT_DISTANCES             120 
   68 #define MAX_HUFFMAN_CODE_LENGTH         15 
   77     17, 18, 0, 1, 2, 3, 4, 5, 16, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15
 
   81     {  0, 1 }, {  1, 0 }, {  1, 1 }, { -1, 1 }, {  0, 2 }, {  2, 0 }, {  1, 2 }, { -1, 2 },
 
   82     {  2, 1 }, { -2, 1 }, {  2, 2 }, { -2, 2 }, {  0, 3 }, {  3, 0 }, {  1, 3 }, { -1, 3 },
 
   83     {  3, 1 }, { -3, 1 }, {  2, 3 }, { -2, 3 }, {  3, 2 }, { -3, 2 }, {  0, 4 }, {  4, 0 },
 
   84     {  1, 4 }, { -1, 4 }, {  4, 1 }, { -4, 1 }, {  3, 3 }, { -3, 3 }, {  2, 4 }, { -2, 4 },
 
   85     {  4, 2 }, { -4, 2 }, {  0, 5 }, {  3, 4 }, { -3, 4 }, {  4, 3 }, { -4, 3 }, {  5, 0 },
 
   86     {  1, 5 }, { -1, 5 }, {  5, 1 }, { -5, 1 }, {  2, 5 }, { -2, 5 }, {  5, 2 }, { -5, 2 },
 
   87     {  4, 4 }, { -4, 4 }, {  3, 5 }, { -3, 5 }, {  5, 3 }, { -5, 3 }, {  0, 6 }, {  6, 0 },
 
   88     {  1, 6 }, { -1, 6 }, {  6, 1 }, { -6, 1 }, {  2, 6 }, { -2, 6 }, {  6, 2 }, { -6, 2 },
 
   89     {  4, 5 }, { -4, 5 }, {  5, 4 }, { -5, 4 }, {  3, 6 }, { -3, 6 }, {  6, 3 }, { -6, 3 },
 
   90     {  0, 7 }, {  7, 0 }, {  1, 7 }, { -1, 7 }, {  5, 5 }, { -5, 5 }, {  7, 1 }, { -7, 1 },
 
   91     {  4, 6 }, { -4, 6 }, {  6, 4 }, { -6, 4 }, {  2, 7 }, { -2, 7 }, {  7, 2 }, { -7, 2 },
 
   92     {  3, 7 }, { -3, 7 }, {  7, 3 }, { -7, 3 }, {  5, 6 }, { -5, 6 }, {  6, 5 }, { -6, 5 },
 
   93     {  8, 0 }, {  4, 7 }, { -4, 7 }, {  7, 4 }, { -7, 4 }, {  8, 1 }, {  8, 2 }, {  6, 6 },
 
   94     { -6, 6 }, {  8, 3 }, {  5, 7 }, { -5, 7 }, {  7, 5 }, { -7, 5 }, {  8, 4 }, {  6, 7 },
 
   95     { -6, 7 }, {  7, 6 }, { -7, 6 }, {  8, 5 }, {  7, 7 }, { -7, 7 }, {  8, 6 }, {  8, 7 }
 
  218 #define GET_PIXEL(frame, x, y) \ 
  219     ((frame)->data[0] + (y) * frame->linesize[0] + 4 * (x)) 
  221 #define GET_PIXEL_COMP(frame, x, y, c) \ 
  222     (*((frame)->data[0] + (y) * frame->linesize[0] + 4 * (x) + c)) 
  231     if (
img->huffman_groups) {
 
  232         for (
i = 0; 
i < 
img->nb_huffman_groups; 
i++) {
 
  238     memset(
img, 0, 
sizeof(*
img));
 
  244         if (
r->nb_symbols == 1)
 
  245             return r->simple_symbols[0];
 
  256     int max_code_length = 0;
 
  260     for (sym = 0; sym < alphabet_size; sym++) {
 
  261         if (code_lengths[sym] > 0) {
 
  270         r->simple_symbols[0] = 
code;
 
  275     for (sym = 0; sym < alphabet_size; sym++)
 
  276         max_code_length = 
FFMAX(max_code_length, code_lengths[sym]);
 
  287     for (
len = 1; 
len <= max_code_length; 
len++) {
 
  288         for (sym = 0; sym < alphabet_size; sym++) {
 
  289             if (code_lengths[sym] != 
len)
 
  296     if (!
r->nb_symbols) {
 
  302                    code_lengths, 
sizeof(*code_lengths), 
sizeof(*code_lengths),
 
  332     HuffReader code_len_hc = { { 0 }, 0, 0, { 0 } };
 
  333     uint8_t *code_lengths;
 
  335     int i, symbol, max_symbol, prev_code_len, 
ret;
 
  340     for (
i = 0; 
i < num_codes; 
i++)
 
  357         if (max_symbol > alphabet_size) {
 
  359                    max_symbol, alphabet_size);
 
  364         max_symbol = alphabet_size;
 
  369     while (symbol < alphabet_size) {
 
  377             code_lengths[symbol++] = code_len;
 
  379                 prev_code_len = code_len;
 
  381             int repeat = 0, length = 0;
 
  388                 length = prev_code_len;
 
  401             if (symbol + repeat > alphabet_size) {
 
  403                        "invalid symbol %d + repeat %d > alphabet size %d\n",
 
  404                        symbol, repeat, alphabet_size);
 
  409                 code_lengths[symbol++] = length;
 
  424 #define PARSE_BLOCK_SIZE(w, h) do {                                         \ 
  425     block_bits = get_bits(&s->gb, 3) + 2;                                   \ 
  426     blocks_w   = FFALIGN((w), 1 << block_bits) >> block_bits;               \ 
  427     blocks_h   = FFALIGN((h), 1 << block_bits) >> block_bits;               \ 
  447     for (y = 0; y < 
img->frame->height; y++) {
 
  448         for (x = 0; x < 
img->frame->width; x++) {
 
  451             int p  = p0 << 8 | p1;
 
  455     s->nb_huffman_groups = 
max + 1;
 
  495     int width_bits, index_size, 
ret, x;
 
  502     else if (index_size <= 4)
 
  504     else if (index_size <= 16)
 
  515     img->size_reduction = width_bits;
 
  517         s->reduced_width = (
s->width + ((1 << width_bits) - 1)) >> width_bits;
 
  520     ct  = 
img->frame->data[0] + 4;
 
  521     for (x = 4; x < 
img->frame->width * 4; x++, ct++)
 
  538         group       = g0 << 8 | g1;
 
  546     uint32_t cache_idx = (0x1E35A7BD * 
c) >> (32 - 
img->color_cache_bits);
 
  547     img->color_cache[cache_idx] = 
c;
 
  557     img       = &
s->image[role];
 
  567     img->frame->width  = 
w;
 
  568     img->frame->height = 
h;
 
  580         if (
img->color_cache_bits < 1 || 
img->color_cache_bits > 11) {
 
  582                    img->color_cache_bits);
 
  586                                      sizeof(*
img->color_cache));
 
  587         if (!
img->color_cache)
 
  590         img->color_cache_bits = 0;
 
  593     img->nb_huffman_groups = 1;
 
  598         img->nb_huffman_groups = 
s->nb_huffman_groups;
 
  602                                     sizeof(*
img->huffman_groups));
 
  603     if (!
img->huffman_groups)
 
  606     for (
i = 0; 
i < 
img->nb_huffman_groups; 
i++) {
 
  610             if (!j && 
img->color_cache_bits > 0)
 
  611                 alphabet_size += 1 << 
img->color_cache_bits;
 
  628     while (y < img->
frame->height) {
 
  643             if (
img->color_cache_bits)
 
  652             int prefix_code, length, 
distance, ref_x, ref_y;
 
  656             if (prefix_code < 4) {
 
  657                 length = prefix_code + 1;
 
  664             if (prefix_code > 39
U) {
 
  666                        "distance prefix code too large: %d\n", prefix_code);
 
  669             if (prefix_code < 4) {
 
  702             ref_x = 
FFMAX(0, ref_x);
 
  703             ref_y = 
FFMAX(0, ref_y);
 
  708             for (
i = 0; 
i < length; 
i++) {
 
  713                 if (
img->color_cache_bits)
 
  721                 if (ref_x == 
width) {
 
  725                 if (y == 
img->frame->height || ref_y == 
img->frame->height)
 
  733             if (!
img->color_cache_bits) {
 
  737             if (cache_idx >= 1 << 
img->color_cache_bits) {
 
  739                        "color cache index out-of-bounds\n");
 
  755 static void inv_predict_0(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  756                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  762 static void inv_predict_1(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  763                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  769 static void inv_predict_2(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  770                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  776 static void inv_predict_3(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  777                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  783 static void inv_predict_4(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  784                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  790 static void inv_predict_5(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  791                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  793     p[0] = p_t[0] + (p_l[0] + p_tr[0] >> 1) >> 1;
 
  794     p[1] = p_t[1] + (p_l[1] + p_tr[1] >> 1) >> 1;
 
  795     p[2] = p_t[2] + (p_l[2] + p_tr[2] >> 1) >> 1;
 
  796     p[3] = p_t[3] + (p_l[3] + p_tr[3] >> 1) >> 1;
 
  800 static void inv_predict_6(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  801                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  803     p[0] = p_l[0] + p_tl[0] >> 1;
 
  804     p[1] = p_l[1] + p_tl[1] >> 1;
 
  805     p[2] = p_l[2] + p_tl[2] >> 1;
 
  806     p[3] = p_l[3] + p_tl[3] >> 1;
 
  810 static void inv_predict_7(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  811                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  813     p[0] = p_l[0] + p_t[0] >> 1;
 
  814     p[1] = p_l[1] + p_t[1] >> 1;
 
  815     p[2] = p_l[2] + p_t[2] >> 1;
 
  816     p[3] = p_l[3] + p_t[3] >> 1;
 
  820 static void inv_predict_8(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  821                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  823     p[0] = p_tl[0] + p_t[0] >> 1;
 
  824     p[1] = p_tl[1] + p_t[1] >> 1;
 
  825     p[2] = p_tl[2] + p_t[2] >> 1;
 
  826     p[3] = p_tl[3] + p_t[3] >> 1;
 
  830 static void inv_predict_9(uint8_t *p, 
const uint8_t *p_l, 
const uint8_t *p_tl,
 
  831                           const uint8_t *p_t, 
const uint8_t *p_tr)
 
  833     p[0] = p_t[0] + p_tr[0] >> 1;
 
  834     p[1] = p_t[1] + p_tr[1] >> 1;
 
  835     p[2] = p_t[2] + p_tr[2] >> 1;
 
  836     p[3] = p_t[3] + p_tr[3] >> 1;
 
  841                            const uint8_t *p_t, 
const uint8_t *p_tr)
 
  843     p[0] = (p_l[0] + p_tl[0] >> 1) + (p_t[0] + p_tr[0] >> 1) >> 1;
 
  844     p[1] = (p_l[1] + p_tl[1] >> 1) + (p_t[1] + p_tr[1] >> 1) >> 1;
 
  845     p[2] = (p_l[2] + p_tl[2] >> 1) + (p_t[2] + p_tr[2] >> 1) >> 1;
 
  846     p[3] = (p_l[3] + p_tl[3] >> 1) + (p_t[3] + p_tr[3] >> 1) >> 1;
 
  851                            const uint8_t *p_t, 
const uint8_t *p_tr)
 
  854                (
FFABS(p_l[1] - p_tl[1]) - 
FFABS(p_t[1] - p_tl[1])) +
 
  855                (
FFABS(p_l[2] - p_tl[2]) - 
FFABS(p_t[2] - p_tl[2])) +
 
  856                (
FFABS(p_l[3] - p_tl[3]) - 
FFABS(p_t[3] - p_tl[3]));
 
  865                            const uint8_t *p_t, 
const uint8_t *p_tr)
 
  881                            const uint8_t *p_t, 
const uint8_t *p_tr)
 
  890                                  const uint8_t *p_tl, 
const uint8_t *p_t,
 
  891                                  const uint8_t *p_tr);
 
  902     uint8_t *dec, *p_l, *p_tl, *p_t, *p_tr;
 
  909     if (x == 
frame->width - 1)
 
  928     for (y = 0; y < 
img->frame->height; y++) {
 
  929         for (x = 0; x < 
s->reduced_width; x++) {
 
  944                        "invalid predictor mode: %d\n", m);
 
  968     for (y = 0; y < 
img->frame->height; y++) {
 
  969         for (x = 0; x < 
s->reduced_width; x++) {
 
  988     for (y = 0; y < 
img->frame->height; y++) {
 
  989         for (x = 0; x < 
s->reduced_width; x++) {
 
 1017         for (y = 0; y < 
img->frame->height; y++) {
 
 1019             memcpy(
line, p, 
img->frame->linesize[0]);
 
 1023             for (x = 0; x < 
img->frame->width; x++) {
 
 1025                 p[2] = 
get_bits(&gb_g, pixel_bits);
 
 1034         s->reduced_width = 
s->width; 
 
 1038     if (
img->frame->height * 
img->frame->width > 300) {
 
 1039         uint8_t palette[256 * 4];
 
 1044         memset(palette + 
size, 0, 256 * 4 - 
size);
 
 1045         for (y = 0; y < 
img->frame->height; y++) {
 
 1046             for (x = 0; x < 
img->frame->width; x++) {
 
 1053         for (y = 0; y < 
img->frame->height; y++) {
 
 1054             for (x = 0; x < 
img->frame->width; x++) {
 
 1073     if (
s->width && 
s->width != 
w) {
 
 1078     if (
s->height && 
s->height != 
h) {
 
 1086                                      int *got_frame, uint8_t *data_start,
 
 1087                                      unsigned int data_size, 
int is_alpha_chunk)
 
 1092     if (!is_alpha_chunk) {
 
 1101     if (!is_alpha_chunk) {
 
 1123         if (!
s->width || !
s->height)
 
 1130     s->nb_transforms = 0;
 
 1131     s->reduced_width = 
s->width;
 
 1139             goto free_and_return;
 
 1155             goto free_and_return;
 
 1164         goto free_and_return;
 
 1167     for (
i = 
s->nb_transforms - 1; 
i >= 0; 
i--) {
 
 1168         switch (
s->transforms[
i]) {
 
 1183             goto free_and_return;
 
 1203     ls = 
frame->linesize[3];
 
 1206     dec = 
frame->data[3] + 1;
 
 1207     for (x = 1; x < 
frame->width; x++, dec++)
 
 1211     dec = 
frame->data[3] + ls;
 
 1212     for (y = 1; y < 
frame->height; y++, dec += ls)
 
 1213         *dec += *(dec - ls);
 
 1218         for (y = 1; y < 
frame->height; y++) {
 
 1219             dec = 
frame->data[3] + y * ls + 1;
 
 1220             for (x = 1; x < 
frame->width; x++, dec++)
 
 1225         for (y = 1; y < 
frame->height; y++) {
 
 1226             dec = 
frame->data[3] + y * ls + 1;
 
 1227             for (x = 1; x < 
frame->width; x++, dec++)
 
 1228                 *dec += *(dec - ls);
 
 1232         for (y = 1; y < 
frame->height; y++) {
 
 1233             dec = 
frame->data[3] + y * ls + 1;
 
 1234             for (x = 1; x < 
frame->width; x++, dec++)
 
 1235                 dec[0] += 
av_clip_uint8(*(dec - 1) + *(dec - ls) - *(dec - ls - 1));
 
 1242                                   uint8_t *data_start,
 
 1243                                   unsigned int data_size)
 
 1252         for (y = 0; y < 
s->height; y++)
 
 1257         int alpha_got_frame = 0;
 
 1260         if (!
s->alpha_frame)
 
 1264                                         data_start, data_size, 1);
 
 1269         if (!alpha_got_frame) {
 
 1275         for (y = 0; y < 
s->height; y++) {
 
 1278             for (x = 0; x < 
s->width; x++) {
 
 1288     if (
s->alpha_filter)
 
 1295                                   int *got_frame, uint8_t *data_start,
 
 1296                                   unsigned int data_size)
 
 1301     if (!
s->initialized) {
 
 1304         s->v.actually_webp = 1;
 
 1309     if (data_size > INT_MAX) {
 
 1315     s->pkt->data = data_start;
 
 1316     s->pkt->size = data_size;
 
 1329                                      s->alpha_data_size);
 
 1343     uint32_t chunk_type, chunk_size;
 
 1358     if (bytestream2_get_le32(&gb) != 
MKTAG(
'R', 
'I', 
'F', 
'F')) {
 
 1363     chunk_size = bytestream2_get_le32(&gb);
 
 1367     if (bytestream2_get_le32(&gb) != 
MKTAG(
'W', 
'E', 
'B', 
'P')) {
 
 1373         char chunk_str[5] = { 0 };
 
 1375         chunk_type = bytestream2_get_le32(&gb);
 
 1376         chunk_size = bytestream2_get_le32(&gb);
 
 1377         if (chunk_size == UINT32_MAX)
 
 1379         chunk_size += chunk_size & 1;
 
 1387         switch (chunk_type) {
 
 1388         case MKTAG(
'V', 
'P', 
'8', 
' '):
 
 1398         case MKTAG(
'V', 
'P', 
'8', 
'L'):
 
 1409         case MKTAG(
'V', 
'P', 
'8', 
'X'):
 
 1410             if (
s->width || 
s->height || *got_frame) {
 
 1414             vp8x_flags = bytestream2_get_byte(&gb);
 
 1416             s->width  = bytestream2_get_le24(&gb) + 1;
 
 1417             s->height = bytestream2_get_le24(&gb) + 1;
 
 1422         case MKTAG(
'A', 
'L', 
'P', 
'H'): {
 
 1423             int alpha_header, filter_m, compression;
 
 1427                        "ALPHA chunk present, but alpha bit not set in the " 
 1430             if (chunk_size == 0) {
 
 1434             alpha_header       = bytestream2_get_byte(&gb);
 
 1436             s->alpha_data_size = chunk_size - 1;
 
 1439             filter_m    = (alpha_header >> 2) & 0x03;
 
 1440             compression =  alpha_header       & 0x03;
 
 1444                        "skipping unsupported ALPHA chunk\n");
 
 1447                 s->alpha_compression = compression;
 
 1448                 s->alpha_filter      = filter_m;
 
 1453         case MKTAG(
'E', 
'X', 
'I', 
'F'): {
 
 1464                        "EXIF chunk present, but Exif bit not set in the " 
 1469                              avpkt->
size - exif_offset);
 
 1489         case MKTAG(
'I', 
'C', 
'C', 
'P'): {
 
 1499                        "ICCP chunk present, but ICC Profile bit not set in the " 
 1510         case MKTAG(
'A', 
'N', 
'I', 
'M'):
 
 1511         case MKTAG(
'A', 
'N', 
'M', 
'F'):
 
 1512         case MKTAG(
'X', 
'M', 
'P', 
' '):
 
 1513             AV_WL32(chunk_str, chunk_type);
 
 1519             AV_WL32(chunk_str, chunk_type);
 
  
void av_packet_unref(AVPacket *pkt)
Wipe the packet.
av_cold int ff_vp8_decode_free(AVCodecContext *avctx)
#define AV_LOG_WARNING
Something somehow does not look correct.
#define FF_CODEC_CAP_INIT_THREADSAFE
The codec does not modify any global variables in the init function, allowing to call the init functi...
static void inv_predict_12(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
static int get_bits_left(GetBitContext *gb)
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
#define NUM_SHORT_DISTANCES
static int vp8_lossy_decode_alpha(AVCodecContext *avctx, AVFrame *p, uint8_t *data_start, unsigned int data_size)
static int vp8_lossy_decode_frame(AVCodecContext *avctx, AVFrame *p, int *got_frame, uint8_t *data_start, unsigned int data_size)
int av_frame_get_buffer(AVFrame *frame, int align)
Allocate new buffer(s) for audio or video data.
static int vp8_lossless_decode_frame(AVCodecContext *avctx, AVFrame *p, int *got_frame, uint8_t *data_start, unsigned int data_size, int is_alpha_chunk)
#define INIT_VLC_OUTPUT_LE
@ PRED_MODE_AVG_T_AVG_L_TR
@ ALPHA_FILTER_HORIZONTAL
uint16_t simple_symbols[2]
AVFrameSideData * av_frame_new_side_data(AVFrame *frame, enum AVFrameSideDataType type, size_t size)
Add a new side data to a frame.
static int8_t ff_u8_to_s8(uint8_t a)
static const uint8_t block_bits[]
static void inv_predict_4(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
static void inv_predict_2(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
static av_always_inline int bytestream2_seek(GetByteContext *g, int offset, int whence)
This structure describes decoded (raw) audio or video data.
#define GET_PIXEL_COMP(frame, x, y, c)
@ PRED_MODE_ADD_SUBTRACT_FULL
@ COLOR_INDEXING_TRANSFORM
#define init_vlc(vlc, nb_bits, nb_codes, bits, bits_wrap, bits_size, codes, codes_wrap, codes_size, flags)
static int parse_transform_color(WebPContext *s)
static av_always_inline int get_vlc2(GetBitContext *s, VLC_TYPE(*table)[2], int bits, int max_depth)
Parse a vlc code.
#define AV_LOG_VERBOSE
Detailed information.
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
static int huff_reader_build_canonical(HuffReader *r, const uint8_t *code_lengths, int alphabet_size)
enum TransformType transforms[4]
void av_packet_free(AVPacket **pkt)
Free the packet, if the packet is reference counted, it will be unreferenced first.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static void skip_bits(GetBitContext *s, int n)
enum AlphaCompression alpha_compression
static void inv_predict_10(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
static int webp_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
static av_always_inline void bytestream2_skip(GetByteContext *g, unsigned int size)
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
static void inv_predict_8(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
the pkt_dts and pkt_pts fields in AVFrame will work as usual Restrictions on codec whose streams don t reset across will not work because their bitstreams cannot be decoded in parallel *The contents of buffers must not be read before as well as code calling up to before the decode process starts Call have so the codec calls ff_thread_report set FF_CODEC_CAP_ALLOCATE_PROGRESS in AVCodec caps_internal and use ff_thread_get_buffer() to allocate frames. The frames must then be freed with ff_thread_release_buffer(). Otherwise decode directly into the user-supplied frames. Call ff_thread_report_progress() after some part of the current picture has decoded. A good place to put this is where draw_horiz_band() is called - add this if it isn 't called anywhere
static void update_canvas_size(AVCodecContext *avctx, int w, int h)
int key_frame
1 -> keyframe, 0-> not
void(* inv_predict_func)(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
#define VP8X_FLAG_EXIF_METADATA
static void inv_predict_3(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
static av_always_inline uint8_t color_transform_delta(uint8_t color_pred, uint8_t color)
static int decode_entropy_coded_image(WebPContext *s, enum ImageRole role, int w, int h)
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
static int read_huffman_code_normal(WebPContext *s, HuffReader *hc, int alphabet_size)
int ff_exif_decode_ifd(void *logctx, GetByteContext *gbytes, int le, int depth, AVDictionary **metadata)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static int init_get_bits8(GetBitContext *s, const uint8_t *buffer, int byte_size)
Initialize GetBitContext.
#define FF_CODEC_PROPERTY_LOSSLESS
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, FILE *outfile)
static void inverse_prediction(AVFrame *frame, enum PredictionMode m, int x, int y)
@ AV_PIX_FMT_YUVA420P
planar YUV 4:2:0, 20bpp, (1 Cr & Cb sample per 2x2 Y & A samples)
#define HUFFMAN_CODES_PER_META_CODE
static const uint8_t code_length_code_order[NUM_CODE_LENGTH_CODES]
static av_always_inline void color_cache_put(ImageContext *img, uint32_t c)
#define NUM_DISTANCE_CODES
#define av_assert0(cond)
assert() equivalent, that is always enabled.
static void inv_predict_11(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
#define NUM_CODE_LENGTH_CODES
#define xi(width, name, var, range_min, range_max, subs,...)
void ff_free_vlc(VLC *vlc)
@ AV_PIX_FMT_YUV420P
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
#define GET_PIXEL(frame, x, y)
static av_cold int webp_decode_close(AVCodecContext *avctx)
HuffReader * huffman_groups
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
static int apply_subtract_green_transform(WebPContext *s)
#define AV_CODEC_CAP_FRAME_THREADS
Codec supports frame-level multithreading.
static av_always_inline uint8_t clamp_add_subtract_half(int a, int b, int c)
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
static const inv_predict_func inverse_predict[14]
static const int8_t transform[32][32]
@ AV_PICTURE_TYPE_I
Intra.
static unsigned int get_bits1(GetBitContext *s)
static int parse_transform_color_indexing(WebPContext *s)
@ AV_FRAME_DATA_ICC_PROFILE
The data contains an ICC profile as an opaque octet buffer following the format described by ISO 1507...
static av_cold int webp_decode_init(AVCodecContext *avctx)
static av_always_inline unsigned int bytestream2_get_buffer(GetByteContext *g, uint8_t *dst, unsigned int size)
static const uint16_t alphabet_sizes[HUFFMAN_CODES_PER_META_CODE]
#define NUM_LITERAL_CODES
int ff_vp8_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
av_cold int ff_vp8_decode_init(AVCodecContext *avctx)
static void alpha_inverse_prediction(AVFrame *frame, enum AlphaFilter m)
static av_always_inline int bytestream2_get_bytes_left(GetByteContext *g)
static av_always_inline int bytestream2_tell(GetByteContext *g)
@ IMAGE_ROLE_COLOR_INDEXING
enum AVPictureType pict_type
Picture type of the frame.
static void inv_predict_0(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() or get_encode_buffer() for allocating buffers and supports custom allocators.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_RB32
static int decode_entropy_image(WebPContext *s)
static int apply_color_transform(WebPContext *s)
The reader does not expect b to be semantically here and if the code is changed by maybe adding a a division or other the signedness will almost certainly be mistaken To avoid this confusion a new type was SUINT is the C unsigned type but it holds a signed int to use the same example SUINT a
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf offset
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.
static int parse_transform_predictor(WebPContext *s)
@ PRED_MODE_AVG_AVG_L_TL_AVG_T_TR
@ AV_PIX_FMT_ARGB
packed ARGB 8:8:8:8, 32bpp, ARGBARGB...
static void inv_predict_5(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
#define i(width, name, range_min, range_max)
and forward the test the status of outputs and forward it to the corresponding return FFERROR_NOT_READY If the filters stores internally one or a few frame for some it can consider them to be part of the FIFO and delay acknowledging a status change accordingly Example code
unsigned properties
Properties of the stream that gets decoded.
#define av_malloc_array(a, b)
static const int8_t lz77_distance_offsets[NUM_SHORT_DISTANCES][2]
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
static int apply_predictor_transform(WebPContext *s)
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
const char * name
Name of the codec implementation.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
static void inv_predict_7(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
void * av_calloc(size_t nmemb, size_t size)
static int huff_reader_get_symbol(HuffReader *r, GetBitContext *gb)
static void inv_predict_13(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
ImageContext image[IMAGE_ROLE_NB]
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
static void inv_predict_6(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
#define AV_INPUT_BUFFER_PADDING_SIZE
main external API structure.
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 void image_ctx_free(ImageContext *img)
static int apply_color_indexing_transform(WebPContext *s)
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.
Structure to hold side data for an AVFrame.
#define MAX_HUFFMAN_CODE_LENGTH
#define PARSE_BLOCK_SIZE(w, h)
static av_always_inline int diff(const uint32_t a, const uint32_t b)
This structure stores compressed data.
int av_dict_copy(AVDictionary **dst, const AVDictionary *src, int flags)
Copy entries from one AVDictionary struct into another.
int width
picture width / height.
static float distance(float x, float y, int band)
static av_always_inline void bytestream2_init(GetByteContext *g, const uint8_t *buf, int buf_size)
#define AVERROR_BUG
Internal bug, also see AVERROR_BUG2.
int linesize[AV_NUM_DATA_POINTERS]
For video, a positive or negative value, which is typically indicating the size in bytes of each pict...
static void read_huffman_code_simple(WebPContext *s, HuffReader *hc)
const AVCodec ff_webp_decoder
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
#define MKTAG(a, b, c, d)
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...
static HuffReader * get_huffman_group(WebPContext *s, ImageContext *img, int x, int y)
static void inv_predict_9(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
static void inv_predict_1(uint8_t *p, const uint8_t *p_l, const uint8_t *p_tl, const uint8_t *p_t, const uint8_t *p_tr)
The official guide to swscale for confused that consecutive non overlapping rectangles of slice_bottom special converter These generally are unscaled converters of common like for each output line the vertical scaler pulls lines from a ring buffer When the ring buffer does not contain the wanted line
enum AlphaFilter alpha_filter
@ PRED_MODE_ADD_SUBTRACT_HALF
@ IMAGE_ROLE_COLOR_TRANSFORM