Git Inbox Mirror of the ffmpeg-devel mailing list - see https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
 help / color / mirror / Atom feed
* [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