From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9A1A22BE03B for ; Sat, 2 May 2026 12:27:05 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777724825; cv=none; b=ZgODw5lRBrrHJbN8hNG5f2DH8zICGW5DNGkCp7aGfxT5OGOfV2k1VgDQfvGnwdkZJAL+XZthCDuO9UQu0498Dkr+wTHef1rCMEWlCvTAdnzZn5fYqMzwHrZzS4lyvvcjmPYNXuxscD6s6H+COPuN1OJS5ajMdINUriOZcBjt8gc= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1777724825; c=relaxed/simple; bh=/spVl180WZp8RJhNvpCzGEQxgmLY7Zczf+qP1YbJsVc=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=VnJHOfj0H5YY6/IT71rh1zmzEKHZEFhtWVT+o2aSkn5VMG24d956fUBaQW4I4qdVUf9uYzdslfCriFdvUj5+Pxt2NEIQqu4wnh5Rc/aPx68SPiBfWWXP3wkKVBQujeSrrELQ0oHzu+MMspCoQSoGHr9iLUUfeRYNK2NnBMYLwZU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=V6EwbM+U; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="V6EwbM+U" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 8D71FC19425; Sat, 2 May 2026 12:27:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1777724825; bh=/spVl180WZp8RJhNvpCzGEQxgmLY7Zczf+qP1YbJsVc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=V6EwbM+UKSXIuhxvKI2U9/FoX8oWmnqu8qBj3G314/ISzJRwcDBVcrv6dUw0wXT8Y s/HYcflWgGLVFkLioEBtoOWfT25qSqVF9IkRwgz2T+sxY5pgUpz1Leyvs2FCNVZo2k TX/W3g6YCVtT9CPNIhPFSwxZja7TUp9Et7ZbVsWpWKZoaYY48u2nRxfVC+BAlUjSmv CFiILLuVzn7ZD8mp+TDPqoB44NzysFD9OQI21ETltzqS3V5Qc9ggP0FOcviXvBpvBG 8xpuUIMDIGjSqLSNL2BTFU75vZQGGnLpetW822PLtNG1z+CgazBKSj1YZICqPXleEs w3nqsNHKiIb+w== From: Sasha Levin To: stable@vger.kernel.org Cc: =?UTF-8?q?Micka=C3=ABl=20Sala=C3=BCn?= , =?UTF-8?q?G=C3=BCnther=20Noack?= , =?UTF-8?q?G=C3=BCnther=20Noack?= , Sasha Levin Subject: [PATCH 7.0.y] selftests/landlock: Fix socket file descriptor leaks in audit helpers Date: Sat, 2 May 2026 08:27:02 -0400 Message-ID: <20260502122702.517486-1-sashal@kernel.org> X-Mailer: git-send-email 2.53.0 In-Reply-To: <2026050112-flakily-uncaring-f2c8@gregkh> References: <2026050112-flakily-uncaring-f2c8@gregkh> Precedence: bulk X-Mailing-List: stable@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit From: Mickaël Salaün [ Upstream commit 9143d790337a0d066c2d632c802f69b981e6c23a ] audit_init() opens a netlink socket and configures it, but leaks the file descriptor if audit_set_status() or setsockopt() fails. Fix this by jumping to an error path that closes the socket before returning. Apply the same fix to audit_init_with_exe_filter(), which leaks the file descriptor from audit_init() if audit_init_filter_exe() or audit_filter_exe() fails, and to audit_cleanup(), which leaks it if audit_init_filter_exe() fails in FIXTURE_TEARDOWN_PARENT(). Cc: Günther Noack Cc: stable@vger.kernel.org Fixes: 6a500b22971c ("selftests/landlock: Add tests for audit flags and domain IDs") Reviewed-by: Günther Noack Link: https://lore.kernel.org/r/20260402192608.1458252-3-mic@digikod.net Signed-off-by: Mickaël Salaün Signed-off-by: Sasha Levin --- tools/testing/selftests/landlock/audit.h | 26 +++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/tools/testing/selftests/landlock/audit.h b/tools/testing/selftests/landlock/audit.h index 44eb433e96661..0007c247cd335 100644 --- a/tools/testing/selftests/landlock/audit.h +++ b/tools/testing/selftests/landlock/audit.h @@ -379,19 +379,25 @@ static int audit_init(void) err = audit_set_status(fd, AUDIT_STATUS_ENABLED, 1); if (err) - return err; + goto err_close; err = audit_set_status(fd, AUDIT_STATUS_PID, getpid()); if (err) - return err; + goto err_close; /* Sets a timeout for negative tests. */ err = setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, &audit_tv_default, sizeof(audit_tv_default)); - if (err) - return -errno; + if (err) { + err = -errno; + goto err_close; + } return fd; + +err_close: + close(fd); + return err; } static int audit_init_filter_exe(struct audit_filter *filter, const char *path) @@ -441,8 +447,10 @@ static int audit_cleanup(int audit_fd, struct audit_filter *filter) filter = &new_filter; err = audit_init_filter_exe(filter, NULL); - if (err) + if (err) { + close(audit_fd); return err; + } } /* Filters might not be in place. */ @@ -468,11 +476,15 @@ static int audit_init_with_exe_filter(struct audit_filter *filter) err = audit_init_filter_exe(filter, NULL); if (err) - return err; + goto err_close; err = audit_filter_exe(fd, filter, AUDIT_ADD_RULE); if (err) - return err; + goto err_close; return fd; + +err_close: + close(fd); + return err; } -- 2.53.0