#!/bin/sh - # # THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT. # generated from: # # OpenBSD: etc.vax/MAKEDEV.md,v 1.13 2003/06/18 18:08:59 todd Exp # OpenBSD: MAKEDEV.mi,v 1.65 2004/01/12 22:31:34 todd Exp # OpenBSD: MAKEDEV.sub,v 1.9 2004/01/12 22:18:24 todd Exp # # # Copyright (c) 2001,2002,2003 Todd T. Fries # # Permission to use, copy, modify, and distribute this software for any # purpose with or without fee is hereby granted, provided that the above # copyright notice and this permission notice appear in all copies. # # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. # # Device "make" file. Valid arguments: # all makes all known devices, including local devices. # Tries to make the ``standard'' number of each type. # std standard devices # local configuration specific devices # Tapes: # st* SCSI tapes # mt* (Magnetic) 9-track reel tape # ht* massbus tm03 & tu?? # tm* unibus tm11 & te10 emulations (e.g. Emulex tc-11) # ts* unibus ts11 # ut* unibus tu45 emulations (e.g.si 9700) # Disks: # hp* massbuss rm?? # hk* unibus rk06 and rk07 # up* other unibus devices (e.g. on Emulex sc-21v controller) # ra* MSCP disks (ra??, hd??) # rb* 730 idc w/ rb80 and/or rb02 # rx* MSCP floppy disk (rx33/50/...) # rl* unibus r102 # hd* HP300 HP-IB disks # sd* SCSI disks # cd* SCSI cdrom drives # ch* SCSI media changer # ss* SCSI scanners # uk* SCSI Unknown device # rd* "rd" pseudo-disks # fd* Floppy disk drives (3 1/2", 5 1/4") # vnd* "file" pseudo-disks # ccd* concatenated disk devices # Pseudo terminals: # tty* set of 16 slave psuedo terminals # pty* set of 16 master pseudo terminals # Printers: # Terminal ports: # dhu* unibus dhu11 # dh* unibus dh11 and emulations (e.g. Able dmax, Emulex cs-11) # dmf* unibus dmf32 # dmz* unibus dmz32 # vt* console # dz* unibus dz11 and dz32 # dl* unibus dl11 # Special purpose devices: # openprom # bpf* Berkeley Packet Filter # pf* Packet Filter # lkm loadable kernel modules interface # tun* network tunnel driver # *random inkernel random data source # magma* magma card (makes 16 tty and 2 bpp) # xfs* XFS filesystem devices # raid* RAIDframe disk devices # fd makes fd/* for the fdescfs # ses* SES/SAF-TE SCSI devices # systrace* system call tracing device PATH=/sbin:/usr/sbin:/bin:/usr/bin T=$0 # set this to echo for Echo-Only debugging [ "$eo" ] || eo= hex() { case $1 in [0-9]) echo -n $1;; 10) echo -n a;; 11) echo -n b;; 12) echo -n c;; 13) echo -n d;; 14) echo -n e;; 15) echo -n f;; esac } alph2d() { local t="$1" local p="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" local sub=${p%${t}*} echo ${#sub} } h2d() { local s="$1" local f=${s%*[0-9a-f]} n=${s#[0-9a-f]*} echo $(($(_h2d $f)*16+ $(_h2d $n) )) } _h2d() { case $1 in [0-9]) echo -n $1;; a) echo -n 10;; b) echo -n 11;; c) echo -n 12;; d) echo -n 13;; e) echo -n 14;; f) echo -n 15;; esac } unt() { # XXX pdksh can't seem to deal with locally scoped variables # in ${foo#$bar} expansions arg="$1" tmp="${arg#[a-zA-Z]*}" tmp="${tmp%*[a-zA-Z]}" while [ "$tmp" != "$arg" ] do arg=$tmp tmp="${arg#[a-zA-Z]*}" tmp="${tmp%*[a-zA-Z]}" done echo $arg } dodisk() { [ "$DEBUG" ] && set -x n=$(($((${5}*${7:-16}))+${6})) count=0 RMlist="$RMlist $1$2? r$1$2?" [ 0$7 -ne 8 ] && l="i j k l m n o p" for d in a b c d e f g h $l do M $1$2$d b $3 $(($n+$count)) 640 M r$1$2$d c $4 $(($n+$count)) 640 let count=count+1 done MKlist="$MKlist;chown root:operator $1$2? r$1$2?" } dodisk2() { n=$(($(($5*${7:-16}))+$6)) M $1$2a b $3 $n 640 operator M r$1$2a c $4 $n 640 operator n=$(($n+2)) M $1$2c b $3 $n 640 operator M r$1$2c c $4 $n 640 operator } # M name b/c major minor [mode] [group] RMlist="rm -f" MKlist=":" mkl() { [ "${mklist[$1]}" ] && { mklist[$1]="${mklist[$1]};mknod -m $1 $2 $3 $4 $5" } || { mklist[$1]="mknod -m $1 $2 $3 $4 $5" modes="$modes $1" } } M() { RMlist="$RMlist $1" mkl ${5-666} $1 $2 $3 $4 mklist="$mklist $1" G=${6:-wheel} [ "$7" ] && { MKlist="$MKlist;chown $7:$G $1" } || { case $G in wheel)g=0;;kmem)g=2;;operator)g=5;;tty)g=4;;dialer)g=117;;_lkm)g=61;; esac [ "${grplist[$g]}" ] && { grplist[$g]="${grplist[$g]} $1" } || { groups="$groups $g" grplist[$g]="chgrp $G $1" } } return 0 } R() { [ "$DEBUG" ] && set -x for i in "$@" do U=`unt $i` [ "$U" ] || U=0 case $i in ramdisk) R std random R fd0 sd0 sd1 rd0 ;; std) M console c 0 0 600 M tty c 2 0 M mem c 3 0 640 kmem M kmem c 3 1 640 kmem M null c 3 2 M zero c 3 12 M stdin c 53 0 M stdout c 53 1 M stderr c 53 2 M ksyms c 50 0 640 kmem M drum c 7 0 640 kmem M klog c 33 0 600 M ttyg0 c 25 0 600 M ttyg1 c 25 1 600 M ttyg2 c 25 2 600 M ttyg3 c 25 3 600 M crl c 35 0 600 M csa1 c 51 0 600 M csa2 c 51 1 600 M tu0 b 8 0 600 M tu1 b 8 1 600 M floppy c 8 0 600 M kUmem c 3 3 600 ;; ht*|tm*|mt*|ts*|ut*) case $i in ht*) n=ht b=1 c=5;; mt*) n=mt b=15 c=38;; tm*) n=tm b=5 c=14;; ts*) n=ts b=6 c=16;; ut*) n=ut b=10 c=17;; esac case $U in [0-7]) four=$(($U+4)) eight=$(($U+8)) twelve=$(($U+12)) twenty=$(($U+20)) M $n$U b $b $U 660 operator M $n$four b $b $four 660 operator M $n$eight b $b $eight 660 operator M $n$twelve b $b $twelve 660 operator M n$n$U b $b $four 660 operator;: sanity w/pdp11 v7 M n$n$eight b $b $twelve 660 operator;: ditto M nr$n$U c $c $four 660 operator;: ditto M nr$n$eight c $c $twelve 660 operator;: ditto M r$n$U c $c $U 660 operator M r$n$four c $c $four 660 operator M r$n$eight c $c $eight 660 operator M r$n$twelve c $c $twelve 660 operator if [ "$i" = "ut" ]; then M $n$twenty b $b $twenty 660 operator M r$n$twenty c $b $twenty 660 operator fi ;; *) echo bad unit for tape in: $i ;; esac umask 77 ;; systrace) M systrace c 49 0 644 ;; ses*) M ses$U c 124 $U 640 operator ;; fd) RMlist="mkdir -p fd;$RMlist" n=0 while [ $n -lt 64 ];do M fd/$n c 53 $n;n=$(($n+1));done MKlist="$MKlist;chmod 555 fd" ;; xfs*) M xfs$U c 51 $U 600 ;; magma*) case $U in 0) offset=0 nam=m;; 1) offset=16 nam=n;; 2) offset=32 nam=o;; *) echo "bad unit for $i: $U"; exit 127;; esac offset=$(($U*64)) n=0 while [ $n -lt 16 ] do name=${nam}`hex $n` M tty$name c major_mag_c $(($offset+$n)) 660 dialer uucp n=$(($n+1)) done M bpp${nam}0 c major_bppmag_c $(($offset+0)) 600 M bpp${nam}1 c major_bppmag_c $(($offset+1)) 600 ;; *random) n=0 for pre in " " s u p a do M ${pre}random c 67 $n 644 n=$(($n+1)) done ;; tun*) M tun$U c 57 $U 600 ;; lkm) M lkm c 28 0 640 _lkm ;; pf*) M pf c 42 0 600 ;; bpf*) M bpf$U c 56 $U 600 ;; openprom) M openprom c 70 0 ;; dz*) case $U in [0-7]) i=0 while [ $i -lt 8 ]; do no=$(($(($U*8))+$i)) if [ $no -lt 10 ]; then no="0${no}" fi M tty${no} c 1 $no 600 let i=i+1 done ;; *) echo bad unit for dz in: $i ;; esac ;; dhu*|dmz*|dmf*|dh*|vt*) set -A cnvtbl 0 1 2 3 4 5 6 7 8 9 a b c d e f g h i j k l m n o p q r s t u v case $i in vt*) name=vt; major=68; count=8; case $U in 0) ch=w ;; *) echo bad unit for $name in: $i ;; esac;; dmz*) name=dmz; major=37; count=24; case $U in 0) ch=a ;; 1) ch=b ;; 2) ch=c ;; 3) ch=e ;; 4) ch=f ;; *) echo bad unit for $name in: $i ;; esac;; dmf*) name=dmf; major=22; count=8; case $U in 0) ch=A ;; 1) ch=B ;; 2) ch=C ;; 3) ch=E ;; 4) ch=F ;; 5) ch=G ;; 6) ch=H ;; 7) ch=I ;; *) echo bad unit for $name in: $i ;; esac;; dhu*) name=dhu; major=34; count=16; case $U in 0) ch=S ;; 1) ch=T ;; 2) ch=U ;; 3) ch=V ;; 4) ch=W ;; 5) ch=X ;; 6) ch=Y ;; 7) ch=Z ;; *) echo bad unit for $name in: $i ;; esac;; dh*) name=dh; major=12; count=16; case $U in 0) ch=h ;; 1) ch=i ;; 2) ch=j ;; 3) ch=k ;; 4) ch=l ;; 5) ch=m ;; 6) ch=n ;; 7) ch=o ;; *) echo bad unit for $name in: $i ;; esac;; esac i=0 while [ $i -lt $count ]; do let=${cnvtbl[$i]} if [ -n "$let" ] ;then M tty${ch}${let} c $major $(($(($U*$count))+$i)) 600 else echo bad count for ${name}: $U, $count, $i fi let i=i+1 done ;; dl*) major=66 let=${cnvtbl[$U]} if [ -n "$let" ] ;then M ttyJ${let} c $major $U 600 else echo bad number for ${name}: $U fi ;; pty*) if [ $U -gt 15 ]; then echo bad unit for pty in: $i continue fi set -A tbl p q r s t u v w x y z P Q R S T name=${tbl[$U]} n=0 while [ $n -lt 16 ] do nam=$name$(hex $n) off=$(($U*16)) M tty$nam c 20 $(($off+$n)) M pty$nam c 21 $(($off+$n)) n=$(($n+1)) done ;; vnd*) dodisk vnd $U 18 55 $U 0 dodisk svnd $U 18 55 $U 2048 ;; fd*) typnam=$U${i#fd[01]*} case $typnam in 0|1) typnum=0;; # no type specified, assume A *A) typnum=0; typnam=0;; *B) typnum=1;; *C) typnum=2;; *D) typnum=3;; *E) typnum=4;; *F) typnum=5;; *G) typnum=6;; *H) typnum=7;; *) echo bad type $typnam for $i; exit 1;; esac case $U in 0|1) blk=16; chr=54;; *) echo bad unit $U for $i; exit 1;; esac nam=fd${typnam} n=$(($(($U*128))+$(($typnum*16)))) M ${nam}a b $blk $n 640 operator M ${nam}b b $blk $(($n+1)) 640 operator M ${nam}c b $blk $(($n+2)) 640 operator M r${nam}a c $chr $n 640 operator M r${nam}b c $chr $(($n+1)) 640 operator M r${nam}c c $chr $(($n+2)) 640 operator ;; rd*) dodisk2 rd $U 23 62 $U 0 ;; uk*) M uk$U c 65 $U 640 operator ;; ss*) M ss$U c 64 $(($U*16)) 640 operator M nss$U c 64 $(($(($U*16))+1)) 640 operator M enss$U c 64 $(($(($U*16))+3)) 640 operator RMlist="$RMlist scan$U" MKlist="$MKlist;umask 77;ln -s ss$U scan$U" ;; ch*) M ch$U c 63 $U 660 operator ;; cd*) dodisk2 cd $U 22 61 $U 0 ;; st*) n=$(($U*16)) for pre in " " n e en do M ${pre}st$U b 21 $n 660 operator M ${pre}rst$U c 60 $n 660 operator n=$(($n+1)) done ;; local) test -s $T.local && sh $T.local ;; all) R vt0 dl0 dz0 dhu0 ts0 ts1 mt0 mt1 hd0 hd1 hd2 ccd0 vnd0 sd0 R sd1 sd2 sd3 cd0 tun0 tun1 bpf0 bpf1 bpf2 bpf3 bpf4 bpf5 bpf6 R bpf7 pty0 pty1 ss0 uk0 random lkm pf systrace rx0 rx1 ra0 R ra1 ra2 ra3 hp0 hp1 hp2 hp3 raid0 raid1 raid2 raid3 std st0 R st1 fd ;; up*|sd*|rx*|rl*|rb*|raid*|ra*|hp*|hk*|hd*|ccd*) case $i in up*) dodisk up $U 2 13 $U 0;; sd*) dodisk sd $U 20 59 $U 0;; rx*) dodisk rx $U 12 30 $U 0;; rl*) dodisk rl $U 14 32 $U 0;; rb*) dodisk rb $U 11 23 $U 0;; raid*) dodisk raid $U 25 73 $U 0;; ra*) dodisk ra $U 9 9 $U 0;; hp*) dodisk hp $U 0 4 $U 0;; hk*) dodisk hk $U 3 11 $U 0;; hd*) dodisk hd $U 19 58 $U 0;; ccd*) dodisk ccd $U 17 54 $U 0;; esac ;; *) echo $i: unknown device ;; esac done } R "$@" if [ "$os" = "SunOS" ]; then eo=transform transform() { case $mode in 600) mask=077;; 640) mask=027;; 660) mask=007;; 644) mask=022;; 666) mask=0;; 440) mask=227;; esac echo `echo "$@"|sed \ 's/mknod -m \([0-9]*\) /umask '$mask';mknod /;s/-m [0-9]* //g;\ s/operator/5/g;s/root.kmem/root.2/g;s/root\./root:/g'` } fi list="$RMlist" for mode in $modes; do list="$list;${mklist[$mode]}" done for group in $groups; do list="$list;${grplist[$group]}" done list="$list;$MKlist" if [ "$eo" = "echo" -o "$eo" = "transform" ]; then $eo "$list" else echo "$list" | sh fi