447 lines
12 KiB
Bash
447 lines
12 KiB
Bash
#!/bin/sh -
|
|
#
|
|
# $NetBSD: MAKEDEV,v 1.2 1999/03/26 04:37:30 mrg Exp $
|
|
#
|
|
# Copyright (c) 1990 The Regents of the University of California.
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions
|
|
# are met:
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# 3. All advertising materials mentioning features or use of this software
|
|
# must display the following acknowledgement:
|
|
# This product includes software developed by the University of
|
|
# California, Berkeley and its contributors.
|
|
# 4. 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 BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
# SUCH DAMAGE.
|
|
#
|
|
# @(#)MAKEDEV 5.5 (Berkeley) 5/28/91
|
|
#
|
|
# Device "make" file. Valid arguments:
|
|
# std standard devices
|
|
# local configuration specific devices
|
|
# Tapes:
|
|
# st* SCSI tape
|
|
# Disks:
|
|
# sd* SCSI disks
|
|
# cd* SCSI cdrom drives
|
|
# ch* SCSI changer
|
|
# xy* Xylogic 450/451 disks
|
|
# xd* Xylogic 753/7053 disks
|
|
# fd* Floppies
|
|
# vnd* "file" pseudo-disks
|
|
# ccd* concatenated disk devices
|
|
# raid* RAIDframe disk driver
|
|
# Pseudo terminals:
|
|
# pty* set of 16 master and slave pseudo terminals
|
|
# Printers:
|
|
# Call units:
|
|
# Special purpose devices:
|
|
# audio*
|
|
# openprom
|
|
# bwtwo*
|
|
# cgtwo*
|
|
# cgthree*
|
|
# cgfour*
|
|
# cgsix*
|
|
# cgeight*
|
|
# tcx*
|
|
# bpf* packet filter
|
|
# lkm loadable kernel modules interface
|
|
# tun* network tunnel driver
|
|
# md* memory pseudo-disk driver
|
|
# ipl ip filter
|
|
# random Random number generator
|
|
# scsibus* SCSI busses
|
|
|
|
dialin=0
|
|
dialout=524288 # high bit of the minor number
|
|
|
|
PATH=/sbin:/bin/:/usr/bin:/usr/sbin:/usr/etc
|
|
umask 77
|
|
|
|
for i
|
|
do
|
|
|
|
case $i in
|
|
|
|
all)
|
|
sh -$- $0 std ttya ttyb ttyc ttyd
|
|
sh -$- $0 fd sd0 sd1 sd2 sd3 sd4 xd0 xd1 xd2 xd3 xy0 xy1 xy2 xy3
|
|
sh -$- $0 cd0 st0 st1 fd0
|
|
sh -$- audio0 audio1 audio2 audio3
|
|
sh -$- $0 pty0 vnd0 vnd1 vnd2 vnd3 audio tun0 tun1 tun2 tun3
|
|
sh -$- $0 ccd0 ccd1 ccd2 ccd3 raid0 raid1 raid2 raid3
|
|
sh -$- $0 bpf0 bpf1 bpf2 bpf3 bpf4 bpf5 bpf6 bpf7
|
|
sh -$- $0 bwtwo0 cgtwo0 cgthree0 cgfour0 cgsix0
|
|
sh -$- $0 cgeight0 tcx0
|
|
sh -$- $0 scsibus0 scsibus1 scsibus2 scsibus3
|
|
sh -$- $0 lkm random local
|
|
;;
|
|
floppy)
|
|
sh -$- $0 std ttya ttyb ttyc ttyd pty0
|
|
sh -$- $0 sd0 sd1 sd2 sd3 sd4 sd5 md0
|
|
sh -$- $0 cd0 cd1 st0 st1 fd0
|
|
;;
|
|
std)
|
|
rm -f console tty kmem mem null zero eeprom openprom drum klog \
|
|
stdin stdout stderr fd/* ttya ttyb fb mouse kbd
|
|
mknod console c 0 0
|
|
mknod tty c 2 0 ; chmod 666 tty
|
|
mknod kmem c 3 1 ; chmod 640 kmem ; chgrp kmem kmem
|
|
mknod mem c 3 0 ; chmod 640 mem ; chgrp kmem mem
|
|
mknod null c 3 2 ; chmod 666 null
|
|
mknod zero c 3 12 ; chmod 666 zero
|
|
mknod eeprom c 3 11 ; chmod 640 eeprom ; chgrp kmem eeprom
|
|
mknod openprom c 70 0 ; chmod 640 openprom;chgrp kmem openprom
|
|
mknod drum c 7 0 ; chmod 640 drum ; chgrp kmem drum
|
|
mknod klog c 16 0 ; chmod 600 klog
|
|
mknod stdin c 24 0 ; chmod 666 stdin
|
|
mknod stdout c 24 1 ; chmod 666 stdout
|
|
mknod stderr c 24 2 ; chmod 666 stderr
|
|
|
|
mknod fb c 22 0 ; chmod 666 fb
|
|
mknod mouse c 13 0 ; chmod 666 mouse
|
|
mknod kbd c 29 0 ; chmod 666 kbd
|
|
;;
|
|
|
|
tty[abcd])
|
|
unit=${i#???}
|
|
case $unit in
|
|
a) index=0;;
|
|
b) index=1;;
|
|
c) index=4;;
|
|
d) index=5;;
|
|
esac
|
|
rm -f tty$unit dty$unit
|
|
mknod tty$unit c 12 $(($index + $dialin ))
|
|
mknod dty$unit c 12 $(($index + $dialout))
|
|
chown uucp.wheel tty$unit dty$unit
|
|
;;
|
|
|
|
fd)
|
|
rm -f fd/*
|
|
mkdir fd > /dev/null 2>&1
|
|
n=0
|
|
while [ $n -lt 64 ]; do
|
|
mknod fd/$n c 24 $n
|
|
n=$(($n + 1))
|
|
done
|
|
chown -R root.wheel fd
|
|
chmod 755 fd
|
|
chmod 666 fd/*
|
|
;;
|
|
|
|
bwtwo*)
|
|
unit=${i#bwtwo}
|
|
rm -f bwtwo$unit
|
|
mknod bwtwo$unit c 27 $unit; chmod 666 bwtwo$unit
|
|
;;
|
|
|
|
cgtwo*)
|
|
unit=${i#cgtwo}
|
|
rm -f cgtwo$unit
|
|
mknod cgtwo$unit c 31 $unit; chmod 666 cgtwo$unit
|
|
;;
|
|
|
|
cgthree*)
|
|
unit=${i#cgthree}
|
|
rm -f cgthree$unit
|
|
mknod cgthree$unit c 55 $unit; chmod 666 cgthree$unit
|
|
;;
|
|
|
|
cgfour*)
|
|
unit=${i#cgfour}
|
|
rm -f cgfour$unit
|
|
mknod cgfour$unit c 39 $unit; chmod 666 cgfour$unit
|
|
;;
|
|
|
|
cgsix*)
|
|
unit=${i#cgsix}
|
|
rm -f cgsix$unit
|
|
mknod cgsix$unit c 67 $unit; chmod 666 cgsix$unit
|
|
;;
|
|
|
|
cgeight*)
|
|
unit=${i#cgeight}
|
|
rm -f cgeight$unit
|
|
mknod cgeight$unit c 64 $unit; chmod 666 cgeight$unit
|
|
;;
|
|
|
|
tcx*)
|
|
unit=${i#tcx}
|
|
rm -f tcx$unit
|
|
mknod tcx$unit c 109 $unit; chmod 666 tcx$unit
|
|
;;
|
|
|
|
audio)
|
|
unit=${i#audio}
|
|
audio=audio$unit
|
|
sound=sound$unit
|
|
mixer=mixer$unit
|
|
major=69
|
|
audioctl=audioctl$unit
|
|
if [ "$unit" = "" ]; then unit=0; fi
|
|
rm -f $audio $sound $mixer $audioctl
|
|
mknod $sound c $major $(($unit + 0))
|
|
mknod $audio c $major $(($unit + 128))
|
|
mknod $mixer c $major $(($unit + 16))
|
|
mknod $audioctl c $major $(($unit + 192))
|
|
chown root.wheel $audio $sound $mixer $audioctl
|
|
chmod 666 $audio $sound $mixer $audioctl
|
|
;;
|
|
|
|
bpf*)
|
|
unit=${i#bpf}
|
|
rm -f bpf$unit
|
|
mknod bpf$unit c 105 $unit
|
|
chmod 600 bpf$unit
|
|
chown root.wheel bpf$unit
|
|
;;
|
|
|
|
tun*)
|
|
unit=${i#tun}
|
|
rm -f tun$unit
|
|
mknod tun$unit c 111 $unit
|
|
chmod 600 tun$unit
|
|
chown root.wheel tun$unit
|
|
;;
|
|
|
|
md*)
|
|
case $i in
|
|
md*) name=md; unit=${i#md}; blk=5; chr=61;;
|
|
esac
|
|
unit=${i#md}
|
|
rm -f $name$unit $name$unit[abc] r$name$unit r$name$unit[abc]
|
|
mknod ${name}${unit} b $blk $(($unit * 8 + 0))
|
|
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 r${name}${unit} c $chr $(($unit * 8 + 0))
|
|
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))
|
|
chown root.operator $name$unit $name$unit[abc] r$name$unit r$name$unit[abc]
|
|
chmod 640 md$unit rmd$unit $name$unit $name$unit[abc] r$name$unit r$name$unit[abc]
|
|
;;
|
|
|
|
ccd*|fd*|sd*|xd*|xy*|cd*|vnd*|raid*)
|
|
case $i in
|
|
ccd*) name=ccd; unit=${i#ccd}; blk=9; chr=23;;
|
|
fd*) name=fd; unit=${i#fd}; blk=16; chr=54;;
|
|
sd*) name=sd; unit=${i#sd}; blk=7; chr=17;;
|
|
xd*) name=xd; unit=${i#xd}; blk=10; chr=42;;
|
|
xy*) name=xy; unit=${i#xy}; blk=3; chr=9;;
|
|
cd*) name=cd; unit=${i#cd}; blk=18; chr=58;;
|
|
raid*) name=raid; unit=${i#raid}; blk=25; chr=121;;
|
|
vnd*) name=vnd; unit=${i#vnd}; blk=8; chr=110;;
|
|
esac
|
|
case $unit in
|
|
0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|\
|
|
17|18|19|20|21|22|23|24|25|26|27|28|29|30|31)
|
|
rm -f ${name}${unit}[a-h] r${name}${unit}[a-h]
|
|
mknod ${name}${unit}c b $blk $(($unit * 8 + 2))
|
|
mknod ${name}${unit}a b $blk $(($unit * 8 + 0))
|
|
mknod ${name}${unit}b b $blk $(($unit * 8 + 1))
|
|
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}[a-h] r${name}${unit}[a-h]
|
|
chmod 640 ${name}${unit}[a-h] r${name}${unit}[a-h]
|
|
;;
|
|
*)
|
|
echo bad unit for disk in: $i
|
|
;;
|
|
esac
|
|
;;
|
|
|
|
st*)
|
|
case $i in
|
|
st*) name=st; unit=${i#st}; blk=11; chr=18;;
|
|
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 660 ${name}${unit} n${name}${unit} \
|
|
e$name$unit en$name$unit \
|
|
r${name}${unit} nr${name}${unit} \
|
|
er${name}${unit} enr${name}${unit}
|
|
;;
|
|
|
|
ss*)
|
|
case $i in
|
|
ss*) name=ss; unit=${i#ss}; chr=59;;
|
|
esac
|
|
rm -f $name$unit n$name$unit en$name$unit
|
|
mknod $name$unit c $chr $(($unit * 16 + 0))
|
|
mknod n$name$unit c $chr $(($unit * 16 + 1))
|
|
mknod en$name$unit c $chr $(($unit * 16 + 3))
|
|
chgrp operator $name$unit n$name$unit en$name$unit
|
|
chmod 640 $name$unit n$name$unit en$name$unit
|
|
;;
|
|
|
|
ch*|uk*)
|
|
case $i in
|
|
ch*) name=ch; unit=${i#ch}; chr=19;;
|
|
uk*) name=uk; unit=${i#uk}; chr=60;;
|
|
esac
|
|
rm -f $name$unit
|
|
mknod ${name}${unit} c $chr $(($unit + 0))
|
|
chgrp operator ${name}${unit}
|
|
chmod 640 ${name}${unit}
|
|
;;
|
|
|
|
lkm)
|
|
rm -f lkm
|
|
mknod lkm c 112 0
|
|
chown root.kmem lkm
|
|
chmod 640 lkm
|
|
;;
|
|
|
|
ipl)
|
|
rm -f ipl ipnat ipstate ipauth
|
|
mknod ipl c 25 0
|
|
mknod ipnat c 25 1
|
|
mknod ipstate c 25 2
|
|
mknod ipauth c 25 3
|
|
chown root.wheel ipl ipnat ipstate ipauth
|
|
chmod 600 ipl ipnat ipstate ipauth
|
|
;;
|
|
|
|
pty*)
|
|
class=${i#pty}
|
|
case $class in
|
|
0) name=p;;
|
|
1) name=q;;
|
|
2) name=r;;
|
|
3) name=s;;
|
|
4) name=t;;
|
|
5) name=u;;
|
|
6) name=v;;
|
|
7) name=w;;
|
|
8) name=x;;
|
|
9) name=y;;
|
|
10) name=z;;
|
|
11) name=P;;
|
|
12) name=Q;;
|
|
13) name=R;;
|
|
14) name=S;;
|
|
15) name=T;;
|
|
*) echo "$0: $i: pty unit must be between 0 and 15"
|
|
continue ;;
|
|
esac
|
|
rm -f tty$name[0-9a-f] pty$name[0-9a-f]
|
|
for j in 0 1 2 3 4 5 6 7 8 9 a b c d e f
|
|
do
|
|
case $j in
|
|
[0-9]) jn=$j ;;
|
|
a) jn=10 ;;
|
|
b) jn=11 ;;
|
|
c) jn=12 ;;
|
|
d) jn=13 ;;
|
|
e) jn=14 ;;
|
|
f) jn=15 ;;
|
|
esac
|
|
unit=$(($class * 16 + $jn))
|
|
mknod tty$name$j c 20 $unit
|
|
mknod pty$name$j c 21 $unit
|
|
done
|
|
chgrp wheel tty$name? pty$name?
|
|
chmod 666 tty$name? pty$name?
|
|
;;
|
|
|
|
random)
|
|
rm -f random urandom
|
|
mknod random c 119 0
|
|
mknod urandom c 119 1
|
|
chown root.wheel random urandom
|
|
chmod 444 random
|
|
chmod 644 urandom
|
|
;;
|
|
|
|
magma*)
|
|
unit=${i#magma}
|
|
if [ 0$unit -gt 3 ]
|
|
then
|
|
echo "bad unit for $i: $unit"
|
|
break
|
|
fi
|
|
|
|
rm -f tty$unit[0-9a-f] bpp$unit[01]
|
|
for j in 0 1 2 3 4 5 6 7 8 9 a b c d e f
|
|
do
|
|
case $j in
|
|
[0-9]) jn=$j ;;
|
|
a) jn=10 ;;
|
|
b) jn=11 ;;
|
|
c) jn=12 ;;
|
|
d) jn=13 ;;
|
|
e) jn=14 ;;
|
|
f) jn=15 ;;
|
|
esac
|
|
mknod tty$unit$j c 100 $(($unit * 64 + $jn))
|
|
done
|
|
|
|
mknod bpp${unit}0 c 101 $(($unit * 64 + 0))
|
|
mknod bpp${unit}1 c 101 $(($unit * 64 + 1))
|
|
;;
|
|
|
|
scsibus*)
|
|
unit=${i#scsibus};
|
|
rm -f scsibus$unit
|
|
mknod scsibus$unit c 120 $unit
|
|
chown root:wheel scsibus$unit
|
|
chmod 644 scsibus$unit
|
|
;;
|
|
|
|
local)
|
|
umask 0
|
|
sh $0.local all
|
|
umask 77
|
|
;;
|
|
|
|
*)
|
|
echo $i: unknown device
|
|
;;
|
|
esac
|
|
done
|