Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp7729009ioo; Fri, 3 Jun 2022 12:11:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyykqaX3fGgBjS1hiijLMjdZBxo2FDiSt2trqia7BG0zElyxCwKC5gWGFUrWS4BQ/ZoKkqA X-Received: by 2002:a17:906:358b:b0:70c:f353:dd24 with SMTP id o11-20020a170906358b00b0070cf353dd24mr6109444ejb.355.1654283518331; Fri, 03 Jun 2022 12:11:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654283518; cv=none; d=google.com; s=arc-20160816; b=dbQtbL27QxoXZ9SOz4lKGa3f4Pb7eQFYK4hrffxsB6v0WClNaMKmqDja7Nnb30Zmhj buy0RNVkgXypBxlZD9JtqmOxBk7fd2a9aVjQYZ0kM8xuvY9+rhtyvWMpzPKazWpcbfu0 GdVacKdRn18UUsCuBm69UJ3V+jd1dwKneILFNWay0eBW3fzCOl6nBKv0apCBX9lEGuq9 +M4zCHzNc/MR/oYM68aZtvFLHGLKTyVC9kqUKV0jgyI9bem5USKyna5sdJiL0+kfAiSA eXqfqX5ZajqPKuo1m7D+9hOcAeS7p8Ql14DmGnN0cJz1SWLMmuvKiIOP4p2cmMR29POj SPtQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=Urv0hy64qRO+iwE9n3rXyY/3KPM/CjLWoCQfis2GBoo=; b=KY6urfm3zheJIl5Pi8kW+jgaUwyaqhIFraFS1k4xvrfqcCxnIBagb8s9845U7nFllm 6tvkmjiZcoMdmAsWUGx9oWuKCf+387Hemu9U2B1uchMdVzKmz4gPs8jGdimCbNf6+hrp uZUs5vaV3HpyvWCu7UZd80ypMnU0SvP3yQQWLez5qVGhANwQO4+7SfMcm3InOxHH2XIb BesHwjdxkhrTsAvDUrzB5TUtkkjs0jOSUMKLFAtEq4236nXKqGe///OKRMJm/4vyFI4c St2sNfasIdxQUdv+dlzu4OZZVkO3RU4tauaoO3fD8ovYs7TWOxStV1E4/HIZT+G3Wkzp 9OpQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b="p/oeStjf"; 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 hs41-20020a1709073ea900b006eff1450aebsi3292525ejc.691.2022.06.03.12.11.32; Fri, 03 Jun 2022 12:11:58 -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="p/oeStjf"; 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 S1344272AbiFCRM6 (ORCPT + 99 others); Fri, 3 Jun 2022 13:12:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57988 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1343523AbiFCRM5 (ORCPT ); Fri, 3 Jun 2022 13:12:57 -0400 Received: from alexa-out.qualcomm.com (alexa-out.qualcomm.com [129.46.98.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4E65F31DE0; Fri, 3 Jun 2022 10:12:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1654276373; x=1685812373; h=from:to:cc:subject:date:message-id:mime-version; bh=Urv0hy64qRO+iwE9n3rXyY/3KPM/CjLWoCQfis2GBoo=; b=p/oeStjf4tVuYJj6PW7xuv97ix5YP/BiUYE15WBKhW7kSTKkWXiNdLIv jlxAgpc62KfveilT8mVVwJ+mMrtJbfhoEbz9KzGDVvopxqeg2orvQOXcE mcygNFwoMW+gRh3Fdhmh/WMJ5Py53pcJMn4nTI8spGLYsLmimFrzE0inz M=; Received: from ironmsg08-lv.qualcomm.com ([10.47.202.152]) by alexa-out.qualcomm.com with ESMTP; 03 Jun 2022 10:12:52 -0700 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg08-lv.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Jun 2022 10:12:52 -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; Fri, 3 Jun 2022 10:12:51 -0700 Received: from hu-harshq-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; Fri, 3 Jun 2022 10:12:47 -0700 From: Harsh Agarwal To: Greg Kroah-Hartman , Rob Herring , Philipp Zabel , "Krzysztof Kozlowski" , Felipe Balbi , Bjorn Andersson CC: , , , , , , , Harsh Agarwal Subject: [PATCH v2 0/3] Add support for multiport controller Date: Fri, 3 Jun 2022 22:42:39 +0530 Message-ID: <1654276362-28930-1-git-send-email-quic_harshq@quicinc.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,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 Currently the DWC3 driver supports only single port controller which requires at most two PHYs ie HS and SS PHYs. There are SoCs that has DWC3 controller with multiple ports that can operate in host mode. Some of the port supports both SS+HS and other port supports only HS mode. This change refactors the PHY logic to support multiport controller. The implementation has been tested with Generic PHYs as well. For any multiport controller we would define a new node "multiport" inside dwc3 and then add subsequent "mport" nodes inside it for individual ports that it supports. Now each individual "mport" node defines their own PHYs. e.g. Consider a Dual port controller where each port supports HS+SS multiport { mp_1: mport1 { usb-phy = , ; /* Can define Generic PHYs also */ }; mp_2: mport2 { usb-phy = , ; }; Changes in v2: Changed dwc3_count_phys to return the number of PHY Phandles in the node. This will be used now in dwc3_extract_num_phys to increment num_usb2_phy and num_usb3_phy. Added new parameter "ss_idx" in dwc3_core_get_phy_ny_node and changed its structure such that the first half is for HS-PHY and second half is for SS-PHY. In dwc3_core_get_phy, for multiport controller, only if SS-PHY phandle is present, pass proper SS_IDX else pass -1. Harsh Agarwal (3): dt-bindings: usb: dwc3: Add support for multiport related properties usb: phy: Add devm_of_usb_get_phy_by_phandle usb: dwc3: Refactor PHY logic to support Multiport Controller .../devicetree/bindings/usb/snps,dwc3.yaml | 55 +++ drivers/usb/dwc3/core.c | 403 +++++++++++++++------ drivers/usb/dwc3/core.h | 12 +- drivers/usb/dwc3/drd.c | 16 +- drivers/usb/dwc3/gadget.c | 4 +- drivers/usb/phy/phy.c | 34 ++ include/linux/usb/phy.h | 8 + 7 files changed, 402 insertions(+), 130 deletions(-) -- 2.7.4