#!/bin/sh - # # $NetBSD: MAKEDEV,v 1.5 1997/01/01 23:46:23 pk Exp $ # # Copyright (c) 1990 The Regents of the University of California. # All rights reserved. # # Written and contributed by W. Jolitz 12/90 # # Redistribution and use in source and binary forms are permitted provided # that: (1) source distributions retain this entire copyright notice and # comment, and (2) distributions including binaries display the following # acknowledgement: ``This product includes software developed by the # University of California, Berkeley and its contributors'' in the # documentation or other materials provided with the distribution and in # all advertising materials mentioning features or use of this software. # Neither the name of the University nor the names of its contributors may # be used to endorse or promote products derived from this software without # specific prior written permission. # THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED # WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. # # @(#)MAKEDEV 5.2 (Berkeley) 6/22/90 # # 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 # # Disks: # sd* SCSI disks # cd* SCSI CD-ROM # vnd* "file" pseudo-disks # md* "memory" pseudo-disks # ccd* contatenated disk devices # # Pseudo terminals: # pty* set of 16 master and slave pseudo terminals # # Printers: # lpt* stock lp # lpa* interruptless lp # # Call units: # # Special purpose devices: # fd file descriptors # bpf* packet filter # lkm loadable kernel modules interface # tun* network tunnel driver # ss* SCSI scanner # uk* SCSI unknown # ch* SCSI changer # PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/etc umask 77 for i do case $i in all) sh $0 std fd sd0 sd1 sd2 pty0 sh $0 st0 st1 ch0 cd0 cd1 lpa0 lpt0 vnd0 vnd1 sh $0 bpf0 bpf1 bpf2 bpf3 bpf4 bpf5 bpf6 bpf7 bpf8 bpf9 sh $0 tun0 tun1 sh $0 ccd0 ccd1 ccd2 ccd3 md0 ss0 ch0 uk0 uk1 lkm sh $0 local ;; std) rm -f console drum mem kmem null zero tty klog stdin stdout stderr mknod console c 0 0 mknod drum c 3 0 ; chmod 640 drum ; chgrp kmem drum mknod kmem c 2 1 ; chmod 640 kmem ; chgrp kmem kmem mknod mem c 2 0 ; chmod 640 mem ; chgrp kmem mem mknod null c 2 2 ; chmod 666 null mknod zero c 2 12 ; chmod 666 zero mknod tty c 1 0 ; chmod 666 tty mknod klog c 6 0 ; chmod 600 klog mknod stdin c 21 0 ; chmod 666 stdin mknod stdout c 21 1 ; chmod 666 stdout mknod stderr c 21 2 ; chmod 666 stderr ;; fd) rm -f fd/* mkdir fd > /dev/null 2>&1 (cd fd && eval `echo "" | awk ' BEGIN { \ for (i = 0; i < 64; i++) \ printf("mknod %d c 21 %d;", i, i)}'`) chown -R bin.bin fd chmod 555 fd chmod 666 fd/* ;; md*) case $i in md*) name=md; unit=${i#md}; chr=32; blk=9;; esac rm -f $name$unit r$name$unit mknod $name$unit b $blk $(($unit + 0)) mknod r$name$unit c $chr $(($unit + 16)) chgrp operator $name$unit r$name$unit chmod 640 $name$unit r$name$unit ;; ss*) case $i in ss*) name=ss; unit=${i#ss}; chr=33;; esac rm -f $name$unit n$name$unit mknod $name$unit c $chr $(($unit * 16 + 0)) mknod n$name$unit c $chr $(($unit * 16 + 1)) chgrp operator $name$unit n$name$unit chmod 640 $name$unit n$name$unit ;; ccd*|sd*) case $i in ccd*) name=ccd; unit=${i#ccd}; blk=5; chr=17;; sd*) name=sd; unit=${i#sd}; blk=4; chr=8;; esac rm -f $name$unit? r$name$unit? mknod ${name}${unit}a b $blk $(($unit * 8 + 0)) mknod ${name}${unit}b b $blk $(($unit * 8 + 1)) mknod ${name}${unit}c b $blk $(($unit * 8 + 2)) mknod ${name}${unit}d b $blk $(($unit * 8 + 3)) mknod ${name}${unit}e b $blk $(($unit * 8 + 4)) mknod ${name}${unit}f b $blk $(($unit * 8 + 5)) mknod ${name}${unit}g b $blk $(($unit * 8 + 6)) mknod ${name}${unit}h b $blk $(($unit * 8 + 7)) mknod r${name}${unit}a c $chr $(($unit * 8 + 0)) mknod r${name}${unit}b c $chr $(($unit * 8 + 1)) mknod r${name}${unit}c c $chr $(($unit * 8 + 2)) mknod r${name}${unit}d c $chr $(($unit * 8 + 3)) mknod r${name}${unit}e c $chr $(($unit * 8 + 4)) mknod r${name}${unit}f c $chr $(($unit * 8 + 5)) mknod r${name}${unit}g c $chr $(($unit * 8 + 6)) mknod r${name}${unit}h c $chr $(($unit * 8 + 7)) chgrp operator $name$unit? r$name$unit? chmod 640 $name$unit? r$name$unit? ;; vnd*) umask 2 ; unit=${i#vnd} for name in vnd svnd; do blk=6; chr=19; case $name in vnd) off=0;; svnd) off=128;; esac rm -f $name$unit? r$name$unit? mknod ${name}${unit}a b $blk $(($unit * 8 + $off + 0)) mknod ${name}${unit}b b $blk $(($unit * 8 + $off + 1)) mknod ${name}${unit}c b $blk $(($unit * 8 + $off + 2)) mknod ${name}${unit}d b $blk $(($unit * 8 + $off + 3)) mknod ${name}${unit}e b $blk $(($unit * 8 + $off + 4)) mknod ${name}${unit}f b $blk $(($unit * 8 + $off + 5)) mknod ${name}${unit}g b $blk $(($unit * 8 + $off + 6)) mknod ${name}${unit}h b $blk $(($unit * 8 + $off + 7)) mknod r${name}${unit}a c $chr $(($unit * 8 + $off + 0)) mknod r${name}${unit}b c $chr $(($unit * 8 + $off + 1)) mknod r${name}${unit}c c $chr $(($unit * 8 + $off + 2)) mknod r${name}${unit}d c $chr $(($unit * 8 + $off + 3)) mknod r${name}${unit}e c $chr $(($unit * 8 + $off + 4)) mknod r${name}${unit}f c $chr $(($unit * 8 + $off + 5)) mknod r${name}${unit}g c $chr $(($unit * 8 + $off + 6)) mknod r${name}${unit}h c $chr $(($unit * 8 + $off + 7)) chown root.operator ${name}${unit}[a-h] r${name}${unit}[a-h] chmod 640 ${name}${unit}[a-h] r${name}${unit}[a-h] done umask 77 ;; pty*) class=${i#pty} case $class in 0) offset=0 name=p;; 1) offset=16 name=q;; 2) offset=32 name=r;; 3) offset=48 name=s;; # Note that telnetd, rlogind, and xterm (at least) only look at p-s. 4) offset=64 name=t;; *) echo bad unit for pty in: $i;; esac case $class in 0|1|2|3|4) umask 0 eval `echo $offset $name | awk ' { b=$1; n=$2 } END { for (i = 0; i < 16; i++) printf("rm -f tty%s%x; mknod tty%s%x c 4 %d; \ rm -f pty%s%x; mknod pty%s%x c 5 %d; ", \ n, i, n, i, b+i, n, i, n, i, b+i); }'` umask 77 ;; esac ;; st*) case $i in st*) name=st; unit=${i#st}; chr=20; blk=7;; esac rm -f $name$unit n$name$unit e$name$unit en$name$unit \ r$name$unit nr$name$unit er$name$unit enr$name$unit mknod $name$unit b $blk $(($unit * 16 + 0)) mknod n$name$unit b $blk $(($unit * 16 + 1)) mknod e$name$unit b $blk $(($unit * 16 + 2)) mknod en$name$unit b $blk $(($unit * 16 + 3)) mknod r$name$unit c $chr $(($unit * 16 + 0)) mknod nr$name$unit c $chr $(($unit * 16 + 1)) mknod er$name$unit c $chr $(($unit * 16 + 2)) mknod enr$name$unit c $chr $(($unit * 16 + 3)) chgrp operator $name$unit n$name$unit e$name$unit en$name$unit \ r$name$unit nr$name$unit er$name$unit enr$name$unit chmod 640 $name$unit n$name$unit e$name$unit en$name$unit \ r$name$unit nr$name$unit er$name$unit enr$name$unit ;; ch*|uk*) case $i in ch*) name=ch; unit=${i#ch}; chr=31;; uk*) name=uk; unit=${i#uk}; chr=34;; esac rm -f $name$unit mknod $name$unit c $chr $unit chgrp operator $name$unit chmod 640 $name$unit ;; cd*) case $i in cd*) name=cd; unit=${i#cd}; chr=18; blk=8;; esac rm -f $name$unit? r$name$unit? mknod ${name}${unit}a b $blk $(($unit * 8 + 0)) mknod ${name}${unit}d b $blk $(($unit * 8 + 3)) mknod r${name}${unit}a c $chr $(($unit * 8 + 0)) mknod r${name}${unit}d c $chr $(($unit * 8 + 3)) chgrp operator $name$unit? r$name$unit? chmod 640 $name$unit? r$name$unit? ;; lpt*|lpa*) case $i in lpt*) name=lpt; unit=${i#lpt}; chr=11; flags=0;; lpa*) name=lpa; unit=${i#lpa}; chr=11; flags=128;; esac rm -f $name$unit mknod $name$unit c $chr $(($unit + $flags)) chown root.wheel $name$unit ;; bpf*|tun*) case $i in bpf*) name=bpf; unit=${i#bpf}; chr=22;; tun*) name=tun; unit=${i#tun}; chr=23;; esac rm -f $name$unit mknod $name$unit c $chr $unit chown root.wheel $name$unit ;; lkm) rm -f lkm mknod lkm c 24 0 chown root.kmem lkm chmod 640 lkm ;; local) umask 0 test -s MAKEDEV.local && sh MAKEDEV.local ;; esac done