From: "Rémi Denis-Courmont" <remi@remlab.net>
To: ffmpeg-devel@ffmpeg.org
Subject: Re: [FFmpeg-devel] [PATCH 2/4] lavc/mpegvideo: use H263DSP dequant function
Date: Sat, 06 Jul 2024 19:47:20 +0300
Message-ID: <3110989.CbtlEUcBR6@basile.remlab.net> (raw)
In-Reply-To: <AS8P250MB0744DBA8C715B876DDC0CCCE8FD82@AS8P250MB0744.EURP250.PROD.OUTLOOK.COM>
Le lauantaina 6. heinäkuuta 2024, 19.20.33 EEST Andreas Rheinhardt a écrit :
> Rémi Denis-Courmont:
> > Le lauantaina 6. heinäkuuta 2024, 18.23.00 EEST Andreas Rheinhardt a écrit
:
> >>> static void dct_unquantize_h263_inter_c(MpegEncContext *s,
> >>>
> >>> int16_t *block, int n, int qscale)
> >>>
> >>> {
> >>>
> >>> - int i, level, qmul, qadd;
> >>> + int qmul = qscale << 1;
> >>> + int qadd = (qscale - 1) | 1;
> >>>
> >>> int nCoeffs;
> >>>
> >>> av_assert2(s->block_last_index[n]>=0);
> >>>
> >>> - qadd = (qscale - 1) | 1;
> >>> - qmul = qscale << 1;
> >>> -
> >>>
> >>> nCoeffs= s->inter_scantable.raster_end[ s->block_last_index[n] ];
> >>>
> >>> -
> >>> - for(i=0; i<=nCoeffs; i++) {
> >>> - level = block[i];
> >>> - if (level) {
> >>> - if (level < 0) {
> >>> - level = level * qmul - qadd;
> >>> - } else {
> >>> - level = level * qmul + qadd;
> >>> - }
> >>> - block[i] = level;
> >>> - }
> >>> - }
> >>> + s->h263dsp.h263_dct_unquantize_inter(block, nCoeffs, qmul, qadd);
> >>
> >> This adds an indirection. I have asked you to actually benchmark this
> >> code (and not only the DSP function you add), but you never did.
> >
> > I already pointed out previously that this is the way this project does
> > DSP
> > code. Certainly it would be nice to hard-code the path when there is only
> > one possible. This is often the case on Armv8 notably, and of course on
> > platforms without optimisations.
> >
> > But that's a general problem way beyond the scope of this patchset. We
> > always add indirect function calls in this sort of situation, and I don't
> > see why I would have duty to benchmark it, so I am going to ignore this.
>
> You have a duty to benchmark it because you add it where it wasn't before.
I don't recall other people benchmarking the indirect branch they've added
previously for other DSP code. Recent examples include VVC and FLAC.
Rightfully so, because there is not really an alternative anyway. Even GNU
IFUNCs and Glibc alternative libraries internally use an indirect branch
(hidden in PLT/GOT), and FFmpeg can't self-patch at load-time like the Linux
kernel does, nor can it generate dynamic PLT entries with direct branches.
Also if an indirect call is unacceptable, then how come the calling code is
itself an indirect call and for abstraction rather than performance.
Your request is completely arbitrary here. Yes, there is already an indirect
call close up, and so? I'm not trying to clean MpegEncContext here, only
trying to add one function to checkasm, RVV and (with James' work) post-MMX
x86.
Lastly, you don't even specify what benchmark to run. Comparing something
against nothing is, as my manager would say, pointless, since the relative
overhead ought to be an approximation of infinity (in practice, you end up
measuring the overhead of the benchmarking code instead).
--
Rémi Denis-Courmont
http://www.remlab.net/
_______________________________________________
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:[~2024-07-06 16:47 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-07-01 19:13 [FFmpeg-devel] [PATCH 1/4] lavc/h263dsp: add DCT dequantisation functions Rémi Denis-Courmont
2024-07-01 19:13 ` [FFmpeg-devel] [PATCH 2/4] lavc/mpegvideo: use H263DSP dequant function Rémi Denis-Courmont
2024-07-06 15:23 ` Andreas Rheinhardt
2024-07-06 16:10 ` Rémi Denis-Courmont
2024-07-06 16:20 ` Andreas Rheinhardt
2024-07-06 16:47 ` Rémi Denis-Courmont [this message]
2024-07-06 18:27 ` Andreas Rheinhardt
2024-07-01 19:13 ` [FFmpeg-devel] [PATCH 3/4] checkasm/h263dsp: test dct_unquantize_{intra, inter} Rémi Denis-Courmont
2024-07-06 19:10 ` Andreas Rheinhardt
2024-07-01 19:13 ` [FFmpeg-devel] [PATCH 4/4] lavc/h263dsp: R-V V " Rémi Denis-Courmont
2024-07-06 10:54 ` [FFmpeg-devel] [PATCH 1/4] lavc/h263dsp: add DCT dequantisation functions Rémi Denis-Courmont
2024-07-06 15:17 ` Andreas Rheinhardt
2024-07-06 16:10 ` Rémi Denis-Courmont
2024-07-06 16:19 ` Andreas Rheinhardt
2024-07-06 17:28 ` Rémi Denis-Courmont
2024-07-06 18:23 ` Andreas Rheinhardt
-- strict thread matches above, loose matches on Subject: below --
2024-06-12 4:47 [FFmpeg-devel] [PATCHv5 " Rémi Denis-Courmont
2024-06-12 4:47 ` [FFmpeg-devel] [PATCH 2/4] lavc/mpegvideo: use H263DSP dequant function Rémi Denis-Courmont
2024-06-14 14:33 ` James Almer
2024-06-14 14:45 ` Rémi Denis-Courmont
2024-06-14 15:11 ` Rémi Denis-Courmont
2024-06-14 15:41 ` James Almer
2024-06-14 19:03 ` Rémi Denis-Courmont
2024-06-09 16:23 [FFmpeg-devel] [PATCHv3 1/4] lavc/h263dsp: add DCT dequantisation functions Rémi Denis-Courmont
2024-06-09 16:23 ` [FFmpeg-devel] [PATCH 2/4] lavc/mpegvideo: use H263DSP dequant function Rémi Denis-Courmont
2024-06-10 11:41 ` Michael Niedermayer
2024-06-10 12:14 ` Rémi Denis-Courmont
2024-06-10 12:32 ` Michael Niedermayer
2024-06-09 9:27 [FFmpeg-devel] [PATCHv2 1/4] lavc/h263dsp: add DCT dequantisation function Rémi Denis-Courmont
2024-06-09 9:27 ` [FFmpeg-devel] [PATCH 2/4] lavc/mpegvideo: use H263DSP dequant function Rémi Denis-Courmont
2024-06-09 16:13 ` Andreas Rheinhardt
2024-06-09 16:39 ` Rémi Denis-Courmont
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=3110989.CbtlEUcBR6@basile.remlab.net \
--to=remi@remlab.net \
--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