Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp1728117lqz; Mon, 1 Apr 2024 15:43:53 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVXfTmsEJ2gUdwZkoYBjRbVpnMPfkrN4expA9Mxfrx8uK7d8BFoYd/X1URTlDnmqTj+Cmi49xgE7Of7ZvaOiCsjk1Z5scCeXSUD6ja/bA== X-Google-Smtp-Source: AGHT+IFD93UYlSFDwJweb7CLEgZ2onWnsph2/SQSmzQqNO5qrr88tmJowvScbjMpBFoQkSSFAUxN X-Received: by 2002:ae9:e607:0:b0:789:e28c:d73 with SMTP id z7-20020ae9e607000000b00789e28c0d73mr11265464qkf.49.1712011432953; Mon, 01 Apr 2024 15:43:52 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712011432; cv=pass; d=google.com; s=arc-20160816; b=r3salTLxrgHwc+8sgstQVYsbhKdo8QBPDR81msbhgNWEUVb5JT9B581STuxvFO1vKm iI2zNzI0BTlqsGNZgB8evkcL1+rBIFpDDIFylHVLqmTRjMy/ogzR5Sp4RhA8kwQvZZEx 7YsdKPBoZav0UJKqdFR/bx/BWaWrFB26Tz+OyLZ4OXa/CbkWy0L5mX6TxzEELQyo+6kh eaoe7L9zXhHCHnz6RdEBpBXRJB39jf7fSfnBcNXQ0q6xzVyBzfllyBgCGBwx9AEbI5XG vO8s4b6wqC31Xzie+cVJEG3a1pYjLDR+7LmmMBizwL6rUayiIGn76oZhpNi3k0cYvX4c RxKQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=x6wOlanwnyuahzpz0MfNPGNkl1E4bit5o3/S2j1nuGQ=; fh=ZeCIuy8FC7k2w4KCmUvHInppT7R40l2fuev5BmqtnIo=; b=JeDk6ecmPKnli7dktF8jVXOEZDwTq17Vy8T/W8guQ7pH6huVkLh14SaSMxMEjagw+V 6YyhH8jI529ohQrzQhvJNoZDbyGIj5s6XA31H28/u96glPnh7a5FI7oZjvheNxtiLORI 7UDD6b2cihH5kq9a8T3pPaCkfbLxb76xa5BKLB0oVvfqLr9okYeuyfN0M35yx5zkKbvD SVsT2gfuBi4fTO/oz2oc/KA8VqSnvnSQ1Sn/FmeYRqUoLjdhz8Li0mR+67XqHSlq0jQi Ohv+kNBk4f5GzngrMe3Ws/VfRRkwfO3/7LLLrRgvtZ5Xdyc7wrnbzNo5HBoE3LuaA7/7 7J/w==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="I6s/V2gT"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-127144-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-127144-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id j23-20020a37ef17000000b0078a1efd49d7si10767119qkk.604.2024.04.01.15.43.52 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Apr 2024 15:43:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-127144-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b="I6s/V2gT"; arc=pass (i=1 spf=pass spfdomain=gmail.com dkim=pass dkdomain=gmail.com dmarc=pass fromdomain=gmail.com); spf=pass (google.com: domain of linux-kernel+bounces-127144-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-127144-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ny.mirrors.kernel.org (Postfix) with ESMTPS id AB4831C2194A for ; Mon, 1 Apr 2024 22:43:52 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 0E52656B70; Mon, 1 Apr 2024 22:43:42 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="I6s/V2gT" Received: from mail-ej1-f47.google.com (mail-ej1-f47.google.com [209.85.218.47]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 800D529CFA for ; Mon, 1 Apr 2024 22:43:39 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.218.47 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712011421; cv=none; b=MvwetWmuX61tVUQQ8VFFJeo/68Y6v3Izc1CprcT9WQ0gK4i8O5e28PtrY1P8/Ea3gBBl/ehMBG+Kj1zO2NsaOf8vVttp8OPdd8/LIT+Orvojsk22SxA0ufSe6hQavhl5zzGt3406R9G4NCkCoClhHVVnH3PBTFgsdA01PzAtUXE= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712011421; c=relaxed/simple; bh=8Vf9Ny+dWGd97zbUbBdSuKZ4GxKDtWvZM5jazU0S0rI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=kd4uB4o8VAregFOL2s7feHwoc4JSE9B2+p2lzwKkTrPXNHA/tOOcGCalAdw4Gdra7v8oU39nEyqZ4yKizwm3jDocSPS8dNMrTHKkTExmThIolsamMinMDKRvvVgT6EcQYK/m3ZNAYLViWxe7lK0cMz3n7Vb/VVESsl7ZpQ8p3Gw= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=I6s/V2gT; arc=none smtp.client-ip=209.85.218.47 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Received: by mail-ej1-f47.google.com with SMTP id a640c23a62f3a-a4734ae95b3so575973366b.0 for ; Mon, 01 Apr 2024 15:43:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1712011418; x=1712616218; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=x6wOlanwnyuahzpz0MfNPGNkl1E4bit5o3/S2j1nuGQ=; b=I6s/V2gTNaHr/H61CGCr4Y56mVVsCQ2D650G0a8qM/fQR3suGN8d7bE2+GPi9Ah7kx vnyy8TyxqFJUyXmfgWP9fwJQWmEt1oTMWAzfp5a2P7pKI/4haFHSoUMAnVLRDIAlY3M0 kLhNQorchn5UFpy4z/dCCYIsvitsJPtJ9Ar5F+vZd0qm5UeQrAHVIN6Rs1Cg+F6OAb1w TDfZZUZjexEvMd7u+oQVnsWvU7FBtDjeyR2zHiEX8bLBl5W727P9Xrn378fPSlZZNTMW iwGA0ga391EA1lG6uEW9fHyIRex76NoWH9WAccye1OeLb3LH7VV1KJfigmdcTHtepgBo 9xKQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1712011418; x=1712616218; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=x6wOlanwnyuahzpz0MfNPGNkl1E4bit5o3/S2j1nuGQ=; b=w3HQclzs7dmPCeKUjd2CXRotEHU5fHJTsEXBWmgZh0iHXpYBB5H3ntP60LkIKRYDTi TXmmILKkdArEsZaeXgtlvdYuwnwfFzwc+p0DpReqG+7rawwN1fi3yxvb0iumM/3IoeY1 6Z6dCVNF5r72sJOpz2B7zRTuSNyNXHB2/RnWWqapLF01/zA4ovbogebTslAcDhw7v70v vSb07n+JHnCd3svUFXNlw1+Gad1n7EZ6T9x9nVjnPDAkxhNGDuLlHvCfyEHaf+tHcJlj XovCa6ifw2ZWcdVYj8cYrHjuVP9MX7U9IFn1T0vepfYMCfpCGT5Yx0R+z2HeJVcHyIaC ckGQ== X-Forwarded-Encrypted: i=1; AJvYcCUCtkNCSv8rWJjrVdMugBjB7w5wUAojgNjwk8jxjm7dnO9jF9qzhwdB217gnVkMACvXqKFMN6b5T+MRwrBELt7oVIss+q9D50k6PTGo X-Gm-Message-State: AOJu0YwjbZwK7FsSMJK9y2bYg+ZfnSvWH0PiyktrJgwwtEUVquynZ6Tv PHPco1FRxn2SoHPKaahjlNGUpxfQ821Yl1uxMINpdh+p3zych9qq X-Received: by 2002:a17:906:494e:b0:a4e:69b5:9835 with SMTP id f14-20020a170906494e00b00a4e69b59835mr2677589ejt.6.1712011417805; Mon, 01 Apr 2024 15:43:37 -0700 (PDT) Received: from mosaic.enunes.eu (ip-78-45-66-209.bb.vodafone.cz. [78.45.66.209]) by smtp.gmail.com with ESMTPSA id c3-20020a170906340300b00a4739efd7cesm5796808ejb.60.2024.04.01.15.43.36 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Apr 2024 15:43:37 -0700 (PDT) From: Erico Nunes To: Qiang Yu , anarsoul@gmail.com, dri-devel@lists.freedesktop.org, lima@lists.freedesktop.org Cc: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , linux-kernel@vger.kernel.org, Erico Nunes Subject: [PATCH 1/2] drm/lima: fix shared irq handling on driver remove Date: Tue, 2 Apr 2024 00:43:28 +0200 Message-ID: <20240401224329.1228468-2-nunes.erico@gmail.com> X-Mailer: git-send-email 2.44.0 In-Reply-To: <20240401224329.1228468-1-nunes.erico@gmail.com> References: <20240401224329.1228468-1-nunes.erico@gmail.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit lima uses a shared interrupt, so the interrupt handlers must be prepared to be called at any time. At driver removal time, the clocks are disabled early and the interrupts stay registered until the very end of the remove process due to the devm usage. This is potentially a bug as the interrupts access device registers which assumes clocks are enabled. A crash can be triggered by removing the driver in a kernel with CONFIG_DEBUG_SHIRQ enabled. This patch frees the interrupts at each lima device finishing callback so that the handlers are already unregistered by the time we fully disable clocks. Signed-off-by: Erico Nunes --- drivers/gpu/drm/lima/lima_gp.c | 2 ++ drivers/gpu/drm/lima/lima_mmu.c | 5 +++++ drivers/gpu/drm/lima/lima_pp.c | 4 ++++ 3 files changed, 11 insertions(+) diff --git a/drivers/gpu/drm/lima/lima_gp.c b/drivers/gpu/drm/lima/lima_gp.c index 6b354e2fb61d..14c39be8da90 100644 --- a/drivers/gpu/drm/lima/lima_gp.c +++ b/drivers/gpu/drm/lima/lima_gp.c @@ -338,7 +338,9 @@ int lima_gp_init(struct lima_ip *ip) void lima_gp_fini(struct lima_ip *ip) { + struct lima_device *dev = ip->dev; + devm_free_irq(dev->dev, ip->irq, ip); } int lima_gp_pipe_init(struct lima_device *dev) diff --git a/drivers/gpu/drm/lima/lima_mmu.c b/drivers/gpu/drm/lima/lima_mmu.c index e18317c5ca8c..6611e2836bf0 100644 --- a/drivers/gpu/drm/lima/lima_mmu.c +++ b/drivers/gpu/drm/lima/lima_mmu.c @@ -118,7 +118,12 @@ int lima_mmu_init(struct lima_ip *ip) void lima_mmu_fini(struct lima_ip *ip) { + struct lima_device *dev = ip->dev; + + if (ip->id == lima_ip_ppmmu_bcast) + return; + devm_free_irq(dev->dev, ip->irq, ip); } void lima_mmu_flush_tlb(struct lima_ip *ip) diff --git a/drivers/gpu/drm/lima/lima_pp.c b/drivers/gpu/drm/lima/lima_pp.c index d0d2db0ef1ce..84bec163c9ed 100644 --- a/drivers/gpu/drm/lima/lima_pp.c +++ b/drivers/gpu/drm/lima/lima_pp.c @@ -286,7 +286,9 @@ int lima_pp_init(struct lima_ip *ip) void lima_pp_fini(struct lima_ip *ip) { + struct lima_device *dev = ip->dev; + devm_free_irq(dev->dev, ip->irq, ip); } int lima_pp_bcast_resume(struct lima_ip *ip) @@ -319,7 +321,9 @@ int lima_pp_bcast_init(struct lima_ip *ip) void lima_pp_bcast_fini(struct lima_ip *ip) { + struct lima_device *dev = ip->dev; + devm_free_irq(dev->dev, ip->irq, ip); } static int lima_pp_task_validate(struct lima_sched_pipe *pipe, -- 2.44.0