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