From nobody Wed Apr 22 21:08:22 2026 X-Original-To: dev-commits-src-all@mlmmj.nyi.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mlmmj.nyi.freebsd.org (Postfix) with ESMTP id 4g1Bdy4crxz6bL2w for ; Wed, 22 Apr 2026 21:08:22 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256 client-signature RSA-PSS (4096 bits) client-digest SHA256) (Client CN "mxrelay.nyi.freebsd.org", Issuer "R13" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id 4g1Bdy31YYz3khZ for ; Wed, 22 Apr 2026 21:08:22 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1776892102; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=kZPqWQMgucbSJIU5CtSfMynt7wDgpl5gFnPh0KecdlY=; b=twQgmHC97b+jlJCSUmGDKiEWonxlMdb4QFTinUB314TRAM4J6dIafu6ivnxnCWhwix6QBB /Er7dHeE41cC3yAxjx1cx3H4usM3IvjZX9j7q/AudepHvTrDrv1nWLuHAvf4NXLUKl3Utl xi2oJC+Fk4iiK5BkbgIVSluX77IiArmIQf5j2ksM6JjgKhD/KaOhKyNQGI16tr582X5S0K Ch0+frWnVE5RFeKtIya0rfUPaxz8HLML8c1beCcP/SAcZtwZuBAGK9IIq8gLWlt6y1R4Hg 1Kk0wgx3J+vgtbkgPNOiZpe0r7dfY18Z7P/vrzAOIS7StGE3nMxF0Dig4hOuNQ== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1776892102; a=rsa-sha256; cv=none; b=CGd73UuiaATS+I89zRzG+ccYs3zAcKuCNxH9tSauLMzlPlTnIw7Vn3XHPBh16RVtxAFHTB mTwsd/4WrtoVN6DuwRh7TqugdBSsrSAVshqntdS55bJE/g3JD5TiTso7Z2JdDXYiCj9hT/ gfTN/XzDJKbrCUD+r22xYW0RB4XZQp6PznT8QCdyOyumYTld8gjMhQAWrLhMA4cnfp3JSe +6G+rxak/GUmYXjj1E6FpWBOQRy2OAFKzC83QawRQkYa1Sm9TtjWY358/c3G17b0VgAnKZ /xw0UGjqHEaHKr2yIximYmmFix3hiRSyj+1n41Gts6TlBnh13vpJm/PeumndAg== ARC-Authentication-Results: i=1; mx1.freebsd.org; none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1776892102; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=kZPqWQMgucbSJIU5CtSfMynt7wDgpl5gFnPh0KecdlY=; b=lhEkF8HPTXoX1tAjV14drfrr/ut6rFT7D9h14brYgRErpzCWDUio5pNa9OJTnT6uS+DESz BGFQt23u0cnyHbVyHc5kGyRqqDon1UIk7yRJowyNI7lwbhkMo0RxErcfDJrUbUKWdQHdj1 CMetarlg0kXvyEEiQkA04KpIE3RfBzu0f6GeGhSlrqodmes2mbPQ5uFlFgqulndSuhd00F 93xd8sAKOv4bHUoWCoOTPearseWUpytLLN/l6vgFiewyMIOndFoLCCLMOJnn2DOtQdnudV M3rkAVSSjXVQ+fK1YkKmoWQbJZO4Cin7CSThpGbFhN1FOvJcPZq5j+g6TeHLGg== Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) by mxrelay.nyi.freebsd.org (Postfix) with ESMTP id 4g1Bdy2GXJznWs for ; Wed, 22 Apr 2026 21:08:22 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from git (uid 1279) (envelope-from git@FreeBSD.org) id 275ed by gitrepo.freebsd.org (DragonFly Mail Agent v0.13+ on gitrepo.freebsd.org); Wed, 22 Apr 2026 21:08:22 +0000 To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-branches@FreeBSD.org Cc: Jean-=?utf-8?Q?S=C3=A9bast?==?utf-8?Q?ien P=C3=A9?=dron From: Bjoern A. Zeeb Subject: git: 10e515465543 - stable/15 - eventfd: Add refcounting List-Id: Commit messages for all branches of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-all List-Help: List-Post: List-Subscribe: List-Unsubscribe: X-BeenThere: dev-commits-src-all@freebsd.org Sender: owner-dev-commits-src-all@FreeBSD.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: bz X-Git-Repository: src X-Git-Refname: refs/heads/stable/15 X-Git-Reftype: branch X-Git-Commit: 10e5154655435e660a02445bd9899fa17f12103c Auto-Submitted: auto-generated Date: Wed, 22 Apr 2026 21:08:22 +0000 Message-Id: <69e938c6.275ed.2c15b4c1@gitrepo.freebsd.org> The branch stable/15 has been updated by bz: URL: https://cgit.FreeBSD.org/src/commit/?id=10e5154655435e660a02445bd9899fa17f12103c commit 10e5154655435e660a02445bd9899fa17f12103c Author: Jean-Sébastien Pédron AuthorDate: 2025-05-26 17:18:24 +0000 Commit: Bjoern A. Zeeb CommitDate: 2026-04-22 20:56:58 +0000 eventfd: Add refcounting An eventfd file descriptor can be used by drivers such as DRM drivers through linuxkpi. A driver can hold a reference to such a file regardless of the fact it is used by userland or not. This patch introduces a refcount in `struct eventfd`, plus the `eventfd_get()` and `eventfd_put()` functions to acquire and release references. These functions will be used by DRM drivers for instance. This structure is internal to `sys/kern/sys_eventfd.c` and not used anywhere else. Thus it is safe to add a field without breaking anything. Reviewed by: markj Sponsored by: The FreeBSD Foundation Differential Revision: https://reviews.freebsd.org/D50849 (cherry picked from commit 5931649751847cc3ca54255bb767424dcb8a3e97) --- sys/kern/sys_eventfd.c | 30 ++++++++++++++++++++++++++++-- sys/sys/eventfd.h | 4 ++++ 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/sys/kern/sys_eventfd.c b/sys/kern/sys_eventfd.c index 04ed107c933d..433bcb57b2b3 100644 --- a/sys/kern/sys_eventfd.c +++ b/sys/kern/sys_eventfd.c @@ -40,6 +40,7 @@ #include #include #include +#include #include #include #include @@ -102,6 +103,7 @@ struct eventfd { uint32_t efd_flags; struct selinfo efd_sel; struct mtx efd_lock; + unsigned int efd_refcount; }; int @@ -119,6 +121,7 @@ eventfd_create_file(struct thread *td, struct file *fp, uint32_t initval, efd->efd_count = initval; mtx_init(&efd->efd_lock, "eventfd", NULL, MTX_DEF); knlist_init_mtx(&efd->efd_sel.si_note, &efd->efd_lock); + refcount_init(&efd->efd_refcount, 1); fflags = FREAD | FWRITE; if ((flags & EFD_NONBLOCK) != 0) @@ -128,16 +131,39 @@ eventfd_create_file(struct thread *td, struct file *fp, uint32_t initval, return (0); } -static int -eventfd_close(struct file *fp, struct thread *td) +struct eventfd * +eventfd_get(struct file *fp) { struct eventfd *efd; + if (fp->f_data == NULL || fp->f_ops != &eventfdops) + return (NULL); + efd = fp->f_data; + refcount_acquire(&efd->efd_refcount); + + return (efd); +} + +void +eventfd_put(struct eventfd *efd) +{ + if (!refcount_release(&efd->efd_refcount)) + return; + seldrain(&efd->efd_sel); knlist_destroy(&efd->efd_sel.si_note); mtx_destroy(&efd->efd_lock); free(efd, M_EVENTFD); +} + +static int +eventfd_close(struct file *fp, struct thread *td) +{ + struct eventfd *efd; + + efd = fp->f_data; + eventfd_put(efd); return (0); } diff --git a/sys/sys/eventfd.h b/sys/sys/eventfd.h index 0f64483753e5..1f36dbecb92d 100644 --- a/sys/sys/eventfd.h +++ b/sys/sys/eventfd.h @@ -38,8 +38,12 @@ typedef uint64_t eventfd_t; #ifdef _KERNEL +struct eventfd; + int eventfd_create_file(struct thread *td, struct file *fp, uint32_t initval, int flags); +struct eventfd *eventfd_get(struct file *fp); +void eventfd_put(struct eventfd *efd); #else