Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp1250734pxx; Fri, 30 Oct 2020 05:58:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzXZbMhW7Nr2DsqAmvPZ/lyCJnewd+7uJ6A89O+E8BHqH15Ib+KXjR8sFAdkiL7cglk93Et X-Received: by 2002:a17:906:5402:: with SMTP id q2mr2288533ejo.316.1604062730986; Fri, 30 Oct 2020 05:58:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1604062730; cv=none; d=google.com; s=arc-20160816; b=JoSJm1JZ8hw9TRqVvhtSsmzRLeFj1ZK7TDBIYJ10oNRSEdLmwmL9R4ruP3B9J73cOK nfAM1k9KdAuXdjdijnvdGd7ksmrJnfMSooLog/yqZ8sC6v6Gw3ad9Ej4e4I7Vib1IGeK eEq/Nkz3m4y8dXfyOSWu9KCaJWOzQ9H54FVwmvw2/lIQbCMG/Kj4yPhgdduLoAfnNqO6 WCMq+/UHZJdGBDn62QACh6+n4bChX9ph7fTnRjo3gE3Krg5nWH//QrYSOsbgCCIbMM+2 P/QM977E1N7U2V/Aqrbs8DW5cUsKMXTmTKNzRWXh3J+QLrHk0JinHcYXItyg056ovQph u0tA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject:cc:ironport-sdr:ironport-sdr; bh=5g44TDRgMSWA9idk/L5HVSqVrJ6Ee5Z5NGqt0crcoKg=; b=FBrA3ac9bel64G3vWVddNwcNySXn5p27xjOJ8pBiPLx47FXRQSwD1rFFzrb/Sidrtk hlrupaP9AoRnkbosKkF3kNYKyhH/hf20WUOydKbh48DXamgv+MhDSWuijk+BaEHMFDxy 2whAGKE2KnoNHcsYFFNYZ8doscBc4sieJyjWCJNb6cpnGwneoEoPMhOGv8z3RTcypLxT wG0o02ShLvaua64/TcnzxFzadj6eekNM+V9G623vAcbcK30GpQGDen0dKRp9SKVRHEJ9 xVZDXZ79i6hCGD8rI+CD9qifBfkqBt/5ewPc0wAPDWDP2HxCCOVlG/18/f0FCQslP5jj gSzg== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o3si4465469ejn.637.2020.10.30.05.58.27; Fri, 30 Oct 2020 05:58:50 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726307AbgJ3MzD (ORCPT + 99 others); Fri, 30 Oct 2020 08:55:03 -0400 Received: from mga09.intel.com ([134.134.136.24]:41701 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725834AbgJ3MzC (ORCPT ); Fri, 30 Oct 2020 08:55:02 -0400 IronPort-SDR: 8g4/bP29pOJTW2/7tWSTB9SrHOzJdcjcK/414CA89c5TUzBMZ0bB9D2Vuk7H4D2pgIfCoJCJ7i kLjy2rNoklqg== X-IronPort-AV: E=McAfee;i="6000,8403,9789"; a="168730382" X-IronPort-AV: E=Sophos;i="5.77,433,1596524400"; d="scan'208";a="168730382" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga102.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 30 Oct 2020 05:55:01 -0700 IronPort-SDR: EQEJIWfEwF9HnjLzf2NvqY/yF+Agy3SzVDSC7NzNZ1QYd5tQlCOS0evb1dYdDAnpIcJJ8EI9ba n1f5Ha+xYAiw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,433,1596524400"; d="scan'208";a="425338716" Received: from allen-box.sh.intel.com (HELO [10.239.159.139]) ([10.239.159.139]) by fmsmga001.fm.intel.com with ESMTP; 30 Oct 2020 05:54:56 -0700 Cc: baolu.lu@linux.intel.com, iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org, yi.l.liu@intel.com, jacob.jun.pan@linux.intel.com Subject: Re: [PATCH v2 1/2] iommu/vt-d: Fix sid not set issue in intel_svm_bind_gpasid() To: Yi Sun , joro@8bytes.org, dwmw2@infradead.org, jean-philippe@linaro.org References: <1604025444-6954-1-git-send-email-yi.y.sun@linux.intel.com> <1604025444-6954-2-git-send-email-yi.y.sun@linux.intel.com> From: Lu Baolu Message-ID: Date: Fri, 30 Oct 2020 20:48:07 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <1604025444-6954-2-git-send-email-yi.y.sun@linux.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/30/20 10:37 AM, Yi Sun wrote: > From: Liu Yi L > > Should get correct sid and set it into sdev. Because we execute > 'sdev->sid != req->rid' in the loop of prq_event_thread(). > > Fixes: eb8d93ea3c1d ("iommu/vt-d: Report page request faults for guest SVA") > Signed-off-by: Liu Yi L > Signed-off-by: Yi Sun Cc: stable@ver.kernel.org Acked-by: Lu Baolu Best regards, baolu > --- > drivers/iommu/intel/svm.c | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/drivers/iommu/intel/svm.c b/drivers/iommu/intel/svm.c > index f1861fa..7584669 100644 > --- a/drivers/iommu/intel/svm.c > +++ b/drivers/iommu/intel/svm.c > @@ -279,6 +279,7 @@ int intel_svm_bind_gpasid(struct iommu_domain *domain, struct device *dev, > struct intel_iommu *iommu = device_to_iommu(dev, NULL, NULL); > struct intel_svm_dev *sdev = NULL; > struct dmar_domain *dmar_domain; > + struct device_domain_info *info; > struct intel_svm *svm = NULL; > int ret = 0; > > @@ -310,6 +311,10 @@ int intel_svm_bind_gpasid(struct iommu_domain *domain, struct device *dev, > if (data->hpasid <= 0 || data->hpasid >= PASID_MAX) > return -EINVAL; > > + info = get_domain_info(dev); > + if (!info) > + return -EINVAL; > + > dmar_domain = to_dmar_domain(domain); > > mutex_lock(&pasid_mutex); > @@ -357,6 +362,7 @@ int intel_svm_bind_gpasid(struct iommu_domain *domain, struct device *dev, > goto out; > } > sdev->dev = dev; > + sdev->sid = PCI_DEVID(info->bus, info->devfn); > > /* Only count users if device has aux domains */ > if (iommu_dev_feature_enabled(dev, IOMMU_DEV_FEAT_AUX)) >