diff options
| -rw-r--r-- | Makefile | 4 | ||||
| -rw-r--r-- | make/system-linux.mk | 49 | 
2 files changed, 52 insertions, 1 deletions
| @@ -64,9 +64,11 @@ TARGETS+=uclibc_toolchain  endif  # Do you want user mode Linux (x86 only), or are you building a  -# real kernel that will run on its own? +# real kernel # that will run on its own?  Perhaps you have a  +# kernel you have already configured and you want to use that?  #TARGETS+=linux  TARGETS+=user-mode-linux +#TARGETS+=system-linux  # The default minimal set  TARGETS+=busybox tinylogin diff --git a/make/system-linux.mk b/make/system-linux.mk new file mode 100644 index 000000000..9b92f083f --- /dev/null +++ b/make/system-linux.mk @@ -0,0 +1,49 @@ +############################################################# +# +# System Linux kernel target +# +# This uses an existing linux kernel source tree on +# your build system, and makes no effort at compiling +# anything.... +# +# You will probably want to change LINUX_SOURCE to +# point to wherever you installed you kernel. +# +#  -Erik +# +############################################################# +ifneq ($(filter $(TARGETS),system-linux),) + +LINUX_SOURCE=/usr/src/linux +LINUX_DIR=$(BUILD_DIR)/linux +LINUX_KERNEL=$(BUILD_DIR)/buildroot-kernel + +$(LINUX_DIR)/.configured: +	mkdir -p $(LINUX_DIR) +	(cd $(LINUX_DIR); ln -s $(LINUX_SOURCE)/include) +	touch $(LINUX_DIR)/.configured + +$(LINUX_KERNEL): $(LINUX_DIR)/.configured + +$(STAGING_DIR)/include/linux/version.h: $(LINUX_DIR)/.configured +	mkdir -p $(STAGING_DIR)/include +	rm -rf $(STAGING_DIR)/include/linux +	cp -dpa $(LINUX_SOURCE)/include/linux $(STAGING_DIR)/include/ +	rm -rf $(STAGING_DIR)/include/asm +	mkdir -p $(STAGING_DIR)/include/asm +	cp -dpa $(LINUX_SOURCE)/include/asm/* $(STAGING_DIR)/include/asm/ +	rm -rf $(STAGING_DIR)/include/scsi +	mkdir -p $(STAGING_DIR)/include/scsi +	cp -dpa $(LINUX_SOURCE)/include/scsi/* $(STAGING_DIR)/include/scsi +	touch -c $(STAGING_DIR)/include/linux/version.h + +system-linux: $(STAGING_DIR)/include/linux/version.h + +system-linux-clean: clean +	rm -f $(LINUX_KERNEL) +	rm -rf $(LINUX_DIR) + +system-linux-dirclean: +	rm -rf $(LINUX_DIR) + +endif | 
