]> git.lizzy.rs Git - plan9front.git/blobdiff - sys/src/9/boot/local.rc
serial console stuff
[plan9front.git] / sys / src / 9 / boot / local.rc
index 2808a9c0b7c116e05d23a2c90b34b746f8c6d057..e67550691ef4883d520b560e8c038d7f549121f0 100755 (executable)
@@ -2,24 +2,33 @@
 
 fn showlocaldevs{
        echo local devices found:
-       for(d in /dev/sd*){
-               if(test -r $d/ctl){
-                       q=`{sed 's,(inquiry|geometry),\
+       for(d in /dev/sd*) if(test -r $d/ctl){
+               q=`{sed 's,(inquiry|geometry),\
 \1,g' $d/ctl | grep inquiry}
-                       echo $d':' $q(2-)
-                       for(i in `{ls -p $d}){
-                               p=$d/$i
-                               switch($i){
-                               case ctl raw log
-                                       ;
-                               case 9fat plan9 nvram
-                                       echo $p
-                               case *
-                                       t=`{fstype $p}
-                                       if(~ $#bootargs 0 && ! ~ $t '')
-                                               bootargs=local!$p
-                                       echo $p $t
-                               }
+               echo $d':' $q(2-)
+               for(i in `{ls -p $d}){
+                       p=$d/$i
+                       switch($i){
+                       case ctl raw log
+                               ;
+                       case 9fat plan9 nvram
+                               echo $p
+                       case *
+                               t=`{fstype $p}
+                               if(~ $#bootargs 0 && ! ~ $t '')
+                                       bootargs=local!$p
+                               echo $p $t
+                       }
+               }
+       }
+       for(d in /shr/sd*) if(test -d $d) {
+               echo $d':'
+               for(p in $d/*.^(iso kfs paq)) if(test -f $p){
+                       t=`{fstype $p}
+                       if(! ~ $t ''){
+                               if(~ $#bootargs 0)
+                                       bootargs=local!$p
+                               echo $p $t
                        }
                }
        }
@@ -34,7 +43,7 @@ fn bootfs{
 }
 
 fn connectlocal{
-       if(test -r $1)
+       if(test -f $1)
                t=`{fstype $1}
        if not {
                t=$1; shift
@@ -44,22 +53,10 @@ fn connectlocal{
                fatal unknown fstype $1
        case 9660
                bootfs 9660srv $*
+       case dos
+               bootfs dossrv $*
        case kfs
                bootfs disk/kfs $*
-       case dos
-               if(! test -f /srv/dos)
-                       dossrv
-               m=/mnt/dosboot
-               must mount /srv/dos $m $1
-               shift
-               if(~ $#* 0)
-                       f=$m/9front.iso
-               if not
-                       f=$m/$1
-               if(test -r $f)
-                       connectlocal $f
-               if not
-                       connectlocal $*
        case *
                bootfs $t $*
        }