Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5031665ybv; Mon, 17 Feb 2020 10:47:12 -0800 (PST) X-Google-Smtp-Source: APXvYqx+j+E6+TVez/8GfPb9MvHWCB+EE2qWZA4EydyRN3pb9/2u6GXNnZTBrd+dODHyn+dkI3Kz X-Received: by 2002:aca:d502:: with SMTP id m2mr240620oig.41.1581965232326; Mon, 17 Feb 2020 10:47:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581965232; cv=none; d=google.com; s=arc-20160816; b=i7l3tWKxHCzNa2NGFJv8Hyx1uo5Vnlelmq5exyHhvuQycXFMGLOORgznWltgtxLECf KA9I2gZHB3Pi2/VSNTH/e6Vxfpmj+KXBrF3i62tM0b+086iKLpHWY83XpEPMmuuaeeIZ IMxFU5CIyW//CwZupZy/umDuLnEUMJE53wGynLOPf8TBBlA66vQgb7jI5wmzd+a2eaVH BxPKYkj1hKntCzNTINifgq8Dh5cr53V6sQ3efN6IREeAHJW68+z0Tu/CJUSs929RXiwk IVY8xuc6+ilbMDwDBREkfRMpAKKRzdcs3NSL6eTCeFyl/T/zgq/qx4tKPLb+M/NxQNju yqWA== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=iYn/WApkZknuw8/6G/scxzQls76dRRJn9vUap7y4zFM=; b=O+eO2a/9b0gw4katPxlEI08vc8ob8xE8EJ4tRRnLCv7mk/0ZY5FIQeFIiPrmDkH9+c 8X3VFTeesxmRya2odoiHd6SzLCxodO2iD+M809XZh1TERDbK+YO3RPda/othaeNtAjch RXYG6O6JFGGUua+X/XouEuOPhtNjJl3mZ695ve5AJm54VXQvhJciYgKbBkTsMsUnOiVL j4IiwboKtRLjtHz7XFNp3FMy+IK0HERMBwjbxHOLjzr/K1dRVvoXhC6tPnRhT8v03N08 UlG63i9+3EXol7OdRURkKDVeRa4t03GQ/jMSh05I1KthEbKYTf3600zQd6UEjRIeXEjV iM7g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=iA6UYFah; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w2si567658otq.31.2020.02.17.10.46.47; Mon, 17 Feb 2020 10:47:12 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=iA6UYFah; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729301AbgBQSgy (ORCPT + 99 others); Mon, 17 Feb 2020 13:36:54 -0500 Received: from us-smtp-2.mimecast.com ([205.139.110.61]:37737 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727601AbgBQSgy (ORCPT ); Mon, 17 Feb 2020 13:36:54 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1581964613; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=iYn/WApkZknuw8/6G/scxzQls76dRRJn9vUap7y4zFM=; b=iA6UYFahqLI60BfDIsXilgbE/aK625m5SaS2BWfSOk3Vuc68YH87+8a56bnjWyDlCSYg3y kJAnClsdADzLoeS/VS/nQmkx+NLtcrWOEeYhu8nqOKrJYizk9PEfFyphJpOEefl+F+JEO8 3NswkJfdDnz91sshLRPRdIeCaZlxPHE= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-44--n7DHrG4OeeiK6e-41apXQ-1; Mon, 17 Feb 2020 13:36:45 -0500 X-MC-Unique: -n7DHrG4OeeiK6e-41apXQ-1 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 999F8107ACC4; Mon, 17 Feb 2020 18:36:44 +0000 (UTC) Received: from lithium.redhat.com (ovpn-204-63.brq.redhat.com [10.40.204.63]) by smtp.corp.redhat.com (Postfix) with ESMTP id 3BCB285735; Mon, 17 Feb 2020 18:36:42 +0000 (UTC) From: Giuseppe Scrivano To: linux-kernel@vger.kernel.org Cc: rcu@vger.kernel.org, ebiederm@xmission.com, paulmck@kernel.org, viro@zeniv.linux.org.uk Subject: [PATCH v2] ipc: use a work queue to free_ipc Date: Mon, 17 Feb 2020 19:36:27 +0100 Message-Id: <20200217183627.4099690-1-gscrivan@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org it avoids blocking on synchronize_rcu() in kern_umount(). the code: \#define _GNU_SOURCE \#include \#include \#include \#include int main() { int i; for (i =3D 0; i < 1000; i++) if (unshare (CLONE_NEWIPC) < 0) error (EXIT_FAILURE, errno, "unshare"); } gets from: Command being timed: "./ipc-namespace" User time (seconds): 0.00 System time (seconds): 0.06 Percent of CPU this job got: 0% Elapsed (wall clock) time (h:mm:ss or m:ss): 0:08.05 to: Command being timed: "./ipc-namespace" User time (seconds): 0.00 System time (seconds): 0.02 Percent of CPU this job got: 96% Elapsed (wall clock) time (h:mm:ss or m:ss): 0:00.03 Signed-off-by: Giuseppe Scrivano --- v2: - comment added in free_ipc_ns() v1: https://lkml.org/lkml/2020/2/11/692 include/linux/ipc_namespace.h | 2 ++ ipc/namespace.c | 20 ++++++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/include/linux/ipc_namespace.h b/include/linux/ipc_namespace.= h index c309f43bde45..a06a78c67f19 100644 --- a/include/linux/ipc_namespace.h +++ b/include/linux/ipc_namespace.h @@ -68,6 +68,8 @@ struct ipc_namespace { struct user_namespace *user_ns; struct ucounts *ucounts; =20 + struct llist_node mnt_llist; + struct ns_common ns; } __randomize_layout; =20 diff --git a/ipc/namespace.c b/ipc/namespace.c index b3ca1476ca51..7b9922244891 100644 --- a/ipc/namespace.c +++ b/ipc/namespace.c @@ -117,6 +117,10 @@ void free_ipcs(struct ipc_namespace *ns, struct ipc_= ids *ids, =20 static void free_ipc_ns(struct ipc_namespace *ns) { + /* mq_put_mnt() waits for a grace period as kern_unmount() + * uses synchronize_rcu(). + */ + mq_put_mnt(ns); sem_exit_ns(ns); msg_exit_ns(ns); shm_exit_ns(ns); @@ -127,6 +131,17 @@ static void free_ipc_ns(struct ipc_namespace *ns) kfree(ns); } =20 +static LLIST_HEAD(free_ipc_list); +static void free_ipc(struct work_struct *unused) +{ + struct llist_node *node =3D llist_del_all(&free_ipc_list); + struct ipc_namespace *n, *t; + + llist_for_each_entry_safe(n, t, node, mnt_llist) + free_ipc_ns(n); +} +static DECLARE_WORK(free_ipc_work, free_ipc); + /* * put_ipc_ns - drop a reference to an ipc namespace. * @ns: the namespace to put @@ -148,8 +163,9 @@ void put_ipc_ns(struct ipc_namespace *ns) if (refcount_dec_and_lock(&ns->count, &mq_lock)) { mq_clear_sbinfo(ns); spin_unlock(&mq_lock); - mq_put_mnt(ns); - free_ipc_ns(ns); + + if (llist_add(&ns->mnt_llist, &free_ipc_list)) + schedule_work(&free_ipc_work); } } =20 --=20 2.24.1