From: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
To: ffmpeg-devel@ffmpeg.org
Subject: Re: [FFmpeg-devel] [PATCH v2 13/14] vvcdec: add CTU thread logical
Date: Sun, 9 Jul 2023 03:04:19 +0200
Message-ID: <GV1P250MB073784005F82507845C6FE498F33A@GV1P250MB0737.EURP250.PROD.OUTLOOK.COM> (raw)
In-Reply-To: <20230708214135.GA1093384@pb2>
Michael Niedermayer:
> On Fri, Jul 07, 2023 at 10:05:39PM +0800, Nuo Mi wrote:
>> This is the main entry point for the CTU (Coding Tree Unit) decoder.
>> The code will divide the CTU decoder into several stages.
>> It will check the stage dependencies and run the stage decoder.
>> ---
>> libavcodec/vvc/Makefile | 3 +-
>> libavcodec/vvc/vvc_thread.c | 804 ++++++++++++++++++++++++++++++++++++
>> libavcodec/vvc/vvc_thread.h | 73 ++++
>> 3 files changed, 879 insertions(+), 1 deletion(-)
>> create mode 100644 libavcodec/vvc/vvc_thread.c
>> create mode 100644 libavcodec/vvc/vvc_thread.h
>
> seems not to build with enable-shared
>
> src/libavcodec/vvc/vvc_thread.c:235:9: error: address argument to atomic operation must be a pointer to non-const _Atomic type ('const atomic_int *' (aka 'const _Atomic(int) *') invalid)
> if (atomic_load(&ft->ret))
> ^ ~~~~~~~~
> /usr/lib/llvm-6.0/lib/clang/6.0.0/include/stdatomic.h:134:29: note: expanded from macro 'atomic_load'
> #define atomic_load(object) __c11_atomic_load(object, __ATOMIC_SEQ_CST)
> ^ ~~~~~~
> 1 error generated.
> src/ffbuild/common.mak:81: recipe for target 'libavcodec/vvc/vvc_thread.o' failed
> make: *** [libavcodec/vvc/vvc_thread.o] Error 1
> make: *** Waiting for unfinished jobs....
>
>
atomic_load() does not accept pointers to non-const atomic objects in
the original C11 spec (presumably the reason for this was that on
systems that lack atomics of the appropriate size an atomic would need
to be emulated somehow and this may involve locking and therefore
require the object to be writable). Your system is old and abides by the
original spec; AFAIK this point has been changed in later specs.
The solution is to use a cast.
- Andreas
PS: Exactly the same thing happened in the HEVC decoder.
_______________________________________________
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
To unsubscribe, visit link above, or email
ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
next prev parent reply other threads:[~2023-07-09 1:03 UTC|newest]
Thread overview: 53+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20230707140540.10279-1-nuomi2021@gmail.com>
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 01/14] vvcdec: add thread executor Nuo Mi
2023-07-08 21:51 ` Michael Niedermayer
2023-07-10 7:41 ` Nuo Mi
2023-07-16 6:28 ` Nuo Mi
2023-07-17 22:13 ` Michael Niedermayer
2023-07-18 11:53 ` Nuo Mi
2023-07-18 14:55 ` Michael Niedermayer
2023-07-14 22:38 ` Michael Niedermayer
2023-07-16 7:07 ` Nuo Mi
2023-07-19 13:13 ` [FFmpeg-devel] [PATCH v3] " Nuo Mi
2023-07-19 13:19 ` Nuo Mi
2023-08-14 16:46 ` Michael Niedermayer
2023-08-15 14:53 ` Nuo Mi
2023-08-15 14:50 ` [FFmpeg-devel] [PATCH v4] " Nuo Mi
2023-08-16 16:35 ` Michael Niedermayer
2023-08-22 13:34 ` Nuo Mi
2023-08-16 16:42 ` Rémi Denis-Courmont
2023-08-18 15:54 ` James Almer
2023-08-22 12:03 ` Nuo Mi
2023-08-22 12:23 ` James Almer
2023-08-22 12:30 ` Nuo Mi
2023-08-22 12:32 ` James Almer
2023-08-22 13:34 ` Nuo Mi
2023-08-18 16:17 ` James Almer
2023-08-19 13:09 ` James Almer
2023-08-22 12:09 ` Nuo Mi
2023-08-22 12:20 ` Nuo Mi
2023-08-22 13:32 ` [FFmpeg-devel] [PATCH v5] " Nuo Mi
2023-08-28 17:06 ` Michael Niedermayer
2023-08-29 13:07 ` Nuo Mi
2023-08-29 12:59 ` [FFmpeg-devel] [PATCH v6] " Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 02/14] vvcdec: add vvc decoder stub Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 03/14] vvcdec: add sps, pps, sh parser Nuo Mi
2023-07-07 14:28 ` James Almer
2023-07-07 15:48 ` Nuo Mi
2023-07-07 16:29 ` James Almer
2023-07-10 7:46 ` Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 04/14] vvcdec: add cabac decoder Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 05/14] vvcdec: add reference management Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 06/14] vvcdec: add motion vector decoder Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 07/14] vvcdec: add inter prediction Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 08/14] vvcdec: add inv transform 1d Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 09/14] vvcdec: add intra prediction Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 10/14] vvcdec: add LMCS, Deblocking, SAO, and ALF filters Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 11/14] vvcdec: add dsp init and inv transform Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 12/14] vvcdec: add CTU parser Nuo Mi
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 13/14] vvcdec: add CTU thread logical Nuo Mi
2023-07-08 21:41 ` Michael Niedermayer
2023-07-09 1:04 ` Andreas Rheinhardt [this message]
2023-07-10 7:45 ` Nuo Mi
2023-07-10 15:04 ` Rémi Denis-Courmont
2023-07-11 17:28 ` Michael Niedermayer
2023-07-07 14:05 ` [FFmpeg-devel] [PATCH v2 14/14] vvcdec: add full vvc decoder Nuo Mi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=GV1P250MB073784005F82507845C6FE498F33A@GV1P250MB0737.EURP250.PROD.OUTLOOK.COM \
--to=andreas.rheinhardt@outlook.com \
--cc=ffmpeg-devel@ffmpeg.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
This inbox may be cloned and mirrored by anyone:
git clone --mirror https://master.gitmailbox.com/ffmpegdev/0 ffmpegdev/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 ffmpegdev ffmpegdev/ https://master.gitmailbox.com/ffmpegdev \
ffmpegdev@gitmailbox.com
public-inbox-index ffmpegdev
Example config snippet for mirrors.
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git