Message ID | 20221111115414.153961-1-luca.weiss@fairphone.com |
---|---|
State | New |
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a5d:6687:0:0:0:0:0 with SMTP id l7csp694304wru; Fri, 11 Nov 2022 03:55:09 -0800 (PST) X-Google-Smtp-Source: AA0mqf5Dp2b2kLVQc4nEdYzCZcsby62aHbnnbB0ng6cgGaCMJuo1UrmSzp3ao5nAP8T49+N9WHnU X-Received: by 2002:a17:902:d353:b0:186:9590:48f5 with SMTP id l19-20020a170902d35300b00186959048f5mr2364503plk.35.1668167708787; Fri, 11 Nov 2022 03:55:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1668167708; cv=none; d=google.com; s=arc-20160816; b=KY5wORpJwvBoWdpl1L68IiSWcFXrF33FraOOOnEjDCdyoC0y7RL4eWAB/1KhHRQIuu pSispeNRK0uP0jPRnziRiYEI9Xb2jRhowb/G7AsM9bCE5LjNnetkj04Gw7OtIFW57Lws t/Us8aHQ+uSmmg2fLoihodViYwbdJNXr41l8sX7KI4WIXU4Fzzt8aMWD4o4lA0oRfrjM GOK9+c2YYmvIobxQUID7Pz/ndxsve3kL19KdoeLQ72dKA4k3TsQc4pJZIJ1jG/F/AfIk Mxgvqa9VTIUDCzbbjVsRUhDgbHmxevpL3QuAX660jkdXGXtkYu+vflDe93saYfs4+mee SqvA== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=KT+IyUbDPgQQlWcRFzbSRfNvsGmzKx+Z/uhCme7VWmc=; b=iv0q5gC6on0szDE+56WvQCG7mfFMfrQLK/sG4lieq/keXyD447S2vhQWOKgUNuqAoP AC97z/RYXy7505f0Jv7PVnMttY2FGxuMvXtWpCib9EGjYbhDOA9Kl+MhZttrlVNPQK6z iYu72anPX0jo34TgDJctqg2og8S20c4+2sXeXyqwRaELPadke6G5oX+fliHkwN55WQFt skhex5Re+YvCxgwifOIFL41JEtaP/paBuC5AWfVVZWQL1m47WYa0+cwSexM8C9dkVLIo qGOq4bI+gspOyNBRx0p9GvT9hAYZtsiCLf6mqeZLM5awo5IotosyMk7pv3sJEI07CVaV Xtbg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fairphone.com header.s=fair header.b=kVCO20cy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=fairphone.com Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c10-20020a631c4a000000b00470092473ffsi2051833pgm.421.2022.11.11.03.54.55; Fri, 11 Nov 2022 03:55:08 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@fairphone.com header.s=fair header.b=kVCO20cy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=fairphone.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233518AbiKKLyb (ORCPT <rfc822;winker.wchi@gmail.com> + 99 others); Fri, 11 Nov 2022 06:54:31 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55978 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233108AbiKKLy3 (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Fri, 11 Nov 2022 06:54:29 -0500 Received: from mail-ej1-x62a.google.com (mail-ej1-x62a.google.com [IPv6:2a00:1450:4864:20::62a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2F75F5D6B2 for <linux-kernel@vger.kernel.org>; Fri, 11 Nov 2022 03:54:28 -0800 (PST) Received: by mail-ej1-x62a.google.com with SMTP id q9so12190742ejd.0 for <linux-kernel@vger.kernel.org>; Fri, 11 Nov 2022 03:54:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fairphone.com; s=fair; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=KT+IyUbDPgQQlWcRFzbSRfNvsGmzKx+Z/uhCme7VWmc=; b=kVCO20cy5h0hDmnQoPeqHuKZrVNqVsfbNR1k3H9g+pDEMYkfizlmqWzDbuKrsViL1M 2F4P6UINavWtbo/IlrFZsMLvrR5zjl8yxcF77Oazajh9lAvtv9Qcqf1aMzDU9/KI0SzZ vn3X4zR4kbSijDnL2S5rNHPQ4rb1BL0twyBEA7kjewSaxBoOk+ONGQ/pCH13NMR1gqHT Q08HqlbE6SKMZ1EQnbL57ldNAaSS/jkO3tm1eVq/xBU6+bhMv0ckilxN3CVabwJZeE6e I/aqQF0d4H1+lIZCShy83MfQuir35Arn+pEod6egWz4W6sw8OfDZR1TmMXsrOPQsTiZ+ MxFw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=KT+IyUbDPgQQlWcRFzbSRfNvsGmzKx+Z/uhCme7VWmc=; b=MeNAuQe4P6zOfSxAhRZTXiMXxwzkb5fpI0acGvrGoJHaTcMtYnkFu48Wc7ixVGC+ql aIR60GIf0TyJQOKP4uv4d4Ba3JeKeB5JKZ1jrXQ7osPLNufxj+z+ke98e5TPYniiVKIo o4ehmP75Bo/ivYQ7n4xsrBNwkXrZtpbd1sEZ3IXK/JRbrTeEl64suo2x+VmGc/0LmF0W f5uzrmSYlGmKKZbC+9JxD5E76N/RFxVay+CIuW09PfvOprNhl6oDEMGxerpEWfI73Qih g07RFw6QOmJX9x73vlIuNMnU6Byi2xaVdRz/w46p1T+zhoCVX6IY/H+c+iPKS1P2RaSe o//g== X-Gm-Message-State: ANoB5pks7JwXOPblTgjYE34ATTjs078j20kez/y2wXHvyv2iz0TS1ndA sHdcjk1XkMouh0n53UcXqhMZmA== X-Received: by 2002:a17:906:3c14:b0:7ae:c9d4:7073 with SMTP id h20-20020a1709063c1400b007aec9d47073mr1295102ejg.711.1668167666768; Fri, 11 Nov 2022 03:54:26 -0800 (PST) Received: from otso.arnhem.chello.nl (k10064.upc-k.chello.nl. [62.108.10.64]) by smtp.gmail.com with ESMTPSA id kz6-20020a17090777c600b007adb86a1e1csm770859ejc.186.2022.11.11.03.54.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Nov 2022 03:54:26 -0800 (PST) From: Luca Weiss <luca.weiss@fairphone.com> To: linux-arm-msm@vger.kernel.org Cc: ~postmarketos/upstreaming@lists.sr.ht, phone-devel@vger.kernel.org, Luca Weiss <luca.weiss@fairphone.com>, Andy Gross <agross@kernel.org>, Bjorn Andersson <andersson@kernel.org>, Konrad Dybcio <konrad.dybcio@somainline.org>, Mathieu Poirier <mathieu.poirier@linaro.org>, Siddharth Gupta <sidgup@codeaurora.org>, Rishabh Bhatnagar <rishabhb@codeaurora.org>, Sibi Sankar <quic_sibis@quicinc.com>, linux-remoteproc@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/2] remoteproc: qcom_q6v5_pas: disable wakeup on probe fail or remove Date: Fri, 11 Nov 2022 12:54:13 +0100 Message-Id: <20221111115414.153961-1-luca.weiss@fairphone.com> X-Mailer: git-send-email 2.38.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=ham 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: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1749200623609623399?= X-GMAIL-MSGID: =?utf-8?q?1749200623609623399?= |
Series |
[1/2] remoteproc: qcom_q6v5_pas: disable wakeup on probe fail or remove
|
|
Commit Message
Luca Weiss
Nov. 11, 2022, 11:54 a.m. UTC
Leaving wakeup enabled during probe fail (-EPROBE_DEFER) or remove makes
the subsequent probe fail.
[ 3.749454] remoteproc remoteproc0: releasing 3000000.remoteproc
[ 3.752949] qcom_q6v5_pas: probe of 3000000.remoteproc failed with error -17
[ 3.878935] remoteproc remoteproc0: releasing 4080000.remoteproc
[ 3.887602] qcom_q6v5_pas: probe of 4080000.remoteproc failed with error -17
[ 4.319552] remoteproc remoteproc0: releasing 8300000.remoteproc
[ 4.332716] qcom_q6v5_pas: probe of 8300000.remoteproc failed with error -17
Fix this by disabling wakeup in both cases so the driver can properly
probe on the next try.
Fixes: a781e5aa5911 ("remoteproc: core: Prevent system suspend during remoteproc recovery")
Fixes: dc86c129b4fb ("remoteproc: qcom: pas: Mark devices as wakeup capable")
Signed-off-by: Luca Weiss <luca.weiss@fairphone.com>
---
drivers/remoteproc/qcom_q6v5_pas.c | 2 ++
1 file changed, 2 insertions(+)
Comments
Hey Luca, Thanks for the patch. On 11/11/22 17:24, Luca Weiss wrote: > Leaving wakeup enabled during probe fail (-EPROBE_DEFER) or remove makes > the subsequent probe fail. > > [ 3.749454] remoteproc remoteproc0: releasing 3000000.remoteproc > [ 3.752949] qcom_q6v5_pas: probe of 3000000.remoteproc failed with error -17 > [ 3.878935] remoteproc remoteproc0: releasing 4080000.remoteproc > [ 3.887602] qcom_q6v5_pas: probe of 4080000.remoteproc failed with error -17 > [ 4.319552] remoteproc remoteproc0: releasing 8300000.remoteproc > [ 4.332716] qcom_q6v5_pas: probe of 8300000.remoteproc failed with error -17 > > Fix this by disabling wakeup in both cases so the driver can properly > probe on the next try. > > Fixes: a781e5aa5911 ("remoteproc: core: Prevent system suspend during remoteproc recovery") > Fixes: dc86c129b4fb ("remoteproc: qcom: pas: Mark devices as wakeup capable") > Signed-off-by: Luca Weiss <luca.weiss@fairphone.com> > --- > drivers/remoteproc/qcom_q6v5_pas.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/remoteproc/qcom_q6v5_pas.c b/drivers/remoteproc/qcom_q6v5_pas.c > index 6afd0941e552..d830bf13c32c 100644 > --- a/drivers/remoteproc/qcom_q6v5_pas.c > +++ b/drivers/remoteproc/qcom_q6v5_pas.c > @@ -557,6 +557,7 @@ static int adsp_probe(struct platform_device *pdev) > adsp_pds_detach(adsp, adsp->proxy_pds, adsp->proxy_pd_count); > free_rproc: > rproc_free(rproc); > + device_init_wakeup(adsp->dev, false); You would want to do ^^ before rproc free since adsp is a private data of rproc struct. > > return ret; > } > @@ -573,6 +574,7 @@ static int adsp_remove(struct platform_device *pdev) > qcom_remove_smd_subdev(adsp->rproc, &adsp->smd_subdev); > qcom_remove_ssr_subdev(adsp->rproc, &adsp->ssr_subdev); > rproc_free(adsp->rproc); > + device_init_wakeup(adsp->dev, false); ditto. > > return 0; > } - Sibi
Hi, On 11/11/2022 5:24 PM, Luca Weiss wrote: > Leaving wakeup enabled during probe fail (-EPROBE_DEFER) or remove makes > the subsequent probe fail. > > [ 3.749454] remoteproc remoteproc0: releasing 3000000.remoteproc > [ 3.752949] qcom_q6v5_pas: probe of 3000000.remoteproc failed with error -17 > [ 3.878935] remoteproc remoteproc0: releasing 4080000.remoteproc > [ 3.887602] qcom_q6v5_pas: probe of 4080000.remoteproc failed with error -17 > [ 4.319552] remoteproc remoteproc0: releasing 8300000.remoteproc > [ 4.332716] qcom_q6v5_pas: probe of 8300000.remoteproc failed with error -17 > > Fix this by disabling wakeup in both cases so the driver can properly > probe on the next try. > > Fixes: a781e5aa5911 ("remoteproc: core: Prevent system suspend during remoteproc recovery") > Fixes: dc86c129b4fb ("remoteproc: qcom: pas: Mark devices as wakeup capable") > Signed-off-by: Luca Weiss <luca.weiss@fairphone.com> LGTM. Reviewed-by: Mukesh Ojha <quic_mojha@quicinc.com> -Mukesh > --- > drivers/remoteproc/qcom_q6v5_pas.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/remoteproc/qcom_q6v5_pas.c b/drivers/remoteproc/qcom_q6v5_pas.c > index 6afd0941e552..d830bf13c32c 100644 > --- a/drivers/remoteproc/qcom_q6v5_pas.c > +++ b/drivers/remoteproc/qcom_q6v5_pas.c > @@ -557,6 +557,7 @@ static int adsp_probe(struct platform_device *pdev) > adsp_pds_detach(adsp, adsp->proxy_pds, adsp->proxy_pd_count); > free_rproc: > rproc_free(rproc); > + device_init_wakeup(adsp->dev, false); > > return ret; > } > @@ -573,6 +574,7 @@ static int adsp_remove(struct platform_device *pdev) > qcom_remove_smd_subdev(adsp->rproc, &adsp->smd_subdev); > qcom_remove_ssr_subdev(adsp->rproc, &adsp->ssr_subdev); > rproc_free(adsp->rproc); > + device_init_wakeup(adsp->dev, false); > > return 0; > }
diff --git a/drivers/remoteproc/qcom_q6v5_pas.c b/drivers/remoteproc/qcom_q6v5_pas.c index 6afd0941e552..d830bf13c32c 100644 --- a/drivers/remoteproc/qcom_q6v5_pas.c +++ b/drivers/remoteproc/qcom_q6v5_pas.c @@ -557,6 +557,7 @@ static int adsp_probe(struct platform_device *pdev) adsp_pds_detach(adsp, adsp->proxy_pds, adsp->proxy_pd_count); free_rproc: rproc_free(rproc); + device_init_wakeup(adsp->dev, false); return ret; } @@ -573,6 +574,7 @@ static int adsp_remove(struct platform_device *pdev) qcom_remove_smd_subdev(adsp->rproc, &adsp->smd_subdev); qcom_remove_ssr_subdev(adsp->rproc, &adsp->ssr_subdev); rproc_free(adsp->rproc); + device_init_wakeup(adsp->dev, false); return 0; }