From nobody Fri Aug 25 14:47:02 2023 X-Original-To: dev-commits-src-main@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 4RXN8659Kpz4rPgD; Fri, 25 Aug 2023 14:47:02 +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 "R3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 4RXN864XHYz4dsZ; Fri, 25 Aug 2023 14:47:02 +0000 (UTC) (envelope-from git@FreeBSD.org) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1692974822; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=t0rUxXVOy0ZaS3dqbwYNYXz/3SGNqWEvnD5nr4URRIQ=; b=l4+MxqpvMmjRx9B5I/N/JcR4otkUdNB1iNeTHpAFk2A5ocir0efumsTVxIsK/zSLKW9Cxw WNi7CX262rj1vTMQZiXLq8Ha+HIMbF10ffi0FJU+FlkwBktAaA6bUAyJh91wsTDQZ+gofX 6Kil/HouVGsHMLhgpjb/wOJ+jLjxtokhSy+kftdzeahQO7fZMSbSYWesLvP9NaSY/ByMLD 02rrdX1yxu541F4Qx0UBzMY6koNAK1K5N1DHTewovLFsyAKvoyiOmmu24MiD/GtgZXowxa JY/Uk4JYxl+d65vsyv3TgzdmsmGjWBDrGJNBldguapFaJw3qzfGPeZBIm3W3RQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=freebsd.org; s=dkim; t=1692974822; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding; bh=t0rUxXVOy0ZaS3dqbwYNYXz/3SGNqWEvnD5nr4URRIQ=; b=dfY80rvMapmFocX+rHnIWLjus4nJjWKMA1L6HFzeSqmzpFUjGC+cIgkApdcVzOIpPqt1BW dCEYXZFJHFNelpifOj7NzzCXzZZ23IzZU8jn/nuf1YZ5LDKi/WtjML7B7pqhr5vKCIVXv1 h0JDRwNN9m7j3hn2KtQrZ/n9mePNHcVuF9P2oprhkh62ilUTBJbhUgCjpLj/pg/LuFXKqV cYfH7gqihKwSmMLmGu5SmvxUOgPurOs8DYdNTP6aRls7LYKpJ1oszKt8cGhetI+IrIv2vl IckK8z+kaNSMRTQpOi8e3Sa7Ll19U2kVvakDDqhFF5Q/Yu76ESJOA1MIhdM52g== ARC-Seal: i=1; s=dkim; d=freebsd.org; t=1692974822; a=rsa-sha256; cv=none; b=U9QscjK19B+jGPumd0vUI9Iw8zoYsAO2wZNzCyvE/o7BlMjWN6iqpuRDGC0ADsfQXw4PbE YLpxSYCa6jfyHgcjCVeQVYz8PR2al9nLe7vqNRkzFDFPiNqwaRyvkN5eIHXDVvMnFi4iWQ cxmOE0Y6VuC6yo5aLcJXo1qNXUSz4TI5P3xoayZfHtjRcf+ReU8wJMPEHVoMFvWl5/OVZZ UPD25345kpCO0snvNnGgw7qavM469V9fVGQjRiQUYfxYeC3sH9CX0My+lC6TMm6GoGSnRY 6z1IZ2p4KOdtdd24z5Cmy6+2XFxz36JJq23UeF8WirOlyRzOG4yqlvph9gjrDA== ARC-Authentication-Results: i=1; mx1.freebsd.org; none Received: from gitrepo.freebsd.org (gitrepo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:5]) (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 did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 4RXN863T7gz1C4V; Fri, 25 Aug 2023 14:47:02 +0000 (UTC) (envelope-from git@FreeBSD.org) Received: from gitrepo.freebsd.org ([127.0.1.44]) by gitrepo.freebsd.org (8.17.1/8.17.1) with ESMTP id 37PEl2gt018655; Fri, 25 Aug 2023 14:47:02 GMT (envelope-from git@gitrepo.freebsd.org) Received: (from git@localhost) by gitrepo.freebsd.org (8.17.1/8.17.1/Submit) id 37PEl2gk018652; Fri, 25 Aug 2023 14:47:02 GMT (envelope-from git) Date: Fri, 25 Aug 2023 14:47:02 GMT Message-Id: <202308251447.37PEl2gk018652@gitrepo.freebsd.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org From: Mateusz Guzik Subject: git: 02f534b57f84 - main - timerfd: fix up a memory leak and missing locking List-Id: Commit messages for the main branch of the src repository List-Archive: https://lists.freebsd.org/archives/dev-commits-src-main List-Help: List-Post: List-Subscribe: List-Unsubscribe: Sender: owner-dev-commits-src-main@freebsd.org X-BeenThere: dev-commits-src-main@freebsd.org MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Git-Committer: mjg X-Git-Repository: src X-Git-Refname: refs/heads/main X-Git-Reftype: branch X-Git-Commit: 02f534b57f84d6f4f97c337b05b383c8b3aaf18c Auto-Submitted: auto-generated The branch main has been updated by mjg: URL: https://cgit.FreeBSD.org/src/commit/?id=02f534b57f84d6f4f97c337b05b383c8b3aaf18c commit 02f534b57f84d6f4f97c337b05b383c8b3aaf18c Author: Mateusz Guzik AuthorDate: 2023-08-25 14:21:39 +0000 Commit: Mateusz Guzik CommitDate: 2023-08-25 14:46:48 +0000 timerfd: fix up a memory leak and missing locking timerfd01 from ltp passes (and some other don't), but none of the tests crash the kernel. This is a bare minimum patch to fix up the immediate regression. Reported by: yasu --- sys/kern/sys_timerfd.c | 31 +++++++++++++++++++++---------- 1 file changed, 21 insertions(+), 10 deletions(-) diff --git a/sys/kern/sys_timerfd.c b/sys/kern/sys_timerfd.c index 6948fa059b8c..2bf2a05c443c 100644 --- a/sys/kern/sys_timerfd.c +++ b/sys/kern/sys_timerfd.c @@ -43,6 +43,7 @@ #include #include #include +#include #include #include #include @@ -59,7 +60,11 @@ #endif static MALLOC_DEFINE(M_TIMERFD, "timerfd", "timerfd structures"); -static LIST_HEAD(, timerfd) timerfd_head; + +static struct sx timerfd_list_lock; +static LIST_HEAD(, timerfd) timerfd_list; +SX_SYSINIT(timerfd, &timerfd_list_lock, "timerfd_list_lock"); + static struct unrhdr64 tfdino_unr; #define TFD_NOJUMP 0 /* Realtime clock has not jumped. */ @@ -125,7 +130,8 @@ timerfd_jumped(void) struct timespec boottime, diff; timerfd_getboottime(&boottime); - LIST_FOREACH(tfd, &timerfd_head, entry) { + sx_xlock(&timerfd_list_lock); + LIST_FOREACH(tfd, &timerfd_list, entry) { mtx_lock(&tfd->tfd_lock); if (tfd->tfd_clockid != CLOCK_REALTIME || (tfd->tfd_timflags & TFD_TIMER_ABSTIME) == 0 || @@ -160,6 +166,7 @@ timerfd_jumped(void) tfd->tfd_boottim = boottime; mtx_unlock(&tfd->tfd_lock); } + sx_xunlock(&timerfd_list_lock); } static int @@ -314,11 +321,14 @@ timerfd_close(struct file *fp, struct thread *td) { struct timerfd *tfd = fp->f_data; + sx_xlock(&timerfd_list_lock); + LIST_REMOVE(tfd, entry); + sx_xunlock(&timerfd_list_lock); + callout_drain(&tfd->tfd_callout); seldrain(&tfd->tfd_sel); knlist_destroy(&tfd->tfd_sel.si_note); mtx_destroy(&tfd->tfd_lock); - LIST_REMOVE(tfd, entry); free(tfd, M_TIMERFD); fp->f_ops = &badfileops; @@ -420,9 +430,11 @@ kern_timerfd_create(struct thread *td, int clockid, int flags) if ((flags & TFD_CLOEXEC) != 0) fflags |= O_CLOEXEC; + error = falloc(td, &fp, &fd, fflags); + if (error != 0) + return (error); + tfd = malloc(sizeof(*tfd), M_TIMERFD, M_WAITOK | M_ZERO); - if (tfd == NULL) - return (ENOMEM); tfd->tfd_clockid = (clockid_t)clockid; tfd->tfd_flags = flags; tfd->tfd_ino = alloc_unr64(&tfdino_unr); @@ -431,16 +443,15 @@ kern_timerfd_create(struct thread *td, int clockid, int flags) knlist_init_mtx(&tfd->tfd_sel.si_note, &tfd->tfd_lock); timerfd_getboottime(&tfd->tfd_boottim); getnanotime(&tfd->tfd_birthtim); - LIST_INSERT_HEAD(&timerfd_head, tfd, entry); + sx_xlock(&timerfd_list_lock); + LIST_INSERT_HEAD(&timerfd_list, tfd, entry); + sx_xunlock(&timerfd_list_lock); - error = falloc(td, &fp, &fd, fflags); - if (error != 0) - return (error); fflags = FREAD; if ((flags & TFD_NONBLOCK) != 0) fflags |= FNONBLOCK; - finit(fp, fflags, DTYPE_TIMERFD, tfd, &timerfdops); + fdrop(fp, td); td->td_retval[0] = fd;