Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp2864827imc; Wed, 13 Mar 2019 03:19:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqxnpmkjVk5TcKBqqk1yHfRxdf11BBxx07HASpM1JVUISbGBnxelUCy4vDRyd0LK7nEDmYDp X-Received: by 2002:a17:902:9008:: with SMTP id a8mr45021949plp.38.1552472364166; Wed, 13 Mar 2019 03:19:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552472364; cv=none; d=google.com; s=arc-20160816; b=uOeFtqeFI5gTl6zyQ+b60ugb5sTt8D1LWCT4nnueTO8UeZGj0qQ5j7LaOsfMw6KHcF FKHnp75lrdDdMVGqqI89h+aJW249Q5PKTgpzNswNOhtHPD3GlpZ8djX4ApmjLxRtjjxt DQwLc+s7mCJi1e4fUlDyDCv40uuxCk+Nkcmt+fwzHOJGFzqexu6nTUiRJqHJ3RlDSBqJ 6bGJJMiW0wv5TplgY58U/XP9JF3MiPAFsB4Y2kl7tUr8acPBWzhWzRWPIJhiowIdBeFG Wx1cSxMpjmydB/+1fyiGVt7lJYG8HbWEwI8l1I+vwvzt+eDO2s/qSfpKJFjB7aANlV/E D/5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=W3+Jgu/yOqujgJps7ypf/fZN8vBKP5UggvbHzLz7Ylw=; b=QCJP+yb2QAhyRQc7ZBorgcy24Ncw2ZXHqfAR29OM4kW51kPWHvaKVn7C7qnPxUjtzB QrkWmkfZ5MEgFwTYhLI2GVHnIm4PnJ5eBO46kih5VzHetjIjjJuVkb01kOFeZvyQsxSQ uNVhX/B8PgMbehxmlrvYkEkl0X4eJOI3FbG2qd6FGXZs33u2yTHP/67UhHeoW7StVpPl y8KoZp/YSQVPAcSIt5dKKAmsqXTFtH4YOa84Y+DUWv2LXzD0YxpT99GH6UXDU1oZ2Zk+ SRapv1wp5G5q6xWX1cT8XHSEvFe6gdq2wkleX57mf4OYY85kTid+BjYfeguEacSSVWFk Zgxg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v3si9186521pgr.11.2019.03.13.03.19.07; Wed, 13 Mar 2019 03:19:24 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726396AbfCMKSn (ORCPT + 99 others); Wed, 13 Mar 2019 06:18:43 -0400 Received: from mail-ed1-f67.google.com ([209.85.208.67]:43193 "EHLO mail-ed1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726130AbfCMKSm (ORCPT ); Wed, 13 Mar 2019 06:18:42 -0400 Received: by mail-ed1-f67.google.com with SMTP id m35so979879ede.10 for ; Wed, 13 Mar 2019 03:18:40 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=W3+Jgu/yOqujgJps7ypf/fZN8vBKP5UggvbHzLz7Ylw=; b=C+fISO4x5uXFiii4ckyGC/KArXcz+EWXQ0i7uOmqYeZHU2GHAmOx2BSIJwxuyE9Fb4 BeZHefoDWpOUBbivfJP1wi8uMAvySZ+VhZ7iQZdDpLk+FAnvyEYmlQjmKFaLCOQ6pKLj Cwk66x4sHRl3FDL/Vl7QGfU5lGQQQEMt3Pm/UQAqMHTne0gs1tiNZheybOXpWilK6ZCJ JEUGwdVq62O3kYjMd8xIVMd53k6e40Y5z5upvlOAEgL64hLTj57FASahgfVfbP5aYC1A Kp4ybIaXib9tyFSeR3noMHycQXJhqTyp48pEF9zN1gtleBAtTJoMfDUDsLKal1Rgb+Fd S4dg== X-Gm-Message-State: APjAAAUSVs8VmmIq6P81hPoG2n369WG9TOP8b9VwLaE54YkmqXTMb9L3 DiAf+sYdUQtBFHvjWfigL3GLRw== X-Received: by 2002:a17:906:f101:: with SMTP id gv1mr28540979ejb.73.1552472320230; Wed, 13 Mar 2019 03:18:40 -0700 (PDT) Received: from dhcp-44-202.space.revspace.nl ([2a01:4f8:1c0c:6c86:46e0:a7ad:5246:f04d]) by smtp.gmail.com with ESMTPSA id n19sm346493eja.38.2019.03.13.03.18.38 (version=TLS1_3 cipher=AEAD-AES128-GCM-SHA256 bits=128/128); Wed, 13 Mar 2019 03:18:39 -0700 (PDT) Subject: Re: [PATCH 1/5] dt-bindings: connector: add optional properties for Type-B To: Chunfeng Yun Cc: Rob Herring , Greg Kroah-Hartman , Heikki Krogerus , Mark Rutland , Matthias Brugger , Adam Thomson , Li Jun , Badhri Jagan Sridharan , Andy Shevchenko , Min Guo , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-usb@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org 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> From: Hans de Goede Message-ID: <0c3ca095-9077-0b9d-839f-61ebc066e3f9@redhat.com> Date: Wed, 13 Mar 2019 11:18:37 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: <1552472109.10179.103.camel@mhfsdcap03> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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, 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. Regards, Hans