Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp49155pxy; Wed, 21 Apr 2021 18:08:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyez37Ztxgq5Lgj7PnA2UMOx36Q5pHhVPUtz80MnLMOiZqFfeVXdqGlkezXu1drU+S1upEe X-Received: by 2002:aa7:828f:0:b029:200:6e27:8c8f with SMTP id s15-20020aa7828f0000b02902006e278c8fmr872055pfm.44.1619053726206; Wed, 21 Apr 2021 18:08:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619053726; cv=none; d=google.com; s=arc-20160816; b=nGuyZu6ldCaPKoBdbFIoILDTti1LLzV75w8os5+e3N7dkrXXiSwIld95zqSCcwwUU9 +i8d0YbAyd2ne3flP2HfG6rpYUwkALmXC//+bBqQOPX/lqJ+7Lc4j5+tuWnMAsnZbjLE JxocChVC89OesXkxfNtfSxV+1chKK0Msb8hmDLf/vdRzmY2X8qQ1WQlyZFqxez22Z2VO kuSmX6B3WzQzw0Weqk+KYTaPmMFj7dGU0fgiYU/Ynbz9/+auuTaiSXIZ9BfyoQ+m3vrW GBJHtY0y6P66UmURuKv3997mcgcj8rSpCt+DHC4g/XhpGWx0FppDM1MIk0LIJKbjMWsK qErw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:message-id:references:in-reply-to :subject:cc:to:from:date:content-transfer-encoding:mime-version :sender:dkim-signature; bh=bUrNF799xx1oKXdWzhByA5YNjTKF+oLeMXDyY+4kcb0=; b=wM9LCOe2p5v+rmWAtKho9Pyq6Ggciz5DnDa78F964GnSUtf93s9NMCfkRwg+Tb+xLH cG5UV/PqK0xYDGe0tJDePDfeyfqFYPJjnw+WRGR4sDqIvWJHe7RHFtwWhqW9OwQBBF9B YTsCzIkJu2h23Y7PiNek3ahEyUBVWYbF+qvvuWNb2ZcPyCGEdybMkqIti5EEZZPjby0d KzdAxJkbR7EFviXhZYpSX/D3sDOjhXX6dhZKCOHmuXMzeQlITIDqdTFXRVFGaEqT+2Ma J/CA7d8gwiGZKMP0J3kynl+L9mmy8/utNQ58k/RfQd89t5b4Tt9A1SWqiSTmeBluO1tk vqCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=aT0M6Zd5; 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 p11si1259032pfn.246.2021.04.21.18.08.34; Wed, 21 Apr 2021 18:08:46 -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=@mg.codeaurora.org header.s=smtp header.b=aT0M6Zd5; 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 S240402AbhDUR1H (ORCPT + 99 others); Wed, 21 Apr 2021 13:27:07 -0400 Received: from so254-9.mailgun.net ([198.61.254.9]:45617 "EHLO so254-9.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235101AbhDUR1E (ORCPT ); Wed, 21 Apr 2021 13:27:04 -0400 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1619025991; h=Message-ID: References: In-Reply-To: Subject: Cc: To: From: Date: Content-Transfer-Encoding: Content-Type: MIME-Version: Sender; bh=bUrNF799xx1oKXdWzhByA5YNjTKF+oLeMXDyY+4kcb0=; b=aT0M6Zd5rGzp9v2jjKclnRRADc1qRIj8G8+hI5peMbIcOHXgpQkTrkypwF2hOR3T4BdgGy+q zBmqraPPmPyzp8kNVCHIzAXqHXQ2AdjmUJAfCu1tG/FPRci6KGqVjZjMuFIc/HLD8BLOzYzl PmunRAOMZ86+GjSlow+QixwDdvY= X-Mailgun-Sending-Ip: 198.61.254.9 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n06.prod.us-west-2.postgun.com with SMTP id 6080603efebcffa80fbed013 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Wed, 21 Apr 2021 17:26:22 GMT Sender: khsieh=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id D41C9C43460; Wed, 21 Apr 2021 17:26:22 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) (using TLSv1 with cipher ECDHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) (Authenticated sender: khsieh) by smtp.codeaurora.org (Postfix) with ESMTPSA id D9061C433F1; Wed, 21 Apr 2021 17:26:21 +0000 (UTC) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Wed, 21 Apr 2021 10:26:21 -0700 From: khsieh@codeaurora.org To: Stephen Boyd Cc: robdclark@gmail.com, sean@poorly.run, abhinavk@codeaurora.org, aravindh@codeaurora.org, airlied@linux.ie, daniel@ffwll.ch, linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/2] drm/msm/dp: service only one irq_hpd if there are multiple irq_hpd pending In-Reply-To: <161895606268.46595.2841353121480638642@swboyd.mtv.corp.google.com> References: <1618604877-28297-1-git-send-email-khsieh@codeaurora.org> <161895606268.46595.2841353121480638642@swboyd.mtv.corp.google.com> Message-ID: X-Sender: khsieh@codeaurora.org User-Agent: Roundcube Webmail/1.3.9 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021-04-20 15:01, Stephen Boyd wrote: > Quoting Kuogee Hsieh (2021-04-16 13:27:57) >> Some dongle may generate more than one irq_hpd events in a short >> period of >> time. This patch will treat those irq_hpd events as single one and >> service >> only one irq_hpd event. > > Why is it bad to get multiple irq_hpd events in a short period of time? > Please tell us here in the commit text. > >> >> Signed-off-by: Kuogee Hsieh >> --- >> drivers/gpu/drm/msm/dp/dp_display.c | 9 +++++++++ >> 1 file changed, 9 insertions(+) >> >> diff --git a/drivers/gpu/drm/msm/dp/dp_display.c >> b/drivers/gpu/drm/msm/dp/dp_display.c >> index 5a39da6..0a7d383 100644 >> --- a/drivers/gpu/drm/msm/dp/dp_display.c >> +++ b/drivers/gpu/drm/msm/dp/dp_display.c >> @@ -707,6 +707,9 @@ static int dp_irq_hpd_handle(struct >> dp_display_private *dp, u32 data) >> return 0; >> } >> >> + /* only handle first irq_hpd in case of multiple irs_hpd >> pending */ >> + dp_del_event(dp, EV_IRQ_HPD_INT); >> + >> ret = dp_display_usbpd_attention_cb(&dp->pdev->dev); >> if (ret == -ECONNRESET) { /* cable unplugged */ >> dp->core_initialized = false; >> @@ -1300,6 +1303,9 @@ static int dp_pm_suspend(struct device *dev) >> /* host_init will be called at pm_resume */ >> dp->core_initialized = false; >> >> + /* system suspended, delete pending irq_hdps */ >> + dp_del_event(dp, EV_IRQ_HPD_INT); > > What happens if I suspend my device and when this function is running I > toggle my monitor to use the HDMI input that is connected instead of > some > other input, maybe the second HDMI input? Wouldn't that generate an HPD > interrupt to grab the attention of this device? no, At this time display is off. this mean dp controller is off and mainlink has teared down. it will start with plug in interrupt to bring dp controller up and start link training. irq_hpd can be generated only panel is at run time of operation mode and need attention from host. If host is shutting down, then no need to service pending irq_hpd. > >> + >> mutex_unlock(&dp->event_mutex); >> >> return 0; >> @@ -1496,6 +1502,9 @@ int msm_dp_display_disable(struct msm_dp *dp, >> struct drm_encoder *encoder) >> /* stop sentinel checking */ >> dp_del_event(dp_display, EV_DISCONNECT_PENDING_TIMEOUT); >> >> + /* link is down, delete pending irq_hdps */ >> + dp_del_event(dp_display, EV_IRQ_HPD_INT); >> + > > I'm becoming convinced that the whole kthread design and event queue is > broken. These sorts of patches are working around the larger problem > that the kthread is running independently of the driver and irqs can > come in at any time but the event queue is not checked from the irq > handler to debounce the irq event. Is the event queue necessary at all? > I wonder if it would be simpler to just use an irq thread and process > the hpd signal from there. Then we're guaranteed to not get an irq > again > until the irq thread is done processing the event. This would naturally > debounce the irq hpd event that way. event q just like bottom half of irq handler. it turns irq into event and handle them sequentially. irq_hpd is asynchronous event from panel to bring up attention of hsot during run time of operation. Here, the dongle is unplugged and main link had teared down so that no need to service pending irq_hpd if any. > >> dp_display_disable(dp_display, 0); >> >> rc = dp_display_unprepare(dp);