Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2728368imj; Mon, 18 Feb 2019 11:03:38 -0800 (PST) X-Google-Smtp-Source: AHgI3IYy9iCPqVshsO/nKD3l2gVizSRapGOGN74oszNswOR39qZKE+kVRKi7wRYtbM82i9/EdB5c X-Received: by 2002:a63:194f:: with SMTP id 15mr20386500pgz.192.1550516618714; Mon, 18 Feb 2019 11:03:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550516618; cv=none; d=google.com; s=arc-20160816; b=vfrlyad5QGiy5+Q4RKe9tdfFjZggbBdxHi2RqZI40HDAtkTP8/tMdQ0m5WUyAmvEyp LFe1MsAo4CzOj+/YJuvb/vPMZXFda0IGa/kcFu9TjFJsLGpAEUOkMfFPm61wzsxBz5AW sYXZTYF5AC7nrFPBLAnJrIsQZ/ebt3Sva+kQ8Y0TEUR3ACz7FavbP2uyZA7Drg/b36oi UMx2cRLXdDu37tZ5h/NfB4rbRMM5GCyiClE8IG9JHPlPPRZUlBSxA8sRflZD7eJVk5aN ZeWp3M06gjD9zGLbfbKFEIdBQGKMAbBjMfTaVZYVzd++2t3qsAmPZeXa5UP9zEtHtPxR TO5w== 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=Y9Ydzah+/6LsQVFzT3X5EOTgMaKIlml1hAkQhlCAkN4=; b=CosUlk8FJuKOHKihyXlsHoXjx5T00rXbjqi/NSixq9Pgf8O1AlLFv70Oh7PL3MIWhL ExEGsAScbjNnZds6IEC90aX5QCsYLUcOBx4VwDDUPXUEDt4JAeoPNlQjMcqGKV/m0cyn yP3hor/wlMUuuddbAYuCxadME8bM1vnOLajzCQB8kA59eUKILZhUuPFGITTaE2ssAUAM NuTMuGXFx+ohPu+AmHqwFPQpCLX1bmJbZEIkRvuSngzD9U7YFoTNSYRKLvTiqkZzomJA mBBmFqrnUlIELjNSHECmwjyEsUrd8ujbsgwhFprAMbPX5aAUX0+YC1XTErihkjslJJhp ZVuw== 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 8si6536581pgf.361.2019.02.18.11.03.23; Mon, 18 Feb 2019 11:03:38 -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 S2387761AbfBRRai (ORCPT + 99 others); Mon, 18 Feb 2019 12:30:38 -0500 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:34856 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731568AbfBRRah (ORCPT ); Mon, 18 Feb 2019 12:30:37 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 1865E15AB; Mon, 18 Feb 2019 09:30:37 -0800 (PST) Received: from [10.1.194.37] (e113632-lin.cambridge.arm.com [10.1.194.37]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id CBE5E3F675; Mon, 18 Feb 2019 09:30:33 -0800 (PST) Subject: Re: [PATCH v2 07/10] usb: dwc3: Registering a role switch in the DRD code. To: Yu Chen , linux-usb@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Cc: john.stultz@linaro.org, suzhuangluan@hisilicon.com, kongfei@hisilicon.com, liuyu712@hisilicon.com, wanghu17@hisilicon.com, butao@hisilicon.com, chenyao11@huawei.com, fangshengzhou@hisilicon.com, lipengcheng8@huawei.com, songxiaowei@hisilicon.com, xuyiping@hisilicon.com, xuyoujun4@huawei.com, yudongbin@hisilicon.com, zangleigang@hisilicon.com, Felipe Balbi , Greg Kroah-Hartman , Heikki Krogerus References: <20190218112310.17860-1-chenyu56@huawei.com> <20190218112310.17860-8-chenyu56@huawei.com> From: Valentin Schneider Message-ID: <8162929c-0d1b-1081-4be0-d40ed6f752d6@arm.com> Date: Mon, 18 Feb 2019 17:30:32 +0000 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: <20190218112310.17860-8-chenyu56@huawei.com> Content-Type: text/plain; charset=utf-8 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 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. > + 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); > } >