Received: by 2002:a05:6602:2086:0:0:0:0 with SMTP id a6csp4472089ioa; Wed, 27 Apr 2022 04:44:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzdjagk+sDIuaNDwYKHs524Aas7/Rn13twlwSmuHHYrksZoh+A3CP5I+DCTo8loY0JWiiSW X-Received: by 2002:a17:902:70cb:b0:158:424e:a657 with SMTP id l11-20020a17090270cb00b00158424ea657mr27833927plt.6.1651059887814; Wed, 27 Apr 2022 04:44:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651059887; cv=none; d=google.com; s=arc-20160816; b=zUwwJI6cn958maF60vChKcv+F0NyWyKiyaVKnpl/YEd0HM0wWcg0jvAcEyhCQCSTTj /I2wLp+YUfbhnkQPxgXSdJoZrM6eMNAvF6klWWY+W7IahAgflQLQWI3bW+3gIaVt4QiP JoYWcLV2J+dSb+SCSNP//ulqCTisH4/0/hE+3rstam2GUGpANptztbumk/2JmdTbtnJK yANfXnxHrf5MB0f+YRmYRLe1e2efPghzN+w8+vJXll++sY6uJhTUSqVmITFi2eMSVlkc Gnhb166yylAgzUM9PhlSZdJfl562UooZu8NfICJYZnBYbcsUwe+JfKigHCg20HJhoBfs hSmg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=/MDg5A9f9rvXZp1xmjZTzHZIeAwlmtx2mQRfLrQsy7E=; b=guYux+iC1IroPWIG2x7jh9SLFGEY6UXrDfd19r+eiogLJ7HxT6c06cxj+dxgmGWt3K m20P/H5Qv6T3QUP+1jD0LlINCmL06EPpvqaFcOqxft4zVeN/NFQWIyy5/BUeHDDRlQ2W 0yeWN9cDukLpLiCAAv4IZbEjo4INfPazwC5/IGODUF15DYw1Ir9wImusioRjx/OeQc+u Aagv9ph/pQ6dL8LNwa9r7Vpboyv3LyCNttSJBRs4/phTNIfUO7xOpJ8Wcgz87TtX52iz gLE5Ypec9GjR3or1HATxmUMHFg9olcfx/l62+yVzHPG4R3Rg3azchKd1DkO2NHJP0k/B i5uQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=pIfuPJr7; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id i1-20020a654841000000b003a94e532eb6si1305861pgs.64.2022.04.27.04.44.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 27 Apr 2022 04:44:47 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=pIfuPJr7; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id A1B1B6B653; Wed, 27 Apr 2022 04:02:10 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232384AbiD0LEx (ORCPT + 99 others); Wed, 27 Apr 2022 07:04:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43706 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231865AbiD0LDm (ORCPT ); Wed, 27 Apr 2022 07:03:42 -0400 Received: from mail-lf1-x134.google.com (mail-lf1-x134.google.com [IPv6:2a00:1450:4864:20::134]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CA061286AAC for ; Wed, 27 Apr 2022 03:53:04 -0700 (PDT) Received: by mail-lf1-x134.google.com with SMTP id k12so2409241lfr.9 for ; Wed, 27 Apr 2022 03:53:04 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:in-reply-to:content-transfer-encoding; bh=/MDg5A9f9rvXZp1xmjZTzHZIeAwlmtx2mQRfLrQsy7E=; b=pIfuPJr7nqblgDaRQ4dMb03d0stbXtuCVITICOO7D+Sw4d+0uljC/gJd1LCHv7Wm9B y2F0N82TJJBYu0rQaIMQKnpmzGNTPTX5A+GLOyh8RADJXlYzT/kGOqQhs7QPP6GHlFJ5 kmLGvEhadsTzLtWOODP2aBnJUHIf7Hk/jn1ipAPo0UhWS72L3ZzXTQ+w41iM/nmLTfl8 wmzpzsg2qFyv1MxvPC3mFzATo055/Ji8SfudiSp05BcwrRzxyyN/sgMAt6+nNg/dWo5X nzaD0OWmvYHrz0atobccvico61skaUsgrUdBzgcJP3W3slbs/JsbPCWA0WzOuMTUYJcg Qwhg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:in-reply-to :content-transfer-encoding; bh=/MDg5A9f9rvXZp1xmjZTzHZIeAwlmtx2mQRfLrQsy7E=; b=xhLklasH3f+wOdUIT4wXEJ8HhvBAzth1GkRrk4dXmCQPO0I9c96rUcHmQWupZzutuZ qO9zB6Wzp994Yc27XBFyRe4h2E4vSORTupQ0nTb/MWTbuaXvvljjY8oxlbeaEs8ASLwS i9UfN5eFVuUuqje2t4gf7OP1R+dxIN73j2OSiT070mMP0Vea+n/Lhmztghs0oM3KzH7q Usp6BgJJwoD5mA9jVuJ5eNGpLAlIUgTsPjIgCmLiD+zqC6geNC9b9NVXSpZg4o10YmfE c5PIAGDnKYmBsXSI+1Ts+Y1ZqmXS5GpMwMkbiWpXPrXHlChhIs1hIzdGVdWNPN6xBLUd CExA== X-Gm-Message-State: AOAM531EhSRBfZ5os24QluwOGYCDgVr3E/Y9+GdSZBdjG30q9HlQyfZX NnaIiJEKxLvfkaT4KH+pPTMB4Q== X-Received: by 2002:ac2:4add:0:b0:471:fc6d:a71d with SMTP id m29-20020ac24add000000b00471fc6da71dmr14050863lfp.350.1651056782925; Wed, 27 Apr 2022 03:53:02 -0700 (PDT) Received: from [192.168.1.211] ([37.153.55.125]) by smtp.gmail.com with ESMTPSA id c6-20020a19e346000000b0046b8aac6e16sm2022462lfk.26.2022.04.27.03.53.01 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 27 Apr 2022 03:53:02 -0700 (PDT) Message-ID: Date: Wed, 27 Apr 2022 13:53:01 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.0 Subject: Re: [PATCH] drm/msm/disp/dpu1: avoid clearing hw interrupts if hw_intr is null during drm uninit Content-Language: en-GB To: Stephen Boyd , Vinod Polimera , devicetree@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, linux-arm-msm@vger.kernel.org Cc: linux-kernel@vger.kernel.org, robdclark@gmail.com, dianders@chromium.org, quic_kalyant@quicinc.com References: <1650952931-31988-1-git-send-email-quic_vpolimer@quicinc.com> From: Dmitry Baryshkov In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-3.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,RDNS_NONE,SPF_HELO_NONE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/04/2022 00:50, Stephen Boyd wrote: > Quoting Vinod Polimera (2022-04-25 23:02:11) >> Avoid clearing irqs and derefernce hw_intr when hw_intr is null. > > Presumably this is only the case when the display driver doesn't fully > probe and something probe defers? Can you clarify how this situation > happens? > >> >> BUG: Unable to handle kernel NULL pointer dereference at virtual address 0000000000000000 >> >> Call trace: >> dpu_core_irq_uninstall+0x50/0xb0 >> dpu_irq_uninstall+0x18/0x24 >> msm_drm_uninit+0xd8/0x16c >> msm_drm_bind+0x580/0x5fc >> try_to_bring_up_master+0x168/0x1c0 >> __component_add+0xb4/0x178 >> component_add+0x1c/0x28 >> dp_display_probe+0x38c/0x400 >> platform_probe+0xb0/0xd0 >> really_probe+0xcc/0x2c8 >> __driver_probe_device+0xbc/0xe8 >> driver_probe_device+0x48/0xf0 >> __device_attach_driver+0xa0/0xc8 >> bus_for_each_drv+0x8c/0xd8 >> __device_attach+0xc4/0x150 >> device_initial_probe+0x1c/0x28 >> >> Fixes: a73033619ea ("drm/msm/dpu: squash dpu_core_irq into dpu_hw_interrupts") > > The fixes tag looks odd. In dpu_core_irq_uninstall() at that commit it > is dealing with 'irq_obj' which isn't a pointer. After commit > f25f656608e3 ("drm/msm/dpu: merge struct dpu_irq into struct > dpu_hw_intr") dpu_core_irq_uninstall() starts using 'hw_intr' which is > allocated on the heap. If we backported this patch to a place that had > a73033619ea without f25f656608e3 it wouldn't make any sense. I'd agree here. The following tag would be correct: Fixes: f25f656608e3 ("drm/msm/dpu: merge struct dpu_irq into struct dpu_hw_intr") > >> Signed-off-by: Vinod Polimera >> --- >> drivers/gpu/drm/msm/disp/dpu1/dpu_hw_interrupts.c | 3 +++ >> 1 file changed, 3 insertions(+) >> >> diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_interrupts.c b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_interrupts.c >> index c515b7c..ab28577 100644 >> --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_interrupts.c >> +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_interrupts.c >> @@ -599,6 +599,9 @@ void dpu_core_irq_uninstall(struct dpu_kms *dpu_kms) >> { >> int i; >> >> + if (!dpu_kms->hw_intr) >> + return; >> + >> pm_runtime_get_sync(&dpu_kms->pdev->dev); >> for (i = 0; i < dpu_kms->hw_intr->total_irqs; i++) -- With best wishes Dmitry