Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp1119209ybg; Thu, 4 Jun 2020 01:15:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwTMKn8vbg5J8FtsZ4QbY6SvHiZrRK0bG8nNQPyYNb4LjsUx0OmKZmKdJlIQtwhzXHVhqKq X-Received: by 2002:aa7:d952:: with SMTP id l18mr3148770eds.151.1591258540544; Thu, 04 Jun 2020 01:15:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591258540; cv=none; d=google.com; s=arc-20160816; b=t+3PqGjG5bGv2Hr928Y/DOS0Ymi8z0/lsyVL+zIYqh95B8XZl8APjzdpPmh2bqArIU GoMZ6jBFH2WY9CS1dQ3xO3edLPT/5bK3X6rIFf0x7tgSN58YBinPkjBmUqx50g2yzKS7 3XVI+0t3yIElrenaRCPnd2b3gby+8436nulWMUU9T55pKPpr9TVqSTu64bUTdxId1toP QlVYOXDsVyukN3zueSd+2NeYWDoeUNPqxDUrVw0kF6FEBxSapUWowPKgYta5+v+pDQWs 9x7CEX3V0E1/FWGD/FWFwKEIuM458n18DKzoKIqoYgelDK5pSxfH+g39/PamFFaR4+8m YTqg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=mPAnyNEtS0uY+bUuM8GxOFOVsLMIhBxwz7ItIj7lR3A=; b=wGcngHakloyjf3ZfUURPAQjB4e7VRclnyOpNZlRLgm0FfPWaYR/lDULnxyJyZ468jD XcZVrR8VFhVwTcDDWoihz39xoR9MH3WdcA5Mbn9WoQA6oaPFcoEp2HmbdSdt/B5fLKq6 F30NOHfEgLMx5cfMSc2iwhCQQkV4neJFBSy90lQ/QwZgLVQPv6uu767MlxLcYlwVRYk1 hBxUOMznjznzXMASKu6IwP5TC7gV/9ReRoLXt2ijO2UdWvEvrt2FdEkQx3rUfP98YOu1 22EY9xhpTHYKl2oTkStFj5IrTjJwxioj6n9fnQJpAL/t8UotcWp871V7Iz65N+4NzBIN twXA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=Cw6DE8ip; 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 k12si1284754edi.198.2020.06.04.01.15.18; Thu, 04 Jun 2020 01:15:40 -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=@ffwll.ch header.s=google header.b=Cw6DE8ip; 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 S1728002AbgFDINQ (ORCPT + 99 others); Thu, 4 Jun 2020 04:13:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51518 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727854AbgFDIMy (ORCPT ); Thu, 4 Jun 2020 04:12:54 -0400 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8AA6FC08C5C7 for ; Thu, 4 Jun 2020 01:12:52 -0700 (PDT) Received: by mail-wr1-x444.google.com with SMTP id x6so4997041wrm.13 for ; Thu, 04 Jun 2020 01:12:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=mPAnyNEtS0uY+bUuM8GxOFOVsLMIhBxwz7ItIj7lR3A=; b=Cw6DE8iprZ3uQg5gII/9i5sihculizd8rViFXjzCXSdVxul9CqWdFgOfY71gVkGiuV juGxO+Tm75A9A2e/W5n2HP7py+rVnr9u2LxOwSRBXRkhwJHpkeuFJDFWdS3KfjcSOmQG RdZmXaDOTVBzfxFPq9ypg/Dpc5CyQyRF0HX2w= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=mPAnyNEtS0uY+bUuM8GxOFOVsLMIhBxwz7ItIj7lR3A=; b=EHFCOMJ1cI+rShNhsXGK6c1zs66wPy3y49pdWcj8vEMm/YR2uRF4uFOaarayqKm5Q/ 08zkl/doJQb3cdG60Va2hfjdWlnHWehZWKDqIxfc6PbvzbjkkQDvxd0MoyEjfXHb/Xcm wyzmMii6s+f13QCRLSaKKEOyWq8UGwQqrPZgR/ADDUBaCtcps+5OdAOprKCQqBOZb1TJ 3Uu8RowKRoqHnf4wyIb7DO3f4GCE4uVB30+Erg4HJRjjRHXUv/+YNCBJNMIMKnJ8kIZL JdULPD0WNLysw2rqEDdL/mL0U5bavkH4keJ7KZeuycKS9cP4JarvHW/BtpqGEMgDTLQp JWXQ== X-Gm-Message-State: AOAM530btn29YLCbOTsev93fcoajA2/3BvoHDf9glKf9/TFCnN5F9k7I AWHIR3lVxlrHzzOUGHHZaQ3UoQ== X-Received: by 2002:a5d:6391:: with SMTP id p17mr3458296wru.118.1591258371351; Thu, 04 Jun 2020 01:12:51 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id f11sm6873305wrj.2.2020.06.04.01.12.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 04 Jun 2020 01:12:50 -0700 (PDT) From: Daniel Vetter To: DRI Development Cc: Intel Graphics Development , LKML , linux-rdma@vger.kernel.org, amd-gfx@lists.freedesktop.org, Daniel Vetter , linux-media@vger.kernel.org, linaro-mm-sig@lists.linaro.org, Chris Wilson , Maarten Lankhorst , =?UTF-8?q?Christian=20K=C3=B6nig?= Subject: [PATCH 15/18] drm/amdgpu: use dma-fence annotations for gpu reset code Date: Thu, 4 Jun 2020 10:12:21 +0200 Message-Id: <20200604081224.863494-16-daniel.vetter@ffwll.ch> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200604081224.863494-1-daniel.vetter@ffwll.ch> References: <20200604081224.863494-1-daniel.vetter@ffwll.ch> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To improve coverage also annotate the gpu reset code itself, since that's called from other places than drm/scheduler (which is already annotated). Annotations nests, so this doesn't break anything, and allows easier testing. Cc: linux-media@vger.kernel.org Cc: linaro-mm-sig@lists.linaro.org Cc: linux-rdma@vger.kernel.org Cc: amd-gfx@lists.freedesktop.org Cc: intel-gfx@lists.freedesktop.org Cc: Chris Wilson Cc: Maarten Lankhorst Cc: Christian König Signed-off-by: Daniel Vetter --- drivers/gpu/drm/amd/amdgpu/amdgpu_device.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c index a027a8f7b281..ac0286a5f2fc 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c @@ -4215,6 +4215,9 @@ int amdgpu_device_gpu_recover(struct amdgpu_device *adev, (amdgpu_asic_reset_method(adev) == AMD_RESET_METHOD_BACO) ? true : false; bool audio_suspended = false; + bool fence_cookie; + + fence_cookie = dma_fence_begin_signalling(); /* * Flush RAM to disk so that after reboot @@ -4243,6 +4246,7 @@ int amdgpu_device_gpu_recover(struct amdgpu_device *adev, DRM_INFO("Bailing on TDR for s_job:%llx, hive: %llx as another already in progress", job ? job->base.id : -1, hive->hive_id); mutex_unlock(&hive->hive_lock); + dma_fence_end_signalling(fence_cookie); return 0; } @@ -4253,8 +4257,10 @@ int amdgpu_device_gpu_recover(struct amdgpu_device *adev, */ INIT_LIST_HEAD(&device_list); if (adev->gmc.xgmi.num_physical_nodes > 1) { - if (!hive) + if (!hive) { + dma_fence_end_signalling(fence_cookie); return -ENODEV; + } if (!list_is_first(&adev->gmc.xgmi.head, &hive->device_list)) list_rotate_to_front(&adev->gmc.xgmi.head, &hive->device_list); device_list_handle = &hive->device_list; @@ -4269,6 +4275,7 @@ int amdgpu_device_gpu_recover(struct amdgpu_device *adev, DRM_INFO("Bailing on TDR for s_job:%llx, as another already in progress", job ? job->base.id : -1); mutex_unlock(&hive->hive_lock); + dma_fence_end_signalling(fence_cookie); return 0; } @@ -4409,6 +4416,7 @@ int amdgpu_device_gpu_recover(struct amdgpu_device *adev, if (r) dev_info(adev->dev, "GPU reset end with ret = %d\n", r); + dma_fence_end_signalling(fence_cookie); return r; } -- 2.26.2