Received: by 2002:a05:6a10:8395:0:0:0:0 with SMTP id n21csp613187pxh; Tue, 9 Nov 2021 16:11:19 -0800 (PST) X-Google-Smtp-Source: ABdhPJx4ZQn4NgVV3e2qKZQhuUHythe2oPBrpNti6b5uhZnkGZ8xA9j/SdmBlGn8a2TwtSMvScU7 X-Received: by 2002:a05:6e02:1d1a:: with SMTP id i26mr9078008ila.303.1636503079162; Tue, 09 Nov 2021 16:11:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1636503079; cv=none; d=google.com; s=arc-20160816; b=p49GGGi/NgfkNi/cAUWPpoEjoX7b+cXDI0a0LaWutgd+BP2RVAS6jZfaBmCU1fpv3i 0EPNUB8p22i3PV9Ocu/q5+C8NhIobORsBq3qo9brGVH50DJVak1FXnF16lDSBKjiIb2c S1f3dMR7GbdfJsxQIIEFtTsSfJZPy7qGac84NJx4HZjrwGeIP08Q91JsPr5RiUx3/bw2 ywWdV/iLrK0NsZFxNxDg5HzS7XEF19su6jBXA8KFvKueUI0oQD55EKznBpl4ui6ZBk8Q G81eem2cduukYZvNgM6Lx7m7RF/Zd+k/818DpBXLrpESiiO9l5sPCHwQZ8I3vGhZpPAT I2Bg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=Ewu5OhDKta9tv0cj+vmNtgtEN7krYewINiiQiOGODF0=; b=AhwUKhuTlK5DnAG+u3Z5Bg5UXtvaRpC9vtlp0EPD9/Jecb7kqBTh9veAvsCK/lE+sq erwefIOECfmC0hShA2p9R4qEGwlwXRskDUz9uNv7eFUOexwURG9x0ouevDXmcdH9Xd8U 5of97a3nnjoSgNFvq/igvnW2d1c4GCLFdO46mN/5aO/FLTV7EYzSwBGxz/3X9yvGewLP q7gFKoqvgrXbaCQN3zaq8AeegXVWMwOBnQQpS+1jU2wplKl2F/eXiQ4wnmnPlk6sRTtS Vordciizq+dmbPKJvSFJO9KL/YnrG3GHVnHR0/pJWQ7gkfAB9D9xN8FfOP5Q5awdPK6j wHFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=Hz3G3Afb; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v12si6411763jat.133.2021.11.09.16.11.03; Tue, 09 Nov 2021 16:11:19 -0800 (PST) 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=@gmail.com header.s=20210112 header.b=Hz3G3Afb; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242157AbhKISKF (ORCPT + 97 others); Tue, 9 Nov 2021 13:10:05 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50306 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241826AbhKISJ0 (ORCPT ); Tue, 9 Nov 2021 13:09:26 -0500 Received: from mail-pl1-x634.google.com (mail-pl1-x634.google.com [IPv6:2607:f8b0:4864:20::634]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8A7DBC061764; Tue, 9 Nov 2021 10:06:39 -0800 (PST) Received: by mail-pl1-x634.google.com with SMTP id r5so26826pls.1; Tue, 09 Nov 2021 10:06:39 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Ewu5OhDKta9tv0cj+vmNtgtEN7krYewINiiQiOGODF0=; b=Hz3G3Afbb/rY/XGlxsubGcd7n5QDeKiLAGHYPhciUQ18io5H6tC9yuVa0BHgIbtZN6 Ubn9b1bPRCGW88lD1wVdSTyzLhjV874CD4RJS9in23QVB8UErtM8aooTsF4fbB9H34R6 8o1q0R2n6cwZEA8GgjbiefS0G+5IrpoKulNX2DEoFjjDc/s2gbZiLB4nzqivtsMI2kEY TX2QQY67Q3hGg4kxCx4voWBYL4BKLKVzHJz8WOwtxx7y91Bb6YNpwKYOcs12Eb1Riocu eHzACDpX9r/zDuTKG0i/OE9JlM/C6iuKqWK3NOOZAeyUSw/7PYiKagMIgOd+pKMR0Yz8 nyMw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Ewu5OhDKta9tv0cj+vmNtgtEN7krYewINiiQiOGODF0=; b=jNXwT/0vsp5pW9jkfehBKbqpdiR3IRjWSzUhAE/JGLeSe5JP3RWh+74lZ9Xh7kS6ZW 5YLoN++OwZJMTW3gRr8h5FEnsMxSEeeYZpZ43leOzrk7kCIFzxo0uAmZ/aHJfwgCiBTL 2ifIDDjsfSUlQNhbg/r2YTRskneFNBJ5Tot6JfPdjbDZZP+gW5an6fn/EIyBnQ7Nefqi 7q5l6x/Kdz++GqeDgDU0HZJXj5RBRkFaWZfjWN7TW5SxCksDQmqlPO6SUcEZAZvBZPUd s0+n/DNf1xtXo+owgCb55WKs4Y58rR9Ggsxd6OK+gBY1DyMAZAKWpwU2VwhucoR46YFM UBYw== X-Gm-Message-State: AOAM532ySf13DKmKenVcysTj4avVrUMeA/BHD+9/yNJbpXhiAv3B/Nx2 EBDGCOvbum5ukrO7iLEJZ8s= X-Received: by 2002:a17:90b:1e45:: with SMTP id pi5mr9598315pjb.146.1636481198993; Tue, 09 Nov 2021 10:06:38 -0800 (PST) Received: from localhost (c-73-25-156-94.hsd1.or.comcast.net. [73.25.156.94]) by smtp.gmail.com with ESMTPSA id u1sm6273840pfl.92.2021.11.09.10.06.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 09 Nov 2021 10:06:37 -0800 (PST) From: Rob Clark To: dri-devel@lists.freedesktop.org Cc: freedreno@lists.freedesktop.org, linux-arm-msm@vger.kernel.org, Jordan Crouse , Akhil P Oommen , Rob Clark , Rob Clark , Sean Paul , David Airlie , Daniel Vetter , AngeloGioacchino Del Regno , Konrad Dybcio , Yangtao Li , Marijn Suijten , Jonathan Marek , Dmitry Baryshkov , Sai Prakash Ranjan , Sharat Masetty , Douglas Anderson , linux-kernel@vger.kernel.org (open list) Subject: [PATCH 5/5] drm/msm: Add debugfs to disable hw err handling Date: Tue, 9 Nov 2021 10:11:05 -0800 Message-Id: <20211109181117.591148-6-robdclark@gmail.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20211109181117.591148-1-robdclark@gmail.com> References: <20211109181117.591148-1-robdclark@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rob Clark Add a debugfs interface to ignore hw error irqs, in order to force fallback to sw hangcheck mechanism. Because the hw error detection is pretty good on newer gens, we need this for igt tests to test the sw hang detection. Signed-off-by: Rob Clark --- drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 6 ++++++ drivers/gpu/drm/msm/adreno/a6xx_gpu.c | 4 ++++ drivers/gpu/drm/msm/msm_debugfs.c | 3 +++ drivers/gpu/drm/msm/msm_drv.h | 9 +++++++++ 4 files changed, 22 insertions(+) diff --git a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c index 6163990a4d09..ec8e043c9d38 100644 --- a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c +++ b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c @@ -1252,6 +1252,7 @@ static void a5xx_fault_detect_irq(struct msm_gpu *gpu) static irqreturn_t a5xx_irq(struct msm_gpu *gpu) { + struct msm_drm_private *priv = gpu->dev->dev_private; u32 status = gpu_read(gpu, REG_A5XX_RBBM_INT_0_STATUS); /* @@ -1261,6 +1262,11 @@ static irqreturn_t a5xx_irq(struct msm_gpu *gpu) gpu_write(gpu, REG_A5XX_RBBM_INT_CLEAR_CMD, status & ~A5XX_RBBM_INT_0_MASK_RBBM_AHB_ERROR); + if (priv->disable_err_irq) { + status &= A5XX_RBBM_INT_0_MASK_CP_CACHE_FLUSH_TS | + A5XX_RBBM_INT_0_MASK_CP_SW; + } + /* Pass status to a5xx_rbbm_err_irq because we've already cleared it */ if (status & RBBM_ERROR_MASK) a5xx_rbbm_err_irq(gpu, status); diff --git a/drivers/gpu/drm/msm/adreno/a6xx_gpu.c b/drivers/gpu/drm/msm/adreno/a6xx_gpu.c index 3d2da81cb2c9..8a2af3a27e33 100644 --- a/drivers/gpu/drm/msm/adreno/a6xx_gpu.c +++ b/drivers/gpu/drm/msm/adreno/a6xx_gpu.c @@ -1373,10 +1373,14 @@ static void a6xx_fault_detect_irq(struct msm_gpu *gpu) static irqreturn_t a6xx_irq(struct msm_gpu *gpu) { + struct msm_drm_private *priv = gpu->dev->dev_private; u32 status = gpu_read(gpu, REG_A6XX_RBBM_INT_0_STATUS); gpu_write(gpu, REG_A6XX_RBBM_INT_CLEAR_CMD, status); + if (priv->disable_err_irq) + status &= A6XX_RBBM_INT_0_MASK_CP_CACHE_FLUSH_TS; + if (status & A6XX_RBBM_INT_0_MASK_RBBM_HANG_DETECT) a6xx_fault_detect_irq(gpu); diff --git a/drivers/gpu/drm/msm/msm_debugfs.c b/drivers/gpu/drm/msm/msm_debugfs.c index 6a99e8b5d25d..956b1efc3721 100644 --- a/drivers/gpu/drm/msm/msm_debugfs.c +++ b/drivers/gpu/drm/msm/msm_debugfs.c @@ -242,6 +242,9 @@ void msm_debugfs_init(struct drm_minor *minor) debugfs_create_u32("hangcheck_period_ms", 0600, minor->debugfs_root, &priv->hangcheck_period); + debugfs_create_bool("disable_err_irq", 0600, minor->debugfs_root, + &priv->disable_err_irq); + debugfs_create_file("shrink", S_IRWXU, minor->debugfs_root, dev, &shrink_fops); diff --git a/drivers/gpu/drm/msm/msm_drv.h b/drivers/gpu/drm/msm/msm_drv.h index 2943c21d9aac..a8da7a7efb84 100644 --- a/drivers/gpu/drm/msm/msm_drv.h +++ b/drivers/gpu/drm/msm/msm_drv.h @@ -246,6 +246,15 @@ struct msm_drm_private { /* For hang detection, in ms */ unsigned int hangcheck_period; + + /** + * disable_err_irq: + * + * Disable handling of GPU hw error interrupts, to force fallback to + * sw hangcheck timer. Written (via debugfs) by igt tests to test + * the sw hangcheck mechanism. + */ + bool disable_err_irq; }; struct msm_format { -- 2.31.1