Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5187219ybv; Tue, 11 Feb 2020 10:48:44 -0800 (PST) X-Google-Smtp-Source: APXvYqzy6/SLfjgfDEVR/qMkg72oCvi8wzm5PP5zquRMakMtUVyLtFirkb9og/c6unP1Lij/mAia X-Received: by 2002:a05:6830:1608:: with SMTP id g8mr6010198otr.169.1581446924458; Tue, 11 Feb 2020 10:48:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581446924; cv=none; d=google.com; s=arc-20160816; b=PnF4vR1t+SwqfLaFIIecBkZLnyzoQ4N6F2Oe6FOjjKkvnG5T7d0wG83qVPNeO/IyZ1 FucbWXHQILCvAGYxYruIqXevV3G0eWWs6Wo4hIzrBpLvspBFSugLNbU8yBgCCsgwzYFb jllYrlw5+Nw2vTx/HVkGL8JeH3EJD6xr6wBTRd7PiZLhDSNTLlUBgibcpnplBRvxDAxi TeAYlhaPvDp0am/qDVDVA0CVsNh865c1Uj3estBQWo/tSCzopSUopnSxaKDBNCgBZRbB 8c/tRLjPnDcKK9TxxXIFzPkCMOEJdeyj9wCoQ2l1JUhSMH9MquRWHFSOSsufd8EhYsUI L7AA== 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=W0ZDjuaIZ1KLsnFDXhfjcN6b+4tlT6PGYmx69L4Q8Yg=; b=G/qUeE6y+5elu8On1AAwatmGqjXbnGTodrET63nfdMfvZu0ZkqVeuvyEF+UnMm5a49 R7TUV7d+pEo8pag7nE6obRRhvmuailBAjfMGUB3nGdxxURqAV0oyN7I20GI1wOFn6xHt DaQlz46qV1BxmFyIO5Cy+aysQHm+GOrT1ykraFkCjSR1eHnZ5E/ne43Gr916L2w7Q3oT t/ZW4j9SsvyeKh2KwwXRf5MRkKwmItlRM1yU7eOCwYg4CBg7qojxbBtg0xdjbswQJXbg cZFwN7JO7wjdtbi9YXr4RlClW+45Mc9X/fcyY6dioX4WK37Jzk+96FWXvOVJaAo6J/u5 dFTA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="PCzzM/8k"; 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 e1si2228951otr.8.2020.02.11.10.48.32; Tue, 11 Feb 2020 10:48:44 -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="PCzzM/8k"; 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 S1729823AbgBKQY2 (ORCPT + 99 others); Tue, 11 Feb 2020 11:24:28 -0500 Received: from us-smtp-delivery-1.mimecast.com ([207.211.31.120]:21133 "EHLO us-smtp-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727722AbgBKQY1 (ORCPT ); Tue, 11 Feb 2020 11:24:27 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1581438266; 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=W0ZDjuaIZ1KLsnFDXhfjcN6b+4tlT6PGYmx69L4Q8Yg=; b=PCzzM/8kQ/YV2yJT8Rt4CFCs3meBEOD1tAdMZo2XntNWViZM/dPMcMEAicoPxGsNxigc1T k3mxWd83JzSdrpAVon85BriDyORsUFfQiJZb4XNgPSqyuUnCxeIaC5bOPWs2xyItq9H7Ru gc3BZdhBIpZr4n926V6yv+RnMkeiHjU= 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-93-IyBcJEbxMLGWlODOxC7_dA-1; Tue, 11 Feb 2020 11:24:25 -0500 X-MC-Unique: IyBcJEbxMLGWlODOxC7_dA-1 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 2B4A1107ACC4; Tue, 11 Feb 2020 16:24:24 +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 9889A26FB0; Tue, 11 Feb 2020 16:24:22 +0000 (UTC) From: Giuseppe Scrivano To: linux-kernel@vger.kernel.org Cc: rcu@vger.kernel.org, ebiederm@xmission.com, paulmck@kernel.org Subject: [PATCH] ipc: use a work queue to free_ipc Date: Tue, 11 Feb 2020 17:24:08 +0100 Message-Id: <20200211162408.2194037-1-gscrivan@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 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 --- include/linux/ipc_namespace.h | 2 ++ ipc/namespace.c | 17 +++++++++++++++-- 2 files changed, 17 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..37d27e1b807a 100644 --- a/ipc/namespace.c +++ b/ipc/namespace.c @@ -117,6 +117,7 @@ void free_ipcs(struct ipc_namespace *ns, struct ipc_i= ds *ids, =20 static void free_ipc_ns(struct ipc_namespace *ns) { + mq_put_mnt(ns); sem_exit_ns(ns); msg_exit_ns(ns); shm_exit_ns(ns); @@ -127,6 +128,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 +160,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