From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-15.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 773A0C43381 for ; Wed, 24 Feb 2021 10:19:49 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 00FAE6023C for ; Wed, 24 Feb 2021 10:19:48 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 00FAE6023C Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=linaro.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 710C96B0006; Wed, 24 Feb 2021 05:19:48 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 6C2DC6B006C; Wed, 24 Feb 2021 05:19:48 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 5B0986B006E; Wed, 24 Feb 2021 05:19:48 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0060.hostedemail.com [216.40.44.60]) by kanga.kvack.org (Postfix) with ESMTP id 454AE6B0006 for ; Wed, 24 Feb 2021 05:19:48 -0500 (EST) Received: from smtpin05.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay04.hostedemail.com (Postfix) with ESMTP id 0CF3981ED for ; Wed, 24 Feb 2021 10:19:48 +0000 (UTC) X-FDA: 77852765256.05.775E473 Received: from mail-wr1-f47.google.com (mail-wr1-f47.google.com [209.85.221.47]) by imf14.hostedemail.com (Postfix) with ESMTP id 8D17DC0007C2 for ; Wed, 24 Feb 2021 10:19:40 +0000 (UTC) Received: by mail-wr1-f47.google.com with SMTP id w11so1309213wrr.10 for ; Wed, 24 Feb 2021 02:19:47 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=/FE7tvrvqoJrGxZtO1M2WLOCJzVWjV9STY44PZX27ks=; b=I+hKBBRhc37miRhiK8ZHrqDkDbC9ZQjaR5dVS+zd58oLtjUmKZm5Zq5kbd4+AwzinV L5Mykd0nm3IjEea2Rzw8z3ekuMvJHPInvHCZx/h8DGBqUQooGetyjVlF+7RgyAP8R8hQ mgBlVMqp4d9I1wwMJ7mYi/kTGeFmNrgu9a+43IKP3OYuJ+1N3j2N/z3Y4Wed9txt1qQV YE5Yu0tgHe4NGY6kWQHm/bgOf0NQXzC0aqwOG4C+y0QK0NZCcHJM6aPY6paaRZV5aoBl fG+XXh+JXLPl7e9TwPOy4rAkFYKSXm2aMjZQ50wtP3BngAZEVQIFWHIOI5yBQ9wanzEE VwdQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=/FE7tvrvqoJrGxZtO1M2WLOCJzVWjV9STY44PZX27ks=; b=pv+7pYxd7nZyLlpwwrpHXD/e2Ru2e2utf4yfwUlRvi8XsItCB7WHoDXjnuukWMlNVc cPDcLTZOJYape6Ts3Vhbdyww6xy9VnBkOODul6FoHEmM8HyHj96Eoad7NhnecgvAdFH4 pZZiAKAfbRKVxTtvf7jA2DN0nO+cbUqOjdNhJXHDTPb4lFtcARpIK9MXnQpJI9/j+1DS G3e5SQUvhMu3ieVmzNw95pSHEIHYjlOsy65HxmwLIkjeHrb5k/BICtxeNbn+T+s3PfVI T+FhDeD/JQextlwAUXtGT6Da8jMx5+jWVExsEbBef73Ln3kwp7h+9+q2rorZs6Ag7Ajo DfpQ== X-Gm-Message-State: AOAM530H5WVt770OKMu2Z1WTMDVtZc/mIV9rGD+aFnd5kDC2rx28TMxJ 1NEetOOK68EPA8GxT200Ov6Sgg== X-Google-Smtp-Source: ABdhPJyKndYC691It/7gqXtAE5RbW9Z17Tm2vdDWURKYH/LNKjlcRD8BPcuGIEs1+3EkHAospr4whg== X-Received: by 2002:adf:f941:: with SMTP id q1mr31859042wrr.189.1614161986271; Wed, 24 Feb 2021 02:19:46 -0800 (PST) Received: from myrica ([2001:1715:4e26:a7e0:116c:c27a:3e7f:5eaf]) by smtp.gmail.com with ESMTPSA id v5sm2015023wmh.2.2021.02.24.02.19.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 24 Feb 2021 02:19:45 -0800 (PST) Date: Wed, 24 Feb 2021 11:19:27 +0100 From: Jean-Philippe Brucker To: Fenghua Yu Cc: Joerg Roedel , Lu Baolu , Ashok Raj , Jacob Jun Pan , linux-kernel , iommu@lists.linux-foundation.org, zhangfei.gao@foxmail.com, linux-mm@kvack.org Subject: Re: [PATCH v6 08/12] fork: Clear PASID for new mm Message-ID: References: <1594684087-61184-1-git-send-email-fenghua.yu@intel.com> <1594684087-61184-9-git-send-email-fenghua.yu@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1594684087-61184-9-git-send-email-fenghua.yu@intel.com> X-Rspamd-Server: rspam04 X-Rspamd-Queue-Id: 8D17DC0007C2 X-Stat-Signature: 43njygwdjibjpjz518g54nsbd9y47p8e Received-SPF: none (linaro.org>: No applicable sender policy available) receiver=imf14; identity=mailfrom; envelope-from=""; helo=mail-wr1-f47.google.com; client-ip=209.85.221.47 X-HE-DKIM-Result: pass/pass X-HE-Tag: 1614161980-489192 X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: Hi Fenghua, [Trimmed the Cc list] On Mon, Jul 13, 2020 at 04:48:03PM -0700, Fenghua Yu wrote: > When a new mm is created, its PASID should be cleared, i.e. the PASID is > initialized to its init state 0 on both ARM and X86. I just noticed this patch was dropped in v7, and am wondering whether we could still upstream it. Does x86 need a child with a new address space (!CLONE_VM) to inherit the PASID of the parent? That doesn't make much sense with regard to IOMMU structures - same PASID indexing multiple PGDs? Currently iommu_sva_alloc_pasid() assumes mm->pasid is always initialized to 0 and fails on forked tasks. I'm trying to figure out how to fix this. Could we clear the pasid on fork or does it break the x86 model? Thanks, Jean > > Signed-off-by: Fenghua Yu > Reviewed-by: Tony Luck > --- > v2: > - Add this patch to initialize PASID value for a new mm. > > include/linux/mm_types.h | 2 ++ > kernel/fork.c | 8 ++++++++ > 2 files changed, 10 insertions(+) > > diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h > index d61285cfe027..d60d2ec10881 100644 > --- a/include/linux/mm_types.h > +++ b/include/linux/mm_types.h > @@ -22,6 +22,8 @@ > #endif > #define AT_VECTOR_SIZE (2*(AT_VECTOR_SIZE_ARCH + AT_VECTOR_SIZE_BASE + 1)) > > +/* Initial PASID value is 0. */ > +#define INIT_PASID 0 > > struct address_space; > struct mem_cgroup; > diff --git a/kernel/fork.c b/kernel/fork.c > index 142b23645d82..43b5f112604d 100644 > --- a/kernel/fork.c > +++ b/kernel/fork.c > @@ -1007,6 +1007,13 @@ static void mm_init_owner(struct mm_struct *mm, struct task_struct *p) > #endif > } > > +static void mm_init_pasid(struct mm_struct *mm) > +{ > +#ifdef CONFIG_IOMMU_SUPPORT > + mm->pasid = INIT_PASID; > +#endif > +} > + > static void mm_init_uprobes_state(struct mm_struct *mm) > { > #ifdef CONFIG_UPROBES > @@ -1035,6 +1042,7 @@ static struct mm_struct *mm_init(struct mm_struct *mm, struct task_struct *p, > mm_init_cpumask(mm); > mm_init_aio(mm); > mm_init_owner(mm, p); > + mm_init_pasid(mm); > RCU_INIT_POINTER(mm->exe_file, NULL); > mmu_notifier_subscriptions_init(mm); > init_tlb_flush_pending(mm); > -- > 2.19.1 >