Source code pulled from OpenBSD for OpenNTPD. The place to contribute to this code is via the OpenBSD CVS tree.
 
 
 
 
 
 

419 lines
7.6 KiB

#!/bin/sh -
#
# THIS FILE AUTOMATICALLY GENERATED. DO NOT EDIT.
# generated from:
#
# OpenBSD: etc.mvme88k/MAKEDEV.md,v 1.26 2010/06/26 23:49:50 jsing Exp
# OpenBSD: MAKEDEV.common,v 1.47 2010/06/09 16:10:24 todd Exp
# OpenBSD: MAKEDEV.mi,v 1.78 2008/06/14 23:09:05 todd Exp
# OpenBSD: MAKEDEV.sub,v 1.13 2005/01/28 18:51:38 danh Exp
#
#
# Copyright (c) 2001-2004 Todd T. Fries <todd@OpenBSD.org>
#
# 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.
# ramdisk Ramdisk kernel devices
# std Standard devices
# local Configuration specific devices
# Disks:
# ccd* Concatenated disk devices
# cd* ATAPI and SCSI CD-ROM drives
# rd* "rd" pseudo-disks
# sd* SCSI disks, including flopticals
# vnd* "file" pseudo-disk devices
# Tapes:
# ch* SCSI media changers
# st* SCSI tape drives
# Terminal ports:
# tty0* MVME1x7 CL-CD2400 serial ports
# ttya-b MVME188 serial ports
# ttyv* MVME332XT serial ports
# Pseudo terminals:
# ptm pty master device
# pty* Set of 62 master pseudo terminals
# tty* Set of 62 slave pseudo terminals
# Special purpose devices:
# bio ioctl tunnel pseudo-device
# bpf* Berkeley Packet Filter
# fd fd/* nodes
# lkm Loadable kernel modules interface
# nvram0 On-board non-volatile memory
# pf* Packet Filter
# *random In-kernel random data source
# sram0 On-board static memory
# ss* SCSI scanners
# systrace* System call tracing device
# tun* Network tunnel driver
# vmel0 VMEbus D32 space
# vmes0 VMEbus D16 space
# uk* Unknown SCSI devices
# nnpfs* NNPFS filesystem node
# vscsi* Virtual SCSI controller
# diskmap Disk mapper
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
[ 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 operator
M r$1$2$d c $4 $(($n+$count)) 640 operator
let count=count+1
done
}
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[0]="rm -f"
mkl() {
mklist[${#mklist[*]}]=";mknod -m $1 $2 $3 $4 $5"
}
M() {
RMlist[${#RMlist[*]}]=$1
mkl ${5-666} $1 $2 $3 $4
G=${6:-wheel}
[ "$7" ] && {
MKlist[${#MKlist[*]}]=";chown $7:$G $1"
} || {
case $G in
wheel)
[ ${#whlist[*]} = 0 ] && whlist[0]=";chgrp wheel"
whlist[${#whlist[*]}]="$1"
;;
operator)
[ ${#oplist[*]} = 0 ] && oplist[0]=";chgrp operator"
oplist[${#oplist[*]}]="$1"
;;
*)
MKlist[${#MKlist[*]}]=";chgrp $G $1";
esac
}
return 0
}
R() {
[ "$DEBUG" ] && set -x
for i in "$@"
do
U=`unt $i`
[ "$U" ] || U=0
case $i in
std)
M console c 0 0 600
M tty c 1 0
M mem c 2 0 640 kmem
M kmem c 2 1 640 kmem
M null c 2 2
M zero c 2 12
M stdin c 21 0
M stdout c 21 1
M stderr c 21 2
M ksyms c 43 0 640 kmem
M klog c 6 0 600
;;
diskmap)
M diskmap c 54 0 640 operator
;;
vscsi*)
M vscsi$U c 53 $U 600
;;
nnpfs*)
M nnpfs$U c 51 $U 600
;;
uk*)
M uk$U c 41 $U 640 operator
;;
vmes0)
M vmes0 c 32 0 640 kmem
;;
vmel0)
M vmel0 c 31 0 640 kmem
;;
tun*)
M tun$U c 23 $U 600
;;
systrace)
M systrace c 50 0 644
;;
ss*)
M ss$U c 42 $(($U*16)) 640 operator
M nss$U c 42 $(($(($U*16))+1)) 640 operator
M enss$U c 42 $(($(($U*16))+3)) 640 operator
RMlist[${#RMlist[*]}]="scan$U"
MKlist[${#MKlist[*]}]=";umask 77;ln -s ss$U scan$U"
;;
sram0)
M sram0 c 7 0 640 kmem
;;
*random)
n=0
for pre in " " s u a
do
M ${pre}random c 40 $n 644
n=$(($n+1))
done
;;
pf*)
M pf c 39 0 600
;;
nvram0)
M nvram0 c 10 0 640 kmem
;;
lkm)
M lkm c 24 0 640 _lkm
;;
fd)
RMlist[${#RMlist[*]}]=";mkdir -p fd;rm -f" n=0
while [ $n -lt 64 ];do M fd/$n c 21 $n;n=$(($n+1));done
MKlist[${#MKlist[*]}]=";chmod 555 fd"
;;
bpf*)
M bpf$U c 22 $U 600
;;
bio)
M bio c 49 0 600
;;
pty*)
if [ $U -gt 15 ]; then
echo bad unit for pty in: $i
continue
fi
set -A letters p q r s t u v w x y z P Q R S T
set -A suffixes 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 w x y z A B C D E F G H I J K L M N O P Q R S T U V W X \
Y Z
name=${letters[$U]}
n=0
while [ $n -lt 62 ]
do
nam=$name${suffixes[$n]}
off=$(($U*62))
M tty$nam c 4 $(($off+$n))
M pty$nam c 5 $(($off+$n))
n=$(($n+1))
done
;;
ptm)
M ptm c 52 0 666
;;
ttyv*)
u=${i#ttyv*}
case $u in
0|1|2|3|4|5|6|7)
M ttyv$u c 15 $u 660 dialer uucp
M cuav$u c 15 $(($u+128)) 660 dialer uucp
;;
*) echo unknown tty device $i ;;
esac
;;
tty[a-z])
u=${i#tty*}
case $u in
a) n=0 ;;
b) n=1 ;;
*) echo unknown tty device $i ;;
esac
case $u in
a|b|c|d)
M tty$u c 12 $n 660 dialer uucp
M cua$u c 12 $(($n+128)) 660 dialer uucp
;;
esac
;;
tty0*)
u=${i#tty0*}
case $u in
0|1|2|3|4|5|6|7)
M tty0$u c 13 $u 660 dialer uucp
M cua0$u c 13 $(($u+128)) 660 dialer uucp
;;
*) echo unknown tty device $i ;;
esac
;;
st*)
n=$(($U*16))
for pre in " " n e en
do
M ${pre}st$U b 5 $n 660 operator
M ${pre}rst$U c 20 $n 660 operator
n=$(($n+1))
done
;;
ch*)
M ch$U c 44 $U 660 operator
;;
vnd*)
dodisk vnd $U 8 19 $U 0
dodisk svnd $U 8 19 $U 2048
;;
rd*)
dodisk2 rd $U 7 18 $U 0
;;
cd*)
dodisk2 cd $U 6 9 $U 0
;;
local)
test -s $T.local && sh $T.local
;;
ramdisk)
R diskmap bio pty0 tty00 ttya rd0 cd0 cd1 st0 st1 sd0 sd1 sd2
R sd3 sd4 bpf0 std
;;
all)
R ttyv0 ttyv1 ttyv2 ttyv3 ttyv4 ttyv5 ttyv6 ttyv7 tty00 tty01
R tty02 tty03 tty04 tty05 tty06 tty07 ttya ttyb ccd0 ccd1 ccd2
R ccd3 vnd0 vnd1 vnd2 vnd3 sd0 sd1 sd2 sd3 sd4 cd0 cd1 rd0
R tun0 tun1 tun2 tun3 bio bpf0 bpf1 bpf2 bpf3 bpf4 bpf5 bpf6
R bpf7 bpf8 bpf9 pty0 diskmap vscsi0 nnpfs0 ss0 ch0 vmel0
R vmes0 nvram0 sram0 ptm local uk0 random lkm pf systrace std
R st0 st1 fd
;;
sd*|ccd*)
case $i in
sd*) dodisk sd $U 4 8 $U 0;;
ccd*) dodisk ccd $U 9 17 $U 0;;
esac
;;
*)
echo $i: unknown device
;;
esac
done
}
R "$@"
{
echo -n ${RMlist[*]}
echo -n ${mklist[*]}
echo -n ${MKlist[*]}
echo -n ${whlist[*]}
echo ${oplist[*]}
} | if [ "$eo" = "echo" ]; then
cat
else
sh
fi