PR = "r41"
 
-
 SRC_URI = "file://altboot-menu \
           file://altboot.rc \
           file://altboot.func \         
 
 SD_DEVICE="/dev/mmcblk0p1"
 SD_KERNEL_MODULE=""
 
-USB_HOST_AVAILABLE="no"
-USB_STORAGE_MODULES="usb_ohci_pxa27x usb-storage"
+USB_HOST_AVAILABLE="yes"
+USB_STORAGE_MODULES="ohci_hcd usb_storage sd_mod"
 USB_STORAGE_PARTITION="/dev/sda1"
 USB_STORAGE_WAIT="4"
 
 
 
 M_TITLE="Boot SD card"
 
-die() {
-       echo "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
 # This function is activated by init.altboot by calling this script with the "run" option
 run_module() {
        
 
 
 M_TITLE="Boot CF card"
 
-die() {
-       echo "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
 # This function is activated by init.altboot by calling this script with the "run" option
 run_module() {
        
 
 # The "title" parameter is implemented at the end of this script so it will never be reached
 # and the script will simply be ignored by altboot.
 
-
-# The die() function aborts the boot if something goes wrong and sets STDIN / STDERR / STDOUT
-# correctly.
-die() {
-       echo "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
 # This function is activated by init.altboot by calling this script with the "run" option
 run_module() {
 
 
 M_TITLE="Boot USB Storage"
 
 test "$USB_HOST_AVAILABLE" = "yes" || exit 0
-
-die() {
-       echo "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
+       
 # This function is activated by init.altboot by calling this script with the "run" option
 run_module() {
        
 
 
 M_TITLE="Boot from NFS"
 
-die() {
-       echo -e "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
 # This function is activated by init.altboot by calling this script with the "run" option
 run_module() {
 
                        
        nfs_host="`cat /etc/fstab | grep -v ^# | grep nfs | awk '{print $1}'|sed -n "s/\(.*\)\:\(.*\)/\1/p" `"
        nfs_mounts="`cat /etc/fstab | grep -v ^# | grep nfs | awk '{print $1}'`"
-       nfs_mountpoints="`cat /etc/fstab | grep -v ^# | grep nfs | awk '{print $2}'`"   
-       
-       WLAN_NIC="`iwconfig 2>/dev/null | grep ESSID | awk '{print $1}'`"
+       nfs_mountpoints="`cat /etc/fstab | grep -v ^# | grep nfs | awk '{print $2}'`"                   
                
        start_networking "$nfs_host"    
        
 
 
 M_TITLE="Install RootFS from tar.gz"
 
-# die() {
-#      echo "ERROR: $1" >/dev/tty0
-#      exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-# }
-
 run_module(){
        test -e /etc/altboot.func && . /etc/altboot.func || die "ERROR: /etc/altboot.func not found. Check your installation!"  
        
 
                        
                        get_pref "kexec_klist" "$junk" KEXEC_SELECTED_KERNEL && break
 
-               done
-               
-               echo "Using [$KEXEC_SELECTED_KERNEL]"
+               done            
+       else
+               KEXEC_SELECTED_KERNEL="`ls -1 $KEXEC_KERNEL_DIR/zImage* | grep -v "kexec.cfg" `"
        fi
        
+       echo -e "\nUsing [$KEXEC_SELECTED_KERNEL]"
+       
        if ! test -e "$KEXEC_SELECTED_KERNEL.kexec.cfg" 
        then
                echo -e "\nWARNING: This kernel has not been configured."
 
                        
                        get_pref "kexec_klist" "$junk" KEXEC_KERNEL && break
 
-               done
-               
-               echo "Using [$KEXEC_KERNEL]"
+               done                            
+       else
+               KEXEC_KERNEL="`ls -1 $KEXEC_KERNEL_DIR/zImage* | grep -v "kexec.cfg" `"
        fi
        
+       echo -e "\nUsing [$KEXEC_KERNEL]"
+       
        configure_rootdev
        configure_roottype
        configure_verbose
 
 # Unfinished script.
 exit 0
 
-die() {
-       echo "ERROR: $1" >/dev/tty0
-       exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
-}
-
 ask_target() {
        available_disks="`mount | grep "/media" | grep -v ram | awk '{print $3}'`"
        
 
 #! /bin/sh
+
+C_RED="\033[31m"
+C_YELLOW="\033[35m"
+C_BLUE="\033[34m"
+C_WHITE="\033[38m"
+C_RESET="\033[0m"
+
+
 # This function checks for the presence of a real filesystem and loop-images on the target
 # $1 = folder of rootfs, $2 = runlevel (defaults to 5)
 # $2 = name of calling module
                boot_new_rootfs_splash          
                echo "Calling INIT"
                        
-               exec /usr/sbin/chroot . /sbin/init $2 >/dev/tty0 2>&1
+               exec /usr/sbin/chroot . $REAL_INIT $2 >/dev/tty0 2>&1
+               #exec /usr/sbin/chroot . /sbin/init $2 >/dev/tty0 2>&1
        else
                echo "FAILED"
                die "* * * pivot_root failed! * * *" 
                while true
                do
                        echo -e "Wasting RAM is never a good idea.\nOnly say Y if your rootfs is very small in size"
-                       echo -n "Do you want to store ipkg package data in RAM? [N|y] "
+                       echo -en "Do you want to store ipkg package data\nin RAM? [N|y] "
                        read junk
                        
                        if test "$junk" = "" -o "$junk" = n -o "$junk" = N
        then                                            
                while true
                do
-                       echo -n "Do you want to keep the SD, CF and /home ipkg install targets? [N|y] "
+                       echo -en "Do you want to keep the SD, CF and /home\nipkg install targets? [N|y] "
                        read junk
                        
                        if test "$junk" = "" -o "$junk" = n -o "$junk" = N
 }
 
 mdie() {
-       echo "ERROR: $1" >/dev/tty0
+       echo -e "${C_RED}ERROR:${C_RESET}${C_WHITE} $1${C_RESET}" >/dev/tty0
        
        echo -e "\nPress <ENTER> to return to the menu"
        read junk
        test -n "$data_value" && return 0
 }
 
+debug_echo() {
+       test "$ENABLE_DEBUG" = "yes" && echo -e "${C_YELLOW}DEBUG:${C_RESET}${C_WHITE} $1 ${C_RESET}" >/dev/tty0 2>&1
+}
+
 start_networking() {
 
+       test -z "$1" && mdie "No remote host configured, check /etc/fstab for NFS hosts"
+       
        if test "$USB_NETWORKING_AVAILABLE" = "yes"
        then
                echo ""
                        junk="`cat /etc/.altboot-lanselect.last`"
                        test -z "$junk" && junk=1
                        
-                       echo -n "Connection Type: $junk (autoboot)"
+                       echo "Connection Type: $junk (autoboot)"
                fi
                        
                case "$junk" in
 
                if test -x /etc/init.d/pcmcia
                then
+                       echo -e "\nRunning cardctl to setup networking..."
                        /etc/init.d/pcmcia start >/dev/null 2>&1 || die "/etc/init.d/pcmcia start failed!"
+                       sleep 1
                else    
                        # With kernel 2.6.16+ udev is used 
-                       ps ax| grep -v grep | grep -q udevd || /etc/init.d/udev start >/dev/null 2>&1 || die "/etc/init.d/udev start failed!"
+                       echo -e "\nRunning udevd to setup networking..."
+                       ps ax | grep -v grep | grep -q udevd || /etc/init.d/udev start >/dev/null 2>&1 || die "/etc/init.d/udev start failed!"
 
-                       /etc/init.d/udev stop
+                       # Stop udev to work around some very ugly (yet harmless) error messages on boot
+                       /etc/init.d/udev stop >/dev/null 2>&1
                fi
        fi
        
                        
                ifup "$USB_NW_DEVICE"
        fi
+
+       WLAN_NIC="`iwconfig 2>/dev/null | grep ESSID | grep -v wifi | awk '{print $1}'`"
+
+       if test -z "$WLAN_NIC"
+       then
+               debug_echo "WARNING: WLAN_NIC is empty!\n" 
+               debug_echo "Filter result: [$WLAN_NIC]"
+               debug_echo "iwconfig: [`iwconfig`]"
+               mdie "No network interface found"
+       fi
        
        # WLAN with DHCP needs some time to get a lease, set up the routing, etc.       
-       echo -n "Waiting for Network."
+       echo -n "Waiting for host [$1] on [$WLAN_NIC]."
        cnt=0
        while true
        do
 
 test -e "$ALTBOOT_CFG_FILE" && . "$ALTBOOT_CFG_FILE" || echo "WARNING: No $ALTBOOT_CFG_FILE found! Check your installation of Altboot!" > /dev/tty1
 
 C_RED="\033[31m"
+C_YELLOW="\033[33m"
 C_BLUE="\033[34m"
 C_WHITE="\033[37m"
 C_RESET="\033[0m"
 
 
 die() {
-       echo -e "ERROR: $1" >/dev/tty0
+       echo -e "${C_RED}ERROR: $1${C_RESET}" >/dev/tty0
        exec $SH_SHELL </dev/tty0 >/dev/tty0 2>&1
 }
 
+debug_shell() {                
+       # VT 2 = Opie, VT 3 = GPE
+       test -z "$1" && VT=4 || VT=$1
+       
+       echo -e "\033c" > /dev/tty$VT
+
+       echo -en "\nPress <ENTER> to activate the debug shell." > /dev/tty$VT
+       read junk </dev/tty$VT
+               
+       echo "" > /dev/tty$VT   
+       /bin/sh  </dev/tty$VT >/dev/tty$VT 2>&1
+       
+       #openvt -lf -c$VT -- /bin/sh </dev/tty$VT >/dev/tty$VT 2>&1
+}
 
 # This function prints the boot-menu
 # $1: Directory containing the scripts for the menu-items
 # Note: this is positively ugly. If someone knows a better way to detect wheter
 # we are already booted into a runlevel _without_ reading /var and / or using `runlevel`
 # PLEASE let me know.
+
+if ( echo "$VERSION" |  egrep -iq "(snapshot|-rc)" )
+then
+       ENABLE_DEBUG="yes"
+       debug_shell 4 >/dev/null 2>&1 &
+fi
+
 if test -f /proc/cmdline -a "`ps ax|wc -l|tr -d " "`" -gt 30 -a "$1" != "-force"
 then
        echo "altboot: Using real init [$REAL_INIT] [$*] [`ps ax|wc -l|tr -d " "`] *" >/dev/tty1