]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blobdiff - lfs/compat-wireless
compat-wireless: update to 3.5.1-1-snpc.
[people/teissler/ipfire-2.x.git] / lfs / compat-wireless
index 8fb61c138eed75b85c0d23ef7f66ab2f16e29506..78bd1d4aa09974116ffa956047e5146c80a9843c 100644 (file)
@@ -1,7 +1,7 @@
 ###############################################################################
 #                                                                             #
 # IPFire.org - A linux based firewall                                         #
-# Copyright (C) 2008  Michael Tremer & Christian Schmidt                      #
+# Copyright (C) 2007-2012  IPFire Team <info@ipfire.org>                      #
 #                                                                             #
 # This program is free software: you can redistribute it and/or modify        #
 # it under the terms of the GNU General Public License as published by        #
 
 include Config
 
-ifeq "$(XEN)" "1"
-       VERSUFIX=ipfire-xen
-else
-       VERSUFIX=ipfire
-endif
+VERSUFIX=ipfire$(KCFG)
+
+VER        = 3.5.1-1-snpc
 
-VER        = 2.6.33.2
+ifeq "$(KCFG)" "-xen"
+       KVER = 2.6.32.59
+endif
 
 THISAPP    = compat-wireless-$(VER)
 DL_FILE    = compat-wireless-$(VER).tar.bz2
@@ -42,11 +42,13 @@ TARGET     = $(DIR_INFO)/$(THISAPP)-kmod-$(KVER)-$(VERSUFIX)
 # Top-level Rules
 ###############################################################################
 
-objects = $(DL_FILE)
+objects = $(DL_FILE) asix-4.4.0.tar.xz
 
 $(DL_FILE) = $(DL_FROM)/$(DL_FILE)
+asix-4.4.0.tar.xz = $(DL_FROM)/asix-4.4.0.tar.xz
 
-$(DL_FILE)_MD5 = 24438dddeda05694b94de450893847e3
+$(DL_FILE)_MD5 = eea8d1c430ad38b713457438e04f47f5
+asix-4.4.0.tar.xz_MD5=633609e889de41554826e0e2cd7bffde
 
 install : $(TARGET)
 
@@ -77,32 +79,45 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
        @$(PREBUILD)
        @rm -rf $(DIR_APP) && cd $(DIR_SRC) && tar xjf $(DIR_DL)/$(DL_FILE)
 
-       cd $(DIR_APP) && make KLIB=/lib/modules/$(KVER)-$(VERSUFIX) KMODDIR=kernel install-modules
-
-       # The makefile put the modules to a wrong place move back...
-       cp -rf /lib/modules/$(KVER)-$(VERSUFIX)/lib /
-       rm -rf /lib/modules/$(KVER)-$(VERSUFIX)/lib
-
-       # Set Regulatory Domain to "EU" (use Channel 1-14 max. 20db)
-       echo options cfg80211 ieee80211_regdom=EU > /etc/modprobe.d/cfg80211
-
-       # Rename ieee80211 modules Because the conflicts with compat-wireless
-       -cd /lib/modules/$(KVER)-$(VERSUFIX)/kernel/net/ieee80211 && rename .ko .off *
-
-       echo "# If you want to use hostap (prism drivers)" > /etc/modprobe.d/hostap
-       echo "# you must rename the ieee80211 modules. Run:" >> /etc/modprobe.d/hostap
-       echo "# rename .off .ko /lib/modules/*/kernel/net/ieee80211/*" >> /etc/modprobe.d/hostap
-       echo "# depmod -a" >> /etc/modprobe.d/hostap
-       echo >> /etc/modprobe.d/hostap
-       echo "# additional you need to blacklist the orinoco modules" >> /etc/modprobe.d/hostap
-       echo "# by uncommenting following lines" >> /etc/modprobe.d/hostap
-       echo >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco" >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco_cs" >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco_plx" >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco_pci" >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco_tmd" >> /etc/modprobe.d/hostap
-       echo "#blacklist orinoco_nortel" >> /etc/modprobe.d/hostap
+       # kfifo has no license info and taints kernel
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/compat-wireless-2.6.39_kfifo_module_info.patch
+
+       # Codel patches
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/compat-wireless_codel-avoid-a-nul-rec_inv_sqrt.patch
+
+       # Build ath5k only if target has pci
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/compat-wireless-3.5-build_ath5k_only_with_pci.patch
+
+       # Copy USB-Net drivers from Kernel...
+       mkdir $(DIR_APP)/drivers/net/usb/new
+       cp $(DIR_APP)/drivers/net/usb/*.c $(DIR_APP)/drivers/net/usb/new
+       cp /usr/src/linux/drivers/net/usb/{*.c,*.h,Makefile} $(DIR_APP)/drivers/net/usb
+       cp $(DIR_APP)/drivers/net/usb/new/*.c $(DIR_APP)/drivers/net/usb
+
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/compat-wireless-2.6.34-usbnet_compile.patch
+
+       # Build Updated asix usb-lan driver
+       cd $(DIR_APP)/drivers/net/usb && tar xvJf $(DIR_DL)/asix-4.4.0.tar.xz
+
+       # Add libartas uAP driver
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/compat-wireless-3.5-libertas_uap.patch
+
+       # uAP will not build with xen-kernel (2.6)
+ifneq "$(KCFG)" "-xen"
+       cd $(DIR_APP) && echo export CONFIG_LIBERTAS_UAP=m >> config.mk
+endif
+
+       # Erase some modules that are obsolete or moved to other path
+       rm -rf /lib/modules/$(KVER)-$(VERSUFIX)/kernel/net/bluetooth
+       rm -rf /lib/modules/$(KVER)-$(VERSUFIX)/kernel/drivers/net/wireless/wl12*
+
+       cd $(DIR_APP) && make KLIB=/lib/modules/$(KVER)-$(VERSUFIX) \
+               KLIB_BUILD=/lib/modules/$(KVER)-$(VERSUFIX)/build \
+               KMODPATH_ARG='INSTALL_MOD_PATH=' KMODDIR=kernel install-modules
+
+       # Install firmware udev files...
+       cd $(DIR_APP)/udev && install -m 644 50-compat_firmware.rules /etc/udev/rules.d/
+       cd $(DIR_APP)/udev && install -m 755 compat_firmware.sh /lib/udev/
 
        -rm -rf $(DIR_APP)
        @$(POSTBUILD)