From: Michael Niedermayer <michael@niedermayer.cc> To: FFmpeg development discussions and patches <ffmpeg-devel@ffmpeg.org> Subject: Re: [FFmpeg-devel] [PATCH v2 5/6] libavutil: Add AVMap Date: Tue, 15 Apr 2025 21:06:31 +0200 Message-ID: <20250415190631.GS4991@pb2> (raw) In-Reply-To: <Z_6pR62oq4act_V1@phare.normalesup.org> [-- Attachment #1.1: Type: text/plain, Size: 1378 bytes --] Hi Nicolas On Tue, Apr 15, 2025 at 08:45:27PM +0200, Nicolas George wrote: > Michael Niedermayer (HE12025-04-15): > > +AVMap *av_map_new(AVMapCompareFunc cmp_keyvalue, AVMapCopyFunc copy, AVMapFreeFunc freef) > > +{ > > + AVMap *s = av_mallocz(sizeof(*s)); > > + if (!s) > > + return NULL; > > Please no. > > The ability to allocate on stack including room for a few values is more > important than any performance enhancement for large maps. Where exactly would that benefit FFmpeg ? Dictionaries generally are used to move stuff aorund, like metadata or options. Or may be used in the future to keep track of some mappings like timestamps to file positions during demuxing or muxing Or maybe codecs/formats lookup from name None of these are confined to a single local function > > > + AVMap *set = av_map_new(our_cmp[settype], NULL, NULL); > > … should be : > > AVMap set = av_map_create(cmp, NULL, NULL); > > or : > > AVMap set; > av_map_init(&set, sizeof(set), cmp, NULL, NULL); i like av_map_new() because "new" is short and sizeof(AVMap) is not public API thx [...] -- Michael GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB Those who would give up essential Liberty, to purchase a little temporary Safety, deserve neither Liberty nor Safety -- Benjamin Franklin [-- Attachment #1.2: signature.asc --] [-- Type: application/pgp-signature, Size: 195 bytes --] [-- Attachment #2: Type: text/plain, Size: 251 bytes --] _______________________________________________ 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:[~2025-04-15 19:06 UTC|newest] Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top 2025-04-15 18:14 [FFmpeg-devel] [PATCH v2 1/6] avutil/tree: av_tree_find2() to also find the first and last elements comparing equal Michael Niedermayer 2025-04-15 18:14 ` [FFmpeg-devel] [PATCH v2 2/6] avutil/tree: Add av_tree_move Michael Niedermayer 2025-04-15 18:14 ` [FFmpeg-devel] [PATCH v2 3/6] avutil/tree: Make av_tree_find2() non recursive Michael Niedermayer 2025-04-15 18:14 ` [FFmpeg-devel] [PATCH v2 4/6] avutil/tree: Make tree_find_next() " Michael Niedermayer 2025-04-15 18:14 ` [FFmpeg-devel] [PATCH v2 5/6] libavutil: Add AVMap Michael Niedermayer 2025-04-15 18:45 ` Nicolas George 2025-04-15 19:06 ` Michael Niedermayer [this message] 2025-04-15 19:14 ` Nicolas George 2025-04-15 21:11 ` Michael Niedermayer 2025-04-15 21:24 ` Nicolas George 2025-04-15 18:14 ` [FFmpeg-devel] [PATCH v2 6/6] [NOT for git] avutil/tests/map: benchmark code Michael Niedermayer
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=20250415190631.GS4991@pb2 \ --to=michael@niedermayer.cc \ --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