Received: by 2002:ab2:6203:0:b0:1f5:f2ab:c469 with SMTP id o3csp1950223lqt; Sun, 21 Apr 2024 17:15:07 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUWnxWVHSsgiyFTNRtbNGWHAxJYmdH0GzSvTOi7NltGF4KNmuFqA1JAIu0rcOc4EPivLVGIF52kuf8DZOQmRbmzEZoN1iIHF/wbaURT5g== X-Google-Smtp-Source: AGHT+IFlOVeXncHLmm9ThOHc/m5Hz6RC78n45ILEbIetyG+bRMblQ2AlL/Z/b7L5cf4tGlLfcxPh X-Received: by 2002:a05:6808:1a:b0:3c6:f5ca:86f8 with SMTP id u26-20020a056808001a00b003c6f5ca86f8mr10132254oic.27.1713744907587; Sun, 21 Apr 2024 17:15:07 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713744907; cv=pass; d=google.com; s=arc-20160816; b=TFuIVDk16ZygD7S8tdfiNopdcYvYt9eAZpoGUU/US9V+G6XUGh3F9eLP7LQ2YRSkl+ Zcsn/cBE8mdb4fsZsPS7Ya8KUMzptNYpb85ugA+s+T/hK7bW/NtdSSoq3gJLurYaQbVQ fJhYmHDWz37d6JWmOwi33DsmQY3AAGVU0WP0+z8XBSxLsv0S5mmL2knUpRAls4vdvnYo UNBzGlQaWYcZ363mrexk3CfMzp8LRk9Wfguw9bE+JTFqRCyBzYmPeWgtGTLy4KzlLsTz 3tTho1ekHHJZMaBVCKgk8NY+5CvUk5fiSX5Mbq6tZZQ7pl4v2LnW9QTLZMHphXNAVSm9 n4jw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=aQEW9jSrB7i2iLc4cs/aY2WU7RH3eD21/w8lP6nqeTw=; fh=6XqS24M901+BCo+ZpyLmoJWXLHvAIySeko9AkkD8vhs=; b=AS4YPoqLCLgOrOgYaZvWIQTY3WSSCze82j0XHF85FtvAYKJDeRi1wMMeSD0XC5B/O+ DOmmGCHR48SkAphKtp36QP9FzeRtfLnw5rAjXVgAa3TCIwUMUVxquizMac5/hti4eGRS DvGdKJXMZ93MZzxnmmRqaaX2u0OdZNgl8TxAbVg4bdgvUHNLwgHXTfgK+w4IOPFoVsmN orXlU62mSZkLvWpakJMWdSDSZpDSvIhZfFJf5R522eZEZFCz48Jb3c2tLE+TtCsBt1lO z9DIF+mqBlRT3e1AOHgNcVubOvEMhr1AS+ss/EGzoA+PQJV0a+AeEoYru0Vj/xzJAHu5 JsbA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=kZDhbe2r; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-bluetooth+bounces-3819-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-3819-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id m14-20020a63f60e000000b005f7717f1068si6625594pgh.854.2024.04.21.17.15.07 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 21 Apr 2024 17:15:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-bluetooth+bounces-3819-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=kZDhbe2r; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-bluetooth+bounces-3819-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-bluetooth+bounces-3819-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 55A30280EDB for ; Mon, 22 Apr 2024 00:15:06 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 96682647; Mon, 22 Apr 2024 00:15:03 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="kZDhbe2r" X-Original-To: linux-bluetooth@vger.kernel.org Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6DD6D184 for ; Mon, 22 Apr 2024 00:15:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.180.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713744903; cv=none; b=qFOmY0xlVEW0qwf43eSri9Qfv7wvE+/Yri4WVEBx6akG22Tdicw49u7qPap6xtd5HI2E6y8zkYGn2v8W2XHZPD6MzLpzPJOvrQXPSLPj9ulVDGv3uiadpCQo7FCPuj4/yoUXnAxvz4IgUUSj3+ASF0JoZUne53QGvUtBbqlC8KY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713744903; c=relaxed/simple; bh=X6bEy64N3+woVIZyJp7cc2chFpf5FbZMQ7y6u029R48=; h=Message-ID:Date:MIME-Version:Subject:To:CC:References:From: In-Reply-To:Content-Type; b=VQrzBB5vhty+sVQnUJqly3eELavqoACq76/xnClzhuGxKgOySPi4WRCZyVFXX8MN+VGKEb9WItq2BCHoSvVGgU1UXdFs5jzpxD21z/kx0tLAlnS9tCxGnIq/3ony2xVlobPRRF6AJNxq78wvQJFwgCiceB3YzaYLbB/i8eh5DZA= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com; spf=pass smtp.mailfrom=quicinc.com; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b=kZDhbe2r; arc=none smtp.client-ip=205.220.180.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=quicinc.com Received: from pps.filterd (m0279872.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 43M03El5027209; Mon, 22 Apr 2024 00:14:39 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=aQEW9jSrB7i2iLc4cs/aY2WU7RH3eD21/w8lP6nqeTw=; b=kZ Dhbe2r1wAtAkuyOxevPW1iwDlb3hz4UgKprD4haYpwJIQHjIOMpNFaCEfKDX2Kc7 Qz1Jf6Jn8X1cPq7dY2yErXj6AaWcUuqYDN/dmoZ+zxQGS08bvlr/25RtYnHigYBZ 5McnWRymSdFN95Nri0rgPguEqXMdUuqegDHaQdpzu8WGpwrUiWWzmhiljpz3itTq YsOR517eri+SsHi/5Qj4pan809hH53ZPrF4wtfQaTmdukMde/zO491MNd+uOQgxr J8rKa7LW1PLArnYe0mXq8O8G+1kuEJueNQ7XF1eRwpfLDvbQ5uOZuuhJcHPHtKrw Lk7CbMyvzXj3S2bNZMxw== Received: from nasanppmta03.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3xm63a2tbr-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Apr 2024 00:14:38 +0000 (GMT) Received: from nasanex01a.na.qualcomm.com (nasanex01a.na.qualcomm.com [10.52.223.231]) by NASANPPMTA03.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 43M0EbL2032360 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 22 Apr 2024 00:14:37 GMT Received: from [10.253.76.25] (10.80.80.8) by nasanex01a.na.qualcomm.com (10.52.223.231) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.9; Sun, 21 Apr 2024 17:14:35 -0700 Message-ID: Date: Mon, 22 Apr 2024 08:14:33 +0800 Precedence: bulk X-Mailing-List: linux-bluetooth@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v4 0/2] Fix two regression issues for QCA controllers To: Krzysztof Kozlowski , Wren Turkal , , , CC: , , References: <1713564212-21725-1-git-send-email-quic_zijuhu@quicinc.com> <1713650800-29741-1-git-send-email-quic_zijuhu@quicinc.com> <369512e2-f091-4370-bce5-9ac32178dc4d@penguintechs.org> Content-Language: en-US From: quic_zijuhu In-Reply-To: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nasanex01a.na.qualcomm.com (10.52.223.231) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: G_oMty2JgoHEi25kb_xxNeCZnhE8M0pQ X-Proofpoint-ORIG-GUID: G_oMty2JgoHEi25kb_xxNeCZnhE8M0pQ X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-04-21_20,2024-04-19_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 suspectscore=0 phishscore=0 bulkscore=0 mlxlogscore=999 clxscore=1011 mlxscore=0 malwarescore=0 adultscore=0 lowpriorityscore=0 spamscore=0 impostorscore=0 priorityscore=1501 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2404010003 definitions=main-2404210147 On 4/22/2024 2:41 AM, Krzysztof Kozlowski wrote: > On 21/04/2024 09:44, Wren Turkal wrote: >> On 4/20/24 3:06 PM, Zijun Hu wrote: >>> This patch series are to fix below 2 regression issues for QCA controllers >>> 1) BT can't be enabled once BT was ever enabled for QCA_QCA6390 >>> 2) BT can't be enabled after disable then warm reboot for QCA_QCA6390 >> >> @Zijun @Krzysztof and @Bartosz Would it be helpful for me to test these >> to ensure they fix the issues I reported? >> > > I look forward to someone testing these on other hardware, not yours. On > the hardware where the original issues were happening leading to this > changes, e.g. RB5. > > Anyway, the problem here is poor explanation of the problem which did > not improve in v3 and v4. Instead I receive explanations like: > > "this is shutdown of serdev and not hdev's shutdown." > Not related... > this is the reply for secondary issue. i believe i have given much explain for my fix for the 2nd issue as shown by below links. let me add a bit more explanation within the ending "For the 2nd issue" section, supposed you known much for generic flag HCI_QUIRK_NON_PERSISTENT_SETUP, otherwise, see header comment for the quirk. also supposed you see commit history to find why qca_serdev_shutdown() was introduced for QCA6390. https://lore.kernel.org/all/fe1a0e3b-3408-4a33-90e9-d4ffcfc7a99b@quicinc.com/ > "now. you understood why your merged change as shown link of 4) have > problems and introduced our discussed issue, right?" > this is the reply for the first issue as shown by below link. it almost have the same description as the following "For 1st issue:" section. i believe it have clear illustration why the commit have bugs. https://lore.kernel.org/all/2166fc66-9340-4e8c-8662-17a19a7d8ce6@linaro.org/ > No. I did not understand and I feel I am wasting here time. > > Code could be correct, could be wrong. Especially second patch looks > suspicious. But the way Zijun Hu explains it and the way Zijun Hu > responds is not helping at all. > > Sorry, with such replies to review, it is not worth my time. > > Best regards, > Krzysztof > Hi luiz,marcel it is time for me to request you give comments for our discussion and for my fixes, Let me explain the 1st issue then 2nd one. For 1st issue: 1) the following commit will cause serious regression issue for QCA controllers, and it has been merged with linus's mainline kernel. Commit 56d074d26c58 ("Bluetooth: hci_qca: don't use IS_ERR_OR_NULL() with gpiod_get_optional()"). 2) the regression issue is described by [PATCH v4 1/2] commit message as following: BT can't be enabled after below steps: cold boot -> enable BT -> disable BT -> warm reboot -> BT enable failure if property enable-gpios is not configured within DT|ACPI for QCA_QCA6390. i will verify and confirm if QCA_QCA2066 and QCA_ROME also are impacted. 3) let me explain the bug point for commit mentioned by 1), its commit message and bug change applet are shown below. The optional variants for the gpiod_get() family of functions return NULL if the GPIO in question is not associated with this device. They return ERR_PTR() on any other error. NULL descriptors are graciously handled by GPIOLIB and can be safely passed to any of the GPIO consumer interfaces as they will return 0 and act as if the function succeeded. If one is using the optional variant, then there's no point in checking for NULL. qcadev->bt_en = devm_gpiod_get_optional(&serdev->dev, "enable", GPIOD_OUT_LOW); - if (IS_ERR_OR_NULL(qcadev->bt_en)) { + if (IS_ERR(qcadev->bt_en)) { dev_warn(&serdev->dev, "failed to acquire enable gpio\n"); power_ctrl_enabled = false; } 3.1) we only need to discuss how to handle case "qcadev->bt_en == NULL" since this is only difference between the commit and BT original design. 3.2) BT original design are agree with the point of above commit message that case "qcadev->bt_en == NULL" should not be treated as error, so BT original design does not do error return for the case and use dev_warn() instead of dev_err() to give. 3.3) the commit misunderstands BT original design and wrongly think BT original design take "qcadev->bt_en == NULL" as error case, so change the following flag power_ctrl_enabled set logic and cause discussed issue. For the 2nd issue: 1) the following commit will cause below regression issue for QCA_QCA6390. Commit 272970be3dab ("Bluetooth: hci_qca: Fix driver shutdown on closed serdev") 2) the regression issue is described by [PATCH v4 2/2] commit message as following: BT can't be enabled after below steps: cold boot -> enable BT -> disable BT -> warm reboot -> BT enable failure if property enable-gpios is not configured within DT|ACPI for QCA_QCA6390. 3) qca_serdev_shutdown() is serdev's shutdown and not hdev's shutdown() it should not and also never get chance to be invoked even if BT is disabled at above 2) step. qca_serdev_shutdown() need to send the VSC to reset controller during warm reset phase of above 2) steps.