FFmpeg
nvdec_hevc.c
Go to the documentation of this file.
1 /*
2  * HEVC HW decode acceleration through NVDEC
3  *
4  * Copyright (c) 2017 Anton Khirnov
5  *
6  * This file is part of FFmpeg.
7  *
8  * FFmpeg is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * FFmpeg is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with FFmpeg; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  */
22 
23 #include <stdint.h>
24 #include <string.h>
25 
26 #include "libavutil/mem.h"
27 #include "avcodec.h"
28 #include "nvdec.h"
29 #include "decode.h"
30 #include "internal.h"
31 #include "hevc/hevcdec.h"
32 #include "hevc/data.h"
33 #include "hwaccel_internal.h"
34 
35 static void dpb_add(CUVIDHEVCPICPARAMS *pp, int idx, const HEVCFrame *src)
36 {
37  FrameDecodeData *fdd = src->f->private_ref;
38  const NVDECFrame *cf = fdd->hwaccel_priv;
39 
40  pp->RefPicIdx[idx] = cf ? cf->idx : -1;
41  pp->PicOrderCntVal[idx] = src->poc;
42  pp->IsLongTerm[idx] = !!(src->flags & HEVC_FRAME_FLAG_LONG_REF);
43 }
44 
45 static void fill_scaling_lists(CUVIDHEVCPICPARAMS *ppc, const HEVCContext *s)
46 {
47  const ScalingList *sl = s->pps->scaling_list_data_present_flag ?
48  &s->pps->scaling_list : &s->pps->sps->scaling_list;
49  int i, j, pos;
50 
51  for (i = 0; i < 6; i++) {
52  for (j = 0; j < 16; j++) {
54  ppc->ScalingList4x4[i][j] = sl->sl[0][i][pos];
55  }
56 
57  for (j = 0; j < 64; j++) {
59  ppc->ScalingList8x8[i][j] = sl->sl[1][i][pos];
60  ppc->ScalingList16x16[i][j] = sl->sl[2][i][pos];
61 
62  if (i < 2)
63  ppc->ScalingList32x32[i][j] = sl->sl[3][i * 3][pos];
64  }
65 
66  ppc->ScalingListDCCoeff16x16[i] = sl->sl_dc[0][i];
67  if (i < 2)
68  ppc->ScalingListDCCoeff32x32[i] = sl->sl_dc[1][i * 3];
69  }
70 }
71 
73  const AVBufferRef *buffer_ref,
74  const uint8_t *buffer, uint32_t size)
75 {
76  const HEVCContext *s = avctx->priv_data;
77  const HEVCLayerContext *l = &s->layers[s->cur_layer];
78  const HEVCPPS *pps = s->pps;
79  const HEVCSPS *sps = pps->sps;
80 
82  CUVIDPICPARAMS *pp = &ctx->pic_params;
83  CUVIDHEVCPICPARAMS *ppc = &pp->CodecSpecific.hevc;
84  FrameDecodeData *fdd;
85  NVDECFrame *cf;
86 
87  int i, j, dpb_size, ret;
88 
89  ret = ff_nvdec_start_frame(avctx, s->cur_frame->f);
90  if (ret < 0)
91  return ret;
92 
93  fdd = s->cur_frame->f->private_ref;
94  cf = (NVDECFrame*)fdd->hwaccel_priv;
95 
96  *pp = (CUVIDPICPARAMS) {
97  .PicWidthInMbs = sps->width / 16,
98  .FrameHeightInMbs = sps->height / 16,
99  .CurrPicIdx = cf->idx,
100  .ref_pic_flag = 1,
101  .intra_pic_flag = IS_IRAP(s),
102 
103  .CodecSpecific.hevc = {
104  .pic_width_in_luma_samples = sps->width,
105  .pic_height_in_luma_samples = sps->height,
106  .log2_min_luma_coding_block_size_minus3 = sps->log2_min_cb_size - 3,
107  .log2_diff_max_min_luma_coding_block_size = sps->log2_diff_max_min_coding_block_size,
108  .log2_min_transform_block_size_minus2 = sps->log2_min_tb_size - 2,
109  .log2_diff_max_min_transform_block_size = sps->log2_max_trafo_size - sps->log2_min_tb_size,
110  .pcm_enabled_flag = sps->pcm_enabled,
111  .log2_min_pcm_luma_coding_block_size_minus3 = sps->pcm_enabled ? sps->pcm.log2_min_pcm_cb_size - 3 : 0,
112  .log2_diff_max_min_pcm_luma_coding_block_size = sps->pcm.log2_max_pcm_cb_size - sps->pcm.log2_min_pcm_cb_size,
113  .pcm_sample_bit_depth_luma_minus1 = sps->pcm_enabled ? sps->pcm.bit_depth - 1 : 0,
114  .pcm_sample_bit_depth_chroma_minus1 = sps->pcm_enabled ? sps->pcm.bit_depth_chroma - 1 : 0,
115 #if NVDECAPI_CHECK_VERSION(8, 1)
116  .log2_max_transform_skip_block_size_minus2 = pps->log2_max_transform_skip_block_size - 2,
117  .log2_sao_offset_scale_luma = pps->log2_sao_offset_scale_luma,
118  .log2_sao_offset_scale_chroma = pps->log2_sao_offset_scale_chroma,
119  .high_precision_offsets_enabled_flag = sps->high_precision_offsets_enabled,
120 #endif
121  .pcm_loop_filter_disabled_flag = sps->pcm_loop_filter_disabled,
122  .strong_intra_smoothing_enabled_flag = sps->strong_intra_smoothing_enabled,
123  .max_transform_hierarchy_depth_intra = sps->max_transform_hierarchy_depth_intra,
124  .max_transform_hierarchy_depth_inter = sps->max_transform_hierarchy_depth_inter,
125  .amp_enabled_flag = sps->amp_enabled,
126  .separate_colour_plane_flag = sps->separate_colour_plane,
127  .log2_max_pic_order_cnt_lsb_minus4 = sps->log2_max_poc_lsb - 4,
128  .num_short_term_ref_pic_sets = sps->nb_st_rps,
129  .long_term_ref_pics_present_flag = sps->long_term_ref_pics_present,
130  .num_long_term_ref_pics_sps = sps->num_long_term_ref_pics_sps,
131  .sps_temporal_mvp_enabled_flag = sps->temporal_mvp_enabled,
132  .sample_adaptive_offset_enabled_flag = sps->sao_enabled,
133  .scaling_list_enable_flag = sps->scaling_list_enabled,
134  .IrapPicFlag = IS_IRAP(s),
135  .IdrPicFlag = IS_IDR(s),
136  .bit_depth_luma_minus8 = sps->bit_depth - 8,
137  .bit_depth_chroma_minus8 = sps->bit_depth - 8,
138 #if NVDECAPI_CHECK_VERSION(9, 0)
139  .sps_range_extension_flag = sps->range_extension,
140  .transform_skip_rotation_enabled_flag = sps->transform_skip_rotation_enabled,
141  .transform_skip_context_enabled_flag = sps->transform_skip_context_enabled,
142  .implicit_rdpcm_enabled_flag = sps->implicit_rdpcm_enabled,
143  .explicit_rdpcm_enabled_flag = sps->explicit_rdpcm_enabled,
144  .extended_precision_processing_flag = sps->extended_precision_processing,
145  .intra_smoothing_disabled_flag = sps->intra_smoothing_disabled,
146  .persistent_rice_adaptation_enabled_flag = sps->persistent_rice_adaptation_enabled,
147  .cabac_bypass_alignment_enabled_flag = sps->cabac_bypass_alignment_enabled,
148 #endif
149 
150  .dependent_slice_segments_enabled_flag = pps->dependent_slice_segments_enabled_flag,
151  .slice_segment_header_extension_present_flag = pps->slice_header_extension_present_flag,
152  .sign_data_hiding_enabled_flag = pps->sign_data_hiding_flag,
153  .cu_qp_delta_enabled_flag = pps->cu_qp_delta_enabled_flag,
154  .diff_cu_qp_delta_depth = pps->diff_cu_qp_delta_depth,
155  .init_qp_minus26 = pps->pic_init_qp_minus26,
156  .pps_cb_qp_offset = pps->cb_qp_offset,
157  .pps_cr_qp_offset = pps->cr_qp_offset,
158  .constrained_intra_pred_flag = pps->constrained_intra_pred_flag,
159  .weighted_pred_flag = pps->weighted_pred_flag,
160  .weighted_bipred_flag = pps->weighted_bipred_flag,
161  .transform_skip_enabled_flag = pps->transform_skip_enabled_flag,
162  .transquant_bypass_enabled_flag = pps->transquant_bypass_enable_flag,
163  .entropy_coding_sync_enabled_flag = pps->entropy_coding_sync_enabled_flag,
164  .log2_parallel_merge_level_minus2 = pps->log2_parallel_merge_level - 2,
165  .num_extra_slice_header_bits = pps->num_extra_slice_header_bits,
166  .loop_filter_across_tiles_enabled_flag = pps->loop_filter_across_tiles_enabled_flag,
167  .loop_filter_across_slices_enabled_flag = pps->seq_loop_filter_across_slices_enabled_flag,
168  .output_flag_present_flag = pps->output_flag_present_flag,
169  .num_ref_idx_l0_default_active_minus1 = pps->num_ref_idx_l0_default_active - 1,
170  .num_ref_idx_l1_default_active_minus1 = pps->num_ref_idx_l1_default_active - 1,
171  .lists_modification_present_flag = pps->lists_modification_present_flag,
172  .cabac_init_present_flag = pps->cabac_init_present_flag,
173  .pps_slice_chroma_qp_offsets_present_flag = pps->pic_slice_level_chroma_qp_offsets_present_flag,
174  .deblocking_filter_override_enabled_flag = pps->deblocking_filter_override_enabled_flag,
175  .pps_deblocking_filter_disabled_flag = pps->disable_dbf,
176  .pps_beta_offset_div2 = pps->beta_offset / 2,
177  .pps_tc_offset_div2 = pps->tc_offset / 2,
178  .tiles_enabled_flag = pps->tiles_enabled_flag,
179  .uniform_spacing_flag = pps->uniform_spacing_flag,
180  .num_tile_columns_minus1 = pps->num_tile_columns - 1,
181  .num_tile_rows_minus1 = pps->num_tile_rows - 1,
182 #if NVDECAPI_CHECK_VERSION(9, 0)
183  .pps_range_extension_flag = pps->pps_range_extensions_flag,
184  .cross_component_prediction_enabled_flag = pps->cross_component_prediction_enabled_flag,
185  .chroma_qp_offset_list_enabled_flag = pps->chroma_qp_offset_list_enabled_flag,
186  .diff_cu_chroma_qp_offset_depth = pps->diff_cu_chroma_qp_offset_depth,
187  .chroma_qp_offset_list_len_minus1 = pps->chroma_qp_offset_list_len_minus1,
188 #endif
189 
190  .NumBitsForShortTermRPSInSlice = s->sh.short_term_rps ? s->sh.short_term_ref_pic_set_size : 0,
191  .NumDeltaPocsOfRefRpsIdx = s->sh.short_term_rps ? s->sh.short_term_rps->rps_idx_num_delta_pocs : 0,
192  .NumPocTotalCurr = ff_hevc_frame_nb_refs(&s->sh, pps, s->cur_layer),
193  .NumPocStCurrBefore = s->rps[ST_CURR_BEF].nb_refs,
194  .NumPocStCurrAfter = s->rps[ST_CURR_AFT].nb_refs,
195  .NumPocLtCurr = s->rps[LT_CURR].nb_refs,
196  .CurrPicOrderCntVal = s->cur_frame->poc,
197  },
198  };
199 
200  if (pps->num_tile_columns > FF_ARRAY_ELEMS(ppc->column_width_minus1) ||
201  pps->num_tile_rows > FF_ARRAY_ELEMS(ppc->row_height_minus1)) {
202  av_log(avctx, AV_LOG_ERROR, "Too many tiles\n");
203  return AVERROR(ENOSYS);
204  }
205  for (i = 0; i < pps->num_tile_columns; i++)
206  ppc->column_width_minus1[i] = pps->column_width[i] - 1;
207  for (i = 0; i < pps->num_tile_rows; i++)
208  ppc->row_height_minus1[i] = pps->row_height[i] - 1;
209 
210 #if NVDECAPI_CHECK_VERSION(9, 0)
211  if (pps->chroma_qp_offset_list_len_minus1 >= FF_ARRAY_ELEMS(ppc->cb_qp_offset_list) ||
212  pps->chroma_qp_offset_list_len_minus1 >= FF_ARRAY_ELEMS(ppc->cr_qp_offset_list)) {
213  av_log(avctx, AV_LOG_ERROR, "Too many chroma_qp_offsets\n");
214  return AVERROR(ENOSYS);
215  }
216  for (i = 0; i <= pps->chroma_qp_offset_list_len_minus1; i++) {
217  ppc->cb_qp_offset_list[i] = pps->cb_qp_offset_list[i];
218  ppc->cr_qp_offset_list[i] = pps->cr_qp_offset_list[i];
219  }
220 #endif
221 
222  if (s->rps[LT_CURR].nb_refs > FF_ARRAY_ELEMS(ppc->RefPicSetLtCurr) ||
223  s->rps[ST_CURR_BEF].nb_refs > FF_ARRAY_ELEMS(ppc->RefPicSetStCurrBefore) ||
224  s->rps[ST_CURR_AFT].nb_refs > FF_ARRAY_ELEMS(ppc->RefPicSetStCurrAfter)) {
225  av_log(avctx, AV_LOG_ERROR, "Too many reference frames\n");
226  return AVERROR(ENOSYS);
227  }
228 
229  dpb_size = 0;
230  for (i = 0; i < FF_ARRAY_ELEMS(l->DPB); i++) {
231  const HEVCFrame *ref = &l->DPB[i];
233  continue;
234  if (dpb_size >= FF_ARRAY_ELEMS(ppc->RefPicIdx)) {
235  av_log(avctx, AV_LOG_ERROR, "Too many reference frames\n");
236  return AVERROR_INVALIDDATA;
237  }
238  dpb_add(ppc, dpb_size++, ref);
239 
240  }
241  for (i = dpb_size; i < FF_ARRAY_ELEMS(ppc->RefPicIdx); i++)
242  ppc->RefPicIdx[i] = -1;
243 
244  for (i = 0; i < s->rps[ST_CURR_BEF].nb_refs; i++) {
245  for (j = 0; j < dpb_size; j++) {
246  if (ppc->PicOrderCntVal[j] == s->rps[ST_CURR_BEF].list[i]) {
247  ppc->RefPicSetStCurrBefore[i] = j;
248  break;
249  }
250  }
251  }
252  for (i = 0; i < s->rps[ST_CURR_AFT].nb_refs; i++) {
253  for (j = 0; j < dpb_size; j++) {
254  if (ppc->PicOrderCntVal[j] == s->rps[ST_CURR_AFT].list[i]) {
255  ppc->RefPicSetStCurrAfter[i] = j;
256  break;
257  }
258  }
259  }
260  for (i = 0; i < s->rps[LT_CURR].nb_refs; i++) {
261  for (j = 0; j < dpb_size; j++) {
262  if (ppc->PicOrderCntVal[j] == s->rps[LT_CURR].list[i]) {
263  ppc->RefPicSetLtCurr[i] = j;
264  break;
265  }
266  }
267  }
268 
269  fill_scaling_lists(ppc, s);
270 
271  return 0;
272 }
273 
274 static int nvdec_hevc_decode_slice(AVCodecContext *avctx, const uint8_t *buffer,
275  uint32_t size)
276 {
278  void *tmp;
279 
280  tmp = av_fast_realloc(ctx->bitstream_internal, &ctx->bitstream_allocated,
281  ctx->bitstream_len + size + 3);
282  if (!tmp)
283  return AVERROR(ENOMEM);
284  ctx->bitstream = ctx->bitstream_internal = tmp;
285 
286  tmp = av_fast_realloc(ctx->slice_offsets, &ctx->slice_offsets_allocated,
287  (ctx->nb_slices + 1) * sizeof(*ctx->slice_offsets));
288  if (!tmp)
289  return AVERROR(ENOMEM);
290  ctx->slice_offsets = tmp;
291 
292  AV_WB24(ctx->bitstream_internal + ctx->bitstream_len, 1);
293  memcpy(ctx->bitstream_internal + ctx->bitstream_len + 3, buffer, size);
294  ctx->slice_offsets[ctx->nb_slices] = ctx->bitstream_len ;
295  ctx->bitstream_len += size + 3;
296  ctx->nb_slices++;
297 
298  return 0;
299 }
300 
302  AVBufferRef *hw_frames_ctx)
303 {
304  const HEVCContext *s = avctx->priv_data;
305  const HEVCSPS *sps = s->pps->sps;
306  return ff_nvdec_frame_params(avctx, hw_frames_ctx, sps->temporal_layer[sps->max_sub_layers - 1].max_dec_pic_buffering + 1, 1);
307 }
308 
311  ctx->supports_444 = 1;
312 
313  if (avctx->profile != AV_PROFILE_HEVC_MAIN &&
314  avctx->profile != AV_PROFILE_HEVC_MAIN_10 &&
316  avctx->profile != AV_PROFILE_HEVC_REXT) {
317  av_log(avctx, AV_LOG_ERROR, "Unsupported HEVC profile: %d\n", avctx->profile);
318  return AVERROR(ENOTSUP);
319  }
320 
321  return ff_nvdec_decode_init(avctx);
322 }
323 
325  .p.name = "hevc_nvdec",
326  .p.type = AVMEDIA_TYPE_VIDEO,
327  .p.id = AV_CODEC_ID_HEVC,
328  .p.pix_fmt = AV_PIX_FMT_CUDA,
329  .start_frame = nvdec_hevc_start_frame,
330  .end_frame = ff_nvdec_end_frame,
331  .decode_slice = nvdec_hevc_decode_slice,
332  .frame_params = nvdec_hevc_frame_params,
333  .init = nvdec_hevc_decode_init,
334  .uninit = ff_nvdec_decode_uninit,
335  .priv_data_size = sizeof(NVDECContext),
336 };
AV_PIX_FMT_CUDA
@ AV_PIX_FMT_CUDA
HW acceleration through CUDA.
Definition: pixfmt.h:260
AVERROR
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
AV_PROFILE_HEVC_MAIN
#define AV_PROFILE_HEVC_MAIN
Definition: defs.h:159
FFHWAccel::p
AVHWAccel p
The public AVHWAccel.
Definition: hwaccel_internal.h:38
FrameDecodeData
This struct stores per-frame lavc-internal data and is attached to it via private_ref.
Definition: decode.h:33
tmp
static uint8_t tmp[11]
Definition: aes_ctr.c:28
internal.h
ScalingList::sl
uint8_t sl[4][6][64]
Definition: ps.h:251
HEVC_FRAME_FLAG_LONG_REF
#define HEVC_FRAME_FLAG_LONG_REF
Definition: hevcdec.h:358
FFHWAccel
Definition: hwaccel_internal.h:34
nvdec_hevc_frame_params
static int nvdec_hevc_frame_params(AVCodecContext *avctx, AVBufferRef *hw_frames_ctx)
Definition: nvdec_hevc.c:301
ff_nvdec_start_frame
int ff_nvdec_start_frame(AVCodecContext *avctx, AVFrame *frame)
Definition: nvdec.c:575
ff_hevc_diag_scan8x8_y
const uint8_t ff_hevc_diag_scan8x8_y[64]
Definition: data.c:58
NVDECAPI_CHECK_VERSION
#define NVDECAPI_CHECK_VERSION(major, minor)
Definition: nvdec.h:40
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:209
FF_ARRAY_ELEMS
#define FF_ARRAY_ELEMS(a)
Definition: sinewin_tablegen.c:29
nvdec_hevc_decode_init
static int nvdec_hevc_decode_init(AVCodecContext *avctx)
Definition: nvdec_hevc.c:309
nvdec_hevc_start_frame
static int nvdec_hevc_start_frame(AVCodecContext *avctx, const AVBufferRef *buffer_ref, const uint8_t *buffer, uint32_t size)
Definition: nvdec_hevc.c:72
av_fast_realloc
void * av_fast_realloc(void *ptr, unsigned int *size, size_t min_size)
Reallocate the given buffer if it is not large enough, otherwise do nothing.
Definition: mem.c:497
s
#define s(width, name)
Definition: cbs_vp9.c:198
NVDECFrame
Definition: nvdec.h:49
ctx
AVFormatContext * ctx
Definition: movenc.c:49
decode.h
IS_IDR
#define IS_IDR(s)
Definition: hevcdec.h:76
HEVC_FRAME_FLAG_SHORT_REF
#define HEVC_FRAME_FLAG_SHORT_REF
Definition: hevcdec.h:357
nvdec_hevc_decode_slice
static int nvdec_hevc_decode_slice(AVCodecContext *avctx, const uint8_t *buffer, uint32_t size)
Definition: nvdec_hevc.c:274
ScalingList
Definition: ps.h:248
dpb_size
int dpb_size
Definition: h264_levels.c:111
ff_hevc_diag_scan4x4_y
const uint8_t ff_hevc_diag_scan4x4_y[16]
Definition: data.c:32
ScalingList::sl_dc
uint8_t sl_dc[2][6]
Definition: ps.h:252
hwaccel_internal.h
ff_nvdec_decode_init
int ff_nvdec_decode_init(AVCodecContext *avctx)
Definition: nvdec.c:327
AVCodecContext::internal
struct AVCodecInternal * internal
Private context used for internal data.
Definition: avcodec.h:466
AV_PROFILE_HEVC_MAIN_STILL_PICTURE
#define AV_PROFILE_HEVC_MAIN_STILL_PICTURE
Definition: defs.h:161
fill_scaling_lists
static void fill_scaling_lists(CUVIDHEVCPICPARAMS *ppc, const HEVCContext *s)
Definition: nvdec_hevc.c:45
data.h
AV_PROFILE_HEVC_MAIN_10
#define AV_PROFILE_HEVC_MAIN_10
Definition: defs.h:160
AV_PROFILE_HEVC_REXT
#define AV_PROFILE_HEVC_REXT
Definition: defs.h:162
IS_IRAP
#define IS_IRAP(s)
Definition: hevcdec.h:79
hevcdec.h
AVCodecInternal::hwaccel_priv_data
void * hwaccel_priv_data
hwaccel-specific private data
Definition: internal.h:130
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:424
NVDECFrame::idx
unsigned int idx
Definition: nvdec.h:50
size
int size
Definition: twinvq_data.h:10344
AV_WB24
#define AV_WB24(p, d)
Definition: intreadwrite.h:446
dpb_add
static void dpb_add(CUVIDHEVCPICPARAMS *pp, int idx, const HEVCFrame *src)
Definition: nvdec_hevc.c:35
nvdec.h
ff_nvdec_decode_uninit
int ff_nvdec_decode_uninit(AVCodecContext *avctx)
Definition: nvdec.c:259
AVHWAccel::name
const char * name
Name of the hardware accelerated codec.
Definition: avcodec.h:1948
ff_hevc_frame_nb_refs
int ff_hevc_frame_nb_refs(const SliceHeader *sh, const HEVCPPS *pps, unsigned layer_idx)
Get the number of candidate references for the current frame.
Definition: refs.c:613
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
HEVCFrame
Definition: hevcdec.h:362
HEVCLayerContext
Definition: hevcdec.h:454
ff_nvdec_end_frame
int ff_nvdec_end_frame(AVCodecContext *avctx)
Definition: nvdec.c:647
AV_CODEC_ID_HEVC
@ AV_CODEC_ID_HEVC
Definition: codec_id.h:228
ff_hevc_diag_scan4x4_x
const uint8_t ff_hevc_diag_scan4x4_x[16]
Definition: data.c:25
ff_hevc_nvdec_hwaccel
const FFHWAccel ff_hevc_nvdec_hwaccel
Definition: nvdec_hevc.c:324
avcodec.h
ret
ret
Definition: filter_design.txt:187
ST_CURR_BEF
@ ST_CURR_BEF
Definition: hevcdec.h:86
sps
static int FUNC() sps(CodedBitstreamContext *ctx, RWContext *rw, H264RawSPS *current)
Definition: cbs_h264_syntax_template.c:260
pos
unsigned int pos
Definition: spdifenc.c:414
LT_CURR
@ LT_CURR
Definition: hevcdec.h:89
AVCodecContext
main external API structure.
Definition: avcodec.h:431
buffer
the frame and frame reference mechanism is intended to as much as expensive copies of that data while still allowing the filters to produce correct results The data is stored in buffers represented by AVFrame structures Several references can point to the same frame buffer
Definition: filter_design.txt:49
HEVCContext
Definition: hevcdec.h:492
ff_nvdec_frame_params
int ff_nvdec_frame_params(AVCodecContext *avctx, AVBufferRef *hw_frames_ctx, int dpb_size, int supports_444)
Definition: nvdec.c:709
AVCodecContext::profile
int profile
profile
Definition: avcodec.h:1621
HEVCLayerContext::DPB
HEVCFrame DPB[32]
Definition: hevcdec.h:455
ref
static int ref[MAX_W *MAX_W]
Definition: jpeg2000dwt.c:117
pps
uint64_t pps
Definition: dovi_rpuenc.c:35
ff_hevc_diag_scan8x8_x
const uint8_t ff_hevc_diag_scan8x8_x[64]
Definition: data.c:39
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
mem.h
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:82
HEVCSPS
Definition: ps.h:255
HEVCPPS
Definition: ps.h:374
ST_CURR_AFT
@ ST_CURR_AFT
Definition: hevcdec.h:87
AVCodecContext::priv_data
void * priv_data
Definition: avcodec.h:458
FrameDecodeData::hwaccel_priv
void * hwaccel_priv
Per-frame private data for hwaccels.
Definition: decode.h:51
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
NVDECContext
Definition: nvdec.h:57
src
#define src
Definition: vp8dsp.c:248