Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp3443963imc; Wed, 13 Mar 2019 19:05:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqxenhUN33we5DTet0YPFlYqlPEaGybZ7vgOGW63oha8XRtEmOK1KioknIeT9hhQrVsaWwvm X-Received: by 2002:a63:d5f:: with SMTP id 31mr42670111pgn.274.1552529159458; Wed, 13 Mar 2019 19:05:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552529159; cv=none; d=google.com; s=arc-20160816; b=VhnpejE2eeeTCCPMx154szvLG+d8+Arrb2zbHmzm5c+VeKchryImFkVirdFV0xY29r Jsscd/8iZ+i0VH8YXIoDQzLzHQJgnKRthmh9L87jlXEBMM1aphYdKFnMGiSQV9l4Rmtd U/Vw6HggItrLUhd1SYHPeo+Tga2/3IhnSf/wkAM/+B9WuMNkEeFlhNNdhtvK2pZCcxQ+ e6jXU0ovYoX85lKPrdfi0MXLOTIGJ1Vw34jDz4clBjeutfrRG7go08bg58icZxjvimV5 Dpzm1rgW6y6w/5D57gsWl1nVAultdGecNcQUF27lOmKxhMdUbOODui5qpmn3NT7APBF+ aUJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :references:in-reply-to:date:cc:to:from:subject:message-id; bh=ora25wquqafVbbWwueZp1Rf8QZw5duWKuM2ex71uJ20=; b=xVlyv6wsfx+rBa8Oe1v6XvjjZhDwFAUny0RisjO1zy3I+orUa6DpX34PmdmEokm1mD zh6kPbiEvQUO4z6tRRT3YN4acW2o+6yzjdiaSGtb0BTzUNL0HMsSZZejtD/fmLYEWlKR fx04vteVBUUWfT3y+sZqWGGfZA6wwO2nsCvHPEVcjSZhTZgSvyzWnW0cK9qeX4dyGjDO XHhq1lt7KPEcF84fxcneNt1aUfj+FOlUKu3ElAM5OfgC/2fGByKFPG9PaiFVE+tnfC35 xg+XwMtjNmaS51130L7cEQG/RtSGScvjTPYYz0lCOvnCs5sUmuiJB5QMdRP9S9FRVQkv gTOA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b40si12576287pla.122.2019.03.13.19.05.43; Wed, 13 Mar 2019 19:05:59 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726799AbfCNCFW (ORCPT + 99 others); Wed, 13 Mar 2019 22:05:22 -0400 Received: from Mailgw01.mediatek.com ([1.203.163.78]:19450 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1726487AbfCNCFW (ORCPT ); Wed, 13 Mar 2019 22:05:22 -0400 X-UUID: f58ab9f435b946b18ad59d55f4068951-20190314 X-UUID: f58ab9f435b946b18ad59d55f4068951-20190314 Received: from mtkcas36.mediatek.inc [(172.27.4.253)] by mailgw01.mediatek.com (envelope-from ) (mailgw01.mediatek.com ESMTP with TLS) with ESMTP id 1609118935; Thu, 14 Mar 2019 10:05:18 +0800 Received: from MTKCAS36.mediatek.inc (172.27.4.186) by MTKMBS31DR.mediatek.inc (172.27.6.102) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Thu, 14 Mar 2019 10:05:16 +0800 Received: from [10.17.3.153] (172.27.4.253) by MTKCAS36.mediatek.inc (172.27.4.170) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Thu, 14 Mar 2019 10:05:14 +0800 Message-ID: <1552529114.10179.113.camel@mhfsdcap03> Subject: Re: [PATCH 1/5] dt-bindings: connector: add optional properties for Type-B From: Chunfeng Yun To: Hans de Goede CC: Rob Herring , Greg Kroah-Hartman , Heikki Krogerus , Mark Rutland , Matthias Brugger , Adam Thomson , Li Jun , "Badhri Jagan Sridharan" , Andy Shevchenko , Min Guo , , , , , Date: Thu, 14 Mar 2019 10:05:14 +0800 In-Reply-To: <0c3ca095-9077-0b9d-839f-61ebc066e3f9@redhat.com> References: <1552025622-15582-1-git-send-email-chunfeng.yun@mediatek.com> <1552025622-15582-2-git-send-email-chunfeng.yun@mediatek.com> <693b11e7-fa9e-ab1f-561a-beb758b1872f@redhat.com> <1552282383.10179.21.camel@mhfsdcap03> <1552360688.10179.55.camel@mhfsdcap03> <464f1021-4c5e-9137-489d-65fd578575d3@redhat.com> <1552472109.10179.103.camel@mhfsdcap03> <0c3ca095-9077-0b9d-839f-61ebc066e3f9@redhat.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.2.3-0ubuntu6 Content-Transfer-Encoding: 7bit MIME-Version: 1.0 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Wed, 2019-03-13 at 11:18 +0100, Hans de Goede wrote: > Hi, > > On 3/13/19 11:15 AM, Chunfeng Yun wrote: > > Hi, > > On Tue, 2019-03-12 at 13:45 +0100, Hans de Goede wrote: > >> Hi, > >> On 12-03-19 04:18, Chunfeng Yun wrote: > >>> Hi, > >>> On Mon, 2019-03-11 at 09:06 +0100, Hans de Goede wrote: > >>>> Hi, > >>>> > >>>> On 11-03-19 06:33, Chunfeng Yun wrote: > >>>>> Hi, > >>>>> > >>>>> On Fri, 2019-03-08 at 13:07 +0100, Hans de Goede wrote: > >>>>>> Hi, > >>>>>> > >>>>>> On 08-03-19 07:13, Chunfeng Yun wrote: > >>>>>>> Add id-gpios, vbus-gpios, vbus-supply and pinctrl properties for > >>>>>>> usb-b-connector > >>>>>>> > >>>>>>> Signed-off-by: Chunfeng Yun > >>>>>>> --- > >>>>>>> .../devicetree/bindings/connector/usb-connector.txt | 10 ++++++++++ > >>>>>>> 1 file changed, 10 insertions(+) > >>>>>>> > >>>>>>> diff --git a/Documentation/devicetree/bindings/connector/usb-connector.txt b/Documentation/devicetree/bindings/connector/usb-connector.txt > >>>>>>> index a9a2f2fc44f2..7a07b0f4f973 100644 > >>>>>>> --- a/Documentation/devicetree/bindings/connector/usb-connector.txt > >>>>>>> +++ b/Documentation/devicetree/bindings/connector/usb-connector.txt > >>>>>>> @@ -17,6 +17,16 @@ Optional properties: > >>>>>>> - self-powered: Set this property if the usb device that has its own power > >>>>>>> source. > >>>>>>> > >>>>>>> +Optional properties for usb-b-connector: > >>>>>>> +- id-gpios: gpio for USB ID pin. > >>>>>> > >>>>>> What about boards where the ID pin is *not* connected to a GPIO, > >>>>>> but e.g. to a special pin on the PMIC which can also detect > >>>>>> an ACA adapter ? Currently this case is handled by extcon > >>>>>> drivers, but we have no way to set e.g. vbus-supply for the > >>>>>> connector. Maybe in this case the usb-connector node should > >>>>>> be a child of the PMIC node ? > >>>>> Yes, it would be, PMIC is in charger of detecting the status of ID pin > >>>> > >>>> Ok, then I think this should be documented too. > >>>> > >>>>>> And in many cases there also is a mux to switch the datalines > >>>>>> between the host and device(gadget) controllers, how should > >>>>>> that be described in this model? See the new usb-role-switch > >>>>>> code under drivers/usb/roles > >>>>>> > >>>>>> In some cases the mux is controlled through a gpio, so we > >>>>>> may want to add a "mux-gpios" here in which case we also > >>>>>> need to define what 0/1 means. > >>>>> I'm not sure, the mux seems not belong to this connector, > >>>>> and may need another driver to register usb-role-switch, > >>>>> similar to: > >>>>> > >>>>> [v2,2/2] usb: typec: add typec switch via GPIO control > >>>>> https://patchwork.kernel.org/patch/10834327/ > >>>> > >>>> Right the mux/role-switch will need a driver, but the "owner" > >>>> of the usb_connector, e.g. the PMIC or the owner of the > >>>> id GPIO pin needs to know which device is the role-switch so > >>>> that it can set the role correctly based on the id-pin. > >>>> > >>>> Your binding already contains Vbus info, allowing the owner > >>>> of the usb_connector to enable/disable Vbus based on the id-pin, > >>>> but the owner will also be responsible for setting the role-switch. > >>> In this patch series, I make usb_connector driver enable/disable Vbus, > >>> but not the parent(USB controller) of usb_connector which registers a > >>> usb-role-switch, which way do you think it is better? > >> > >> IMHO there should not be a driver for the usb_connector child-node, > >> only for the parent-device of that child-node. > > If so, each USB controller driver should process this special case by > > itself when use a gpio to detect the status of ID pin, it's not a > > friendly way. And it's easy by using extcon-usb-gpio driver before, so > > we also want to provide a simple way when support usb_connector, no > > matter what method we choose. > > > > Ideally, the only one thing that USB controller driver need to do, just > > register a usb-role-switch, and leave decision when switch the role to > > other drivers, such as type-C, PMIC/charger, also include gpio > > > >> > >> There are going to be too many specific setups surrounding PMICs to > >> be able to do a single generic driver for the connector. > >> > > Fortunately, these patches only focus on the simplest gpio driven role > > switch :) > > In that case there should be an extra compatible added to the > usb_b_connector node to which the "simple gpio" driver binds, > so that not all devicetree-s declaring a usb_b_connector child-node > automatically get that driver bound, Yes > and the gpio / vbus > properties should be mandatory properties for usb_b_connector > child nodes declaring the extra compatible, rather then being > optional for the generic compatible. At least one of id-gpios and vbus-gpios should exist, so both of them are optional, of course if only vbus-gpios exists, then only device mode is supported, in this case vbus is also optional. > > Regards, > > Hans >