X-Git-Url: http://git.rohieb.name/openwrt.git/blobdiff_plain/0df4ee56ecb61d4340dcaaf30df71dca1fd4aafb..e979f0524a468f8fe8d531d9aae1914909f58c8a:/package/linux/linux.mk diff --git a/package/linux/linux.mk b/package/linux/linux.mk index 6d4545b3c..225683d08 100644 --- a/package/linux/linux.mk +++ b/package/linux/linux.mk @@ -11,7 +11,6 @@ # 4xx patches needed to integrate feature patches # ############################################################# -ifneq ($(filter $(TARGETS),linux),) LINUX_FORMAT=zImage LINUX_KARCH:=$(shell echo $(ARCH) | sed -e 's/i[3-9]86/i386/' \ @@ -20,45 +19,51 @@ LINUX_KARCH:=$(shell echo $(ARCH) | sed -e 's/i[3-9]86/i386/' \ -e 's/sh[234]/sh/' \ ) -LINUX_VERSION=2.4.29 -LINUX_DIR=$(BUILD_DIR)/linux-$(LINUX_VERSION) LINUX_SITE=http://www.kernel.org/pub/linux/kernel/v2.4 +LINUX_BINARY_DRIVER_SITE=http://openwrt.openbsd-geek.de LINUX_SOURCE=linux-$(LINUX_VERSION).tar.bz2 -LINUX_KCONFIG=package/linux/linux.config -LINUX_KERNEL=$(BUILD_DIR)/buildroot-kernel -LINUX_PATCHES=$(PACKAGE_DIR)/linux/kernel-patches +LINUX_KCONFIG=./linux.config +LINUX_PATCHES=./kernel-patches +LINUX_KERNEL_SOURCE=./kernel-source LINUX_BINLOC=arch/$(LINUX_KARCH)/brcm-boards/bcm947xx/compressed/vmlinuz # Used by pcmcia-cs and others -LINUX_SOURCE_DIR=$(LINUX_DIR) +LINUX_SOURCE_DIR=$(LINUX_DIR)-$(LINUX_VERSION) -# kernel stuff extracted from linksys firmware GPL sourcetree -# WRT54GS_3_37_2_1109_US (shared,include,wl,et) -LINKSYS_KERNEL_SITE=http://openwrt.openbsd-geek.de -LINKSYS_KERNEL_TGZ=linksys-kernel.tar.gz +# binary driver extracted from linksys firmware GPL sourcetree WRT54GS_3_37_2_1109_US +LINUX_BINARY_WL_DRIVER=kernel-binary-wl.tar.gz +LINUX_BINARY_ET_DRIVER=kernel-binary-et.tar.gz TARGET_MODULES_DIR=$(TARGET_DIR)/lib/modules/$(LINUX_VERSION) -$(DL_DIR)/$(LINKSYS_KERNEL_TGZ): - $(WGET) -P $(DL_DIR) $(LINKSYS_KERNEL_SITE)/$(LINKSYS_KERNEL_TGZ) +$(DL_DIR)/$(LINUX_BINARY_WL_DRIVER): + $(WGET) -P $(DL_DIR) $(LINUX_BINARY_DRIVER_SITE)/$(LINUX_BINARY_WL_DRIVER) -$(LINUX_DIR)/.unpacked: $(DL_DIR)/$(LINUX_SOURCE) $(DL_DIR)/$(LINKSYS_KERNEL_TGZ) +$(DL_DIR)/$(LINUX_BINARY_ET_DRIVER): + $(WGET) -P $(DL_DIR) $(LINUX_BINARY_DRIVER_SITE)/$(LINUX_BINARY_ET_DRIVER) + +$(LINUX_DIR)/.unpacked: $(DL_DIR)/$(LINUX_SOURCE) $(DL_DIR)/$(LINUX_BINARY_WL_DRIVER) $(DL_DIR)/$(LINUX_BINARY_ET_DRIVER) -mkdir -p $(BUILD_DIR) bzcat $(DL_DIR)/$(LINUX_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - - # extract linksys binary kernel stuff and include/shared files - zcat $(DL_DIR)/$(LINKSYS_KERNEL_TGZ) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + ln -sf $(LINUX_DIR)-$(LINUX_VERSION) $(LINUX_DIR) + # extract wlan and lan binary only driver + zcat $(DL_DIR)/$(LINUX_BINARY_WL_DRIVER) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - + zcat $(DL_DIR)/$(LINUX_BINARY_ET_DRIVER) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - touch $(LINUX_DIR)/.unpacked $(LINUX_DIR)/.patched: $(LINUX_DIR)/.unpacked $(PATCH) $(LINUX_DIR) $(LINUX_PATCHES) -ifeq ($(BR2_TARGET_ROOTFS_SQUASHFS_LZMA),y) - $(PATCH) $(LINUX_DIR) target/squashfs-lzma/kernel-patch -endif + # copy kernel source which is maintained in openwrt via cvs + cp -a $(LINUX_KERNEL_SOURCE)/* $(LINUX_DIR) + # copy binary drivers + cp -a $(BUILD_DIR)/wl/*.o $(LINUX_DIR)/drivers/net/wl + cp -a $(BUILD_DIR)/et/*.o $(LINUX_DIR)/drivers/net/et touch $(LINUX_DIR)/.patched -$(LINUX_DIR)/.configured: $(LINUX_DIR)/.patched +$(LINUX_DIR)/.configured: $(LINUX_DIR)/.patched -cp $(LINUX_KCONFIG) $(LINUX_DIR)/.config - $(SED) "s,^CROSS_COMPILE.*,CROSS_COMPILE=$(KERNEL_CROSS),g;" $(LINUX_DIR)/Makefile - $(SED) "s,^CROSS_COMPILE.*,CROSS_COMPILE=$(KERNEL_CROSS),g;" $(LINUX_DIR)/arch/mips/Makefile + $(SED) "s,^CROSS_COMPILE.*,CROSS_COMPILE=$(KERNEL_CROSS),g;" \ + $(LINUX_DIR)/Makefile \ + $(LINUX_DIR)/arch/mips/Makefile $(SED) "s,\-mcpu=,\-mtune=,g;" $(LINUX_DIR)/arch/mips/Makefile $(MAKE) -C $(LINUX_DIR) ARCH=$(LINUX_KARCH) oldconfig include/linux/version.h touch $(LINUX_DIR)/.configured @@ -78,7 +83,6 @@ $(LINUX_KERNEL): $(LINUX_DIR)/$(LINUX_BINLOC) $(LINUX_DIR)/.modules_done: $(LINUX_KERNEL) rm -rf $(BUILD_DIR)/modules $(MAKE) -C $(LINUX_DIR) DEPMOD=true INSTALL_MOD_PATH=$(BUILD_DIR)/modules modules_install - tar -C $(BUILD_DIR)/modules/lib -cjf openwrt-kmodules.tar.bz2 modules touch $(LINUX_DIR)/.modules_done $(STAGING_DIR)/include/linux/version.h: $(LINUX_DIR)/.configured @@ -102,15 +106,8 @@ linuxclean: clean -$(MAKE) -C $(LINUX_DIR) clean linux-dirclean: + rm -f $(BUILD_DIR)/openwrt-kmodules.tar.bz2 + rm -rf $(LINUX_DIR)-$(LINUX_VERSION) rm -rf $(LINUX_DIR) + rm -rf $(BUILD_DIR)/modules -endif - -############################################################# -# -# Toplevel Makefile options -# -############################################################## -ifeq ($(strip $(BR2_PACKAGE_LINUX)),y) -TARGETS+=linux -endif