change handling of target/linux/generic-2.x/files to match other targets (#1648)
SVN-Revision: 7158
This commit is contained in:
		| @@ -29,6 +29,7 @@ KERNEL_MAKEOPTS := -C $(LINUX_DIR) \ | |||||||
|  |  | ||||||
| define Kernel/Prepare/Default | define Kernel/Prepare/Default | ||||||
| 	bzcat $(DL_DIR)/$(LINUX_SOURCE) | tar -C $(KERNEL_BUILD_DIR) $(TAR_OPTIONS) | 	bzcat $(DL_DIR)/$(LINUX_SOURCE) | tar -C $(KERNEL_BUILD_DIR) $(TAR_OPTIONS) | ||||||
|  | 	if [ -d $(GENERIC_PLATFORM_DIR)/files ]; then $(CP) $(GENERIC_PLATFORM_DIR)/files/* $(LINUX_DIR)/; fi | ||||||
| 	if [ -d $(GENERIC_PLATFORM_DIR)/patches ]; then $(PATCH) $(LINUX_DIR) $(GENERIC_PLATFORM_DIR)/patches; fi | 	if [ -d $(GENERIC_PLATFORM_DIR)/patches ]; then $(PATCH) $(LINUX_DIR) $(GENERIC_PLATFORM_DIR)/patches; fi | ||||||
| 	if [ -d ./files ]; then $(CP) ./files/* $(LINUX_DIR)/; fi | 	if [ -d ./files ]; then $(CP) ./files/* $(LINUX_DIR)/; fi | ||||||
| 	if [ -d ./patches ]; then $(PATCH) $(LINUX_DIR) ./patches; fi | 	if [ -d ./patches ]; then $(PATCH) $(LINUX_DIR) ./patches; fi | ||||||
| @@ -67,14 +68,12 @@ ifeq ($(KERNEL),2.6) | |||||||
| 		echo 'CONFIG_INITRAMFS_SOURCE="../../root"' >> $(LINUX_DIR)/.config | 		echo 'CONFIG_INITRAMFS_SOURCE="../../root"' >> $(LINUX_DIR)/.config | ||||||
| 		echo 'CONFIG_INITRAMFS_ROOT_UID=0' >> $(LINUX_DIR)/.config | 		echo 'CONFIG_INITRAMFS_ROOT_UID=0' >> $(LINUX_DIR)/.config | ||||||
| 		echo 'CONFIG_INITRAMFS_ROOT_GID=0' >> $(LINUX_DIR)/.config | 		echo 'CONFIG_INITRAMFS_ROOT_GID=0' >> $(LINUX_DIR)/.config | ||||||
| 		mkdir -p $(BUILD_DIR)/root/etc/init.d |  | ||||||
| 		$(CP) $(GENERIC_PLATFORM_DIR)/files/init $(BUILD_DIR)/root/ |  | ||||||
|     endef |     endef | ||||||
|   else |   else | ||||||
|     define Kernel/SetInitramfs |     define Kernel/SetInitramfs | ||||||
| 		mv $(LINUX_DIR)/.config $(LINUX_DIR)/.config.old | 		mv $(LINUX_DIR)/.config $(LINUX_DIR)/.config.old | ||||||
| 		grep -v INITRAMFS $(LINUX_DIR)/.config.old > $(LINUX_DIR)/.config | 		grep -v INITRAMFS $(LINUX_DIR)/.config.old > $(LINUX_DIR)/.config | ||||||
| 		rm -f $(BUILD_DIR)/root/init $(BUILD_DIR)/root/etc/init.d/S00initramfs | 		rm -f $(BUILD_DIR)/root/init | ||||||
| 		echo 'CONFIG_INITRAMFS_SOURCE=""' >> $(LINUX_DIR)/.config | 		echo 'CONFIG_INITRAMFS_SOURCE=""' >> $(LINUX_DIR)/.config | ||||||
|     endef |     endef | ||||||
|   endif |   endif | ||||||
|   | |||||||
							
								
								
									
										93
									
								
								target/linux/generic-2.6/base-files/init
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										93
									
								
								target/linux/generic-2.6/base-files/init
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,93 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | # Copyright (C) 2006 OpenWrt.org | ||||||
|  |  | ||||||
|  | export PATH=/bin:/sbin:/usr/bin:/usr/sbin | ||||||
|  | mount none /proc -t proc | ||||||
|  |  | ||||||
|  | if grep devfs /proc/filesystems > /dev/null; then | ||||||
|  | 	mount none /dev -t devfs | ||||||
|  | else | ||||||
|  | 	mount -t sysfs none /sys | ||||||
|  | 	mount -t tmpfs tmpfs /dev -o size=512K | ||||||
|  | 	mknod /dev/console c 5 1 | ||||||
|  | 	mkdir /dev/pts | ||||||
|  | 	mkdir /dev/shm | ||||||
|  | 	/sbin/hotplug2 --no-persistent --coldplug --max_children 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | mount none /dev/pts -t devpts | ||||||
|  |  | ||||||
|  | # the root mount point can come from the kernel command line | ||||||
|  | # or it can be overridden in the preinit.arch file | ||||||
|  | [ -f /etc/preinit.arch ] && . /etc/preinit.arch | ||||||
|  |  | ||||||
|  | # if we have no root parameter, just go to running from ramfs | ||||||
|  | [ -z $rootfs ] && { | ||||||
|  |   export NOMOUNT="No Root" | ||||||
|  |   exec /sbin/init | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if we have a failsafe boot selected, dont bother | ||||||
|  | #trying to find or wait for a root mount point | ||||||
|  | [ -z "$FAILSAFE" ] || { | ||||||
|  |   exec /bin/busybox init | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # Load the modules we have in initramfs, this should | ||||||
|  | # make the media accessible, but, it may take some time | ||||||
|  | . /etc/functions.sh | ||||||
|  | load_modules /etc/modules /etc/modules.d/* | ||||||
|  |  | ||||||
|  | #wait 10 seconds for the disc to show up | ||||||
|  | #usb stick typically takes 4 to 6 seconds | ||||||
|  | #till it's readable | ||||||
|  | #it's quite possible the disc never shows up | ||||||
|  | #if we netbooted this kernel | ||||||
|  | COUNTER=0 | ||||||
|  | while [ $COUNTER -lt 10 ]; do | ||||||
|  |   sleep 1 | ||||||
|  |   [ -e $rootfs ] && let COUNTER=10; | ||||||
|  |   let COUNTER=COUNTER+1 | ||||||
|  | done | ||||||
|  | [ -e $rootfs ] || { | ||||||
|  |   export FAILSAFE="NoDisc" | ||||||
|  |   exec /bin/busybox init | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # now we'll try mount it, again with a timeout | ||||||
|  | # This will fail if the inserted stick is formatted | ||||||
|  | # in a manner we dont understand | ||||||
|  | COUNTER=0 | ||||||
|  | while [ $COUNTER -lt 10 ]; do | ||||||
|  |   sleep 1 | ||||||
|  |   mount $rootfs /mnt | ||||||
|  |   [ $? -eq "0" ] && let COUNTER=100; | ||||||
|  |   let COUNTER=COUNTER+1 | ||||||
|  | done | ||||||
|  | [ $? -ne "0" ] && { | ||||||
|  |   export FAILSAFE="MountFail" | ||||||
|  |   exec /bin/busybox init | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #It mounted, lets look for a postinit file, again, give it time | ||||||
|  | #I've seen this take 6 seconds to actually complete | ||||||
|  | COUNTER=0 | ||||||
|  | while [ $COUNTER -lt 10 ]; do | ||||||
|  |   sleep 1 | ||||||
|  |   [ -e /mnt/etc/banner ] && let COUNTER=10; | ||||||
|  |   let COUNTER=COUNTER+1 | ||||||
|  | done | ||||||
|  | [ -e /mnt/etc/banner ] || { | ||||||
|  |   export FAILSAFE="No Openwrt FS" | ||||||
|  |   exec /bin/busybox init | ||||||
|  | } | ||||||
|  |  | ||||||
|  | unset rootfs | ||||||
|  |  | ||||||
|  | mount -o move /proc /mnt/proc | ||||||
|  | mount -o move /dev /mnt/dev | ||||||
|  | mount -o move /dev/pts /mnt/dev/pts | ||||||
|  | mount -o move /tmp /mnt/tmp | ||||||
|  | mount -o move /sys /mnt/sys | ||||||
|  | mount none /tmp -t tmpfs | ||||||
|  | exec switch_root -c /dev/console /mnt /sbin/init | ||||||
		Reference in New Issue
	
	Block a user
	 Mike Baker
					Mike Baker