Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp746712ybt; Fri, 26 Jun 2020 10:31:23 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyUenJNUMJsuPwyLtlj5cXGkkxfOL3tfS8InfBkbF+NUVhVxWXPOGpx2Pl2kkD48nBSa+Sx X-Received: by 2002:aa7:d297:: with SMTP id w23mr4276496edq.49.1593192682933; Fri, 26 Jun 2020 10:31:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593192682; cv=none; d=google.com; s=arc-20160816; b=baX53M1iU2zOsx67MvhQ75OKy8A9rYe5Gzg+3GsLTuU923kfkfOSg9eSrpnJAoMgu1 SQFGi7awwoVIwFeKZSnKNZsO9y7GcTqobm1yGtZ+NFGIvrBCXEG95wGPcsW3di/eC2Hc SMGv3rL9/dd/qMVgWbrWHPZyLl40SD6Kvcpu6c6cSP8STxwK3cto9QFuYgkwIyK6HT57 HKxn7nSIHWpsXa/jcOaLixNUIaW8oZMFgFefjHwMhLBfy7ZBF5bhGJAb6Vo8bwEkqfHV 6Lt0fmMXmO59lmFcAQkb4s3e0mGoUHVDOpR5w1oH+bXBirT/oMJc53xxNX9i3dQlLjZR XG/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-transfer-encoding :mime-version:message-id:date:subject:cc:to:from; bh=+jL8198tCi4VPutVCs4yXHE2/yX1fXK0+ZzD5egdp4w=; b=s3LmKiFWaiXXSjQAWo4O1LqXoLSQq7hHnc+a5wAdXf5h9JKvnIwV2eDGKh9ffUzW2s IbUsh8TNEy/e+x+8Y7orRtqpJT+St5oN5HOsH3jVOuc/KIcf8JnJWICrIunAoNTkPiRM wlcNRXfkR4QRY7Q7qRtAMxKo/r6tI4TSvvMj4/suQ5L6zgtAIDKfB/s+tWJGOKY05ekI cnTxD4zyyODt1AEueXH/QbVI6LRy6P/qwh9v304zWsdWEBILL6wC3KU3v+j+1xya9VEv 8I0XtAt3vs/dZhRCTGn4TcCT+Jnl/PC9zppD3ZPQ7cOCbczsPj/uJsdVgz2GxPs9Huqo 1/hA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=dSKhZ+J1; 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=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v20si12258115ejx.754.2020.06.26.10.30.59; Fri, 26 Jun 2020 10:31:22 -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=@nvidia.com header.s=n1 header.b=dSKhZ+J1; 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=pass (p=NONE sp=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726631AbgFZR0l (ORCPT + 99 others); Fri, 26 Jun 2020 13:26:41 -0400 Received: from hqnvemgate26.nvidia.com ([216.228.121.65]:9996 "EHLO hqnvemgate26.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725833AbgFZR0l (ORCPT ); Fri, 26 Jun 2020 13:26:41 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate26.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Fri, 26 Jun 2020 10:26:28 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Fri, 26 Jun 2020 10:26:41 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Fri, 26 Jun 2020 10:26:41 -0700 Received: from HQMAIL107.nvidia.com (172.20.187.13) by HQMAIL111.nvidia.com (172.20.187.18) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Fri, 26 Jun 2020 17:26:31 +0000 Received: from rnnvemgw01.nvidia.com (10.128.109.123) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3 via Frontend Transport; Fri, 26 Jun 2020 17:26:31 +0000 Received: from rcampbell-dev.nvidia.com (Not Verified[10.110.48.66]) by rnnvemgw01.nvidia.com with Trustwave SEG (v7,5,8,10121) id ; Fri, 26 Jun 2020 10:26:30 -0700 From: Ralph Campbell To: , CC: Jerome Glisse , John Hubbard , Christoph Hellwig , Jason Gunthorpe , "Ben Skeggs" , Ralph Campbell Subject: [PATCH] nouveau: fix page fault on device private memory Date: Fri, 26 Jun 2020 10:26:26 -0700 Message-ID: <20200626172626.19207-1-rcampbell@nvidia.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 X-NVConfidentiality: public Content-Transfer-Encoding: quoted-printable Content-Type: text/plain DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1593192388; bh=+jL8198tCi4VPutVCs4yXHE2/yX1fXK0+ZzD5egdp4w=; h=X-PGP-Universal:From:To:CC:Subject:Date:Message-ID:X-Mailer: MIME-Version:X-NVConfidentiality:Content-Transfer-Encoding: Content-Type; b=dSKhZ+J1Nn3Eb0LX95a8mp/H26NjdofgeBJOetygGbQkKjHzbZyrwmqEC8ErmvCS1 eUA99lTXoBFGkmL6xDJtRRF94rW9DzYwnDhvi4TFwLxXXyAzWwALy8yhk4EGhbY3Bb dM9eAML6m8QPXetN/JpnNXJ3EIjbnTy2qTQJLk6Ka8GKBkmNtDgc4SYKdvITcbD4X4 27HWfqCOadM0ADG566k+W7W+V9Cn9hKHfOc1FjWdWzTJhJHZ6EnyT9phhQSJ/zhc8c UgmzTQaANl52Mx1odNDsQazX9USnqk2tgx9XzVzMHFfoy9dyAoo6ZojlUjoPAGFykl zbNqgCRLeM0Yw== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If system memory is migrated to device private memory and no GPU MMU page table entry exists, the GPU will fault and call hmm_range_fault() to get the PFN for the page. Since the .dev_private_owner pointer in struct hmm_range is not set, hmm_range_fault returns an error which results in the GPU program stopping with a fatal fault. Fix this by setting .dev_private_owner appropriately. Fixes: 08ddddda667b ("mm/hmm: check the device private page owner in hmm_ra= nge_fault()") Signed-off-by: Ralph Campbell --- This is based on Linux-5.8.0-rc2 and is for Ben Skeggs nouveau tree. It doesn't depend on any of the other nouveau/HMM changes I have recently posted. drivers/gpu/drm/nouveau/nouveau_svm.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/gpu/drm/nouveau/nouveau_svm.c b/drivers/gpu/drm/nouvea= u/nouveau_svm.c index ba9f9359c30e..6586d9d39874 100644 --- a/drivers/gpu/drm/nouveau/nouveau_svm.c +++ b/drivers/gpu/drm/nouveau/nouveau_svm.c @@ -562,6 +562,7 @@ static int nouveau_range_fault(struct nouveau_svmm *svm= m, .end =3D notifier->notifier.interval_tree.last + 1, .pfn_flags_mask =3D HMM_PFN_REQ_FAULT | HMM_PFN_REQ_WRITE, .hmm_pfns =3D hmm_pfns, + .dev_private_owner =3D drm->dev, }; struct mm_struct *mm =3D notifier->notifier.mm; int ret; --=20 2.20.1