Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp3090248imj; Mon, 18 Feb 2019 19:38:32 -0800 (PST) X-Google-Smtp-Source: AHgI3IaHuOGGRPzP1GzisZDFj3KbvQ6BSdi9DnxwDNlZG09wVIkzfXkgmZRKuLyzj1mEwMFRGAGn X-Received: by 2002:a63:e84c:: with SMTP id a12mr25646842pgk.241.1550547512322; Mon, 18 Feb 2019 19:38:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550547512; cv=none; d=google.com; s=arc-20160816; b=AtZwyef6sAAKmoHIAGCDd93+uR9jr2yqYsAE4G8TwuIe56jklQqA+V1KucMI+jmgXT NXDE0HEHUcSzYxyOV5lQXu2GojE5TUQiC4Fzn8H3gSkve36qsnBNazmVY7/qKvVRsWBV LR/oJI427afW1XyRggCgv1K7lWQJp3WcT5XqEDUdOrTELXoDpLBOYYCqFzmXbA0Y2Bu4 2VR+h7DloecJ3X5C7xpqKuw/Qees2upmoodOkkd1hlLW3EfiY+ED23fWWvA+ZuecUaR0 Eqg2lLzS0+sxNkuTkvlUg8pt4DmMQu7TwCBbSEq0YCAczGJkYmDb+cYIgC/KVSwURIqn 41jA== 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:to:subject:cc; bh=8dKVkKhZaV6vtpqQ7W8Z8Zue6y3ic0Xrrf3kRVeFwqY=; b=yPNHzltgk8YJWV7xjWwm7oEnnzwu353/iY8zcxme7ByzQjfqhQ4biCgz84i1gAHwzO yaMoGp0Olwl3zpaMFN3QprIX+KX+K3KXQO0G5a3TUypk2Ol09YmyIRaFrjGUZn3VW9BV FYU4biJX6nBiRPAxEpgRreueJIG7BmNhoOa5lN8sX5TELCKxwwZHrQT9BatLndTvI3iK fZg4zhaCFLqMZg/5R15I45/NBQqe5GOZwX8WF1/ZnyxmGR+5o9v/TM6utvoEOd6rb03k Pm4WXGmW34NzVgLzUmmGJAZKoK3FYcb21XDI2esJsvT5evQfZ8j0YCJGgLo6TVI9gvNn zx/g== 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 u8si15855550plh.385.2019.02.18.19.38.17; Mon, 18 Feb 2019 19:38:32 -0800 (PST) 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 S1726154AbfBSDhr (ORCPT + 99 others); Mon, 18 Feb 2019 22:37:47 -0500 Received: from szxga07-in.huawei.com ([45.249.212.35]:41942 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1725536AbfBSDhr (ORCPT ); Mon, 18 Feb 2019 22:37:47 -0500 Received: from DGGEMS406-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 692623ED6A6C00D1E62B; Tue, 19 Feb 2019 11:37:45 +0800 (CST) Received: from [127.0.0.1] (10.142.63.192) by DGGEMS406-HUB.china.huawei.com (10.3.19.206) with Microsoft SMTP Server id 14.3.408.0; Tue, 19 Feb 2019 11:37:35 +0800 CC: , , , , , , , , , , , , , , , , , Felipe Balbi , "Greg Kroah-Hartman" , Heikki Krogerus , Li Jun Subject: Re: [PATCH v2 07/10] usb: dwc3: Registering a role switch in the DRD code. To: Jun Li References: <20190218112310.17860-1-chenyu56@huawei.com> <20190218112310.17860-8-chenyu56@huawei.com> From: Chen Yu Message-ID: <39e822a2-54fb-f4ac-4471-ed8312acf53e@huawei.com> Date: Tue, 19 Feb 2019 11:37:33 +0800 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.142.63.192] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 2019/2/19 10:57, Jun Li wrote: >> >> +static int dwc3_usb_role_switch_set(struct device *dev, enum usb_role role) >> +{ >> + u32 mode; >> + >> + switch (role) { >> + case USB_ROLE_HOST: >> + mode = DWC3_GCTL_PRTCAP_HOST; >> + break; >> + case USB_ROLE_DEVICE: >> + mode = DWC3_GCTL_PRTCAP_DEVICE; >> + break; >> + default: >> + mode = DWC3_GCTL_PRTCAP_HOST; > > I'd propose let dwc3 stay at device mode at default case. > Setting mode to DWC3_GCTL_PRTCAP_HOST at default case due to the requirement of Hikey960 board. When there is no cable connected to type-C port, dwc3 should be set to HOST mode and the hub on the Hikey960 will be power on. Here is the details of the Hikey960: https://www.96boards.org/documentation/consumer/hikey/hikey960/hardware-docs/hardware-user-manual.md.html But I will check the code to see if it is possible to make dwc3 set to device mode at default case. >> + break; >> + }; >> + >> + dwc3_set_mode(dev_get_drvdata(dev), mode); >> + return 0; >> +} >> + >> +static enum usb_role dwc3_usb_role_switch_get(struct device *dev) >> +{ >> + struct dwc3 *dwc = dev_get_drvdata(dev); >> + unsigned long flags; >> + enum usb_role role; >> + >> + spin_lock_irqsave(&dwc->lock, flags); >> + role = dwc->current_otg_role; >> + spin_unlock_irqrestore(&dwc->lock, flags); >> + >> + return role; >> +} >> + >> int dwc3_drd_init(struct dwc3 *dwc) >> { >> + struct usb_role_switch_desc dwc3_role_switch = {0}; >> int ret, irq; >> >> dwc->edev = dwc3_get_extcon(dwc); >> @@ -522,6 +556,15 @@ int dwc3_drd_init(struct dwc3 *dwc) >> dwc3_set_mode(dwc, DWC3_GCTL_PRTCAP_OTG); >> } >> >> + dwc3_role_switch.fwnode = dev_fwnode(dwc->dev); >> + dwc3_role_switch.set = dwc3_usb_role_switch_set; >> + dwc3_role_switch.get = dwc3_usb_role_switch_get; >> + dwc->role_sw = usb_role_switch_register(dwc->dev, &dwc3_role_switch); >> + if (ret) { >> + dwc3_drd_exit(dwc); >> + return PTR_ERR(dwc->role_sw); >> + } >> + > > My understanding is, if you use usb role switch, you don't need either edev or > OTG block event, so this should be like: > > if (device_property_read_bool(dwc->dev, "usb-role-switch")) { > usb role switch register; > } else if (edev) { > ... > } else { > ... > } Yes. Thanks! > > Jun >> return 0; >> } >> >> @@ -557,4 +600,6 @@ void dwc3_drd_exit(struct dwc3 *dwc) >> >> if (!dwc->edev) >> free_irq(dwc->otg_irq, dwc); >> + >> + usb_role_switch_unregister(dwc->role_sw); >> } >> -- >> 2.15.0-rc2 >> > > . > Thanks Yu Chen