Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2458786pxb; Fri, 17 Sep 2021 10:10:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzp9QbC8DXUqUlsio4R5a9+ZuaLM6lIpHp0aRyka11oiCXhj5WUtfC2McwgDzZyvKuEJh1s X-Received: by 2002:a17:907:785a:: with SMTP id lb26mr13715776ejc.77.1631898628374; Fri, 17 Sep 2021 10:10:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631898628; cv=none; d=google.com; s=arc-20160816; b=slZ62yYulqQ2ecGyB9qSaPUh8jlT6bS/cpDoIZ8yj3Xh8WGLqNPQL5Hx5InZZhgUG2 qpHonJ9ySs+a+Wk5wWC6MWRtEmkZwp736jgg3Iik+PpYzgpSaAUmnpYBQjkEVAF+8eLC EGbqy1C+gFUDT+ZalCm0F4dm83+5COqtoSEQ9pc+wSbHLfpAQHkugLrQLqZp1UWFmFyt ZRAwJVmmVucn1lErGHkyGv12XPdivAEf5pBHc707TXayKC7wV/xsvV4P/lSuiXQ6iqDm LlPTtxxEyD+EFVgkWD74kY3mk1MceFYkYZS1IjOfdbUjGjnWZtC46pXC85ZHfRM7bEqg Cg3Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=KAOT1QriVAB4eECc9vz5PA1mRndKDvWQNMUrIEYWTzY=; b=YWIaXiSqnIvmaeVs17WofWcITUYFKE9n9alxQYQsXlJpZRXX88qQOURjfJWf34KXGq +exlDTksEnevB9uaa9q4vYUy1XRI4i9gDI4ZqUUneSzGBR7of9X0uv49OLc0lAZTAjT6 /RkIfdZ7nGe3OD58C8xP7r5CohAvidjUlvAagdmywgYJ6tPYIKfvQRFSLf4IgFxBDUXr EKJJPHwPXxKLv/qwRKtpLAKHQusLiaMt5iUexvWZHbj8LPi9dJgrYsf4QNoFddqNK8mm bl7ynd0xYJuZ/u9hnN9sunUvjxTBp7/Wk+6mUoerlwoMSToFKZO430glZmqFL+UAzVyP iW2w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=jCZORZkl; 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 t26si7277237eds.588.2021.09.17.10.09.56; Fri, 17 Sep 2021 10:10:28 -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=@infradead.org header.s=casper.20170209 header.b=jCZORZkl; 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 S244928AbhIQGEW (ORCPT + 99 others); Fri, 17 Sep 2021 02:04:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33078 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232726AbhIQGEV (ORCPT ); Fri, 17 Sep 2021 02:04:21 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 575B5C061574 for ; Thu, 16 Sep 2021 23:03:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=KAOT1QriVAB4eECc9vz5PA1mRndKDvWQNMUrIEYWTzY=; b=jCZORZklm63UqwMLJXpjQ2dudy DYOj986Ojkr/OVt9ajFXRE8UE3zvbrF2FnBbfnN2JiljfGCOl+cxXH07SwrL8oFywRMkUiVnDKg5x CoL+AHQMfH3sOyqhCz5sIKvyTSE4EGUMdPBzEjoRafaG8YssbtlAmPZMgMvyKetgiFMo8NvCRMe8c MqvV8YtiHzSGESvrBSad03r3TxJhYuDpE1UeJdpK4M3zdNx17K33n9YRHxYD1CRuKOv5emRrZFKeH xYYX/FC+qRm4F9rWKjvBDbm6Ul2KYDBWS4CaVGpEH7pkH3dCR05nP0Jf5ITd0eNywEnUxBzvq72cj VDAh08BQ==; Received: from hch by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1mR6vL-00HYMi-IS; Fri, 17 Sep 2021 06:01:06 +0000 Date: Fri, 17 Sep 2021 07:00:35 +0100 From: Christoph Hellwig To: Mike Christie Cc: stefanha@redhat.com, jasowang@redhat.com, mst@redhat.com, sgarzare@redhat.com, virtualization@lists.linux-foundation.org, christian.brauner@ubuntu.com, axboe@kernel.dk, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/8] fork: add helper to clone a process Message-ID: References: <20210916212051.6918-1-michael.christie@oracle.com> <20210916212051.6918-2-michael.christie@oracle.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210916212051.6918-2-michael.christie@oracle.com> X-SRS-Rewrite: SMTP reverse-path rewritten from by casper.infradead.org. See http://www.infradead.org/rpr.html Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Sep 16, 2021 at 04:20:44PM -0500, Mike Christie wrote: > The vhost layer has similar requirements as io_uring where its worker > threads need to access the userspace thread's memory, want to inherit the > parents's cgroups and namespaces, and be checked against the parent's > RLIMITs. Right now, the vhost layer uses the kthread API which has > kthread_use_mm for mem access, and those threads can use > cgroup_attach_task_all for v1 cgroups, but there are no helpers for the > other items. > > This adds a helper to clone a process so we can inherit everything we > want in one call. It's a more generic version of create_io_thread which > will be used by the vhost layer and io_uring in later patches in this set. > > This patch also exports __set_task_comm and wake_up_new_task which is > needed by modules to use the new helper. io_uring calls these functions > already but its always built into the kernel so was not needed before. Can you build proper APIs please? e.g. the set_task_comm users generally want a printf-like varargs caling conventions. I'd also much prefer to hide as much as possible in the actual helper. That is build a helper that gets the name, a flag to ignore the singals etc instead of exporting all these random low-level helpers.