Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp997818ybt; Fri, 19 Jun 2020 21:04:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyFKunZjde7dfyYMWCYtXofdfC0S1fgX/qYHEBNFH4UDLA+L0Ycc/iKPBQOOGajIomsK406 X-Received: by 2002:a17:906:35ca:: with SMTP id p10mr6344785ejb.392.1592625853503; Fri, 19 Jun 2020 21:04:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592625853; cv=none; d=google.com; s=arc-20160816; b=qZi3+BS0wdnOkptDI1k23fpIo/wQ9uXkcPyUQU1o4kQ21j2ehyRwWO8wJ+MtqR4rcS Fyzq7QgoO52U263k0tPWUzRqvFaivalLfeHXDtfTc8ooQ/u25FKP/NljUf0wZvniO2k4 sY2EowWegvIKfzjGu2GyQKBpDEX/Ldq1j+wQmBQCuuaqsvnZpJAWDNmHZ907wnyKbWQi u4BQoc7wcYgr2DRK5oznYRYlKqu5N2K1/EPruH7cVIkURMSVWBLxkRqKpgd2XrnBXy0q PtNFPkYAClwLEy6GqWA6w1+95HQG2pLaOf1VBHa9PA2/pb7HQZgUnIVD2K6wpFvVtPKS CIdA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=e2KQwsDe2Hw0jqLWwa/QRQpNXoT21VO6pza6laPm748=; b=SMgUOv12KsZcNgQzRv3IqY9YDdPcEWpgJ8LXpvgtKncqw/BUlh2UN+g26r5DuWcSTP Rk/fnhmz4J5lCgF+mGu8WwVy6MpugLR9Mi+5YsQqiFsQoOpAOlfJo4E41fSElNQMmpZp onmLJBNazw9XqGYwGgCdDqc5h4lDl2JgONpeou3oTjHGUCpnitq6W0kGt2ddSoHYn2xY MpXl+V9ayvo+Tw7nQWNQ/TP1pgUUvJxlxQ31A18tOSemPkhtf65VapVA9lYVPKTUxftU Mgew+mZD4V6h5iiKuH7kFXrMj3StIW705YyLRBveMCIa8Af+/pLFi2pE55cVvNVIOS4O B87g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yArwRUKI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b5si6987071edz.386.2020.06.19.21.03.51; Fri, 19 Jun 2020 21:04:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yArwRUKI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2395277AbgFSQgW (ORCPT + 99 others); Fri, 19 Jun 2020 12:36:22 -0400 Received: from mail.kernel.org ([198.145.29.99]:41804 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389158AbgFSOtP (ORCPT ); Fri, 19 Jun 2020 10:49:15 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id DD83521835; Fri, 19 Jun 2020 14:49:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592578154; bh=R8GShnj3OVytMBRlD8iKVc+bZrURK3zjJSAhd6W6V9M=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yArwRUKIFdWnOyIerZCpWZ1fNiKePg7LX/HVQN6kqFkrlx15F2LhutAWR4OeXwiuO RmMF29b5qQK98SlIwKDnze6LDg+U/mcnpQQeK/tCc/vEdK1AaVLEz9RIWKedJKEp3+ paTc/sPTkN7S4CiD1RbDID40uIcc8Kepnxw0A/ko= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, teroincn@gmail.com, Richard Guy Briggs , Paul Moore , Sasha Levin Subject: [PATCH 4.14 104/190] audit: fix a net reference leak in audit_list_rules_send() Date: Fri, 19 Jun 2020 16:32:29 +0200 Message-Id: <20200619141638.782540805@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200619141633.446429600@linuxfoundation.org> References: <20200619141633.446429600@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Paul Moore [ Upstream commit 3054d06719079388a543de6adb812638675ad8f5 ] If audit_list_rules_send() fails when trying to create a new thread to send the rules it also fails to cleanup properly, leaking a reference to a net structure. This patch fixes the error patch and renames audit_send_list() to audit_send_list_thread() to better match its cousin, audit_send_reply_thread(). Reported-by: teroincn@gmail.com Reviewed-by: Richard Guy Briggs Signed-off-by: Paul Moore Signed-off-by: Sasha Levin --- kernel/audit.c | 2 +- kernel/audit.h | 2 +- kernel/auditfilter.c | 16 +++++++--------- 3 files changed, 9 insertions(+), 11 deletions(-) diff --git a/kernel/audit.c b/kernel/audit.c index 53224f399038..6faaa908544a 100644 --- a/kernel/audit.c +++ b/kernel/audit.c @@ -853,7 +853,7 @@ main_queue: return 0; } -int audit_send_list(void *_dest) +int audit_send_list_thread(void *_dest) { struct audit_netlink_list *dest = _dest; struct sk_buff *skb; diff --git a/kernel/audit.h b/kernel/audit.h index 9b110ae17ee3..1007773b0b81 100644 --- a/kernel/audit.h +++ b/kernel/audit.h @@ -248,7 +248,7 @@ struct audit_netlink_list { struct sk_buff_head q; }; -int audit_send_list(void *_dest); +int audit_send_list_thread(void *_dest); extern int selinux_audit_rule_update(void); diff --git a/kernel/auditfilter.c b/kernel/auditfilter.c index 16cf396ea738..f26f4cb5d08d 100644 --- a/kernel/auditfilter.c +++ b/kernel/auditfilter.c @@ -1137,11 +1137,8 @@ int audit_rule_change(int type, int seq, void *data, size_t datasz) */ int audit_list_rules_send(struct sk_buff *request_skb, int seq) { - u32 portid = NETLINK_CB(request_skb).portid; - struct net *net = sock_net(NETLINK_CB(request_skb).sk); struct task_struct *tsk; struct audit_netlink_list *dest; - int err = 0; /* We can't just spew out the rules here because we might fill * the available socket buffer space and deadlock waiting for @@ -1149,25 +1146,26 @@ int audit_list_rules_send(struct sk_buff *request_skb, int seq) * happen if we're actually running in the context of auditctl * trying to _send_ the stuff */ - dest = kmalloc(sizeof(struct audit_netlink_list), GFP_KERNEL); + dest = kmalloc(sizeof(*dest), GFP_KERNEL); if (!dest) return -ENOMEM; - dest->net = get_net(net); - dest->portid = portid; + dest->net = get_net(sock_net(NETLINK_CB(request_skb).sk)); + dest->portid = NETLINK_CB(request_skb).portid; skb_queue_head_init(&dest->q); mutex_lock(&audit_filter_mutex); audit_list_rules(seq, &dest->q); mutex_unlock(&audit_filter_mutex); - tsk = kthread_run(audit_send_list, dest, "audit_send_list"); + tsk = kthread_run(audit_send_list_thread, dest, "audit_send_list"); if (IS_ERR(tsk)) { skb_queue_purge(&dest->q); + put_net(dest->net); kfree(dest); - err = PTR_ERR(tsk); + return PTR_ERR(tsk); } - return err; + return 0; } int audit_comparator(u32 left, u32 op, u32 right) -- 2.25.1