FFmpeg
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Macros | Functions | Variables
h264.c File Reference

H.264 / AVC / MPEG4 part10 codec. More...

#include "libavutil/avassert.h"
#include "libavutil/display.h"
#include "libavutil/imgutils.h"
#include "libavutil/opt.h"
#include "libavutil/stereo3d.h"
#include "libavutil/timer.h"
#include "internal.h"
#include "cabac.h"
#include "cabac_functions.h"
#include "error_resilience.h"
#include "avcodec.h"
#include "h264.h"
#include "h264data.h"
#include "h264chroma.h"
#include "h264_mvpred.h"
#include "golomb.h"
#include "mathops.h"
#include "me_cmp.h"
#include "mpegutils.h"
#include "rectangle.h"
#include "svq3.h"
#include "thread.h"
#include "vdpau_compat.h"

Go to the source code of this file.

Macros

#define UNCHECKED_BITSTREAM_READER   1
 
#define STARTCODE_TEST
 
#define OFFSET(x)   offsetof(H264Context, x)
 
#define VD   AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_DECODING_PARAM
 

Functions

int avpriv_h264_has_num_reorder_frames (AVCodecContext *avctx)
 
static void h264_er_decode_mb (void *opaque, int ref, int mv_dir, int mv_type, int(*mv)[2][4][2], int mb_x, int mb_y, int mb_intra, int mb_skipped)
 
void ff_h264_draw_horiz_band (const H264Context *h, H264SliceContext *sl, int y, int height)
 
int ff_h264_check_intra4x4_pred_mode (const H264Context *h, H264SliceContext *sl)
 Check if the top & left blocks are available if needed and change the dc mode so it only uses the available blocks. More...
 
int ff_h264_check_intra_pred_mode (const H264Context *h, H264SliceContext *sl, int mode, int is_chroma)
 Check if the top & left blocks are available if needed and change the dc mode so it only uses the available blocks. More...
 
const uint8_tff_h264_decode_nal (H264Context *h, H264SliceContext *sl, const uint8_t *src, int *dst_length, int *consumed, int length)
 Decode a network abstraction layer unit. More...
 
static int decode_rbsp_trailing (H264Context *h, const uint8_t *src)
 Identify the exact end of the bitstream. More...
 
void ff_h264_free_tables (H264Context *h)
 
int ff_h264_alloc_tables (H264Context *h)
 Allocate tables. More...
 
int ff_h264_slice_context_init (H264Context *h, H264SliceContext *sl)
 Init context Allocate buffers which are not shared amongst multiple threads. More...
 
static int decode_nal_units (H264Context *h, const uint8_t *buf, int buf_size, int parse_extradata)
 
int ff_h264_decode_extradata (H264Context *h, const uint8_t *buf, int size)
 
static int h264_init_context (AVCodecContext *avctx, H264Context *h)
 
av_cold int ff_h264_decode_init (AVCodecContext *avctx)
 
static int decode_init_thread_copy (AVCodecContext *avctx)
 
static void decode_postinit (H264Context *h, int setup_finished)
 Run setup operations that must be run after slice header decoding. More...
 
int ff_pred_weight_table (H264Context *h, H264SliceContext *sl)
 
static void idr (H264Context *h)
 instantaneous decoder refresh. More...
 
void ff_h264_flush_change (H264Context *h)
 
static void flush_dpb (AVCodecContext *avctx)
 
int ff_init_poc (H264Context *h, int pic_field_poc[2], int *pic_poc)
 
int ff_h264_get_profile (SPS *sps)
 Compute profile from profile_idc and constraint_set?_flags. More...
 
int ff_set_ref_count (H264Context *h, H264SliceContext *sl)
 
static int get_bit_length (H264Context *h, const uint8_t *buf, const uint8_t *ptr, int dst_length, int i, int next_avc)
 
static int get_last_needed_nal (H264Context *h, const uint8_t *buf, int buf_size)
 
static int get_consumed_bytes (int pos, int buf_size)
 Return the number of bytes consumed for building the current frame. More...
 
static int output_frame (H264Context *h, AVFrame *dst, H264Picture *srcp)
 
static int is_extra (const uint8_t *buf, int buf_size)
 
static int h264_decode_frame (AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
 
av_cold void ff_h264_free_context (H264Context *h)
 Free any data that may have been allocated in the H264 context like SPS, PPS etc. More...
 
static av_cold int h264_decode_end (AVCodecContext *avctx)
 

Variables

const uint16_t ff_h264_mb_sizes [4] = { 256, 384, 512, 768 }
 
static const uint8_t start_code [] = { 0x00, 0x00, 0x01 }
 
static const AVOption h264_options []
 
static const AVClass h264_class
 
static const AVProfile profiles []
 
AVCodec ff_h264_decoder
 

Detailed Description

H.264 / AVC / MPEG4 part10 codec.

Author
Michael Niedermayer micha.nosp@m.elni.nosp@m.@gmx..nosp@m.at

Definition in file h264.c.

Macro Definition Documentation

#define UNCHECKED_BITSTREAM_READER   1

Definition at line 28 of file h264.c.

#define STARTCODE_TEST
Value:
if (i + 2 < length && src[i + 1] == 0 && src[i + 2] <= 3) { \
if (src[i + 2] != 3 && src[i + 2] != 0) { \
/* startcode, so we must be past the end */ \
length = i; \
} \
break; \
}
if()
Definition: avfilter.c:975
GLsizei GLsizei * length
Definition: opengl_enc.c:115
AVS_Value src
Definition: avisynth_c.h:482

Referenced by ff_h264_decode_nal().

#define OFFSET (   x)    offsetof(H264Context, x)

Definition at line 1892 of file h264.c.

Definition at line 1893 of file h264.c.

Function Documentation

int avpriv_h264_has_num_reorder_frames ( AVCodecContext avctx)

Definition at line 56 of file h264.c.

Referenced by has_decode_delay_been_guessed().

static void h264_er_decode_mb ( void opaque,
int  ref,
int  mv_dir,
int  mv_type,
int(*)  mv[2][4][2],
int  mb_x,
int  mb_y,
int  mb_intra,
int  mb_skipped 
)
static

Definition at line 62 of file h264.c.

Referenced by ff_h264_slice_context_init().

void ff_h264_draw_horiz_band ( const H264Context h,
H264SliceContext sl,
int  y,
int  height 
)
int ff_h264_check_intra4x4_pred_mode ( const H264Context h,
H264SliceContext sl 
)

Check if the top & left blocks are available if needed and change the dc mode so it only uses the available blocks.

Check if the top & left blocks are available if needed & change the dc mode so it only uses the available blocks.

Definition at line 137 of file h264.c.

Referenced by ff_h264_decode_mb_cabac(), ff_h264_decode_mb_cavlc(), and svq3_decode_mb().

int ff_h264_check_intra_pred_mode ( const H264Context h,
H264SliceContext sl,
int  mode,
int  is_chroma 
)

Check if the top & left blocks are available if needed and change the dc mode so it only uses the available blocks.

Check if the top & left blocks are available if needed & change the dc mode so it only uses the available blocks.

Definition at line 184 of file h264.c.

Referenced by ff_h264_decode_mb_cabac(), ff_h264_decode_mb_cavlc(), and svq3_decode_mb().

const uint8_t* ff_h264_decode_nal ( H264Context h,
H264SliceContext sl,
const uint8_t src,
int *  dst_length,
int *  consumed,
int  length 
)

Decode a network abstraction layer unit.

Parameters
consumedis the number of bytes used as input
lengthis the length of the array
dst_lengthis the number of decoded bytes FIXME here or a decode rbsp tailing?
Returns
decoded bytes, might be src+1 if no escapes

Definition at line 226 of file h264.c.

Referenced by decode_nal_units(), get_last_needed_nal(), and parse_nal_units().

static int decode_rbsp_trailing ( H264Context h,
const uint8_t src 
)
static

Identify the exact end of the bitstream.

Returns
the length of the trailing, or 0 if damaged

Definition at line 340 of file h264.c.

Referenced by get_bit_length().

void ff_h264_free_tables ( H264Context h)
int ff_h264_alloc_tables ( H264Context h)

Allocate tables.

needs width/height

Definition at line 398 of file h264.c.

Referenced by h264_slice_header_init(), and svq3_decode_init().

int ff_h264_slice_context_init ( H264Context h,
H264SliceContext sl 
)

Init context Allocate buffers which are not shared amongst multiple threads.

Definition at line 459 of file h264.c.

Referenced by h264_slice_header_init().

static int decode_nal_units ( H264Context h,
const uint8_t buf,
int  buf_size,
int  parse_extradata 
)
static

< number of NALs that need decoding before the next frame thread starts

Definition at line 1349 of file h264.c.

Referenced by ff_h264_decode_extradata(), and h264_decode_frame().

int ff_h264_decode_extradata ( H264Context h,
const uint8_t buf,
int  size 
)

Definition at line 527 of file h264.c.

Referenced by ff_h264_decode_init(), h264_decode_frame(), and h264_parse().

static int h264_init_context ( AVCodecContext avctx,
H264Context h 
)
static

Definition at line 589 of file h264.c.

Referenced by decode_init_thread_copy(), and ff_h264_decode_init().

av_cold int ff_h264_decode_init ( AVCodecContext avctx)

Definition at line 644 of file h264.c.

Referenced by svq3_decode_init().

static int decode_init_thread_copy ( AVCodecContext avctx)
static

Definition at line 701 of file h264.c.

static void decode_postinit ( H264Context h,
int  setup_finished 
)
static

Run setup operations that must be run after slice header decoding.

This includes finding the next displayed frame.

Parameters
hh264 master context
setup_finishedenough NALs have been read that we can call ff_thread_finish_setup()

Definition at line 728 of file h264.c.

Referenced by decode_nal_units(), and h264_decode_frame().

int ff_pred_weight_table ( H264Context h,
H264SliceContext sl 
)

Definition at line 968 of file h264.c.

Referenced by ff_h264_decode_slice_header(), and scan_mmco_reset().

static void idr ( H264Context h)
static

instantaneous decoder refresh.

Definition at line 1043 of file h264.c.

Referenced by decode_nal_units(), ff_h264_flush_change(), and h264_probe().

void ff_h264_flush_change ( H264Context h)

Definition at line 1056 of file h264.c.

Referenced by ff_h264_decode_init(), ff_h264_decode_slice_header(), and flush_dpb().

static void flush_dpb ( AVCodecContext avctx)
static

Definition at line 1085 of file h264.c.

int ff_init_poc ( H264Context h,
int  pic_field_poc[2],
int *  pic_poc 
)

Definition at line 1105 of file h264.c.

Referenced by ff_h264_decode_slice_header(), and parse_nal_units().

int ff_h264_get_profile ( SPS sps)

Compute profile from profile_idc and constraint_set?_flags.

compute profile from sps

Parameters
spsSPS
Returns
profile as defined by FF_PROFILE_H264_*

Definition at line 1190 of file h264.c.

Referenced by ff_h264_decode_slice_header(), and parse_nal_units().

int ff_set_ref_count ( H264Context h,
H264SliceContext sl 
)

Definition at line 1210 of file h264.c.

Referenced by ff_h264_decode_slice_header(), and scan_mmco_reset().

static int get_bit_length ( H264Context h,
const uint8_t buf,
const uint8_t ptr,
int  dst_length,
int  i,
int  next_avc 
)
static

Definition at line 1266 of file h264.c.

Referenced by decode_nal_units(), and get_last_needed_nal().

static int get_last_needed_nal ( H264Context h,
const uint8_t buf,
int  buf_size 
)
static

Definition at line 1285 of file h264.c.

Referenced by decode_nal_units().

static int get_consumed_bytes ( int  pos,
int  buf_size 
)
static

Return the number of bytes consumed for building the current frame.

Definition at line 1657 of file h264.c.

Referenced by h264_decode_frame().

static int output_frame ( H264Context h,
AVFrame dst,
H264Picture srcp 
)
static
Examples:
transcode_aac.c.

Definition at line 1667 of file h264.c.

Referenced by h264_decode_frame(), and load_encode_and_write().

static int is_extra ( const uint8_t buf,
int  buf_size 
)
static

Definition at line 1693 of file h264.c.

Referenced by h264_decode_frame().

static int h264_decode_frame ( AVCodecContext avctx,
void data,
int *  got_frame,
AVPacket avpkt 
)
static

Definition at line 1715 of file h264.c.

av_cold void ff_h264_free_context ( H264Context h)

Free any data that may have been allocated in the H264 context like SPS, PPS etc.

Definition at line 1851 of file h264.c.

Referenced by ff_h264_decode_init(), h264_close(), h264_decode_end(), and svq3_decode_end().

static av_cold int h264_decode_end ( AVCodecContext avctx)
static

Definition at line 1877 of file h264.c.

Variable Documentation

const uint16_t ff_h264_mb_sizes[4] = { 256, 384, 512, 768 }

Definition at line 54 of file h264.c.

Referenced by ff_h264_decode_mb_cabac(), ff_h264_decode_mb_cavlc(), and hl_decode_mb().

const uint8_t start_code[] = { 0x00, 0x00, 0x01 }
static
const AVOption h264_options[]
static
Initial value:
= {
{"is_avc", "is avc", 0x42, FF_OPT_TYPE_INT, {.i64 = 0}, 0, 1, 0},
{"nal_length_size", "nal_length_size", 0x42, FF_OPT_TYPE_INT, {.i64 = 0}, 0, 4, 0},
{ "enable_er", "Enable error resilience on damaged frames (unsafe)", OFFSET(enable_er), AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 1, VD },
{ NULL },
}
#define NULL
Definition: coverity.c:32
#define OFFSET(x)
Definition: h264.c:1892
#define VD
Definition: h264.c:1893

Definition at line 1894 of file h264.c.

const AVClass h264_class
static
Initial value:
= {
.class_name = "H264 Decoder",
.item_name = av_default_item_name,
.option = h264_options,
}
#define LIBAVUTIL_VERSION_INT
Definition: version.h:62
av_default_item_name
static const AVOption h264_options[]
Definition: h264.c:1894

Definition at line 1901 of file h264.c.

const AVProfile profiles[]
static
Initial value:
= {
{ FF_PROFILE_H264_BASELINE, "Baseline" },
{ FF_PROFILE_H264_CONSTRAINED_BASELINE, "Constrained Baseline" },
{ FF_PROFILE_H264_MAIN, "Main" },
{ FF_PROFILE_H264_EXTENDED, "Extended" },
{ FF_PROFILE_H264_HIGH, "High" },
{ FF_PROFILE_H264_HIGH_10, "High 10" },
{ FF_PROFILE_H264_HIGH_10_INTRA, "High 10 Intra" },
{ FF_PROFILE_H264_HIGH_422, "High 4:2:2" },
{ FF_PROFILE_H264_HIGH_422_INTRA, "High 4:2:2 Intra" },
{ FF_PROFILE_H264_HIGH_444, "High 4:4:4" },
{ FF_PROFILE_H264_HIGH_444_PREDICTIVE, "High 4:4:4 Predictive" },
{ FF_PROFILE_H264_HIGH_444_INTRA, "High 4:4:4 Intra" },
{ FF_PROFILE_H264_CAVLC_444, "CAVLC 4:4:4" },
}
#define FF_PROFILE_H264_HIGH_10
Definition: avcodec.h:2872
#define FF_PROFILE_H264_HIGH_444
Definition: avcodec.h:2876
#define FF_PROFILE_H264_MAIN
Definition: avcodec.h:2869
#define FF_PROFILE_H264_EXTENDED
Definition: avcodec.h:2870
#define FF_PROFILE_UNKNOWN
Definition: avcodec.h:2836
#define FF_PROFILE_H264_HIGH_444_INTRA
Definition: avcodec.h:2878
#define FF_PROFILE_H264_HIGH_422_INTRA
Definition: avcodec.h:2875
#define FF_PROFILE_H264_HIGH_10_INTRA
Definition: avcodec.h:2873
#define FF_PROFILE_H264_HIGH_444_PREDICTIVE
Definition: avcodec.h:2877
#define FF_PROFILE_H264_CAVLC_444
Definition: avcodec.h:2879
#define FF_PROFILE_H264_HIGH
Definition: avcodec.h:2871
#define FF_PROFILE_H264_CONSTRAINED_BASELINE
Definition: avcodec.h:2868
#define FF_PROFILE_H264_BASELINE
Definition: avcodec.h:2867
#define FF_PROFILE_H264_HIGH_422
Definition: avcodec.h:2874

Definition at line 1908 of file h264.c.

AVCodec ff_h264_decoder
Initial value:
= {
.name = "h264",
.long_name = NULL_IF_CONFIG_SMALL("H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10"),
.priv_data_size = sizeof(H264Context),
.close = h264_decode_end,
.capabilities = CODEC_CAP_DR1 |
.priv_class = &h264_class,
}
static const AVClass h264_class
Definition: h264.c:1901
static av_cold int init(AVCodecContext *avctx)
Definition: avrndec.c:35
av_cold int ff_h264_decode_init(AVCodecContext *avctx)
Definition: h264.c:644
H264Context.
Definition: h264.h:499
static int decode_init_thread_copy(AVCodecContext *avctx)
Definition: h264.c:701
#define CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
Definition: avcodec.h:789
#define CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
Definition: avcodec.h:824
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
Definition: internal.h:175
static void flush_dpb(AVCodecContext *avctx)
Definition: h264.c:1085
#define ONLY_IF_THREADS_ENABLED(x)
Define a function with only the non-default version specified.
Definition: internal.h:214
static int h264_decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
Definition: h264.c:1715
static void flush(AVCodecContext *avctx)
Definition: aacdec.c:514
int ff_h264_update_thread_context(AVCodecContext *dst, const AVCodecContext *src)
Definition: h264_slice.c:434
static av_cold int h264_decode_end(AVCodecContext *avctx)
Definition: h264.c:1877
static int decode(AVCodecContext *avctx, void *data, int *got_sub, AVPacket *avpkt)
Definition: ccaption_dec.c:522
#define CODEC_CAP_SLICE_THREADS
Codec supports slice-based (or partition-based) multithreading.
Definition: avcodec.h:870
#define CODEC_CAP_FRAME_THREADS
Codec supports frame-level multithreading.
Definition: avcodec.h:866
static int init_thread_copy(AVCodecContext *avctx)
Definition: alac.c:640
static const AVProfile profiles[]
Definition: h264.c:1908

Definition at line 1925 of file h264.c.