Don't use patch -b, the flag has different meanings for BSD and GNU patch.
[dragonfly.git] / etc / MAKEDEV
1 #!/bin/sh -
2 #
3 # Copyright (c) 1990 The Regents of the University of California.
4 # All rights reserved.
5 #
6 # Written and contributed by W. Jolitz 12/90
7 #
8 # Redistribution and use in source and binary forms are permitted provided
9 # that: (1) source distributions retain this entire copyright notice and
10 # comment, and (2) distributions including binaries display the following
11 # acknowledgement:  ``This product includes software developed by the
12 # University of California, Berkeley and its contributors'' in the
13 # documentation or other materials provided with the distribution and in
14 # all advertising materials mentioning features or use of this software.
15 # Neither the name of the University nor the names of its contributors may
16 # be used to endorse or promote products derived from this software without
17 # specific prior written permission.
18 # THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
19 # WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
20 # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
21 #
22 #       @(#)MAKEDEV     5.2 (Berkeley) 6/22/90
23 # $FreeBSD: src/etc/MAKEDEV,v 1.243.2.57 2003/02/10 11:35:53 simokawa Exp $
24 # $DragonFly: src/etc/MAKEDEV,v 1.13 2004/09/23 14:30:16 simokawa Exp $
25 #
26 # Device "make" file.  Valid arguments:
27 #       all     makes all known devices, standard number of units (or close)
28 #       std     standard devices
29 #       jail    suitable for a jail(8)
30 #       local   configuration specific devices
31 #       mach-4  mach4&lites+devices for Mach's XFree86 distribution
32 #       (see http://www.cs.hut.fi/lites.html for more info on LITES)
33 #
34 # Tapes:
35 #       ast*    ATAPI tape drives
36 #       wt*     QIC-interfaced (e.g. not SCSI) 3M cartridge tape
37 #       sa*     SCSI Sequential Access Devices
38 #
39 # Disks:
40 #       aac*    Adaptec FSA RAID controllers
41 #       aacd*   Adaptec FSA RAID
42 #       acd*    ATAPI CD-ROM disks
43 #       ad*     ATA disks
44 #       afd*    ATAPI floppy disks
45 #       amrd*   AMI MegaRAID
46 #       cd*     SCSI CD-ROM disks
47 #       da*     SCSI Direct Access Devices
48 #       fd*     floppy disk drives (3 1/2", 5 1/4")
49 #       fla*    M-Systems DiskOnChip
50 #       idad*   Compaq Smart-2 RAID arrays
51 #       ips*    IBM ServeRAID controller
52 #       ipsd*   IBM ServeRAID
53 #       mcd*    Mitsumi CD-ROM disks
54 #       md*     Memory (or malloc) disk
55 #       mlx*    Mylex DAC960 RAID controllers
56 #       mlxd*   Mylex DAC960 RAID disk volumes
57 #       pst*    Promise SuperTrak RAID disks
58 #       scd*    Sony CD-ROM disks
59 #       vn*     vnode disks
60 #
61 # Console ports:
62 #       vty*    virtual console devices for syscons/pcvt/codrv
63 #
64 # Pointing devices:
65 #       mse*    Logitech and ATI Inport bus mouse
66 #       psm*    PS/2 mouse
67 #       jogdial Sony VAIO Jogdial
68 #       sysmouse Mousesystems mouse emulator for syscons
69 #
70 # Time devices:
71 #       refclock-* serial ports used by xntpd parse refclocks
72 #
73 # Terminal ports:
74 #       tty*    general purpose serial ports
75 #       cua*    dialout serial ports
76 #       ttyA*   Specialix SI/XIO dialin ports ('*' = number of devices)
77 #       cuaA*   Specialix SI/XIO dialout ports
78 #       ttyD*   Digiboard - 16 dialin ports
79 #       cuaD*   Digiboard - 16 dialout ports
80 #       ttyE*   Stallion EasyIO (stl) dialin ports
81 #       cuaE*   Stallion EasyIO (stl) dialout ports
82 #       ttyF*   Stallion Brumby (stli) dialin ports
83 #       cuaF*   Stallion Brumby (stli) dialout ports
84 #       ttyR*   Rocketport dialin ports
85 #       cuaR*   Rocketport dialout ports
86 #
87 #       stlN    Stallion EasyIO board N dialin and dialout
88 #       stliN   Stallion Brumby board N dialin and dialout
89 #
90 # Pseudo terminals:
91 #       pty*    set of 32 master and slave pseudo terminals
92 #       vty*    virtual terminals using syscons/pcvt/codrv console
93 #
94 # Parallel port:
95 #       lpt*    Printer
96 #       ppi*    Parallel port i/o
97 #       pps*    Pulse per second timing interface
98 #       pcfclock* Parallel time sync interface
99 #
100 # I2C and SMBus:
101 #       iic*    I2C devices
102 #       smb*    SMBUS devices
103 #
104 # USB devices:
105 #       usb*    USB bus control device
106 #       ucom*   USB serial devices
107 #       ugen*   generic USB device
108 #       uhid*   Human Interface Device (HID)
109 #       ulpt*   printer
110 #       umodem* modems
111 #       ums*    mouse
112 #       urio*   Diamond Rio 500
113 #       uscanner* USB scanners
114 #
115 # SCSI devices (other than CD-ROM, tape and disk):
116 #       ch*     SCSI Media-Changer (juke box) driver
117 #       pt*     Processor Type (HP scanner, as one example)
118 #       pass*   CAM Passthrough device
119 #       ses*    SES (SCSI Environmental Services) and
120 #               SAF-TE (Scsi Accessable Fault-Tolerant Enclosures) device
121 #
122 # PC-CARD (previously called PCMCIA) support
123 #       card*   PC-CARD slots
124 #
125 # ISDN devices:
126 #       i4b     isdnd call control device
127 #       i4bctl  debugging control device
128 #       i4btrc* trace data interface(s), one per passive card
129 #       i4btel* telephony interface(s)
130 #       i4bteld* telephony dialout interface(s)
131 #       i4brbch* raw b channel access device(s)
132 #
133 # Special purpose devices:
134 #       acpi    ACPI control device
135 #       apm     Advanced Power Management BIOS
136 #       apmctl  APM BIOS control device
137 #       bpf*    packet filter
138 #       crypto  crypto interface
139 #       speaker pc speaker
140 #       tw*     xten power controller
141 #       snd*    various sound cards
142 #       pcaudio PCM audio driver
143 #       socksys iBCS2 socket system driver
144 #       vat     VAT compatibility audio driver (requires snd*)
145 #       gsc     Genius GS-4500 hand scanner
146 #       joy     pc joystick
147 #       tun*    Tunneling IP device
148 #       tap*    Ethernet Tunneling device
149 #       snp*    tty snoop devices
150 #       spigot  Video Spigot video acquisition card
151 #       ctx*    Cortex-I video acquisition card
152 #       meteor* Matrox Meteor video acquisition card (pci)
153 #       bktr*   Bt848 based video acquisition card (pci)
154 #       labpc*  National Instrument's Lab-PC and LAB-PC+
155 #       perfmon CPU performance-monitoring counters
156 #       pci     PCI configuration-space access from user mode
157 #       ipl     ipfilter control devices (ipl, ipnat, ipstate, ipauth)
158 #       kbd     keyboard devices
159 #       elan-mmcr       AMD Elan support (e.g. mmap MMCR)
160 #       agpgart AGP interface
161 #       cfs*    Coda Distributed Filesystem
162 #       nsmb*   SMB/CIFS protocol interface
163 #       pf      PF packet filter
164 #
165
166 if [ -n "$MAKEDEVPATH" ]; then
167         PATH="$MAKEDEVPATH"
168 else
169         PATH=/sbin:/bin
170 fi
171 umask 77
172
173 # Usage: die exitcode msg
174 die() {
175         echo $2
176         exit $1
177 }
178
179 # Convert integer to partition name
180 dkitop() {
181         local p
182
183         case $1 in
184         0) p=a;; 1) p=b;; 2) p=c;; 3) p=d;; 4) p=e;; 5) p=f;; 6) p=g;; 7) p=h;;
185         8) p=i;; 9) p=j;; 10) p=k;; 11) p=l;; 12) p=m;; 13) p=n;; 14) p=o;; 15) p=p;;
186         *) p="?";;
187         esac
188         echo $p
189 }
190
191 # Convert integer to slice name
192 dkitos() {
193         local s
194
195         case $1 in
196         0) s="";;
197         1) s="";;
198         *) s=s$(($1-1));;
199         esac
200         echo $s
201 }
202
203 # Convert disk (type, unit, slice, partition) to minor number
204 dkminor()
205 {
206         echo $(($1 << 25 | ($2 / 32) << 21 | ($2 % 32) << 3 | $3 << 16 | ($4 & 7) | ($4 & 8) << 17))
207 }
208
209 # Override mknod(2) to add extra handling to it.
210 mknod=/sbin/mknod
211 for i in `IFS=':'; echo $PATH`; do
212         if [ -x "${i}/mknod" ]; then
213                 mknod="${i}/mknod"
214                 break
215         fi
216 done
217 mknod() {
218         rm -f "$1" || exit 1
219         case $# in
220         4) "$mknod" "$@" root:wheel || die 2 "$mknod $@ failed";;
221         5) "$mknod" "$@"            || die 2 "$mknod $@ failed";;
222         *) die 2 "bad node: mknod $@";;
223         esac
224 }
225
226 # Convert tape (ctrl, unit, mode, access) to minor number
227 saminor()
228 {
229         echo $(($1 << 29 | ($2 / 16) << 16 | ($2 % 16) << 4 | $3 << 2 | $4))
230 }
231
232 # Convert the last character of a tty name to a minor number.
233 ttyminor()
234 {
235         case $1 in
236         [0-9]) m=$1;;
237         a) m=10;; b) m=11;; c) m=12;; d) m=13;; e) m=14;; f) m=15;; g) m=16;;
238         h) m=17;; i) m=18;; j) m=19;; k) m=20;; l) m=21;; m) m=22;; n) m=23;;
239         o) m=24;; p) m=25;; q) m=26;; r) m=27;; s) m=28;; t) m=29;; u) m=30;;
240         v) m=31;;
241         *) m="?";;
242         esac
243         echo $m
244 }
245
246 # Convert a unit number to a minor number.
247 unit2minor()
248 {
249   echo $(((($1 >> 8) << 16) | ($1 % 256)))
250 }
251
252 # For the stallion devices tty[EF]
253 # stallion major letter card iscallout
254 stallion () {
255         major=$1
256         letter=$2
257         card=$3
258         iscallout=$4
259
260         port=0
261         maxport=8
262         pref=tty
263         owner=
264         minorbase=0
265
266         if [ $iscallout -gt 0 ]; then
267             pref=cua
268             owner=uucp:dialer
269             minorbase=128
270         fi
271
272         case "$card" in 
273         [0-7]);;
274         *) die 1 "Invalid stl card number $card";;
275         esac
276
277         # make the mem interface for extracting stats & loading microcode.
278         # 0x1000000 + card number
279         mknod staliomem$card c $major 0x0100000$card
280
281         while [ $port -lt $maxport ]; do
282             minor=$(($minorbase + $card * 1048576 + $port))
283             if [ $port -ge 32 ]; then
284                 minor=$(($minor + 65504))
285             fi
286             unit=$(($card * 64 + $port))
287
288             mknod ${pref}${letter}$unit c $major $minor $owner
289             mknod ${pref}i${letter}$unit c $major $(($minor + 32)) $owner
290             mknod ${pref}l${letter}$unit c $major $(($minor + 64)) $owner
291             port=$(($port + 1))
292         done
293 }
294
295 # Raw partition for disks
296 dkrawpart=2
297
298 # Compatibility slice for disks
299 dkcompatslice=0
300
301 # Raw slice for disks
302 dkrawslice=1
303
304 # Standard umasks
305 disk_umask=037                  # allow group operator to read disks
306 tape_umask=017                  # allow group operator to read/write tapes
307
308 for i in $*; do
309 case $i in
310
311 all)
312         sh MAKEDEV std                                  # standard
313         sh MAKEDEV fd0 fd1                              # bdev, floppy disk
314         sh MAKEDEV da0 da1 da2 da3                      # bdev, SCSI disk
315         sh MAKEDEV ata                                  # cdev, ATA control
316         sh MAKEDEV ad0 ad1 ad2 ad3                      # bdev, ATA disk
317         sh MAKEDEV ar0 ar1                              # bdev, ATA RAID disk
318         sh MAKEDEV acd0 afd0 ast0                       # bdev, ATAPI devices
319         sh MAKEDEV wd0 wd1 wd2 wd3                      # bdev, OLD disk
320         sh MAKEDEV wcd0 wfd0 wst0                       # bdev, OLD ATAPI devs
321         sh MAKEDEV vn0                                  # bdev, virtual disk
322         sh MAKEDEV cd0 mcd0 scd0                        # bdev, cdrom
323         sh MAKEDEV sa0 wt0                              # bdev, tape
324         sh MAKEDEV vty12                                # cdev, virtual tty
325         sh MAKEDEV cuaa0 cuaa1 cuaa2 cuaa3              # cdev, serial tty
326         sh MAKEDEV pty0                                 # cdev, pseudo tty
327         sh MAKEDEV ttyd0 ttyd1 ttyd2 ttyd3              # cdev, serial tty
328         sh MAKEDEV zs0                                  # big-Alpha serial tty
329         sh MAKEDEV kbd0 kbd1                            # cdev, keyboard
330         sh MAKEDEV mse0 psm0 jogdial sysmouse           # cdev, mouse
331         sh MAKEDEV pcaudio speaker snd0                 # cdev, noise
332         sh MAKEDEV lpt0 lpt1 lpt2                       # cdev, printer
333         sh MAKEDEV ppi0 ppi1 ppi2                       # cdev, parallel port
334         sh MAKEDEV iic0 iic1                            # cdev, I2C device
335         sh MAKEDEV smb0 smb1                            # cdev, SMBus device
336         sh MAKEDEV usb usb0 uhid0 ums0 ulpt0 ugen0      # cdev, USB devices
337         sh MAKEDEV usb1 uhid1 ums1 ulpt1 ugen1          # cdev, USB devices
338         sh MAKEDEV usb2 usb3 usb4 usb5                  # cdev, USB devices
339         sh MAKEDEV urio0 uscanner0 umodem0              # cdev, USB devices too
340         sh MAKEDEV bpf0 bpf1 bpf2 bpf3                  # cdev, network
341         sh MAKEDEV ipl tun0 tun1 tun2 tun3              # cdev, network
342         sh MAKEDEV tap0 tap1 tap2 tap3                  # cdev, network
343         sh MAKEDEV ch0 perfmon tw0                      # cdev, miscellaneous
344         sh MAKEDEV acpi                                 # cdev, laptop
345         sh MAKEDEV apm apmctl card0 card1 card2 card3   # cdev, laptop
346         sh MAKEDEV pass4 xpt2                           # cdev, CAM
347         sh MAKEDEV i4b i4bctl i4btrc0 i4btrc1           # cdev, ISDN
348         sh MAKEDEV i4btel0 i4btel1 i4bteld0 i4bteld1    # cdev, ISDN
349         sh MAKEDEV i4brbch0 i4brbch1                    # cdev, ISDN
350         sh MAKEDEV agpgart                              # cdev, AGP
351         sh MAKEDEV nsmb0                                # cdev, SMB/CIFS
352         sh MAKEDEV twed0                                # 3ware
353         sh MAKEDEV crypto                               # cdev, crypto
354         sh MAKEDEV fw0                                  # cdev, firewire
355         sh MAKEDEV dcons                                # cdev, dcons
356         sh MAKEDEV pf                                   # pf
357         ;;
358
359 # a much restricted set of the above, to save precious i-nodes on the
360 # fixit floppy
361 fixit)
362         sh MAKEDEV std                                  # standard
363         sh MAKEDEV fd0                                  # bdev, floppy disk
364         sh MAKEDEV da0                                  # bdev, SCSI disk
365         sh MAKEDEV ad0                                  # bdev, ATA disk
366         sh MAKEDEV acd0 afd0 ast0                       # bdev, ATAPI devices
367         sh MAKEDEV wd0                                  # bdev, OLD disk
368         sh MAKEDEV wcd0 wfd0 wst0                       # bdev, OLD ATAPI devs
369         sh MAKEDEV vn0                                  # bdev, virtual disk
370         sh MAKEDEV cd0                                  # bdev, cdrom
371         sh MAKEDEV sa0                                  # bdev, tape
372         sh MAKEDEV vty2                                 # cdev, virtual tty
373         sh MAKEDEV cuaa0                                # cdev, serial tty
374         sh MAKEDEV pty0                                 # cdev, pseudo tty
375         sh MAKEDEV ttyd0                                # cdev, serial tty
376         sh MAKEDEV zs0                                  # big-Alpha serial tty
377         sh MAKEDEV kbd0                                 # cdev, keyboard
378         sh MAKEDEV mse0 psm0 sysmouse                   # cdev, mouse
379         sh MAKEDEV lpt0                                 # cdev, printer
380         sh MAKEDEV ppi0                                 # cdev, parallel port
381         sh MAKEDEV iic0                                 # cdev, I2C device
382         sh MAKEDEV smb0                                 # cdev, SMBus device
383         sh MAKEDEV ums0                                 # cdev, USB devices
384         sh MAKEDEV tun0                                 # cdev, network
385         sh MAKEDEV tap0                                 # cdev, network
386         sh MAKEDEV ch0                                  # cdev, miscellaneous
387         sh MAKEDEV apm apmctl card0                     # cdev, laptop
388         sh MAKEDEV pass1 xpt1                           # cdev, CAM
389         sh MAKEDEV i4b i4bctl i4btrc0 i4btrc1           # cdev, ISDN
390         sh MAKEDEV i4btel0 i4bteld0                     # cdev, ISDN
391         sh MAKEDEV i4brbch0                             # cdev, ISDN
392         rm -f fd/[1-9]?
393         ;;
394
395 std)
396         mknod console   c 0 0;                  chmod 600 console
397         mknod kmem      c 2 1 root:kmem;        chmod 640 kmem
398         mknod mem       c 2 0 root:kmem;        chmod 640 mem
399         mknod null      c 2 2;                  chmod 666 null
400         mknod random    c 2 3;                  chmod 644 random
401         mknod urandom   c 2 4;                  chmod 644 urandom
402         mknod zero      c 2 12;                 chmod 666 zero
403         mknod io        c 2 14;                 chmod 600 io
404         mknod tty       c 1 0;                  chmod 666 tty
405         mknod klog      c 7 0;                  chmod 600 klog
406         mknod stdin     c 22 0;                 chmod 666 stdin
407         mknod stdout    c 22 1;                 chmod 666 stdout
408         mknod stderr    c 22 2;                 chmod 666 stderr
409         mknod pci       c 78 0;                 chmod 644 pci
410         mkdir -p fd
411         (cd fd && i=0 &&
412                 while [ $i -lt 64 ]; do
413                         mknod $i c 22 $i
414                         i=$(($i + 1))
415                 done
416         )
417         chmod 555 fd
418         chmod 666 fd/*
419         ;;
420
421 jail)
422         sh MAKEDEV std pty0
423         rm mem kmem pci io klog console         # for security
424         ln -sf null mem                 # for libkvm (ab)users
425         ln -sf null kmem                # --//--
426         ln -sf null console
427         ;;
428
429 mach-4)
430         mknod iopl c 22 0
431         mknod kbd c 23 0
432         mknod mouse c 24 0
433         mknod time c 25 0
434         mknod timezone c 26 0
435         ;;
436
437 # Create device files for new Archive/Wangtek QIC-02 tape driver (vak)
438 wt*)
439         umask $tape_umask
440         u=`expr $i : '..\(.*\)'`
441         if [ -z "${u}" ]; then u=0; fi
442         # default density, 512b blocks
443         mknod rwt${u}   c 10 $(( 0 + $u)) root:operator
444         mknod nrwt${u}  c 10 $(( 4 + $u)) root:operator
445         # default density, 1024b blocks
446 #       mknod rWt${u}   c 10 $((64 + $u)) root:operator
447 #       mknod nrWt${u}  c 10 $((68 + $u)) root:operator
448         mknod rwt${u}b  c 10 $((16 + $u)) root:operator # 60 megabytes
449         mknod nrwt${u}b c 10 $((20 + $u)) root:operator
450         mknod rwt${u}c  c 10 $((24 + $u)) root:operator # 120 megabytes
451         mknod nrwt${u}c c 10 $((28 + $u)) root:operator
452         mknod rwt${u}d  c 10 $((32 + $u)) root:operator # 150 megabytes
453         mknod nrwt${u}d c 10 $((36 + $u)) root:operator
454 #       mknod rwt${u}e  c 10 $((40 + $u)) root:operator # 300 megabytes?
455 #       mknod nrwt${u}e c 10 $((44 + $u)) root:operator
456 #       mknod rwt${u}f  c 10 $((48 + $u)) root:operator # 600 megabytes?
457 #       mknod nrwt${u}f c 10 $((52 + $u)) root:operator
458         umask 77
459         ;;
460
461 # Individual slices.
462 aacd*s*|ad*s*|ar*s*|afd*s*|amrd*s*|da*s*|fla*s*|idad*s*|ipsd*s*|md*s*|mlxd*s*|pst*s*|twed*s*|vn*s*|wd*s*|wfd*s*)
463         umask $disk_umask
464         case $i in
465         aacd*s*) name=aacd; chr=151;;
466         ad*s*) name=ad; chr=116;;
467         ar*s*) name=ar; chr=157;;
468         afd*s*) name=afd; chr=118;;
469         amrd*s*) name=amrd; chr=133;;
470         da*s*) name=da;  chr=13;;
471         fla*s*) name=fla; chr=102;;
472         idad*s*) name=idad; chr=109;;
473         ipsd*s*) name=ipsd; chr=176;;
474         md*s*) name=md;  chr=95;;
475         mlxd*s*) name=mlxd; chr=131;;
476         pst*s*) name=pst; chr=168;;
477         twed*s*) name=twed; chr=147;;
478         vn*s*) name=vn; chr=43;;
479         wd*s*) name=wd;  chr=3;;
480         wfd*s*) name=wfd; chr=87;;
481         esac
482         case $i in
483         aacd*s*|amrd*s*|idad*s*|ipsd*s*|mlxd*s*|twed*s*)
484                 unit=`expr $i : '....\([0-9]*\)s'`
485                 slice=`expr $i : '....[0-9]*s\([0-9]*\)'`
486                 part=`expr $i : '....[0-9]*s[0-9]*\(.*\)'`
487                 ;;
488         afd*s*|fla*s*|pst*s*|wfd*s*)
489                 unit=`expr $i : '...\([0-9]*\)s'`
490                 slice=`expr $i : '...[0-9]*s\([0-9]*\)'`
491                 part=`expr $i : '...[0-9]*s[0-9]*\(.*\)'`
492                 ;;
493         *)
494                 unit=`expr $i : '..\([0-9]*\)s'`
495                 slice=`expr $i : '..[0-9]*s\([0-9]*\)'`
496                 part=`expr $i : '..[0-9]*s[0-9]*\(.*\)'`
497                 ;;
498         esac
499         case $unit in
500         [0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
501                 case $slice in
502                 [0-9]|[1-2][0-9]|30)
503                         oldslice=$slice
504                         slice=$(($slice+1))
505                         slicename=`dkitos $slice`
506                         minor=`dkminor 0 $unit $slice $dkrawpart`
507                         mknod  $name$unit$slicename c $chr $minor root:operator
508                         rm -f r$name$unit$slicename
509                         case $part in
510                         [a-h])
511                                 case $oldslice in
512                                 0) slice=$oldslice ;;
513                                 esac
514                                 for part in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
515                                 do
516                                         minor=`dkminor 0 $unit $slice $part`
517                                         partname=`dkitop $part`
518                                         mknod  $name$unit$slicename$partname \
519                                               c $chr $minor root:operator
520                                         rm -f r$name$unit$slicename$partname
521                                 done
522                                 ;;
523                         "")
524                                 ;;
525                         *)
526                                 echo bad partition for disk in: $i
527                                 ;;
528                         esac
529                         ;;
530                 *)
531                         echo bad slice for disk in: $i
532                         ;;
533                 esac
534                 ;;
535         *)
536                 echo bad unit for disk in: $i "(unit=$unit, slice=$slice, part=$part)"
537                 ;;
538         esac
539         umask 77
540         ;;
541
542 fd*)
543         umask $disk_umask
544         unit=`expr $i : '..\(.*\)'`
545         name=fd; chr=9
546         case $unit in
547         0|1|2|3)
548                 mknod ${name}${unit}   c $chr $(($unit * 64)) root:operator
549                 rm -f r${name}${unit}
550                 # Fake BSD partitions
551                 for i in a b c d e f g h
552                 do
553                         ln -f ${name}${unit} ${name}${unit}$i
554                         rm -f r${name}${unit} r${name}${unit}$i
555                 done
556                 # User-readable and programmer-readable name sets
557
558                 mknod ${name}${unit}.1720  c $chr $(($unit * 64 + 1)) \
559                     root:operator
560                 rm -f r${name}${unit}.1720
561                 # ln -f ${name}${unit}.1720 ${name}${unit}135hs21
562                 # rm -f r${name}${unit}135hs21
563
564                 mknod ${name}${unit}.1480  c $chr $(($unit * 64 + 2)) \
565                     root:operator
566                 rm -f r${name}${unit}.1480
567                 # ln -f ${name}${unit}.1480 ${name}${unit}135hs18
568                 # rm -f r${name}${unit}135hs18
569                 # ln -f ${name}${unit}.1480 ${name}${unit}96hs18
570                 # rm -f r${name}${unit}96hs18
571
572                 mknod ${name}${unit}.1440  c $chr $(($unit * 64 + 3)) \
573                     root:operator
574                 rm -f r${name}${unit}.1440
575                 # ln -f ${name}${unit}.1440 ${name}${unit}135
576                 # rm -f r${name}${unit}135
577                 # ln -f ${name}${unit}.1440 ${name}${unit}135ds18
578                 # rm -f r${name}${unit}135ds18
579                 # ln -f ${name}${unit}.1440 ${name}${unit}96ds18
580                 # rm -f r${name}${unit}96ds18
581
582                 mknod ${name}${unit}.1200  c $chr $(($unit * 64 + 4)) \
583                     root:operator
584                 rm -f r${name}${unit}.1200
585                 # ln -f ${name}${unit}.1200 ${name}${unit}96
586                 # rm -f r${name}${unit}96
587                 # ln -f ${name}${unit}.1200 ${name}${unit}96ds15
588                 # rm -f r${name}${unit}96ds15
589                 # ln -f ${name}${unit}.1200 ${name}${unit}135ds15
590                 # rm -f r${name}${unit}135ds15
591
592                 mknod ${name}${unit}.820  c $chr $(($unit * 64 + 5)) \
593                     root:operator
594                 rm -f r${name}${unit}.820
595                 # ln -f ${name}${unit}.820 ${name}${unit}96hs10
596                 # rm -f r${name}${unit}96hs10
597                 # ln -f ${name}${unit}.820 ${name}${unit}135hs10
598                 # rm -f r${name}${unit}135hs10
599
600                 mknod ${name}${unit}.800  c $chr $(($unit * 64 + 6)) \
601                     root:operator
602                 rm -f r${name}${unit}.800
603                 # ln -f ${name}${unit}.800 ${name}${unit}96ds10
604                 # rm -f r${name}${unit}96ds10
605                 # ln -f ${name}${unit}.800 ${name}${unit}135ds10
606                 # rm -f r${name}${unit}135ds10
607
608                 mknod ${name}${unit}.720  c $chr $(($unit * 64 + 7)) \
609                     root:operator
610                 rm -f r${name}${unit}.720
611                 # ln -f ${name}${unit}.720 ${name}${unit}96ds9
612                 # rm -f r${name}${unit}96ds9
613                 # ln -f ${name}${unit}.720 ${name}${unit}135ds9
614                 # rm -f r${name}${unit}135ds9
615
616                 mknod ${name}${unit}.360  c $chr $(($unit * 64 + 8)) \
617                     root:operator
618                 rm -f r${name}${unit}.360
619                 # ln -f ${name}${unit}.360 ${name}${unit}48
620                 # rm -f r${name}${unit}48
621                 # ln -f ${name}${unit}.360 ${name}${unit}48ds9
622                 # rm -f r${name}${unit}48ds9
623
624                 mknod ${name}${unit}.640  c $chr $(($unit * 64 + 9)) \
625                     root:operator
626                 rm -f r${name}${unit}.640
627                 # ln -f ${name}${unit}.640 ${name}${unit}96ds8
628                 # rm -f r${name}${unit}96ds8
629                 # ln -f ${name}${unit}.640 ${name}${unit}135ds8
630                 # rm -f r${name}${unit}135ds8
631
632                 mknod ${name}${unit}.1232  c $chr $(($unit * 64 + 10)) \
633                     root:operator
634                 rm -f r${name}${unit}.1232
635                 # ln -f ${name}${unit}.1232 ${name}${unit}96ds8
636                 # rm -f r${name}${unit}96ds8
637                 # ln -f ${name}${unit}.1232 ${name}${unit}135ds8
638                 # rm -f r${name}${unit}135ds8
639                 ;;
640         *)
641                 echo bad unit for disk in: $i
642                 ;;
643         esac
644         umask 77
645         ;;
646
647 aacd*|ad*|ar*|afd*|amrd*|da*|fla*|idad*|ipsd*|md*|mlxd*|pst*|twed*|vn*|wd*|wfd*)
648         umask $disk_umask
649         case $i in
650         aacd*) name=aacd; chr=151;;
651         ad*) name=ad; chr=116;;
652         ar*) name=ar; chr=157;;
653         afd*) name=afd; chr=118;;
654         amrd*) name=amrd; chr=133;;
655         da*) name=da;  chr=13;;
656         fla*) name=fla; chr=102;;
657         idad*) name=idad; chr=109;;
658         ipsd*) name=ipsd; chr=176;;
659         md*) name=md; chr=95;;
660         mlxd*) name=mlxd; chr=131;;
661         pst*) name=pst; chr=168;;
662         twed*) name=twed; chr=147;;
663         vn*) name=vn; chr=43;;
664         wd*) name=wd;  chr=3;;
665         wfd*) name=wfd; chr=87;;
666         esac
667         case $i in
668         aacd*|amrd*|idad*|ipsd*|mlxd*|twed*)
669                 unit=`expr $i : '....\(.*\)'`
670                 ;;
671         afd*|fla*|pst*|wfd*)
672                 unit=`expr $i : '...\(.*\)'`
673                 ;;
674         *)
675                 unit=`expr $i : '..\(.*\)'`
676                 ;;
677         esac
678         case $unit in
679         [0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
680                 for slicepartname in s0h s1h s2 s3 s4
681                 do
682                         sh MAKEDEV $name$unit$slicepartname
683                 done
684                 ;;
685         *)
686                 echo bad unit for disk in: $i
687                 ;;
688         esac
689         umask 77
690         ;;
691
692 ccd*)
693         umask $disk_umask
694         name=ccd
695         chr=74
696         unit=`expr $i : '...\(.*\)'`
697         case $unit in
698         [0-9]|[0-9][0-9]|[0-4][0-9][0-9]|50[0-9]|51[0-1])
699                 for part in 0 1 2 3 4 5 6 7
700                 do
701                         minor=`dkminor 0 $unit 0 $part`
702                         partname=`dkitop $part`
703                         mknod  $name$unit$partname c $chr $minor root:operator
704                         rm -f r$name$unit$partname
705                 done
706                 ;;
707         *)
708                 echo bad unit for disk in: $i
709                 ;;
710         esac
711         umask 77
712         ;;
713
714 # SCSI processor type driver
715 pt[0-9]*)
716         chr=61
717         name=pt
718         unit=`expr $i : 'pt\([0-9][0-9]*\)'`
719         if [ -z "${unit}" ]; then
720                 unit=0
721         fi
722         unit=$(($unit + 1 - 1))
723         mknod ${name}${unit} c $chr `unit2minor $unit`
724         ;;
725
726 # SCSI SES/SAF-TE type driver
727 ses[0-9]*)
728         chr=110
729         name=ses
730         unit=`expr $i : 'ses\([0-9][0-9]*\)'`
731         if [ -z "${unit}" ]; then
732                 unit=0
733         fi
734         unit=$(($unit + 1 - 1))
735         mknod ${name}${unit} c $chr `unit2minor $unit`
736         ;;
737 # SCSI target mode sample driver
738 targ[0-9]*)
739         chr=65
740         name=targ
741         unit=`expr $i : 'targ\([0-9][0-9]*\)'`
742         if [ -z "${unit}" ]; then
743                 unit=0
744         fi
745         unit=$(($unit + 1 - 1))
746         mknod ${name}${unit} c $chr `unit2minor $unit`
747         mknod ${name}.ctl c $chr 0xffff00ff
748         ;;
749
750 # CAM transport layer device
751 xpt*)
752         # This major number is temporary
753         chr=104
754         name=xpt
755         units=`expr $i : 'xpt\(.*\)'`
756         if [ -z "${units}" ]; then
757                 units=1
758         fi
759         i=0
760         while [ $i -lt $units ]; do
761                 dname=$name$i
762                 rm -rf $dname
763                 mknod $dname c $chr `unit2minor $i` root:operator
764                 i=$(($i + 1))
765         done
766         ;;
767
768 # CAM passthrough device
769 pass*)
770         # This major number is temporary
771         chr=31
772         name=pass
773         units=`expr $i : 'pass\(.*\)'`
774         if [ -z "${units}" ]; then
775                 units=1
776         fi
777         i=0
778         while [ $i -lt $units ]; do
779                 dname=$name$i
780                 rm -rf $dname
781                 mknod $dname c $chr `unit2minor $i` root:operator
782                 i=$(($i + 1))
783         done
784         ;;
785 pty*)
786         class=`expr $i : 'pty\(.*\)'`
787         case $class in
788         0) offset=0 name=p;;
789         1) offset=32 name=q;;
790         2) offset=64 name=r;;
791         3) offset=96 name=s;;
792 # Note that xterm (at least) only look at p-s.
793         4) offset=128 name=P;;
794         5) offset=160 name=Q;;
795         6) offset=192 name=R;;
796         7) offset=224 name=S;;
797         # This still leaves [tuTU].
798         *) echo bad unit for pty in: $i;;
799         esac
800         umask 0
801         case $class in
802         0|1|2|3|4|5|6|7)
803                 i=0
804                 while [ $i -lt 32 ]; do
805 #                       This was an awk substr() before.
806                         c=$(echo 0123456789abcdefghijklmnopqrstuv |
807                             dd bs=1 skip=$i count=1 2>/dev/null)
808                         mknod tty$name$c c 5 $(($offset + $i))
809                         mknod pty$name$c c 6 $(($offset + $i))
810                         i=$(($i + 1))
811                 done
812                 ;;
813         esac
814         umask 77
815         ;;
816
817 sa*)
818         umask $tape_umask
819         unit=`expr $i : '..\(.*\)'`
820         chr=14
821
822         case $unit in
823         [0-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9])
824                 mknod sa${unit}.ctl c $chr `saminor 1 ${unit} 0 0`
825                 ln -f sa${unit}.ctl rsa${unit}.ctl
826                 for m in 0 1 2 3
827                 do
828                         mknod sa${unit}.${m} c $chr \
829                             `saminor 0 ${unit} ${m} 0`  root:operator
830                         ln -f sa${unit}.${m} rsa${unit}.${m}
831                         mknod nsa${unit}.${m} c $chr \
832                             `saminor 0 ${unit} ${m} 1` root:operator
833                         ln -f nsa${unit}.${m} nrsa${unit}.${m}
834                         mknod esa${unit}.${m} c $chr \
835                             `saminor 0 ${unit} ${m} 2` root:operator
836                         ln -f esa${unit}.${m} ersa${unit}.${m}
837                 done
838                 ln -f sa${unit}.0 sa${unit}
839                 ln -f sa${unit}.0 rsa${unit}.0
840                 ln -f sa${unit}.0 rsa${unit}
841                 ln -f nsa${unit}.0 nsa${unit}
842                 ln -f nsa${unit}.0 nrsa${unit}.0
843                 ln -f nsa${unit}.0 nrsa${unit}
844                 ln -f esa${unit}.0 esa${unit}
845                 ln -f esa${unit}.0 ersa${unit}.0
846                 ln -f esa${unit}.0 ersa${unit}
847                 ;;
848         *)
849                 echo bad unit for tape in: $i
850                 ;;
851         esac
852         umask 77
853         ;;
854
855 ch*)
856         umask 37
857         unit=`expr $i : '..\(.*\)'`
858         case $i in
859         ch*) name=ch;  chr=17;;
860         esac
861         case $unit in
862         0|1|2|3|4|5|6)
863                 mknod ${name}${unit}    c $chr $unit root:operator
864                 ;;
865         *)
866                 echo bad unit for media changer in: $i
867                 ;;
868         esac
869         umask 77
870         ;;
871
872 ata)
873         mknod ata c 159 0 root:operator
874         ;;
875 ast*)
876         umask 2 ;
877         unit=`expr $i : '...\(.*\)'`
878         chr=119
879         case $unit in
880         0|1|2|3)
881                 mknod ast${unit} c $chr $(($unit * 8 + 0)) root:operator
882                 chmod 640 ast${unit}
883                 mknod nast${unit} c $chr $(($unit * 8 + 1)) root:operator
884                 chmod 640 nast${unit}
885                 ;;
886         *)
887                 echo bad unit for tape in: $i
888                 ;;
889         esac
890         umask 77
891         ;;
892
893 acd*t*)
894         umask $disk_umask
895         units=`expr $i : '...\(.*\)t'`;
896         tracks=`expr $i : '.*t\(.*\)'`;
897         name=acd;
898         chr=117;
899         if [ -z "${units}" ]; then
900                 units=0
901         fi
902         if [ -z "${tracks}" ]; then
903                 tracks=100
904         fi
905         if [ "${units}" -le 31 -a "${tracks}" -le 169 ]; then
906                 i=0
907                 while [ $i -le $units ]; do
908                         dname=$name$i
909                         rm -rf ${dname}t*
910                         j=1
911                         while [ $j -le ${tracks} ]; do
912                                 mknod ${dname}t$j c $chr \
913                                         $((($i * 8) + (65536 * $j))) \
914                                         root:operator
915                                 j=$(($j + 1))
916                         done
917                         i=$(($i + 1))
918                 done
919         else
920                 echo "$i is invalid -- can't have more than 32 cd devices or 169 tracks"
921         fi
922         umask 77
923         ;;
924
925 acd*|cd*|mcd*|scd*)
926         umask $disk_umask
927         case $i in
928         acd*) units=`expr $i : '...\(.*\)'`; name=acd; chr=117;;
929         cd*) units=`expr $i : '..\(.*\)'`; name=cd; chr=15;;
930         mcd*) units=`expr $i : '...\(.*\)'`; name=mcd; chr=29;;
931         scd*) units=`expr $i : '...\(.*\)'`; name=scd; chr=45;;
932         esac
933         if [ -z "${units}" ]; then
934                 units=0
935         fi
936         if [ "${units}" -le 31 ]; then
937                 i=0
938                 while [ $i -le $units ]; do
939                         dname=$name$i
940                         rm -rf ${dname}*
941                         mknod ${dname}a c $chr $(($i * 8)) root:operator
942                         case $name in 
943                         acd)
944                                 ln -f ${dname}a ${dname}c;;
945                         *)
946                                 mknod ${dname}c c $chr $(($i * 8 + 2)) root:operator;;
947                         esac
948                         rm -f r${dname}a
949                         rm -f r${dname}c
950                         i=$(($i + 1))
951                 done
952         else
953                 echo "$i is invalid -- can't have more than 32 cd devices"
954         fi
955         umask 77
956         ;;
957
958 wcd*)
959         umask 2 ;
960         unit=`expr $i : '...\(.*\)'`
961         chr=69
962         case $unit in
963         0|1|2|3|4|5|6|7)
964                 mknod wcd${unit}a  c $chr $(($unit * 8 + 0)) root:operator
965                 mknod wcd${unit}c  c $chr $(($unit * 8 + 2)) root:operator
966                 ln -f wcd${unit}a rwcd${unit}a
967                 ln -f wcd${unit}c rwcd${unit}c
968                 chmod 640 wcd${unit}[a-h] rwcd${unit}[a-h]
969                 ;;
970         *)
971                 echo bad unit for disk in: $i
972                 ;;
973         esac
974         umask 77
975         ;;
976
977 wst*)
978         umask 2 ;
979         unit=`expr $i : '...\(.*\)'`
980         chr=90
981         case $unit in
982         0|1|2|3)
983                 mknod rwst${unit} c $chr $(($unit * 8 + 0)) root:operator
984                 chmod 640 rwst${unit}
985                 ;;
986         esac
987         umask 77
988         ;;
989
990 iic*)
991         unit=`expr $i : 'iic\(.*\)'`
992         mknod iic$unit c 105 `unit2minor $unit`
993         ;;
994
995 smb*)
996         unit=`expr $i : 'smb\(.*\)'`
997         mknod smb$unit c 106 `unit2minor $unit`
998         ;;
999
1000 pcfclock*)
1001         unit=`expr $i : 'pcfclock\(.*\)'`
1002         mknod pcfclock$unit c 140 `unit2minor $unit`
1003         ;;
1004
1005 ppi*)
1006         unit=`expr $i : 'ppi\(.*\)'`
1007         mknod ppi$unit c 82 `unit2minor $unit`
1008         ;;
1009
1010 pps*)
1011         unit=`expr $i : 'pps\(.*\)'`
1012         mknod pps$unit c 89 `unit2minor $unit`
1013         ;;
1014
1015 usb)
1016         mknod usb c 108 255 root:operator
1017         chmod 0660 usb
1018         ;;
1019
1020 usb*)
1021         umask 7
1022         unit=`expr $i : 'usb\(.*\)'`
1023         mknod usb$unit c 108 `unit2minor $unit` root:operator
1024         umask 77
1025         ;;
1026
1027 ucom*)
1028         umask 7
1029         unit=`expr $i : 'ucom\(.*\)'`
1030         minor=$(($unit + 128))
1031         minor=`unit2minor $(($unit + 128))`
1032         mknod ucom$unit c 138 $minor uucp:dialer
1033         umask 77
1034         ;;
1035
1036 uhid*)
1037         umask 7
1038         unit=`expr $i : 'uhid\(.*\)'`
1039         mknod uhid$unit c 122 `unit2minor $unit` root:operator
1040         umask 77
1041         ;;
1042
1043 ums*)
1044         umask 7
1045         unit=`expr $i : 'ums\(.*\)'`
1046         mknod ums$unit c 111 `unit2minor $unit` root:operator
1047         umask 77
1048         ;;
1049
1050 ulpt*)
1051         unit=`expr $i : 'ulpt\(.*\)'`
1052         minor=`unit2minor $unit`
1053         mknod ulpt$unit c 113 $minor
1054         minor=`unit2minor $(($unit + 64))`
1055         mknod unlpt$unit c 113 $minor           # and the 'no prime' version
1056         ;;
1057
1058 ugen*)
1059         umask 7
1060         unit=`expr $i : 'ugen\([0-9][0-9]*\)'`
1061         endpoint=`expr $i : 'ugen.*\.\([0-9][0-9]*\)'`
1062         if [ -z "${unit}" ]; then
1063                 echo $i - Invalid unit number
1064         fi
1065         if [ -z "${endpoint}" ]; then           # ugen0 & ugen0.1 - ugen0.15
1066                 mknod ugen$unit c 114 \
1067                                 `unit2minor $(($unit * 16))` root:operator
1068                 i=1
1069                 while [ $i -lt 16 ]; do
1070                         mknod ugen$unit.$i c 114 \
1071                                 `unit2minor $(($unit * 16 + $i))` root:operator
1072                         i=$(($i + 1))
1073                 done
1074         else
1075                 minor=`unit2minor $(($unit * 16 + $endpoint))`
1076                 mknod ugen$unit.$endpoint c 114 $minor root:operator
1077         fi
1078         umask 77
1079         ;;
1080
1081 urio*)
1082         umask 7
1083         unit=`expr $i : 'urio\(.*\)'`
1084         mknod urio$unit c 143 `unit2minor $unit` root:operator
1085         umask 77
1086         ;;
1087
1088 uscanner*)
1089         umask 7
1090         unit=`expr $i : 'uscanner\(.*\)'`
1091         mknod uscanner$unit c 156 `unit2minor $unit` root:operator
1092         umask 77
1093         ;;
1094
1095 umodem*)
1096         umask 7
1097         unit=`expr $i : 'umodem\(.*\)'`
1098         mknod umodem$unit c 124 `unit2minor $unit` uucp:dialer
1099         umask 77
1100         ;;
1101
1102 lpt*)
1103         unit=`expr $i : 'lpt\(.*\)'`
1104         mknod lpt$unit c 16 `unit2minor $unit`
1105         mknod lpctl$unit c 16 `unit2minor $(($unit + 128))`
1106         ;;
1107
1108 # Use this to create virtual consoles for syscons, pcvt or codrv
1109 # ttyv0-b
1110 # use as MAKEDEV vtyNN to create NN entries
1111 vty*)
1112         chr=12
1113         units=`expr $i : 'vty\(.*\)'`
1114         i=0
1115         while [ $i -lt $units ]; do
1116                 mknod ttyv$(printf %01x $i) c $chr `unit2minor $i`
1117                 i=$(($i + 1))
1118         done
1119         ln -fs ttyv0 vga        # XXX X still needs this pccons relic
1120         ;;
1121
1122 nmdm*)
1123         units=`expr $i : 'nmdm\(.*\)'`
1124         chr=18
1125         i=0
1126         while [ $i -lt $units ]; do
1127                 minor=`unit2minor $i`
1128                 minor=$(($minor + $minor))
1129                 mknod nmdm${i}A c $chr $minor
1130                 mknod nmdm${i}B c $chr $(($minor + 1))
1131                 i=$(($i + 1))
1132         done
1133         ;;
1134
1135 bpf*)
1136         nbpf=`expr $i : 'bpf\(.*\)$'`
1137         unit=0
1138         while [ $unit -le $nbpf ]; do
1139                 mknod bpf$unit c 23 `unit2minor $unit`
1140                 unit=$(($unit + 1))
1141         done
1142         ;;
1143
1144 speaker)
1145         mknod speaker c 26 0
1146         ;;
1147
1148 cua?|cuaa?|cuaa??)
1149         umask 7
1150         unit_low=`expr $i : 'cua.*\(.\)$'`
1151         case $i in
1152         cua?|cuaa?)
1153                 unit_high=""
1154                 m_high=0
1155                 ;;
1156         cuaa??)
1157                 unit_high=`expr $i : 'cuaa\(.\).$'`
1158                 m_high=`ttyminor $unit_high`
1159                 ;;
1160         esac
1161         unit=$unit_high$unit_low
1162         m=$(($m_high << 16 | `ttyminor $unit_low`))
1163         mknod cuaa$unit c 28 $(($m | 128)) uucp:dialer
1164         mknod cuaia$unit c 28 $(($m | 32 | 128)) uucp:dialer
1165         mknod cuala$unit c 28 $(($m | 64 | 128)) uucp:dialer
1166         umask 77
1167         ;;
1168
1169 crypto)
1170         mknod crypto c 70 0 root:operator
1171         chmod 666 crypto
1172         ;;
1173 pf)
1174         mknod pf c 73 0 root:operator
1175         chmod 600 pf
1176         ;;
1177 fw?)
1178         unit=`expr $i : 'fw\(.\)$'`
1179         for sub in 0 1 2 3
1180         do
1181                 minor=$(($unit << 16 | $sub))
1182                 mknod fw$unit.$sub c 127 $minor root:operator
1183                 chmod 660 fw$unit.$sub
1184                 mknod fwmem$unit.$sub c 127 $((1<<24 | $minor)) root:operator
1185                 chmod 660 fwmem$unit.$sub
1186         done
1187         ln -sf fw$unit.0 fw$unit
1188         ln -sf fwmem$unit.0 fwmem$unit
1189         ;;
1190
1191 dcons)
1192         mknod dcons c 184 0 root:wheel
1193         chmod 600 dcons
1194         ;;
1195
1196 tty?|tty0?|ttyd?|ttyd??)
1197         unit_low=`expr $i : 'tty.*\(.\)$'`
1198         case $i in
1199         tty?|tty0?|ttyd?)
1200                 unit_high=""
1201                 m_high=0
1202                 ;;
1203         ttyd??)
1204                 unit_high=`expr $i : 'ttyd\(.\).$'`
1205                 m_high=`ttyminor $unit_high`
1206                 ;;
1207         esac
1208         unit=$unit_high$unit_low
1209         m=$(($m_high << 16 | `ttyminor $unit_low`))
1210         mknod ttyd$unit c 28 $m
1211         mknod ttyid$unit c 28 $(($m | 32))
1212         mknod ttyld$unit c 28 $(($m | 64))
1213         ;;
1214
1215 cuac?)
1216         umask 7
1217         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f
1218                   g h i j k l m n o p q r s t u v"
1219         major=48
1220         card=`expr $i : 'cua.*\(.\)$'`
1221         for unit in $portlist
1222         do
1223                 minor=`ttyminor $unit`
1224                 minor=$(($card * 65536 + $minor))
1225                 name=$card$unit
1226                 mknod cuac$name c $major $(($minor + 128)) uucp:dialer
1227                 mknod cuaic$name c $major $(($minor + 32 + 128)) uucp:dialer
1228                 mknod cualc$name c $major $(($minor + 64 + 128)) uucp:dialer
1229         done
1230         umask 77
1231         ;;
1232
1233 ttyc?)
1234         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f
1235                   g h i j k l m n o p q r s t u v"
1236         major=48
1237         card=`expr $i : 'tty.*\(.\)$'`
1238         for unit in $portlist
1239         do
1240                 minor=`ttyminor $unit`
1241                 minor=$(($card * 65536 + $minor))
1242                 name=$card$unit
1243                 mknod ttyc$name c $major $minor
1244                 mknod ttyic$name c $major $(($minor + 32))
1245                 mknod ttylc$name c $major $(($minor + 64))
1246         done
1247         ;;
1248
1249 # RISCom8 'rc' driver entries
1250
1251 cuam?)
1252         umask 7
1253         unit=`expr $i : 'cua.*\(.\)$'`
1254         m=`ttyminor $unit`
1255         mknod cuam$unit c 63 $(($m + 128)) uucp:dialer
1256         umask 77
1257         ;;
1258
1259 ttym?)
1260         unit=`expr $i : 'tty.*\(.\)$'`
1261         m=`ttyminor $unit`
1262         mknod ttym$unit c 63 $m
1263         ;;
1264
1265 # Specialix SI/XIO.
1266 # Note: these are 'base 1' to match the numbers on the panels, and to match
1267 #       the manual that comes with the system.
1268 ttyA*)
1269         major=68
1270         nports=`expr $i : 'ttyA\(.*\)$'`
1271         port=1
1272         while [ $port -le $nports ]; do
1273                 minor=$(($port - 1))
1274                 name=$(printf %02d $port)
1275                 mknod ttyA$name c $major $minor
1276                 mknod ttyiA$name c $major $(($minor + 65536))
1277                 mknod ttylA$name c $major $(($minor + 131072))
1278                 port=$(($port + 1))
1279         done
1280         # For the user-mode control program, 'sicontrol'
1281         mknod si_control c 68 262144
1282         ;;
1283
1284 cuaA*)
1285         umask 7
1286         major=68
1287         nports=`expr $i : 'cuaA\(.*\)$'`
1288         port=1
1289         while [ $port -le $nports ]; do
1290                 minor=$(($port - 1))
1291                 name=$(printf %02d $port)
1292                 mknod cuaA$name c $major $(($minor + 128)) uucp:dialer
1293                 mknod cuaiA$name c $major $(($minor + 128 + 65536)) \
1294                     uucp:dialer
1295                 mknod cualA$name c $major $(($minor + 128 + 131072)) \
1296                     uucp:dialer
1297                 port=$(($port + 1))
1298         done
1299         umask 77
1300         ;;
1301
1302 # Alpha AS8[24]00 (TurboLaser) console.
1303 zs?)
1304         unit=`expr $i : 'zs.*\(.\)$'`
1305         m=`ttyminor $unit`
1306         mknod zs$unit c 135 $m
1307         ;;
1308
1309 # Digiboard PC/?? 16 port card.
1310 # The current scheme of minor numbering is:
1311 #
1312 #       unused{14} CARD{2} major{8} CALLOUT{1} LOCK{1} INIT{1} PORT{5}
1313 #
1314 #   CARD bitfield in future versions may be extended to 3 bits.
1315 #
1316 # See dgb(4)
1317 #
1318 ttyD?)
1319         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
1320         major=58
1321         card=`expr $i : 'tty.*\(.\)$'`
1322         for unit in $portlist
1323         do
1324                 minor=`ttyminor $unit`
1325                 minor=$(($card * 65536 + $minor))
1326                 name=$card$unit
1327                 mknod ttyD$name c $major $minor
1328                 mknod ttyiD$name c $major $(($minor + 32))
1329                 mknod ttylD$name c $major $(($minor + 64))
1330         done
1331         ;;
1332
1333 cuaD?)
1334         umask 7
1335         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
1336         major=58
1337         card=`expr $i : 'cua.*\(.\)$'`
1338         for unit in $portlist
1339         do
1340                 minor=`ttyminor $unit`
1341                 minor=$(($card * 65536 + $minor))
1342                 name=$card$unit
1343                 mknod cuaD$name c $major $(($minor + 128)) uucp:dialer
1344                 mknod cuaiD$name c $major $(($minor + 32 + 128)) uucp:dialer
1345                 mknod cualD$name c $major $(($minor + 64 + 128)) uucp:dialer
1346         done
1347         umask 77
1348         ;;
1349
1350 # Stallion multi serial cards (stl and stli drivers)
1351
1352 # These drivers reserve 64 minor devices per board, even if the board
1353 # supports only 4 devices.  We default to creating only 8 of the 64 devices
1354 # to keep /dev from getting too large (which => slow).  The last part of the
1355 # arg is the board number to create ports for.  So:
1356 #       ttyE0 will create 8 dialin ports ttyE0-ttyE7, plus ttyiE* and ttylE*
1357 #       cuaE0 will create 8 dialout ports cuaE0-cuaE7, plus cuaiE* and cualE*
1358 #       ttyE1 will create 8 dialin ports ttyE64-ttyE71, plus ttyiE* and ttylE*
1359 #       etc
1360 # If you have EasyConnect 8/32 or 8/64 cards, you will need to change the 
1361 # definition of "maxport" below to get nodes for the full 32 or 64 
1362 # ports per card.
1363 #
1364 # Note that the mapping of minor device numbers (with the hole between
1365 # 32-64k) is a bit odd to keep compatibility with ttyd? for
1366 # lock/initial devices.  
1367 # Minor device field for the ports is
1368 #       card{3} unused{4} unit-msb{1} unused{8} callout{1} lock{1} init{1} unit-lsbs{5}
1369 # for the mem device is
1370 #       0x1000000 + card
1371 # (For stl, there is only 1 mem device per system; for stli, one per board)
1372
1373 ttyE*)
1374         stallion 72 E `expr $i : 'tty.*\(.\)$'` 0
1375         ;;
1376 cuaE*)
1377         stallion 72 E `expr $i : 'cua.*\(.\)$'` 1
1378         ;;
1379 stl*)
1380         card=`expr $i : 'stl\(.\)$'`
1381         stallion 72 E $card 0
1382         stallion 72 E $card 1
1383         ;;
1384
1385 ttyF*)
1386         stallion 75 F `expr $i : 'tty.*\(.\)$'` 0
1387         ;;
1388 cuaF*)
1389         stallion 75 F `expr $i : 'cua.*\(.\)$'` 1
1390         ;;
1391 stli*)
1392         card=`expr $i : 'stl\(.\)$'`
1393         stallion 75 F $card 0
1394         stallion 75 F $card 1
1395         ;;
1396
1397 ttyM*)
1398         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
1399         modulelist="a b c d"
1400         major=101
1401         card=`expr $i : 'tty.*\(.\)$'`
1402         for unit in $modulelist
1403         do
1404                 moduleminor=`ttyminor $unit`
1405                 moduleminor=$(($moduleminor % 10 * 16))
1406                 modulename=$unit
1407
1408                 for unit in $portlist
1409                 do
1410                         minor=`ttyminor $unit`
1411                         minor=$(($card * 65536 + $minor + $moduleminor))
1412                         name=$card$modulename$unit
1413                         rm -f tty*M$name
1414                         mknod ttyM$name c $major $minor
1415                         mknod ttyiM$name c $major $(($minor + 64))
1416                         mknod ttylM$name c $major $(($minor + 128))
1417                 done
1418         done
1419         ;;
1420
1421 cuaM?)
1422         umask 7
1423         portlist="0 1 2 3 4 5 6 7 8 9 a b c d e f"
1424         modulelist="a b c d"
1425         major=101
1426         card=`expr $i : 'cua.*\(.\)$'`
1427         for unit in $modulelist
1428         do
1429                 moduleminor=`ttyminor $unit`
1430                 moduleminor=$(($moduleminor % 10 * 16))
1431                 modulename=$unit
1432
1433                 for unit in $portlist
1434                 do
1435                         minor=`ttyminor $unit`
1436                         minor=$(($card * 65536 + $minor + $moduleminor))
1437                         name=$card$modulename$unit
1438                         rm -f cua*M$name
1439                         mknod cuaM$name c $major $(($minor + 262144)) \
1440                             uucp:dialer
1441                         mknod cuaiM$name c $major $(($minor + 64 + 262144)) \
1442                             uucp:dialer
1443                         mknod cualM$name c $major $(($minor + 128 + 262144)) \
1444                             uucp:dialer
1445                 done
1446         done
1447         umask 77
1448         ;;
1449
1450 ttyR?)
1451         major=81
1452         BOARD=1; Rnum=0
1453         MINOR=$(($BOARD * 65536))
1454         controllers=$(
1455                 dmesg | while read first rest; do
1456                         case "$first" in
1457                         RocketPort[0-4])
1458                                 echo "$first"
1459                                 ;;
1460                         esac
1461                 done
1462         )
1463         rm -f ttyR* ttyiR* ttylR*
1464         for i in $controllers; do
1465            ndevices=$(
1466                 dmesg | while read first bar ports rest; do
1467                         case "$first" in
1468                         $i*)
1469                                 echo "$ports"
1470                                 ;;
1471                         esac
1472                 done
1473            )
1474            echo -n "Creating $ndevices devices for $i: "
1475            dev=0
1476            while [ $dev -lt $ndevices ]; do
1477                    mknod ttyR$Rnum c $major $MINOR
1478                    mknod ttyiR$Rnum c $major $(($MINOR + 32))
1479                    mknod ttylR$Rnum c $major $(($MINOR + 64))
1480                    Rnum=$(($Rnum + 1))
1481                    MINOR=$(($MINOR + 1))
1482                    dev=$(($dev + 1))
1483            done
1484                 BOARD=$(($BOARD + 1))
1485                 MINOR=$(($BOARD * 65536))
1486            echo " "
1487         done
1488         ;;
1489
1490 cuaR?)
1491         major=81
1492         BOARD=1; Rnum=0
1493         MINOR=$(($BOARD * 65536))
1494         controllers=$(
1495                 dmesg | while read first rest; do
1496                         case "$first" in
1497                         RocketPort[0-4])
1498                                 echo "$first"
1499                                 ;;
1500                         esac
1501                 done
1502         )
1503         rm -f cuaR* cuaiR* cualR*
1504         for i in $controllers; do
1505            ndevices=$(
1506                 dmesg | while read first bar ports rest; do
1507                         case "$first" in
1508                         $i*)
1509                                 echo "$ports"
1510                                 ;;
1511                         esac
1512                 done
1513            )
1514            echo -n "Creating $ndevices devices for $i: "
1515            dev=0
1516            while [ $dev -lt $ndevices ]; do
1517                    mknod cuaR$Rnum c  $major $(($MINOR + 128)) uucp:dialer
1518                    mknod cuaiR$Rnum c $major $(($MINOR + 128 + 32)) \
1519                        uucp:dialer
1520                    mknod cualR$Rnum c $major $(($MINOR + 128 + 64)) \
1521                        uucp:dialer
1522                    Rnum=$(($Rnum + 1))
1523                    MINOR=$(($MINOR + 1))
1524                    dev=$(($dev + 1))
1525            done
1526                 BOARD=$(($BOARD + 1))
1527                 MINOR=$(($BOARD * 65536))
1528            echo " "
1529         done
1530         ;;
1531
1532 mse*)
1533         unit=`expr $i : 'mse\(.*\)'`
1534         chr=27
1535         # non-blocking for X11
1536         mknod mse$unit c $chr `unit2minor $(($unit * 2 + 1))`
1537         ;;
1538
1539 psm*)
1540         unit=`expr $i : 'psm\(.*\)'`
1541         chr=21
1542         # non-blocking for X11
1543         mknod psm$unit c $chr `unit2minor $(($unit * 2 + 1))`
1544         ;;
1545
1546 mouse*)
1547         name=`expr $i : 'mouse\(.*\)'`
1548         if [ ! -c $name ]; then
1549                 $0 $name                        # make the appropriate device
1550         fi
1551         ln -fs $name mouse
1552         ;;
1553
1554 pcaudio)
1555         mknod pcaudio c 24 0
1556         mknod pcaudioctl c 24 128
1557         ;;
1558
1559 socksys)
1560         mknod socksys c 41 0
1561         mknod spx c 41 1
1562         ln -fs socksys nfsd
1563         chmod 666 socksys nfsd spx
1564         ;;
1565
1566 snd*)
1567 #
1568 # changes from Linux voxware
1569 # minor         Linux                   FreeBSD
1570 # 8             sequencer2 (aka music0) music0
1571 # 17            patmgr0                 sequencer1
1572 # 33            patmgr1                 sequencer2
1573 #
1574
1575         unit=`expr $i : 'snd\(.*\)'`
1576         chr=30
1577
1578         # XXX write this less verbosely, like std
1579         snd_security_hole=0     # XXX
1580         umask $snd_security_hole
1581
1582         ln -fs mixer$unit mixer
1583         ln -fs sequencer$unit sequencer
1584         ln -fs dsp$unit dsp
1585         ln -fs audio$unit audio
1586         ln -fs dspW$unit dspW
1587         ln -fs music$unit music
1588         ln -fs pss$unit pss
1589         ln -fs dsp$unit.0 dsp$unit
1590         ln -fs audio$unit.0 audio$unit
1591         ln -fs dspW$unit.0 dspW$unit
1592
1593         mknod mixer$unit        c $chr `unit2minor $(($unit * 16 + 0))`
1594         mknod sequencer$unit    c $chr `unit2minor $(($unit * 16 + 1))`
1595         mknod midi$unit         c $chr `unit2minor $(($unit * 16 + 2))`
1596
1597         for chn in 0 1 2 3
1598         do
1599                 minor=$(($chn * 65536 + $unit * 16))
1600                 mknod dsp$unit.$chn     c $chr $(($minor + 3))
1601                 mknod audio$unit.$chn   c $chr $(($minor + 4))
1602                 mknod dspW$unit.$chn    c $chr $(($minor + 5))
1603         done
1604
1605         mknod sndstat           c $chr 6
1606                                 # minor number 7 is unused
1607         mknod music$unit        c $chr `unit2minor $(($unit * 16 + 8))`
1608         mknod pss$unit          c $chr `unit2minor $(($unit * 16 + 9))`
1609                                 # minor numbers 10-15 are unused
1610         umask 77
1611         ;;
1612
1613 vat)
1614         mknod vatio c 25 128
1615         chmod 660 vatio
1616         ;;
1617
1618 gsc*)
1619         unit=`expr $i : 'gsc\(.*\)'`
1620         mknod gsc${unit} c 47 `unit2minor $unit`
1621         mknod gsc${unit}p c 47 `unit2minor $(($unit + 8))`
1622         mknod gsc${unit}d c 47 `unit2minor $(($unit + 32))`
1623         mknod gsc${unit}pd c 47 `unit2minor $(($unit + 40))`
1624         chmod 666 gsc${unit}*
1625         ;;
1626
1627 acpi)
1628         mknod acpi c 152 0 root:operator
1629         chmod 664 acpi
1630         ;;
1631 apm)
1632         mknod apm c 39 0 root:operator
1633         chmod 664 apm
1634         ;;
1635
1636 apmctl)
1637         mknod apmctl c 39 8 root:operator
1638         chmod 660 apmctl
1639         ;;
1640
1641 card*)
1642         unit=`expr $i : 'card\(.*\)'`
1643         chr=50
1644         mknod card$unit c $chr `unit2minor $unit`
1645         chmod 644 card$unit
1646         ;;
1647
1648 ttyx?|ttyy?|ttyz?)
1649         case $i in
1650         *0) unit=0;;    *1) unit=1;;    *2) unit=2;;    *3) unit=3;;
1651         *4) unit=4;;    *5) unit=5;;    *6) unit=6;;    *7) unit=7;;
1652         *8) unit=8;;    *9) unit=9;;    *a) unit=10;;   *b) unit=11;;
1653         *c) unit=12;;   *d) unit=13;;   *e) unit=14;;   *f) unit=15;;
1654         esac
1655         case $i in
1656         ttyy?)  unit=$(($unit + 16));;
1657         ttyz?)  unit=$(($unit + 32));;
1658         esac
1659         mknod $i c 42 $unit
1660         ;;
1661
1662 cronyx)
1663         mknod cronyx c 42 63
1664         ;;
1665
1666 joy)
1667         mknod joy0 c 51 0 root:operator
1668         mknod joy1 c 51 1 root:operator
1669         chmod 640  joy0 joy1
1670         ;;
1671
1672 spigot)
1673         mknod spigot c 11 0
1674         chmod 444 spigot
1675         ;;
1676
1677 ctx?)
1678         unit=`expr $i : 'ctx\(.*\)'`
1679         mknod ctx$unit c 40 `unit2minor $unit`
1680         chmod 444 ctx$unit
1681         ;;
1682
1683 meteor?)
1684         unit=`expr $i : 'meteor\(.*\)'`
1685         mknod meteor$unit c 67 `unit2minor $unit`
1686         chmod 444 meteor$unit
1687         ;;
1688
1689 bktr?)
1690         unit=`expr $i : 'bktr\(.*\)'`
1691         mknod bktr$unit c 92 `unit2minor $unit`
1692         mknod tuner$unit c 92 `unit2minor $((16 + $unit))`
1693         mknod vbi$unit c 92 `unit2minor $((32 + $unit))`
1694         chmod 444 bktr$unit tuner$unit vbi$unit
1695         ;;
1696
1697 tun*)
1698         ntun=`expr $i : 'tun\(.*\)$'`
1699         unit=0
1700         while [ $unit -le $ntun ]; do
1701                 mknod tun$unit c 52 `unit2minor $unit`
1702                 unit=$(($unit + 1))
1703         done
1704         ;;
1705
1706 tap*)
1707         ntap=`expr $i : 'tap\(.*\)$'`
1708         unit=0
1709         while [ $unit -le $ntap ]; do
1710                 mknod tap$unit c 149 `unit2minor $unit` root:network
1711                 unit=$(($unit + 1))
1712         done
1713         ;;
1714
1715 sysmouse)
1716         mknod sysmouse c 12 128
1717         mknod consolectl c 12 255
1718         ;;
1719
1720 jogdial)
1721         mknod jogdial c 160 0
1722         ;;
1723
1724 snp?)
1725         unit=`expr $i : 'snp\(.*\)'`
1726         mknod snp$unit c 53 `unit2minor $unit`
1727         ;;
1728
1729 # dufault@hda.com: If I do much more work on other A-D boards
1730 # then eventually we'll have a "ad" and "dio" interface and some of these
1731 # "labpcaio" ones will be gone.
1732 # labpcaio: D-A and A-D.
1733 # labpcdio: Digital in and Digital out.
1734 #
1735 labpc*)
1736         umask 7
1737         case $i in
1738         labpcaio*)
1739                 name=labpcaio
1740                 unit=`expr $i : 'labpcaio\(.*\)'`
1741                 all="0 1 2 3 4 5 6 7"
1742                 offset=0
1743                 ;;
1744         labpcdio*)
1745                 name=labpcdio
1746                 unit=`expr $i : 'labpcdio\(.*\)'`
1747                 all="0 1 2 3"
1748                 offset=8
1749                 ;;
1750         *)
1751                 die 3 "Don't know LabPC type $i"
1752                 ;;
1753         esac
1754         if [ -z "${unit}" ]; then
1755                 unit=all
1756         fi
1757         case $unit in
1758                 0|1|2|3|4|5|6|7)
1759                                 mknod $name$unit c 66 $(($offset + $unit))
1760                 ;;
1761                 all)
1762                         for i in $all
1763                         do
1764                                 mknod $name$i c 66 $(($offset + $i))
1765                         done
1766                         ;;
1767                 *)
1768                         echo "No such LabPC unit: $unit"
1769                         ;;
1770         esac
1771         umask 77
1772         ;;
1773
1774 perfmon)
1775         mknod perfmon c 2 32 root:kmem
1776         chmod 640 perfmon
1777         ;;
1778
1779 ipl)
1780         mknod ipl c 79 0
1781         mknod ipnat c 79 1
1782         mknod ipstate c 79 2
1783         mknod ipauth c 79 3
1784         ;;
1785
1786 elan*)
1787         mknod elan-mmcr c 100 0 # XXX local major
1788         chmod 600 elan-mmcr
1789         ;;
1790
1791 kbd*)
1792         unit=`expr $i : 'kbd\(.*\)'`
1793         chr=112
1794         mknod kbd$unit c $chr `unit2minor $unit`
1795         ;;
1796
1797 i4b)
1798         mknod i4b c 60 0
1799         ;;
1800
1801 i4bctl)
1802         mknod i4bctl c 55 0
1803         ;;
1804
1805 i4brbch*)
1806         unit=`expr $i : 'i4brbch\(.*\)'`
1807         mknod i4brbch$unit c 57 `unit2minor $unit`
1808         ;;
1809
1810 i4bteld*)
1811         offset=64
1812         unit=`expr $i : 'i4bteld\(.*\)'`
1813         mknod i4bteld$unit c 56 `unit2minor $(($offset + $unit))`
1814         ;;
1815
1816 i4btel*)
1817         unit=`expr $i : 'i4btel\(.*\)'`
1818         mknod i4btel$unit c 56 `unit2minor $unit`
1819         ;;
1820
1821 i4btrc*)
1822         unit=`expr $i : 'i4btrc\(.*\)'`
1823         mknod i4btrc$unit c 59 `unit2minor $unit`
1824         ;;
1825
1826 aac*)
1827         unit=`expr $i : 'aac\(.*\)'`
1828         mknod aac$unit c 150 `unit2minor $unit`
1829         ln -fs aac$unit afa$unit
1830         ln -fs aac$unit hpn$unit
1831         ;;
1832
1833 mlx*)
1834         unit=`expr $i : 'mlx\(.*\)'`
1835         mknod mlx$unit c 130 `unit2minor $unit`
1836         ;;
1837
1838 amr*)
1839         unit=`expr $i : 'amr\(.*\)'`
1840         mknod amr$unit c 132 `unit2minor $unit`
1841         ;;
1842
1843 ips*)
1844         unit=`expr $i : 'ips\(.*\)'`
1845         mknod mlx$unit c 175 `unit2minor $unit`
1846         ;;
1847
1848 ciss*)
1849         unit=`expr $i : 'ciss\(.*\)'`
1850         mknod ciss$unit c 166 `unit2minor $unit`
1851         ;;
1852
1853 agpgart)
1854         mknod agpgart c 148 0
1855         ;;
1856
1857 twe*)
1858         unit=`expr $i : 'twe\(.*\)'`
1859         mknod twe$unit c 146 `unit2minor $unit`
1860         ;;
1861
1862 tw*)
1863         unit=`expr $i : 'tw\(.*\)'`
1864         mknod tw$unit c 19 `unit2minor $unit` root:operator
1865         ;;
1866
1867 cfs*)
1868         unit=`expr $i : 'cfs\(.*\)'`
1869         mknod cfs$unit c 93 $unit root:operator
1870         ;;
1871
1872 nsmb*)
1873         unit=`expr $i : 'nsmb\(.*\)'`
1874         mknod nsmb$unit c 144 $unit
1875         ;;
1876
1877 local)
1878         umask 0                 # XXX should be elsewhere
1879         sh MAKEDEV.local
1880         umask 77
1881         ;;
1882
1883 *)
1884         echo $i - no such device name
1885         ;;
1886
1887 esac
1888 done