kernel: mark kmod-usb-phy-nop as hidden to avoid building it where it is not needed
[openwrt.git] / package / kernel / linux / modules / usb.mk
index ab7c5dd828f901690f4edc037cd6894c2467a356..882809fc09ce524714d148b93bbabb397ade6cc1 100644 (file)
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2006-2012 OpenWrt.org
+# Copyright (C) 2006-2014 OpenWrt.org
 #
 # This is free software, licensed under the GNU General Public License v2.
 # See /LICENSE for more information.
@@ -49,8 +49,7 @@ define KernelPackage/usb-musb-hdrc
        CONFIG_USB_MUSB_DEBUG=y
   DEPENDS:= \
        @(TARGET_omap||TARGET_omap24xx) +kmod-usb-gadget \
-       +TARGET_omap24xx:kmod-usb-musb-tusb6010 \
-       +TARGET_omap:kmod-usb-musb-platformglue
+       +TARGET_omap24xx:kmod-usb-musb-tusb6010
   FILES:=$(LINUX_DIR)/drivers/usb/musb/musb_hdrc.ko
   AUTOLOAD:=$(call AutoLoad,46,musb_hdrc)
   $(call AddDepends/usb)
@@ -67,11 +66,15 @@ define KernelPackage/usb-musb-platformglue
   TITLE:=MUSB platform glue layer
   KCONFIG:= \
        CONFIG_USB_MUSB_TUSB6010=n \
-       CONFIG_USB_MUSB_OMAP2PLUS \
-       CONFIG_USB_MUSB_AM35X \
-       CONFIG_USB_MUSB_DSPS=n\
+       CONFIG_USB_MUSB_OMAP2PLUS=n \
+       CONFIG_USB_MUSB_AM35X=n \
+       CONFIG_USB_MUSB_DSPS \
        CONFIG_USB_MUSB_UX500=n
-  DEPENDS:=@TARGET_omap
+  DEPENDS:=@TARGET_omap +kmod-usb-phy-nop +kmod-usb-musb-hdrc +kmod-usb-phy-am335x
+  FILES:= \
+       $(LINUX_DIR)/drivers/usb/musb/musb_dsps.ko \
+       $(LINUX_DIR)/drivers/usb/musb/musb_am335x.ko
+  AUTOLOAD:=$(call AutoLoad,45,phy-omap-control musb_dsps musb_am335x)
   $(call AddDepends/usb)
 endef
 
@@ -99,8 +102,19 @@ $(eval $(call KernelPackage,usb-musb-tusb6010))
 define KernelPackage/usb-phy-nop
   TITLE:=Support for USB NOP transceiver
   KCONFIG:=CONFIG_NOP_USB_XCEIV
+  HIDDEN:=1
+ifneq ($(wildcard $(LINUX_DIR)/drivers/usb/phy/phy-generic.ko),)
   FILES:=$(LINUX_DIR)/drivers/usb/phy/phy-generic.ko
-  AUTOLOAD:=$(call AutoLoad,45,phy-generic)
+  AUTOLOAD:=$(call AutoLoad,43,phy-generic)
+else
+ifneq ($(wildcard $(LINUX_DIR)/drivers/usb/phy/phy-nop.ko),)
+  FILES:=$(LINUX_DIR)/drivers/usb/phy/phy-nop.ko
+  AUTOLOAD:=$(call AutoLoad,43,phy-nop)
+else
+  FILES:=$(LINUX_DIR)/drivers/usb/otg/nop-usb-xceiv.ko
+  AUTOLOAD:=$(call AutoLoad,43,nop-usb-xceiv)
+endif
+endif
   $(call AddDepends/usb)
 endef
 
@@ -113,10 +127,14 @@ $(eval $(call KernelPackage,usb-phy-nop))
 
 define KernelPackage/usb-phy-am335x
   TITLE:=Support for AM335x USB PHY
-  KCONFIG:=CONFIG_AM335X_PHY_USB
+  KCONFIG:= \
+       CONFIG_AM335X_PHY_USB \
+       CONFIG_AM335X_CONTROL_USB
   DEPENDS:=@TARGET_omap +kmod-usb-phy-nop
-  FILES:=$(LINUX_DIR)/drivers/usb/phy/phy-am335x.ko
-  AUTOLOAD:=$(call AutoLoad,45,phy-am335x)
+  FILES:= \
+       $(LINUX_DIR)/drivers/usb/phy/phy-am335x.ko \
+       $(LINUX_DIR)/drivers/usb/phy/phy-am335x-control.ko
+  AUTOLOAD:=$(call AutoLoad,44,phy-am335x)
   $(call AddDepends/usb)
 endef
 
@@ -127,6 +145,26 @@ endef
 $(eval $(call KernelPackage,usb-phy-am335x))
 
 
+define KernelPackage/usb-phy-omap-usb2
+  TITLE:=Support for OMAP2 USB PHY
+  KCONFIG:= \
+       CONFIG_OMAP_USB2 \
+       CONFIG_OMAP_CONTROL_USB
+  DEPENDS:=@TARGET_omap
+  FILES:= \
+       $(LINUX_DIR)/drivers/phy/phy-omap-usb2.ko \
+       $(LINUX_DIR)/drivers/usb/phy/phy-omap-control.ko
+  AUTOLOAD:=$(call AutoLoad,45,phy-omap-control phy-omap-usb2)
+  $(call AddDepends/usb)
+endef
+
+define KernelPackage/usb-phy-omap-usb2/description
+  Support for AM335x USB PHY
+endef
+
+$(eval $(call KernelPackage,usb-phy-omap-usb2))
+
+
 define KernelPackage/usb-phy-omap-usb3
   TITLE:=Support for OMAP USB3 PHY
   KCONFIG:=CONFIG_OMAP_USB3
@@ -144,9 +182,9 @@ $(eval $(call KernelPackage,usb-phy-omap-usb3))
 
 
 define KernelPackage/usb-phy-twl4030
-  TITLE:=Support for TWL6030 OTG PHY
+  TITLE:=Support for TWL4030 OTG PHY
   KCONFIG:=CONFIG_TWL4030_USB
-  DEPENDS:=@TARGET_omap
+  DEPENDS:=@TARGET_omap +kmod-usb-phy-omap-usb2 +kmod-usb-musb-hdrc
   FILES:=$(LINUX_DIR)/drivers/phy/phy-twl4030-usb.ko
   AUTOLOAD:=$(call AutoLoad,45,phy-twl4030-usb)
   $(call AddDepends/usb)
@@ -162,7 +200,7 @@ $(eval $(call KernelPackage,usb-phy-twl4030))
 define KernelPackage/usb-phy-twl6030
   TITLE:=Support for TWL6030 OTG PHY
   KCONFIG:=CONFIG_TWL6030_USB
-  DEPENDS:=@TARGET_omap
+  DEPENDS:=@TARGET_omap +kmod-usb-phy-omap-usb2 +kmod-usb-musb-hdrc
   FILES:=$(LINUX_DIR)/drivers/usb/phy/phy-twl6030-usb.ko
   AUTOLOAD:=$(call AutoLoad,45,phy-twl6030-usb)
   $(call AddDepends/usb)
@@ -216,11 +254,13 @@ define KernelPackage/usb-eth-gadget
 ifneq ($(wildcard $(LINUX_DIR)/drivers/usb/gadget/u_ether.ko),)
   FILES:= \
        $(LINUX_DIR)/drivers/usb/gadget/u_ether.ko \
-       $(LINUX_DIR)/drivers/usb/gadget/u_rndis.ko \
        $(LINUX_DIR)/drivers/usb/gadget/usb_f_ecm.ko \
        $(LINUX_DIR)/drivers/usb/gadget/usb_f_ecm_subset.ko \
        $(LINUX_DIR)/drivers/usb/gadget/usb_f_rndis.ko \
        $(LINUX_DIR)/drivers/usb/gadget/g_ether.ko
+  ifneq ($(wildcard $(LINUX_DIR)/drivers/usb/gadget/u_rndis.ko),)
+    FILES+=$(LINUX_DIR)/drivers/usb/gadget/u_rndis.ko
+  endif
   AUTOLOAD:=$(call AutoLoad,52,usb_f_ecm g_ether)
 else
   FILES:=$(LINUX_DIR)/drivers/usb/gadget/g_ether.ko
@@ -297,13 +337,9 @@ $(eval $(call KernelPackage,usb2-fsl))
 define KernelPackage/usb2-omap
   TITLE:=Support for USB2 for OMAP
   DEPENDS:=@TARGET_omap +kmod-usb-phy-nop +kmod-usb-phy-am335x
-  KCONFIG:=\
-       CONFIG_USB_EHCI_HCD_OMAP \
-       CONFIG_OMAP_USB2
-  FILES:= \
-       $(LINUX_DIR)/drivers/phy/phy-omap2-usb.ko \
-       $(LINUX_DIR)/drivers/usb/host/ehci-omap.ko
-  AUTOLOAD:=$(call AutoLoad,39,phy-omap2-usb ehci-omap)
+  KCONFIG:=CONFIG_USB_EHCI_HCD_OMAP
+  FILES:=$(LINUX_DIR)/drivers/usb/host/ehci-omap.ko
+  AUTOLOAD:=$(call AutoLoad,39,ehci-omap)
   $(call AddDepends/usb)
 endef
 
@@ -372,9 +408,15 @@ define KernelPackage/usb-dwc2
        CONFIG_USB_DWC2_DEBUG=n \
        CONFIG_USB_DWC2_VERBOSE=n \
        CONFIG_USB_DWC2_TRACK_MISSED_SOFS=n
+ifeq ($(strip $(call CompareKernelPatchVer,$(KERNEL_PATCHVER),ge,3.14.0)),1)
+  FILES:= \
+       $(LINUX_DIR)/drivers/usb/dwc2/dwc2.ko \
+       $(LINUX_DIR)/drivers/usb/dwc2/dwc2_platform.ko
+else
   FILES:= \
        $(LINUX_DIR)/drivers/staging/dwc2/dwc2.ko \
        $(LINUX_DIR)/drivers/staging/dwc2/dwc2_platform.ko
+endif
   AUTOLOAD:=$(call AutoLoad,54,dwc2 dwc2_platform,1)
   $(call AddDepends/usb)
 endef
@@ -906,15 +948,10 @@ $(eval $(call KernelPackage,usb-atm-cxacru))
 
 define KernelPackage/usb-net
   TITLE:=Kernel modules for USB-to-Ethernet convertors
-  KCONFIG:=CONFIG_USB_USBNET CONFIG_MII=y
+  DEPENDS:=+kmod-mii
+  KCONFIG:=CONFIG_USB_USBNET
   AUTOLOAD:=$(call AutoProbe,usbnet)
-ifeq ($(strip $(call CompareKernelPatchVer,$(KERNEL_PATCHVER),lt,3.12.0)),1)
   FILES:=$(LINUX_DIR)/drivers/$(USBNET_DIR)/usbnet.ko
-else
-  FILES:=\
-       $(LINUX_DIR)/drivers/$(USBNET_DIR)/usbnet.ko \
-       $(LINUX_DIR)/drivers/net/mii.ko
-endif
   $(call AddDepends/usb)
 endef
 
@@ -1014,7 +1051,7 @@ define KernelPackage/usb-net-smsc95xx
   KCONFIG:=CONFIG_USB_NET_SMSC95XX
   FILES:=$(LINUX_DIR)/drivers/$(USBNET_DIR)/smsc95xx.ko
   AUTOLOAD:=$(call AutoProbe,smsc95xx)
-  $(call AddDepends/usb-net)
+  $(call AddDepends/usb-net, +(!LINUX_3_3&&!LINUX_3_6):kmod-lib-crc16)
 endef
 
 define KernelPackage/usb-net-smsc95xx/description