summaryrefslogtreecommitdiff
path: root/libavcodec
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2015-07-12 22:55:47 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2015-07-12 22:55:47 +0200
commit4c42c66935a7bdaded8667fa76dc0945ae66e867 (patch)
tree34fe29a6bbbbd099f728a5c082f124fa8cf5d053 /libavcodec
parent760304e4c3184d65cf90a017ea75ed40c3b823ea (diff)
parentae05b4865514fd71b5e9431e93aa0d03d7ba7751 (diff)
Merge commit 'ae05b4865514fd71b5e9431e93aa0d03d7ba7751'
* commit 'ae05b4865514fd71b5e9431e93aa0d03d7ba7751': hevc: eliminate the second call to hls_nal_unit() Conflicts: libavcodec/hevc.c Merged-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/hevc.c32
-rw-r--r--libavcodec/hevc.h5
2 files changed, 20 insertions, 17 deletions
diff --git a/libavcodec/hevc.c b/libavcodec/hevc.c
index 0f0846efa0..a3798e6189 100644
--- a/libavcodec/hevc.c
+++ b/libavcodec/hevc.c
@@ -2509,24 +2509,24 @@ static int hls_slice_data_wpp(HEVCContext *s, const uint8_t *nal, int length)
* @return AVERROR_INVALIDDATA if the packet is not a valid NAL unit,
* 0 if the unit should be skipped, 1 otherwise
*/
-static int hls_nal_unit(HEVCContext *s)
+static int hls_nal_unit(HEVCNAL *nal, AVCodecContext *avctx)
{
- GetBitContext *gb = &s->HEVClc->gb;
+ GetBitContext *gb = &nal->gb;
int nuh_layer_id;
if (get_bits1(gb) != 0)
return AVERROR_INVALIDDATA;
- s->nal_unit_type = get_bits(gb, 6);
+ nal->type = get_bits(gb, 6);
nuh_layer_id = get_bits(gb, 6);
- s->temporal_id = get_bits(gb, 3) - 1;
- if (s->temporal_id < 0)
+ nal->temporal_id = get_bits(gb, 3) - 1;
+ if (nal->temporal_id < 0)
return AVERROR_INVALIDDATA;
- av_log(s->avctx, AV_LOG_DEBUG,
+ av_log(avctx, AV_LOG_DEBUG,
"nal_unit_type: %d, nuh_layer_id: %d, temporal_id: %d\n",
- s->nal_unit_type, nuh_layer_id, s->temporal_id);
+ nal->type, nuh_layer_id, nal->temporal_id);
return nuh_layer_id == 0;
}
@@ -2643,11 +2643,9 @@ static int decode_nal_unit(HEVCContext *s, const HEVCNAL *nal)
GetBitContext *gb = &lc->gb;
int ctb_addr_ts, ret;
- ret = init_get_bits8(gb, nal->data, nal->size);
- if (ret < 0)
- return ret;
-
- hls_nal_unit(s);
+ *gb = nal->gb;
+ s->nal_unit_type = nal->type;
+ s->temporal_id = nal->temporal_id;
switch (s->nal_unit_type) {
case NAL_VPS:
@@ -2873,22 +2871,22 @@ static int decode_nal_units(HEVCContext *s, const uint8_t *buf, int length)
s->skipped_bytes_pos_size_nal[s->nb_nals] = s->skipped_bytes_pos_size;
s->skipped_bytes_pos_nal[s->nb_nals++] = s->skipped_bytes_pos;
- ret = init_get_bits8(&s->HEVClc->gb, nal->data, nal->size);
+ ret = init_get_bits8(&nal->gb, nal->data, nal->size);
if (ret < 0)
goto fail;
- ret = hls_nal_unit(s);
+ ret = hls_nal_unit(nal, s->avctx);
if (ret <= 0) {
if (ret < 0) {
av_log(s->avctx, AV_LOG_ERROR, "Invalid NAL unit %d, skipping.\n",
- s->nal_unit_type);
+ nal->type);
}
s->nb_nals--;
goto skip_nal;
}
- if (s->nal_unit_type == NAL_EOB_NUT ||
- s->nal_unit_type == NAL_EOS_NUT)
+ if (nal->type == NAL_EOB_NUT ||
+ nal->type == NAL_EOS_NUT)
s->eos = 1;
skip_nal:
diff --git a/libavcodec/hevc.h b/libavcodec/hevc.h
index 73824514c9..8f4346efa2 100644
--- a/libavcodec/hevc.h
+++ b/libavcodec/hevc.h
@@ -754,6 +754,11 @@ typedef struct HEVCNAL {
int raw_size;
const uint8_t *raw_data;
+
+ GetBitContext gb;
+
+ enum NALUnitType type;
+ int temporal_id;
} HEVCNAL;
typedef struct HEVCLocalContext {