freebsd-skq/etc/MAKEDEV
Kenneth D. Merry 98cb733c67 At long last, commit the zero copy sockets code.
MAKEDEV:	Add MAKEDEV glue for the ti(4) device nodes.

ti.4:		Update the ti(4) man page to include information on the
		TI_JUMBO_HDRSPLIT and TI_PRIVATE_JUMBOS kernel options,
		and also include information about the new character
		device interface and the associated ioctls.

man9/Makefile:	Add jumbo.9 and zero_copy.9 man pages and associated
		links.

jumbo.9:	New man page describing the jumbo buffer allocator
		interface and operation.

zero_copy.9:	New man page describing the general characteristics of
		the zero copy send and receive code, and what an
		application author should do to take advantage of the
		zero copy functionality.

NOTES:		Add entries for ZERO_COPY_SOCKETS, TI_PRIVATE_JUMBOS,
		TI_JUMBO_HDRSPLIT, MSIZE, and MCLSHIFT.

conf/files:	Add uipc_jumbo.c and uipc_cow.c.

conf/options:	Add the 5 options mentioned above.

kern_subr.c:	Receive side zero copy implementation.  This takes
		"disposable" pages attached to an mbuf, gives them to
		a user process, and then recycles the user's page.
		This is only active when ZERO_COPY_SOCKETS is turned on
		and the kern.ipc.zero_copy.receive sysctl variable is
		set to 1.

uipc_cow.c:	Send side zero copy functions.  Takes a page written
		by the user and maps it copy on write and assigns it
		kernel virtual address space.  Removes copy on write
		mapping once the buffer has been freed by the network
		stack.

uipc_jumbo.c:	Jumbo disposable page allocator code.  This allocates
		(optionally) disposable pages for network drivers that
		want to give the user the option of doing zero copy
		receive.

uipc_socket.c:	Add kern.ipc.zero_copy.{send,receive} sysctls that are
		enabled if ZERO_COPY_SOCKETS is turned on.

		Add zero copy send support to sosend() -- pages get
		mapped into the kernel instead of getting copied if
		they meet size and alignment restrictions.

uipc_syscalls.c:Un-staticize some of the sf* functions so that they
		can be used elsewhere.  (uipc_cow.c)

if_media.c:	In the SIOCGIFMEDIA ioctl in ifmedia_ioctl(), avoid
		calling malloc() with M_WAITOK.  Return an error if
		the M_NOWAIT malloc fails.

		The ti(4) driver and the wi(4) driver, at least, call
		this with a mutex held.  This causes witness warnings
		for 'ifconfig -a' with a wi(4) or ti(4) board in the
		system.  (I've only verified for ti(4)).

ip_output.c:	Fragment large datagrams so that each segment contains
		a multiple of PAGE_SIZE amount of data plus headers.
		This allows the receiver to potentially do page
		flipping on receives.

if_ti.c:	Add zero copy receive support to the ti(4) driver.  If
		TI_PRIVATE_JUMBOS is not defined, it now uses the
		jumbo(9) buffer allocator for jumbo receive buffers.

		Add a new character device interface for the ti(4)
		driver for the new debugging interface.  This allows
		(a patched version of) gdb to talk to the Tigon board
		and debug the firmware.  There are also a few additional
		debugging ioctls available through this interface.

		Add header splitting support to the ti(4) driver.

		Tweak some of the default interrupt coalescing
		parameters to more useful defaults.

		Add hooks for supporting transmit flow control, but
		leave it turned off with a comment describing why it
		is turned off.

if_tireg.h:	Change the firmware rev to 12.4.11, since we're really
		at 12.4.11 plus fixes from 12.4.13.

		Add defines needed for debugging.

		Remove the ti_stats structure, it is now defined in
		sys/tiio.h.

ti_fw.h:	12.4.11 firmware.

ti_fw2.h:	12.4.11 firmware, plus selected fixes from 12.4.13,
		and my header splitting patches.  Revision 12.4.13
		doesn't handle 10/100 negotiation properly.  (This
		firmware is the same as what was in the tree previously,
		with the addition of header splitting support.)

sys/jumbo.h:	Jumbo buffer allocator interface.

sys/mbuf.h:	Add a new external mbuf type, EXT_DISPOSABLE, to
		indicate that the payload buffer can be thrown away /
		flipped to a userland process.

socketvar.h:	Add prototype for socow_setup.

tiio.h:		ioctl interface to the character portion of the ti(4)
		driver, plus associated structure/type definitions.

uio.h:		Change prototype for uiomoveco() so that we'll know
		whether the source page is disposable.

ufs_readwrite.c:Update for new prototype of uiomoveco().

vm_fault.c:	In vm_fault(), check to see whether we need to do a page
		based copy on write fault.

vm_object.c:	Add a new function, vm_object_allocate_wait().  This
		does the same thing that vm_object allocate does, except
		that it gives the caller the opportunity to specify whether
		it should wait on the uma_zalloc() of the object structre.

		This allows vm objects to be allocated while holding a
		mutex.  (Without generating WITNESS warnings.)

		vm_object_allocate() is implemented as a call to
		vm_object_allocate_wait() with the malloc flag set to
		M_WAITOK.

vm_object.h:	Add prototype for vm_object_allocate_wait().

vm_page.c:	Add page-based copy on write setup, clear and fault
		routines.

vm_page.h:	Add page based COW function prototypes and variable in
		the vm_page structure.

Many thanks to Drew Gallatin, who wrote the zero copy send and receive
code, and to all the other folks who have tested and reviewed this code
over the years.
2002-06-26 03:37:47 +00:00

1779 lines
38 KiB
Bash

#!/bin/sh -
#
# 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
# $FreeBSD$
#
# Device "make" file. Valid arguments:
# all makes all known devices, standard number of units (or close)
# std standard devices
# jail suitable for a jail(8)
# local configuration specific devices
# mach-4 mach4&lites+devices for Mach's XFree86 distribution
# (see http://www.cs.hut.fi/lites.html for more info on LITES)
#
# Tapes:
# wt* QIC-interfaced (e.g. not SCSI) 3M cartridge tape
# sa* SCSI Sequential Access Devices
#
# Disks:
# aac* Adaptec FSA RAID controllers
# aacd* Adaptec FSA RAID
# acd* ATAPI CD-ROM disks
# amrd* AMI MegaRAID
# cd* SCSI CD-ROM disks
# da* SCSI Direct Access Devices
# fd* floppy disk drives (3 1/2", 5 1/4")
# fla* M-Systems DiskOnChip
# idad* Compaq Smart-2 RAID arrays
# matcd* Matsushita (Panasonic) CD-ROM disks
# mcd* Mitsumi CD-ROM disks
# md* Memory (or malloc) disk
# mlx* Mylex DAC960 RAID controllers
# mlxd* Mylex DAC960 RAID disk volumes
# mly* Mylex RAID controllers (newer models)
# scd* Sony CD-ROM disks
# wd* "Winchester" disk drives (ST506,IDE,ESDI,RLL,...)
# wfd* IDE floppy disk drives (LS-120)
#
# Console ports:
# vty* virtual console devices for syscons/pcvt/codrv
#
# Pointing devices:
# mse* Logitech and ATI Inport bus mouse
# psm* PS/2 mouse
# jogdial Sony VAIO jog dial
# sysmouse Mousesystems mouse emulator for syscons
#
# Time devices:
# refclock-* serial ports used by xntpd parse refclocks
#
# Terminal ports:
# tty* general purpose serial ports
# cua* dialout serial ports
# ttyA* Specialix SI/XIO dialin ports ('*' = number of devices)
# cuaA* Specialix SI/XIO dialout ports
# ttyDXX Digiboard Xi - 16 dialin ports (dgb)
# cuaDXX Digiboard Xi - 16 dialout ports (dgb)
# ttyDX.X Digiboards (work in progress) - 16 dialin ports (digi)
# cuaDX.X Digiboards (work in progress) - 16 dialout ports (digi)
# ttyM* Digiboard Xem - 16 dialin ports (dgm)
# cuaM* Digiboard Xem - 16 dialout ports (dgm)
# ttyR* Rocketport dialin ports
# cuaR* Rocketport dialout ports
#
# Pseudo terminals:
# pty* set of 32 master and slave pseudo terminals
# vty* virtual terminals using syscons/pcvt/codrv console
#
# Parallel port:
# lpt* Printer
# ppi* Parallel port i/o
# pps* Pulse per second timing interface
# pcfclock* Parallel time sync interface
#
# I2C and SMBus:
# iic* I2C devices
# smb* SMBUS devices
#
# USB devices:
# usb* USB bus control device
# ugen* generic USB device
# uhid* Human Interface Device (HID)
# ulpt* printer
# umodem* modems
# ums* mouse
# urio* Diamond Rio 500
# uscanner* USB scanners
# usio* USB serial devices
#
# SCSI devices (other than CD-ROM, tape and disk):
# ch* SCSI Media-Changer (juke box) driver
# pt* Processor Type (HP scanner, as one example)
# pass* CAM Passthrough device
# ses* SES (SCSI Environmental Services) and
# SAF-TE (Scsi Accessable Fault-Tolerant Enclosures) device
#
# PC-CARD (previously called PCMCIA) support
# card* PC-CARD slots
#
# ISDN devices:
# i4b isdnd call control device
# i4bctl debugging control device
# i4btrc* trace data interface(s), one per passive card
# i4btel* telephony interface(s)
# i4bteld* telephony dialout interface(s)
# i4brbch* raw b channel access device(s)
#
# Special purpose devices:
# acpi Advanced Configuration and Power Interface
# apm Advanced Power Management BIOS
# apmctl APM BIOS control device
# bpf* packet filter
# speaker pc speaker
# tw* xten power controller
# snd* various sound cards
# pcaudio PCM audio driver
# socksys iBCS2 socket system driver
# vat VAT compatibility audio driver (requires snd*)
# gsc Genius GS-4500 hand scanner
# joy pc joystick
# tun* Tunneling IP device
# tap* Ethernet Tunneling device
# snp* tty snoop devices
# spigot Video Spigot video acquisition card
# ctx* Cortex-I video acquisition card
# meteor* Matrox Meteor video acquisition card (pci)
# bktr* Bt848 based video acquisition card (pci)
# labpc* National Instrument's Lab-PC and LAB-PC+
# perfmon CPU performance-monitoring counters
# pci PCI configuration-space access from user mode
# ipl ipfilter control devices (ipl, ipnat, ipstate, ipauth)
# kbd keyboard devices
# 3dfx* 3dfx voodoo device for glide (tdfx) (/dev/3dfx,3dfxN,voodoo)
# agpgart AGP interface
# cfs* Coda Distributed Filesystem
# nsmb* SMB/CIFS protocol interface
#
if [ -n "$MAKEDEVPATH" ]; then
PATH="$MAKEDEVPATH"
else
PATH=/sbin:/bin
fi
umask 77
# Usage: die exitcode msg
die() {
echo $2
exit $1
}
# Convert integer to partition name
dkitop() {
local p
case $1 in
0) p=a;; 1) p=b;; 2) p=c;; 3) p=d;; 4) p=e;; 5) p=f;; 6) p=g;; 7) p=h;;
*) p="?";;
esac
echo $p
}
# Convert integer to slice name
dkitos() {
local s
case $1 in
0) s="";;
1) s="";;
*) s=s$(($1-1));;
esac
echo $s
}
# Convert disk (type, unit, slice, partition) to minor number
dkminor()
{
echo $(($1 << 25 | ($2 / 32) << 21 | ($2 % 32) << 3 | $3 << 16 | $4))
}
# Print the hexadecimal representation of a decimal value from 0 to 15.
hexdigit() {
local d
if [ $1 -lt 10 ]; then
d=$1
else
case $1 in
10) d=a;; 11) d=b;; 12) d=c;; 13) d=d;; 14) d=e;; 15) d=f;;
*) d="?";;
esac
fi
echo $d
}
# Print the hexadecimal representation of an arbitrary decimal value.
hexprint() {
local dig
local str
local val
val=$1
str=''
dig=`hexdigit $(($val & 15))`
str=$dig$str
val=$(($val >> 4))
while [ $val -gt 0 ]; do
dig=`hexdigit $(($val & 15))`
str=$dig$str
val=$(($val >> 4))
done
echo $str
}
# Override mknod(2) to add extra handling to it.
mknod=/sbin/mknod
for i in `IFS=':'; echo $PATH`; do
if [ -x "${i}/mknod" ]; then
mknod="${i}/mknod"
break
fi
done
mknod() {
rm -f "$1" || exit 1
case $# in
4) "$mknod" "$@" root:wheel || die 2 "$mknod $@ failed";;
5) "$mknod" "$@" || die 2 "$mknod $@ failed";;
*) die 2 "bad node: mknod $@";;
esac
}
# Convert tape (ctrl, unit, mode, access) to minor number
saminor()
{
echo $(($1 << 29 | ($2 / 16) << 16 | ($2 % 16) << 4 | $3 << 2 | $4))
}
# Convert the last character of a tty name to a minor number.
ttyminor()
{
case $1 in
[0-9]) m=$1;;
a) m=10;; b) m=11;; c) m=12;; d) m=13;; e) m=14;; f) m=15;; g) m=16;;
h) m=17;; i) m=18;; j) m=19;; k) m=20;; l) m=21;; m) m=22;; n) m=23;;
o) m=24;; p) m=25;; q) m=26;; r) m=27;; s) m=28;; t) m=29;; u) m=30;;
v) m=31;;
*) m="?";;
esac
echo $m
}
# Convert a unit number to a minor number.
unit2minor()
{
echo $(((($1 >> 8) << 16) | ($1 % 256)))
}
# Zero-pad a value to the appropriate minimum length.
zeropad() {
local min
local val
min=$1
val=$2
while [ ${#val} -lt $min ]; do
val=0$val
done
echo $val
}
# Raw partition for disks
dkrawpart=2
# Compatibility slice for disks
dkcompatslice=0
# Raw slice for disks
dkrawslice=1
# Standard umasks
disk_umask=037 # allow group operator to read disks
tape_umask=017 # allow group operator to read/write tapes
for i in $*; do
case $i in
all)
sh $0 std # standard
sh $0 fd0 fd1 # floppy disk
sh $0 da0 da1 da2 da3 # SCSI disk
sh $0 ata # ATA control
sh $0 ad0 ad1 ad2 ad3 # ATA disk
sh $0 ar0 ar1 # ATA RAID disk
sh $0 acd0 acd0t0 afd0 ast0 # ATAPI devices
sh $0 wd0 wd1 wd2 wd3 # OLD disk
sh $0 wcd0 wfd0 wst0 # OLD ATAPI devs
sh $0 cd0 matcd0 mcd0 scd0 # cdrom
sh $0 sa0 wt0 # tape
sh $0 vty12 # virtual tty
sh $0 cuaa0 cuaa1 cuaa2 cuaa3 # serial tty
sh $0 pty0 # pseudo tty
sh $0 ttyd0 ttyd1 ttyd2 ttyd3 # serial tty
sh $0 kbd0 kbd1 # keyboard
sh $0 mse0 psm0 jogdial sysmouse # mouse
sh $0 pcaudio speaker # noise
sh $0 lpt0 lpt1 lpt2 # printer
sh $0 ppi0 ppi1 ppi2 # parallel port
sh $0 iic0 iic1 # I2C device
sh $0 smb0 smb1 # SMBus device
sh $0 usb usb0 uhid0 ums0 ulpt0 ugen0 # USB devices
sh $0 urio0 uscanner0 umodem0 # USB devices too
sh $0 bpf0 bpf1 bpf2 bpf3 # network
sh $0 ipl tun0 tun1 tun2 tun3 # network
sh $0 tap0 tap1 tap2 tap3 # network
sh $0 ch0 perfmon tw0 # miscellaneous
sh $0 acpi # ACPI
sh $0 apm apmctl card0 card1 card2 card3 # laptop
sh $0 pass4 xpt2 # CAM
sh $0 i4b i4bctl i4btrc0 i4btrc1 # ISDN
sh $0 i4btel0 i4btel1 i4bteld0 i4bteld1 # ISDN
sh $0 i4brbch0 i4brbch1 # ISDN
sh $0 agpgart # AGP
sh $0 nsmb0 # SMB/CIFS
sh $0 ti0 ti1 # ti(4)
;;
# a much restricted set of the above, to save precious i-nodes on the
# fixit floppy
fixit)
sh $0 std # standard
sh $0 fd0 # floppy disk
sh $0 da0 # SCSI disk
sh $0 ad0 # ATA disk
sh $0 acd0 afd0 ast0 # ATAPI devices
sh $0 wd0 # OLD disk
sh $0 wcd0 wfd0 wst0 # OLD ATAPI devs
sh $0 cd0 # cdrom
sh $0 sa0 # tape
sh $0 vty2 # virtual tty
sh $0 cuaa0 # serial tty
sh $0 pty0 # pseudo tty
sh $0 ttyd0 # serial tty
sh $0 kbd0 # keyboard
sh $0 mse0 psm0 jogdial sysmouse # mouse
sh $0 lpt0 # printer
sh $0 ppi0 # parallel port
sh $0 iic0 # I2C device
sh $0 smb0 # SMBus device
sh $0 ums0 # USB devices
sh $0 tun0 # network
sh $0 tap0 # network
sh $0 ch0 # miscellaneous
sh $0 acpi # ACPI
sh $0 apm apmctl card0 # laptop
sh $0 pass1 xpt1 # CAM
sh $0 i4b i4bctl i4btrc0 i4btrc1 # ISDN
sh $0 i4btel0 i4bteld0 # ISDN
sh $0 i4brbch0 # ISDN
rm -f fd/[1-9]?
;;
std)
mknod console c 0 0; chmod 600 console
mknod kmem c 2 1 root:kmem; chmod 640 kmem
mknod mem c 2 0 root:kmem; chmod 640 mem
mknod null c 2 2; chmod 666 null
mknod random c 2 3; chmod 666 random
ln -f random urandom
mknod zero c 2 12; chmod 666 zero
mknod io c 2 14; chmod 600 io
mknod tty c 1 0; chmod 666 tty
mknod klog c 7 0; chmod 600 klog
mknod pci c 78 0; chmod 644 pci
mknod mdctl c 95 0xffff00ff; chmod 600 mdctl
mkdir -p fd
(cd fd && i=0 &&
while [ $i -lt 64 ]; do
mknod $i c 22 $i
i=$(($i + 1))
done
)
chmod 555 fd
chmod 666 fd/*
ln -sf fd/0 stdin
ln -sf fd/1 stdout
ln -sf fd/2 stderr
;;
jail)
sh $0 std pty0
rm mem kmem pci io klog console # for security
ln -sf null mem # for libkvm (ab)users
ln -sf null kmem # --//--
ln -sf null console
;;
mach-4)
mknod iopl c 22 0
mknod kbd c 23 0
mknod mouse c 24 0
mknod time c 25 0
mknod timezone c 26 0
;;
# Create device files for new Archive/Wangtek QIC-02 tape driver (vak)
wt*)
umask $tape_umask
u=`expr $i : '..\(.*\)'`
if [ -z "${u}" ]; then u=0; fi
# default density, 512b blocks
mknod rwt${u} c 10 $(( 0 + $u)) root:operator
mknod nrwt${u} c 10 $(( 4 + $u)) root:operator
# default density, 1024b blocks
# mknod rWt${u} c 10 $((64 + $u)) root:operator
# mknod nrWt${u} c 10 $((68 + $u)) root:operator
mknod rwt${u}b c 10 $((16 + $u)) root:operator # 60 megabytes
mknod nrwt${u}b c 10 $((20 + $u)) root:operator
mknod rwt${u}c c 10 $((24 + $u)) root:operator # 120 megabytes
mknod nrwt${u}c c 10 $((28 + $u)) root:operator
mknod rwt${u}d c 10 $((32 + $u)) root:operator # 150 megabytes
mknod nrwt${u}d c 10 $((36 + $u)) root:operator
# mknod rwt${u}e c 10 $((40 + $u)) root:operator # 300 megabytes?
# mknod nrwt${u}e c 10 $((44 + $u)) root:operator
# mknod rwt${u}f c 10 $((48 + $u)) root:operator # 600 megabytes?
# mknod nrwt${u}f c 10 $((52 + $u)) root:operator
umask 77
;;
# Individual slices.
aacd*s*|ad*s*|ar*s*|afd*s*|amrd*s*|da*s*|fla*s*|idad*s*|md*s*|mlxd*s*|twed*s*|wd*s*|wfd*s*)
umask $disk_umask
case $i in
aacd*s*) name=aacd; chr=151;;
ad*s*) name=ad; chr=116;;
ar*s*) name=ar; chr=157;;
afd*s*) name=afd; chr=118;;
amrd*s*) name=amrd; chr=133;;
da*s*) name=da; chr=13;;
fla*s*) name=fla; chr=102;;
idad*s*) name=idad; chr=109;;
md*s*) name=md; chr=95;;
mlxd*s*) name=mlxd; chr=131;;
twed*s*) name=twed; chr=147;;
wd*s*) name=wd; chr=3;;
wfd*s*) name=wfd; chr=87;;
esac
case $i in
aacd*s*|amrd*s*|idad*s*|mlxd*s*|twed*s*)
unit=`expr $i : '....\([0-9]*\)s'`
slice=`expr $i : '....[0-9]*s\([0-9]*\)'`
part=`expr $i : '....[0-9]*s[0-9]*\(.*\)'`
;;
afd*s*|fla*s*|wfd*s*)
unit=`expr $i : '...\([0-9]*\)s'`
slice=`expr $i : '...[0-9]*s\([0-9]*\)'`
part=`expr $i : '...[0-9]*s[0-9]*\(.*\)'`
;;
*)
unit=`expr $i : '..\([0-9]*\)s'`
slice=`expr $i : '..[0-9]*s\([0-9]*\)'`
part=`expr $i : '..[0-9]*s[0-9]*\(.*\)'`
;;
esac
case $unit in
[0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
case $slice in
[0-9]|[1-2][0-9]|30)
oldslice=$slice
slice=$(($slice+1))
slicename=`dkitos $slice`
minor=`dkminor 0 $unit $slice $dkrawpart`
mknod $name$unit$slicename c $chr $minor root:operator
ln -f $name$unit$slicename r$name$unit$slicename
case $part in
[a-h])
case $oldslice in
0) slice=$oldslice ;;
esac
for part in 0 1 2 3 4 5 6 7
do
minor=`dkminor 0 $unit $slice $part`
partname=`dkitop $part`
mknod $name$unit$slicename$partname \
c $chr $minor root:operator
ln -f $name$unit$slicename$partname \
r$name$unit$slicename$partname
done
;;
"")
;;
*)
echo bad partition for disk in: $i
;;
esac
;;
*)
echo bad slice for disk in: $i
;;
esac
;;
*)
echo bad unit for disk in: $i "(unit=$unit, slice=$slice, part=$part)"
;;
esac
umask 77
;;
fd*)
umask $disk_umask
unit=`expr $i : '..\(.*\)'`
name=fd; chr=9
case $unit in
0|1|2|3)
mknod ${name}${unit} c $chr $(($unit * 64)) root:operator
# Fake BSD partitions
for i in a b c d e f g h
do
ln -f ${name}${unit} ${name}${unit}$i
done
;;
*)
echo bad unit for disk in: $i
;;
esac
umask 77
;;
ata)
umask 177
mknod ata c 159 0 root:operator
umask 77
;;
aacd*|ad*|ar*|afd*|amrd*|da*|fla*|idad*|md*|mlxd*|twed*|wd*|wfd*)
umask $disk_umask
case $i in
aacd*) name=aacd; chr=151;;
ad*) name=ad; chr=116;;
ar*) name=ar; chr=157;;
afd*) name=afd; chr=118;;
amrd*) name=amrd; chr=133;;
da*) name=da; chr=13;;
fla*) name=fla; chr=102;;
idad*) name=idad; chr=109;;
md*) name=md; chr=95;;
mlxd*) name=mlxd; chr=131;;
twed*) name=twed; chr=147;;
wd*) name=wd; chr=3;;
wfd*) name=wfd; chr=87;;
esac
case $i in
aacd*|amrd*|idad*|mlxd*|twed*)
unit=`expr $i : '....\(.*\)'`
;;
afd*|fla*|wfd*)
unit=`expr $i : '...\(.*\)'`
;;
*)
unit=`expr $i : '..\(.*\)'`
;;
esac
case $unit in
[0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
for slicepartname in s0h s1h s2 s3 s4
do
sh $0 $name$unit$slicepartname
done
;;
*)
echo bad unit for disk in: $i
;;
esac
umask 77
;;
ccd*)
umask $disk_umask
name=ccd
chr=74
unit=`expr $i : '...\(.*\)'`
case $unit in
[0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
for part in 0 1 2 3 4 5 6 7
do
minor=`dkminor 0 $unit 0 $part`
partname=`dkitop $part`
mknod $name$unit$partname c $chr $minor root:operator
ln -f $name$unit$partname r$name$unit$partname
done
;;
*)
echo bad unit for disk in: $i
;;
esac
umask 77
;;
# SCSI processor type driver
pt[0-9]*)
chr=61
name=pt
unit=`expr $i : 'pt\([0-9][0-9]*\)'`
if [ -z "${unit}" ]; then
unit=0
fi
unit=$(($unit + 1 - 1))
mknod ${name}${unit} c $chr `unit2minor $unit`
;;
# SCSI SES/SAF-TE type driver
ses[0-9]*)
chr=110
name=ses
unit=`expr $i : 'ses\([0-9][0-9]*\)'`
if [ -z "${unit}" ]; then
unit=0
fi
unit=$(($unit + 1 - 1))
mknod ${name}${unit} c $chr `unit2minor $unit`
;;
# SCSI target mode sample driver
targ[0-9]*)
chr=65
name=targ
unit=`expr $i : 'targ\([0-9][0-9]*\)'`
if [ -z "${unit}" ]; then
unit=0
fi
unit=$(($unit + 1 - 1))
mknod ${name}${unit} c $chr `unit2minor $unit`
mknod ${name}.ctl c $chr 0xffff00ff
;;
# CAM transport layer device
xpt*)
# This major number is temporary
chr=104
name=xpt
units=`expr $i : 'xpt\(.*\)'`
if [ -z "${units}" ]; then
units=1
fi
i=0
while [ $i -lt $units ]; do
dname=$name$i
rm -rf $dname r$dname
mknod $dname c $chr `unit2minor $i` root:operator
i=$(($i + 1))
done
;;
# CAM passthrough device
pass*)
# This major number is temporary
chr=31
name=pass
units=`expr $i : 'pass\(.*\)'`
if [ -z "${units}" ]; then
units=1
fi
i=0
while [ $i -lt $units ]; do
dname=$name$i
rm -rf $dname r$dname
mknod $dname c $chr `unit2minor $i` root:operator
i=$(($i + 1))
done
;;
pty*)
class=`expr $i : 'pty\(.*\)'`
case $class in
0) offset=0 name=p;;
1) offset=32 name=q;;
2) offset=64 name=r;;
3) offset=96 name=s;;
# Note that xterm (at least) only look at p-s.
4) offset=128 name=P;;
5) offset=160 name=Q;;
6) offset=192 name=R;;
7) offset=224 name=S;;
# This still leaves [tuTU].
*) echo bad unit for pty in: $i;;
esac
umask 0
case $class in
0|1|2|3|4|5|6|7)
i=0
while [ $i -lt 32 ]; do
# This was an awk substr() before.
c=$(echo 0123456789abcdefghijklmnopqrstuv |
dd bs=1 skip=$i count=1 2>/dev/null)
mknod tty$name$c c 5 $(($offset + $i))
mknod pty$name$c c 6 $(($offset + $i))
i=$(($i + 1))
done
;;
esac
umask 77
;;
sa*)
umask $tape_umask
unit=`expr $i : '..\(.*\)'`
chr=14
case $unit in
[0-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9])
mknod sa${unit}.ctl c $chr `saminor 1 ${unit} 0 0`
ln -f sa${unit}.ctl rsa${unit}.ctl
for m in 0 1 2 3
do
mknod sa${unit}.${m} c $chr \
`saminor 0 ${unit} ${m} 0` root:operator
ln -f sa${unit}.${m} rsa${unit}.${m}
mknod nsa${unit}.${m} c $chr \
`saminor 0 ${unit} ${m} 1` root:operator
ln -f nsa${unit}.${m} nrsa${unit}.${m}
mknod esa${unit}.${m} c $chr \
`saminor 0 ${unit} ${m} 2` root:operator
ln -f esa${unit}.${m} ersa${unit}.${m}
done
ln -f sa${unit}.0 sa${unit}
ln -f sa${unit}.0 rsa${unit}.0
ln -f sa${unit}.0 rsa${unit}
ln -f nsa${unit}.0 nsa${unit}
ln -f nsa${unit}.0 nrsa${unit}.0
ln -f nsa${unit}.0 nrsa${unit}
ln -f esa${unit}.0 esa${unit}
ln -f esa${unit}.0 ersa${unit}.0
ln -f esa${unit}.0 ersa${unit}
;;
*)
echo bad unit for tape in: $i
;;
esac
umask 77
;;
ch*)
umask 37
unit=`expr $i : '..\(.*\)'`
case $i in
ch*) name=ch; chr=17;;
esac
case $unit in
0|1|2|3|4|5|6)
mknod ${name}${unit} c $chr $unit root:operator
;;
*)
echo bad unit for media changer in: $i
;;
esac
umask 77
;;
ast*)
umask 2 ;
unit=`expr $i : '...\(.*\)'`
chr=119
case $unit in
0|1|2|3)
mknod ast${unit} c $chr $(($unit * 8 + 0)) root:operator
chmod 640 ast${unit}
mknod nast${unit} c $chr $(($unit * 8 + 1)) root:operator
chmod 640 nast${unit}
;;
*)
echo bad unit for tape in: $i
;;
esac
umask 77
;;
acd*t*)
umask $disk_umask
units=`expr $i : '...\(.*\)t'`;
tracks=`expr $i : '.*t\(.*\)'`;
name=acd;
chr=117;
if [ -z "${units}" -o "${units}" -le 0 ]; then
units=1
fi
if [ -z "${tracks}" -o "${tracks}" -le 0 ]; then
tracks=100
fi
if [ "${units}" -le 31 -a "${tracks}" -le 169 ]; then
i=0
while [ $i -le $units ]; do
dname=$name$i
rm -rf ${dname}t*
j=1
while [ $j -le ${tracks} ]; do
mknod ${dname}t$j c $chr \
$((($i * 8) + (65536 * $j))) \
root:operator
j=$(($j + 1))
done
i=$(($i + 1))
done
else
echo "$i is invalid -- can't have more than 32 cd devices or 169 tracks"
fi
umask 77
;;
acd*|cd*|mcd*|scd*)
umask $disk_umask
case $i in
acd*) units=`expr $i : '...\(.*\)'`; name=acd; chr=117;;
cd*) units=`expr $i : '..\(.*\)'`; name=cd; chr=15;;
mcd*) units=`expr $i : '...\(.*\)'`; name=mcd; chr=29;;
scd*) units=`expr $i : '...\(.*\)'`; name=scd; chr=45;;
esac
if [ -z "${units}" -o "${units}" -le 0 ]; then
units=1
fi
if [ "${units}" -le 31 ]; then
i=0
while [ $i -le $units ]; do
dname=$name$i
rm -rf ${dname}[!t]* r${dname}*
mknod ${dname}a c $chr $(($i * 8)) root:operator
mknod ${dname}c c $chr $(($i * 8 + 2)) root:operator
ln -f ${dname}a r${dname}a
ln -f ${dname}c r${dname}c
i=$(($i + 1))
done
else
echo "$i is invalid -- can't have more than 32 cd devices"
fi
umask 77
;;
matcd*)
umask 2
case $i in
matcd*) unit=`expr $i : '.....\(.*\)'`; name=matcd; chr=46;;
esac
case $unit in
0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15)
mknod ${name}${unit}a c $chr $(($unit * 8 + 0)) \
root:operator
mknod ${name}${unit}c c $chr $(($unit * 8 + 2)) \
root:operator
ln -f ${name}${unit}a r${name}${unit}a
ln -f ${name}${unit}c r${name}${unit}c
chmod 640 ${name}${unit}[a-h] r${name}${unit}[a-h]
mknod ${name}${unit}la c $chr $(($unit * 8 + 128)) \
root:operator
mknod ${name}${unit}lc c $chr $(($unit * 8 + 130)) \
root:operator
ln -f ${name}${unit}la r${name}${unit}la
ln -f ${name}${unit}lc r${name}${unit}lc
chmod 640 ${name}${unit}l[a-h] r${name}${unit}l[a-h]
;;
*)
echo bad unit for disk in: $i
;;
esac
umask 77
;;
wcd*)
umask 2 ;
unit=`expr $i : '...\(.*\)'`
chr=69
case $unit in
0|1|2|3|4|5|6|7)
mknod wcd${unit}a c $chr $(($unit * 8 + 0)) root:operator
mknod wcd${unit}c c $chr $(($unit * 8 + 2)) root:operator
ln -f wcd${unit}a rwcd${unit}a
ln -f wcd${unit}c rwcd${unit}c
chmod 640 wcd${unit}[a-h] rwcd${unit}[a-h]
;;
*)
echo bad unit for disk in: $i
;;
esac
umask 77
;;
wst*)
umask 2 ;
unit=`expr $i : '...\(.*\)'`
chr=90
case $unit in
0|1|2|3)
mknod rwst${unit} c $chr $(($unit * 8 + 0)) root:operator
chmod 640 rwst${unit}
;;
esac
umask 77
;;
iic*)
unit=`expr $i : 'iic\(.*\)'`
mknod iic$unit c 105 `unit2minor $unit`
;;
smb*)
unit=`expr $i : 'smb\(.*\)'`
mknod smb$unit c 106 `unit2minor $unit`
;;
pcfclock*)
unit=`expr $i : 'pcfclock\(.*\)'`
mknod pcfclock$unit c 140 `unit2minor $unit`
;;
ppi*)
unit=`expr $i : 'ppi\(.*\)'`
mknod ppi$unit c 82 `unit2minor $unit`
;;
pps*)
unit=`expr $i : 'pps\(.*\)'`
mknod pps$unit c 89 `unit2minor $unit`
;;
usb)
mknod usb$unit c 108 255 root:operator
chmod 0660 usb$unit
;;
usb*)
umask 7
unit=`expr $i : 'usb\(.*\)'`
mknod usb$unit c 108 `unit2minor $unit` root:operator
umask 77
;;
uhid*)
umask 7
unit=`expr $i : 'uhid\(.*\)'`
mknod uhid$unit c 122 `unit2minor $unit` root:operator
umask 77
;;
ums*)
umask 7
unit=`expr $i : 'ums\(.*\)'`
mknod ums$unit c 111 `unit2minor $unit` root:operator
umask 77
;;
ulpt*)
unit=`expr $i : 'ulpt\(.*\)'`
minor=`unit2minor $unit`
mknod ulpt$unit c 113 $minor
minor=`unit2minor $(($unit + 64))`
mknod unlpt$unit c 113 $minor # and the 'no prime' version
;;
ugen*)
umask 7
unit=`expr $i : 'ugen\([0-9][0-9]*\)'`
endpoint=`expr $i : 'ugen.*\.\([0-9][0-9]*\)'`
if [ -z "${unit}" ]; then
echo $i - Invalid unit number
fi
if [ -z "${endpoint}" ]; then # ugen0 & ugen0.1 - ugen0.15
mknod ugen$unit c 114 \
`unit2minor $(($unit * 16))` root:operator
i=1
while [ $i -lt 16 ]; do
mknod ugen$unit.$i c 114 \
`unit2minor $(($unit * 16 + $i))` root:operator
i=$(($i + 1))
done
else
minor=`unit2minor $(($unit * 16 + $endpoint))`
mknod ugen$unit.$endpoint c 114 $minor root:operator
fi
umask 77
;;
urio*)
umask 7
unit=`expr $i : 'urio\(.*\)'`
mknod urio$unit c 143 `unit2minor $unit` root:operator
umask 77
;;
usio*)
umask 7
unit=`expr $i : 'usio\(.*\)'`
minor=`unit2minor $(($unit + 128))`
mknod usio$unit c 138 $minor uucp:dialer
umask 77
;;
uscanner*)
umask 7
unit=`expr $i : 'uscanner\(.*\)'`
mknod uscanner$unit c 156 `unit2minor $unit` root:operator
umask 77
;;
umodem*)
umask 7
unit=`expr $i : 'umodem\(.*\)'`
mknod umodem$unit c 124 `unit2minor $unit` uucp:dialer
umask 77
;;
lpt*)
unit=`expr $i : 'lpt\(.*\)'`
mknod lpt$unit c 16 `unit2minor $unit`
mknod lpctl$unit c 16 `unit2minor $(($unit + 128))`
;;
# Use this to create virtual consoles for syscons, pcvt or codrv
# ttyv0-b
# use as MAKEDEV vtyNN to create NN entries
vty*)
chr=12
units=`expr $i : 'vty\(.*\)'`
i=0
while [ $i -lt $units ]; do
mknod ttyv$(hexprint $i) c $chr `unit2minor $i`
i=$(($i + 1))
done
ln -fs ttyv0 vga # XXX X still needs this pccons relic
;;
nmdm*)
units=`expr $i : 'nmdm\(.*\)'`
chr=18
i=0
while [ $i -lt $units ]; do
minor=`unit2minor $i`
minor=$(($minor + $minor))
mknod nmdm${i}A c $chr $minor
mknod nmdm${i}B c $chr $(($minor + 1))
i=$(($i + 1))
done
;;
bpf*)
units=`expr $i : 'bpf\(.*\)$'`
unit=0
while [ $unit -le $units ]; do
mknod bpf$unit c 23 `unit2minor $unit`
unit=$(($unit + 1))
done
;;
speaker)
mknod speaker c 26 0
;;
cua?|cuaa?|cuaa??)
umask 7
unit_low=`expr $i : 'cua.*\(.\)$'`
case $i in
cua?|cuaa?)
unit_high=""
m_high=0
;;
cuaa??)
unit_high=`expr $i : 'cuaa\(.\).$'`
m_high=`ttyminor $unit_high`
;;
esac
unit=$unit_high$unit_low
m=$(($m_high << 16 | `ttyminor $unit_low`))
mknod cuaa$unit c 28 $(($m | 128)) uucp:dialer
mknod cuaia$unit c 28 $(($m | 32 | 128)) uucp:dialer
mknod cuala$unit c 28 $(($m | 64 | 128)) uucp:dialer
umask 77
;;
tty?|tty0?|ttyd?|ttyd??)
unit_low=`expr $i : 'tty.*\(.\)$'`
case $i in
tty?|tty0?|ttyd?)
unit_high=""
m_high=0
;;
ttyd??)
unit_high=`expr $i : 'ttyd\(.\).$'`
m_high=`ttyminor $unit_high`
;;
esac
unit=$unit_high$unit_low
m=$(($m_high << 16 | `ttyminor $unit_low`))
mknod ttyd$unit c 28 $m
mknod ttyid$unit c 28 $(($m | 32))
mknod ttyld$unit c 28 $(($m | 64))
;;
cuac?)
umask 7
portlist="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"
major=48
card=`expr $i : 'cua.*\(.\)$'`
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor))
name=$card$unit
mknod cuac$name c $major $(($minor + 128)) uucp:dialer
mknod cuaic$name c $major $(($minor + 32 + 128)) uucp:dialer
mknod cualc$name c $major $(($minor + 64 + 128)) uucp:dialer
done
umask 77
;;
ttyc?)
portlist="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"
major=48
card=`expr $i : 'tty.*\(.\)$'`
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor))
name=$card$unit
mknod ttyc$name c $major $minor
mknod ttyic$name c $major $(($minor + 32))
mknod ttylc$name c $major $(($minor + 64))
done
;;
# RISCom8 'rc' driver entries
cuam?)
umask 7
unit=`expr $i : 'cua.*\(.\)$'`
m=`ttyminor $unit`
mknod cuam$unit c 63 $(($m + 128)) uucp:dialer
umask 77
;;
ttym?)
unit=`expr $i : 'tty.*\(.\)$'`
m=`ttyminor $unit`
mknod ttym$unit c 63 $m
;;
# Specialix SI/XIO.
# Note: these are 'base 1' to match the numbers on the panels, and to match
# the manual that comes with the system.
ttyA*)
major=68
units=`expr $i : 'ttyA\(.*\)$'`
port=1
while [ $port -le $units ]; do
minor=$(($port - 1))
name=$(zeropad 2 $port)
mknod ttyA$name c $major $minor
mknod ttyiA$name c $major $(($minor + 65536))
mknod ttylA$name c $major $(($minor + 131072))
port=$(($port + 1))
done
# For the user-mode control program, 'sicontrol'
mknod si_control c 68 262144
;;
cuaA*)
umask 7
major=68
units=`expr $i : 'cuaA\(.*\)$'`
port=1
while [ $port -le $units ]; do
minor=$(($port - 1))
name=$(zeropad 2 $port)
mknod cuaA$name c $major $(($minor + 128)) uucp:dialer
mknod cuaiA$name c $major $(($minor + 128 + 65536)) \
uucp:dialer
mknod cualA$name c $major $(($minor + 128 + 131072)) \
uucp:dialer
port=$(($port + 1))
done
umask 77
;;
# Alpha AS8[24]00 (TurboLaser) console.
zs?)
unit=`expr $i : 'zs.*\(.\)$'`
m=`ttyminor $unit`
mknod zs$unit c 135 $m
;;
# Digiboard PC/?? 16 port card.
# The current scheme of minor numbering is:
#
# unused{14} CARD{2} major{8} CALLOUT{1} LOCK{1} INIT{1} PORT{5}
#
# CARD bitfield in future versions may be extended to 3 bits.
#
# See dgb(4)
#
ttyD?)
portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
major=58
card=`expr $i : 'tty.*\(.\)$'`
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor))
name=$card$unit
mknod ttyD$name c $major $minor
mknod ttyiD$name c $major $(($minor + 32))
mknod ttylD$name c $major $(($minor + 64))
done
# Also create devices for the digi driver
umask 7
major=162
card=`expr $i : 'tty.*\(.\)$'`
rm -f digi$card.ctl
mknod digi$card.ctl c $major $(($card * 65536 + 8388608)) uucp:dialer
unit=0
while [ $unit -lt 16 ]
do
base=$(($card * 65536 + $unit))
name=$card.$unit
rm -f tty*D$name
mknod ttyD$name c $major $base
mknod ttyiD$name c $major $(($base + 1048576))
mknod ttylD$name c $major $(($base + 2097152))
unit=$(($unit + 1))
done
umask 77
;;
cuaD?)
umask 7
portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
major=58
card=`expr $i : 'cua.*\(.\)$'`
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor))
name=$card$unit
mknod cuaD$name c $major $(($minor + 128)) uucp:dialer
mknod cuaiD$name c $major $(($minor + 32 + 128)) uucp:dialer
mknod cualD$name c $major $(($minor + 64 + 128)) uucp:dialer
done
# Also create devices for the digi driver
major=162
card=`expr $i : 'cua.*\(.\)$'`
rm -f digi$card.ctl
mknod digi$card.ctl c $major $(($card * 65536 + 8388608)) uucp:dialer
unit=0
while [ $unit -lt 16 ]
do
base=$(($card * 65536 + $unit))
name=$card.$unit
rm -f cua*D$name
mknod cuaD$name c $major $(($base + 4194304)) uucp:dialer
mknod cuaiD$name c $major $(($base + 5242880)) uucp:dialer
mknod cualD$name c $major $(($base + 6291456)) uucp:dialer
unit=$(($unit + 1))
done
umask 77
;;
# Digiboard Xem - superceeded by the digi device above
#
ttyM*)
portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
modulelist="a b c d"
major=101
card=`expr $i : 'tty.*\(.\)$'`
for unit in $modulelist
do
moduleminor=`ttyminor $unit`
moduleminor=$(($moduleminor % 10 * 16))
modulename=$unit
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor + $moduleminor))
name=$card$modulename$unit
rm -f tty*M$name
mknod ttyM$name c $major $minor
mknod ttyiM$name c $major $(($minor + 64))
mknod ttylM$name c $major $(($minor + 128))
done
done
;;
cuaM?)
umask 7
portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
modulelist="a b c d"
major=101
card=`expr $i : 'cua.*\(.\)$'`
for unit in $modulelist
do
moduleminor=`ttyminor $unit`
moduleminor=$(($moduleminor % 10 * 16))
modulename=$unit
for unit in $portlist
do
minor=`ttyminor $unit`
minor=$(($card * 65536 + $minor + $moduleminor))
name=$card$modulename$unit
rm -f cua*M$name
mknod cuaM$name c $major $(($minor + 262144)) \
uucp:dialer
mknod cuaiM$name c $major $(($minor + 64 + 262144)) \
uucp:dialer
mknod cualM$name c $major $(($minor + 128 + 262144)) \
uucp:dialer
done
done
umask 77
;;
ttyR?)
major=81
BOARD=1; Rnum=0
MINOR=$(($BOARD * 65536))
controllers=$(
dmesg | while read first rest; do
case "$first" in
RocketPort[0-4])
echo "$first"
;;
esac
done
)
rm -f ttyR* ttyiR* ttylR*
for i in $controllers; do
ndevices=$(
dmesg | while read first foo bar ports rest; do
case "$first" in
$i*)
echo "$ports"
;;
esac
done
)
echo -n "Creating $ndevices devices for $i: "
dev=0
while [ $dev -lt $ndevices ]; do
mknod ttyR$Rnum c $major $MINOR
mknod ttyiR$Rnum c $major $(($MINOR + 32))
mknod ttylR$Rnum c $major $(($MINOR + 64))
Rnum=$(($Rnum + 1))
MINOR=$(($MINOR + 1))
dev=$(($dev + 1))
done
BOARD=$(($BOARD + 1))
MINOR=$(($BOARD * 65536))
echo " "
done
;;
cuaR?)
major=81
BOARD=1; Rnum=0
MINOR=$(($BOARD * 65536))
controllers=$(
dmesg | while read first rest; do
case "$first" in
RocketPort[0-4])
echo "$first"
;;
esac
done
)
rm -f cuaR* cuaiR* cualR*
for i in $controllers; do
ndevices=$(
dmesg | while read first foo bar ports rest; do
case "$first" in
$i*)
echo "$ports"
;;
esac
done
)
echo -n "Creating $ndevices devices for $i: "
dev=0
while [ $dev -lt $ndevices ]; do
mknod cuaR$Rnum c $major $(($MINOR + 128)) uucp:dialer
mknod cuaiR$Rnum c $major $(($MINOR + 128 + 32)) \
uucp:dialer
mknod cualR$Rnum c $major $(($MINOR + 128 + 64)) \
uucp:dialer
Rnum=$(($Rnum + 1))
MINOR=$(($MINOR + 1))
dev=$(($dev + 1))
done
BOARD=$(($BOARD + 1))
MINOR=$(($BOARD * 65536))
echo " "
done
;;
mse*)
unit=`expr $i : 'mse\(.*\)'`
chr=27
# non-blocking for X11
mknod mse$unit c $chr `unit2minor $(($unit * 2 + 1))`
;;
psm*)
unit=`expr $i : 'psm\(.*\)'`
chr=21
# non-blocking for X11
mknod psm$unit c $chr `unit2minor $(($unit * 2 + 1))`
;;
mouse*)
name=`expr $i : 'mouse\(.*\)'`
if [ ! -c $name ]; then
$0 $name # make the appropriate device
fi
ln -fs $name mouse
;;
pcaudio)
mknod pcaudio c 24 0
mknod pcaudioctl c 24 128
;;
socksys)
mknod socksys c 41 0
mknod spx c 41 1
ln -fs socksys nfsd
chmod 666 socksys nfsd spx
;;
snd*)
#
# changes from Linux voxware
# minor Linux FreeBSD
# 8 sequencer2 (aka music0) music0
# 17 patmgr0 sequencer1
# 33 patmgr1 sequencer2
#
unit=`expr $i : 'snd\(.*\)'`
chr=30
# XXX write this less verbosely, like std
snd_security_hole=0 # XXX
umask $snd_security_hole
ln -fs mixer$unit mixer
ln -fs sequencer$unit sequencer
ln -fs dsp$unit dsp
ln -fs audio$unit audio
ln -fs dspW$unit dspW
ln -fs music$unit music
ln -fs pss$unit pss
mknod mixer$unit c $chr `unit2minor $(($unit * 16 + 0))`
mknod sequencer$unit c $chr `unit2minor $(($unit * 16 + 1))`
mknod midi$unit c $chr `unit2minor $(($unit * 16 + 2))`
mknod dsp$unit c $chr `unit2minor $(($unit * 16 + 3))`
mknod audio$unit c $chr `unit2minor $(($unit * 16 + 4))`
mknod dspW$unit c $chr `unit2minor $(($unit * 16 + 5))`
mknod sndstat c $chr 6
# minor number 7 is unused
mknod music$unit c $chr `unit2minor $(($unit * 16 + 8))`
mknod pss$unit c $chr `unit2minor $(($unit * 16 + 9))`
# minor number 10 is unused
mknod midistat c $chr 11
# minor numbers 12-15 are unused
umask 77
;;
vat)
mknod vatio c 25 128
chmod 660 vatio
;;
gsc*)
unit=`expr $i : 'gsc\(.*\)'`
mknod gsc${unit} c 47 `unit2minor $unit`
mknod gsc${unit}p c 47 `unit2minor $(($unit + 8))`
mknod gsc${unit}d c 47 `unit2minor $(($unit + 32))`
mknod gsc${unit}pd c 47 `unit2minor $(($unit + 40))`
chmod 666 gsc${unit}*
;;
acpi)
mknod acpi c 152 0 root:operator
chmod 660 acpi
;;
apm)
mknod apm c 39 0 root:operator
chmod 664 apm
;;
apmctl)
mknod apmctl c 39 8 root:operator
chmod 660 apmctl
;;
card*)
unit=`expr $i : 'card\(.*\)'`
chr=50
mknod card$unit c $chr `unit2minor $unit`
chmod 644 card$unit
;;
ti*) unit=`expr $i : 'ti\(.*\)'`
chr=153
mknod ti$unit c $chr `unit2minor $unit`
chmod 600 ti$unit
;;
ttyx?|ttyy?|ttyz?)
case $i in
*0) unit=0;; *1) unit=1;; *2) unit=2;; *3) unit=3;;
*4) unit=4;; *5) unit=5;; *6) unit=6;; *7) unit=7;;
*8) unit=8;; *9) unit=9;; *a) unit=10;; *b) unit=11;;
*c) unit=12;; *d) unit=13;; *e) unit=14;; *f) unit=15;;
esac
case $i in
ttyy?) unit=$(($unit + 16));;
ttyz?) unit=$(($unit + 32));;
esac
mknod $i c 42 $unit
;;
cronyx)
mknod cronyx c 42 63
;;
joy)
mknod joy0 c 51 0 root:operator
mknod joy1 c 51 1 root:operator
chmod 640 joy0 joy1
;;
spigot)
mknod spigot c 11 0
chmod 444 spigot
;;
ctx?)
unit=`expr $i : 'ctx\(.*\)'`
mknod ctx$unit c 40 `unit2minor $unit`
chmod 444 ctx$unit
;;
meteor?)
unit=`expr $i : 'meteor\(.*\)'`
mknod meteor$unit c 67 `unit2minor $unit`
chmod 444 meteor$unit
;;
bktr?)
unit=`expr $i : 'bktr\(.*\)'`
mknod bktr$unit c 92 `unit2minor $unit`
mknod tuner$unit c 92 `unit2minor $((16 + $unit))`
mknod vbi$unit c 92 `unit2minor $((32 + $unit))`
chmod 444 bktr$unit tuner$unit vbi$unit
;;
tun*)
units=`expr $i : 'tun\(.*\)$'`
unit=0
while [ $unit -le $units ]; do
mknod tun$unit c 52 `unit2minor $unit`
unit=$(($unit + 1))
done
;;
tap*)
units=`expr $i : 'tap\(.*\)$'`
unit=0
while [ $unit -le $units ]; do
mknod tap$unit c 149 `unit2minor $unit` root:network
unit=$(($unit + 1))
done
;;
sysmouse)
mknod sysmouse c 12 128
mknod consolectl c 12 255
;;
jogdial)
mknod jogdial c 160 0
;;
snp?)
unit=`expr $i : 'snp\(.*\)'`
mknod snp$unit c 53 `unit2minor $unit`
;;
# dufault@hda.com: If I do much more work on other A-D boards
# then eventually we'll have a "ad" and "dio" interface and some of these
# "labpcaio" ones will be gone.
# labpcaio: D-A and A-D.
# labpcdio: Digital in and Digital out.
#
labpc*)
umask 7
case $i in
labpcaio*)
name=labpcaio
unit=`expr $i : 'labpcaio\(.*\)'`
all="0 1 2 3 4 5 6 7"
offset=0
;;
labpcdio*)
name=labpcdio
unit=`expr $i : 'labpcdio\(.*\)'`
all="0 1 2 3"
offset=8
;;
*)
die 3 "Don't know LabPC type $i"
;;
esac
if [ -z "${unit}" ]; then
unit=all
fi
case $unit in
0|1|2|3|4|5|6|7)
mknod $name$unit c 66 $(($offset + $unit))
;;
all)
for i in $all
do
mknod $name$i c 66 $(($offset + $i))
done
;;
*)
echo "No such LabPC unit: $unit"
;;
esac
umask 77
;;
perfmon)
mknod perfmon c 2 32 root:kmem
chmod 640 perfmon
;;
ipl)
mknod ipl c 79 0
mknod ipnat c 79 1
mknod ipstate c 79 2
mknod ipauth c 79 3
;;
kbd*)
unit=`expr $i : 'kbd\(.*\)'`
chr=112
mknod kbd$unit c $chr `unit2minor $unit`
;;
i4b)
mknod i4b c 60 0
;;
i4bctl)
mknod i4bctl c 55 0
;;
i4brbch*)
unit=`expr $i : 'i4brbch\(.*\)'`
mknod i4brbch$unit c 57 `unit2minor $unit`
;;
i4bteld*)
offset=64
unit=`expr $i : 'i4bteld\(.*\)'`
mknod i4bteld$unit c 56 `unit2minor $(($offset + $unit))`
;;
i4btel*)
unit=`expr $i : 'i4btel\(.*\)'`
mknod i4btel$unit c 56 `unit2minor $unit`
;;
i4btrc*)
unit=`expr $i : 'i4btrc\(.*\)'`
mknod i4btrc$unit c 59 `unit2minor $unit`
;;
aac*)
unit=`expr $i : 'aac\(.*\)'`
mknod aac$unit c 150 `unit2minor $unit`
ln -fs aac$unit afa$unit
ln -fs aac$unit hpn$unit
;;
mlx*)
unit=`expr $i : 'mlx\(.*\)'`
mknod mlx$unit c 130 `unit2minor $unit`
;;
mly*)
unit=`expr $i : 'mlx\(.*\)'`
mknod mlx$unit c 158 `unit2minor $unit`
;;
amr*)
unit=`expr $i : 'amr\(.*\)'`
mknod amr$unit c 132 `unit2minor $unit`
;;
ciss*)
unit=`expr $i : 'ciss\(.*\)'`
mknod ciss$unit c 166 `unit2minor $unit`
;;
3dfx*)
unit=`expr $i : '3dfx\(.*\)'`
mknod 3dfx$unit c 107 `unit2minor $unit`
ln -sf 3dfx$unit 3dfx
ln -sf 3dfx$unit voodoo
;;
agpgart)
mknod agpgart c 148 0
;;
twe*)
unit=`expr $i : 'twe\(.*\)'`
mknod twe$unit c 146 `unit2minor $unit`
;;
tw*)
unit=`expr $i : 'tw\(.*\)'`
mknod tw$unit c 19 `unit2minor $unit` root:operator
;;
cfs*)
unit=`expr $i : 'cfs\(.*\)'`
mknod cfs$unit c 93 $unit root:operator
;;
nsmb*)
unit=`expr $i : 'nsmb\(.*\)'`
mknod nsmb$unit c 144 $unit
;;
local)
umask 0 # XXX should be elsewhere
sh $0.local
umask 77
;;
*)
echo $i - no such device name
;;
esac
done