[FFmpeg-devel] [PATCH 04/18] avcodec/hevcdec: Add pointers to logctx and parent ctx to HEVCLocalCtx
Andreas Rheinhardt
andreas.rheinhardt at outlook.com
Fri Jul 1 01:29:35 EEST 2022
It is safe for a slice thread to read the main context
and therefore it is safe to add a pointer to const HEVCContext
(namely the parent context) to each HEVCLocalContext.
It is also safe (and actually redundant) to add a pointer
to a logcontext to HEVCLocalContext.
Doing so allows to pass the HEVCLocalContext as context in
the parts of the code that is run slice-threaded when slice-threading
is in use (currently these parts of the code use ordinary
HEVCContext*). This way one is not tempted to modify
the main context from the slice contexts.
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at outlook.com>
---
One could btw also cache the pointers to the current SPS and PPS;
doing so would make several accesses to the parent context superfluous.
libavcodec/hevcdec.c | 4 ++++
libavcodec/hevcdec.h | 3 +++
2 files changed, 7 insertions(+)
diff --git a/libavcodec/hevcdec.c b/libavcodec/hevcdec.c
index 5ad02742ba..111da42836 100644
--- a/libavcodec/hevcdec.c
+++ b/libavcodec/hevcdec.c
@@ -2661,6 +2661,8 @@ static int hls_slice_data_wpp(HEVCContext *s, const H2645NAL *nal)
res = AVERROR(ENOMEM);
goto error;
}
+ s->HEVClcList[i]->logctx = s->avctx;
+ s->HEVClcList[i]->parent = s->sList[i];
}
offset = (lc->gb.index >> 3);
@@ -3646,6 +3648,8 @@ static av_cold int hevc_init_context(AVCodecContext *avctx)
s->sList = av_mallocz(sizeof(HEVCContext*) * s->threads_number);
if (!s->HEVClc || !s->HEVClcList || !s->sList)
return AVERROR(ENOMEM);
+ s->HEVClc->parent = s;
+ s->HEVClc->logctx = avctx;
s->HEVClcList[0] = s->HEVClc;
s->sList[0] = s;
diff --git a/libavcodec/hevcdec.h b/libavcodec/hevcdec.h
index ff2199aa5a..a4cea2284d 100644
--- a/libavcodec/hevcdec.h
+++ b/libavcodec/hevcdec.h
@@ -428,6 +428,9 @@ typedef struct HEVCLocalContext {
uint8_t first_qp_group;
+ void *logctx;
+ const struct HEVCContext *parent;
+
GetBitContext gb;
CABACContext cc;
--
2.34.1
More information about the ffmpeg-devel
mailing list