Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4085777rwd; Tue, 23 May 2023 02:55:51 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ5MJK5WszV4Po96zEgSjmCL3pMwPZScI1F27yq0fz9HT3wZJ9vlG/2J/LQyykp/KQEITwy7 X-Received: by 2002:a05:6a20:3d8a:b0:10c:1a3d:6b97 with SMTP id s10-20020a056a203d8a00b0010c1a3d6b97mr4586541pzi.49.1684835750608; Tue, 23 May 2023 02:55:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684835750; cv=none; d=google.com; s=arc-20160816; b=sF1RH/+NIQqc2ylp41yqYGQ5zn09yb0ktvKSCZIwkkyBuPBcgYepLT5iG1vle3m4Dn 7u92eCi4wNcivnYWZ48f+RrEp+uNjeKk83sJ/ZPmk0lVFVTqfRkYV+NLR+8VGmXTTob5 atJxyt3RJ7g51TAsgo88zbGfYje129FdiWz9nOfqj5Pr+zeTAhSb+48MAfCruQGq+61S ZVTI/1zXc5Z06cm6mwRzy19KA26mik2FrytfkzcS3guedMZBQwggVmUcoUvJjRglwRWL 9Ne4A8aVulVKywQBL/7WNTWa7o9yV56KigikKsdHJXbK5D2REEUMsetUi+sDfTOUCFO1 CArw== 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=Wx4vzQMGh0QMOVeZ5m8BC4+mW94IjdyG1lF5Fe88bvg=; b=a9gL/Emi/LHk7RNCjFBPi+DNFYG2W7FfdwIdQHX7xTM4MObIgQ9lO2c+2LW+Ngotxe 292U4nJVsqb0b0hG5Tq/uCcRJkXfFzmBBNVVWIgoCKifiZ+sX5aOiSDC124i08gZJkI7 JIsxg2iJHm09UOHHgePc+X6SfkOp0roODUpy5BElVWeKHaTpPbfScdzAhe+nBSEnFTpv zccsZUzQNECCRYWJfmD7Z9xpYGlVXxMOXU4A6USH7Zgsdg8YaOdapKF+4AVQKR4gbZiU b0n+UXSX0OuBTPdW6Jj2U+clCxyOMj68GXh3EiPlEhlSeEwpuR6CfogaNuhVQBxQ1kj4 v2bw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="MP/7BDPR"; 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 k186-20020a6284c3000000b0064d109bad99si4515006pfd.29.2023.05.23.02.55.35; Tue, 23 May 2023 02:55: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=qcppdkim1 header.b="MP/7BDPR"; 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 S235414AbjEWJmn (ORCPT + 99 others); Tue, 23 May 2023 05:42:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59332 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236355AbjEWJml (ORCPT ); Tue, 23 May 2023 05:42:41 -0400 Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C236194; Tue, 23 May 2023 02:42:39 -0700 (PDT) Received: from pps.filterd (m0279871.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 34N5LQVf029700; Tue, 23 May 2023 09:42:35 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h=message-id : date : mime-version : subject : to : cc : references : from : in-reply-to : content-type : content-transfer-encoding; s=qcppdkim1; bh=Wx4vzQMGh0QMOVeZ5m8BC4+mW94IjdyG1lF5Fe88bvg=; b=MP/7BDPR65h2VIvZWd9VPR0DVPyMZvmreKmEVJl721YgckNZruUYyXi4mnpXpjTJu4RD 8Sle+afTzTeTiZiVraNEo7Ih6Yg6TZSJm7yCm4BjSGLOIjjxSfJa5ijSFQDEkxDfPTOo SIIben13VkZKoYCwskAUNAepuWDt21vwTFQiDy9H5bgC/sZUjnUBoVkiRqG9XokE40lA tBnGdMIsGjFnakDvw6GzNFechoNJDTO9bitYjsXWdG3nOloAcZd3e2Z/FRxS2+R4pboH Dj3TU8j2VpmOHK6W9sJVOvJbd0IZ2u8zULGBH4AA4B1IBFCWkI9Sqm5B3JYLyX7zxJRU zQ== Received: from nasanppmta02.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3qraast4d3-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 23 May 2023 09:42:35 +0000 Received: from nasanex01c.na.qualcomm.com (nasanex01c.na.qualcomm.com [10.45.79.139]) by NASANPPMTA02.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 34N9gYoQ022748 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 23 May 2023 09:42:34 GMT Received: from [10.214.66.81] (10.80.80.8) by nasanex01c.na.qualcomm.com (10.45.79.139) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.42; Tue, 23 May 2023 02:42:31 -0700 Message-ID: Date: Tue, 23 May 2023 15:12:28 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH v3] firmware: qcom_scm: Clear download bit during reboot Content-Language: en-US To: Robert Marko CC: , , , , References: <1678979666-551-1-git-send-email-quic_mojha@quicinc.com> <76943268-3982-deaf-9736-429dd51e01b0@gmail.com> <0e645486-f0be-4468-18ad-9e49088dee0b@quicinc.com> From: Mukesh Ojha In-Reply-To: Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nasanex01c.na.qualcomm.com (10.45.79.139) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: ZljVx8EmCU4izf7ai3YxY4pl45xVL3Ot X-Proofpoint-ORIG-GUID: ZljVx8EmCU4izf7ai3YxY4pl45xVL3Ot X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.254,Aquarius:18.0.957,Hydra:6.0.573,FMLib:17.11.176.26 definitions=2023-05-23_06,2023-05-22_03,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 adultscore=0 suspectscore=0 priorityscore=1501 mlxscore=0 lowpriorityscore=0 mlxlogscore=999 spamscore=0 impostorscore=0 bulkscore=0 malwarescore=0 phishscore=0 clxscore=1015 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2304280000 definitions=main-2305230079 X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_MSPIKE_H2, 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 On 5/22/2023 3:34 PM, Robert Marko wrote: > On Mon, 22 May 2023 at 11:26, Robert Marko wrote: >> >> On Mon, 22 May 2023 at 11:11, Mukesh Ojha wrote: >>> >>> >>> >>> On 5/22/2023 2:29 PM, Robert Marko wrote: >>>> On Mon, 22 May 2023 at 08:11, Mukesh Ojha wrote: >>>>> >>>>> >>>>> >>>>> On 5/18/2023 3:45 PM, Robert Marko wrote: >>>>>> >>>>>> On 16. 03. 2023. 16:14, Mukesh Ojha wrote: >>>>>>> During normal restart of a system download bit should >>>>>>> be cleared irrespective of whether download mode is >>>>>>> set or not. >>>>>>> >>>>>>> Fixes: 8c1b7dc9ba22 ("firmware: qcom: scm: Expose download-mode control") >>>>>>> Signed-off-by: Mukesh Ojha >>>>>> >>>>>> Hi, this has been backported to 5.15.111, however it seems to be >>>>>> breaking reboot >>>>>> on IPQ4019 by causing the board to then hang in SBL with: >>>>>> root@OpenWrt:/# reboot >>>>>> root@OpenWrt:/# [ 76.473541] device lan1 left promiscuous mode >>>>>> [ 76.474204] br-lan: port 1(lan1) entered disabled state >>>>>> [ 76.527975] device lan2 left promiscuous mode >>>>>> [ 76.530301] br-lan: port 2(lan2) entered disabled state >>>>>> [ 76.579376] device lan3 left promiscuous mode >>>>>> [ 76.581698] br-lan: port 3(lan3) entered disabled state >>>>>> [ 76.638434] device lan4 left promiscuous mode >>>>>> [ 76.638777] br-lan: port 4(lan4) entered disabled state >>>>>> [ 76.978489] qca8k-ipq4019 c000000.switch wan: Link is Down >>>>>> [ 76.978883] device eth0 left promiscuous mode >>>>>> [ 76.987077] ipqess-edma c080000.ethernet eth0: Link is Down >>>>>> [ >>>>>> Format: Log Type - Time(microsec) - Message - Optional Info >>>>>> Log Type: B - Since Boot(Power On Reset), D - Delta, S - Statistic >>>>>> S - QC_IMAGE_VERSION_STRING=BOOT.BF.3.1.1-00123 >>>>>> S - IMAGE_VARIANT_STRING=DAABANAZA >>>>>> S - OEM_IMAGE_VERSION_STRING=CRM >>>>>> S - Boot Config, 0x00000021 >>>>>> S - Reset status Config, 0x00000010 >>>>>> S - Core 0 Frequency, 0 MHz >>>>>> B - 261 - PBL, Start >>>>>> B - 1339 - bootable_media_detect_entry, Start >>>>>> B - 1679 - bootable_media_detect_success, Start >>>>>> B - 1693 - elf_loader_entry, Start >>>>>> B - 5076 - auth_hash_seg_entry, Start >>>>>> B - 7223 - auth_hash_seg_exit, Start >>>>>> B - 578349 - elf_segs_hash_verify_entry, Start >>>>>> B - 696356 - PBL, End >>>>>> B - 696380 - SBL1, Start >>>>>> B - 787236 - pm_device_init, Start >>>>>> D - 7 - pm_device_init, Delta >>>>>> B - 788701 - boot_flash_init, Start >>>>>> D - 52782 - boot_flash_init, Delta >>>>>> B - 845625 - boot_config_data_table_init, Start >>>>>> D - 3836 - boot_config_data_table_init, Delta - (419 Bytes) >>>>>> B - 852841 - clock_init, Start >>>>>> D - 7566 - clock_init, Delta >>>>>> B - 864883 - CDT version:2,Platform ID:9,Major ID:0,Minor >>>>>> ID:0,Subtype:64 >>>>>> B - 868413 - sbl1_ddr_set_params, Start >>>>>> B - 873402 - cpr_init, Start >>>>>> D - 2 - cpr_init, Delta >>>>>> B - 877842 - Pre_DDR_clock_init, Start >>>>>> D - 4 - Pre_DDR_clock_init, Delta >>>>>> D - 13234 - sbl1_ddr_set_params, Delta >>>>>> B - 891155 - pm_driver_init, Start >>>>>> D - 2 - pm_driver_init, Delta >>>>>> B - 909105 - Image Load, Start >>>>>> B - 1030210 - Boot error ocuured!. Error code: 303d >>>>>> >>>>>> Reverting the commit fixes rebooting. >>>>> >>>>> Hi Robert, >>>>> >>>>> Can you check if disable SDI [1] works with this issue >>>>> >>>>> https://lore.kernel.org/linux-arm-msm/20230518140224.2248782-1-robimarko@gmail.com/ >>>>> >>>>> [1] >>>>> >>>>> >>>>> diff --git a/drivers/firmware/qcom_scm.c b/drivers/firmware/qcom_scm.c >>>>> index fde33acd46b7..01496ceb7136 100644 >>>>> --- a/drivers/firmware/qcom_scm.c >>>>> +++ b/drivers/firmware/qcom_scm.c >>>>> @@ -1508,6 +1508,7 @@ static int qcom_scm_probe(struct platform_device >>>>> *pdev) >>>>> static void qcom_scm_shutdown(struct platform_device *pdev) >>>>> { >>>>> /* Clean shutdown, disable download mode to allow normal restart */ >>>>> + qcom_scm_disable_sdi(); >>>>> qcom_scm_set_download_mode(false); >>>>> } >>>> >>>> Hi, >>>> I can confirm reboot works this way as well. >>> >>> That's great, So, i don't need to revert the patch and you can >>> add this in your patch without target specific check ? >> >> Oh, you mean IPQ4019 not rebooting? >> I haven't tested that, give me couple of minutes to try that out. >> Cause, the link was just back to the SDI patchset. > > And, I can confirm that IPQ4019 does not reboot even with SDI disabled if dload > mode was set so it still needs a revert. Ok, So, before we go for revert of the change. - How do you generally collect the ram dump on your device on crash ? did you check if you get any error when qcom_scm_set_download_mode() get called. -- Mukesh > > Regards, > Robert >> >> Regards, >> Robert >>> >>> -- Mukesh >>> >>>> >>>> Regards, >>>> Robert >>>>> >>>>> >>>>> -- Mukesh >>>>> >>>>>> >>>>>> Regards, >>>>>> Robert >>>>>> >>>>>>> --- >>>>>>> Changes in v3: >>>>>>> - Added Fixes tag. >>>>>>> - Removed it from below patch series, as it makes sense to go this >>>>>>> independently. >>>>>>> >>>>>>> https://lore.kernel.org/lkml/1677664555-30191-1-git-send-email-quic_mojha@quicinc.com/ >>>>>>> >>>>>>> Changes in v2: >>>>>>> - No change. >>>>>>> >>>>>>> drivers/firmware/qcom_scm.c | 3 +-- >>>>>>> 1 file changed, 1 insertion(+), 2 deletions(-) >>>>>>> >>>>>>> diff --git a/drivers/firmware/qcom_scm.c b/drivers/firmware/qcom_scm.c >>>>>>> index 468d4d5..3e020d1 100644 >>>>>>> --- a/drivers/firmware/qcom_scm.c >>>>>>> +++ b/drivers/firmware/qcom_scm.c >>>>>>> @@ -1506,8 +1506,7 @@ static int qcom_scm_probe(struct platform_device >>>>>>> *pdev) >>>>>>> static void qcom_scm_shutdown(struct platform_device *pdev) >>>>>>> { >>>>>>> /* Clean shutdown, disable download mode to allow normal restart */ >>>>>>> - if (download_mode) >>>>>>> - qcom_scm_set_download_mode(false); >>>>>>> + qcom_scm_set_download_mode(false); >>>>>>> } >>>>>>> static const struct of_device_id qcom_scm_dt_match[] = {