home *** CD-ROM | disk | FTP | other *** search
/ Source Code 1994 March / Source_Code_CD-ROM_Walnut_Creek_March_1994.iso / unix_c / kernel / dev_fd.tar < prev    next >
Tape Archive  |  1989-02-26  |  24.0 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was processed as: Tape Archive (archive/tar).

You can browse this item here: dev_fd.tar

ConfidenceProgramDetectionMatch TypeSupport
100% dexvert Tape Archive (archive/tar) magic Supported
100% file tar archive default
99% file tar archive (V7), file dev-fd/, mode 755 , uid 243 , gid 12 , size 0 , seconds 4402110541 default
98% file data default
100% TrID Sybase iAnywhere database files default (weak)
100% lsar Tar default
100% gt2 TAR Archiv gefunden (Auflistung ist deaktiviert) default
100% disktype Pre-POSIX tar archive default



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 64 65 76 2d 66 64 2f 00 | 00 00 00 00 00 00 00 00 |dev-fd/.|........|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000050| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000060| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00000070| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00000080| 20 20 20 20 20 20 30 20 | 20 34 34 30 32 31 31 30 | 0 | 4402110|
|00000090| 35 34 31 20 20 20 35 31 | 35 30 00 20 00 00 00 00 |541 51|50. ....|
|000000a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000000b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000000c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000000d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000000e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000000f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000100| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000110| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000120| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000130| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000140| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000150| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000160| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000170| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000180| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000190| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000001f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000200| 64 65 76 2d 66 64 2f 52 | 45 41 44 4d 45 2d 46 49 |dev-fd/R|EADME-FI|
|00000210| 52 53 54 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |RST.....|........|
|00000220| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000230| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000240| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000250| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000260| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00000270| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00000280| 20 20 20 33 37 37 35 20 | 20 34 34 30 32 31 31 30 | 3775 | 4402110|
|00000290| 35 33 32 20 20 20 37 30 | 32 31 00 20 00 00 00 00 |532 70|21. ....|
|000002a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000002b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000002c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000002d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000002e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000002f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000300| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000310| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000320| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000330| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000340| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000350| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000360| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000370| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000380| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000390| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000003f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000400| 52 45 41 44 4d 45 2d 46 | 49 52 53 54 0a 0a 09 54 |README-F|IRST...T|
|00000410| 68 65 20 66 69 6c 65 73 | 20 69 6e 20 74 68 69 73 |he files| in this|
|00000420| 20 64 69 72 65 63 74 6f | 72 79 20 63 6f 6e 74 61 | directo|ry conta|
|00000430| 69 6e 20 74 68 65 20 73 | 6f 75 72 63 65 20 63 6f |in the s|ource co|
|00000440| 64 65 20 66 6f 72 20 74 | 68 65 20 22 66 64 22 0a |de for t|he "fd".|
|00000450| 70 73 65 75 64 6f 2d 64 | 65 76 69 63 65 20 64 72 |pseudo-d|evice dr|
|00000460| 69 76 65 72 20 66 6f 72 | 20 34 2e 5b 32 33 5d 20 |iver for| 4.[23] |
|00000470| 42 53 44 20 55 6e 69 78 | 2e 20 54 68 65 20 69 64 |BSD Unix|. The id|
|00000480| 65 61 20 6f 72 69 67 69 | 6e 61 74 65 64 20 77 69 |ea origi|nated wi|
|00000490| 74 68 20 74 68 65 20 45 | 69 67 68 74 68 0a 45 64 |th the E|ighth.Ed|
|000004a0| 69 74 69 6f 6e 20 52 65 | 73 65 61 72 63 68 20 55 |ition Re|search U|
|000004b0| 6e 69 78 20 73 79 73 74 | 65 6d 2e 0a 09 54 68 65 |nix syst|em...The|
|000004c0| 20 6f 72 69 67 69 6e 61 | 6c 20 76 65 72 73 69 6f | origina|l versio|
|000004d0| 6e 20 66 6f 72 20 42 53 | 44 20 55 6e 69 78 20 77 |n for BS|D Unix w|
|000004e0| 61 73 20 64 6f 6e 65 20 | 62 79 20 46 72 65 64 20 |as done |by Fred |
|000004f0| 42 6c 6f 6e 64 65 72 20 | 61 74 20 74 68 65 0a 55 |Blonder |at the.U|
|00000500| 6e 69 76 65 72 73 69 74 | 79 20 6f 66 20 4d 61 72 |niversit|y of Mar|
|00000510| 79 6c 61 6e 64 2e 20 48 | 65 20 73 69 6d 70 6c 79 |yland. H|e simply|
|00000520| 20 68 61 64 20 61 20 62 | 75 6e 63 68 20 6f 66 20 | had a b|unch of |
|00000530| 64 65 76 69 63 65 73 2c | 20 2f 64 65 76 2f 66 64 |devices,| /dev/fd|
|00000540| 30 20 2d 20 2f 64 65 76 | 2f 66 64 31 39 2e 0a 54 |0 - /dev|/fd19..T|
|00000550| 68 65 20 52 65 73 65 61 | 72 63 68 20 55 6e 69 78 |he Resea|rch Unix|
|00000560| 20 73 79 73 74 65 6d 20 | 75 73 65 73 20 61 20 2f | system |uses a /|
|00000570| 64 65 76 2f 66 64 20 64 | 69 72 65 63 74 6f 72 79 |dev/fd d|irectory|
|00000580| 2c 20 77 69 74 68 20 66 | 69 6c 65 73 20 30 20 2d |, with f|iles 0 -|
|00000590| 20 31 39 2e 0a 09 54 68 | 65 20 6c 61 74 74 65 72 | 19...Th|e latter|
|000005a0| 20 76 65 72 73 69 6f 6e | 20 6f 66 20 74 68 65 20 | version| of the |
|000005b0| 6d 65 63 68 61 6e 69 73 | 6d 20 69 73 20 75 73 65 |mechanis|m is use|
|000005c0| 64 20 62 79 20 74 68 65 | 20 4b 6f 72 6e 20 73 68 |d by the| Korn sh|
|000005d0| 65 6c 6c 20 28 6b 73 68 | 29 0a 66 6f 72 20 22 70 |ell (ksh|).for "p|
|000005e0| 72 6f 63 65 73 73 20 73 | 75 62 73 74 69 74 75 74 |rocess s|ubstitut|
|000005f0| 69 6f 6e 22 2c 20 61 20 | 66 65 61 74 75 72 65 20 |ion", a |feature |
|00000600| 77 68 65 72 65 62 79 20 | 70 72 6f 67 72 61 6d 73 |whereby |programs|
|00000610| 20 63 61 6e 20 72 65 61 | 64 2f 77 72 69 74 65 20 | can rea|d/write |
|00000620| 66 69 6c 65 73 0a 77 68 | 69 63 68 20 61 72 65 20 |files.wh|ich are |
|00000630| 72 65 61 6c 6c 79 20 70 | 69 70 65 73 20 66 72 6f |really p|ipes fro|
|00000640| 6d 2f 74 6f 20 6f 74 68 | 65 72 20 70 72 6f 63 65 |m/to oth|er proce|
|00000650| 73 73 65 73 2e 20 20 54 | 68 69 73 20 6d 65 63 68 |sses. T|his mech|
|00000660| 61 6e 69 73 6d 20 61 6c | 6c 6f 77 73 20 6f 6e 65 |anism al|lows one|
|00000670| 0a 74 6f 20 68 61 76 65 | 20 70 69 70 65 6c 69 6e |.to have| pipelin|
|00000680| 65 73 20 74 68 61 74 20 | 6d 6f 76 65 20 64 61 74 |es that |move dat|
|00000690| 61 20 69 6e 20 6d 6f 72 | 65 20 74 68 61 6e 20 6f |a in mor|e than o|
|000006a0| 6e 65 20 64 69 6d 65 6e | 73 69 6f 6e 2e 20 4f 6e |ne dimen|sion. On|
|000006b0| 63 65 20 74 68 69 73 0a | 64 72 69 76 65 72 20 69 |ce this.|driver i|
|000006c0| 73 20 69 6e 73 74 61 6c | 6c 65 64 2c 20 74 68 65 |s instal|led, the|
|000006d0| 20 6b 73 68 20 6e 65 65 | 64 73 20 74 6f 20 62 65 | ksh nee|ds to be|
|000006e0| 20 72 65 63 6f 6d 70 69 | 6c 65 64 2e 20 50 72 6f | recompi|led. Pro|
|000006f0| 63 65 73 73 20 73 75 62 | 73 74 69 74 75 74 69 6f |cess sub|stitutio|
|00000700| 6e 0a 69 73 20 6e 65 77 | 20 69 6e 20 74 68 65 20 |n.is new| in the |
|00000710| 76 65 72 73 69 6f 6e 20 | 6f 66 20 74 68 65 20 6b |version |of the k|
|00000720| 73 68 20 6b 6e 6f 77 6e | 20 61 73 20 22 6b 73 68 |sh known| as "ksh|
|00000730| 2d 69 22 2e 20 49 20 64 | 6f 6e 27 74 20 6b 6e 6f |-i". I d|on't kno|
|00000740| 77 20 69 66 20 74 68 65 | 20 6f 6c 64 65 72 0a 6b |w if the| older.k|
|00000750| 73 68 20 68 61 64 20 69 | 74 20 61 73 20 61 6e 20 |sh had i|t as an |
|00000760| 75 6e 64 6f 63 75 6d 65 | 6e 74 65 64 20 66 65 61 |undocume|nted fea|
|00000770| 74 75 72 65 2e 0a 09 54 | 6f 20 61 6c 6c 6f 77 20 |ture...T|o allow |
|00000780| 74 68 65 20 6b 73 68 20 | 74 6f 20 75 73 65 20 74 |the ksh |to use t|
|00000790| 68 65 20 66 64 20 64 72 | 69 76 65 72 2c 20 61 6e |he fd dr|iver, an|
|000007a0| 64 20 66 6f 72 20 63 6f | 6d 70 61 74 69 62 69 6c |d for co|mpatibil|
|000007b0| 69 74 79 20 77 69 74 68 | 0a 52 65 73 65 61 72 63 |ity with|.Researc|
|000007c0| 68 20 55 6e 69 78 2c 20 | 49 20 68 61 76 65 20 63 |h Unix, |I have c|
|000007d0| 68 61 6e 67 65 64 20 74 | 68 65 20 66 64 2e 34 20 |hanged t|he fd.4 |
|000007e0| 6d 61 6e 20 70 61 67 65 | 20 74 6f 20 72 65 66 65 |man page| to refe|
|000007f0| 72 20 74 6f 20 74 68 65 | 20 2f 64 65 76 2f 66 64 |r to the| /dev/fd|
|00000800| 0a 64 69 72 65 63 74 6f | 72 79 2e 0a 0a 09 54 68 |.directo|ry....Th|
|00000810| 69 73 20 76 65 72 73 69 | 6f 6e 20 6f 66 20 74 68 |is versi|on of th|
|00000820| 65 20 66 64 20 64 72 69 | 76 65 72 20 6e 6f 77 20 |e fd dri|ver now |
|00000830| 69 6e 63 6c 75 64 65 73 | 20 63 6f 64 65 20 66 6f |includes| code fo|
|00000840| 72 20 4e 46 53 20 73 79 | 73 74 65 6d 73 2e 0a 55 |r NFS sy|stems..U|
|00000850| 6e 66 6f 72 74 75 6e 61 | 74 65 6c 79 2c 20 66 6f |nfortuna|tely, fo|
|00000860| 72 20 72 65 61 73 6f 6e | 73 20 64 65 74 61 69 6c |r reason|s detail|
|00000870| 65 64 20 69 6e 20 74 68 | 65 20 73 6f 75 72 63 65 |ed in th|e source|
|00000880| 20 63 6f 64 65 2c 20 74 | 68 65 20 4e 46 53 20 76 | code, t|he NFS v|
|00000890| 65 72 73 69 6f 6e 0a 72 | 65 71 75 69 72 65 73 20 |ersion.r|equires |
|000008a0| 61 20 73 6d 61 6c 6c 20 | 70 61 74 63 68 20 74 6f |a small |patch to|
|000008b0| 20 74 68 65 20 73 74 6f | 63 6b 20 73 79 73 74 65 | the sto|ck syste|
|000008c0| 6d 20 63 6f 64 65 2e 20 | 54 68 65 20 66 69 6c 65 |m code. |The file|
|000008d0| 20 74 68 61 74 20 69 73 | 20 61 66 66 65 63 74 65 | that is| affecte|
|000008e0| 64 0a 69 73 20 2f 73 79 | 73 2f 73 70 65 63 66 73 |d.is /sy|s/specfs|
|000008f0| 2f 73 70 65 63 5f 76 6e | 6f 64 65 6f 70 73 2e 63 |/spec_vn|odeops.c|
|00000900| 2e 20 20 54 68 69 73 20 | 70 61 74 63 68 20 69 73 |. This |patch is|
|00000910| 20 69 6e 63 6c 75 64 65 | 64 20 69 6e 20 74 68 65 | include|d in the|
|00000920| 20 66 69 6c 65 20 50 41 | 54 43 48 2e 0a 54 68 69 | file PA|TCH..Thi|
|00000930| 73 20 70 61 74 63 68 20 | 73 68 6f 75 6c 64 20 6e |s patch |should n|
|00000940| 6f 74 20 61 66 66 65 63 | 74 20 61 6e 79 20 6f 74 |ot affec|t any ot|
|00000950| 68 65 72 20 73 79 73 74 | 65 6d 20 63 6f 64 65 20 |her syst|em code |
|00000960| 28 66 61 6d 6f 75 73 20 | 6c 61 73 74 20 77 6f 72 |(famous |last wor|
|00000970| 64 73 21 29 2e 0a 42 65 | 73 69 64 65 73 20 74 68 |ds!)..Be|sides th|
|00000980| 65 20 4e 46 53 20 76 65 | 72 73 69 6f 6e 2c 20 49 |e NFS ve|rsion, I|
|00000990| 20 68 61 76 65 20 61 64 | 64 65 64 20 73 6f 6d 65 | have ad|ded some|
|000009a0| 20 61 64 64 69 74 69 6f | 6e 61 6c 20 65 72 72 6f | additio|nal erro|
|000009b0| 72 20 63 68 65 63 6b 69 | 6e 67 2c 20 61 6e 64 0a |r checki|ng, and.|
|000009c0| 61 20 62 75 67 20 66 69 | 78 20 74 6f 20 74 68 65 |a bug fi|x to the|
|000009d0| 20 69 6e 6f 64 65 20 76 | 65 72 73 69 6f 6e 20 61 | inode v|ersion a|
|000009e0| 73 20 77 65 6c 6c 2e 20 | 54 68 69 73 20 69 73 20 |s well. |This is |
|000009f0| 63 6f 6d 6d 65 6e 74 65 | 64 2c 20 73 6f 20 69 66 |commente|d, so if|
|00000a00| 20 73 6f 6d 65 6f 6e 65 | 0a 77 61 6e 74 73 20 74 | someone|.wants t|
|00000a10| 68 65 20 65 78 61 63 74 | 20 6f 72 69 67 69 6e 61 |he exact| origina|
|00000a20| 6c 20 63 6f 64 65 2c 20 | 74 68 65 79 20 63 61 6e |l code, |they can|
|00000a30| 20 63 68 61 6e 67 65 20 | 69 74 20 62 61 63 6b 2e | change |it back.|
|00000a40| 0a 0a 09 54 68 65 20 4e | 46 53 20 76 65 72 73 69 |...The N|FS versi|
|00000a50| 6f 6e 20 77 6f 72 6b 73 | 20 77 69 74 68 6f 75 74 |on works| without|
|00000a60| 20 63 68 61 6e 67 65 20 | 6f 6e 20 62 6f 74 68 20 | change |on both |
|00000a70| 53 75 6e 20 73 79 73 74 | 65 6d 73 20 72 75 6e 6e |Sun syst|ems runn|
|00000a80| 69 6e 67 0a 53 75 6e 4f | 53 20 33 2e 33 2c 20 61 |ing.SunO|S 3.3, a|
|00000a90| 6e 64 20 4d 74 2e 20 58 | 69 6e 75 20 34 2e 33 20 |nd Mt. X|inu 4.3 |
|00000aa0| 2b 20 4e 46 53 20 33 2e | 32 2e 20 4f 6e 20 74 68 |+ NFS 3.|2. On th|
|00000ab0| 65 20 53 75 6e 2c 20 22 | 6d 61 6b 65 20 64 65 70 |e Sun, "|make dep|
|00000ac0| 65 6e 64 22 20 77 69 6c | 6c 20 6e 6f 74 0a 77 6f |end" wil|l not.wo|
|00000ad0| 72 6b 20 62 65 63 61 75 | 73 65 20 6f 66 20 77 68 |rk becau|se of wh|
|00000ae0| 65 72 65 20 74 68 65 20 | 69 6e 6f 64 65 2e 68 20 |ere the |inode.h |
|00000af0| 66 69 6c 65 20 69 73 20 | 69 6e 63 6c 75 64 65 64 |file is |included|
|00000b00| 20 66 72 6f 6d 20 69 66 | 20 4e 46 53 20 69 73 20 | from if| NFS is |
|00000b10| 6e 6f 74 0a 64 65 66 69 | 6e 65 64 2e 20 54 68 69 |not.defi|ned. Thi|
|00000b20| 73 20 69 73 20 6e 6f 74 | 20 61 20 76 65 72 79 20 |s is not| a very |
|00000b30| 62 69 67 20 64 65 61 6c | 2c 20 6a 75 73 74 20 63 |big deal|, just c|
|00000b40| 6f 6d 6d 65 6e 74 20 6f | 75 74 20 74 68 61 74 20 |omment o|ut that |
|00000b50| 6c 69 6e 65 2e 20 20 54 | 68 65 0a 69 6e 74 65 72 |line. T|he.inter|
|00000b60| 61 63 74 69 6f 6e 20 77 | 69 74 68 20 74 68 65 20 |action w|ith the |
|00000b70| 66 69 6c 65 20 6c 6f 63 | 6b 69 6e 67 20 6d 65 63 |file loc|king mec|
|00000b80| 68 61 6e 69 73 6d 73 20 | 69 73 20 6e 6f 74 20 63 |hanisms |is not c|
|00000b90| 6c 65 61 72 2e 20 28 69 | 2e 65 2e 20 49 20 64 69 |lear. (i|.e. I di|
|00000ba0| 64 6e 27 74 0a 62 6f 74 | 68 65 72 20 74 6f 20 69 |dn't.bot|her to i|
|00000bb0| 6e 76 65 73 74 69 67 61 | 74 65 20 69 74 2e 29 0a |nvestiga|te it.).|
|00000bc0| 0a 41 72 6e 6f 6c 64 20 | 52 6f 62 62 69 6e 73 0a |.Arnold |Robbins.|
|00000bd0| 45 6d 6f 72 79 20 55 6e | 69 76 65 72 73 69 74 79 |Emory Un|iversity|
|00000be0| 20 43 6f 6d 70 75 74 69 | 6e 67 20 43 65 6e 74 65 | Computi|ng Cente|
|00000bf0| 72 0a 4a 75 6c 79 2c 20 | 31 39 38 37 0a 00 00 00 |r.July, |1987....|
|00000c00| 64 65 76 2d 66 64 2f 52 | 45 41 44 4d 45 00 00 00 |dev-fd/R|EADME...|
|00000c10| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000c20| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000c30| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000c40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000c50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000c60| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00000c70| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00000c80| 20 20 20 33 33 36 35 20 | 20 34 34 30 32 31 31 30 | 3365 | 4402110|
|00000c90| 35 33 34 20 20 20 36 31 | 33 31 00 20 00 00 00 00 |534 61|31. ....|
|00000ca0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000cb0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000cc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000cd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000ce0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000cf0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d00| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d10| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d20| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d30| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d70| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d80| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000d90| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000da0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000db0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000dc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000dd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000de0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000df0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000e00| 46 72 6f 6d 20 66 72 65 | 64 40 67 79 6d 62 6c 65 |From fre|d@gymble|
|00000e10| 2e 55 55 43 50 20 28 46 | 72 65 64 20 42 6c 6f 6e |.UUCP (F|red Blon|
|00000e20| 64 65 72 29 20 46 72 69 | 20 4a 75 6e 20 32 31 20 |der) Fri| Jun 21 |
|00000e30| 30 30 3a 33 34 3a 35 33 | 20 31 39 38 35 0a 52 65 |00:34:53| 1985.Re|
|00000e40| 6c 61 79 2d 56 65 72 73 | 69 6f 6e 3a 20 76 65 72 |lay-Vers|ion: ver|
|00000e50| 73 69 6f 6e 20 42 20 32 | 2e 31 30 2e 32 20 39 2f |sion B 2|.10.2 9/|
|00000e60| 31 38 2f 38 34 3b 20 73 | 69 74 65 20 67 61 74 65 |18/84; s|ite gate|
|00000e70| 63 68 2e 43 53 4e 45 54 | 0a 50 6f 73 74 69 6e 67 |ch.CSNET|.Posting|
|00000e80| 2d 56 65 72 73 69 6f 6e | 3a 20 76 65 72 73 69 6f |-Version|: versio|
|00000e90| 6e 20 42 20 32 2e 31 30 | 2e 31 20 36 2f 32 34 2f |n B 2.10|.1 6/24/|
|00000ea0| 38 33 3b 20 73 69 74 65 | 20 67 79 6d 62 6c 65 2e |83; site| gymble.|
|00000eb0| 55 55 43 50 0a 50 61 74 | 68 3a 20 67 61 74 65 63 |UUCP.Pat|h: gatec|
|00000ec0| 68 21 61 6b 67 75 61 21 | 77 68 75 78 6c 6d 21 77 |h!akgua!|whuxlm!w|
|00000ed0| 68 75 78 6c 21 68 6f 75 | 78 6d 21 69 68 6e 70 34 |huxl!hou|xm!ihnp4|
|00000ee0| 21 6d 68 75 78 6e 21 6d | 68 75 78 72 21 75 6c 79 |!mhuxn!m|huxr!uly|
|00000ef0| 73 73 65 73 21 61 6c 6c | 65 67 72 61 21 6d 69 74 |sses!all|egra!mit|
|00000f00| 2d 65 64 64 69 65 21 67 | 65 6e 72 61 64 21 70 61 |-eddie!g|enrad!pa|
|00000f10| 6e 64 61 21 74 61 6c 63 | 6f 74 74 21 68 61 72 76 |nda!talc|ott!harv|
|00000f20| 61 72 64 21 73 65 69 73 | 6d 6f 21 75 6d 63 70 2d |ard!seis|mo!umcp-|
|00000f30| 63 73 21 67 79 6d 62 6c | 65 21 66 72 65 64 0a 46 |cs!gymbl|e!fred.F|
|00000f40| 72 6f 6d 3a 20 66 72 65 | 64 40 67 79 6d 62 6c 65 |rom: fre|d@gymble|
|00000f50| 2e 55 55 43 50 20 28 46 | 72 65 64 20 42 6c 6f 6e |.UUCP (F|red Blon|
|00000f60| 64 65 72 29 0a 4e 65 77 | 73 67 72 6f 75 70 73 3a |der).New|sgroups:|
|00000f70| 20 6e 65 74 2e 73 6f 75 | 72 63 65 73 0a 53 75 62 | net.sou|rces.Sub|
|00000f80| 6a 65 63 74 3a 20 60 60 | 66 69 6c 65 20 64 65 73 |ject: ``|file des|
|00000f90| 63 72 69 70 74 6f 72 27 | 27 20 70 73 65 75 64 6f |criptor'|' pseudo|
|00000fa0| 2d 64 65 76 69 63 65 20 | 64 72 69 76 65 72 20 66 |-device |driver f|
|00000fb0| 6f 72 20 34 2e 32 42 53 | 44 0a 4d 65 73 73 61 67 |or 4.2BS|D.Messag|
|00000fc0| 65 2d 49 44 3a 20 3c 31 | 37 33 40 67 79 6d 62 6c |e-ID: <1|73@gymbl|
|00000fd0| 65 2e 55 55 43 50 3e 0a | 44 61 74 65 3a 20 32 31 |e.UUCP>.|Date: 21|
|00000fe0| 20 4a 75 6e 20 38 35 20 | 30 34 3a 33 34 3a 35 33 | Jun 85 |04:34:53|
|00000ff0| 20 47 4d 54 0a 44 61 74 | 65 2d 52 65 63 65 69 76 | GMT.Dat|e-Receiv|
|00001000| 65 64 3a 20 32 33 20 4a | 75 6e 20 38 35 20 30 33 |ed: 23 J|un 85 03|
|00001010| 3a 32 39 3a 35 33 20 47 | 4d 54 0a 44 69 73 74 72 |:29:53 G|MT.Distr|
|00001020| 69 62 75 74 69 6f 6e 3a | 20 6e 65 74 0a 4f 72 67 |ibution:| net.Org|
|00001030| 61 6e 69 7a 61 74 69 6f | 6e 3a 20 55 20 6f 66 20 |anizatio|n: U of |
|00001040| 4d 61 72 79 6c 61 6e 64 | 2c 20 4c 61 62 6f 72 61 |Maryland|, Labora|
|00001050| 74 6f 72 79 20 66 6f 72 | 20 50 61 72 61 6c 6c 65 |tory for| Paralle|
|00001060| 6c 20 43 6f 6d 70 75 74 | 61 74 69 6f 6e 2c 20 43 |l Comput|ation, C|
|00001070| 2e 50 2e 2c 20 4d 44 0a | 4c 69 6e 65 73 3a 20 32 |.P., MD.|Lines: 2|
|00001080| 37 32 0a 0a 49 27 6d 20 | 72 65 2d 70 6f 73 74 69 |72..I'm |re-posti|
|00001090| 6e 67 20 74 68 69 73 20 | 64 75 65 20 74 6f 20 70 |ng this |due to p|
|000010a0| 6f 70 75 6c 61 72 20 64 | 65 6d 61 6e 64 3a 0a 0a |opular d|emand:..|
|000010b0| 54 68 69 73 20 69 73 20 | 61 20 70 73 65 75 64 6f |This is |a pseudo|
|000010c0| 2d 64 65 76 69 63 65 20 | 64 72 69 76 65 72 20 77 |-device |driver w|
|000010d0| 68 69 63 68 20 69 6d 70 | 6c 65 6d 65 6e 74 73 20 |hich imp|lements |
|000010e0| 61 0a 73 65 72 69 65 73 | 20 6f 66 20 64 65 76 69 |a.series| of devi|
|000010f0| 63 65 73 3a 20 2f 64 65 | 76 2f 66 64 30 20 2d 20 |ces: /de|v/fd0 - |
|00001100| 2f 64 65 76 2f 66 64 31 | 39 20 77 68 69 63 68 20 |/dev/fd1|9 which |
|00001110| 61 72 65 0a 73 75 72 72 | 65 70 74 69 74 69 6f 75 |are.surr|eptitiou|
|00001120| 73 6c 79 20 65 71 75 69 | 76 61 6c 65 6e 63 65 64 |sly equi|valenced|
|00001130| 20 74 6f 20 77 68 61 74 | 65 76 65 72 20 66 69 6c | to what|ever fil|
|00001140| 65 20 28 69 66 0a 61 6e | 79 29 20 69 73 20 61 73 |e (if.an|y) is as|
|00001150| 73 6f 63 69 61 74 65 64 | 20 77 69 74 68 20 74 68 |sociated| with th|
|00001160| 65 20 63 6f 72 72 65 73 | 70 6f 6e 64 69 6e 67 20 |e corres|ponding |
|00001170| 66 69 6c 65 0a 64 65 73 | 63 72 69 70 74 6f 72 20 |file.des|criptor |
|00001180| 69 6e 20 74 68 65 20 70 | 72 6f 63 65 73 73 20 77 |in the p|rocess w|
|00001190| 68 69 63 68 20 69 73 20 | 61 74 74 65 6d 70 74 69 |hich is |attempti|
|000011a0| 6e 67 20 74 6f 0a 6f 70 | 65 6e 20 74 68 61 74 20 |ng to.op|en that |
|000011b0| 66 69 6c 65 2e 20 49 6e | 20 6f 74 68 65 72 20 77 |file. In| other w|
|000011c0| 6f 72 64 73 3a 20 6f 70 | 65 6e 69 6e 67 20 74 68 |ords: op|ening th|
|000011d0| 65 20 66 69 6c 65 0a 2f | 64 65 76 2f 66 64 3c 6e |e file./|dev/fd<n|
|000011e0| 3e 20 69 73 20 61 6c 6d | 6f 73 74 20 74 68 65 20 |> is alm|ost the |
|000011f0| 73 61 6d 65 20 61 73 20 | 64 6f 69 6e 67 20 74 68 |same as |doing th|
|00001200| 65 20 73 79 73 74 65 6d | 0a 63 61 6c 6c 3a 20 64 |e system|.call: d|
|00001210| 75 70 28 6e 29 2e 20 49 | 74 27 73 20 64 69 66 66 |up(n). I|t's diff|
|00001220| 65 72 65 6e 74 20 69 6e | 20 74 68 61 74 20 69 66 |erent in| that if|
|00001230| 20 74 68 65 20 66 69 6c | 65 0a 69 73 20 61 20 64 | the fil|e.is a d|
|00001240| 65 76 69 63 65 2c 20 74 | 68 65 20 64 72 69 76 65 |evice, t|he drive|
|00001250| 72 27 73 20 6f 70 65 6e | 20 72 6f 75 74 69 6e 65 |r's open| routine|
|00001260| 20 69 73 20 63 61 6c 6c | 65 64 2e 0a 49 66 20 74 | is call|ed..If t|
|00001270| 68 65 20 63 6f 72 72 65 | 73 70 6f 6e 64 69 6e 67 |he corre|sponding|
|00001280| 20 66 69 6c 65 20 64 65 | 73 63 72 69 70 74 6f 72 | file de|scriptor|
|00001290| 20 69 73 20 61 20 70 69 | 70 65 0a 28 73 6f 63 6b | is a pi|pe.(sock|
|000012a0| 65 74 29 20 61 20 64 75 | 70 28 29 20 73 79 73 20 |et) a du|p() sys |
|000012b0| 63 61 6c 6c 20 69 73 20 | 66 61 6b 65 64 2e 0a 0a |call is |faked...|
|000012c0| 54 68 69 73 20 63 61 6e | 20 62 65 20 75 73 65 64 |This can| be used|
|000012d0| 20 74 6f 20 66 6f 72 63 | 65 20 70 72 6f 67 72 61 | to forc|e progra|
|000012e0| 6d 73 20 74 6f 20 72 65 | 61 64 20 66 72 6f 6d 0a |ms to re|ad from.|
|000012f0| 74 68 65 69 72 20 73 74 | 61 6e 64 61 72 64 20 69 |their st|andard i|
|00001300| 6e 70 75 74 2c 20 6f 72 | 20 77 72 69 74 65 20 74 |nput, or| write t|
|00001310| 6f 20 74 68 65 69 72 20 | 73 74 61 6e 64 61 72 64 |o their |standard|
|00001320| 0a 6f 75 74 70 75 74 2c | 20 65 76 65 6e 20 69 66 |.output,| even if|
|00001330| 20 74 68 65 79 20 68 61 | 76 65 6e 27 74 20 62 65 | they ha|ven't be|
|00001340| 65 6e 20 64 65 73 69 67 | 6e 65 64 20 74 6f 20 64 |en desig|ned to d|
|00001350| 6f 0a 73 6f 2e 20 20 46 | 6f 72 20 69 6e 73 74 61 |o.so. F|or insta|
|00001360| 6e 63 65 3a 0a 0a 09 6c | 6e 20 2d 73 20 2f 64 65 |nce:...l|n -s /de|
|00001370| 76 2f 66 64 30 20 78 78 | 2e 63 0a 09 63 63 20 78 |v/fd0 xx|.c..cc x|
|00001380| 78 2e 63 0a 09 7b 20 54 | 79 70 65 20 61 20 43 20 |x.c..{ T|ype a C |
|00001390| 70 72 6f 67 72 61 6d 20 | 68 65 72 65 2e 20 7d 0a |program |here. }.|
|000013a0| 09 5e 44 0a 09 61 2e 6f | 75 74 0a 0a 4f 72 2c 20 |.^D..a.o|ut..Or, |
|000013b0| 74 6f 20 73 65 65 20 69 | 66 20 61 20 63 65 72 74 |to see i|f a cert|
|000013c0| 61 69 6e 20 73 6f 75 72 | 63 65 20 66 69 6c 65 20 |ain sour|ce file |
|000013d0| 63 6f 6d 70 69 6c 65 64 | 20 69 6e 74 6f 20 61 0a |compiled| into a.|
|000013e0| 70 61 72 74 69 63 75 6c | 61 72 20 6f 62 6a 65 63 |particul|ar objec|
|000013f0| 74 20 66 69 6c 65 3a 0a | 0a 09 63 63 20 73 6f 75 |t file:.|..cc sou|
|00001400| 72 63 65 2e 63 20 2d 6f | 20 2f 64 65 76 2f 66 64 |rce.c -o| /dev/fd|
|00001410| 31 20 7c 20 63 6d 70 20 | 2d 20 6f 62 6a 65 63 74 |1 | cmp |- object|
|00001420| 66 69 6c 65 0a 0a 42 65 | 20 73 75 72 65 20 74 6f |file..Be| sure to|
|00001430| 20 6d 61 6b 65 20 74 68 | 65 73 65 20 6d 6f 64 73 | make th|ese mods|
|00001440| 20 69 6e 20 79 6f 75 72 | 20 63 6f 6e 66 20 64 69 | in your| conf di|
|00001450| 72 65 63 74 6f 72 79 2e | 0a 0a 49 6e 20 74 68 65 |rectory.|..In the|
|00001460| 20 63 6f 6e 66 69 67 20 | 66 69 6c 65 3a 0a 09 70 | config |file:..p|
|00001470| 73 65 75 64 6f 2d 64 65 | 76 69 63 65 09 66 64 0a |seudo-de|vice.fd.|
|00001480| 0a 49 6e 20 74 68 65 20 | 60 60 66 69 6c 65 73 27 |.In the |``files'|
|00001490| 27 20 66 69 6c 65 3a 0a | 09 73 79 73 2f 64 65 76 |' file:.|.sys/dev|
|000014a0| 5f 66 64 2e 63 09 09 6f | 70 74 69 6f 6e 61 6c 20 |_fd.c..o|ptional |
|000014b0| 66 64 0a 0a 3c 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |fd..<***|********|
|000014c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000014d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000014e0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000014f0| 2a 2a 2a 3e 0a 69 73 20 | 69 6e 63 6c 75 64 65 64 |***>.is |included|
|00001500| 20 66 72 6f 6d 20 69 66 | 20 4e 46 53 20 69 73 20 | from if| NFS is |
|00001510| 6e 6f 74 0a 64 65 66 69 | 6e 65 64 2e 20 54 68 69 |not.defi|ned. Thi|
|00001520| 73 20 69 73 20 6e 6f 74 | 20 61 20 76 65 72 79 20 |s is not| a very |
|00001530| 62 69 67 20 64 65 61 6c | 2c 20 6a 75 73 74 20 63 |big deal|, just c|
|00001540| 6f 6d 6d 65 6e 74 20 6f | 75 74 20 74 68 61 74 20 |omment o|ut that |
|00001550| 6c 69 6e 65 2e 20 20 54 | 68 65 0a 69 6e 74 65 72 |line. T|he.inter|
|00001560| 61 63 74 69 6f 6e 20 77 | 69 74 68 20 74 68 65 20 |action w|ith the |
|00001570| 66 69 6c 65 20 6c 6f 63 | 6b 69 6e 67 20 6d 65 63 |file loc|king mec|
|00001580| 68 61 6e 69 73 6d 73 20 | 69 73 20 6e 6f 74 20 63 |hanisms |is not c|
|00001590| 6c 65 61 72 2e 20 28 69 | 2e 65 2e 20 49 20 64 69 |lear. (i|.e. I di|
|000015a0| 64 6e 27 74 0a 62 6f 74 | 68 65 72 20 74 6f 20 69 |dn't.bot|her to i|
|000015b0| 6e 76 65 73 74 69 67 61 | 74 65 20 69 74 2e 29 0a |nvestiga|te it.).|
|000015c0| 0a 41 72 6e 6f 6c 64 20 | 52 6f 62 62 69 6e 73 0a |.Arnold |Robbins.|
|000015d0| 45 6d 6f 72 79 20 55 6e | 69 76 65 72 73 69 74 79 |Emory Un|iversity|
|000015e0| 20 43 6f 6d 70 75 74 69 | 6e 67 20 43 65 6e 74 65 | Computi|ng Cente|
|000015f0| 72 0a 4a 75 6c 79 2c 20 | 31 39 38 37 0a 00 00 00 |r.July, |1987....|
|00001600| 64 65 76 2d 66 64 2f 66 | 64 2e 34 00 00 00 00 00 |dev-fd/f|d.4.....|
|00001610| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001620| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001630| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001640| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001650| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001660| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00001670| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00001680| 20 20 20 37 30 33 37 20 | 20 34 34 30 32 31 31 30 | 7037 | 4402110|
|00001690| 35 33 35 20 20 20 35 37 | 33 30 00 20 00 00 00 00 |535 57|30. ....|
|000016a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000016b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000016c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000016d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000016e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000016f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001700| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001710| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001720| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001730| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001740| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001750| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001760| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001770| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001780| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001790| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000017f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00001800| 2e 2e 2e 0a 2e 2e 2e 20 | 24 48 65 61 64 65 72 3a |....... |$Header:|
|00001810| 20 66 64 2e 34 2c 76 20 | 31 2e 33 20 38 37 2f 30 | fd.4,v |1.3 87/0|
|00001820| 37 2f 31 30 20 31 30 3a | 32 30 3a 32 36 20 72 6f |7/10 10:|20:26 ro|
|00001830| 6f 74 20 4c 6f 63 6b 65 | 64 20 24 0a 2e 2e 2e 20 |ot Locke|d $.... |
|00001840| 0a 2e 2e 2e 20 24 4c 6f | 67 3a 09 66 64 2e 34 2c |.... $Lo|g:.fd.4,|
|00001850| 76 20 24 0a 2e 2e 2e 20 | 52 65 76 69 73 69 6f 6e |v $.... |Revision|
|00001860| 20 31 2e 33 20 20 38 37 | 2f 30 37 2f 31 30 20 20 | 1.3 87|/07/10 |
|00001870| 31 30 3a 32 30 3a 32 36 | 20 20 72 6f 6f 74 0a 2e |10:20:26| root..|
|00001880| 2e 2e 20 41 64 64 65 64 | 20 45 52 52 4f 52 53 20 |.. Added| ERRORS |
|00001890| 73 65 63 74 69 6f 6e 2e | 20 41 44 52 2e 0a 2e 2e |section.| ADR....|
|000018a0| 2e 20 0a 2e 2e 2e 20 52 | 65 76 69 73 69 6f 6e 20 |. .... R|evision |
|000018b0| 31 2e 32 20 20 38 37 2f | 30 37 2f 30 35 20 20 31 |1.2 87/|07/05 1|
|000018c0| 32 3a 30 35 3a 34 39 20 | 20 72 6f 6f 74 0a 2e 2e |2:05:49 | root...|
|000018d0| 2e 20 41 64 64 65 64 20 | 73 79 6e 6f 70 73 69 73 |. Added |synopsis|
|000018e0| 20 65 6e 74 72 79 2c 20 | 63 68 61 6e 67 65 64 20 | entry, |changed |
|000018f0| 66 6f 72 20 2f 64 65 76 | 2f 66 64 20 61 73 20 61 |for /dev|/fd as a|
|00001900| 20 64 69 72 65 63 74 6f | 72 79 2c 20 61 64 64 65 | directo|ry, adde|
|00001910| 64 20 6e 6f 74 65 73 0a | 2e 2e 2e 20 61 62 6f 75 |d notes.|... abou|
|00001920| 74 20 6b 73 68 2c 20 2f | 64 65 76 2f 73 74 64 7b |t ksh, /|dev/std{|
|00001930| 69 6e 2c 20 6f 75 74 2c | 20 65 72 72 7d 20 61 6e |in, out,| err} an|
|00001940| 64 20 6f 6e 6c 79 20 68 | 61 76 69 6e 67 20 32 30 |d only h|aving 20|
|00001950| 20 65 6e 74 72 69 65 73 | 2e 20 41 44 52 2e 0a 2e | entries|. ADR...|
|00001960| 2e 2e 20 0a 2e 2e 2e 20 | 52 65 76 69 73 69 6f 6e |.. .... |Revision|
|00001970| 20 31 2e 31 20 20 38 37 | 2f 30 37 2f 30 32 20 20 | 1.1 87|/07/02 |
|00001980| 31 35 3a 32 38 3a 30 31 | 20 20 72 6f 6f 74 0a 2e |15:28:01| root..|
|00001990| 2e 2e 20 49 6e 69 74 69 | 61 6c 20 72 65 76 69 73 |.. Initi|al revis|
|000019a0| 69 6f 6e 0a 2e 2e 2e 20 | 0a 2e 2e 2e 0a 2e 54 48 |ion.... |......TH|
|000019b0| 20 46 44 20 34 20 45 55 | 43 43 0a 2e 55 43 20 34 | FD 4 EU|CC..UC 4|
|000019c0| 0a 2e 53 48 20 4e 41 4d | 45 0a 2f 64 65 76 2f 66 |..SH NAM|E./dev/f|
|000019d0| 64 2f 2a 20 5c 2d 20 60 | 60 66 69 6c 65 20 64 65 |d/* \- `|`file de|
|000019e0| 73 63 72 69 70 74 6f 72 | 27 27 20 64 72 69 76 65 |scriptor|'' drive|
|000019f0| 72 0a 2e 53 48 20 53 59 | 4e 4f 50 53 49 53 0a 2e |r..SH SY|NOPSIS..|
|00001a00| 42 20 22 70 73 65 75 64 | 6f 2d 64 65 76 69 63 65 |B "pseud|o-device|
|00001a10| 09 66 64 22 0a 2e 53 48 | 20 44 45 53 43 52 49 50 |.fd"..SH| DESCRIP|
|00001a20| 54 49 4f 4e 0a 2e 42 20 | 2f 64 65 76 2f 66 64 2f |TION..B |/dev/fd/|
|00001a30| 30 0a 2d 0a 2e 42 20 2f | 64 65 76 2f 66 64 2f 31 |0.-..B /|dev/fd/1|
|00001a40| 39 0a 61 72 65 20 73 70 | 65 63 69 61 6c 20 66 69 |9.are sp|ecial fi|
|00001a50| 6c 65 73 20 74 68 61 74 | 20 72 65 66 65 72 65 6e |les that| referen|
|00001a60| 63 65 20 74 68 65 20 66 | 69 6c 65 73 20 61 73 73 |ce the f|iles ass|
|00001a70| 6f 63 69 61 74 65 64 20 | 77 69 74 68 20 61 20 70 |ociated |with a p|
|00001a80| 72 6f 63 65 73 73 27 0a | 6f 70 65 6e 20 66 69 6c |rocess'.|open fil|
|00001a90| 65 20 64 65 73 63 72 69 | 70 74 6f 72 73 2e 0a 54 |e descri|ptors..T|
|00001aa0| 68 61 74 20 69 73 2c 20 | 6f 70 65 6e 69 6e 67 20 |hat is, |opening |
|00001ab0| 74 68 65 20 66 69 6c 65 | 3a 20 5c 66 42 2f 64 65 |the file|: \fB/de|
|00001ac0| 76 2f 66 64 2f 5c 66 49 | 4e 5c 66 52 20 69 73 20 |v/fd/\fI|N\fR is |
|00001ad0| 65 71 75 69 76 61 6c 65 | 6e 74 20 74 6f 20 6f 70 |equivale|nt to op|
|00001ae0| 65 6e 69 6e 67 20 77 68 | 61 74 65 76 65 72 0a 66 |ening wh|atever.f|
|00001af0| 69 6c 65 20 79 6f 75 20 | 6f 70 65 6e 65 64 20 74 |ile you |opened t|
|00001b00| 6f 20 67 65 74 20 74 68 | 65 20 66 69 6c 65 20 64 |o get th|e file d|
|00001b10| 65 73 63 72 69 70 74 6f | 72 0a 2e 49 52 20 4e 20 |escripto|r..IR N |
|00001b20| 2c 0a 65 76 65 6e 20 74 | 68 6f 75 67 68 20 79 6f |,.even t|hough yo|
|00001b30| 75 20 6d 61 79 20 6e 6f | 74 0a 6b 6e 6f 77 20 74 |u may no|t.know t|
|00001b40| 68 65 20 66 69 6c 65 27 | 73 20 74 72 75 65 20 6e |he file'|s true n|
|00001b50| 61 6d 65 20 28 6f 72 20 | 65 76 65 6e 20 69 66 20 |ame (or |even if |
|00001b60| 69 74 20 68 61 73 20 6f | 6e 65 29 2e 0a 54 68 69 |it has o|ne)..Thi|
|00001b70| 73 20 63 61 6e 20 62 65 | 20 75 73 65 64 20 74 6f |s can be| used to|
|00001b80| 20 66 6f 72 63 65 20 61 | 20 70 72 6f 67 72 61 6d | force a| program|
|00001b90| 20 77 68 69 63 68 20 6f | 70 65 6e 73 20 66 69 6c | which o|pens fil|
|00001ba0| 65 73 20 62 79 20 6e 61 | 6d 65 2c 20 74 6f 20 63 |es by na|me, to c|
|00001bb0| 6f 6e 6e 65 63 74 0a 69 | 74 73 65 6c 66 20 74 6f |onnect.i|tself to|
|00001bc0| 20 6f 70 65 6e 20 66 69 | 6c 65 20 64 65 73 63 72 | open fi|le descr|
|00001bd0| 69 70 74 6f 72 73 20 28 | 77 68 69 63 68 20 79 6f |iptors (|which yo|
|00001be0| 75 20 68 61 76 65 20 74 | 68 6f 75 67 68 74 66 75 |u have t|houghtfu|
|00001bf0| 6c 6c 79 20 70 72 6f 76 | 69 64 65 64 29 20 69 6e |lly prov|ided) in|
|00001c00| 0a 77 65 69 72 64 20 61 | 6e 64 20 77 6f 6e 64 65 |.weird a|nd wonde|
|00001c10| 72 66 75 6c 20 77 61 79 | 73 2e 20 41 20 73 69 6d |rful way|s. A sim|
|00001c20| 70 6c 65 20 75 73 65 20 | 77 6f 75 6c 64 20 62 65 |ple use |would be|
|00001c30| 20 74 6f 20 66 6f 72 63 | 65 20 61 20 70 72 6f 67 | to forc|e a prog|
|00001c40| 72 61 6d 20 77 68 69 63 | 68 0a 6f 6e 6c 79 20 61 |ram whic|h.only a|
|00001c50| 63 63 65 70 74 73 20 69 | 6e 70 75 74 20 66 72 6f |ccepts i|nput fro|
|00001c60| 6d 20 66 69 6c 65 73 2c | 20 74 6f 20 72 65 61 64 |m files,| to read|
|00001c70| 20 66 72 6f 6d 20 69 74 | 73 20 73 74 61 6e 64 61 | from it|s standa|
|00001c80| 72 64 20 69 6e 70 75 74 | 2e 0a 46 6f 72 20 69 6e |rd input|..For in|
|00001c90| 73 74 61 6e 63 65 3a 0a | 2e 73 70 0a 2e 74 69 20 |stance:.|.sp..ti |
|00001ca0| 2b 31 30 0a 63 61 74 20 | 2f 64 65 76 2f 66 64 2f |+10.cat |/dev/fd/|
|00001cb0| 30 0a 2e 73 70 0a 70 72 | 6f 64 75 63 65 73 20 74 |0..sp.pr|oduces t|
|00001cc0| 68 65 20 73 61 6d 65 20 | 72 65 73 75 6c 74 20 61 |he same |result a|
|00001cd0| 73 3a 0a 2e 73 70 0a 2e | 74 69 20 2b 31 30 0a 63 |s:..sp..|ti +10.c|
|00001ce0| 61 74 20 2d 0a 2e 73 70 | 0a 77 68 69 63 68 20 77 |at -..sp|.which w|
|00001cf0| 6f 75 6c 64 20 62 65 20 | 75 73 65 66 75 6c 20 69 |ould be |useful i|
|00001d00| 66 0a 2e 49 52 20 63 61 | 74 20 28 31 29 0a 64 69 |f..IR ca|t (1).di|
|00001d10| 64 6e 27 74 20 75 73 65 | 20 74 68 65 20 60 60 2d |dn't use| the ``-|
|00001d20| 27 27 20 63 6f 6e 76 65 | 6e 74 69 6f 6e 2e 0a 2e |'' conve|ntion...|
|00001d30| 50 50 0a 54 68 69 73 20 | 64 72 69 76 65 72 20 69 |PP.This |driver i|
|00001d40| 73 20 70 61 72 74 69 63 | 75 6c 61 72 6c 79 20 75 |s partic|ularly u|
|00001d50| 73 65 66 75 6c 20 66 6f | 72 20 65 6e 61 62 6c 69 |seful fo|r enabli|
|00001d60| 6e 67 20 74 68 65 20 60 | 60 70 72 6f 63 65 73 73 |ng the `|`process|
|00001d70| 20 73 75 62 73 74 69 74 | 75 74 69 6f 6e 27 27 0a | substit|ution''.|
|00001d80| 6d 65 63 68 61 6e 69 73 | 6d 20 69 6e 0a 2e 49 52 |mechanis|m in..IR|
|00001d90| 20 6b 73 68 20 28 31 29 | 2e 0a 2e 50 50 0a 49 66 | ksh (1)|...PP.If|
|00001da0| 20 74 68 65 20 6f 70 65 | 6e 20 66 69 6c 65 20 64 | the ope|n file d|
|00001db0| 65 73 63 72 69 70 74 6f | 72 20 72 65 66 65 72 65 |escripto|r refere|
|00001dc0| 6e 63 65 73 20 61 20 73 | 6f 63 6b 65 74 2c 20 74 |nces a s|ocket, t|
|00001dd0| 68 65 20 64 72 69 76 65 | 72 20 66 61 6b 65 73 20 |he drive|r fakes |
|00001de0| 61 0a 2e 49 52 20 64 75 | 70 20 28 32 29 0a 73 79 |a..IR du|p (2).sy|
|00001df0| 73 74 65 6d 20 63 61 6c | 6c 20 69 6e 73 74 65 61 |stem cal|l instea|
|00001e00| 64 20 6f 66 20 61 63 74 | 75 61 6c 6c 79 20 6f 70 |d of act|ually op|
|00001e10| 65 6e 69 6e 67 20 61 20 | 66 69 6c 65 2e 20 49 6e |ening a |file. In|
|00001e20| 20 74 68 69 73 20 63 61 | 73 65 20 69 74 0a 63 68 | this ca|se it.ch|
|00001e30| 65 63 6b 73 20 74 6f 20 | 73 65 65 20 74 68 61 74 |ecks to |see that|
|00001e40| 20 74 68 65 20 72 65 61 | 64 2f 77 72 69 74 65 20 | the rea|d/write |
|00001e50| 6d 6f 64 65 20 79 6f 75 | 20 61 72 65 20 61 74 74 |mode you| are att|
|00001e60| 65 6d 70 74 69 6e 67 20 | 74 6f 20 6f 70 65 6e 0a |empting |to open.|
|00001e70| 74 68 65 20 66 69 6c 65 | 20 77 69 74 68 2c 20 69 |the file| with, i|
|00001e80| 73 20 63 6f 6d 70 61 74 | 69 62 6c 65 20 77 69 74 |s compat|ible wit|
|00001e90| 68 20 74 68 65 20 6d 6f | 64 65 20 6f 66 20 74 68 |h the mo|de of th|
|00001ea0| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|00001eb0| 64 65 73 63 72 69 70 74 | 6f 72 2e 0a 54 68 61 74 |descript|or..That|
|00001ec0| 20 69 73 2c 20 69 66 20 | 64 65 73 63 72 69 70 74 | is, if |descript|
|00001ed0| 6f 72 20 35 20 72 65 66 | 65 72 73 20 74 6f 20 61 |or 5 ref|ers to a|
|00001ee0| 20 73 6f 63 6b 65 74 20 | 61 6e 64 0a 69 73 20 6f | socket |and.is o|
|00001ef0| 70 65 6e 20 66 6f 72 20 | 77 72 69 74 69 6e 67 2c |pen for |writing,|
|00001f00| 20 79 6f 75 20 63 61 6e | 6e 6f 74 20 6f 70 65 6e | you can|not open|
|00001f10| 0a 2e 42 20 2f 64 65 76 | 2f 66 64 2f 35 0a 66 6f |..B /dev|/fd/5.fo|
|00001f20| 72 20 72 65 61 64 69 6e | 67 2e 0a 2e 50 50 0a 41 |r readin|g...PP.A|
|00001f30| 73 20 61 20 6e 6f 74 61 | 74 69 6f 6e 61 6c 20 63 |s a nota|tional c|
|00001f40| 6f 6e 76 65 6e 69 65 6e | 63 65 2c 20 74 68 65 20 |onvenien|ce, the |
|00001f50| 66 69 6c 65 73 0a 2e 42 | 52 20 2f 64 65 76 2f 73 |files..B|R /dev/s|
|00001f60| 74 64 69 6e 20 2c 0a 2e | 42 52 20 2f 64 65 76 2f |tdin ,..|BR /dev/|
|00001f70| 73 74 64 6f 75 74 20 2c | 0a 61 6e 64 0a 2e 42 20 |stdout ,|.and..B |
|00001f80| 2f 64 65 76 2f 73 74 64 | 65 72 72 0a 61 72 65 20 |/dev/std|err.are |
|00001f90| 70 72 6f 76 69 64 65 64 | 20 61 73 20 68 61 72 64 |provided| as hard|
|00001fa0| 20 6c 69 6e 6b 73 20 74 | 6f 0a 2e 42 52 20 2f 64 | links t|o..BR /d|
|00001fb0| 65 76 2f 66 64 2f 30 20 | 2c 0a 2e 42 52 20 2f 64 |ev/fd/0 |,..BR /d|
|00001fc0| 65 76 2f 66 64 2f 31 20 | 2c 0a 61 6e 64 0a 2e 42 |ev/fd/1 |,.and..B|
|00001fd0| 52 20 2f 64 65 76 2f 66 | 64 2f 32 0a 72 65 73 70 |R /dev/f|d/2.resp|
|00001fe0| 65 63 74 69 76 65 6c 79 | 2e 0a 2e 53 48 20 45 52 |ectively|...SH ER|
|00001ff0| 52 4f 52 53 0a 54 68 65 | 20 6e 61 6d 65 64 20 66 |RORS.The| named f|
|00002000| 69 6c 65 20 64 65 73 63 | 72 69 70 74 6f 72 20 77 |ile desc|riptor w|
|00002010| 69 6c 6c 20 62 65 20 60 | 60 6f 70 65 6e 65 64 27 |ill be `|`opened'|
|00002020| 27 20 61 73 20 64 65 73 | 63 72 69 62 65 64 20 61 |' as des|cribed a|
|00002030| 62 6f 76 65 20 75 6e 6c | 65 73 73 0a 6f 6e 65 20 |bove unl|ess.one |
|00002040| 6f 66 20 74 68 65 20 66 | 6f 6c 6c 6f 77 69 6e 67 |of the f|ollowing|
|00002050| 20 69 73 20 74 72 75 65 | 2e 0a 2e 50 50 0a 2e 54 | is true|...PP..T|
|00002060| 50 20 31 35 0a 5b 45 4e | 58 49 4f 5d 0a 54 68 65 |P 15.[EN|XIO].The|
|00002070| 20 66 69 6c 65 20 64 65 | 73 63 72 69 70 74 6f 72 | file de|scriptor|
|00002080| 20 61 74 74 65 6d 70 74 | 69 6e 67 20 74 6f 20 62 | attempt|ing to b|
|00002090| 65 20 72 65 6f 70 65 6e | 65 64 20 69 73 20 6c 61 |e reopen|ed is la|
|000020a0| 72 67 65 72 20 74 68 61 | 6e 20 74 68 65 0a 6d 61 |rger tha|n the.ma|
|000020b0| 78 69 6d 75 6d 20 6e 75 | 6d 62 65 72 20 6f 66 20 |ximum nu|mber of |
|000020c0| 6f 70 65 6e 20 66 69 6c | 65 73 20 74 68 61 74 20 |open fil|es that |
|000020d0| 61 20 70 72 6f 63 65 73 | 73 20 6d 61 79 20 68 61 |a proces|s may ha|
|000020e0| 76 65 2e 0a 28 45 2e 67 | 2e 2c 20 61 74 74 65 6d |ve..(E.g|., attem|
|000020f0| 70 74 69 6e 67 20 74 6f | 20 6f 70 65 6e 20 66 69 |pting to| open fi|
|00002100| 6c 65 20 64 65 73 63 72 | 69 70 74 6f 72 20 36 35 |le descr|iptor 65|
|00002110| 20 6f 6e 20 61 20 34 2e | 33 42 53 44 20 73 79 73 | on a 4.|3BSD sys|
|00002120| 74 65 6d 2e 29 0a 2e 54 | 50 20 31 35 0a 5b 45 42 |tem.)..T|P 15.[EB|
|00002130| 41 44 46 5d 0a 54 68 65 | 20 66 69 6c 65 20 64 65 |ADF].The| file de|
|00002140| 73 63 72 69 70 74 6f 72 | 20 61 74 74 65 6d 70 74 |scriptor| attempt|
|00002150| 69 6e 67 20 74 6f 20 62 | 65 20 72 65 6f 70 65 6e |ing to b|e reopen|
|00002160| 65 64 20 69 73 20 6e 6f | 74 20 61 6e 20 6f 70 65 |ed is no|t an ope|
|00002170| 6e 20 66 69 6c 65 2e 0a | 2e 50 50 0a 4f 74 68 65 |n file..|.PP.Othe|
|00002180| 72 20 65 72 72 6f 72 73 | 20 61 73 20 77 6f 75 6c |r errors| as woul|
|00002190| 64 20 62 65 20 72 65 74 | 75 72 6e 65 64 20 62 79 |d be ret|urned by|
|000021a0| 0a 2e 49 52 20 61 63 63 | 65 73 73 20 28 32 29 2c |..IR acc|ess (2),|
|000021b0| 0a 61 6e 64 0a 2e 49 52 | 20 6f 70 65 6e 20 28 32 |.and..IR| open (2|
|000021c0| 29 2e 0a 2e 53 48 20 53 | 45 45 20 41 4c 53 4f 0a |)...SH S|EE ALSO.|
|000021d0| 2e 49 52 20 6b 73 68 20 | 28 31 29 2c 0a 2e 49 52 |.IR ksh |(1),..IR|
|000021e0| 20 61 63 63 65 73 73 20 | 28 32 29 2c 0a 2e 49 52 | access |(2),..IR|
|000021f0| 20 64 75 70 20 28 32 29 | 2c 0a 2e 49 52 20 6f 70 | dup (2)|,..IR op|
|00002200| 65 6e 20 28 32 29 2e 0a | 2e 53 48 20 41 55 54 48 |en (2)..|.SH AUTH|
|00002210| 4f 52 0a 46 72 65 64 20 | 42 6c 6f 6e 64 65 72 20 |OR.Fred |Blonder |
|00002220| 3c 46 72 65 64 40 6d 69 | 6d 73 79 2e 75 6d 64 2e |<Fred@mi|msy.umd.|
|00002230| 45 44 55 3e 0a 2e 62 72 | 0a 4e 46 53 20 76 65 72 |EDU>..br|.NFS ver|
|00002240| 73 69 6f 6e 20 62 79 20 | 41 72 6e 6f 6c 64 20 52 |sion by |Arnold R|
|00002250| 6f 62 62 69 6e 73 20 3c | 61 72 6e 6f 6c 64 40 65 |obbins <|arnold@e|
|00002260| 6d 6f 72 79 2e 45 44 55 | 3e 0a 2e 53 48 20 46 49 |mory.EDU|>..SH FI|
|00002270| 4c 45 53 0a 2e 42 52 20 | 2f 64 65 76 2f 66 64 2f |LES..BR |/dev/fd/|
|00002280| 2a 20 2c 0a 2e 42 52 20 | 2f 64 65 76 2f 73 74 64 |* ,..BR |/dev/std|
|00002290| 69 6e 20 2c 0a 2e 42 52 | 20 2f 64 65 76 2f 73 74 |in ,..BR| /dev/st|
|000022a0| 64 6f 75 74 20 2c 0a 2e | 42 20 2f 64 65 76 2f 73 |dout ,..|B /dev/s|
|000022b0| 74 64 65 72 72 0a 2e 53 | 48 20 42 55 47 53 0a 53 |tderr..S|H BUGS.S|
|000022c0| 69 6e 63 65 2c 20 66 6f | 72 20 73 6f 63 6b 65 74 |ince, fo|r socket|
|000022d0| 73 2c 0a 74 68 65 20 64 | 72 69 76 65 72 20 66 61 |s,.the d|river fa|
|000022e0| 6b 65 73 20 61 0a 2e 49 | 20 64 75 70 0a 73 79 73 |kes a..I| dup.sys|
|000022f0| 74 65 6d 20 63 61 6c 6c | 20 72 61 74 68 65 72 20 |tem call| rather |
|00002300| 74 68 61 6e 20 61 63 74 | 75 61 6c 6c 79 20 72 65 |than act|ually re|
|00002310| 2d 6f 70 65 6e 69 6e 67 | 0a 74 68 65 20 66 69 6c |-opening|.the fil|
|00002320| 65 2c 20 74 68 65 20 6e | 65 77 20 64 65 73 63 72 |e, the n|ew descr|
|00002330| 69 70 74 6f 72 20 69 73 | 20 61 20 63 6f 70 79 20 |iptor is| a copy |
|00002340| 6f 66 20 74 68 65 0a 2e | 49 52 20 64 75 70 20 27 |of the..|IR dup '|
|00002350| 65 64 0a 64 65 73 63 72 | 69 70 74 6f 72 2c 20 61 |ed.descr|iptor, a|
|00002360| 6e 64 20 73 68 61 72 65 | 73 0a 69 74 73 20 70 72 |nd share|s.its pr|
|00002370| 6f 70 65 72 74 69 65 73 | 2e 20 53 70 65 63 69 66 |operties|. Specif|
|00002380| 69 63 61 6c 6c 79 3a 20 | 69 74 20 77 69 6c 6c 20 |ically: |it will |
|00002390| 68 61 76 65 20 74 68 65 | 20 73 61 6d 65 20 72 65 |have the| same re|
|000023a0| 61 64 2f 77 72 69 74 65 | 20 6d 6f 64 65 20 61 73 |ad/write| mode as|
|000023b0| 20 74 68 65 0a 2e 49 52 | 20 64 75 70 20 27 65 64 | the..IR| dup 'ed|
|000023c0| 0a 64 65 73 63 72 69 70 | 74 6f 72 2e 20 49 66 20 |.descrip|tor. If |
|000023d0| 64 65 73 63 72 69 70 74 | 6f 72 20 30 20 69 73 20 |descript|or 0 is |
|000023e0| 6f 70 65 6e 20 66 6f 72 | 20 72 65 61 64 69 6e 67 |open for| reading|
|000023f0| 20 61 6e 64 20 77 72 69 | 74 69 6e 67 2c 20 6f 70 | and wri|ting, op|
|00002400| 65 6e 69 6e 67 0a 2e 42 | 20 2f 64 65 76 2f 66 64 |ening..B| /dev/fd|
|00002410| 2f 30 0a 66 6f 72 20 72 | 65 61 64 69 6e 67 20 77 |/0.for r|eading w|
|00002420| 69 6c 6c 20 72 65 74 75 | 72 6e 20 61 20 77 72 69 |ill retu|rn a wri|
|00002430| 74 61 62 6c 65 2c 20 61 | 73 20 77 65 6c 6c 20 61 |table, a|s well a|
|00002440| 73 20 72 65 61 64 61 62 | 6c 65 2c 20 66 69 6c 65 |s readab|le, file|
|00002450| 0a 64 65 73 63 72 69 70 | 74 6f 72 2e 0a 41 6c 73 |.descrip|tor..Als|
|00002460| 6f 3a 20 74 68 65 20 64 | 65 73 63 72 69 70 74 6f |o: the d|escripto|
|00002470| 72 73 20 73 68 61 72 65 | 20 74 68 65 20 73 61 6d |rs share| the sam|
|00002480| 65 20 72 65 61 64 2f 77 | 72 69 74 65 20 70 6f 69 |e read/w|rite poi|
|00002490| 6e 74 65 72 2c 20 73 6f | 20 73 65 65 6b 73 2c 20 |nter, so| seeks, |
|000024a0| 72 65 61 64 73 20 61 6e | 64 0a 77 72 69 74 65 73 |reads an|d.writes|
|000024b0| 20 6f 6e 20 6f 6e 65 20 | 77 69 6c 6c 20 61 66 66 | on one |will aff|
|000024c0| 65 63 74 20 74 68 65 20 | 6f 74 68 65 72 2e 0a 2e |ect the |other...|
|000024d0| 50 50 0a 57 68 69 6c 65 | 20 6e 6f 74 20 61 20 62 |PP.While| not a b|
|000024e0| 75 67 20 69 6e 20 74 68 | 65 20 64 72 69 76 65 72 |ug in th|e driver|
|000024f0| 20 73 70 65 63 69 66 69 | 63 61 6c 6c 79 2c 20 75 | specifi|cally, u|
|00002500| 73 65 20 6f 66 20 74 68 | 65 73 65 20 66 69 6c 65 |se of th|ese file|
|00002510| 73 20 63 61 6e 20 70 72 | 6f 64 75 63 65 20 6f 64 |s can pr|oduce od|
|00002520| 64 0a 69 6e 74 65 72 61 | 63 74 69 6f 6e 73 20 77 |d.intera|ctions w|
|00002530| 69 74 68 20 70 72 6f 67 | 72 61 6d 73 20 77 68 69 |ith prog|rams whi|
|00002540| 63 68 20 64 6f 6e 27 74 | 20 65 78 70 65 63 74 20 |ch don't| expect |
|00002550| 74 6f 20 68 61 76 65 20 | 74 68 65 69 72 20 66 69 |to have |their fi|
|00002560| 6c 65 0a 64 65 73 63 72 | 69 70 74 6f 72 73 20 73 |le.descr|iptors s|
|00002570| 75 72 72 65 70 74 69 74 | 69 6f 75 73 6c 79 20 61 |urreptit|iously a|
|00002580| 6c 69 61 73 65 64 2e 0a | 2e 50 50 0a 48 61 76 69 |liased..|.PP.Havi|
|00002590| 6e 67 20 6f 6e 6c 79 20 | 32 30 20 65 6e 74 72 69 |ng only |20 entri|
|000025a0| 65 73 20 69 6e 20 74 68 | 65 0a 2e 42 20 2f 64 65 |es in th|e..B /de|
|000025b0| 76 2f 66 64 0a 64 69 72 | 65 63 74 6f 72 79 20 69 |v/fd.dir|ectory i|
|000025c0| 73 20 61 6e 20 61 6e 61 | 63 68 72 6f 6e 69 73 6d |s an ana|chronism|
|000025d0| 3b 20 6d 6f 64 65 72 6e | 20 55 6e 69 78 20 73 79 |; modern| Unix sy|
|000025e0| 73 74 65 6d 73 20 61 6c | 6c 6f 77 0a 61 20 70 72 |stems al|low.a pr|
|000025f0| 6f 63 65 73 73 20 74 6f | 20 68 61 76 65 20 6d 61 |ocess to| have ma|
|00002600| 6e 79 20 6d 6f 72 65 20 | 6f 70 65 6e 20 66 69 6c |ny more |open fil|
|00002610| 65 20 64 65 73 63 72 69 | 70 74 6f 72 73 2e 0a 6e |e descri|ptors..n|
|00002620| 20 74 68 69 73 20 63 61 | 73 65 20 69 74 0a 63 68 | this ca|se it.ch|
|00002630| 65 63 6b 73 20 74 6f 20 | 73 65 65 20 74 68 61 74 |ecks to |see that|
|00002640| 20 74 68 65 20 72 65 61 | 64 2f 77 72 69 74 65 20 | the rea|d/write |
|00002650| 6d 6f 64 65 20 79 6f 75 | 20 61 72 65 20 61 74 74 |mode you| are att|
|00002660| 65 6d 70 74 69 6e 67 20 | 74 6f 20 6f 70 65 6e 0a |empting |to open.|
|00002670| 74 68 65 20 66 69 6c 65 | 20 77 69 74 68 2c 20 69 |the file| with, i|
|00002680| 73 20 63 6f 6d 70 61 74 | 69 62 6c 65 20 77 69 74 |s compat|ible wit|
|00002690| 68 20 74 68 65 20 6d 6f | 64 65 20 6f 66 20 74 68 |h the mo|de of th|
|000026a0| 65 20 65 78 69 73 74 69 | 6e 67 20 66 69 6c 65 20 |e existi|ng file |
|000026b0| 64 65 73 63 72 69 70 74 | 6f 72 2e 0a 54 68 61 74 |descript|or..That|
|000026c0| 20 69 73 2c 20 69 66 20 | 64 65 73 63 72 69 70 74 | is, if |descript|
|000026d0| 6f 72 20 35 20 72 65 66 | 65 72 73 20 74 6f 20 61 |or 5 ref|ers to a|
|000026e0| 20 73 6f 63 6b 65 74 20 | 61 6e 64 0a 69 73 20 6f | socket |and.is o|
|000026f0| 70 65 6e 20 66 6f 72 20 | 77 72 69 74 69 6e 67 2c |pen for |writing,|
|00002700| 20 79 6f 75 20 63 61 6e | 6e 6f 74 20 6f 70 65 6e | you can|not open|
|00002710| 0a 2e 42 20 2f 64 65 76 | 2f 66 64 2f 35 0a 66 6f |..B /dev|/fd/5.fo|
|00002720| 72 20 72 65 61 64 69 6e | 67 2e 0a 2e 50 50 0a 41 |r readin|g...PP.A|
|00002730| 73 20 61 20 6e 6f 74 61 | 74 69 6f 6e 61 6c 20 63 |s a nota|tional c|
|00002740| 6f 6e 76 65 6e 69 65 6e | 63 65 2c 20 74 68 65 20 |onvenien|ce, the |
|00002750| 66 69 6c 65 73 0a 2e 42 | 52 20 2f 64 65 76 2f 73 |files..B|R /dev/s|
|00002760| 74 64 69 6e 20 2c 0a 2e | 42 52 20 2f 64 65 76 2f |tdin ,..|BR /dev/|
|00002770| 73 74 64 6f 75 74 20 2c | 0a 61 6e 64 0a 2e 42 20 |stdout ,|.and..B |
|00002780| 2f 64 65 76 2f 73 74 64 | 65 72 72 0a 61 72 65 20 |/dev/std|err.are |
|00002790| 70 72 6f 76 69 64 65 64 | 20 61 73 20 68 61 72 64 |provided| as hard|
|000027a0| 20 6c 69 6e 6b 73 20 74 | 6f 0a 2e 42 52 20 2f 64 | links t|o..BR /d|
|000027b0| 65 76 2f 66 64 2f 30 20 | 2c 0a 2e 42 52 20 2f 64 |ev/fd/0 |,..BR /d|
|000027c0| 65 76 2f 66 64 2f 31 20 | 2c 0a 61 6e 64 0a 2e 42 |ev/fd/1 |,.and..B|
|000027d0| 52 20 2f 64 65 76 2f 66 | 64 2f 32 0a 72 65 73 70 |R /dev/f|d/2.resp|
|000027e0| 65 63 74 69 76 65 6c 79 | 2e 0a 2e 53 48 20 45 52 |ectively|...SH ER|
|000027f0| 52 4f 52 53 0a 54 68 65 | 20 6e 61 6d 65 64 20 66 |RORS.The| named f|
|00002800| 64 65 76 2d 66 64 2f 64 | 65 76 5f 66 64 2e 63 00 |dev-fd/d|ev_fd.c.|
|00002810| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002820| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002830| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002840| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002850| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002860| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00002870| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00002880| 20 20 32 31 34 32 35 20 | 20 34 34 30 32 31 31 30 | 21425 | 4402110|
|00002890| 35 34 30 20 20 20 36 36 | 35 36 00 20 00 00 00 00 |540 66|56. ....|
|000028a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000028b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000028c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000028d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000028e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000028f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002900| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002910| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002920| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002930| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002940| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002950| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002960| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002970| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002980| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002990| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000029f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002a00| 23 69 66 6e 64 65 66 20 | 6c 69 6e 74 0a 73 74 61 |#ifndef |lint.sta|
|00002a10| 74 69 63 20 63 68 61 72 | 20 72 63 73 69 64 5b 5d |tic char| rcsid[]|
|00002a20| 20 3d 20 22 40 28 23 29 | 24 48 65 61 64 65 72 3a | = "@(#)|$Header:|
|00002a30| 20 64 65 76 5f 66 64 2e | 63 2c 76 20 31 2e 36 20 | dev_fd.|c,v 1.6 |
|00002a40| 38 37 2f 30 37 2f 31 30 | 20 31 30 3a 32 34 3a 31 |87/07/10| 10:24:1|
|00002a50| 33 20 72 6f 6f 74 20 4c | 6f 63 6b 65 64 20 24 22 |3 root L|ocked $"|
|00002a60| 3b 0a 23 65 6e 64 69 66 | 20 6c 69 6e 74 0a 0a 2f |;.#endif| lint../|
|00002a70| 2a 0a 20 2a 20 66 64 2e | 63 09 09 46 72 65 64 20 |*. * fd.|c..Fred |
|00002a80| 42 6c 6f 6e 64 65 72 20 | 2d 20 55 20 6f 66 20 4d |Blonder |- U of M|
|00002a90| 61 72 79 6c 61 6e 64 09 | 31 31 2d 53 65 70 2d 31 |aryland.|11-Sep-1|
|00002aa0| 39 38 34 0a 20 2a 0a 20 | 2a 20 60 60 46 69 6c 65 |984. *. |* ``File|
|00002ab0| 20 44 65 73 63 72 69 70 | 74 6f 72 27 27 20 70 73 | Descrip|tor'' ps|
|00002ac0| 65 75 64 6f 2d 64 65 76 | 69 63 65 20 64 72 69 76 |eudo-dev|ice driv|
|00002ad0| 65 72 2c 20 72 65 77 72 | 69 74 74 65 6e 20 66 6f |er, rewr|itten fo|
|00002ae0| 72 20 42 65 72 6b 65 6c | 65 79 20 34 2e 32 2e 0a |r Berkel|ey 4.2..|
|00002af0| 20 2a 0a 20 2a 20 4f 70 | 65 6e 69 6e 67 20 6d 69 | *. * Op|ening mi|
|00002b00| 6e 6f 72 20 64 65 76 69 | 63 65 20 4e 20 6f 70 65 |nor devi|ce N ope|
|00002b10| 6e 73 20 74 68 65 20 66 | 69 6c 65 20 28 69 66 20 |ns the f|ile (if |
|00002b20| 61 6e 79 29 20 63 6f 6e | 6e 65 63 74 65 64 20 74 |any) con|nected t|
|00002b30| 6f 20 66 69 6c 65 2d 64 | 65 73 63 72 69 70 74 6f |o file-d|escripto|
|00002b40| 72 0a 20 2a 20 4e 20 62 | 65 6c 6f 6e 67 69 6e 67 |r. * N b|elonging|
|00002b50| 20 74 6f 20 74 68 65 20 | 63 61 6c 6c 69 6e 67 20 | to the |calling |
|00002b60| 70 72 6f 63 65 73 73 2e | 20 4e 6f 74 65 20 74 68 |process.| Note th|
|00002b70| 61 74 20 74 68 69 73 20 | 64 72 69 76 65 72 20 63 |at this |driver c|
|00002b80| 6f 6e 73 69 73 74 73 20 | 6f 66 20 6f 6e 6c 79 0a |onsists |of only.|
|00002b90| 20 2a 20 74 68 65 20 60 | 60 6f 70 65 6e 28 29 27 | * the `|`open()'|
|00002ba0| 27 20 72 6f 75 74 69 6e | 65 2c 20 62 65 63 61 75 |' routin|e, becau|
|00002bb0| 73 65 20 61 6c 6c 20 73 | 75 62 73 65 71 75 65 6e |se all s|ubsequen|
|00002bc0| 74 20 72 65 66 65 72 65 | 6e 63 65 73 20 74 6f 20 |t refere|nces to |
|00002bd0| 74 68 69 73 20 66 69 6c | 65 20 77 69 6c 6c 0a 20 |this fil|e will. |
|00002be0| 2a 20 62 65 20 64 69 72 | 65 63 74 20 74 6f 20 74 |* be dir|ect to t|
|00002bf0| 68 65 20 6f 74 68 65 72 | 20 64 72 69 76 65 72 2e |he other| driver.|
|00002c00| 0a 20 2a 0a 20 2a 20 4e | 46 53 20 76 65 72 73 69 |. *. * N|FS versi|
|00002c10| 6f 6e 20 62 79 0a 20 2a | 20 41 72 6e 6f 6c 64 20 |on by. *| Arnold |
|00002c20| 52 6f 62 62 69 6e 73 20 | 2d 2d 20 45 6d 6f 72 79 |Robbins |-- Emory|
|00002c30| 20 55 6e 69 76 65 72 73 | 69 74 79 20 43 6f 6d 70 | Univers|ity Comp|
|00002c40| 75 74 69 6e 67 20 43 65 | 6e 74 65 72 20 2d 2d 20 |uting Ce|nter -- |
|00002c50| 53 75 6d 6d 65 72 20 38 | 37 0a 20 2a 2f 0a 0a 2f |Summer 8|7. */../|
|00002c60| 2a 0a 20 2a 20 24 4c 6f | 67 3a 09 64 65 76 5f 66 |*. * $Lo|g:.dev_f|
|00002c70| 64 2e 63 2c 76 20 24 0a | 20 2a 20 52 65 76 69 73 |d.c,v $.| * Revis|
|00002c80| 69 6f 6e 20 31 2e 36 20 | 20 38 37 2f 30 37 2f 31 |ion 1.6 | 87/07/1|
|00002c90| 30 20 20 31 30 3a 32 34 | 3a 31 33 20 20 72 6f 6f |0 10:24|:13 roo|
|00002ca0| 74 0a 20 2a 20 52 65 6d | 6f 76 65 64 20 64 65 62 |t. * Rem|oved deb|
|00002cb0| 75 67 67 69 6e 67 20 70 | 72 69 6e 74 66 73 2e 20 |ugging p|rintfs. |
|00002cc0| 41 44 52 2e 0a 20 2a 20 | 0a 20 2a 20 52 65 76 69 |ADR.. * |. * Revi|
|00002cd0| 73 69 6f 6e 20 31 2e 35 | 20 20 38 37 2f 30 37 2f |sion 1.5| 87/07/|
|00002ce0| 31 30 20 20 31 30 3a 32 | 30 3a 31 32 20 20 72 6f |10 10:2|0:12 ro|
|00002cf0| 6f 74 0a 20 2a 20 41 64 | 64 65 64 20 45 4e 58 49 |ot. * Ad|ded ENXI|
|00002d00| 4f 20 63 68 65 63 6b 20 | 74 6f 20 69 6e 6f 64 65 |O check |to inode|
|00002d10| 20 76 65 72 73 69 6f 6e | 2e 20 41 44 52 2e 0a 20 | version|. ADR.. |
|00002d20| 2a 20 0a 20 2a 20 52 65 | 76 69 73 69 6f 6e 20 31 |* . * Re|vision 1|
|00002d30| 2e 34 20 20 38 37 2f 30 | 37 2f 30 35 20 20 31 34 |.4 87/0|7/05 14|
|00002d40| 3a 31 39 3a 34 31 20 20 | 72 6f 6f 74 0a 20 2a 20 |:19:41 |root. * |
|00002d50| 41 64 64 65 64 20 4e 4f | 46 49 4c 45 2f 45 4e 58 |Added NO|FILE/ENX|
|00002d60| 49 4f 20 63 68 65 63 6b | 2c 20 73 6f 6d 65 20 6d |IO check|, some m|
|00002d70| 69 6e 6f 72 20 63 6c 65 | 61 6e 75 70 2e 20 41 44 |inor cle|anup. AD|
|00002d80| 52 2e 0a 20 2a 20 0a 20 | 2a 20 52 65 76 69 73 69 |R.. * . |* Revisi|
|00002d90| 6f 6e 20 31 2e 33 20 20 | 38 37 2f 30 37 2f 30 35 |on 1.3 |87/07/05|
|00002da0| 20 20 31 30 3a 34 36 3a | 34 38 20 20 72 6f 6f 74 | 10:46:|48 root|
|00002db0| 0a 20 2a 20 42 72 6f 75 | 67 68 74 20 74 68 65 20 |. * Brou|ght the |
|00002dc0| 63 6f 6d 6d 65 6e 74 73 | 20 69 6e 74 6f 20 73 79 |comments| into sy|
|00002dd0| 6e 63 20 77 69 74 68 20 | 72 65 61 6c 69 74 79 2e |nc with |reality.|
|00002de0| 20 42 75 67 20 66 69 78 | 20 74 6f 20 69 6e 6f 64 | Bug fix| to inod|
|00002df0| 65 20 76 65 72 73 69 6f | 6e 2e 20 41 44 52 2e 0a |e versio|n. ADR..|
|00002e00| 20 2a 20 0a 20 2a 20 52 | 65 76 69 73 69 6f 6e 20 | * . * R|evision |
|00002e10| 31 2e 32 20 20 38 37 2f | 30 37 2f 30 33 20 20 31 |1.2 87/|07/03 1|
|00002e20| 36 3a 35 33 3a 34 36 20 | 20 72 6f 6f 74 0a 20 2a |6:53:46 | root. *|
|00002e30| 20 4e 46 53 20 76 65 72 | 73 69 6f 6e 20 6f 66 20 | NFS ver|sion of |
|00002e40| 74 68 65 20 64 72 69 76 | 65 72 2e 20 57 6f 72 6b |the driv|er. Work|
|00002e50| 73 20 6a 75 73 74 20 66 | 69 6e 65 20 6f 6e 20 61 |s just f|ine on a|
|00002e60| 20 73 75 6e 2e 20 41 44 | 52 2e 0a 20 2a 20 0a 20 | sun. AD|R.. * . |
|00002e70| 2a 20 52 65 76 69 73 69 | 6f 6e 20 31 2e 31 20 20 |* Revisi|on 1.1 |
|00002e80| 38 34 2f 31 32 2f 30 31 | 20 20 32 31 3a 33 38 3a |84/12/01| 21:38:|
|00002e90| 31 37 20 20 63 68 72 69 | 73 0a 20 2a 20 49 6e 69 |17 chri|s. * Ini|
|00002ea0| 74 69 61 6c 20 72 65 76 | 69 73 69 6f 6e 0a 20 2a |tial rev|ision. *|
|00002eb0| 20 0a 20 2a 2f 0a 0a 23 | 69 6e 63 6c 75 64 65 20 | . */..#|include |
|00002ec0| 22 66 64 2e 68 22 0a 23 | 69 66 20 4e 46 44 20 3e |"fd.h".#|if NFD >|
|00002ed0| 20 30 0a 0a 23 69 6e 63 | 6c 75 64 65 20 22 2e 2e | 0..#inc|lude "..|
|00002ee0| 2f 68 2f 70 61 72 61 6d | 2e 68 22 0a 23 69 66 64 |/h/param|.h".#ifd|
|00002ef0| 65 66 20 4e 46 53 0a 23 | 69 6e 63 6c 75 64 65 20 |ef NFS.#|include |
|00002f00| 22 2e 2e 2f 68 2f 74 69 | 6d 65 2e 68 22 0a 23 69 |"../h/ti|me.h".#i|
|00002f10| 6e 63 6c 75 64 65 20 22 | 2e 2e 2f 68 2f 76 6e 6f |nclude "|../h/vno|
|00002f20| 64 65 2e 68 22 0a 23 65 | 6c 73 65 0a 23 69 6e 63 |de.h".#e|lse.#inc|
|00002f30| 6c 75 64 65 20 22 2e 2e | 2f 68 2f 69 6e 6f 64 65 |lude "..|/h/inode|
|00002f40| 2e 68 22 0a 23 65 6e 64 | 69 66 0a 23 69 6e 63 6c |.h".#end|if.#incl|
|00002f50| 75 64 65 20 22 2e 2e 2f | 68 2f 66 69 6c 65 2e 68 |ude "../|h/file.h|
|00002f60| 22 0a 23 69 6e 63 6c 75 | 64 65 20 22 2e 2e 2f 68 |".#inclu|de "../h|
|00002f70| 2f 64 69 72 2e 68 22 0a | 23 69 6e 63 6c 75 64 65 |/dir.h".|#include|
|00002f80| 20 22 2e 2e 2f 68 2f 75 | 73 65 72 2e 68 22 0a 23 | "../h/u|ser.h".#|
|00002f90| 69 6e 63 6c 75 64 65 20 | 22 2e 2e 2f 68 2f 65 72 |include |"../h/er|
|00002fa0| 72 6e 6f 2e 68 22 0a 0a | 2f 2a 0a 20 2a 20 54 48 |rno.h"..|/*. * TH|
|00002fb0| 49 53 20 43 4f 44 45 20 | 4e 45 45 44 53 20 43 4c |IS CODE |NEEDS CL|
|00002fc0| 45 41 4e 49 4e 47 20 41 | 53 20 53 4f 4f 4e 20 41 |EANING A|S SOON A|
|00002fd0| 53 20 41 53 53 49 47 4e | 4d 45 4e 54 53 20 54 4f |S ASSIGN|MENTS TO|
|00002fe0| 20 75 2e 75 5f 2a 20 47 | 4f 20 41 57 41 59 0a 20 | u.u_* G|O AWAY. |
|00002ff0| 2a 2f 0a 0a 2f 2a 0a 20 | 2a 20 54 68 65 20 4e 46 |*/../*. |* The NF|
|00003000| 53 20 6d 6f 64 73 20 61 | 72 65 20 73 6f 20 65 78 |S mods a|re so ex|
|00003010| 74 65 6e 73 69 76 65 20 | 74 68 61 74 20 49 20 68 |tensive |that I h|
|00003020| 61 76 65 20 64 65 63 69 | 64 65 64 20 74 6f 20 70 |ave deci|ded to p|
|00003030| 72 6f 76 69 64 65 20 74 | 77 6f 20 77 68 6f 6c 65 |rovide t|wo whole|
|00003040| 0a 20 2a 20 63 6f 70 69 | 65 73 20 6f 66 20 74 68 |. * copi|es of th|
|00003050| 65 20 72 6f 75 74 69 6e | 65 2c 20 6f 6e 65 20 66 |e routin|e, one f|
|00003060| 6f 72 20 4e 46 53 20 61 | 6e 64 20 6f 6e 65 20 66 |or NFS a|nd one f|
|00003070| 6f 72 20 72 65 67 75 6c | 61 72 20 42 53 44 2c 20 |or regul|ar BSD, |
|00003080| 69 6e 73 74 65 61 64 0a | 20 2a 20 6f 66 20 6d 69 |instead.| * of mi|
|00003090| 78 69 6e 67 20 74 68 65 | 6d 20 75 70 20 77 69 74 |xing the|m up wit|
|000030a0| 68 20 69 66 64 65 66 73 | 2e 20 54 68 65 20 6e 6f |h ifdefs|. The no|
|000030b0| 6e 2d 4e 46 53 20 63 6f | 64 65 20 69 73 20 74 68 |n-NFS co|de is th|
|000030c0| 65 20 6f 72 69 67 69 6e | 61 6c 0a 20 2a 20 76 65 |e origin|al. * ve|
|000030d0| 72 73 69 6f 6e 20 66 72 | 6f 6d 20 55 4d 44 2e 20 |rsion fr|om UMD. |
|000030e0| 20 41 2e 44 2e 52 2e 0a | 20 2a 2f 0a 0a 23 69 66 | A.D.R..| */..#if|
|000030f0| 64 65 66 20 4e 46 53 0a | 2f 2a 0a 20 2a 20 58 58 |def NFS.|/*. * XX|
|00003100| 58 0a 20 2a 0a 20 2a 20 | 57 41 52 4e 49 4e 47 21 |X. *. * |WARNING!|
|00003110| 21 21 21 21 20 54 68 69 | 73 20 70 69 65 63 65 20 |!!!! Thi|s piece |
|00003120| 6f 66 20 63 6f 64 65 20 | 72 65 71 75 69 72 65 73 |of code |requires|
|00003130| 20 74 68 61 74 20 61 20 | 70 61 74 63 68 20 62 65 | that a |patch be|
|00003140| 20 6d 61 64 65 0a 20 2a | 20 74 6f 20 74 68 65 20 | made. *| to the |
|00003150| 73 74 6f 63 6b 20 4e 46 | 53 20 33 2e 32 20 63 6f |stock NF|S 3.2 co|
|00003160| 64 65 20 69 6e 20 73 70 | 65 63 66 73 2f 73 70 65 |de in sp|ecfs/spe|
|00003170| 63 5f 76 6e 6f 64 65 6f | 70 73 2e 63 24 73 70 65 |c_vnodeo|ps.c$spe|
|00003180| 63 5f 6f 70 65 6e 28 29 | 2e 0a 20 2a 20 54 68 65 |c_open()|.. * The|
|00003190| 20 6d 6f 64 69 66 69 63 | 61 74 69 6f 6e 20 69 73 | modific|ation is|
|000031a0| 20 74 6f 20 70 61 73 73 | 20 61 20 70 6f 69 6e 74 | to pass| a point|
|000031b0| 65 72 20 74 6f 20 74 68 | 65 20 76 6e 6f 64 65 20 |er to th|e vnode |
|000031c0| 66 6f 72 20 74 68 69 73 | 20 66 69 6c 65 0a 20 2a |for this| file. *|
|000031d0| 20 69 6e 74 6f 20 74 68 | 69 73 20 72 6f 75 74 69 | into th|is routi|
|000031e0| 6e 65 20 69 6e 20 74 68 | 65 20 63 61 6c 6c 20 74 |ne in th|e call t|
|000031f0| 6f 20 28 2a 63 64 65 77 | 73 77 5b 6d 61 6a 6f 72 |o (*cdew|sw[major|
|00003200| 28 64 65 76 29 5d 29 28 | 29 2c 20 61 73 20 61 20 |(dev)])(|), as a |
|00003210| 66 6f 75 72 74 68 0a 20 | 2a 20 61 72 67 75 6d 65 |fourth. |* argume|
|00003220| 6e 74 2e 0a 20 2a 0a 20 | 2a 20 57 68 79 3f 20 79 |nt.. *. |* Why? y|
|00003230| 6f 75 20 61 73 6b 2e 20 | 57 68 65 6e 20 74 68 69 |ou ask. |When thi|
|00003240| 73 20 64 65 76 69 63 65 | 20 69 73 20 6f 70 65 6e |s device| is open|
|00003250| 65 64 2c 20 6f 70 65 6e | 28 29 20 63 61 6c 6c 73 |ed, open|() calls|
|00003260| 20 63 6f 70 65 6e 28 29 | 20 77 68 69 63 68 20 63 | copen()| which c|
|00003270| 61 6c 6c 73 0a 20 2a 20 | 76 6e 5f 6f 70 65 6e 28 |alls. * |vn_open(|
|00003280| 29 2e 20 4e 6f 77 2c 20 | 74 68 65 20 77 68 6f 6c |). Now, |the whol|
|00003290| 65 20 69 64 65 61 20 62 | 65 68 69 6e 64 20 74 68 |e idea b|ehind th|
|000032a0| 69 73 20 22 64 65 76 69 | 63 65 22 20 69 73 20 74 |is "devi|ce" is t|
|000032b0| 6f 20 73 75 62 73 74 69 | 74 75 74 65 20 61 6e 0a |o substi|tute an.|
|000032c0| 20 2a 20 61 6c 72 65 61 | 64 79 20 6f 70 65 6e 20 | * alrea|dy open |
|000032d0| 66 69 6c 65 20 66 6f 72 | 20 74 68 69 73 20 6f 6e |file for| this on|
|000032e0| 65 2e 20 54 68 65 20 77 | 61 79 20 74 6f 20 64 6f |e. The w|ay to do|
|000032f0| 20 74 68 69 73 20 69 73 | 20 74 6f 20 68 61 6e 64 | this is| to hand|
|00003300| 20 62 61 63 6b 20 75 70 | 20 61 20 76 6e 6f 64 65 | back up| a vnode|
|00003310| 0a 20 2a 20 66 6f 72 20 | 73 61 69 64 20 6f 70 65 |. * for |said ope|
|00003320| 6e 20 66 69 6c 65 2e 20 | 54 68 65 20 72 65 67 75 |n file. |The regu|
|00003330| 6c 61 72 20 69 6e 6f 64 | 65 20 76 65 72 73 69 6f |lar inod|e versio|
|00003340| 6e 20 6f 66 20 74 68 69 | 73 20 63 6f 64 65 20 68 |n of thi|s code h|
|00003350| 61 73 20 69 74 20 65 61 | 73 79 2e 0a 20 2a 20 54 |as it ea|sy.. * T|
|00003360| 68 65 20 66 69 6c 65 20 | 73 74 72 75 63 74 75 72 |he file |structur|
|00003370| 65 20 66 6f 72 20 74 68 | 69 73 20 64 65 76 69 63 |e for th|is devic|
|00003380| 65 20 70 6f 69 6e 74 73 | 20 61 74 20 74 68 65 20 |e points| at the |
|00003390| 64 65 76 69 63 65 27 73 | 20 69 6e 6f 64 65 2e 20 |device's| inode. |
|000033a0| 43 68 75 63 6b 0a 20 2a | 20 74 68 61 74 20 69 6e |Chuck. *| that in|
|000033b0| 6f 64 65 20 61 6e 64 20 | 73 75 62 73 74 69 74 75 |ode and |substitu|
|000033c0| 74 65 20 74 68 65 20 69 | 6e 6f 64 65 20 6f 66 20 |te the i|node of |
|000033d0| 74 68 65 20 61 6c 72 65 | 61 64 79 20 6f 70 65 6e |the alre|ady open|
|000033e0| 20 66 69 6c 65 2e 20 49 | 74 20 69 73 20 6e 6f 74 | file. I|t is not|
|000033f0| 0a 20 2a 20 73 6f 20 65 | 61 73 79 20 69 6e 20 74 |. * so e|asy in t|
|00003400| 68 65 20 4e 46 53 20 63 | 61 73 65 2c 20 62 65 63 |he NFS c|ase, bec|
|00003410| 61 75 73 65 20 2a 74 68 | 65 20 66 69 6c 65 20 73 |ause *th|e file s|
|00003420| 74 72 75 63 74 75 72 65 | 20 64 6f 65 73 20 6e 6f |tructure| does no|
|00003430| 74 20 79 65 74 0a 20 2a | 20 70 6f 69 6e 74 20 61 |t yet. *| point a|
|00003440| 74 20 61 20 76 6e 6f 64 | 65 2a 2e 20 54 68 61 74 |t a vnod|e*. That|
|00003450| 20 69 73 20 6f 6e 6c 79 | 20 64 6f 6e 65 20 69 6e | is only| done in|
|00003460| 20 63 6f 70 65 6e 28 29 | 20 61 66 74 65 72 20 74 | copen()| after t|
|00003470| 68 65 20 76 6e 5f 6f 70 | 65 6e 28 29 0a 20 2a 20 |he vn_op|en(). * |
|00003480| 63 6f 6d 70 6c 65 74 65 | 73 2e 20 52 69 67 68 74 |complete|s. Right|
|00003490| 20 6e 6f 77 2c 20 77 65 | 27 72 65 20 73 74 69 6c | now, we|'re stil|
|000034a0| 6c 20 69 6e 20 74 68 65 | 20 6d 69 64 64 6c 65 20 |l in the| middle |
|000034b0| 6f 66 20 74 68 65 20 6f | 70 65 6e 2e 20 53 6f 20 |of the o|pen. So |
|000034c0| 77 65 20 68 61 76 65 0a | 20 2a 20 6e 6f 20 77 61 |we have.| * no wa|
|000034d0| 79 20 6f 66 20 67 65 74 | 74 69 6e 67 20 61 74 20 |y of get|ting at |
|000034e0| 74 68 65 20 6f 72 69 67 | 69 6e 61 6c 20 76 6e 6f |the orig|inal vno|
|000034f0| 64 65 20 75 6e 6c 65 73 | 73 20 69 74 20 69 73 20 |de unles|s it is |
|00003500| 70 61 73 73 65 64 20 69 | 6e 20 74 6f 20 75 73 2e |passed i|n to us.|
|00003510| 0a 20 2a 20 53 6f 20 74 | 68 61 74 20 69 73 20 77 |. * So t|hat is w|
|00003520| 68 79 20 73 70 65 63 5f | 6f 70 65 6e 28 29 20 68 |hy spec_|open() h|
|00003530| 61 73 20 74 6f 20 70 61 | 73 73 20 61 20 70 6f 69 |as to pa|ss a poi|
|00003540| 6e 74 65 72 20 74 6f 20 | 74 68 65 20 76 6e 6f 64 |nter to |the vnod|
|00003550| 65 20 28 70 6f 69 6e 74 | 65 72 29 0a 20 2a 20 74 |e (point|er). * t|
|00003560| 6f 20 75 73 2c 20 73 6f | 20 77 65 20 63 61 6e 20 |o us, so| we can |
|00003570| 73 77 69 74 63 68 20 69 | 74 20 61 72 6f 75 6e 64 |switch i|t around|
|00003580| 2e 0a 20 2a 2f 0a 0a 66 | 64 6f 70 65 6e 20 28 64 |.. */..f|dopen (d|
|00003590| 65 76 2c 20 6d 6f 64 65 | 2c 20 6e 65 77 64 65 76 |ev, mode|, newdev|
|000035a0| 2c 20 76 70 70 29 0a 64 | 65 76 5f 74 20 64 65 76 |, vpp).d|ev_t dev|
|000035b0| 3b 0a 69 6e 74 20 6d 6f | 64 65 3b 0a 64 65 76 5f |;.int mo|de;.dev_|
|000035c0| 74 20 2a 6e 65 77 64 65 | 76 3b 0a 73 74 72 75 63 |t *newde|v;.struc|
|000035d0| 74 20 76 6e 6f 64 65 20 | 2a 2a 76 70 70 3b 09 2f |t vnode |**vpp;./|
|000035e0| 2a 20 76 6e 6f 64 65 20 | 66 6f 72 20 74 68 69 73 |* vnode |for this|
|000035f0| 20 64 65 76 69 63 65 20 | 2a 2f 0a 7b 0a 09 73 74 | device |*/.{..st|
|00003600| 72 75 63 74 20 66 69 6c | 65 20 2a 66 70 2c 20 2a |ruct fil|e *fp, *|
|00003610| 77 66 70 3b 0a 09 73 74 | 72 75 63 74 20 76 6e 6f |wfp;..st|ruct vno|
|00003620| 64 65 20 2a 76 70 2c 20 | 2a 77 76 70 3b 0a 09 69 |de *vp, |*wvp;..i|
|00003630| 6e 74 20 76 6d 6f 64 65 | 20 3d 20 30 3b 0a 09 69 |nt vmode| = 0;..i|
|00003640| 6e 74 20 72 77 6d 6f 64 | 65 2c 20 65 72 72 6f 72 |nt rwmod|e, error|
|00003650| 3b 0a 0a 09 69 66 20 28 | 6d 69 6e 6f 72 28 64 65 |;...if (|minor(de|
|00003660| 76 29 20 3e 3d 20 4e 4f | 46 49 4c 45 29 09 2f 2a |v) >= NO|FILE)./*|
|00003670| 20 73 61 6e 69 74 79 20 | 63 68 65 63 6b 20 2a 2f | sanity |check */|
|00003680| 0a 09 09 72 65 74 75 72 | 6e 20 28 45 4e 58 49 4f |...retur|n (ENXIO|
|00003690| 29 3b 0a 0a 09 2a 6e 65 | 77 64 65 76 20 3d 20 64 |);...*ne|wdev = d|
|000036a0| 65 76 3b 09 2f 2a 20 58 | 58 58 20 2d 20 66 6f 72 |ev;./* X|XX - for|
|000036b0| 63 65 20 6c 6f 6f 70 20 | 74 65 72 6d 69 6e 61 74 |ce loop |terminat|
|000036c0| 69 6f 6e 20 69 6e 20 73 | 70 65 63 5f 6f 70 65 6e |ion in s|pec_open|
|000036d0| 28 29 20 2a 2f 0a 0a 09 | 2f 2a 0a 09 20 2a 20 4e |() */...|/*.. * N|
|000036e0| 6f 74 65 20 74 68 65 20 | 68 6f 72 72 69 64 20 6b |ote the |horrid k|
|000036f0| 6c 75 64 67 65 20 68 65 | 72 65 3a 20 75 2e 75 5f |ludge he|re: u.u_|
|00003700| 72 2e 72 5f 76 61 6c 31 | 20 63 6f 6e 74 61 69 6e |r.r_val1| contain|
|00003710| 73 20 74 68 65 20 76 61 | 6c 75 65 0a 09 20 2a 20 |s the va|lue.. * |
|00003720| 6f 66 20 74 68 65 20 6e | 65 77 20 66 69 6c 65 20 |of the n|ew file |
|00003730| 64 65 73 63 72 69 70 74 | 6f 72 2c 20 77 68 69 63 |descript|or, whic|
|00003740| 68 20 68 61 73 20 6e 6f | 74 20 62 65 65 6e 20 64 |h has no|t been d|
|00003750| 69 73 74 75 72 62 65 64 | 20 73 69 6e 63 65 0a 09 |isturbed| since..|
|00003760| 20 2a 20 69 74 20 77 61 | 73 20 61 6c 6c 6f 63 61 | * it wa|s alloca|
|00003770| 74 65 64 2e 0a 09 20 2a | 2f 0a 0a 09 69 66 20 28 |ted... *|/...if (|
|00003780| 28 66 70 20 3d 20 67 65 | 74 66 28 75 2e 75 5f 72 |(fp = ge|tf(u.u_r|
|00003790| 2e 72 5f 76 61 6c 31 29 | 29 20 3d 3d 20 4e 55 4c |.r_val1)|) == NUL|
|000037a0| 4c 29 0a 09 09 72 65 74 | 75 72 6e 20 28 75 2e 75 |L)...ret|urn (u.u|
|000037b0| 5f 65 72 72 6f 72 29 3b | 0a 0a 09 69 66 20 28 28 |_error);|...if ((|
|000037c0| 77 66 70 20 3d 20 67 65 | 74 66 28 6d 69 6e 6f 72 |wfp = ge|tf(minor|
|000037d0| 28 64 65 76 29 29 29 20 | 3d 3d 20 4e 55 4c 4c 29 |(dev))) |== NULL)|
|000037e0| 0a 09 09 72 65 74 75 72 | 6e 20 28 75 2e 75 5f 65 |...retur|n (u.u_e|
|000037f0| 72 72 6f 72 29 3b 0a 0a | 09 2f 2a 0a 09 20 2a 20 |rror);..|./*.. * |
|00003800| 57 65 20 6d 75 73 74 20 | 65 78 70 6c 69 63 69 74 |We must |explicit|
|00003810| 6c 79 20 74 65 73 74 20 | 66 6f 72 20 74 68 69 73 |ly test |for this|
|00003820| 20 63 61 73 65 20 62 65 | 63 61 75 73 65 20 75 66 | case be|cause uf|
|00003830| 61 6c 6c 6f 63 28 29 20 | 6d 61 79 0a 09 20 2a 20 |alloc() |may.. * |
|00003840| 68 61 76 65 20 61 6c 6c | 6f 63 61 74 65 64 20 75 |have all|ocated u|
|00003850| 73 20 74 68 65 20 73 61 | 6d 65 20 66 69 6c 65 20 |s the sa|me file |
|00003860| 64 65 73 72 69 70 74 6f | 72 20 77 65 20 61 72 65 |desripto|r we are|
|00003870| 20 72 65 66 65 72 72 69 | 6e 67 0a 09 20 2a 20 74 | referri|ng.. * t|
|00003880| 6f 2c 20 69 66 20 74 68 | 65 20 70 72 6f 63 63 65 |o, if th|e procce|
|00003890| 73 73 20 72 65 66 65 72 | 72 65 64 20 74 6f 20 61 |ss refer|red to a|
|000038a0| 6e 20 69 6e 76 61 6c 69 | 64 20 28 63 6c 6f 73 65 |n invali|d (close|
|000038b0| 64 29 20 64 65 73 63 72 | 69 70 74 6f 72 2e 0a 09 |d) descr|iptor...|
|000038c0| 20 2a 20 4f 72 64 69 6e | 61 72 69 6c 79 20 74 68 | * Ordin|arily th|
|000038d0| 69 73 20 77 6f 75 6c 64 | 20 62 65 20 63 61 75 67 |is would| be caug|
|000038e0| 68 74 20 62 79 20 67 65 | 74 66 28 29 2c 20 62 75 |ht by ge|tf(), bu|
|000038f0| 74 20 62 79 20 74 68 65 | 20 74 69 6d 65 20 77 65 |t by the| time we|
|00003900| 0a 09 20 2a 20 72 65 61 | 63 68 20 74 68 69 73 20 |.. * rea|ch this |
|00003910| 72 6f 75 74 69 6e 65 20 | 75 5f 70 6f 66 69 6c 65 |routine |u_pofile|
|00003920| 5b 6d 69 6e 6f 72 28 64 | 65 76 29 5d 20 63 6f 75 |[minor(d|ev)] cou|
|00003930| 6c 64 20 61 6c 72 65 61 | 64 79 20 62 65 20 73 65 |ld alrea|dy be se|
|00003940| 74 0a 09 20 2a 20 74 6f | 20 70 6f 69 6e 74 20 74 |t.. * to| point t|
|00003950| 6f 20 6f 75 72 20 66 69 | 6c 65 20 73 74 72 75 63 |o our fi|le struc|
|00003960| 74 2e 0a 09 20 2a 2f 0a | 09 69 66 20 28 66 70 20 |t... */.|.if (fp |
|00003970| 3d 3d 20 77 66 70 29 0a | 09 09 72 65 74 75 72 6e |== wfp).|..return|
|00003980| 20 28 45 42 41 44 46 29 | 3b 0a 0a 09 76 70 20 3d | (EBADF)|;...vp =|
|00003990| 20 2a 76 70 70 3b 0a 0a | 09 2f 2a 0a 09 20 2a 20 | *vpp;..|./*.. * |
|000039a0| 46 61 6b 65 20 61 20 60 | 60 64 75 70 28 29 27 27 |Fake a `|`dup()''|
|000039b0| 20 73 79 73 20 63 61 6c | 6c 20 69 66 20 69 74 20 | sys cal|l if it |
|000039c0| 69 73 6e 27 74 20 61 20 | 76 6e 6f 64 65 2e 0a 09 |isn't a |vnode...|
|000039d0| 20 2a 2f 0a 09 69 66 20 | 28 77 66 70 2d 3e 66 5f | */..if |(wfp->f_|
|000039e0| 74 79 70 65 20 21 3d 20 | 44 54 59 50 45 5f 56 4e |type != |DTYPE_VN|
|000039f0| 4f 44 45 29 20 7b 0a 09 | 09 2f 2a 0a 09 09 20 2a |ODE) {..|./*... *|
|00003a00| 20 43 68 65 63 6b 20 74 | 68 61 74 20 74 68 65 20 | Check t|hat the |
|00003a10| 6d 6f 64 65 20 74 68 65 | 20 66 69 6c 65 20 69 73 |mode the| file is|
|00003a20| 20 62 65 69 6e 67 20 6f | 70 65 6e 65 64 0a 09 09 | being o|pened...|
|00003a30| 20 2a 20 66 6f 72 20 69 | 73 20 63 6f 6e 73 69 73 | * for i|s consis|
|00003a40| 74 65 6e 74 20 77 69 74 | 68 20 74 68 65 20 6d 6f |tent wit|h the mo|
|00003a50| 64 65 20 6f 66 20 74 68 | 65 20 65 78 69 73 74 69 |de of th|e existi|
|00003a60| 6e 67 0a 09 09 20 2a 20 | 64 65 73 63 72 69 70 74 |ng... * |descript|
|00003a70| 6f 72 2e 20 54 68 69 73 | 20 69 73 6e 27 74 20 61 |or. This| isn't a|
|00003a80| 73 20 63 6c 65 61 6e 20 | 61 73 20 69 74 20 73 68 |s clean |as it sh|
|00003a90| 6f 75 6c 64 20 62 65 2c | 0a 09 09 20 2a 20 62 75 |ould be,|... * bu|
|00003aa0| 74 20 74 68 69 73 20 65 | 6e 74 69 72 65 20 64 72 |t this e|ntire dr|
|00003ab0| 69 76 65 72 20 69 73 20 | 61 20 72 65 61 6c 20 6b |iver is |a real k|
|00003ac0| 6c 75 64 67 65 20 61 6e | 79 77 61 79 2e 0a 09 09 |ludge an|yway....|
|00003ad0| 20 2a 2f 0a 09 09 72 77 | 6d 6f 64 65 20 3d 20 6d | */...rw|mode = m|
|00003ae0| 6f 64 65 20 26 20 28 46 | 52 45 41 44 7c 46 57 52 |ode & (F|READ|FWR|
|00003af0| 49 54 45 29 3b 0a 09 09 | 69 66 20 28 28 77 66 70 |ITE);...|if ((wfp|
|00003b00| 2d 3e 66 5f 66 6c 61 67 | 20 26 20 72 77 6d 6f 64 |->f_flag| & rwmod|
|00003b10| 65 29 20 21 3d 20 72 77 | 6d 6f 64 65 29 0a 09 09 |e) != rw|mode)...|
|00003b20| 09 72 65 74 75 72 6e 20 | 28 45 41 43 43 45 53 29 |.return |(EACCES)|
|00003b30| 3b 0a 0a 09 09 2f 2a 20 | 44 65 6c 65 74 65 20 72 |;..../* |Delete r|
|00003b40| 65 66 65 72 65 6e 63 65 | 73 20 74 6f 20 74 68 69 |eference|s to thi|
|00003b50| 73 20 70 73 65 75 64 6f | 2d 64 65 76 69 63 65 2e |s pseudo|-device.|
|00003b60| 20 2a 2f 0a 09 09 56 4e | 5f 52 45 4c 45 28 76 70 | */...VN|_RELE(vp|
|00003b70| 29 3b 09 09 2f 2a 20 43 | 68 75 63 6b 20 74 68 65 |);../* C|huck the|
|00003b80| 20 76 6e 6f 64 65 2e 20 | 2a 2f 0a 09 09 66 70 2d | vnode. |*/...fp-|
|00003b90| 3e 66 5f 63 6f 75 6e 74 | 20 3d 20 30 3b 09 2f 2a |>f_count| = 0;./*|
|00003ba0| 20 43 68 75 63 6b 20 74 | 68 65 20 66 69 6c 65 20 | Chuck t|he file |
|00003bb0| 73 74 72 75 63 74 75 72 | 65 2e 20 2a 2f 0a 09 09 |structur|e. */...|
|00003bc0| 63 72 66 72 65 65 28 66 | 70 2d 3e 66 5f 63 72 65 |crfree(f|p->f_cre|
|00003bd0| 64 29 3b 0a 09 09 2f 2a | 20 44 75 70 20 74 68 65 |d);.../*| Dup the|
|00003be0| 20 66 69 6c 65 20 64 65 | 73 63 72 69 70 74 6f 72 | file de|scriptor|
|00003bf0| 2e 20 2a 2f 0a 09 09 64 | 75 70 69 74 28 75 2e 75 |. */...d|upit(u.u|
|00003c00| 5f 72 2e 72 5f 76 61 6c | 31 2c 20 77 66 70 2c 20 |_r.r_val|1, wfp, |
|00003c10| 75 2e 75 5f 70 6f 66 69 | 6c 65 5b 6d 69 6e 6f 72 |u.u_pofi|le[minor|
|00003c20| 28 64 65 76 29 5d 29 3b | 0a 09 09 2a 76 70 70 20 |(dev)]);|...*vpp |
|00003c30| 3d 20 28 73 74 72 75 63 | 74 20 76 6e 6f 64 65 20 |= (struc|t vnode |
|00003c40| 2a 29 77 66 70 2d 3e 66 | 5f 64 61 74 61 3b 09 2f |*)wfp->f|_data;./|
|00003c50| 2a 20 6e 65 65 64 65 64 | 3f 20 2a 2f 0a 09 09 72 |* needed|? */...r|
|00003c60| 65 74 75 72 6e 20 28 30 | 29 3b 0a 09 7d 0a 0a 09 |eturn (0|);..}...|
|00003c70| 2f 2a 0a 09 20 2a 20 6e | 6f 77 20 68 61 76 65 20 |/*.. * n|ow have |
|00003c80| 61 20 72 65 67 75 6c 61 | 72 20 76 6e 6f 64 65 2e |a regula|r vnode.|
|00003c90| 0a 09 20 2a 2f 0a 09 65 | 72 72 6f 72 20 3d 20 30 |.. */..e|rror = 0|
|00003ca0| 3b 0a 09 77 76 70 20 3d | 20 28 73 74 72 75 63 74 |;..wvp =| (struct|
|00003cb0| 20 76 6e 6f 64 65 20 2a | 29 77 66 70 2d 3e 66 5f | vnode *|)wfp->f_|
|00003cc0| 64 61 74 61 3b 0a 0a 09 | 2f 2a 0a 09 20 2a 20 53 |data;...|/*.. * S|
|00003cd0| 69 6e 63 65 20 77 65 27 | 72 65 20 6f 70 65 6e 69 |ince we'|re openi|
|00003ce0| 6e 67 20 61 20 66 69 6c | 65 20 61 67 61 69 6e 2c |ng a fil|e again,|
|00003cf0| 20 77 65 20 72 75 6e 20 | 74 68 72 6f 75 67 68 20 | we run |through |
|00003d00| 61 6c 6c 20 74 68 65 0a | 09 20 2a 20 70 65 72 6d |all the.|. * perm|
|00003d10| 69 73 73 69 6f 6e 20 63 | 68 65 63 6b 73 20 73 6f |ission c|hecks so|
|00003d20| 20 74 68 69 73 20 63 61 | 6e 27 74 20 62 65 20 75 | this ca|n't be u|
|00003d30| 73 65 64 20 61 73 20 61 | 20 6c 6f 6f 70 68 6f 6c |sed as a| loophol|
|00003d40| 65 20 74 6f 0a 09 20 2a | 20 67 65 74 20 61 63 63 |e to.. *| get acc|
|00003d50| 65 73 73 20 74 6f 20 61 | 20 66 69 6c 65 20 77 65 |ess to a| file we|
|00003d60| 20 73 68 6f 75 6c 64 6e | 27 74 20 68 61 76 65 2e | shouldn|'t have.|
|00003d70| 20 20 28 47 52 4f 54 29 | 0a 09 20 2a 2f 0a 09 69 | (GROT)|.. */..i|
|00003d80| 66 20 28 6d 6f 64 65 20 | 26 20 46 52 45 41 44 20 |f (mode |& FREAD |
|00003d90| 26 26 20 28 65 72 72 6f | 72 20 3d 20 56 4f 50 5f |&& (erro|r = VOP_|
|00003da0| 41 43 43 45 53 53 28 77 | 76 70 2c 20 56 52 45 41 |ACCESS(w|vp, VREA|
|00003db0| 44 2c 20 75 2e 75 5f 63 | 72 65 64 29 29 29 0a 09 |D, u.u_c|red)))..|
|00003dc0| 09 67 6f 74 6f 20 62 61 | 64 3b 0a 09 69 66 20 28 |.goto ba|d;..if (|
|00003dd0| 6d 6f 64 65 20 26 20 28 | 46 57 52 49 54 45 7c 46 |mode & (|FWRITE|F|
|00003de0| 54 52 55 4e 43 29 29 20 | 7b 0a 09 09 69 66 20 28 |TRUNC)) |{...if (|
|00003df0| 76 70 2d 3e 76 5f 74 79 | 70 65 20 3d 3d 20 56 44 |vp->v_ty|pe == VD|
|00003e00| 49 52 29 20 7b 0a 09 09 | 09 65 72 72 6f 72 20 3d |IR) {...|.error =|
|00003e10| 20 45 49 53 44 49 52 3b | 0a 09 09 09 67 6f 74 6f | EISDIR;|....goto|
|00003e20| 20 62 61 64 3b 0a 09 09 | 7d 0a 09 09 69 66 20 28 | bad;...|}...if (|
|00003e30| 28 65 72 72 6f 72 20 3d | 20 56 4f 50 5f 41 43 43 |(error =| VOP_ACC|
|00003e40| 45 53 53 28 77 76 70 2c | 20 56 57 52 49 54 45 2c |ESS(wvp,| VWRITE,|
|00003e50| 20 75 2e 75 5f 63 72 65 | 64 29 29 29 0a 09 09 09 | u.u_cre|d)))....|
|00003e60| 67 6f 74 6f 20 62 61 64 | 3b 0a 09 7d 0a 0a 09 2f |goto bad|;..}.../|
|00003e70| 2a 0a 09 20 2a 20 54 68 | 65 20 66 69 6c 65 20 6d |*.. * Th|e file m|
|00003e80| 75 73 74 20 61 6c 77 61 | 79 73 20 65 78 69 73 74 |ust alwa|ys exist|
|00003e90| 2c 20 73 6f 20 77 65 20 | 64 6f 6e 27 74 20 65 76 |, so we |don't ev|
|00003ea0| 65 6e 20 62 6f 74 68 65 | 72 20 74 65 73 74 69 6e |en bothe|r testin|
|00003eb0| 67 0a 09 20 2a 20 66 6f | 72 20 69 74 73 20 70 72 |g.. * fo|r its pr|
|00003ec0| 65 73 65 6e 63 65 2e 0a | 09 20 2a 2f 0a 09 69 66 |esence..|. */..if|
|00003ed0| 20 28 28 6d 6f 64 65 20 | 26 20 28 46 43 52 45 41 | ((mode |& (FCREA|
|00003ee0| 54 7c 46 45 58 43 4c 29 | 29 20 3d 3d 20 28 46 43 |T|FEXCL)|) == (FC|
|00003ef0| 52 45 41 54 7c 46 45 58 | 43 4c 29 29 20 7b 0a 09 |REAT|FEX|CL)) {..|
|00003f00| 09 65 72 72 6f 72 20 3d | 20 45 45 58 49 53 54 3b |.error =| EEXIST;|
|00003f10| 0a 09 09 67 6f 74 6f 20 | 62 61 64 3b 0a 09 7d 0a |...goto |bad;..}.|
|00003f20| 0a 09 2f 2a 0a 09 20 2a | 20 54 68 69 73 20 6d 61 |../*.. *| This ma|
|00003f30| 79 20 6e 6f 74 20 6d 61 | 6b 65 20 61 6e 79 20 73 |y not ma|ke any s|
|00003f40| 65 6e 73 65 2c 20 62 75 | 74 20 49 27 6d 20 70 61 |ense, bu|t I'm pa|
|00003f50| 72 61 6e 6f 69 64 20 61 | 6e 64 20 66 69 67 75 72 |ranoid a|nd figur|
|00003f60| 65 20 74 68 61 74 0a 09 | 20 2a 20 69 74 27 73 20 |e that..| * it's |
|00003f70| 70 72 6f 62 61 62 6c 79 | 20 61 6e 20 65 72 72 6f |probably| an erro|
|00003f80| 72 2e 0a 09 20 2a 2f 0a | 09 69 66 20 28 6d 6f 64 |r... */.|.if (mod|
|00003f90| 65 20 26 20 46 54 52 55 | 4e 43 29 20 7b 0a 09 09 |e & FTRU|NC) {...|
|00003fa0| 65 72 72 6f 72 20 3d 20 | 45 42 55 53 59 3b 0a 09 |error = |EBUSY;..|
|00003fb0| 09 67 6f 74 6f 20 62 61 | 64 3b 0a 09 7d 0a 0a 09 |.goto ba|d;..}...|
|00003fc0| 2f 2a 20 43 61 6c 6c 20 | 74 68 65 20 64 65 76 69 |/* Call |the devi|
|00003fd0| 63 65 2d 73 70 65 63 69 | 66 69 63 20 6f 70 65 6e |ce-speci|fic open|
|00003fe0| 20 72 6f 75 74 69 6e 65 | 2c 20 69 66 20 61 6e 79 | routine|, if any|
|00003ff0| 2e 20 2a 2f 0a 09 76 6d | 6f 64 65 20 3d 20 6d 6f |. */..vm|ode = mo|
|00004000| 64 65 20 26 20 7e 28 46 | 43 52 45 41 54 20 7c 20 |de & ~(F|CREAT | |
|00004010| 46 45 58 43 4c 29 3b 0a | 09 69 66 20 28 77 76 70 |FEXCL);.|.if (wvp|
|00004020| 2d 3e 76 5f 74 79 70 65 | 20 21 3d 20 56 52 45 47 |->v_type| != VREG|
|00004030| 20 26 26 0a 09 09 09 28 | 65 72 72 6f 72 20 3d 20 | &&....(|error = |
|00004040| 56 4f 50 5f 4f 50 45 4e | 28 26 77 76 70 2c 20 76 |VOP_OPEN|(&wvp, v|
|00004050| 6d 6f 64 65 2c 20 75 2e | 75 5f 63 72 65 64 29 29 |mode, u.|u_cred))|
|00004060| 20 21 3d 20 30 29 0a 09 | 09 67 6f 74 6f 20 62 61 | != 0)..|.goto ba|
|00004070| 64 3b 0a 0a 09 2f 2a 0a | 09 20 2a 20 4d 61 64 65 |d;.../*.|. * Made|
|00004080| 20 69 74 20 74 68 69 73 | 20 66 61 72 2c 20 6e 6f | it this| far, no|
|00004090| 77 20 72 65 74 75 72 6e | 20 74 68 65 20 6f 74 68 |w return| the oth|
|000040a0| 65 72 20 76 6e 6f 64 65 | 20 62 61 63 6b 20 75 70 |er vnode| back up|
|000040b0| 20 74 68 65 0a 09 20 2a | 20 63 61 6c 6c 20 63 68 | the.. *| call ch|
|000040c0| 61 69 6e 20 66 6f 72 20 | 69 6e 73 65 72 74 69 6f |ain for |insertio|
|000040d0| 6e 20 69 6e 74 6f 20 74 | 68 65 20 66 69 6c 65 20 |n into t|he file |
|000040e0| 74 61 62 6c 65 20 65 6e | 74 72 79 2e 0a 09 20 2a |table en|try... *|
|000040f0| 2f 0a 09 56 4e 5f 52 45 | 4c 45 28 76 70 29 3b 09 |/..VN_RE|LE(vp);.|
|00004100| 09 2f 2a 20 57 65 20 64 | 6f 6e 27 74 20 6e 65 65 |./* We d|on't nee|
|00004110| 64 20 74 68 69 73 20 61 | 6e 79 6d 6f 72 65 2e 20 |d this a|nymore. |
|00004120| 2a 2f 0a 09 77 76 70 2d | 3e 76 5f 63 6f 75 6e 74 |*/..wvp-|>v_count|
|00004130| 2b 2b 3b 0a 09 2a 76 70 | 70 20 3d 20 77 76 70 3b |++;..*vp|p = wvp;|
|00004140| 0a 09 72 65 74 75 72 6e | 20 28 30 29 3b 0a 0a 62 |..return| (0);..b|
|00004150| 61 64 3a 0a 09 72 65 74 | 75 72 6e 20 28 65 72 72 |ad:..ret|urn (err|
|00004160| 6f 72 29 3b 0a 7d 0a 0a | 23 65 6c 73 65 09 2f 2a |or);.}..|#else./*|
|00004170| 20 21 20 4e 46 53 20 2a | 2f 0a 0a 66 64 6f 70 65 | ! NFS *|/..fdope|
|00004180| 6e 28 64 65 76 2c 20 6d | 6f 64 65 29 0a 64 65 76 |n(dev, m|ode).dev|
|00004190| 5f 74 20 64 65 76 3b 0a | 69 6e 74 20 6d 6f 64 65 |_t dev;.|int mode|
|000041a0| 3b 0a 7b 0a 09 73 74 72 | 75 63 74 20 66 69 6c 65 |;.{..str|uct file|
|000041b0| 20 2a 66 70 2c 20 2a 77 | 66 70 3b 0a 09 73 74 72 | *fp, *w|fp;..str|
|000041c0| 75 63 74 20 69 6e 6f 64 | 65 20 2a 69 70 2c 20 2a |uct inod|e *ip, *|
|000041d0| 77 69 70 3b 0a 09 69 6e | 74 20 72 77 6d 6f 64 65 |wip;..in|t rwmode|
|000041e0| 2c 20 65 72 72 6f 72 3b | 0a 0a 09 2f 2a 20 74 68 |, error;|.../* th|
|000041f0| 69 73 20 63 68 65 63 6b | 20 61 64 64 65 64 20 62 |is check| added b|
|00004200| 79 20 41 44 52 20 2a 2f | 0a 09 69 66 20 28 6d 69 |y ADR */|..if (mi|
|00004210| 6e 6f 72 28 64 65 76 29 | 20 3e 3d 20 4e 4f 46 49 |nor(dev)| >= NOFI|
|00004220| 4c 45 29 09 2f 2a 20 73 | 61 6e 69 74 79 20 63 68 |LE)./* s|anity ch|
|00004230| 65 63 6b 20 2a 2f 0a 09 | 09 72 65 74 75 72 6e 20 |eck */..|.return |
|00004240| 28 45 4e 58 49 4f 29 3b | 0a 0a 09 2f 2a 0a 09 20 |(ENXIO);|.../*.. |
|00004250| 2a 20 4e 6f 74 65 20 74 | 68 65 20 68 6f 72 72 69 |* Note t|he horri|
|00004260| 64 20 6b 6c 75 64 67 65 | 20 68 65 72 65 3a 20 75 |d kludge| here: u|
|00004270| 2e 75 5f 72 2e 72 5f 76 | 61 6c 31 20 63 6f 6e 74 |.u_r.r_v|al1 cont|
|00004280| 61 69 6e 73 20 74 68 65 | 20 76 61 6c 75 65 0a 09 |ains the| value..|
|00004290| 20 2a 20 6f 66 20 74 68 | 65 20 6e 65 77 20 66 69 | * of th|e new fi|
|000042a0| 6c 65 20 64 65 73 63 72 | 69 70 74 6f 72 2c 20 77 |le descr|iptor, w|
|000042b0| 68 69 63 68 20 68 61 73 | 20 6e 6f 74 20 62 65 65 |hich has| not bee|
|000042c0| 6e 20 64 69 73 74 75 72 | 62 65 64 20 73 69 6e 63 |n distur|bed sinc|
|000042d0| 65 0a 09 20 2a 20 69 74 | 20 77 61 73 20 61 6c 6c |e.. * it| was all|
|000042e0| 6f 63 61 74 65 64 2e 0a | 09 20 2a 2f 0a 09 69 66 |ocated..|. */..if|
|000042f0| 20 28 28 66 70 20 3d 20 | 67 65 74 66 28 75 2e 75 | ((fp = |getf(u.u|
|00004300| 5f 72 2e 72 5f 76 61 6c | 31 29 29 20 3d 3d 20 4e |_r.r_val|1)) == N|
|00004310| 55 4c 4c 29 0a 09 09 72 | 65 74 75 72 6e 20 28 75 |ULL)...r|eturn (u|
|00004320| 2e 75 5f 65 72 72 6f 72 | 29 3b 0a 0a 09 69 66 20 |.u_error|);...if |
|00004330| 28 28 77 66 70 20 3d 20 | 67 65 74 66 28 6d 69 6e |((wfp = |getf(min|
|00004340| 6f 72 28 64 65 76 29 29 | 29 20 3d 3d 20 4e 55 4c |or(dev))|) == NUL|
|00004350| 4c 29 0a 09 09 72 65 74 | 75 72 6e 20 28 75 2e 75 |L)...ret|urn (u.u|
|00004360| 5f 65 72 72 6f 72 29 3b | 0a 0a 09 2f 2a 0a 09 20 |_error);|.../*.. |
|00004370| 2a 20 57 65 20 6d 75 73 | 74 20 65 78 70 6c 69 63 |* We mus|t explic|
|00004380| 69 74 6c 79 20 74 65 73 | 74 20 66 6f 72 20 74 68 |itly tes|t for th|
|00004390| 69 73 20 63 61 73 65 20 | 62 65 63 61 75 73 65 20 |is case |because |
|000043a0| 75 66 61 6c 6c 6f 63 28 | 29 20 6d 61 79 0a 09 20 |ufalloc(|) may.. |
|000043b0| 2a 20 68 61 76 65 20 61 | 6c 6c 6f 63 61 74 65 64 |* have a|llocated|
|000043c0| 20 75 73 20 74 68 65 20 | 73 61 6d 65 20 66 69 6c | us the |same fil|
|000043d0| 65 20 64 65 73 72 69 70 | 74 6f 72 20 77 65 20 61 |e desrip|tor we a|
|000043e0| 72 65 20 72 65 66 65 72 | 72 69 6e 67 0a 09 20 2a |re refer|ring.. *|
|000043f0| 20 74 6f 2c 20 69 66 20 | 74 68 65 20 70 72 6f 63 | to, if |the proc|
|00004400| 63 65 73 73 20 72 65 66 | 65 72 72 65 64 20 74 6f |cess ref|erred to|
|00004410| 20 61 6e 20 69 6e 76 61 | 6c 69 64 20 28 63 6c 6f | an inva|lid (clo|
|00004420| 73 65 64 29 20 64 65 73 | 63 72 69 70 74 6f 72 2e |sed) des|criptor.|
|00004430| 0a 09 20 2a 20 4f 72 64 | 69 6e 61 72 69 6c 79 20 |.. * Ord|inarily |
|00004440| 74 68 69 73 20 77 6f 75 | 6c 64 20 62 65 20 63 61 |this wou|ld be ca|
|00004450| 75 67 68 74 20 62 79 20 | 67 65 74 66 28 29 2c 20 |ught by |getf(), |
|00004460| 62 75 74 20 62 79 20 74 | 68 65 20 74 69 6d 65 20 |but by t|he time |
|00004470| 77 65 0a 09 20 2a 20 72 | 65 61 63 68 20 74 68 69 |we.. * r|each thi|
|00004480| 73 20 72 6f 75 74 69 6e | 65 20 75 5f 70 6f 66 69 |s routin|e u_pofi|
|00004490| 6c 65 5b 6d 69 6e 6f 72 | 28 64 65 76 29 5d 20 63 |le[minor|(dev)] c|
|000044a0| 6f 75 6c 64 20 61 6c 72 | 65 61 64 79 20 62 65 20 |ould alr|eady be |
|000044b0| 73 65 74 0a 09 20 2a 20 | 74 6f 20 70 6f 69 6e 74 |set.. * |to point|
|000044c0| 20 74 6f 20 6f 75 72 20 | 66 69 6c 65 20 73 74 72 | to our |file str|
|000044d0| 75 63 74 2e 0a 09 20 2a | 2f 0a 09 69 66 20 28 66 |uct... *|/..if (f|
|000044e0| 70 20 3d 3d 20 77 66 70 | 29 0a 09 09 72 65 74 75 |p == wfp|)...retu|
|000044f0| 72 6e 20 28 45 42 41 44 | 46 29 3b 0a 0a 09 69 70 |rn (EBAD|F);...ip|
|00004500| 20 3d 20 28 73 74 72 75 | 63 74 20 69 6e 6f 64 65 | = (stru|ct inode|
|00004510| 20 2a 29 66 70 2d 3e 66 | 5f 64 61 74 61 3b 0a 0a | *)fp->f|_data;..|
|00004520| 09 2f 2a 0a 09 20 2a 20 | 46 61 6b 65 20 61 20 60 |./*.. * |Fake a `|
|00004530| 60 64 75 70 28 29 27 27 | 20 73 79 73 20 63 61 6c |`dup()''| sys cal|
|00004540| 6c 20 69 66 20 69 74 20 | 69 73 6e 27 74 20 61 6e |l if it |isn't an|
|00004550| 20 69 6e 6f 64 65 2e 0a | 09 20 2a 2f 0a 09 69 66 | inode..|. */..if|
|00004560| 20 28 77 66 70 2d 3e 66 | 5f 74 79 70 65 20 21 3d | (wfp->f|_type !=|
|00004570| 20 44 54 59 50 45 5f 49 | 4e 4f 44 45 29 20 7b 0a | DTYPE_I|NODE) {.|
|00004580| 09 09 2f 2a 0a 09 09 20 | 2a 20 43 68 65 63 6b 20 |../*... |* Check |
|00004590| 74 68 61 74 20 74 68 65 | 20 6d 6f 64 65 20 74 68 |that the| mode th|
|000045a0| 65 20 66 69 6c 65 20 69 | 73 20 62 65 69 6e 67 20 |e file i|s being |
|000045b0| 6f 70 65 6e 65 64 0a 09 | 09 20 2a 20 66 6f 72 20 |opened..|. * for |
|000045c0| 69 73 20 63 6f 6e 73 69 | 73 74 65 6e 74 20 77 69 |is consi|stent wi|
|000045d0| 74 68 20 74 68 65 20 6d | 6f 64 65 20 6f 66 20 74 |th the m|ode of t|
|000045e0| 68 65 20 65 78 69 73 74 | 69 6e 67 0a 09 09 20 2a |he exist|ing... *|
|000045f0| 20 64 65 73 63 72 69 70 | 74 6f 72 2e 20 54 68 69 | descrip|tor. Thi|
|00004600| 73 20 69 73 6e 27 74 20 | 61 73 20 63 6c 65 61 6e |s isn't |as clean|
|00004610| 20 61 73 20 69 74 20 73 | 68 6f 75 6c 64 20 62 65 | as it s|hould be|
|00004620| 2c 0a 09 09 20 2a 20 62 | 75 74 20 74 68 69 73 20 |,... * b|ut this |
|00004630| 65 6e 74 69 72 65 20 64 | 72 69 76 65 72 20 69 73 |entire d|river is|
|00004640| 20 61 20 72 65 61 6c 20 | 6b 6c 75 64 67 65 20 61 | a real |kludge a|
|00004650| 6e 79 77 61 79 2e 0a 09 | 09 20 2a 2f 0a 09 09 72 |nyway...|. */...r|
|00004660| 77 6d 6f 64 65 20 3d 20 | 6d 6f 64 65 20 26 20 28 |wmode = |mode & (|
|00004670| 46 52 45 41 44 7c 46 57 | 52 49 54 45 29 3b 0a 09 |FREAD|FW|RITE);..|
|00004680| 09 2f 2a 20 41 44 52 3a | 20 42 75 67 20 66 69 78 |./* ADR:| Bug fix|
|00004690| 3a 20 77 66 70 20 62 65 | 6c 6f 77 20 77 61 73 20 |: wfp be|low was |
|000046a0| 6f 72 69 67 69 6e 61 6c | 6c 79 20 66 70 20 2a 2f |original|ly fp */|
|000046b0| 0a 09 09 69 66 20 28 28 | 77 66 70 2d 3e 66 5f 66 |...if ((|wfp->f_f|
|000046c0| 6c 61 67 20 26 20 72 77 | 6d 6f 64 65 29 20 21 3d |lag & rw|mode) !=|
|000046d0| 20 72 77 6d 6f 64 65 29 | 0a 09 09 09 72 65 74 75 | rwmode)|....retu|
|000046e0| 72 6e 20 28 45 41 43 43 | 45 53 29 3b 0a 0a 09 09 |rn (EACC|ES);....|
|000046f0| 2f 2a 20 44 65 6c 65 74 | 65 20 72 65 66 65 72 65 |/* Delet|e refere|
|00004700| 6e 63 65 73 20 74 6f 20 | 74 68 69 73 20 70 73 65 |nces to |this pse|
|00004710| 75 64 6f 2d 64 65 76 69 | 63 65 2e 20 2a 2f 0a 09 |udo-devi|ce. */..|
|00004720| 09 69 72 65 6c 65 28 69 | 70 29 3b 09 09 2f 2a 20 |.irele(i|p);../* |
|00004730| 43 68 75 63 6b 20 74 68 | 65 20 69 6e 6f 64 65 2e |Chuck th|e inode.|
|00004740| 20 2a 2f 0a 09 09 66 70 | 2d 3e 66 5f 63 6f 75 6e | */...fp|->f_coun|
|00004750| 74 20 3d 20 30 3b 09 2f | 2a 20 43 68 75 63 6b 20 |t = 0;./|* Chuck |
|00004760| 74 68 65 20 66 69 6c 65 | 20 73 74 72 75 63 74 75 |the file| structu|
|00004770| 72 65 2e 20 2a 2f 0a 09 | 09 2f 2a 20 44 75 70 20 |re. */..|./* Dup |
|00004780| 74 68 65 20 66 69 6c 65 | 20 64 65 73 63 72 69 70 |the file| descrip|
|00004790| 74 6f 72 2e 20 2a 2f 0a | 09 09 64 75 70 69 74 28 |tor. */.|..dupit(|
|000047a0| 75 2e 75 5f 72 2e 72 5f | 76 61 6c 31 2c 20 77 66 |u.u_r.r_|val1, wf|
|000047b0| 70 2c 20 75 2e 75 5f 70 | 6f 66 69 6c 65 5b 6d 69 |p, u.u_p|ofile[mi|
|000047c0| 6e 6f 72 28 64 65 76 29 | 5d 29 3b 0a 09 09 72 65 |nor(dev)|]);...re|
|000047d0| 74 75 72 6e 20 28 30 29 | 3b 0a 09 7d 0a 0a 09 65 |turn (0)|;..}...e|
|000047e0| 72 72 6f 72 20 3d 20 30 | 3b 0a 09 77 69 70 20 3d |rror = 0|;..wip =|
|000047f0| 20 28 73 74 72 75 63 74 | 20 69 6e 6f 64 65 20 2a | (struct| inode *|
|00004800| 29 77 66 70 2d 3e 66 5f | 64 61 74 61 3b 0a 0a 09 |)wfp->f_|data;...|
|00004810| 2f 2a 0a 09 20 2a 20 49 | 27 6d 20 6e 6f 74 20 73 |/*.. * I|'m not s|
|00004820| 75 72 65 20 74 68 61 74 | 20 77 65 20 72 65 61 6c |ure that| we real|
|00004830| 6c 79 20 6e 65 65 64 20 | 74 6f 20 6c 6f 63 6b 20 |ly need |to lock |
|00004840| 74 68 65 20 69 6e 6f 64 | 65 20 68 65 72 65 2c 0a |the inod|e here,.|
|00004850| 09 20 2a 20 62 75 74 20 | 77 68 79 20 6e 6f 74 20 |. * but |why not |
|00004860| 62 65 20 70 61 72 61 6e | 6f 69 64 3f 0a 09 20 2a |be paran|oid?.. *|
|00004870| 2f 0a 09 69 6c 6f 63 6b | 28 77 69 70 29 3b 0a 0a |/..ilock|(wip);..|
|00004880| 09 2f 2a 0a 09 20 2a 20 | 53 69 6e 63 65 20 77 65 |./*.. * |Since we|
|00004890| 27 72 65 20 6f 70 65 6e | 69 6e 67 20 61 20 66 69 |'re open|ing a fi|
|000048a0| 6c 65 20 61 67 61 69 6e | 2c 20 77 65 20 72 75 6e |le again|, we run|
|000048b0| 20 74 68 72 6f 75 67 68 | 20 61 6c 6c 20 74 68 65 | through| all the|
|000048c0| 0a 09 20 2a 20 70 65 72 | 6d 69 73 73 69 6f 6e 20 |.. * per|mission |
|000048d0| 63 68 65 63 6b 73 20 73 | 6f 20 74 68 69 73 20 63 |checks s|o this c|
|000048e0| 61 6e 27 74 20 62 65 20 | 75 73 65 64 20 61 73 20 |an't be |used as |
|000048f0| 61 20 6c 6f 6f 70 68 6f | 6c 65 20 74 6f 0a 09 20 |a loopho|le to.. |
|00004900| 2a 20 67 65 74 20 61 63 | 63 65 73 73 20 74 6f 20 |* get ac|cess to |
|00004910| 61 20 66 69 6c 65 20 77 | 65 20 73 68 6f 75 6c 64 |a file w|e should|
|00004920| 6e 27 74 20 68 61 76 65 | 2e 20 20 28 47 52 4f 54 |n't have|. (GROT|
|00004930| 29 0a 09 20 2a 2f 0a 09 | 69 66 20 28 6d 6f 64 65 |).. */..|if (mode|
|00004940| 20 26 20 46 52 45 41 44 | 20 26 26 20 61 63 63 65 | & FREAD| && acce|
|00004950| 73 73 28 77 69 70 2c 20 | 49 52 45 41 44 29 29 0a |ss(wip, |IREAD)).|
|00004960| 09 09 67 6f 74 6f 20 62 | 61 64 3b 0a 09 69 66 20 |..goto b|ad;..if |
|00004970| 28 6d 6f 64 65 20 26 20 | 28 46 57 52 49 54 45 7c |(mode & |(FWRITE||
|00004980| 46 54 52 55 4e 43 29 29 | 20 7b 0a 09 09 69 66 20 |FTRUNC))| {...if |
|00004990| 28 28 69 70 2d 3e 69 5f | 6d 6f 64 65 26 49 46 4d |((ip->i_|mode&IFM|
|000049a0| 54 29 20 3d 3d 20 49 46 | 44 49 52 29 20 7b 0a 09 |T) == IF|DIR) {..|
|000049b0| 09 09 65 72 72 6f 72 20 | 3d 20 45 49 53 44 49 52 |..error |= EISDIR|
|000049c0| 3b 0a 09 09 09 67 6f 74 | 6f 20 62 61 64 3b 0a 09 |;....got|o bad;..|
|000049d0| 09 7d 0a 09 09 69 66 20 | 28 61 63 63 65 73 73 28 |.}...if |(access(|
|000049e0| 77 69 70 2c 20 49 57 52 | 49 54 45 29 29 0a 09 09 |wip, IWR|ITE))...|
|000049f0| 09 67 6f 74 6f 20 62 61 | 64 3b 0a 09 7d 0a 0a 09 |.goto ba|d;..}...|
|00004a00| 2f 2a 0a 09 20 2a 20 54 | 68 65 20 66 69 6c 65 20 |/*.. * T|he file |
|00004a10| 6d 75 73 74 20 61 6c 77 | 61 79 73 20 65 78 69 73 |must alw|ays exis|
|00004a20| 74 2c 20 73 6f 20 77 65 | 20 64 6f 6e 27 74 20 65 |t, so we| don't e|
|00004a30| 76 65 6e 20 62 6f 74 68 | 65 72 20 74 65 73 74 69 |ven both|er testi|
|00004a40| 6e 67 0a 09 20 2a 20 66 | 6f 72 20 69 74 73 20 70 |ng.. * f|or its p|
|00004a50| 72 65 73 65 6e 63 65 2e | 0a 09 20 2a 2f 0a 09 69 |resence.|.. */..i|
|00004a60| 66 20 28 28 6d 6f 64 65 | 20 26 20 28 46 43 52 45 |f ((mode| & (FCRE|
|00004a70| 41 54 7c 46 45 58 43 4c | 29 29 20 3d 3d 20 28 46 |AT|FEXCL|)) == (F|
|00004a80| 43 52 45 41 54 7c 46 45 | 58 43 4c 29 29 20 7b 0a |CREAT|FE|XCL)) {.|
|00004a90| 09 09 65 72 72 6f 72 20 | 3d 20 45 45 58 49 53 54 |..error |= EEXIST|
|00004aa0| 3b 0a 09 09 67 6f 74 6f | 20 62 61 64 3b 0a 09 7d |;...goto| bad;..}|
|00004ab0| 0a 0a 09 2f 2a 0a 09 20 | 2a 20 54 68 69 73 20 6d |.../*.. |* This m|
|00004ac0| 61 79 20 6e 6f 74 20 6d | 61 6b 65 20 61 6e 79 20 |ay not m|ake any |
|00004ad0| 73 65 6e 73 65 2c 20 62 | 75 74 20 49 27 6d 20 70 |sense, b|ut I'm p|
|00004ae0| 61 72 61 6e 6f 69 64 20 | 61 6e 64 20 66 69 67 75 |aranoid |and figu|
|00004af0| 72 65 20 74 68 61 74 0a | 09 20 2a 20 69 74 27 73 |re that.|. * it's|
|00004b00| 20 70 72 6f 62 61 62 6c | 79 20 61 6e 20 65 72 72 | probabl|y an err|
|00004b10| 6f 72 2e 0a 09 20 2a 2f | 0a 09 69 66 20 28 6d 6f |or... */|..if (mo|
|00004b20| 64 65 20 26 20 46 54 52 | 55 4e 43 29 20 7b 0a 09 |de & FTR|UNC) {..|
|00004b30| 09 65 72 72 6f 72 20 3d | 20 45 42 55 53 59 3b 0a |.error =| EBUSY;.|
|00004b40| 09 09 67 6f 74 6f 20 62 | 61 64 3b 0a 09 7d 0a 0a |..goto b|ad;..}..|
|00004b50| 09 2f 2a 20 43 61 6c 6c | 20 74 68 65 20 64 65 76 |./* Call| the dev|
|00004b60| 69 63 65 2d 73 70 65 63 | 69 66 69 63 20 6f 70 65 |ice-spec|ific ope|
|00004b70| 6e 20 72 6f 75 74 69 6e | 65 2c 20 69 66 20 61 6e |n routin|e, if an|
|00004b80| 79 2e 20 2a 2f 0a 09 69 | 66 20 28 28 65 72 72 6f |y. */..i|f ((erro|
|00004b90| 72 20 3d 20 6f 70 65 6e | 69 28 77 69 70 2c 20 6d |r = open|i(wip, m|
|00004ba0| 6f 64 65 29 29 20 21 3d | 20 30 29 0a 09 09 67 6f |ode)) !=| 0)...go|
|00004bb0| 74 6f 20 62 61 64 3b 0a | 0a 09 2f 2a 0a 09 20 2a |to bad;.|../*.. *|
|00004bc0| 20 4d 61 64 65 20 69 74 | 20 74 68 69 73 20 66 61 | Made it| this fa|
|00004bd0| 72 2c 20 6e 6f 77 20 73 | 77 69 74 63 68 20 74 68 |r, now s|witch th|
|00004be0| 65 20 69 6e 6f 64 65 20 | 70 6f 69 6e 74 65 72 73 |e inode |pointers|
|00004bf0| 20 69 6e 20 74 68 65 0a | 09 20 2a 20 66 69 6c 65 | in the.|. * file|
|00004c00| 20 64 65 73 63 72 69 70 | 74 6f 72 73 20 61 72 6f | descrip|tors aro|
|00004c10| 75 6e 64 2c 20 74 6f 20 | 6d 61 6b 65 20 74 68 69 |und, to |make thi|
|00004c20| 73 20 66 69 6c 65 20 6f | 70 65 6e 20 72 65 66 65 |s file o|pen refe|
|00004c30| 72 0a 09 20 2a 20 74 6f | 20 74 68 65 20 6f 74 68 |r.. * to| the oth|
|00004c40| 65 72 20 66 69 6c 65 2e | 0a 09 20 2a 2f 0a 09 69 |er file.|.. */..i|
|00004c50| 72 65 6c 65 28 69 70 29 | 3b 09 09 2f 2a 20 57 65 |rele(ip)|;../* We|
|00004c60| 20 64 6f 6e 27 74 20 6e | 65 65 64 20 74 68 69 73 | don't n|eed this|
|00004c70| 20 61 6e 79 6d 6f 72 65 | 2e 20 2a 2f 0a 09 66 70 | anymore|. */..fp|
|00004c80| 2d 3e 66 5f 64 61 74 61 | 20 3d 20 28 63 61 64 64 |->f_data| = (cadd|
|00004c90| 72 5f 74 29 77 69 70 3b | 0a 09 77 69 70 2d 3e 69 |r_t)wip;|..wip->i|
|00004ca0| 5f 63 6f 75 6e 74 2b 2b | 3b 0a 09 69 75 6e 6c 6f |_count++|;..iunlo|
|00004cb0| 63 6b 28 77 69 70 29 3b | 0a 09 72 65 74 75 72 6e |ck(wip);|..return|
|00004cc0| 20 28 30 29 3b 0a 0a 62 | 61 64 3a 0a 09 69 75 6e | (0);..b|ad:..iun|
|00004cd0| 6c 6f 63 6b 28 77 69 70 | 29 3b 0a 09 72 65 74 75 |lock(wip|);..retu|
|00004ce0| 72 6e 20 28 65 72 72 6f | 72 29 3b 0a 7d 0a 0a 23 |rn (erro|r);.}..#|
|00004cf0| 65 6e 64 69 66 20 2f 2a | 20 4e 46 53 20 2a 2f 0a |endif /*| NFS */.|
|00004d00| 23 65 6e 64 69 66 20 2f | 2a 20 4e 46 44 20 3e 20 |#endif /|* NFD > |
|00004d10| 30 20 2a 2f 0a 20 76 61 | 6c 75 65 0a 09 20 2a 20 |0 */. va|lue.. * |
|00004d20| 6f 66 20 74 68 65 20 6e | 65 77 20 66 69 6c 65 20 |of the n|ew file |
|00004d30| 64 65 73 63 72 69 70 74 | 6f 72 2c 20 77 68 69 63 |descript|or, whic|
|00004d40| 68 20 68 61 73 20 6e 6f | 74 20 62 65 65 6e 20 64 |h has no|t been d|
|00004d50| 69 73 74 75 72 62 65 64 | 20 73 69 6e 63 65 0a 09 |isturbed| since..|
|00004d60| 20 2a 20 69 74 20 77 61 | 73 20 61 6c 6c 6f 63 61 | * it wa|s alloca|
|00004d70| 74 65 64 2e 0a 09 20 2a | 2f 0a 0a 09 69 66 20 28 |ted... *|/...if (|
|00004d80| 28 66 70 20 3d 20 67 65 | 74 66 28 75 2e 75 5f 72 |(fp = ge|tf(u.u_r|
|00004d90| 2e 72 5f 76 61 6c 31 29 | 29 20 3d 3d 20 4e 55 4c |.r_val1)|) == NUL|
|00004da0| 4c 29 0a 09 09 72 65 74 | 75 72 6e 20 28 75 2e 75 |L)...ret|urn (u.u|
|00004db0| 5f 65 72 72 6f 72 29 3b | 0a 0a 09 69 66 20 28 28 |_error);|...if ((|
|00004dc0| 77 66 70 20 3d 20 67 65 | 74 66 28 6d 69 6e 6f 72 |wfp = ge|tf(minor|
|00004dd0| 28 64 65 76 29 29 29 20 | 3d 3d 20 4e 55 4c 4c 29 |(dev))) |== NULL)|
|00004de0| 0a 09 09 72 65 74 75 72 | 6e 20 28 75 2e 75 5f 65 |...retur|n (u.u_e|
|00004df0| 72 72 6f 72 29 3b 0a 0a | 09 2f 2a 0a 09 20 2a 20 |rror);..|./*.. * |
|00004e00| 64 65 76 2d 66 64 2f 50 | 41 54 43 48 00 00 00 00 |dev-fd/P|ATCH....|
|00004e10| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004e20| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004e30| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004e40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004e50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004e60| 00 00 00 00 20 20 20 37 | 35 35 20 00 20 20 20 32 |.... 7|55 . 2|
|00004e70| 34 33 20 00 20 20 20 20 | 31 32 20 00 20 20 20 20 |43 . |12 . |
|00004e80| 20 20 20 31 30 34 30 20 | 20 34 34 30 32 31 31 30 | 1040 | 4402110|
|00004e90| 35 34 31 20 20 20 36 30 | 31 35 00 20 00 00 00 00 |541 60|15. ....|
|00004ea0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004eb0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004ec0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004ed0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004ee0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004ef0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f00| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f10| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f20| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f30| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f70| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f80| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004f90| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004fa0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004fb0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004fc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004fd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004fe0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00004ff0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005000| 2a 2a 2a 20 2f 74 6d 70 | 2f 2c 52 43 53 74 31 30 |*** /tmp|/,RCSt10|
|00005010| 31 33 33 38 38 09 46 72 | 69 20 4a 75 6c 20 31 30 |13388.Fr|i Jul 10|
|00005020| 20 31 30 3a 33 31 3a 31 | 35 20 31 39 38 37 0a 2d | 10:31:1|5 1987.-|
|00005030| 2d 2d 20 73 70 65 63 5f | 76 6e 6f 64 65 6f 70 73 |-- spec_|vnodeops|
|00005040| 2e 63 09 53 75 6e 20 4a | 75 6c 20 20 35 20 31 37 |.c.Sun J|ul 5 17|
|00005050| 3a 32 37 3a 32 34 20 31 | 39 38 37 0a 2a 2a 2a 2a |:27:24 1|987.****|
|00005060| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 0a 2a 2a 2a 20 |********|***.*** |
|00005070| 31 32 39 2c 31 33 35 20 | 2a 2a 2a 2a 0a 20 20 09 |129,135 |****. .|
|00005080| 09 09 69 66 20 28 28 75 | 5f 69 6e 74 29 6d 61 6a |..if ((u|_int)maj|
|00005090| 6f 72 28 64 65 76 29 20 | 3e 3d 20 6e 63 68 72 64 |or(dev) |>= nchrd|
|000050a0| 65 76 29 0a 20 20 09 09 | 09 09 72 65 74 75 72 6e |ev). ..|..return|
|000050b0| 20 28 45 4e 58 49 4f 29 | 3b 0a 20 20 0a 21 20 09 | (ENXIO)|;. .! .|
|000050c0| 09 09 65 72 72 6f 72 20 | 3d 20 28 2a 63 64 65 76 |..error |= (*cdev|
|000050d0| 73 77 5b 6d 61 6a 6f 72 | 28 64 65 76 29 5d 2e 64 |sw[major|(dev)].d|
|000050e0| 5f 6f 70 65 6e 29 28 64 | 65 76 2c 66 6c 61 67 2c |_open)(d|ev,flag,|
|000050f0| 20 26 6e 65 77 64 65 76 | 29 3b 0a 20 20 0a 20 20 | &newdev|);. . |
|00005100| 09 09 09 2f 2a 0a 20 20 | 09 09 09 20 2a 20 49 66 |.../*. |... * If|
|00005110| 20 74 68 69 73 20 69 73 | 20 61 6e 20 69 6e 64 69 | this is| an indi|
|00005120| 72 65 63 74 20 64 65 76 | 69 63 65 20 77 65 20 6e |rect dev|ice we n|
|00005130| 65 65 64 20 74 6f 20 64 | 6f 20 74 68 65 0a 2d 2d |eed to d|o the.--|
|00005140| 2d 20 31 33 32 2c 31 33 | 39 20 2d 2d 2d 2d 0a 20 |- 132,13|9 ----. |
|00005150| 20 09 09 09 69 66 20 28 | 28 75 5f 69 6e 74 29 6d | ...if (|(u_int)m|
|00005160| 61 6a 6f 72 28 64 65 76 | 29 20 3e 3d 20 6e 63 68 |ajor(dev|) >= nch|
|00005170| 72 64 65 76 29 0a 20 20 | 09 09 09 09 72 65 74 75 |rdev). |....retu|
|00005180| 72 6e 20 28 45 4e 58 49 | 4f 29 3b 0a 20 20 0a 21 |rn (ENXI|O);. .!|
|00005190| 20 09 09 09 65 72 72 6f | 72 20 3d 20 28 2a 63 64 | ...erro|r = (*cd|
|000051a0| 65 76 73 77 5b 6d 61 6a | 6f 72 28 64 65 76 29 5d |evsw[maj|or(dev)]|
|000051b0| 2e 64 5f 6f 70 65 6e 29 | 28 64 65 76 2c 66 6c 61 |.d_open)|(dev,fla|
|000051c0| 67 2c 20 26 6e 65 77 64 | 65 76 2c 0a 21 20 09 09 |g, &newd|ev,.! ..|
|000051d0| 09 09 09 09 09 09 09 76 | 70 70 29 3b 0a 20 20 0a |.......v|pp);. .|
|000051e0| 20 20 09 09 09 2f 2a 0a | 20 20 09 09 09 20 2a 20 | .../*.| ... * |
|000051f0| 49 66 20 74 68 69 73 20 | 69 73 20 61 6e 20 69 6e |If this |is an in|
|00005200| 64 69 72 65 63 74 20 64 | 65 76 69 63 65 20 77 65 |direct d|evice we|
|00005210| 20 6e 65 65 64 20 74 6f | 20 64 6f 20 74 68 65 0a | need to| do the.|
|00005220| 4c 45 29 09 2f 2a 20 73 | 61 6e 69 74 79 20 63 68 |LE)./* s|anity ch|
|00005230| 65 63 6b 20 2a 2f 0a 09 | 09 72 65 74 75 72 6e 20 |eck */..|.return |
|00005240| 28 45 4e 58 49 4f 29 3b | 0a 0a 09 2f 2a 0a 09 20 |(ENXIO);|.../*.. |
|00005250| 2a 20 4e 6f 74 65 20 74 | 68 65 20 68 6f 72 72 69 |* Note t|he horri|
|00005260| 64 20 6b 6c 75 64 67 65 | 20 68 65 72 65 3a 20 75 |d kludge| here: u|
|00005270| 2e 75 5f 72 2e 72 5f 76 | 61 6c 31 20 63 6f 6e 74 |.u_r.r_v|al1 cont|
|00005280| 61 69 6e 73 20 74 68 65 | 20 76 61 6c 75 65 0a 09 |ains the| value..|
|00005290| 20 2a 20 6f 66 20 74 68 | 65 20 6e 65 77 20 66 69 | * of th|e new fi|
|000052a0| 6c 65 20 64 65 73 63 72 | 69 70 74 6f 72 2c 20 77 |le descr|iptor, w|
|000052b0| 68 69 63 68 20 68 61 73 | 20 6e 6f 74 20 62 65 65 |hich has| not bee|
|000052c0| 6e 20 64 69 73 74 75 72 | 62 65 64 20 73 69 6e 63 |n distur|bed sinc|
|000052d0| 65 0a 09 20 2a 20 69 74 | 20 77 61 73 20 61 6c 6c |e.. * it| was all|
|000052e0| 6f 63 61 74 65 64 2e 0a | 09 20 2a 2f 0a 09 69 66 |ocated..|. */..if|
|000052f0| 20 28 28 66 70 20 3d 20 | 67 65 74 66 28 75 2e 75 | ((fp = |getf(u.u|
|00005300| 5f 72 2e 72 5f 76 61 6c | 31 29 29 20 3d 3d 20 4e |_r.r_val|1)) == N|
|00005310| 55 4c 4c 29 0a 09 09 72 | 65 74 75 72 6e 20 28 75 |ULL)...r|eturn (u|
|00005320| 2e 75 5f 65 72 72 6f 72 | 29 3b 0a 0a 09 69 66 20 |.u_error|);...if |
|00005330| 28 28 77 66 70 20 3d 20 | 67 65 74 66 28 6d 69 6e |((wfp = |getf(min|
|00005340| 6f 72 28 64 65 76 29 29 | 29 20 3d 3d 20 4e 55 4c |or(dev))|) == NUL|
|00005350| 4c 29 0a 09 09 72 65 74 | 75 72 6e 20 28 75 2e 75 |L)...ret|urn (u.u|
|00005360| 5f 65 72 72 6f 72 29 3b | 0a 0a 09 2f 2a 0a 09 20 |_error);|.../*.. |
|00005370| 2a 20 57 65 20 6d 75 73 | 74 20 65 78 70 6c 69 63 |* We mus|t explic|
|00005380| 69 74 6c 79 20 74 65 73 | 74 20 66 6f 72 20 74 68 |itly tes|t for th|
|00005390| 69 73 20 63 61 73 65 20 | 62 65 63 61 75 73 65 20 |is case |because |
|000053a0| 75 66 61 6c 6c 6f 63 28 | 29 20 6d 61 79 0a 09 20 |ufalloc(|) may.. |
|000053b0| 2a 20 68 61 76 65 20 61 | 6c 6c 6f 63 61 74 65 64 |* have a|llocated|
|000053c0| 20 75 73 20 74 68 65 20 | 73 61 6d 65 20 66 69 6c | us the |same fil|
|000053d0| 65 20 64 65 73 72 69 70 | 74 6f 72 20 77 65 20 61 |e desrip|tor we a|
|000053e0| 72 65 20 72 65 66 65 72 | 72 69 6e 67 0a 09 20 2a |re refer|ring.. *|
|000053f0| 20 74 6f 2c 20 69 66 20 | 74 68 65 20 70 72 6f 63 | to, if |the proc|
|00005400| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005410| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005420| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005430| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005440| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005450| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005460| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005470| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005480| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005490| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000054f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005500| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005510| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005520| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005530| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005540| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005550| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005560| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005570| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005580| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005590| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000055f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005600| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005610| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005620| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005630| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005640| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005650| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005660| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005670| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005680| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005690| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000056f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005700| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005710| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005720| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005730| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005740| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005750| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005760| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005770| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005780| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005790| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057a0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057b0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057c0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000057f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00005800| 57 65 20 6d 75 73 74 20 | 65 78 70 6c 69 63 69 74 |We must |explicit|
|00005810| 6c 79 20 74 65 73 74 20 | 66 6f 72 20 74 68 69 73 |ly test |for this|
|00005820| 20 63 61 73 65 20 62 65 | 63 61 75 73 65 20 75 66 | case be|cause uf|
|00005830| 61 6c 6c 6f 63 28 29 20 | 6d 61 79 0a 09 20 2a 20 |alloc() |may.. * |
|00005840| 68 61 76 65 20 61 6c 6c | 6f 63 61 74 65 64 20 75 |have all|ocated u|
|00005850| 73 20 74 68 65 20 73 61 | 6d 65 20 66 69 6c 65 20 |s the sa|me file |
|00005860| 64 65 73 72 69 70 74 6f | 72 20 77 65 20 61 72 65 |desripto|r we are|
|00005870| 20 72 65 66 65 72 72 69 | 6e 67 0a 09 20 2a 20 74 | referri|ng.. * t|
|00005880| 6f 2c 20 69 66 20 74 68 | 65 20 70 72 6f 63 63 65 |o, if th|e procce|
|00005890| 73 73 20 72 65 66 65 72 | 72 65 64 20 74 6f 20 61 |ss refer|red to a|
|000058a0| 6e 20 69 6e 76 61 6c 69 | 64 20 28 63 6c 6f 73 65 |n invali|d (close|
|000058b0| 64 29 20 64 65 73 63 72 | 69 70 74 6f 72 2e 0a 09 |d) descr|iptor...|
|000058c0| 20 2a 20 4f 72 64 69 6e | 61 72 69 6c 79 20 74 68 | * Ordin|arily th|
|000058d0| 69 73 20 77 6f 75 6c 64 | 20 62 65 20 63 61 75 67 |is would| be caug|
|000058e0| 68 74 20 62 79 20 67 65 | 74 66 28 29 2c 20 62 75 |ht by ge|tf(), bu|
|000058f0| 74 20 62 79 20 74 68 65 | 20 74 69 6d 65 20 77 65 |t by the| time we|
|00005900| 0a 09 20 2a 20 72 65 61 | 63 68 20 74 68 69 73 20 |.. * rea|ch this |
|00005910| 72 6f 75 74 69 6e 65 20 | 75 5f 70 6f 66 69 6c 65 |routine |u_pofile|
|00005920| 5b 6d 69 6e 6f 72 28 64 | 65 76 29 5d 20 63 6f 75 |[minor(d|ev)] cou|
|00005930| 6c 64 20 61 6c 72 65 61 | 64 79 20 62 65 20 73 65 |ld alrea|dy be se|
|00005940| 74 0a 09 20 2a 20 74 6f | 20 70 6f 69 6e 74 20 74 |t.. * to| point t|
|00005950| 6f 20 6f 75 72 20 66 69 | 6c 65 20 73 74 72 75 63 |o our fi|le struc|
|00005960| 74 2e 0a 09 20 2a 2f 0a | 09 69 66 20 28 66 70 20 |t... */.|.if (fp |
|00005970| 3d 3d 20 77 66 70 29 0a | 09 09 72 65 74 75 72 6e |== wfp).|..return|
|00005980| 20 28 45 42 41 44 46 29 | 3b 0a 0a 09 76 70 20 3d | (EBADF)|;...vp =|
|00005990| 20 2a 76 70 70 3b 0a 0a | 09 2f 2a 0a 09 20 2a 20 | *vpp;..|./*.. * |
|000059a0| 46 61 6b 65 20 61 20 60 | 60 64 75 70 28 29 27 27 |Fake a `|`dup()''|
|000059b0| 20 73 79 73 20 63 61 6c | 6c 20 69 66 20 69 74 20 | sys cal|l if it |
|000059c0| 69 73 6e 27 74 20 61 20 | 76 6e 6f 64 65 2e 0a 09 |isn't a |vnode...|
|000059d0| 20 2a 2f 0a 09 69 66 20 | 28 77 66 70 2d 3e 66 5f | */..if |(wfp->f_|
|000059e0| 74 79 70 65 20 21 3d 20 | 44 54 59 50 45 5f 56 4e |type != |DTYPE_VN|
|000059f0| 4f 44 45 29 20 7b 0a 09 | 09 2f 2a 0a 09 09 20 2a |ODE) {..|./*... *|
|00005a00| 20 43 68 65 63 6b 20 74 | 68 61 74 20 74 68 65 20 | Check t|hat the |
|00005a10| 6d 6f 64 65 20 74 68 65 | 20 66 69 6c 65 20 69 73 |mode the| file is|
|00005a20| 20 62 65 69 6e 67 20 6f | 70 65 6e 65 64 0a 09 09 | being o|pened...|
|00005a30| 20 2a 20 66 6f 72 20 69 | 73 20 63 6f 6e 73 69 73 | * for i|s consis|
|00005a40| 74 65 6e 74 20 77 69 74 | 68 20 74 68 65 20 6d 6f |tent wit|h the mo|
|00005a50| 64 65 20 6f 66 20 74 68 | 65 20 65 78 69 73 74 69 |de of th|e existi|
|00005a60| 6e 67 0a 09 09 20 2a 20 | 64 65 73 63 72 69 70 74 |ng... * |descript|
|00005a70| 6f 72 2e 20 54 68 69 73 | 20 69 73 6e 27 74 20 61 |or. This| isn't a|
|00005a80| 73 20 63 6c 65 61 6e 20 | 61 73 20 69 74 20 73 68 |s clean |as it sh|
|00005a90| 6f 75 6c 64 20 62 65 2c | 0a 09 09 20 2a 20 62 75 |ould be,|... * bu|
|00005aa0| 74 20 74 68 69 73 20 65 | 6e 74 69 72 65 20 64 72 |t this e|ntire dr|
|00005ab0| 69 76 65 72 20 69 73 20 | 61 20 72 65 61 6c 20 6b |iver is |a real k|
|00005ac0| 6c 75 64 67 65 20 61 6e | 79 77 61 79 2e 0a 09 09 |ludge an|yway....|
|00005ad0| 20 2a 2f 0a 09 09 72 77 | 6d 6f 64 65 20 3d 20 6d | */...rw|mode = m|
|00005ae0| 6f 64 65 20 26 20 28 46 | 52 45 41 44 7c 46 57 52 |ode & (F|READ|FWR|
|00005af0| 49 54 45 29 3b 0a 09 09 | 69 66 20 28 28 77 66 70 |ITE);...|if ((wfp|
|00005b00| 2d 3e 66 5f 66 6c 61 67 | 20 26 20 72 77 6d 6f 64 |->f_flag| & rwmod|
|00005b10| 65 29 20 21 3d 20 72 77 | 6d 6f 64 65 29 0a 09 09 |e) != rw|mode)...|
|00005b20| 09 72 65 74 75 72 6e 20 | 28 45 41 43 43 45 53 29 |.return |(EACCES)|
|00005b30| 3b 0a 0a 09 09 2f 2a 20 | 44 65 6c 65 74 65 20 72 |;..../* |Delete r|
|00005b40| 65 66 65 72 65 6e 63 65 | 73 20 74 6f 20 74 68 69 |eference|s to thi|
|00005b50| 73 20 70 73 65 75 64 6f | 2d 64 65 76 69 63 65 2e |s pseudo|-device.|
|00005b60| 20 2a 2f 0a 09 09 56 4e | 5f 52 45 4c 45 28 76 70 | */...VN|_RELE(vp|
|00005b70| 29 3b 09 09 2f 2a 20 43 | 68 75 63 6b 20 74 68 65 |);../* C|huck the|
|00005b80| 20 76 6e 6f 64 65 2e 20 | 2a 2f 0a 09 09 66 70 2d | vnode. |*/...fp-|
|00005b90| 3e 66 5f 63 6f 75 6e 74 | 20 3d 20 30 3b 09 2f 2a |>f_count| = 0;./*|
|00005ba0| 20 43 68 75 63 6b 20 74 | 68 65 20 66 69 6c 65 20 | Chuck t|he file |
|00005bb0| 73 74 72 75 63 74 75 72 | 65 2e 20 2a 2f 0a 09 09 |structur|e. */...|
|00005bc0| 63 72 66 72 65 65 28 66 | 70 2d 3e 66 5f 63 72 65 |crfree(f|p->f_cre|
|00005bd0| 64 29 3b 0a 09 09 2f 2a | 20 44 75 70 20 74 68 65 |d);.../*| Dup the|
|00005be0| 20 66 69 6c 65 20 64 65 | 73 63 72 69 70 74 6f 72 | file de|scriptor|
|00005bf0| 2e 20 2a 2f 0a 09 09 64 | 75 70 69 74 28 75 2e 75 |. */...d|upit(u.u|
|00005c00| 5f 72 2e 72 5f 76 61 6c | 31 2c 20 77 66 70 2c 20 |_r.r_val|1, wfp, |
|00005c10| 75 2e 75 5f 70 6f 66 69 | 6c 65 5b 6d 69 6e 6f 72 |u.u_pofi|le[minor|
|00005c20| 28 64 65 76 29 5d 29 3b | 0a 09 09 2a 76 70 70 20 |(dev)]);|...*vpp |
|00005c30| 3d 20 28 73 74 72 75 63 | 74 20 76 6e 6f 64 65 20 |= (struc|t vnode |
|00005c40| 2a 29 77 66 70 2d 3e 66 | 5f 64 61 74 61 3b 09 2f |*)wfp->f|_data;./|
|00005c50| 2a 20 6e 65 65 64 65 64 | 3f 20 2a 2f 0a 09 09 72 |* needed|? */...r|
|00005c60| 65 74 75 72 6e 20 28 30 | 29 3b 0a 09 7d 0a 0a 09 |eturn (0|);..}...|
|00005c70| 2f 2a 0a 09 20 2a 20 6e | 6f 77 20 68 61 76 65 20 |/*.. * n|ow have |
|00005c80| 61 20 72 65 67 75 6c 61 | 72 20 76 6e 6f 64 65 2e |a regula|r vnode.|
|00005c90| 0a 09 20 2a 2f 0a 09 65 | 72 72 6f 72 20 3d 20 30 |.. */..e|rror = 0|
|00005ca0| 3b 0a 09 77 76 70 20 3d | 20 28 73 74 72 75 63 74 |;..wvp =| (struct|
|00005cb0| 20 76 6e 6f 64 65 20 2a | 29 77 66 70 2d 3e 66 5f | vnode *|)wfp->f_|
|00005cc0| 64 61 74 61 3b 0a 0a 09 | 2f 2a 0a 09 20 2a 20 53 |data;...|/*.. * S|
|00005cd0| 69 6e 63 65 20 77 65 27 | 72 65 20 6f 70 65 6e 69 |ince we'|re openi|
|00005ce0| 6e 67 20 61 20 66 69 6c | 65 20 61 67 61 69 6e 2c |ng a fil|e again,|
|00005cf0| 20 77 65 20 72 75 6e 20 | 74 68 72 6f 75 67 68 20 | we run |through |
|00005d00| 61 6c 6c 20 74 68 65 0a | 09 20 2a 20 70 65 72 6d |all the.|. * perm|
|00005d10| 69 73 73 69 6f 6e 20 63 | 68 65 63 6b 73 20 73 6f |ission c|hecks so|
|00005d20| 20 74 68 69 73 20 63 61 | 6e 27 74 20 62 65 20 75 | this ca|n't be u|
|00005d30| 73 65 64 20 61 73 20 61 | 20 6c 6f 6f 70 68 6f 6c |sed as a| loophol|
|00005d40| 65 20 74 6f 0a 09 20 2a | 20 67 65 74 20 61 63 63 |e to.. *| get acc|
|00005d50| 65 73 73 20 74 6f 20 61 | 20 66 69 6c 65 20 77 65 |ess to a| file we|
|00005d60| 20 73 68 6f 75 6c 64 6e | 27 74 20 68 61 76 65 2e | shouldn|'t have.|
|00005d70| 20 20 28 47 52 4f 54 29 | 0a 09 20 2a 2f 0a 09 69 | (GROT)|.. */..i|
|00005d80| 66 20 28 6d 6f 64 65 20 | 26 20 46 52 45 41 44 20 |f (mode |& FREAD |
|00005d90| 26 26 20 28 65 72 72 6f | 72 20 3d 20 56 4f 50 5f |&& (erro|r = VOP_|
|00005da0| 41 43 43 45 53 53 28 77 | 76 70 2c 20 56 52 45 41 |ACCESS(w|vp, VREA|
|00005db0| 44 2c 20 75 2e 75 5f 63 | 72 65 64 29 29 29 0a 09 |D, u.u_c|red)))..|
|00005dc0| 09 67 6f 74 6f 20 62 61 | 64 3b 0a 09 69 66 20 28 |.goto ba|d;..if (|
|00005dd0| 6d 6f 64 65 20 26 20 28 | 46 57 52 49 54 45 7c 46 |mode & (|FWRITE|F|
|00005de0| 54 52 55 4e 43 29 29 20 | 7b 0a 09 09 69 66 20 28 |TRUNC)) |{...if (|
|00005df0| 76 70 2d 3e 76 5f 74 79 | 70 65 20 3d 3d 20 56 44 |vp->v_ty|pe == VD|
|00005e00| 49 52 29 20 7b 0a 09 09 | 09 65 72 72 6f 72 20 3d |IR) {...|.error =|
|00005e10| 20 45 49 53 44 49 52 3b | 0a 09 09 09 67 6f 74 6f | EISDIR;|....goto|
|00005e20| 20 62 61 64 3b 0a 09 09 | 7d 0a 09 09 69 66 20 28 | bad;...|}...if (|
|00005e30| 28 65 72 72 6f 72 20 3d | 20 56 4f 50 5f 41 43 43 |(error =| VOP_ACC|
|00005e40| 45 53 53 28 77 76 70 2c | 20 56 57 52 49 54 45 2c |ESS(wvp,| VWRITE,|
|00005e50| 20 75 2e 75 5f 63 72 65 | 64 29 29 29 0a 09 09 09 | u.u_cre|d)))....|
|00005e60| 67 6f 74 6f 20 62 61 64 | 3b 0a 09 7d 0a 0a 09 2f |goto bad|;..}.../|
|00005e70| 2a 0a 09 20 2a 20 54 68 | 65 20 66 69 6c 65 20 6d |*.. * Th|e file m|
|00005e80| 75 73 74 20 61 6c 77 61 | 79 73 20 65 78 69 73 74 |ust alwa|ys exist|
|00005e90| 2c 20 73 6f 20 77 65 20 | 64 6f 6e 27 74 20 65 76 |, so we |don't ev|
|00005ea0| 65 6e 20 62 6f 74 68 65 | 72 20 74 65 73 74 69 6e |en bothe|r testin|
|00005eb0| 67 0a 09 20 2a 20 66 6f | 72 20 69 74 73 20 70 72 |g.. * fo|r its pr|
|00005ec0| 65 73 65 6e 63 65 2e 0a | 09 20 2a 2f 0a 09 69 66 |esence..|. */..if|
|00005ed0| 20 28 28 6d 6f 64 65 20 | 26 20 28 46 43 52 45 41 | ((mode |& (FCREA|
|00005ee0| 54 7c 46 45 58 43 4c 29 | 29 20 3d 3d 20 28 46 43 |T|FEXCL)|) == (FC|
|00005ef0| 52 45 41 54 7c 46 45 58 | 43 4c 29 29 20 7b 0a 09 |REAT|FEX|CL)) {..|
|00005f00| 09 65 72 72 6f 72 20 3d | 20 45 45 58 49 53 54 3b |.error =| EEXIST;|
|00005f10| 0a 09 09 67 6f 74 6f 20 | 62 61 64 3b 0a 09 7d 0a |...goto |bad;..}.|
|00005f20| 0a 09 2f 2a 0a 09 20 2a | 20 54 68 69 73 20 6d 61 |../*.. *| This ma|
|00005f30| 79 20 6e 6f 74 20 6d 61 | 6b 65 20 61 6e 79 20 73 |y not ma|ke any s|
|00005f40| 65 6e 73 65 2c 20 62 75 | 74 20 49 27 6d 20 70 61 |ense, bu|t I'm pa|
|00005f50| 72 61 6e 6f 69 64 20 61 | 6e 64 20 66 69 67 75 72 |ranoid a|nd figur|
|00005f60| 65 20 74 68 61 74 0a 09 | 20 2a 20 69 74 27 73 20 |e that..| * it's |
|00005f70| 70 72 6f 62 61 62 6c 79 | 20 61 6e 20 65 72 72 6f |probably| an erro|
|00005f80| 72 2e 0a 09 20 2a 2f 0a | 09 69 66 20 28 6d 6f 64 |r... */.|.if (mod|
|00005f90| 65 20 26 20 46 54 52 55 | 4e 43 29 20 7b 0a 09 09 |e & FTRU|NC) {...|
|00005fa0| 65 72 72 6f 72 20 3d 20 | 45 42 55 53 59 3b 0a 09 |error = |EBUSY;..|
|00005fb0| 09 67 6f 74 6f 20 62 61 | 64 3b 0a 09 7d 0a 0a 09 |.goto ba|d;..}...|
|00005fc0| 2f 2a 20 43 61 6c 6c 20 | 74 68 65 20 64 65 76 69 |/* Call |the devi|
|00005fd0| 63 65 2d 73 70 65 63 69 | 66 69 63 20 6f 70 65 6e |ce-speci|fic open|
|00005fe0| 20 72 6f 75 74 69 6e 65 | 2c 20 69 66 20 61 6e 79 | routine|, if any|
|00005ff0| 2e 20 2a 2f 0a 09 76 6d | 6f 64 65 20 3d 20 6d 6f |. */..vm|ode = mo|
+--------+-------------------------+-------------------------+--------+--------+