X-Git-Url: https://git.grml.org/?a=blobdiff_plain;f=rewrite%2Flinuxrc;h=199e12370c3fa6d8ef23531cf5c18540136bf6ca;hb=bcc5cca5dd7665ffffa3519b745b7ced1e621bca;hp=85ac6bf8ca2ea634cafae0d586d97e2c3eabe4bc;hpb=f70d07c0576c853ac314e2ab7fe084fb9645ad76;p=grml-live.git diff --git a/rewrite/linuxrc b/rewrite/linuxrc index 85ac6bf..199e123 100644 --- a/rewrite/linuxrc +++ b/rewrite/linuxrc @@ -2,7 +2,7 @@ # Filename: /linuxrc # Purpose: minirt for kernel 2.6 running on grml live-cd # Authors: (c) Klaus Knopper , (c) Michael Prokop -# Latest change: Sat Dec 2 18:12:39 CET 2006 [mika] +# Latest change: Mon Apr 09 12:47:28 CEST 2007 ####################################################################################### # hardcoded configurable options @@ -171,19 +171,32 @@ FAILED=" ${NORMAL}[${RED}fail${NORMAL}]" # echo "$CLEAR" # Just go to the top of the screen # echo -n "" +DISTRI="$(getbootparam 'distri' 2>/dev/null)" +if [ -n "$DISTRI" ] ; then +SPLASH=" +${RED} $DISTRI + +${WHITE}based on grml.org. + +${NORMAL}" +else +SPLASH=" +${RED} ____ ____ __ __ _ +${RED} / ___| _ \| \/ | | +${RED} | | _| |_) | |\/| | | +${RED} | |_| | _ <| | | | |___ +${RED} \____|_| \_\_| |_|_____| + +${WHITE}grml.org - Linux for users of texttools and sysadmins. + +${NORMAL}" +fi + echo "" echo "${WHITE}Welcome to" -echo "" -echo "${RED} ____ ____ __ __ _ " -echo "${RED} / ___| _ \| \/ | | " -echo "${RED} | | _| |_) | |\/| | | " -echo "${RED} | |_| | _ <| | | | |___ " -echo "${RED} \____|_| \_\_| |_|_____|" -echo "" -echo "${WHITE}grml.org - Linux for users of texttools and sysadmins." -echo "${NORMAL}" +echo "$SPLASH" -# We only need the builtin commands and /static at this point +# We need the builtin commands and /static only starting at this point PATH=/static export PATH @@ -216,12 +229,37 @@ GRML_NAME="GRML" case "$CMDLINE" in *grml_dir=*) GRML_DIR="$grml_dir"; ;; esac case "$CMDLINE" in *grml_name=*) GRML_NAME="$grml_name"; ;; esac +# NFS +for i in $cmdline; do case "$i" in nfsdir=*|NFSDIR=*) eval $i;; esac; done +[ -n "$nfsdir" ] && NFS="$nfsdir" + if [ -n "$DEBUG" ]; then log_begin_msg "Bootoption debug detected. Printing kernel command line:" echo "" cat /proc/cmdline fi +# check for available ram +RAM=$(/static/awk '/MemTotal/{print $2}' /proc/meminfo) +log_begin_msg "${RAM} kB of RAM available" + +case "$CMDLINE" in *small*) GRML_TYPE="small"; ;; esac + +if [ "$GRML_TYPE" = "small" ] +then + if [[ $RAM -lt 25000 ]] + then + log_end_msg "You need at least 32MB of RAM available for grml-small" + return 1 + fi +else + if [[ $RAM -lt 58000 ]] + then + log_end_msg "You need at least 64Mb of RAM available for grml" + return 1 + fi +fi + # Run a shell if in debug mode # echo "${BLUE}Dropping you to a busybox shell for debugging.${NORMAL}" stage=1 @@ -287,7 +325,7 @@ loadmodules(){ echo "" for i in "$@"; do echo -n " Probing ${TYPE}... ${WHITE}$i${NORMAL}: " - if test -f /modules/scsi/$i.ko && $INSMOD -f /modules/scsi/$i.ko >/dev/null 2>&1 && echo " $SUCCESS" || echo " failed " ; then + if test -f /modules/scsi/$i.ko && $INSMOD /modules/scsi/$i.ko >/dev/null 2>&1 && echo " $SUCCESS" || echo " failed " ; then case "$TYPE" in scsi|SCSI) FOUND_SCSI="yes"; ;; esac fi done @@ -322,7 +360,7 @@ fi # New sysfs based SCSI detection (thanks, Jörg Schirottke) sysfsscsi(){ -SYS=$(for x in $(find /sys/devices/ -name modalias); do grep pci: $x; done|cut -f2 -d:) +SYS=$(for x in $(find /sys/devices/ -name modalias); do grep pci: $x 2>/dev/null; done|cut -f2 -d:) while read id driver; do for sysid in $SYS; do case $sysid in $id) @@ -350,7 +388,7 @@ fi if test -z "$NOSCSI" ; then log_begin_msg "Scanning for SCSI devices." - $INSMOD -f /modules/scsi/firmware_class.ko 1>/dev/null + $INSMOD /modules/scsi/firmware_class.ko 1>/dev/null test -n "$MODULES" && loadmodules SCSI $MODULES && echo -n "" || echo " ${BLUE}[${NORMAL} none found ${BLUE}]${NORMAL} (try bootoption scsi=probe)" else log_warn_msg "Not scanning for SCSI devices as requested on commandline." && echo " $SUCCESS" @@ -361,10 +399,10 @@ if checkbootparam scsi ; then if test "$MODULE" = "probe" ; then log_begin_msg "Bootoption scsi=probe found. Trying to autoprobe SCSI modules:" echo "" - echo -n " Trying to load scsi_debug: " ; $INSMOD -f /modules/scsi/scsi_debug.ko 1>/dev/null && echo " $SUCCESS" || echo " [ failed ]" + echo -n " Trying to load scsi_debug: " ; $INSMOD /modules/scsi/scsi_debug.ko 1>/dev/null && echo " $SUCCESS" || echo " [ failed ]" for module in /modules/scsi/*.ko ; do echo -n " Probing ${WHITE}${module}${NORMAL}..." - $INSMOD -f ${module} >/dev/null 2>&1 && echo " $SUCCESS" || echo " [ failed ]" + $INSMOD ${module} >/dev/null 2>&1 && echo " $SUCCESS" || echo " [ failed ]" done elif test "$MODULE" = "ask" ; then askmodules SCSI $(cd /modules/scsi; echo *.ko) @@ -372,7 +410,7 @@ if checkbootparam scsi ; then else [ -n "$MODULE" ] || echo " ${RED}Neither a specific module nor option probe nor option ask for SCSI module given. Skipping.${NORMAL}" [ -n "$MODULE" ] && echo -n " Trying to load module ${WHITE}${MODULE}${NORMAL}:" ; \ - $INSMOD -f "/modules/scsi/${MODULE}.ko" 1>/dev/null && echo " $SUCCESS" || echo " [ failed ]" + $INSMOD "/modules/scsi/${MODULE}.ko" 1>/dev/null && echo " $SUCCESS" || echo " [ failed ]" fi fi # End of SCSI check @@ -382,7 +420,7 @@ if test -n "$VMWARE" ; then echo "" for module in mptbase mptscsih mptspi BusLogic ; do echo -n " Trying to load ${WHITE}${module}${NORMAL}: " - $INSMOD -f /modules/scsi/${module}.ko >/dev/null 2>&1 && echo " $SUCCESS" || echo " [ failed ]" + $INSMOD /modules/scsi/${module}.ko >/dev/null 2>&1 && echo " $SUCCESS" || echo " [ failed ]" done fi @@ -458,11 +496,11 @@ fi # boot via pcmcia if checkbootparam bootpcmcia ; then log_begin_msg "Bootoption bootpcmcia found. Trying to load ${WHITE}PCMCIA${NORMAL} modules..." - if $INSMOD -f /modules/div/pcmcia_core.ko 1>/dev/null ; then - $INSMOD -f /modules/div/firmware_class.ko 1>/dev/null && \ - $INSMOD -f /modules/div/pcmcia.ko 1>/dev/null && \ - $INSMOD -f /modules/div/rsrc_nonstatic.ko 1>/dev/null && \ - $INSMOD -f /modules/div/yenta_socket.ko 1>/dev/null && echo " $SUCCESS" + if $INSMOD /modules/div/pcmcia_core.ko 1>/dev/null ; then + $INSMOD /modules/div/firmware_class.ko 1>/dev/null && \ + $INSMOD /modules/div/pcmcia.ko 1>/dev/null && \ + $INSMOD /modules/div/rsrc_nonstatic.ko 1>/dev/null && \ + $INSMOD /modules/div/yenta_socket.ko 1>/dev/null && echo " $SUCCESS" else echo " [ failed ]" fi @@ -508,57 +546,51 @@ esac stage=2 rundebugshell -# NFS -for i in $cmdline; do case "$i" in nfsdir=*|NFSDIR=*) eval $i;; esac; done -[ -n "$nfsdir" ] && NFS="$nfsdir" if [ -n "$NFS" ]; then tmp_="$(getbootparam nfsdir)" log_begin_msg "Bootoption NFS found." ; echo "$SUCCESS" - # put the mylibs into /lib for discover and udhcpc - cdir - - # starting hw-detection for network card - currently broken, so don't use it - # echo "Starting hw-detection" - # kernel_version_=`uname -r` - # modules_to_load=$(/static/discover --disable-bus all --enable-bus pci --type network --normalize-whitespace --data-path=linux/module/name --data-version=$kernel_version_ | grep -v '^ $' | uniq) - # echo "trying to load the following network modules: \"$modules_to_load\"" + /static/cdir - KERNELVER=`uname -r` - for mod in `find /lib/modules/$KERNELVER/kernel/drivers/net/ -name \*.ko` ; do - echo `basename $mod | sed -e 's/\.ko$//'` >> /modules.load - done - modules_to_load=`cat /modules.load | xargs` - - # FIXME modprobe is buggy from busybox log_begin_msg "Trying to load network driver(s)." ; echo modLoad() { for mod in $@ ; do - tmp_="`modprobe -vn $mod 2>/dev/null`" - if [ $? -ne 0 ]; then - continue + if [ -n "$DEBUG" ] ; then + echo "Debug: trying to load $mod:" + modprobe -v $mod + else + modprobe $mod 2>/dev/null fi - # be quiet by default, be verbose only with bootoption debuglinuxrc - [ -n "$DEBUG" ] && eval "$tmp_" || eval "$tmp_" 1>/dev/null 2>/dev/null done } - modLoad "$modules_to_load" - rm -f /modules.load - + # modules.alias and modules.dep are in place so USE IT :)! + find /sys/devices/ -name modalias |/static/xargs -r /static/grep -h pci: |while read i; do + modLoad "$i" + done # loading additional modules modLoad sunrpc lockd af_packet nfs - for INTERFACE in `ifconfig -a | grep '^eth' | sed 's/\ .*//'` ; do + dhcp_iface_=$(getbootparam dhcp_iface) + if [ -z "$dhcp_iface_" ]; then + dhcp_iface_=`ifconfig -a | grep '^eth' | sed 's/ .*//'` + fi + + # make sure we have a udhcpc executable, if it's not present + # assume that busybox provides one + if ! [ -x /static/udhcpc ] ; then + ln -s /static/busybox /static/udhcpc + fi + + for INTERFACE in $dhcp_iface_ ; do log_begin_msg "Requesting network configuration using udhcp for ${INTERFACE}:" ; echo /static/timeout 10 /static/udhcpc --interface="${INTERFACE}" --foreground --quit --script=/static/udhcp-config.sh # echo "press to start a system shell and configure your system" # sh done - # recreate the old dir structures - rdir - #rm -rf /myusr /mylib + # recreate dir layout + remove extra modules + /static/rdir log_begin_msg "Looking for GRML in: ${MAGENTA}$NFS${NORMAL}" ; echo "$SUCCESS" if mount -t nfs "$NFS" -o "async,ro,nolock" /cdrom #>/dev/null 2>&1 @@ -573,31 +605,41 @@ if [ -n "$NFS" ]; then fi # Now that the right SCSI driver is (hopefully) loaded, try to find CD-ROM -if test -z $NFS ; then - DEVICES="/dev/hd?" - test -n "$FOUND_SCSI" -a -z "$NOCD" && DEVICES="/dev/scd? /dev/scd?? $DEVICES" - # New: Also try parallel port CD-Roms [for Mike]. - DEVICES="$DEVICES /dev/pcd?" - # New: also check HD partitions for a GRML/GRML image - # notice: use /dev/sd? for usb-sticks without partition(s) - test -n "$FOUND_SCSI" -a -z "$NOSCSI" && DEVICES="$DEVICES /dev/sd?[1-9] /dev/sd?[1-9][0-9] /dev/sd?" - DEVICES="$DEVICES /dev/hd?[1-9] /dev/hd?[1-9][0-9]" - case "$CMDLINE" in *fromhd=/dev/*) DEVICES="$fromhd"; ;; esac - for i in $DEVICES - do - log_begin_msg "${CRE} ${GREEN}*${NORMAL} Looking for CD-ROM in: ${MAGENTA}$i${NORMAL}" - if mountit $i /cdrom "-o ro" >/dev/null 2>&1 - then - echo " $SUCCESS" - if test -f /cdrom/$GRML_DIR/$GRML_NAME - then - log_begin_msg "Accessing grml CD-ROM at: ${MAGENTA}$i${NORMAL}" ; echo " $SUCCESS" - FOUND_GRML="$i" - break - fi - umount /cdrom +grmlmount() +{ + if test -z $NFS ; then + DEVICES="/dev/hd?" + test -n "$FOUND_SCSI" -a -z "$NOCD" && DEVICES="/dev/scd? /dev/scd?? $DEVICES" + # New: Also try parallel port CD-ROMs + DEVICES="$DEVICES /dev/pcd?" + # New: also check HD partitions for a GRML/GRML image + # notice: use /dev/sd? for usb-sticks without partition(s) + test -n "$FOUND_SCSI" -a -z "$NOSCSI" && DEVICES="$DEVICES /dev/sd?[1-9] /dev/sd?[1-9][0-9] /dev/sd?" + DEVICES="$DEVICES /dev/hd?[1-9] /dev/hd?[1-9][0-9]" + case "$CMDLINE" in *fromhd=/dev/*) DEVICES="$fromhd"; ;; esac + for i in $DEVICES ; do + log_begin_msg "${CRE} ${GREEN}*${NORMAL} Looking for CD-ROM in: ${MAGENTA}$i${NORMAL}" + if mountit $i /cdrom "-o ro" >/dev/null 2>&1 ; then + echo " $SUCCESS" + if test -f /cdrom/$GRML_DIR/$GRML_NAME ; then + log_begin_msg "Accessing grml CD-ROM at: ${MAGENTA}$i${NORMAL}" ; echo " $SUCCESS" + FOUND_GRML="$i" + break + fi + umount /cdrom + fi + done fi - done +} + +# Rerun the grml-CDROM part 3 times at total +if ! grmlmount ; then + log_warning_msg "grml CD-ROM not yet found, sleeping for 5 seconds and trying again then." + sleep 5 + if ! grmlmount ; then + log_warning_msg "grml CD-ROM still not yet found, sleeping for 5 more seconds and trying once more again." + sleep 5 + fi fi # Harddisk-installed script part version has been removed @@ -640,7 +682,7 @@ boot_from() # load filesystems /GRML/sbin/modprobe fuse /GRML/sbin/modprobe ntfs - $INSMOD -f /modules/div/ntfs.ko 1>/dev/null + $INSMOD /modules/div/ntfs.ko 1>/dev/null if [ -n "$ISO_PATH" ]; then LOOP_SOURCE="$TARGET.loop" @@ -802,17 +844,24 @@ if test -n "$DO_REMOUNT" -a -n "$FOUND_GRML" ; then fi # Final test if everything succeeded. -if test -n "$FOUND_GRML" -then +if test -n "$FOUND_GRML" ; then # copy library cache cat /GRML/etc/ld.so.cache > /etc/ld.so.cache UNIONFS="" -$INSMOD /modules/unionfs.ko 1>/dev/null -grep -q unionfs /proc/filesystems && UNIONFS=yes - -# Enable kernel messages -echo "6" > /proc/sys/kernel/printk +if checkbootparam "unionfs" ; then + $INSMOD /modules/unionfs.ko 1>/dev/null + grep -q unionfs /proc/filesystems && UNIONFS=yes + unionfs='unionfs' + UNIONFS_FILETYPE='unionfs' + AUFS='' +else + $INSMOD /modules/aufs.ko 1>/dev/null + grep -q aufs /proc/filesystems && UNIONFS=yes + unionfs='unionfs (using aufs)' + UNIONFS_FILETYPE='aufs' + AUFS='yes' +fi # Set paths log_begin_msg "Setting paths" @@ -865,38 +914,55 @@ MINSIZE=20000 # At least this much memory minus 30% should remain when home and var are full. MINLEFT=16000 # Maximum ramdisk size -[ -n "$TOTALMEM" ] && MAXSIZE="$(expr $TOTALMEM - $MINLEFT)" +[ -n "$TOTALMEM" ] && MAXSIZE="$(/usr/bin/expr $TOTALMEM - $MINLEFT)" # Default ramdisk size for ramdisk -[ -n "$TOTALMEM" ] && RAMSIZE="$(expr $TOTALMEM / 5)" +[ -n "$TOTALMEM" ] && RAMSIZE="$(/usr/bin/expr $TOTALMEM / 5)" # Create additional dynamic ramdisk. test -z "$RAMSIZE" -o "$RAMSIZE" -lt "$MINSIZE" && RAMSIZE="$MINSIZE" mkdir -p /ramdisk # tmpfs/varsize version, can use swap -RAMSIZE=$(expr $RAMSIZE \* 4) +RAMSIZE=$(/usr/bin/expr $RAMSIZE \* 4) log_begin_msg "Creating /ramdisk (dynamic size=${RAMSIZE}k) on shared memory" # We need /bin/mount here for the -o size= option /bin/mount -t tmpfs -o "size=${RAMSIZE}k" /ramdisk /ramdisk && echo "$SUCCESS" -mkdir -p /ramdisk/tmp /ramdisk/home/grml && chmod 1777 /ramdisk/tmp && chown grml.grml /ramdisk/home/grml && ln -snf /ramdisk/home /home && mv /tmp /tmp.old && ln -s /ramdisk/tmp /tmp && rm -rf /tmp.old +mkdir -p /ramdisk/tmp /ramdisk/home/grml && chmod 1777 /ramdisk/tmp && chown grml.grml /ramdisk/home/grml && ln -snf /ramdisk/home /home && /bin/mv /tmp /tmp.old && ln -s /ramdisk/tmp /tmp && rm -rf /tmp.old stage=3 rundebugshell # unionfs -log_begin_msg "Creating unionfs and symlinks on ramdisk" +log_begin_msg "Creating $unionfs and symlinks on ramdisk" mkdir -p /UNIONFS -if test -n "$UNIONFS" && /bin/mount -t unionfs -o noatime${SECURE},dirs=/ramdisk=rw:/GRML=ro /UNIONFS /UNIONFS; then +if test -n "$UNIONFS" && /bin/mount -t $UNIONFS_FILETYPE -o noatime${SECURE},dirs=/ramdisk=rw:/GRML=ro /UNIONFS /UNIONFS ; then + # check architecture + if [ -f /GRML/lib/ld-linux.so.2 ] ; then + LDLINUX=/GRML/lib/ld-linux.so.2 + GRMLLIB=/GRML/lib + elif [ -f /GRML/lib64/ld-linux-x86-64.so.2 ] ; then + LDLINUX=/GRML/lib64/ld-linux-x86-64.so.2 + EMUL='emul' + LIB64='lib64' + GRMLLIB=/GRML/lib64 + fi # We now have unionfs, copy some data from the initial ramdisk first cp -a /etc/fstab /etc/auto.mnt /etc/filesystems /etc/mtab /UNIONFS/etc/ - for i in bin boot etc sbin var lib opt root usr; do # Move directories to unionfs + # disable resolvconf on the terminalserver client + if [ -n "$NFS" ] ; then + rm /UNIONFS/etc/resolv.conf + cp -a /etc/resolv.conf /UNIONFS/etc + echo REPORT_ABSENT_SYMLINK=no >> /UNIONFS/etc/default/resolvconf + fi + for i in bin boot etc sbin var opt root usr $EMUL $LIB64 lib ; do # Move directories to unionfs if test -d /$i; then - mv /$i /$i.old && \ - /GRML/lib/ld-linux.so.2 --library-path /GRML/lib /GRML/bin/ln -snf /UNIONFS/$i /$i && \ + /bin/mv /$i /$i.old && \ + # /GRML/lib/ld-linux.so.2 --library-path /GRML/lib /GRML/bin/ln -snf /UNIONFS/$i /$i && \ + $LDLINUX --library-path $GRMLLIB /GRML/bin/ln -snf /UNIONFS/$i /$i 1>/dev/null 2>/dev/null rm -rf /$i.old else ln -snf /UNIONFS/$i /$i fi done - echo " $SUCCESS" + [ -n "$AUFS" ] && echo " $SUCCESS" || echo " $SUCCESS" log_begin_msg "Merging read-only system with read-writeable /ramdisk." for i in $(cd /UNIONFS; echo *); do # Create links for new stuff on /UNIONFS test "$i" = "home" -o "$i" = "tmp" && continue @@ -906,8 +972,10 @@ else echo "" log_failure_msg "ERROR: CANNOT UNITE READ-ONLY MEDIA AND INITIAL RAMDISK!" echo "$FAILED" - NOUNIONFS="yes" - /GRML/sbin/halt -f -n + sleep 2 + echo "Can not continue booting, dropping you to a busybox shell." + stage=4 + rundebugshell fi chown grml.grml /home/grml @@ -945,7 +1013,7 @@ echo "/sbin/modprobe" > /proc/sys/kernel/modprobe # Change root device from /dev/fd0 to /dev/ram0 echo "0x100" > /proc/sys/kernel/real-root-dev -umount /sys # (remount in grml-autoconfig) +/bin/umount /sys # (remount in grml-autoconfig) stage=4 rundebugshell