Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp3061048imj; Mon, 18 Feb 2019 18:50:13 -0800 (PST) X-Google-Smtp-Source: AHgI3IbHylV5asYskSAmxQ/sEodSYEk61+eYT2k0i+U0ejaX+RyHraOW8QMaCZlfWj1ZHFNK3zP4 X-Received: by 2002:a63:f552:: with SMTP id e18mr21855651pgk.239.1550544613158; Mon, 18 Feb 2019 18:50:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550544613; cv=none; d=google.com; s=arc-20160816; b=aieB3fDreZU5Af/qfNnRCSrBLMbQlwpthBk9uRbLuafeXLdId1AJXy86HxMc9sACiR HF5X5iwnBu41BJDMc3P/fbDThtHSX5iPYRhFwgh9wX2iZLtoZdbuBx1O4sVBPLemH59K soAK5l5vxOMT+BZWaDRMVuMsPUJK6kPprV0b4oW9crrG6o5Q+f+2w3P7t/Ko/hFZ6z+L Zj1r10bL0wNVKYbYWluKwYwqTueQC1/7vXmod2P7fy0QBkqWKx1eRVcvMw6Mq9i0o0xg 0Dr2F9uwcNL0A+044/oC1MROIDSqc4KgpkAqwJmrSUrzjRibKSTSw1A0wssGgBh5o5do 0cYw== 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=HUr5kIw7scrkbaKSyMk89/n82/fKxRtDyTxp1NN5/oU=; b=Q7SZ5TNmBjpoklgmL3+9YXHi5wgaWtxieZDGbW/3Qi7UBPvYvRleophdRsEOlCi63O M0EM+ScsjYfhQAX4SAPOtt6Wfcx5KaZwxrNqDcvjoozK2MOSrXV3Dqc+g4KlhVRZb8fu FDqvQXgmGcgeMudVIaaVKVc5L8Uww61wbWs8RwY+nfaYVQr7EwzQALNk6HGjVy4qB2hB Kmd/MR1cCOsE/3Ig/F3N0Hj8UCVQH1p3DLNU2b3KyiCCygdF/k5goqRyY9sNXOjajkIr naO3seozqdLZiwZ44mQRoYP5HboUv+2INjhqORpy6y56vs5WfbCYc6j8fbD8/F1miVsk nj+A== 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 z20si14706999pfd.204.2019.02.18.18.49.57; Mon, 18 Feb 2019 18:50:13 -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 S1732907AbfBSBlG (ORCPT + 99 others); Mon, 18 Feb 2019 20:41:06 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:3776 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1732885AbfBSBlG (ORCPT ); Mon, 18 Feb 2019 20:41:06 -0500 Received: from DGGEMS403-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 392784F5C1F6EE46A44C; Tue, 19 Feb 2019 09:41:04 +0800 (CST) Received: from [127.0.0.1] (10.142.63.192) by DGGEMS403-HUB.china.huawei.com (10.3.19.203) with Microsoft SMTP Server id 14.3.408.0; Tue, 19 Feb 2019 09:40:58 +0800 CC: , , , , , , , , , , , , , , Felipe Balbi , "Greg Kroah-Hartman" , Heikki Krogerus Subject: Re: [PATCH v2 07/10] usb: dwc3: Registering a role switch in the DRD code. To: Valentin Schneider , , , References: <20190218112310.17860-1-chenyu56@huawei.com> <20190218112310.17860-8-chenyu56@huawei.com> <8162929c-0d1b-1081-4be0-d40ed6f752d6@arm.com> From: Chen Yu Message-ID: Date: Tue, 19 Feb 2019 09:40:56 +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: <8162929c-0d1b-1081-4be0-d40ed6f752d6@arm.com> 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 1:30, Valentin Schneider wrote: > Hi, > > On 18/02/2019 11:23, Yu Chen wrote: > [...] >> @@ -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); > > Building arm64 defconfig gives me this: > > drivers/usb/dwc3/drd.o: In function `dwc3_drd_exit': > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:604: undefined reference to `usb_role_switch_unregister' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:604:(.text+0x814): relocation truncated to fit: R_AARCH64_CALL26 against undefined symbol `usb_role_switch_unregister' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:604: undefined reference to `usb_role_switch_unregister' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:604:(.text+0x844): relocation truncated to fit: R_AARCH64_CALL26 against undefined symbol `usb_role_switch_unregister' > drivers/usb/dwc3/drd.o: In function `dwc3_drd_init': > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:562: undefined reference to `usb_role_switch_register' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:562:(.text+0xa20): relocation truncated to fit: R_AARCH64_CALL26 against undefined symbol `usb_role_switch_register' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:562: undefined reference to `usb_role_switch_register' > /home/valsch01/Work/kernel/drivers/usb/dwc3/drd.c:562:(.text+0xb4c): relocation truncated to fit: R_AARCH64_CALL26 against undefined symbol `usb_role_switch_register' > Makefile:1024: recipe for target 'vmlinux' failed > make: *** [vmlinux] Error 1 > > This has CONFIG_USB_ROLE_SWITCH=m, setting it as a built-in makes the thing > linkable. > > I suppose that's because defconfig gives us > > CONFIG_USB_DWC3_DUAL_ROLE=y > > but then that should probably force a CONFIG_USB_ROLE_SWITCH=y. My > immediate reaction to this would be to add: > > --- > diff --git a/drivers/usb/dwc3/Kconfig b/drivers/usb/dwc3/Kconfig > index 2b1494460d0c..661b1d2efc8b 100644 > --- a/drivers/usb/dwc3/Kconfig > +++ b/drivers/usb/dwc3/Kconfig > @@ -44,6 +44,7 @@ config USB_DWC3_DUAL_ROLE > bool "Dual Role mode" > depends on ((USB=y || USB=USB_DWC3) && (USB_GADGET=y || USB_GADGET=USB_DWC3)) > depends on (EXTCON=y || EXTCON=USB_DWC3) > + select USB_ROLE_SWITCH > help > This is the default mode of working of DWC3 controller where > both host and gadget features are enabled. > --- > > Not sure how acceptable that is though. > Thanks for your notice! I will add this in next version. > >> + if (ret) { >> + dwc3_drd_exit(dwc); >> + return PTR_ERR(dwc->role_sw); >> + } >> + >> 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); >> } >> > > . > Thanks Yu Chen