mt76: update to the latest version, adds stability fixes
[openwrt/openwrt.git] / package / kernel / mt76 / Makefile
index bcf69b231d3a295f001ab579c3f2bcf3dccfb310..eb02431adbab11fd896152d787a52ba887ecc6c3 100644 (file)
@@ -1,7 +1,6 @@
 include $(TOPDIR)/rules.mk
 
 PKG_NAME:=mt76
-PKG_VERSION:=2015-06-15
 PKG_RELEASE=1
 
 PKG_LICENSE:=GPLv2
@@ -9,22 +8,55 @@ PKG_LICENSE_FILES:=
 
 PKG_SOURCE_URL:=https://github.com/openwrt/mt76
 PKG_SOURCE_PROTO:=git
-PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION)
-PKG_SOURCE_VERSION:=ec91841868a554375b3019bcfaa13ae6d20fe91c
-PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION)-$(PKG_SOURCE_VERSION).tar.xz
+PKG_SOURCE_DATE:=2017-12-03
+PKG_SOURCE_VERSION:=8e17d36381a119df346016dd2bd1c551988a583f
+PKG_MIRROR_HASH:=3cad68b9ec2514c067cfd81ea51fe74aedce2a1b2c85a0a1b70f764726716861
 
-PKG_MAINTAINER:=Felix Fietkau <nbd@openwrt.org>
+PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name>
 PKG_BUILD_PARALLEL:=1
 
+STAMP_CONFIGURED_DEPENDS := $(STAGING_DIR)/usr/include/mac80211-backport/backport/autoconf.h
+
 include $(INCLUDE_DIR)/kernel.mk
 include $(INCLUDE_DIR)/package.mk
 
+define KernelPackage/mt76-default
+  SUBMENU:=Wireless Drivers
+  DEPENDS:= \
+       +kmod-mac80211 @PCI_SUPPORT @!LINUX_3_18 \
+       +@DRIVER_11AC_SUPPORT +@DRIVER_11N_SUPPORT +@DRIVER_11W_SUPPORT
+endef
+
 define KernelPackage/mt76
   SUBMENU:=Wireless Drivers
+  TITLE:=MediaTek MT76x2/MT7603 wireless driver (metapackage)
+  DEPENDS:= \
+       +kmod-mt76-core +kmod-mt76x2 +kmod-mt7603
+endef
+
+define KernelPackage/mt76-core
+  $(KernelPackage/mt76-default)
+  TITLE:=MediaTek MT76xx wireless driver
+  FILES:=\
+       $(PKG_BUILD_DIR)/mt76.ko
+endef
+
+define KernelPackage/mt76x2
+  $(KernelPackage/mt76-default)
   TITLE:=MediaTek MT76x2 wireless driver
-  DEPENDS:=+kmod-mac80211 +@DRIVER_11N_SUPPORT @PCI_SUPPORT
-  FILES:=$(PKG_BUILD_DIR)/mt76pci.ko
-  AUTOLOAD:=$(call AutoLoad,50,mac80211 mt76pci)
+  DEPENDS+=+kmod-mt76-core
+  FILES:=\
+       $(PKG_BUILD_DIR)/mt76x2e.ko
+  AUTOLOAD:=$(call AutoProbe,mt76x2e)
+endef
+
+define KernelPackage/mt7603
+  $(KernelPackage/mt76-default)
+  TITLE:=MediaTek MT7603 wireless driver
+  DEPENDS+=+kmod-mt76-core
+  FILES:=\
+       $(PKG_BUILD_DIR)/mt7603e.ko
+  AUTOLOAD:=$(call AutoProbe,mt7603e)
 endef
 
 NOSTDINC_FLAGS = \
@@ -42,14 +74,17 @@ endif
 
 define Build/Compile
        +$(MAKE) $(PKG_JOBS) -C "$(LINUX_DIR)" \
-               ARCH="$(LINUX_KARCH)" \
-               CROSS_COMPILE="$(TARGET_CROSS)" \
+               $(KERNEL_MAKE_FLAGS) \
                SUBDIRS="$(PKG_BUILD_DIR)" \
                NOSTDINC_FLAGS="$(NOSTDINC_FLAGS)" \
                modules
 endef
 
-define KernelPackage/mt76/install
+define Package/kmod-mt76/install
+       true
+endef
+
+define KernelPackage/mt76x2/install
        $(INSTALL_DIR) $(1)/lib/firmware
        cp \
                $(PKG_BUILD_DIR)/firmware/mt7662_rom_patch.bin \
@@ -57,4 +92,19 @@ define KernelPackage/mt76/install
                $(1)/lib/firmware
 endef
 
+define KernelPackage/mt7603/install
+       $(INSTALL_DIR) $(1)/lib/firmware
+       cp $(if $(CONFIG_TARGET_ramips_mt76x8), \
+               $(PKG_BUILD_DIR)/firmware/mt7628_e1.bin \
+               $(PKG_BUILD_DIR)/firmware/mt7628_e2.bin \
+               ,\
+               $(PKG_BUILD_DIR)/firmware/mt7603_e1.bin \
+               $(PKG_BUILD_DIR)/firmware/mt7603_e2.bin \
+               ) \
+               $(1)/lib/firmware
+endef
+
+$(eval $(call KernelPackage,mt76-core))
+$(eval $(call KernelPackage,mt76x2))
+$(eval $(call KernelPackage,mt7603))
 $(eval $(call KernelPackage,mt76))