* [FFmpeg-devel] [PATCH] avcodec/h2645_vui: Interpret a degenerate SAR as unspecified.
@ 2025-11-04 13:37 Giovanni Mascellani via ffmpeg-devel
2025-11-04 13:50 ` [FFmpeg-devel] " Zhao Zhili via ffmpeg-devel
0 siblings, 1 reply; 3+ messages in thread
From: Giovanni Mascellani via ffmpeg-devel @ 2025-11-04 13:37 UTC (permalink / raw)
To: ffmpeg-devel; +Cc: Giovanni Mascellani
[-- Attachment #1.1.1: Type: text/plain, Size: 1100 bytes --]
The specification says that if either the numerator or the
denominator is zero then the SAR is to be intended unspecified.
Internally ffmpeg represents an unspecified SAR as 0/1, while
fractions with a zero denominator are not handled properly;
so we bridge the gap by replacing x/0 with 0/1.
Signed-off-by: Giovanni Mascellani <gmascellani@codeweavers.com>
---
libavcodec/h2645_vui.c | 2 ++
1 file changed, 2 insertions(+)
diff --git a/libavcodec/h2645_vui.c b/libavcodec/h2645_vui.c
index 0e576c1563..7d01354761 100644
--- a/libavcodec/h2645_vui.c
+++ b/libavcodec/h2645_vui.c
@@ -46,6 +46,8 @@ void ff_h2645_decode_common_vui_params(GetBitContext
*gb, H2645VUI *vui, void *l
else if (vui->aspect_ratio_idc == EXTENDED_SAR) {
vui->sar.num = get_bits(gb, 16);
vui->sar.den = get_bits(gb, 16);
+ if (vui->sar.den == 0)
+ vui->sar = (AVRational){ 0, 1 };
} else
av_log(logctx, AV_LOG_WARNING,
"Unknown SAR index: %u.\n", vui->aspect_ratio_idc);
--
2.51.0
[-- Attachment #1.2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
[-- Attachment #2: Type: text/plain, Size: 163 bytes --]
_______________________________________________
ffmpeg-devel mailing list -- ffmpeg-devel@ffmpeg.org
To unsubscribe send an email to ffmpeg-devel-leave@ffmpeg.org
^ permalink raw reply [flat|nested] 3+ messages in thread
* [FFmpeg-devel] Re: [PATCH] avcodec/h2645_vui: Interpret a degenerate SAR as unspecified.
2025-11-04 13:37 [FFmpeg-devel] [PATCH] avcodec/h2645_vui: Interpret a degenerate SAR as unspecified Giovanni Mascellani via ffmpeg-devel
@ 2025-11-04 13:50 ` Zhao Zhili via ffmpeg-devel
2025-11-04 13:58 ` Giovanni Mascellani via ffmpeg-devel
0 siblings, 1 reply; 3+ messages in thread
From: Zhao Zhili via ffmpeg-devel @ 2025-11-04 13:50 UTC (permalink / raw)
To: FFmpeg development discussions and patches
Cc: Giovanni Mascellani, Zhao Zhili
> On Nov 4, 2025, at 21:37, Giovanni Mascellani via ffmpeg-devel <ffmpeg-devel@ffmpeg.org> wrote:
>
> The specification says that if either the numerator or the
> denominator is zero then the SAR is to be intended unspecified.
> Internally ffmpeg represents an unspecified SAR as 0/1, while
> fractions with a zero denominator are not handled properly;
Is there any known issue?
> so we bridge the gap by replacing x/0 with 0/1.
>
> Signed-off-by: Giovanni Mascellani <gmascellani@codeweavers.com>
> ---
> libavcodec/h2645_vui.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/libavcodec/h2645_vui.c b/libavcodec/h2645_vui.c
> index 0e576c1563..7d01354761 100644
> --- a/libavcodec/h2645_vui.c
> +++ b/libavcodec/h2645_vui.c
> @@ -46,6 +46,8 @@ void ff_h2645_decode_common_vui_params(GetBitContext *gb, H2645VUI *vui, void *l
> else if (vui->aspect_ratio_idc == EXTENDED_SAR) {
> vui->sar.num = get_bits(gb, 16);
> vui->sar.den = get_bits(gb, 16);
> + if (vui->sar.den == 0)
> + vui->sar = (AVRational){ 0, 1 };
> } else
> av_log(logctx, AV_LOG_WARNING,
> "Unknown SAR index: %u.\n", vui->aspect_ratio_idc);
> --
> 2.51.0
>
> _______________________________________________
> ffmpeg-devel mailing list -- ffmpeg-devel@ffmpeg.org
> To unsubscribe send an email to ffmpeg-devel-leave@ffmpeg.org
>
_______________________________________________
ffmpeg-devel mailing list -- ffmpeg-devel@ffmpeg.org
To unsubscribe send an email to ffmpeg-devel-leave@ffmpeg.org
^ permalink raw reply [flat|nested] 3+ messages in thread
* [FFmpeg-devel] Re: [PATCH] avcodec/h2645_vui: Interpret a degenerate SAR as unspecified.
2025-11-04 13:50 ` [FFmpeg-devel] " Zhao Zhili via ffmpeg-devel
@ 2025-11-04 13:58 ` Giovanni Mascellani via ffmpeg-devel
0 siblings, 0 replies; 3+ messages in thread
From: Giovanni Mascellani via ffmpeg-devel @ 2025-11-04 13:58 UTC (permalink / raw)
To: Zhao Zhili, FFmpeg development discussions and patches
Cc: Giovanni Mascellani
[-- Attachment #1.1.1: Type: text/plain, Size: 631 bytes --]
Hi,
Il 04/11/25 14:50, Zhao Zhili ha scritto:
>> The specification says that if either the numerator or the
>> denominator is zero then the SAR is to be intended unspecified.
>> Internally ffmpeg represents an unspecified SAR as 0/1, while
>> fractions with a zero denominator are not handled properly;
>
> Is there any known issue?
I observed this problem with a bunch of video files provided by game
OddBallers when executed with Wine/Proton. There is some more backstory
on my first submission of this patch last year:
https://ffmpeg.org/pipermail/ffmpeg-devel/2024-July/331835.html
Thanks, Giovanni.
[-- Attachment #1.2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 228 bytes --]
[-- Attachment #2: Type: text/plain, Size: 163 bytes --]
_______________________________________________
ffmpeg-devel mailing list -- ffmpeg-devel@ffmpeg.org
To unsubscribe send an email to ffmpeg-devel-leave@ffmpeg.org
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-11-04 13:59 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-11-04 13:37 [FFmpeg-devel] [PATCH] avcodec/h2645_vui: Interpret a degenerate SAR as unspecified Giovanni Mascellani via ffmpeg-devel
2025-11-04 13:50 ` [FFmpeg-devel] " Zhao Zhili via ffmpeg-devel
2025-11-04 13:58 ` Giovanni Mascellani via ffmpeg-devel
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