Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp5912761iob; Tue, 10 May 2022 06:35:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzc5SLOts+nNkZ37fH8HtQ/AINSFwyyeb9ytNH3/FxAa0XvYKIxFEztbZX18WKTIWQvgfcY X-Received: by 2002:a17:902:a707:b0:15b:6ea2:8ea2 with SMTP id w7-20020a170902a70700b0015b6ea28ea2mr20188703plq.134.1652189750384; Tue, 10 May 2022 06:35:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652189750; cv=none; d=google.com; s=arc-20160816; b=c9K8WiBTlL7klk15Ca1EQ9WnmtOD0+995Yb52vBwlHtmISc03krUYs08JFjqdtqvOq evhAETI2Z8G2oQSijmBePfNWxgvPGGcxCVk/93j5ruaCzE7g5bY/mFh3bijCH0PH9rA3 ziyvKzKOnfxqDtAsPv9Mg1tg9W6kId2j/gyKug82VWe/zMQ3SeYaV621Rrbbwd6liMC/ Uoeu3uCRNHCsh7p/HEvdaZLD8wtz3Gbnd1xWbN0Hn+EBe8wqFfDuGy+IbuPmPHGaxYDQ Ml12HHrSLAsszgKkH5ZSsH8SD1VyDJTsXtdCDBR5Q4VFPc3BPDUvGNnt8H05uqgC7LYM DoNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=sdNRxDIfnksd3fpkm2K+v0TV8UU/vL/TT0dLoHicC0c=; b=TDgoCVdT0f+JwXWFag7yZ5grNnJJi60/l+LPszlYBDa58GgC4U1N074PGvUfq042cw KOjbtzH5QC9kw7khOV/rWd1sFlaBFp6I31kWig65Z84S6h4rnAcFs04OzJtdYBMYQXcE 9BcuQBdvxJPq+SHTFLivN6a3K2sRB/eh/SjTEJyx41NAf7HZROxSLUjYTBOeHnlRK1w0 gkNSVUhyweihphR8N0gbH64IGeO66uqufBObw56qa0FaE9cIVeFUdBANWSSkbFqannNt Y4QqnT8Kk1ugSRJ/9uj50iI4qm/JLqvOe2V5PHlPKGb53MdM/TXRKagjT3zyH6kNAcC7 F29A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=tVJdCFGA; 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=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d3-20020a170902cec300b00158ea24bbb5si3728926plg.197.2022.05.10.06.35.33; Tue, 10 May 2022 06:35:50 -0700 (PDT) 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=@quicinc.com header.s=qcdkim header.b=tVJdCFGA; 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=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240974AbiEJLaQ (ORCPT + 99 others); Tue, 10 May 2022 07:30:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36608 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240920AbiEJLaB (ORCPT ); Tue, 10 May 2022 07:30:01 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E751154BEC; Tue, 10 May 2022 04:26:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1652181964; x=1683717964; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version; bh=sdNRxDIfnksd3fpkm2K+v0TV8UU/vL/TT0dLoHicC0c=; b=tVJdCFGAmH4+PuiKF0jaUM34Q5mnKrEvTdNfMajyMieRcA1ZTNwVuAfD IEtehKggnUFEp4AMJ/g1RqJcgQ0Mk3CpufWzsT4yBCYlWcFj+NEI0/t4v cXVBQsqjyREEeKdqgYdhsHgeLHvIchqMV2DueAo9+hpx35wfY1Jk2ARaa s=; Received: from ironmsg07-lv.qualcomm.com ([10.47.202.151]) by alexa-out.qualcomm.com with ESMTP; 10 May 2022 04:26:01 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg07-lv.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 May 2022 04:26:01 -0700 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 10 May 2022 04:25:55 -0700 Received: from hu-ylal-hyd.qualcomm.com (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Tue, 10 May 2022 04:25:52 -0700 From: Yogesh Lal To: , CC: , , , Siddharth Gupta , Yogesh Lal Subject: [PATCH 2/2 V2] remoteproc: qcom: Add full coredump fallback mechanism Date: Tue, 10 May 2022 16:55:30 +0530 Message-ID: <1652181930-22212-2-git-send-email-quic_ylal@quicinc.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1652181930-22212-1-git-send-email-quic_ylal@quicinc.com> References: <1652181930-22212-1-git-send-email-quic_ylal@quicinc.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01a.na.qualcomm.com (10.52.223.231) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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: X-Mailing-List: linux-kernel@vger.kernel.org From: Siddharth Gupta If a remoteproc's firmware does not support minidump but the driver adds an ID, the minidump driver does not collect any coredumps when the remoteproc crashes. This hinders the purpose of coredump collection. This change adds a fallback mechanism in the event of a crash. Signed-off-by: Siddharth Gupta Signed-off-by: Yogesh Lal --- drivers/remoteproc/qcom_common.c | 7 +++++-- drivers/remoteproc/qcom_q6v5_pas.c | 1 + 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/remoteproc/qcom_common.c b/drivers/remoteproc/qcom_common.c index 4b91e3c..b3fdc66 100644 --- a/drivers/remoteproc/qcom_common.c +++ b/drivers/remoteproc/qcom_common.c @@ -163,8 +163,11 @@ void qcom_minidump(struct rproc *rproc, unsigned int minidump_id) */ if (subsystem->regions_baseptr == 0 || le32_to_cpu(subsystem->status) != 1 || - le32_to_cpu(subsystem->enabled) != MD_SS_ENABLED || - le32_to_cpu(subsystem->encryption_status) != MD_SS_ENCR_DONE) { + le32_to_cpu(subsystem->enabled) != MD_SS_ENABLED) { + return rproc_coredump(rproc); + } + + if (le32_to_cpu(subsystem->encryption_status) != MD_SS_ENCR_DONE) { dev_err(&rproc->dev, "Minidump not ready, skipping\n"); return; } diff --git a/drivers/remoteproc/qcom_q6v5_pas.c b/drivers/remoteproc/qcom_q6v5_pas.c index 401b1ec..6e5cbca 100644 --- a/drivers/remoteproc/qcom_q6v5_pas.c +++ b/drivers/remoteproc/qcom_q6v5_pas.c @@ -274,6 +274,7 @@ static const struct rproc_ops adsp_minidump_ops = { .start = adsp_start, .stop = adsp_stop, .da_to_va = adsp_da_to_va, + .parse_fw = qcom_register_dump_segments, .load = adsp_load, .panic = adsp_panic, .coredump = adsp_minidump, -- 2.7.4