Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp566800rwd; Wed, 14 Jun 2023 21:47:46 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6blQ+bAXuOtLG8yK60kxJgOhy9hqFffAwzF6KfXK2LGxELXurLoGjPLB9tIuBiK1ibdFcI X-Received: by 2002:a17:906:ef0b:b0:965:ff38:2fbb with SMTP id f11-20020a170906ef0b00b00965ff382fbbmr18016813ejs.1.1686804465990; Wed, 14 Jun 2023 21:47:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686804465; cv=none; d=google.com; s=arc-20160816; b=eLRUujWtGvhk8bpY25VaU/ni91xsZYJES44YHOHHpK9kwrv8ii9FFRR1NvNtm+E+yM Rl6utLvZxZf26Dh/N1N2MTzdWhqbvQK9eZ8pxyhNYw1isdlWI+XZ1XG2qW05eTrta2Po fFAt2el+ZQ6GkIaFnZLpeXXLDe1jIx1v9VlEISDc1YS70ETX9drdrs8ra1+ur7NZNR2+ DtRhKYUGLvzKW7jMkhhWheXISP9cCPxUKPNXmYkXKN8IqpLOq1LPWU4/wJ9VFVUeiBsH xL8MWRpV11JHT4PaWWgc290rT7D+Fqy8+8LhkcmuYbR1GH4g8Xt/1ZdTqznzLI1ZymSs hZSw== 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 :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=+sY6EDEo13oPoY5uS3X0Ti3bqtu4p89U+RQaEFX/62I=; b=OEv/xXv/KIfN2BBt+yrIGZGnrYH75Txms5Kq1AEU+d+fEbAuo2ZRZ1ueB7KgTYM3On vjpqZU8m5x5NMOcL9IV5cClqNkxEibBYMRiO50zDqDfCrWp79z25/QiK452w4II9FLKR ny7t1XcIYCzdodDcgBad+Z2/uzAaGXi89sSQbPQ4S8fY3cT1fnVbdAO48stbs0jBvY2M E7qLqTKni1j7wevMvehkiKgnZ9by0DPYzgleMYbitBJTRg2FNZR7XbSvviF5kKKz7Wlk FLGT0GZpCp9k4XWCWGToENWRZhO583uxlUgRQE13FQVRxc56rx3UXnOQsaU4f8TeLPN0 cjbg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=Dnz6uN9p; 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 t25-20020aa7d4d9000000b00518986d6a6esi1446826edr.100.2023.06.14.21.47.21; Wed, 14 Jun 2023 21:47:45 -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=Dnz6uN9p; 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 S243019AbjFOEVb (ORCPT + 99 others); Thu, 15 Jun 2023 00:21:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34318 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243064AbjFOEVT (ORCPT ); Thu, 15 Jun 2023 00:21:19 -0400 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 20DB92132; Wed, 14 Jun 2023 21:21:15 -0700 (PDT) Received: from pps.filterd (m0279864.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 35F3QGAj026798; Thu, 15 Jun 2023 04:21:03 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=+sY6EDEo13oPoY5uS3X0Ti3bqtu4p89U+RQaEFX/62I=; b=Dnz6uN9pxXdwQ90WI84LEoidEYZS2PJQCvKs3HnNonG3u3ATrXC32xMPnWhLwPnfVVDS 6rCOOY9zQW9eyFkIrFfAK+wITzQ3Ko6T5GJRlX8QjiCI4bTQ0BtorYjnooPE48QqaYqA D6xLG/ook6gA991ZnvfWKd/gM0jWHLi3HK1tY0YUYMnFt31+CXACiQQcLFD5u0q/1K+M IX+JkFswc6g/OPHIWsW9tyaNRLoF5LbbOSuJONL4roVU+9f5doP8r/naGn+dmjlP6GXD 9RIFUsXXTSzQbTKL79iToTixAT0URyXvgiO88tLsJaHWCPKD7lf6QU4iJSGKcfKYg4F7 Qg== Received: from nalasppmta04.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3r7ecehgn1-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 15 Jun 2023 04:21:02 +0000 Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com [10.47.209.196]) by NALASPPMTA04.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 35F4L1Z3004586 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 15 Jun 2023 04:21:01 GMT Received: from [10.217.219.188] (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.42; Wed, 14 Jun 2023 21:20:55 -0700 Message-ID: Date: Thu, 15 Jun 2023 09:50:52 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.11.1 Subject: Re: [PATCH v8 6/9] usb: dwc3: qcom: Add multiport controller support for qcom wrapper To: Thinh Nguyen , Johan Hovold , Bjorn Andersson CC: Greg Kroah-Hartman , Philipp Zabel , Andy Gross , Konrad Dybcio , Rob Herring , "Krzysztof Kozlowski" , Felipe Balbi , "linux-usb@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "linux-arm-msm@vger.kernel.org" , "devicetree@vger.kernel.org" , "quic_pkondeti@quicinc.com" , "quic_ppratap@quicinc.com" , "quic_wcheng@quicinc.com" , "quic_jackp@quicinc.com" , "quic_harshq@quicinc.com" , "ahalaney@redhat.com" References: <20230515222730.7snn2i33gkg6ctd2@ripper> <82553597-ce0e-48f4-44d4-9eeaaf4cb1c4@quicinc.com> <99cded6f-6a71-ffce-8479-c7c0726bfb8e@quicinc.com> <279fff8b-57e2-cfc8-cd6d-c69d00e71799@quicinc.com> <20230608175705.2ajrteztdeqdrkzg@synopsys.com> <20230609181602.ljxdchgzl7kzk73n@synopsys.com> Content-Language: en-US From: Krishna Kurapati PSSNV In-Reply-To: <20230609181602.ljxdchgzl7kzk73n@synopsys.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit 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-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: oHSDEarIi8d1j7eoXO90blEX3cBlLXXH X-Proofpoint-ORIG-GUID: oHSDEarIi8d1j7eoXO90blEX3cBlLXXH 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-06-15_02,2023-06-14_02,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 mlxscore=0 clxscore=1015 impostorscore=0 suspectscore=0 spamscore=0 mlxlogscore=999 lowpriorityscore=0 phishscore=0 priorityscore=1501 bulkscore=0 malwarescore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2305260000 definitions=main-2306150036 X-Spam-Status: No, score=-2.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 6/9/2023 11:46 PM, Thinh Nguyen wrote: > On Fri, Jun 09, 2023, Johan Hovold wrote: >> On Thu, Jun 08, 2023 at 05:57:23PM +0000, Thinh Nguyen wrote: >>> On Thu, Jun 08, 2023, Krishna Kurapati PSSNV wrote: >>>> On 6/8/2023 3:12 PM, Johan Hovold wrote: >>>>> On Thu, Jun 08, 2023 at 01:21:02AM +0530, Krishna Kurapati PSSNV wrote: >>>>>> On 6/7/2023 5:07 PM, Johan Hovold wrote: >>>>> >>>>>>> So there at least two issues with this series: >>>>>>> >>>>>>> 1. accessing xhci registers from the dwc3 core >>>>>>> 2. accessing driver data of a child device >>>>>>> >>>>>>> 1. The first part about accessing xhci registers goes against the clear >>>>>>> separation between glue, core and xhci that Felipe tried to maintain. >>>>>>> >>>>>>> I'm not entirely against doing this from the core driver before >>>>>>> registering the xhci platform device as the registers are unmapped >>>>>>> afterwards. But if this is to be allowed, then the implementation should >>>>>>> be shared with xhci rather than copied verbatim. >>> >>> The core will just be looking at the HW capability registers and >>> accessing the ports capability. Our programming guide also listed the >>> host capability registers in its documentation. We're not driving the >>> xhci controller here. We're initializing some of the core configs base >>> on its capability. >>> >>> We're duplicating the logic here and not exactly doing it verbatim. >>> Let's try not to share the whole xhci header where we should not have >>> visibility over. Perhaps it makes sense in some other driver, but let's >>> not do it here. >> >> The patch series even copied the kernel doc verbatim. This is just not >> the way things are supposed to be done upstream. We share defines and >> implementations all the time, but we should not be making copies of >> them. > > We had some fixes to the kernel doc as it's incorrect description. > Perhaps we can fully rewrite the kernel-doc if that what makes it > better. We can share define implementations if they are meant to be > shared. However, with the current way xhci header is implemented, it's > not meant to be shared with dwc3. You agreed that we are violating this > in some driver, but you're also insistent that we should not duplicate > the logic to avoid this violation. Perhaps I'm not a maintainer here > long enough to know some violation is better kept. If sharing the xhci > header is what it takes to get this through, then fine. > >> >>>>>>> >>>>>>> The alternative that avoids this issue entirely could indeed be to >>>>>>> simply count the number of PHYs described in DT as Rob initially >>>>>>> suggested. Why would that not work? >>> >>> See below. >>> >>>>>>> >>>>>> The reason why I didn't want to read the Phy's from DT is explained in >>>>>> [1]. I felt it makes the code unreadable and its very tricky to read the >>>>>> phy's properly, so we decided we would initialize phy's for all ports >>>>>> and if a phy is missing in DT, the corresponding member in >>>>>> dwc->usbX_generic_phy[] would be NULL and any phy op on it would be a NOP. >>>>> >>>>> That doesn't sound too convincing. Can't you just iterate over the PHYs >>>>> described in DT and determine the maximum port number used for HS and >>>>> SS? >>>>>> Also as per Krzysztof suggestion on [2], we can add a compatible to read >>>>>> number of phy's / ports present. This avoids accessing xhci members >>>>>> atleast in driver core. But the layering violations would still be present. >>>>> >>>>> Yes, but if the information is already available in DT it's better to use >>>>> it rather than re-encode it in the driver. >> >>>> Are you suggesting that we just do something like >>>> num_ports = max( highest usb2 portnum, highest usb3 port num) >>> >>> Why do we want to do this? This makes num_ports ambiguous. Let's not >>> sacrifice clarity for some lines of code. >> >> This is not about lines of code, but avoiding the bad practice of >> copying code around and, to some degree, maintaining the separation >> between the glue, core, and xhci which Felipe (perhaps mistakingly) has >> fought for. > > We're talking about combining num_usb3_ports and num_usb2_ports here, > what does that have to do with layer separation? > >> >> If you just need to know how many PHYs you have in DT so that you can >> iterate over that internal array, you can just look at the max index in >> DT where the indexes are specified in the first place. >> >> Don't get hung up on the current variable names, those can be renamed to >> match the implementation. Call it max_ports or whatever. > > It doesn't matter what variable name is given, it doesn't change the > fact that this "num_ports" or "max_ports" obfuscated usb2 vs usb3 ports > just for this specific implementation. So, don't do that. > >> >>>> If so, incase the usb2 phy of quad port controller is missing in DT, we >>>> would still read num_usb2_ports as 4 but the usb2_generic_phy[1] would be >>>> NULL and any phy ops would still be NOP. But we would be getting rid of >>>> reading the xhci registers compeltely in core driver. >>>> >>>> Thinh, Bjorn, can you also let us know your views on this. >>>> >>>> 1. Read: >>>> num_usb3_ports = highest usb3 port index in DT >>>> num_usb2_ports = max( highest usb2 port index, num_usb3_ports) >>>> >>>> 2. Read the same by parsing xhci registers as done in recent versions of >>>> this series. >>> >>> DT is not reliable to get this info. As noted, the DT may skip some >>> ports and still be fine. However, the driver doesn't know which port >>> reflects which port config index without the exact port count. >> >> That's not correct. DT provides the port indexes already, for example: >> >> phy-names = "usb2-port0", "usb3-port0", >> "usb2-port1", "usb3-port1", >> "usb2-port2", >> "usb2-port3"; >> >> So if you just need this to iterate over the PHYs all the information >> needed is here. >> >> If you need to access ports which do not have a PHY described in DT, >> then this is not going to suffice, but I have not seen anyone claim that >> that is needed yet. > > Perhaps I misunderstand the conversation. However, there isn't a method > that everyone's agree on yet regarding DT [*]. Perhaps this indicates it > may not be the best approach. You can resume the conversation if you > want to: > > [*] https://lore.kernel.org/linux-usb/9671cade-1820-22e1-9db9-5c9836414908@quicinc.com/#t > >> >>> More importantly, the host controller that lives on the PCI bus will not >>> use DT. This can be useful for some re-configurations if the controller >>> is a PCI device and that goes through the dwc3 code path. >> >> Ok, this is a bit hand wavy, but if this ever turns out to be needed it >> can also be implemented then. > > What does hand wavy mean? We have case where it's useful outside of > this, and it would be useful for PCI device too: > > https://lore.kernel.org/linux-usb/20230517233218.rjfmvptrexgkpam3@synopsys.com/ > >> >> Or just generalise the xhci implementation for parsing these registers >> and reuse that from the start. (As a bonus you'd shrink the kernel text >> size by getting rid of that iffy inline implementation.) >> > > I don't like the iffy inline function either. We changed that here. To > rework the xhci header and define its global header seems a bit > excessive just for dwc3 to get the port capability. Regardless, as I've > said, if we _must_, perhaps we can just import xhci-ext-caps.h instead > of the whole xhci.h. Hi Thinh, Johan, How about we add compatible data indicating the number of usb2/usb3 ports. That way we needn't parse the DT or read xhci registers atleast as a temporary solution to unblock other patches. Once this series is merged, we can get back to fixing the port count calculation. Does it seem fine ? Regards, Krishna,