home *** CD-ROM | disk | FTP | other *** search
view JSON data
|
view as text
|
open on a Mac
|
open on a PC
This file was processed as: SHell self-extracting ARchive
(archive/shar).
You can browse this item here: part02
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| dexvert
| SHell self-extracting ARchive (archive/shar)
| magic
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| C source, ASCII text
| default
| |
100%
| checkBytes
| Printable ASCII
| default
| |
100%
| perlTextCheck
| Likely Text (Perl)
| default
| |
100%
| siegfried
| fmt/329 Shell Archive Format
| default
| |
100%
| detectItEasy
| Format: plain text[LF]
| default (weak)
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 4e 65 77 73 67 72 6f 75 | 70 73 3a 20 63 6f 6d 70 |Newsgrou|ps: comp|
|00000010| 2e 73 6f 75 72 63 65 73 | 2e 6d 69 73 63 0a 6f 72 |.sources|.misc.or|
|00000020| 67 61 6e 69 7a 61 74 69 | 6f 6e 3a 20 43 53 55 20 |ganizati|on: CSU |
|00000030| 53 74 61 6e 69 73 6c 61 | 75 73 0a 73 75 62 6a 65 |Stanisla|us.subje|
|00000040| 63 74 3a 20 76 31 31 69 | 30 39 34 3a 20 50 43 20 |ct: v11i|094: PC |
|00000050| 53 65 72 69 61 6c 20 50 | 6f 72 74 20 52 6f 75 74 |Serial P|ort Rout|
|00000060| 69 6e 65 73 20 28 4e 53 | 43 38 32 35 30 20 65 74 |ines (NS|C8250 et|
|00000070| 20 61 6c 29 20 50 61 72 | 74 20 32 0a 66 72 6f 6d | al) Par|t 2.from|
|00000080| 3a 20 6a 62 40 61 6c 74 | 61 69 72 2e 63 73 75 73 |: jb@alt|air.csus|
|00000090| 74 61 6e 2e 65 64 75 20 | 28 4a 6f 68 6e 20 42 69 |tan.edu |(John Bi|
|000000a0| 72 63 68 66 69 65 6c 64 | 29 0a 53 65 6e 64 65 72 |rchfield|).Sender|
|000000b0| 3a 20 61 6c 6c 62 65 72 | 79 40 75 75 6e 65 74 2e |: allber|y@uunet.|
|000000c0| 55 55 2e 4e 45 54 20 28 | 42 72 61 6e 64 6f 6e 20 |UU.NET (|Brandon |
|000000d0| 53 2e 20 41 6c 6c 62 65 | 72 79 20 2d 20 63 6f 6d |S. Allbe|ry - com|
|000000e0| 70 2e 73 6f 75 72 63 65 | 73 2e 6d 69 73 63 29 0a |p.source|s.misc).|
|000000f0| 0a 50 6f 73 74 69 6e 67 | 2d 6e 75 6d 62 65 72 3a |.Posting|-number:|
|00000100| 20 56 6f 6c 75 6d 65 20 | 31 31 2c 20 49 73 73 75 | Volume |11, Issu|
|00000110| 65 20 39 34 0a 53 75 62 | 6d 69 74 74 65 64 2d 62 |e 94.Sub|mitted-b|
|00000120| 79 3a 20 6a 62 40 61 6c | 74 61 69 72 2e 63 73 75 |y: jb@al|tair.csu|
|00000130| 73 74 61 6e 2e 65 64 75 | 20 28 4a 6f 68 6e 20 42 |stan.edu| (John B|
|00000140| 69 72 63 68 66 69 65 6c | 64 29 0a 41 72 63 68 69 |irchfiel|d).Archi|
|00000150| 76 65 2d 6e 61 6d 65 3a | 20 70 63 2d 38 32 35 30 |ve-name:| pc-8250|
|00000160| 2f 70 61 72 74 30 32 0a | 0a 23 21 20 2f 62 69 6e |/part02.|.#! /bin|
|00000170| 2f 73 68 0a 23 20 54 68 | 69 73 20 69 73 20 61 20 |/sh.# Th|is is a |
|00000180| 73 68 65 6c 6c 20 61 72 | 63 68 69 76 65 2e 20 20 |shell ar|chive. |
|00000190| 52 65 6d 6f 76 65 20 61 | 6e 79 74 68 69 6e 67 20 |Remove a|nything |
|000001a0| 62 65 66 6f 72 65 20 74 | 68 69 73 20 6c 69 6e 65 |before t|his line|
|000001b0| 2c 20 74 68 65 6e 20 75 | 6e 70 61 63 6b 0a 23 20 |, then u|npack.# |
|000001c0| 69 74 20 62 79 20 73 61 | 76 69 6e 67 20 69 74 20 |it by sa|ving it |
|000001d0| 69 6e 74 6f 20 61 20 66 | 69 6c 65 20 61 6e 64 20 |into a f|ile and |
|000001e0| 74 79 70 69 6e 67 20 22 | 73 68 20 66 69 6c 65 22 |typing "|sh file"|
|000001f0| 2e 20 20 54 6f 20 6f 76 | 65 72 77 72 69 74 65 20 |. To ov|erwrite |
|00000200| 65 78 69 73 74 69 6e 67 | 0a 23 20 66 69 6c 65 73 |existing|.# files|
|00000210| 2c 20 74 79 70 65 20 22 | 73 68 20 66 69 6c 65 20 |, type "|sh file |
|00000220| 2d 63 22 2e 20 20 59 6f | 75 20 63 61 6e 20 61 6c |-c". Yo|u can al|
|00000230| 73 6f 20 66 65 65 64 20 | 74 68 69 73 20 61 73 20 |so feed |this as |
|00000240| 73 74 61 6e 64 61 72 64 | 20 69 6e 70 75 74 20 76 |standard| input v|
|00000250| 69 61 0a 23 20 75 6e 73 | 68 61 72 2c 20 6f 72 20 |ia.# uns|har, or |
|00000260| 62 79 20 74 79 70 69 6e | 67 20 22 73 68 20 3c 66 |by typin|g "sh <f|
|00000270| 69 6c 65 22 2c 20 65 2e | 67 2e 2e 20 20 49 66 20 |ile", e.|g.. If |
|00000280| 74 68 69 73 20 61 72 63 | 68 69 76 65 20 69 73 20 |this arc|hive is |
|00000290| 63 6f 6d 70 6c 65 74 65 | 2c 20 79 6f 75 0a 23 20 |complete|, you.# |
|000002a0| 77 69 6c 6c 20 73 65 65 | 20 74 68 65 20 66 6f 6c |will see| the fol|
|000002b0| 6c 6f 77 69 6e 67 20 6d | 65 73 73 61 67 65 20 61 |lowing m|essage a|
|000002c0| 74 20 74 68 65 20 65 6e | 64 3a 0a 23 09 09 22 45 |t the en|d:.#.."E|
|000002d0| 6e 64 20 6f 66 20 61 72 | 63 68 69 76 65 20 32 20 |nd of ar|chive 2 |
|000002e0| 28 6f 66 20 33 29 2e 22 | 0a 23 20 43 6f 6e 74 65 |(of 3)."|.# Conte|
|000002f0| 6e 74 73 3a 20 20 38 32 | 35 30 64 74 72 2e 63 20 |nts: 82|50dtr.c |
|00000300| 38 32 35 30 78 6f 6e 2e | 63 20 5f 6b 62 2e 63 20 |8250xon.|c _kb.c |
|00000310| 6f 70 74 69 6f 6e 73 2e | 63 20 73 63 72 65 65 6e |options.|c screen|
|00000320| 2e 63 0a 23 20 57 72 61 | 70 70 65 64 20 62 79 20 |.c.# Wra|pped by |
|00000330| 6a 62 40 64 65 6e 65 62 | 20 6f 6e 20 53 61 74 20 |jb@deneb| on Sat |
|00000340| 4d 61 72 20 32 34 20 31 | 30 3a 34 32 3a 31 38 20 |Mar 24 1|0:42:18 |
|00000350| 31 39 39 30 0a 50 41 54 | 48 3d 2f 62 69 6e 3a 2f |1990.PAT|H=/bin:/|
|00000360| 75 73 72 2f 62 69 6e 3a | 2f 75 73 72 2f 75 63 62 |usr/bin:|/usr/ucb|
|00000370| 20 3b 20 65 78 70 6f 72 | 74 20 50 41 54 48 0a 69 | ; expor|t PATH.i|
|00000380| 66 20 74 65 73 74 20 2d | 66 20 27 38 32 35 30 64 |f test -|f '8250d|
|00000390| 74 72 2e 63 27 20 2d 61 | 20 22 24 7b 31 7d 22 20 |tr.c' -a| "${1}" |
|000003a0| 21 3d 20 22 2d 63 22 20 | 3b 20 74 68 65 6e 20 0a |!= "-c" |; then .|
|000003b0| 20 20 65 63 68 6f 20 73 | 68 61 72 3a 20 57 69 6c | echo s|har: Wil|
|000003c0| 6c 20 6e 6f 74 20 63 6c | 6f 62 62 65 72 20 65 78 |l not cl|obber ex|
|000003d0| 69 73 74 69 6e 67 20 66 | 69 6c 65 20 5c 22 27 38 |isting f|ile \"'8|
|000003e0| 32 35 30 64 74 72 2e 63 | 27 5c 22 0a 65 6c 73 65 |250dtr.c|'\".else|
|000003f0| 0a 65 63 68 6f 20 73 68 | 61 72 3a 20 45 78 74 72 |.echo sh|ar: Extr|
|00000400| 61 63 74 69 6e 67 20 5c | 22 27 38 32 35 30 64 74 |acting \|"'8250dt|
|00000410| 72 2e 63 27 5c 22 20 5c | 28 31 31 32 35 32 20 63 |r.c'\" \|(11252 c|
|00000420| 68 61 72 61 63 74 65 72 | 73 5c 29 0a 73 65 64 20 |haracter|s\).sed |
|00000430| 22 73 2f 5e 58 2f 2f 22 | 20 3e 27 38 32 35 30 64 |"s/^X//"| >'8250d|
|00000440| 74 72 2e 63 27 20 3c 3c | 27 45 4e 44 5f 4f 46 5f |tr.c' <<|'END_OF_|
|00000450| 46 49 4c 45 27 0a 58 2f | 2a 0a 58 20 2a 20 20 20 |FILE'.X/|*.X * |
|00000460| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000470| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 44 54 52 | | DTR|
|00000480| 38 32 35 30 2e 43 0a 58 | 20 2a 0a 58 20 2a 20 20 |8250.C.X| *.X * |
|00000490| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000004a0| 20 20 4e 53 43 38 32 35 | 30 20 44 54 52 20 48 61 | NSC825|0 DTR Ha|
|000004b0| 6e 64 73 68 61 6b 65 20 | 49 53 52 20 4d 6f 64 75 |ndshake |ISR Modu|
|000004c0| 6c 65 0a 58 20 2a 0a 58 | 20 2a 20 20 20 20 20 20 |le.X *.X| * |
|000004d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000004e0| 20 20 20 20 20 57 72 69 | 74 74 65 6e 20 66 6f 72 | Wri|tten for|
|000004f0| 20 74 68 65 0a 58 20 2a | 0a 58 20 2a 20 20 20 20 | the.X *|.X * |
|00000500| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000510| 20 20 20 20 20 20 20 20 | 20 20 44 61 74 61 6c 69 | | Datali|
|00000520| 67 68 74 0a 58 20 2a 20 | 20 20 20 20 20 20 20 20 |ght.X * | |
|00000530| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000540| 20 20 4d 69 63 72 6f 73 | 6f 66 74 20 56 20 35 2e | Micros|oft V 5.|
|00000550| 78 0a 58 20 2a 20 20 20 | 20 20 20 20 20 20 20 20 |x.X * | |
|00000560| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000570| 20 20 20 20 20 54 75 72 | 62 6f 43 0a 58 20 2a 20 | Tur|boC.X * |
|00000580| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00000590| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000005a0| 20 26 0a 58 20 2a 20 20 | 20 20 20 20 20 20 20 20 | &.X * | |
|000005b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000005c0| 20 20 20 20 20 5a 6f 72 | 74 65 63 68 0a 58 20 2a | Zor|tech.X *|
|000005d0| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|000005e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000005f0| 20 43 20 43 6f 6d 70 69 | 6c 65 72 73 0a 58 20 2a | C Compi|lers.X *|
|00000600| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|00000610| 43 6f 70 79 72 69 67 68 | 74 20 28 63 29 20 4a 6f |Copyrigh|t (c) Jo|
|00000620| 68 6e 20 42 69 72 63 68 | 66 69 65 6c 64 20 31 39 |hn Birch|field 19|
|00000630| 38 37 2c 20 31 39 38 38 | 2c 20 31 39 38 39 0a 58 |87, 1988|, 1989.X|
|00000640| 20 2a 2f 0a 58 0a 58 23 | 69 6e 63 6c 75 64 65 20 | */.X.X#|include |
|00000650| 3c 73 74 64 69 6f 2e 68 | 3e 0a 58 23 69 6e 63 6c |<stdio.h|>.X#incl|
|00000660| 75 64 65 20 22 64 65 70 | 65 6e 64 6e 74 2e 68 22 |ude "dep|endnt.h"|
|00000670| 0a 58 23 69 6e 63 6c 75 | 64 65 20 22 71 75 65 75 |.X#inclu|de "queu|
|00000680| 65 2e 68 22 0a 58 23 69 | 6e 63 6c 75 64 65 20 22 |e.h".X#i|nclude "|
|00000690| 38 32 35 30 6e 73 63 2e | 68 22 0a 58 23 69 6e 63 |8250nsc.|h".X#inc|
|000006a0| 6c 75 64 65 20 22 38 32 | 35 30 64 74 72 2e 68 22 |lude "82|50dtr.h"|
|000006b0| 0a 58 23 69 6e 63 6c 75 | 64 65 20 22 74 69 6d 65 |.X#inclu|de "time|
|000006c0| 72 2e 68 22 0a 58 0a 58 | 23 69 66 20 28 21 64 65 |r.h".X.X|#if (!de|
|000006d0| 66 69 6e 65 64 20 28 54 | 52 55 45 29 29 0a 58 23 |fined (T|RUE)).X#|
|000006e0| 09 64 65 66 69 6e 65 20 | 54 52 55 45 20 20 28 31 |.define |TRUE (1|
|000006f0| 29 0a 58 23 09 64 65 66 | 69 6e 65 20 46 41 4c 53 |).X#.def|ine FALS|
|00000700| 45 20 28 30 29 0a 58 23 | 65 6e 64 69 66 0a 58 0a |E (0).X#|endif.X.|
|00000710| 75 6e 73 69 67 6e 65 64 | 20 44 54 52 5f 50 4f 52 |unsigned| DTR_POR|
|00000720| 54 5f 63 68 61 6e 6e 65 | 6c 3b 20 20 20 20 20 20 |T_channe|l; |
|00000730| 2f 2a 20 45 69 74 68 65 | 72 20 31 20 6f 72 20 32 |/* Eithe|r 1 or 2|
|00000740| 20 66 6f 72 20 43 4f 4d | 31 20 6f 72 20 43 4f 4d | for COM|1 or COM|
|00000750| 32 20 20 20 20 20 20 20 | 2a 2f 0a 63 68 61 72 20 |2 |*/.char |
|00000760| 20 20 20 64 74 72 38 32 | 35 30 5f 53 41 56 45 5f | dtr82|50_SAVE_|
|00000770| 69 6e 74 5f 6d 61 73 6b | 2c 20 20 2f 2a 20 73 61 |int_mask|, /* sa|
|00000780| 76 65 64 20 69 6e 74 65 | 72 72 75 70 74 20 63 6f |ved inte|rrupt co|
|00000790| 6e 74 72 6f 6c 6c 65 72 | 20 6d 61 73 6b 20 77 6f |ntroller| mask wo|
|000007a0| 72 64 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 64 |rd */.X | d|
|000007b0| 74 72 38 32 35 30 5f 49 | 45 52 5f 73 61 76 65 20 |tr8250_I|ER_save |
|000007c0| 3d 20 30 2c 20 20 20 2f | 2a 20 53 61 76 65 64 20 |= 0, /|* Saved |
|000007d0| 6f 66 66 20 49 6e 74 65 | 72 72 75 70 74 20 45 6e |off Inte|rrupt En|
|000007e0| 61 62 6c 65 20 52 65 67 | 69 73 74 65 72 20 20 2a |able Reg|ister *|
|000007f0| 2f 0a 58 20 20 20 20 20 | 20 20 20 64 74 72 38 32 |/.X | dtr82|
|00000800| 35 30 5f 4c 43 52 5f 73 | 61 76 65 20 3d 20 30 2c |50_LCR_s|ave = 0,|
|00000810| 20 20 20 2f 2a 20 53 61 | 76 65 64 20 6f 66 66 20 | /* Sa|ved off |
|00000820| 4c 69 6e 65 20 43 6f 6e | 74 72 6f 6c 20 52 65 67 |Line Con|trol Reg|
|00000830| 69 73 74 65 72 20 20 20 | 20 20 20 2a 2f 0a 58 20 |ister | */.X |
|00000840| 20 20 20 20 20 20 20 64 | 74 72 38 32 35 30 5f 4d | d|tr8250_M|
|00000850| 43 52 5f 73 61 76 65 20 | 3d 20 30 2c 20 20 20 2f |CR_save |= 0, /|
|00000860| 2a 20 53 61 76 65 64 20 | 6f 66 66 20 4d 6f 64 65 |* Saved |off Mode|
|00000870| 6d 20 43 6f 6e 74 72 6f | 6c 20 52 65 67 69 73 74 |m Contro|l Regist|
|00000880| 65 72 20 20 20 20 20 2a | 2f 0a 58 20 20 20 20 20 |er *|/.X |
|00000890| 20 20 20 64 74 72 38 32 | 35 30 5f 44 4c 5f 6c 73 | dtr82|50_DL_ls|
|000008a0| 62 20 3d 20 30 2c 20 20 | 20 20 20 2f 2a 20 53 61 |b = 0, | /* Sa|
|000008b0| 76 65 64 20 6f 66 66 20 | 42 61 75 64 20 52 61 74 |ved off |Baud Rat|
|000008c0| 65 20 4c 53 42 20 20 20 | 20 20 20 20 20 20 20 20 |e LSB | |
|000008d0| 20 20 20 2a 2f 0a 58 20 | 20 20 20 20 20 20 20 64 | */.X | d|
|000008e0| 74 72 38 32 35 30 5f 44 | 4c 5f 6d 73 62 20 3d 20 |tr8250_D|L_msb = |
|000008f0| 30 3b 20 20 20 20 20 2f | 2a 20 53 61 76 65 64 20 |0; /|* Saved |
|00000900| 6f 66 66 20 42 61 75 64 | 20 52 61 74 65 20 4d 53 |off Baud| Rate MS|
|00000910| 42 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 2a |B | *|
|00000920| 2f 0a 58 0a 58 0a 58 0a | 76 6f 6c 61 74 69 6c 65 |/.X.X.X.|volatile|
|00000930| 20 75 6e 73 69 67 6e 65 | 64 20 44 54 52 5f 50 4f | unsigne|d DTR_PO|
|00000940| 52 54 5f 61 64 64 72 3b | 0a 76 6f 6c 61 74 69 6c |RT_addr;|.volatil|
|00000950| 65 20 63 68 61 72 20 44 | 54 52 5f 50 4f 52 54 5f |e char D|TR_PORT_|
|00000960| 73 74 61 74 75 73 2c 20 | 52 43 56 5f 64 69 73 61 |status, |RCV_disa|
|00000970| 62 6c 65 64 20 3d 20 46 | 41 4c 53 45 2c 20 58 4d |bled = F|ALSE, XM|
|00000980| 49 54 5f 64 69 73 61 62 | 6c 65 64 20 3d 20 54 52 |IT_disab|led = TR|
|00000990| 55 45 2c 20 64 74 72 38 | 32 35 30 5f 4d 53 52 5f |UE, dtr8|250_MSR_|
|000009a0| 72 65 67 20 3d 20 30 3b | 0a 76 6f 6c 61 74 69 6c |reg = 0;|.volatil|
|000009b0| 65 20 51 55 45 55 45 20 | 2a 64 74 72 38 32 35 30 |e QUEUE |*dtr8250|
|000009c0| 5f 69 6e 71 75 65 75 65 | 3b 0a 58 23 69 66 20 28 |_inqueue|;.X#if (|
|000009d0| 64 65 66 69 6e 65 64 20 | 28 44 4c 43 29 29 0a 65 |defined |(DLC)).e|
|000009e0| 78 74 65 72 6e 20 76 6f | 69 64 20 6f 75 74 70 20 |xtern vo|id outp |
|000009f0| 28 29 3b 0a 58 23 65 6e | 64 69 66 0a 58 0a 58 0a |();.X#en|dif.X.X.|
|00000a00| 58 23 64 65 66 69 6e 65 | 20 44 49 53 41 42 4c 45 |X#define| DISABLE|
|00000a10| 5f 78 6d 69 74 20 6f 75 | 74 62 79 74 65 20 28 44 |_xmit ou|tbyte (D|
|00000a20| 54 52 5f 50 4f 52 54 5f | 61 64 64 72 2b 49 45 52 |TR_PORT_|addr+IER|
|00000a30| 2c 20 52 58 5f 65 6e 61 | 62 6c 65 29 0a 58 23 64 |, RX_ena|ble).X#d|
|00000a40| 65 66 69 6e 65 20 45 4e | 41 42 4c 45 5f 78 6d 69 |efine EN|ABLE_xmi|
|00000a50| 74 20 20 6f 75 74 62 79 | 74 65 20 28 44 54 52 5f |t outby|te (DTR_|
|00000a60| 50 4f 52 54 5f 61 64 64 | 72 2b 49 45 52 2c 20 52 |PORT_add|r+IER, R|
|00000a70| 58 5f 54 58 5f 65 6e 61 | 62 6c 65 29 0a 58 23 64 |X_TX_ena|ble).X#d|
|00000a80| 65 66 69 6e 65 20 44 52 | 4f 50 50 45 44 5f 63 74 |efine DR|OPPED_ct|
|00000a90| 73 20 20 28 28 64 74 72 | 38 32 35 30 5f 4d 53 52 |s ((dtr|8250_MSR|
|00000aa0| 5f 72 65 67 26 30 78 31 | 30 29 3d 3d 30 29 0a 58 |_reg&0x1|0)==0).X|
|00000ab0| 23 64 65 66 69 6e 65 20 | 44 52 4f 50 50 45 44 5f |#define |DROPPED_|
|00000ac0| 64 73 72 20 20 28 28 64 | 74 72 38 32 35 30 5f 4d |dsr ((d|tr8250_M|
|00000ad0| 53 52 5f 72 65 67 26 30 | 78 32 30 29 3d 3d 30 29 |SR_reg&0|x20)==0)|
|00000ae0| 0a 58 23 64 65 66 69 6e | 65 20 44 52 4f 50 50 45 |.X#defin|e DROPPE|
|00000af0| 44 5f 64 74 72 20 20 28 | 28 64 74 72 38 32 35 30 |D_dtr (|(dtr8250|
|00000b00| 5f 4d 53 52 5f 72 65 67 | 26 30 78 33 30 29 21 3d |_MSR_reg|&0x30)!=|
|00000b10| 30 78 33 30 29 0a 58 23 | 64 65 66 69 6e 65 20 41 |0x30).X#|define A|
|00000b20| 53 53 45 52 54 5f 64 74 | 72 20 20 20 6f 75 74 62 |SSERT_dt|r outb|
|00000b30| 79 74 65 20 28 69 6e 62 | 79 74 65 20 28 44 54 52 |yte (inb|yte (DTR|
|00000b40| 5f 50 4f 52 54 5f 61 64 | 64 72 2b 4d 43 52 29 7c |_PORT_ad|dr+MCR)||
|00000b50| 39 2c 20 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |9, DTR_P|ORT_addr|
|00000b60| 2b 4d 43 52 29 0a 58 23 | 64 65 66 69 6e 65 20 44 |+MCR).X#|define D|
|00000b70| 52 4f 50 5f 64 74 72 20 | 20 20 20 20 6f 75 74 62 |ROP_dtr | outb|
|00000b80| 79 74 65 20 28 69 6e 62 | 79 74 65 20 28 44 54 52 |yte (inb|yte (DTR|
|00000b90| 5f 50 4f 52 54 5f 61 64 | 64 72 2b 4d 43 52 29 26 |_PORT_ad|dr+MCR)&|
|00000ba0| 30 78 30 41 2c 20 44 54 | 52 5f 50 4f 52 54 5f 61 |0x0A, DT|R_PORT_a|
|00000bb0| 64 64 72 2b 4d 43 52 29 | 0a 58 23 64 65 66 69 6e |ddr+MCR)|.X#defin|
|00000bc0| 65 20 41 53 53 45 52 54 | 5f 72 74 73 20 20 20 6f |e ASSERT|_rts o|
|00000bd0| 75 74 62 79 74 65 20 28 | 69 6e 62 79 74 65 20 28 |utbyte (|inbyte (|
|00000be0| 44 54 52 5f 50 4f 52 54 | 5f 61 64 64 72 2b 4d 43 |DTR_PORT|_addr+MC|
|00000bf0| 52 29 7c 30 78 30 41 2c | 20 44 54 52 5f 50 4f 52 |R)|0x0A,| DTR_POR|
|00000c00| 54 5f 61 64 64 72 2b 4d | 43 52 29 0a 58 23 64 65 |T_addr+M|CR).X#de|
|00000c10| 66 69 6e 65 20 44 52 4f | 50 5f 72 74 73 20 20 20 |fine DRO|P_rts |
|00000c20| 20 20 6f 75 74 62 79 74 | 65 20 28 69 6e 62 79 74 | outbyt|e (inbyt|
|00000c30| 65 20 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |e (DTR_P|ORT_addr|
|00000c40| 2b 4d 43 52 29 26 39 2c | 20 44 54 52 5f 50 4f 52 |+MCR)&9,| DTR_POR|
|00000c50| 54 5f 61 64 64 72 2b 4d | 43 52 29 0a 58 23 64 65 |T_addr+M|CR).X#de|
|00000c60| 66 69 6e 65 20 54 53 52 | 45 5f 62 69 74 20 20 20 |fine TSR|E_bit |
|00000c70| 20 20 30 78 34 30 0a 58 | 0a 58 0a 58 0a 58 2f 2a | 0x40.X|.X.X.X/*|
|00000c80| 0a 58 20 2a 09 44 54 52 | 38 32 35 30 5f 49 53 52 |.X *.DTR|8250_ISR|
|00000c90| 20 2d 20 54 68 69 73 20 | 49 6e 74 65 72 72 75 70 | - This |Interrup|
|00000ca0| 74 20 53 65 72 76 69 63 | 65 20 52 6f 75 74 69 6e |t Servic|e Routin|
|00000cb0| 65 20 61 74 74 61 63 68 | 65 64 20 74 6f 20 65 69 |e attach|ed to ei|
|00000cc0| 74 68 65 72 20 43 4f 4d | 31 0a 58 20 2a 09 20 20 |ther COM|1.X *. |
|00000cd0| 20 20 20 20 20 20 20 20 | 20 20 20 20 6f 72 20 43 | | or C|
|00000ce0| 4f 4d 32 2e 20 20 49 74 | 20 64 72 69 76 65 73 20 |OM2. It| drives |
|00000cf0| 74 68 65 20 4e 53 43 38 | 32 35 30 20 77 69 74 68 |the NSC8|250 with|
|00000d00| 20 48 61 72 64 77 61 72 | 65 0a 58 20 2a 09 20 20 | Hardwar|e.X *. |
|00000d10| 20 20 20 20 20 20 20 20 | 20 20 20 20 48 61 6e 64 | | Hand|
|00000d20| 73 68 61 6b 69 6e 67 2e | 20 20 69 2e 65 2e 20 46 |shaking.| i.e. F|
|00000d30| 6c 6f 77 20 6f 66 20 43 | 6f 6e 74 72 6f 6c 20 69 |low of C|ontrol i|
|00000d40| 73 20 6d 61 69 6e 74 61 | 69 6e 65 64 20 62 79 20 |s mainta|ined by |
|00000d50| 0a 58 20 2a 09 20 20 20 | 20 20 20 20 20 20 20 20 |.X *. | |
|00000d60| 20 20 20 52 54 53 20 28 | 52 65 71 75 65 73 74 20 | RTS (|Request |
|00000d70| 74 6f 20 53 65 6e 64 29 | 20 43 54 53 20 28 43 6c |to Send)| CTS (Cl|
|00000d80| 65 61 72 20 74 6f 20 53 | 65 6e 64 29 20 4c 6f 67 |ear to S|end) Log|
|00000d90| 69 63 2e 0a 58 20 2a 20 | 20 20 20 20 20 20 20 20 |ic..X * | |
|00000da0| 20 20 20 20 20 20 20 41 | 66 74 65 72 20 69 6e 73 | A|fter ins|
|00000db0| 74 61 6c 6c 61 74 69 6f | 6e 20 62 79 20 43 61 74 |tallatio|n by Cat|
|00000dc0| 63 68 5f 52 74 2c 20 69 | 74 20 63 61 74 63 68 65 |ch_Rt, i|t catche|
|00000dd0| 73 20 74 68 65 0a 58 20 | 2a 20 20 20 20 20 20 20 |s the.X |* |
|00000de0| 20 20 20 20 20 20 20 20 | 20 38 32 35 30 20 69 6e | | 8250 in|
|00000df0| 74 65 72 72 75 70 74 73 | 20 61 6e 64 20 65 6e 5f |terrupts| and en_|
|00000e00| 71 75 65 75 65 73 20 69 | 6e 63 6f 6d 69 6e 67 20 |queues i|ncoming |
|00000e10| 63 68 61 72 61 63 74 65 | 72 73 0a 58 20 2a 20 20 |characte|rs.X * |
|00000e20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 66 72 | | fr|
|00000e30| 6f 6d 20 74 68 65 20 53 | 65 72 69 61 6c 20 50 6f |om the S|erial Po|
|00000e40| 72 74 20 2d 20 61 6e 64 | 20 64 65 2d 71 75 65 75 |rt - and| de-queu|
|00000e50| 65 73 20 6f 75 74 67 6f | 69 6e 67 0a 58 20 2a 20 |es outgo|ing.X * |
|00000e60| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 63 | | c|
|00000e70| 68 61 72 61 63 74 65 72 | 73 20 74 6f 20 74 68 65 |haracter|s to the|
|00000e80| 20 53 65 72 69 61 6c 20 | 50 6f 72 74 2e 0a 58 20 | Serial |Port..X |
|00000e90| 2a 2f 0a 58 0a 58 23 69 | 66 20 28 21 64 65 66 69 |*/.X.X#i|f (!defi|
|00000ea0| 6e 65 64 20 28 44 4c 43 | 29 29 0a 76 6f 69 64 20 |ned (DLC|)).void |
|00000eb0| 20 20 20 28 69 6e 74 65 | 72 72 75 70 74 20 66 61 | (inte|rrupt fa|
|00000ec0| 72 20 2a 20 64 74 72 5f | 73 61 76 65 5f 76 65 63 |r * dtr_|save_vec|
|00000ed0| 29 20 28 76 6f 69 64 29 | 3b 0a 76 6f 69 64 20 69 |) (void)|;.void i|
|00000ee0| 6e 74 65 72 72 75 70 74 | 20 66 61 72 20 0a 64 74 |nterrupt| far .dt|
|00000ef0| 72 38 32 35 30 5f 69 73 | 72 20 28 76 6f 69 64 29 |r8250_is|r (void)|
|00000f00| 0a 58 23 65 6c 73 65 0a | 69 6e 74 20 0a 64 74 72 |.X#else.|int .dtr|
|00000f10| 38 32 35 30 5f 69 73 72 | 20 28 29 0a 58 23 65 6e |8250_isr| ().X#en|
|00000f20| 64 69 66 0a 58 7b 0a 58 | 20 20 20 20 69 6e 74 20 |dif.X{.X| int |
|00000f30| 20 20 20 20 63 68 3b 0a | 58 20 20 20 20 63 68 61 | ch;.|X cha|
|00000f40| 72 20 20 20 20 74 65 73 | 74 5f 73 74 61 74 75 73 |r tes|t_status|
|00000f50| 3b 0a 58 0a 58 20 20 20 | 20 65 6e 61 62 6c 65 20 |;.X.X | enable |
|00000f60| 28 29 3b 0a 58 20 20 20 | 20 74 65 73 74 5f 73 74 |();.X | test_st|
|00000f70| 61 74 75 73 20 3d 20 69 | 6e 62 79 74 65 20 28 28 |atus = i|nbyte ((|
|00000f80| 44 54 52 5f 50 4f 52 54 | 5f 61 64 64 72 20 2b 20 |DTR_PORT|_addr + |
|00000f90| 49 49 52 29 29 3b 0a 58 | 20 20 20 20 64 6f 0a 58 |IIR));.X| do.X|
|00000fa0| 20 20 20 20 7b 0a 58 20 | 20 20 20 20 20 20 20 73 | {.X | s|
|00000fb0| 77 69 74 63 68 20 28 74 | 65 73 74 5f 73 74 61 74 |witch (t|est_stat|
|00000fc0| 75 73 29 0a 58 20 20 20 | 20 20 20 20 20 7b 0a 58 |us).X | {.X|
|00000fd0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 |.X | ca|
|00000fe0| 73 65 20 49 49 52 5f 72 | 6c 73 3a 0a 58 20 20 20 |se IIR_r|ls:.X |
|00000ff0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 44 54 52 | | DTR|
|00001000| 5f 50 4f 52 54 5f 73 74 | 61 74 75 73 20 7c 3d 20 |_PORT_st|atus |= |
|00001010| 69 6e 62 79 74 65 20 28 | 28 44 54 52 5f 50 4f 52 |inbyte (|(DTR_POR|
|00001020| 54 5f 61 64 64 72 20 2b | 20 4c 53 52 29 29 3b 0a |T_addr +| LSR));.|
|00001030| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00001040| 20 62 72 65 61 6b 3b 0a | 58 0a 58 20 20 20 20 20 | break;.|X.X |
|00001050| 20 20 20 20 20 20 20 63 | 61 73 65 20 49 49 52 5f | c|ase IIR_|
|00001060| 72 65 63 65 69 76 65 3a | 0a 58 20 20 20 20 20 20 |receive:|.X |
|00001070| 20 20 20 20 20 20 20 20 | 20 20 63 68 20 3d 20 69 | | ch = i|
|00001080| 6e 62 79 74 65 20 28 44 | 54 52 5f 50 4f 52 54 5f |nbyte (D|TR_PORT_|
|00001090| 61 64 64 72 29 3b 0a 58 | 20 20 20 20 20 20 20 20 |addr);.X| |
|000010a0| 20 20 20 20 20 20 20 20 | 69 66 20 28 28 65 6e 5f | |if ((en_|
|000010b0| 71 75 65 75 65 20 28 64 | 74 72 38 32 35 30 5f 69 |queue (d|tr8250_i|
|000010c0| 6e 71 75 65 75 65 2c 20 | 63 68 29 20 3c 20 31 30 |nqueue, |ch) < 10|
|000010d0| 29 20 26 26 20 21 52 43 | 56 5f 64 69 73 61 62 6c |) && !RC|V_disabl|
|000010e0| 65 64 29 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |ed).X | |
|000010f0| 20 20 20 20 20 7b 0a 58 | 20 20 20 20 20 20 20 20 | {.X| |
|00001100| 20 20 20 20 20 20 20 20 | 20 20 20 20 52 43 56 5f | | RCV_|
|00001110| 64 69 73 61 62 6c 65 64 | 20 3d 20 54 52 55 45 3b |disabled| = TRUE;|
|00001120| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00001130| 20 20 20 20 20 20 44 52 | 4f 50 5f 64 74 72 3b 0a | DR|OP_dtr;.|
|00001140| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00001150| 20 7d 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00001160| 20 20 20 20 65 6c 73 65 | 0a 58 20 20 20 20 20 20 | else|.X |
|00001170| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 52 43 | | if (RC|
|00001180| 56 5f 64 69 73 61 62 6c | 65 64 20 26 26 20 28 71 |V_disabl|ed && (q|
|00001190| 75 65 75 65 5f 61 76 61 | 69 6c 20 28 64 74 72 38 |ueue_ava|il (dtr8|
|000011a0| 32 35 30 5f 69 6e 71 75 | 65 75 65 29 20 3e 20 32 |250_inqu|eue) > 2|
|000011b0| 30 29 29 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |0)).X | |
|000011c0| 20 20 20 20 20 7b 0a 58 | 20 20 20 20 20 20 20 20 | {.X| |
|000011d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 52 43 56 5f | | RCV_|
|000011e0| 64 69 73 61 62 6c 65 64 | 20 3d 20 46 41 4c 53 45 |disabled| = FALSE|
|000011f0| 3b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |;.X | |
|00001200| 20 20 20 20 20 20 20 41 | 53 53 45 52 54 5f 64 74 | A|SSERT_dt|
|00001210| 72 3b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |r;.X | |
|00001220| 20 20 20 20 7d 0a 58 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00001230| 20 20 20 20 20 20 20 62 | 72 65 61 6b 3b 0a 58 0a | b|reak;.X.|
|00001240| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 63 61 73 |X | cas|
|00001250| 65 20 49 49 52 5f 74 72 | 61 6e 73 6d 69 74 3a 0a |e IIR_tr|ansmit:.|
|00001260| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00001270| 20 44 49 53 41 42 4c 45 | 5f 78 6d 69 74 3b 0a 58 | DISABLE|_xmit;.X|
|00001280| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00001290| 62 72 65 61 6b 3b 0a 58 | 0a 58 20 20 20 20 20 20 |break;.X|.X |
|000012a0| 20 20 20 20 20 20 63 61 | 73 65 20 49 49 52 5f 6d | ca|se IIR_m|
|000012b0| 73 74 61 74 75 73 3a 0a | 58 20 20 20 20 20 20 20 |status:.|X |
|000012c0| 20 20 20 20 20 20 20 20 | 20 64 74 72 38 32 35 30 | | dtr8250|
|000012d0| 5f 4d 53 52 5f 72 65 67 | 20 3d 20 69 6e 62 79 74 |_MSR_reg| = inbyt|
|000012e0| 65 20 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |e (DTR_P|ORT_addr|
|000012f0| 20 2b 20 4d 53 52 29 3b | 0a 58 20 20 20 20 20 20 | + MSR);|.X |
|00001300| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 52 43 | | if (RC|
|00001310| 56 5f 64 69 73 61 62 6c | 65 64 20 26 26 20 28 71 |V_disabl|ed && (q|
|00001320| 75 65 75 65 5f 61 76 61 | 69 6c 20 28 64 74 72 38 |ueue_ava|il (dtr8|
|00001330| 32 35 30 5f 69 6e 71 75 | 65 75 65 29 20 3e 20 32 |250_inqu|eue) > 2|
|00001340| 30 29 29 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |0)).X | |
|00001350| 20 20 20 20 20 7b 0a 58 | 20 20 20 20 20 20 20 20 | {.X| |
|00001360| 20 20 20 20 20 20 20 20 | 20 20 20 20 52 43 56 5f | | RCV_|
|00001370| 64 69 73 61 62 6c 65 64 | 20 3d 20 46 41 4c 53 45 |disabled| = FALSE|
|00001380| 3b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |;.X | |
|00001390| 20 20 20 20 20 20 20 41 | 53 53 45 52 54 5f 64 74 | A|SSERT_dt|
|000013a0| 72 3b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |r;.X | |
|000013b0| 20 20 20 20 7d 0a 58 20 | 20 20 20 20 20 20 20 20 | }.X | |
|000013c0| 20 20 20 20 20 20 20 62 | 72 65 61 6b 3b 0a 58 20 | b|reak;.X |
|000013d0| 20 20 20 20 20 20 20 7d | 0a 58 20 20 20 20 7d 20 | }|.X } |
|000013e0| 77 68 69 6c 65 20 28 28 | 74 65 73 74 5f 73 74 61 |while ((|test_sta|
|000013f0| 74 75 73 20 3d 20 69 6e | 62 79 74 65 20 28 44 54 |tus = in|byte (DT|
|00001400| 52 5f 50 4f 52 54 5f 61 | 64 64 72 20 2b 20 49 49 |R_PORT_a|ddr + II|
|00001410| 52 29 29 20 21 3d 20 49 | 49 52 5f 63 6f 6d 70 6c |R)) != I|IR_compl|
|00001420| 65 74 65 29 3b 0a 58 20 | 20 20 20 64 69 73 61 62 |ete);.X | disab|
|00001430| 6c 65 20 28 29 3b 0a 58 | 20 20 20 20 6f 75 74 62 |le ();.X| outb|
|00001440| 79 74 65 20 28 49 4e 54 | 5f 63 6e 74 72 6c 2c 20 |yte (INT|_cntrl, |
|00001450| 45 4f 49 5f 77 6f 72 64 | 29 3b 0a 58 23 69 66 20 |EOI_word|);.X#if |
|00001460| 28 64 65 66 69 6e 65 64 | 20 28 44 4c 43 29 29 0a |(defined| (DLC)).|
|00001470| 58 20 20 20 20 72 65 74 | 75 72 6e 20 28 31 29 3b |X ret|urn (1);|
|00001480| 0a 58 23 65 6e 64 69 66 | 0a 58 7d 0a 58 0a 58 0a |.X#endif|.X}.X.X.|
|00001490| 58 0a 58 0a 58 2f 2a 0a | 58 20 2a 09 44 54 52 38 |X.X.X/*.|X *.DTR8|
|000014a0| 32 35 30 5f 49 4e 49 54 | 20 2d 20 48 65 72 65 20 |250_INIT| - Here |
|000014b0| 77 65 20 67 65 74 20 74 | 68 65 20 61 64 64 72 65 |we get t|he addre|
|000014c0| 73 73 20 6f 66 20 74 68 | 65 20 38 32 35 30 20 50 |ss of th|e 8250 P|
|000014d0| 6f 72 74 0a 58 20 2a 09 | 20 20 20 20 20 20 20 20 |ort.X *.| |
|000014e0| 20 20 20 20 20 20 20 77 | 68 69 63 68 20 63 6f 72 | w|hich cor|
|000014f0| 72 65 73 70 6f 6e 64 73 | 20 74 6f 20 74 68 65 20 |responds| to the |
|00001500| 63 68 61 6e 6e 65 6c 20 | 70 61 73 73 65 64 20 69 |channel |passed i|
|00001510| 6e 2e 0a 58 20 2a 09 20 | 20 20 20 20 20 20 20 20 |n..X *. | |
|00001520| 20 20 20 20 20 20 57 65 | 20 74 68 65 6e 20 6d 61 | We| then ma|
|00001530| 73 73 61 67 65 20 74 68 | 65 20 38 32 35 39 20 49 |ssage th|e 8259 I|
|00001540| 6e 74 65 72 72 75 70 74 | 20 43 6f 6e 74 72 6f 6c |nterrupt| Control|
|00001550| 6c 65 72 0a 58 20 2a 09 | 20 20 20 20 20 20 20 20 |ler.X *.| |
|00001560| 20 20 20 20 20 20 20 63 | 61 6c 63 75 6c 61 74 65 | c|alculate|
|00001570| 20 74 68 65 20 50 68 79 | 73 69 63 61 6c 20 49 6e | the Phy|sical In|
|00001580| 74 65 72 72 75 70 74 20 | 61 6e 64 20 73 61 76 65 |terrupt |and save|
|00001590| 20 6f 66 66 0a 58 20 2a | 09 20 20 20 20 20 20 20 | off.X *|. |
|000015a0| 20 20 20 20 20 20 20 20 | 74 68 65 20 38 32 35 30 | |the 8250|
|000015b0| 27 73 20 63 75 72 72 65 | 6e 74 20 63 6f 6e 74 65 |'s curre|nt conte|
|000015c0| 6e 74 73 2e 20 20 54 68 | 65 6e 20 61 74 74 61 63 |nts. Th|en attac|
|000015d0| 68 20 74 68 65 0a 58 20 | 2a 09 20 20 20 20 20 20 |h the.X |*. |
|000015e0| 20 20 20 20 20 20 20 20 | 20 6e 73 63 38 32 35 30 | | nsc8250|
|000015f0| 5f 69 6e 74 65 72 72 75 | 70 74 20 72 6f 75 74 69 |_interru|pt routi|
|00001600| 6e 65 20 74 6f 20 74 68 | 65 20 69 6e 74 65 72 72 |ne to th|e interr|
|00001610| 75 70 74 20 61 6e 64 0a | 58 20 2a 09 20 20 20 20 |upt and.|X *. |
|00001620| 20 20 20 20 20 20 20 20 | 20 20 20 72 65 74 75 72 | | retur|
|00001630| 6e 20 74 68 65 20 72 74 | 20 72 65 74 75 72 6e 65 |n the rt| returne|
|00001640| 64 20 69 6e 64 65 78 20 | 66 6f 72 20 73 61 76 69 |d index |for savi|
|00001650| 6e 67 20 2d 20 69 74 27 | 73 0a 58 20 2a 09 20 20 |ng - it'|s.X *. |
|00001660| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 6e 65 65 | | nee|
|00001670| 64 65 64 20 74 6f 20 74 | 65 72 6d 69 6e 61 74 65 |ded to t|erminate|
|00001680| 20 74 68 65 20 69 6e 74 | 65 72 72 75 70 74 2e 0a | the int|errupt..|
|00001690| 58 20 2a 2f 0a 58 0a 58 | 23 64 65 66 69 6e 65 20 |X */.X.X|#define |
|000016a0| 44 54 52 38 32 35 30 5f | 53 54 41 43 4b 5f 53 49 |DTR8250_|STACK_SI|
|000016b0| 5a 45 20 31 30 32 34 0a | 69 6e 74 20 20 20 20 20 |ZE 1024.|int |
|000016c0| 20 20 20 64 74 72 38 32 | 35 30 5f 69 6e 74 6e 6f | dtr82|50_intno|
|000016d0| 3b 0a 73 74 61 74 69 63 | 20 69 6e 74 20 64 74 72 |;.static| int dtr|
|000016e0| 5f 69 6e 74 6d 61 73 6b | 20 5b 5d 20 3d 20 7b 20 |_intmask| [] = { |
|000016f0| 30 78 65 66 2c 20 30 78 | 66 37 2c 20 30 78 65 66 |0xef, 0x|f7, 0xef|
|00001700| 2c 20 30 78 66 37 20 7d | 3b 0a 58 2f 2a 0a 58 20 |, 0xf7 }|;.X/*.X |
|00001710| 2a 20 54 68 65 20 61 62 | 6f 76 65 20 38 32 35 39 |* The ab|ove 8259|
|00001720| 20 6d 61 73 6b 20 62 69 | 74 73 20 61 72 65 20 64 | mask bi|ts are d|
|00001730| 65 74 65 72 6d 69 6e 65 | 64 20 66 72 6f 6d 20 74 |etermine|d from t|
|00001740| 68 65 20 66 6f 72 6d 75 | 6c 61 0a 58 20 2a 20 20 |he formu|la.X * |
|00001750| 20 20 20 20 20 20 20 20 | 6d 61 73 6b 20 3d 20 7e | |mask = ~|
|00001760| 28 31 20 3c 3c 20 28 35 | 20 2d 20 50 4f 52 54 5f |(1 << (5| - PORT_|
|00001770| 43 48 41 4e 4e 45 4c 29 | 29 3b 0a 58 20 2a 20 54 |CHANNEL)|);.X * T|
|00001780| 68 65 20 61 72 72 61 79 | 20 61 73 73 75 6d 65 73 |he array| assumes|
|00001790| 20 74 68 61 74 20 43 4f | 4d 33 20 61 6e 64 20 43 | that CO|M3 and C|
|000017a0| 4f 4d 34 20 75 73 65 20 | 74 68 65 20 73 61 6d 65 |OM4 use |the same|
|000017b0| 20 69 6e 74 65 72 72 75 | 70 74 73 0a 58 20 2a 20 | interru|pts.X * |
|000017c0| 61 73 20 43 4f 4d 31 20 | 61 6e 64 20 43 4f 4d 32 |as COM1 |and COM2|
|000017d0| 2e 0a 58 20 2a 2f 0a 73 | 74 61 74 69 63 20 69 6e |..X */.s|tatic in|
|000017e0| 74 20 64 74 72 5f 69 6e | 74 6e 6f 20 20 20 5b 5d |t dtr_in|tno []|
|000017f0| 20 3d 20 7b 20 31 32 2c | 20 31 31 2c 20 31 32 2c | = { 12,| 11, 12,|
|00001800| 20 31 31 20 7d 3b 0a 58 | 2f 2a 0a 58 20 2a 20 54 | 11 };.X|/*.X * T|
|00001810| 68 65 20 61 62 6f 76 65 | 20 69 6e 74 65 72 72 75 |he above| interru|
|00001820| 70 74 20 6e 75 6d 62 65 | 72 20 61 72 72 61 79 20 |pt numbe|r array |
|00001830| 69 73 20 62 61 73 65 64 | 20 6f 6e 20 74 68 65 20 |is based| on the |
|00001840| 61 6c 67 6f 72 69 74 68 | 6d 0a 58 20 2a 20 20 20 |algorith|m.X * |
|00001850| 20 20 20 20 64 74 72 38 | 32 35 30 5f 69 6e 74 6e | dtr8|250_intn|
|00001860| 6f 20 3d 20 28 31 33 20 | 2d 20 50 4f 52 54 5f 63 |o = (13 |- PORT_c|
|00001870| 68 61 6e 6e 65 6c 29 3b | 0a 58 20 2a 2f 0a 58 0a |hannel);|.X */.X.|
|00001880| 58 0a 76 6f 69 64 20 0a | 64 74 72 38 32 35 30 5f |X.void .|dtr8250_|
|00001890| 69 6e 69 74 20 28 63 68 | 61 6e 6e 65 6c 2c 20 62 |init (ch|annel, b|
|000018a0| 75 66 5f 73 69 7a 65 29 | 0a 69 6e 74 20 20 20 20 |uf_size)|.int |
|000018b0| 20 63 68 61 6e 6e 65 6c | 2c 20 62 75 66 5f 73 69 | channel|, buf_si|
|000018c0| 7a 65 3b 0a 58 7b 0a 58 | 20 20 20 20 69 6e 74 20 |ze;.X{.X| int |
|000018d0| 20 20 20 20 44 6f 73 5f | 61 64 64 72 65 73 73 2c | Dos_|address,|
|000018e0| 20 6d 61 73 6b 3b 0a 58 | 20 20 20 20 44 54 52 5f | mask;.X| DTR_|
|000018f0| 50 4f 52 54 5f 63 68 61 | 6e 6e 65 6c 20 3d 20 63 |PORT_cha|nnel = c|
|00001900| 68 61 6e 6e 65 6c 3b 0a | 58 20 20 20 20 64 74 72 |hannel;.|X dtr|
|00001910| 38 32 35 30 5f 69 6e 71 | 75 65 75 65 20 3d 20 61 |8250_inq|ueue = a|
|00001920| 6c 6c 6f 63 5f 71 75 65 | 75 65 20 28 62 75 66 5f |lloc_que|ue (buf_|
|00001930| 73 69 7a 65 29 3b 0a 58 | 20 20 20 20 44 6f 73 5f |size);.X| Dos_|
|00001940| 61 64 64 72 65 73 73 20 | 3d 20 28 44 54 52 5f 50 |address |= (DTR_P|
|00001950| 4f 52 54 5f 63 68 61 6e | 6e 65 6c 20 2d 20 31 29 |ORT_chan|nel - 1)|
|00001960| 20 2a 20 32 3b 0a 58 20 | 20 20 20 70 65 65 6b 6d | * 2;.X | peekm|
|00001970| 65 6d 20 28 30 78 34 30 | 2c 20 44 6f 73 5f 61 64 |em (0x40|, Dos_ad|
|00001980| 64 72 65 73 73 2c 20 44 | 54 52 5f 50 4f 52 54 5f |dress, D|TR_PORT_|
|00001990| 61 64 64 72 29 3b 0a 58 | 20 20 20 20 6d 61 73 6b |addr);.X| mask|
|000019a0| 20 3d 20 64 74 72 5f 69 | 6e 74 6d 61 73 6b 20 5b | = dtr_i|ntmask [|
|000019b0| 44 54 52 5f 50 4f 52 54 | 5f 63 68 61 6e 6e 65 6c |DTR_PORT|_channel|
|000019c0| 2d 31 5d 3b 0a 58 20 20 | 20 20 64 74 72 38 32 35 |-1];.X | dtr825|
|000019d0| 30 5f 53 41 56 45 5f 69 | 6e 74 5f 6d 61 73 6b 20 |0_SAVE_i|nt_mask |
|000019e0| 3d 20 69 6e 62 79 74 65 | 20 28 49 4e 54 5f 6d 61 |= inbyte| (INT_ma|
|000019f0| 73 6b 29 3b 0a 58 20 20 | 20 20 6d 61 73 6b 20 26 |sk);.X | mask &|
|00001a00| 3d 20 64 74 72 38 32 35 | 30 5f 53 41 56 45 5f 69 |= dtr825|0_SAVE_i|
|00001a10| 6e 74 5f 6d 61 73 6b 3b | 0a 58 09 64 74 72 38 32 |nt_mask;|.X.dtr82|
|00001a20| 35 30 5f 69 6e 74 6e 6f | 20 3d 20 64 74 72 5f 69 |50_intno| = dtr_i|
|00001a30| 6e 74 6e 6f 20 5b 44 54 | 52 5f 50 4f 52 54 5f 63 |ntno [DT|R_PORT_c|
|00001a40| 68 61 6e 6e 65 6c 2d 31 | 5d 3b 0a 58 20 20 20 20 |hannel-1|];.X |
|00001a50| 64 74 72 38 32 35 30 5f | 4c 43 52 5f 73 61 76 65 |dtr8250_|LCR_save|
|00001a60| 20 3d 20 69 6e 62 79 74 | 65 20 28 44 54 52 5f 50 | = inbyt|e (DTR_P|
|00001a70| 4f 52 54 5f 61 64 64 72 | 20 2b 20 4c 43 52 29 3b |ORT_addr| + LCR);|
|00001a80| 0a 58 20 20 20 20 64 69 | 73 61 62 6c 65 20 28 29 |.X di|sable ()|
|00001a90| 3b 0a 58 20 20 20 20 6f | 75 74 62 79 74 65 20 28 |;.X o|utbyte (|
|00001aa0| 44 54 52 5f 50 4f 52 54 | 5f 61 64 64 72 20 2b 20 |DTR_PORT|_addr + |
|00001ab0| 4c 43 52 2c 20 64 74 72 | 38 32 35 30 5f 4c 43 52 |LCR, dtr|8250_LCR|
|00001ac0| 5f 73 61 76 65 20 7c 20 | 4c 43 52 5f 44 4c 41 42 |_save | |LCR_DLAB|
|00001ad0| 29 3b 0a 58 20 20 20 20 | 64 74 72 38 32 35 30 5f |);.X |dtr8250_|
|00001ae0| 4d 43 52 5f 73 61 76 65 | 20 3d 20 69 6e 62 79 74 |MCR_save| = inbyt|
|00001af0| 65 20 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |e (DTR_P|ORT_addr|
|00001b00| 20 2b 20 4d 43 52 29 3b | 0a 58 20 20 20 20 64 74 | + MCR);|.X dt|
|00001b10| 72 38 32 35 30 5f 44 4c | 5f 6c 73 62 20 3d 20 69 |r8250_DL|_lsb = i|
|00001b20| 6e 62 79 74 65 20 28 44 | 54 52 5f 50 4f 52 54 5f |nbyte (D|TR_PORT_|
|00001b30| 61 64 64 72 29 3b 0a 58 | 20 20 20 20 64 74 72 38 |addr);.X| dtr8|
|00001b40| 32 35 30 5f 44 4c 5f 6d | 73 62 20 3d 20 69 6e 62 |250_DL_m|sb = inb|
|00001b50| 79 74 65 20 28 44 54 52 | 5f 50 4f 52 54 5f 61 64 |yte (DTR|_PORT_ad|
|00001b60| 64 72 20 2b 20 31 29 3b | 0a 58 20 20 20 20 6f 75 |dr + 1);|.X ou|
|00001b70| 74 62 79 74 65 20 28 44 | 54 52 5f 50 4f 52 54 5f |tbyte (D|TR_PORT_|
|00001b80| 61 64 64 72 20 2b 20 4c | 43 52 2c 20 64 74 72 38 |addr + L|CR, dtr8|
|00001b90| 32 35 30 5f 4c 43 52 5f | 73 61 76 65 20 26 20 30 |250_LCR_|save & 0|
|00001ba0| 78 37 46 29 3b 0a 58 20 | 20 20 20 64 74 72 38 32 |x7F);.X | dtr82|
|00001bb0| 35 30 5f 49 45 52 5f 73 | 61 76 65 20 3d 20 69 6e |50_IER_s|ave = in|
|00001bc0| 62 79 74 65 20 28 44 54 | 52 5f 50 4f 52 54 5f 61 |byte (DT|R_PORT_a|
|00001bd0| 64 64 72 20 2b 20 49 45 | 52 29 3b 0a 58 20 20 20 |ddr + IE|R);.X |
|00001be0| 20 65 6e 61 62 6c 65 20 | 28 29 3b 0a 58 23 69 66 | enable |();.X#if|
|00001bf0| 20 28 64 65 66 69 6e 65 | 64 20 28 44 4c 43 29 29 | (define|d (DLC))|
|00001c00| 0a 58 20 20 20 20 69 6e | 74 5f 69 6e 74 65 72 63 |.X in|t_interc|
|00001c10| 65 70 74 20 28 64 74 72 | 38 32 35 30 5f 69 6e 74 |ept (dtr|8250_int|
|00001c20| 6e 6f 2c 20 26 64 74 72 | 38 32 35 30 5f 69 73 72 |no, &dtr|8250_isr|
|00001c30| 2c 20 44 54 52 38 32 35 | 30 5f 53 54 41 43 4b 5f |, DTR825|0_STACK_|
|00001c40| 53 49 5a 45 29 3b 0a 58 | 23 65 6c 73 65 0a 58 20 |SIZE);.X|#else.X |
|00001c50| 20 20 20 64 74 72 5f 73 | 61 76 65 5f 76 65 63 20 | dtr_s|ave_vec |
|00001c60| 3d 20 67 65 74 76 65 63 | 74 20 28 64 74 72 38 32 |= getvec|t (dtr82|
|00001c70| 35 30 5f 69 6e 74 6e 6f | 29 3b 0a 58 20 20 20 20 |50_intno|);.X |
|00001c80| 73 65 74 76 65 63 74 20 | 28 64 74 72 38 32 35 30 |setvect |(dtr8250|
|00001c90| 5f 69 6e 74 6e 6f 2c 20 | 64 74 72 38 32 35 30 5f |_intno, |dtr8250_|
|00001ca0| 69 73 72 29 3b 0a 58 23 | 65 6e 64 69 66 0a 58 20 |isr);.X#|endif.X |
|00001cb0| 20 20 20 44 45 4c 41 59 | 5f 69 6e 69 74 20 28 29 | DELAY|_init ()|
|00001cc0| 3b 0a 58 20 20 20 20 6f | 75 74 62 79 74 65 20 28 |;.X o|utbyte (|
|00001cd0| 49 4e 54 5f 6d 61 73 6b | 2c 20 6d 61 73 6b 29 3b |INT_mask|, mask);|
|00001ce0| 0a 58 7d 0a 58 0a 58 0a | 58 0a 58 0a 58 2f 2a 0a |.X}.X.X.|X.X.X/*.|
|00001cf0| 58 20 2a 09 44 54 52 38 | 32 35 30 5f 54 45 52 4d |X *.DTR8|250_TERM|
|00001d00| 20 2d 20 54 68 69 73 20 | 72 6f 75 74 69 6e 65 20 | - This |routine |
|00001d10| 72 65 73 74 6f 72 65 73 | 20 74 68 65 20 52 53 32 |restores| the RS2|
|00001d20| 33 32 20 56 65 63 74 6f | 72 20 62 61 63 6b 20 74 |32 Vecto|r back t|
|00001d30| 6f 20 69 74 73 0a 58 20 | 2a 09 20 20 20 20 20 20 |o its.X |*. |
|00001d40| 20 20 20 20 20 20 20 20 | 20 73 74 61 74 65 20 62 | | state b|
|00001d50| 65 66 6f 72 65 20 44 54 | 52 38 32 35 30 5f 49 4e |efore DT|R8250_IN|
|00001d60| 49 54 20 77 61 73 20 63 | 61 6c 6c 65 64 2e 0a 58 |IT was c|alled..X|
|00001d70| 20 2a 2f 0a 58 0a 76 6f | 69 64 20 0a 64 74 72 38 | */.X.vo|id .dtr8|
|00001d80| 32 35 30 5f 74 65 72 6d | 20 28 69 6e 74 20 72 65 |250_term| (int re|
|00001d90| 73 74 6f 72 65 29 0a 58 | 7b 0a 58 20 20 20 20 64 |store).X|{.X d|
|00001da0| 69 73 61 62 6c 65 20 28 | 29 3b 0a 58 20 20 20 20 |isable (|);.X |
|00001db0| 6f 75 74 62 79 74 65 20 | 28 49 4e 54 5f 6d 61 73 |outbyte |(INT_mas|
|00001dc0| 6b 2c 20 64 74 72 38 32 | 35 30 5f 53 41 56 45 5f |k, dtr82|50_SAVE_|
|00001dd0| 69 6e 74 5f 6d 61 73 6b | 29 3b 0a 58 20 20 20 20 |int_mask|);.X |
|00001de0| 69 66 20 28 72 65 73 74 | 6f 72 65 29 0a 58 20 20 |if (rest|ore).X |
|00001df0| 20 20 7b 0a 58 09 20 20 | 20 20 6f 75 74 62 79 74 | {.X. | outbyt|
|00001e00| 65 20 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |e (DTR_P|ORT_addr|
|00001e10| 20 2b 20 4c 43 52 2c 20 | 4c 43 52 5f 44 4c 41 42 | + LCR, |LCR_DLAB|
|00001e20| 29 3b 0a 58 09 20 20 20 | 20 6f 75 74 62 79 74 65 |);.X. | outbyte|
|00001e30| 20 28 44 54 52 5f 50 4f | 52 54 5f 61 64 64 72 2c | (DTR_PO|RT_addr,|
|00001e40| 20 64 74 72 38 32 35 30 | 5f 44 4c 5f 6c 73 62 29 | dtr8250|_DL_lsb)|
|00001e50| 3b 0a 58 09 20 20 20 20 | 6f 75 74 62 79 74 65 20 |;.X. |outbyte |
|00001e60| 28 44 54 52 5f 50 4f 52 | 54 5f 61 64 64 72 20 2b |(DTR_POR|T_addr +|
|00001e70| 20 31 2c 20 64 74 72 38 | 32 35 30 5f 44 4c 5f 6d | 1, dtr8|250_DL_m|
|00001e80| 73 62 29 3b 0a 58 09 20 | 20 20 20 6f 75 74 62 79 |sb);.X. | outby|
|00001e90| 74 65 20 28 44 54 52 5f | 50 4f 52 54 5f 61 64 64 |te (DTR_|PORT_add|
|00001ea0| 72 20 2b 20 4d 43 52 2c | 20 64 74 72 38 32 35 30 |r + MCR,| dtr8250|
|00001eb0| 5f 4d 43 52 5f 73 61 76 | 65 29 3b 0a 58 09 20 20 |_MCR_sav|e);.X. |
|00001ec0| 20 20 6f 75 74 62 79 74 | 65 20 28 44 54 52 5f 50 | outbyt|e (DTR_P|
|00001ed0| 4f 52 54 5f 61 64 64 72 | 20 2b 20 4c 43 52 2c 20 |ORT_addr| + LCR, |
|00001ee0| 30 78 37 46 29 3b 0a 58 | 09 20 20 20 20 6f 75 74 |0x7F);.X|. out|
|00001ef0| 62 79 74 65 20 28 44 54 | 52 5f 50 4f 52 54 5f 61 |byte (DT|R_PORT_a|
|00001f00| 64 64 72 20 2b 20 49 45 | 52 2c 20 64 74 72 38 32 |ddr + IE|R, dtr82|
|00001f10| 35 30 5f 49 45 52 5f 73 | 61 76 65 29 3b 0a 58 09 |50_IER_s|ave);.X.|
|00001f20| 20 20 20 20 6f 75 74 62 | 79 74 65 20 28 44 54 52 | outb|yte (DTR|
|00001f30| 5f 50 4f 52 54 5f 61 64 | 64 72 20 2b 20 4c 43 52 |_PORT_ad|dr + LCR|
|00001f40| 2c 20 64 74 72 38 32 35 | 30 5f 4c 43 52 5f 73 61 |, dtr825|0_LCR_sa|
|00001f50| 76 65 29 3b 0a 58 09 7d | 0a 58 23 69 66 20 28 64 |ve);.X.}|.X#if (d|
|00001f60| 65 66 69 6e 65 64 20 28 | 44 4c 43 29 29 0a 58 20 |efined (|DLC)).X |
|00001f70| 20 20 20 69 6e 74 5f 72 | 65 73 74 6f 72 65 20 28 | int_r|estore (|
|00001f80| 64 74 72 38 32 35 30 5f | 69 6e 74 6e 6f 29 3b 0a |dtr8250_|intno);.|
|00001f90| 58 23 65 6c 73 65 0a 58 | 20 20 20 20 73 65 74 76 |X#else.X| setv|
|00001fa0| 65 63 74 20 28 64 74 72 | 38 32 35 30 5f 69 6e 74 |ect (dtr|8250_int|
|00001fb0| 6e 6f 2c 20 64 74 72 5f | 73 61 76 65 5f 76 65 63 |no, dtr_|save_vec|
|00001fc0| 29 3b 0a 58 23 65 6e 64 | 69 66 0a 58 7d 0a 58 0a |);.X#end|if.X}.X.|
|00001fd0| 58 0a 58 0a 58 0a 58 2f | 2a 0a 58 20 2a 09 44 54 |X.X.X.X/|*.X *.DT|
|00001fe0| 52 38 32 35 30 5f 52 45 | 41 44 20 2d 20 74 68 69 |R8250_RE|AD - thi|
|00001ff0| 73 20 72 6f 75 74 69 6e | 65 20 6c 6f 6f 6b 73 20 |s routin|e looks |
|00002000| 69 6e 20 74 68 65 20 52 | 53 32 33 32 68 77 5f 69 |in the R|S232hw_i|
|00002010| 6e 71 75 65 75 65 20 66 | 6f 72 20 61 20 63 68 61 |nqueue f|or a cha|
|00002020| 72 61 63 74 65 72 0a 58 | 20 2a 0a 58 20 2a 2f 0a |racter.X| *.X */.|
|00002030| 58 0a 69 6e 74 20 0a 64 | 74 72 38 32 35 30 5f 72 |X.int .d|tr8250_r|
|00002040| 65 61 64 20 28 76 6f 69 | 64 29 0a 58 7b 0a 58 20 |ead (voi|d).X{.X |
|00002050| 20 20 20 69 6e 74 20 20 | 20 20 20 63 68 3b 0a 58 | int | ch;.X|
|00002060| 20 20 20 20 64 69 73 61 | 62 6c 65 20 28 29 3b 0a | disa|ble ();.|
|00002070| 58 20 20 20 20 63 68 20 | 3d 20 64 65 5f 71 75 65 |X ch |= de_que|
|00002080| 75 65 20 28 64 74 72 38 | 32 35 30 5f 69 6e 71 75 |ue (dtr8|250_inqu|
|00002090| 65 75 65 29 3b 0a 58 20 | 20 20 20 65 6e 61 62 6c |eue);.X | enabl|
|000020a0| 65 20 28 29 3b 0a 58 20 | 20 20 20 72 65 74 75 72 |e ();.X | retur|
|000020b0| 6e 20 28 63 68 29 3b 0a | 58 7d 0a 58 0a 58 0a 58 |n (ch);.|X}.X.X.X|
|000020c0| 0a 58 0a 58 2f 2a 0a 58 | 20 2a 09 44 54 52 38 32 |.X.X/*.X| *.DTR82|
|000020d0| 35 30 5f 54 49 4d 45 44 | 5f 52 45 41 44 20 2d 20 |50_TIMED|_READ - |
|000020e0| 61 74 74 65 6d 70 74 73 | 20 74 6f 20 72 65 61 64 |attempts| to read|
|000020f0| 20 72 73 32 33 32 20 70 | 6f 72 74 20 2d 20 69 66 | rs232 p|ort - if|
|00002100| 20 6e 6f 20 63 68 61 72 | 0a 58 20 2a 09 20 20 20 | no char|.X *. |
|00002110| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002120| 20 20 61 76 61 69 6c 61 | 62 6c 65 20 69 6e 20 6e | availa|ble in n|
|00002130| 75 6d 62 65 72 20 6f 66 | 20 73 65 63 6f 6e 64 73 |umber of| seconds|
|00002140| 20 70 61 73 73 65 64 0a | 58 20 2a 09 20 20 20 20 | passed.|X *. |
|00002150| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002160| 20 72 65 74 75 72 6e 73 | 20 2d 31 0a 58 20 2a 2f | returns| -1.X */|
|00002170| 0a 58 0a 69 6e 74 20 0a | 64 74 72 38 32 35 30 5f |.X.int .|dtr8250_|
|00002180| 74 69 6d 65 64 5f 72 65 | 61 64 20 28 69 6e 74 20 |timed_re|ad (int |
|00002190| 73 65 63 29 0a 58 7b 0a | 58 20 20 20 20 69 6e 74 |sec).X{.|X int|
|000021a0| 20 20 20 20 20 63 68 3b | 0a 58 0a 58 20 20 20 20 | ch;|.X.X |
|000021b0| 74 69 6d 65 72 5f 73 65 | 74 20 28 29 3b 0a 58 20 |timer_se|t ();.X |
|000021c0| 20 20 20 77 68 69 6c 65 | 20 28 28 63 68 20 3d 20 | while| ((ch = |
|000021d0| 64 74 72 38 32 35 30 5f | 72 65 61 64 20 28 29 29 |dtr8250_|read ())|
|000021e0| 20 3d 3d 20 2d 31 29 0a | 58 20 20 20 20 20 20 20 | == -1).|X |
|000021f0| 20 69 66 20 28 28 74 69 | 6d 65 72 5f 72 65 61 64 | if ((ti|mer_read|
|00002200| 20 28 29 20 2f 20 31 38 | 29 20 3e 20 73 65 63 29 | () / 18|) > sec)|
|00002210| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 62 72 |.X | br|
|00002220| 65 61 6b 3b 0a 58 20 20 | 20 20 72 65 74 75 72 6e |eak;.X | return|
|00002230| 20 28 63 68 29 3b 0a 58 | 7d 0a 58 0a 58 0a 58 0a | (ch);.X|}.X.X.X.|
|00002240| 58 0a 58 2f 2a 0a 58 20 | 2a 09 44 54 52 38 32 35 |X.X/*.X |*.DTR825|
|00002250| 30 5f 57 52 49 54 45 20 | 2d 20 70 6c 61 69 6e 20 |0_WRITE |- plain |
|00002260| 76 61 6e 69 6c 6c 61 20 | 77 72 69 74 65 20 74 6f |vanilla |write to|
|00002270| 20 74 68 65 20 70 6f 72 | 74 20 2d 20 63 68 65 63 | the por|t - chec|
|00002280| 6b 20 74 6f 20 73 65 65 | 20 74 68 61 74 0a 58 20 |k to see| that.X |
|00002290| 2a 09 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |*. | |
|000022a0| 20 20 74 68 65 20 63 68 | 69 70 20 6d 61 79 20 6e | the ch|ip may n|
|000022b0| 65 65 64 20 61 20 6b 69 | 63 6b 20 69 6e 20 74 68 |eed a ki|ck in th|
|000022c0| 65 20 70 61 6e 74 73 20 | 62 65 66 6f 72 65 20 72 |e pants |before r|
|000022d0| 65 74 75 72 6e 69 6e 67 | 0a 58 20 2a 2f 0a 58 0a |eturning|.X */.X.|
|000022e0| 69 6e 74 20 0a 64 74 72 | 38 32 35 30 5f 77 72 69 |int .dtr|8250_wri|
|000022f0| 74 65 20 28 63 68 61 72 | 20 63 68 29 0a 58 7b 0a |te (char| ch).X{.|
|00002300| 58 20 20 20 20 77 68 69 | 6c 65 20 28 28 69 6e 62 |X whi|le ((inb|
|00002310| 79 74 65 20 28 44 54 52 | 5f 50 4f 52 54 5f 61 64 |yte (DTR|_PORT_ad|
|00002320| 64 72 20 2b 20 4c 53 52 | 29 20 26 20 54 53 52 45 |dr + LSR|) & TSRE|
|00002330| 5f 62 69 74 29 20 3d 3d | 20 30 29 0a 58 20 20 20 |_bit) ==| 0).X |
|00002340| 20 20 20 20 20 3b 0a 58 | 20 20 20 20 64 74 72 38 | ;.X| dtr8|
|00002350| 32 35 30 5f 4d 53 52 5f | 72 65 67 20 3d 20 69 6e |250_MSR_|reg = in|
|00002360| 62 79 74 65 20 28 28 44 | 54 52 5f 50 4f 52 54 5f |byte ((D|TR_PORT_|
|00002370| 61 64 64 72 20 2b 20 4d | 53 52 29 29 3b 0a 58 20 |addr + M|SR));.X |
|00002380| 20 20 20 69 66 20 28 44 | 52 4f 50 50 45 44 5f 64 | if (D|ROPPED_d|
|00002390| 74 72 29 0a 58 20 20 20 | 20 20 20 20 20 72 65 74 |tr).X | ret|
|000023a0| 75 72 6e 20 2d 31 3b 0a | 58 20 20 20 20 6f 75 74 |urn -1;.|X out|
|000023b0| 62 79 74 65 20 28 44 54 | 52 5f 50 4f 52 54 5f 61 |byte (DT|R_PORT_a|
|000023c0| 64 64 72 2c 20 63 68 29 | 3b 0a 58 20 20 20 20 69 |ddr, ch)|;.X i|
|000023d0| 66 20 28 52 43 56 5f 64 | 69 73 61 62 6c 65 64 20 |f (RCV_d|isabled |
|000023e0| 26 26 20 28 71 75 65 75 | 65 5f 61 76 61 69 6c 20 |&& (queu|e_avail |
|000023f0| 28 64 74 72 38 32 35 30 | 5f 69 6e 71 75 65 75 65 |(dtr8250|_inqueue|
|00002400| 29 20 3e 20 32 30 29 29 | 0a 58 20 20 20 20 7b 0a |) > 20))|.X {.|
|00002410| 58 20 20 20 20 20 20 20 | 20 52 43 56 5f 64 69 73 |X | RCV_dis|
|00002420| 61 62 6c 65 64 20 3d 20 | 46 41 4c 53 45 3b 0a 58 |abled = |FALSE;.X|
|00002430| 20 20 20 20 20 20 20 20 | 41 53 53 45 52 54 5f 64 | |ASSERT_d|
|00002440| 74 72 3b 0a 58 20 20 20 | 20 7d 0a 58 7d 0a 58 0a |tr;.X | }.X}.X.|
|00002450| 58 0a 58 0a 58 0a 58 2f | 2a 0a 58 20 2a 09 44 54 |X.X.X.X/|*.X *.DT|
|00002460| 52 38 32 35 30 5f 44 54 | 52 4e 52 20 2d 20 64 72 |R8250_DT|RNR - dr|
|00002470| 6f 70 20 44 61 74 61 20 | 54 65 72 6d 69 6e 61 6c |op Data |Terminal|
|00002480| 20 52 65 61 64 79 20 4c | 69 6e 65 0a 58 20 2a 2f | Ready L|ine.X */|
|00002490| 0a 76 6f 69 64 0a 64 74 | 72 38 32 35 30 5f 64 74 |.void.dt|r8250_dt|
|000024a0| 6e 72 20 28 76 6f 69 64 | 29 0a 58 7b 0a 58 20 20 |nr (void|).X{.X |
|000024b0| 20 20 63 68 61 72 20 6d | 63 72 5f 73 61 76 65 3b | char m|cr_save;|
|000024c0| 0a 58 20 20 20 20 64 69 | 73 61 62 6c 65 20 28 29 |.X di|sable ()|
|000024d0| 3b 0a 58 20 20 20 20 6d | 63 72 5f 73 61 76 65 20 |;.X m|cr_save |
|000024e0| 3d 20 69 6e 62 79 74 65 | 20 28 44 54 52 5f 50 4f |= inbyte| (DTR_PO|
|000024f0| 52 54 5f 61 64 64 72 20 | 2b 20 4d 43 52 29 3b 0a |RT_addr |+ MCR);.|
|00002500| 58 20 20 20 20 6f 75 74 | 62 79 74 65 20 28 44 54 |X out|byte (DT|
|00002510| 52 5f 50 4f 52 54 5f 61 | 64 64 72 20 2b 20 4d 43 |R_PORT_a|ddr + MC|
|00002520| 52 2c 20 30 29 3b 0a 58 | 20 20 20 20 44 45 4c 41 |R, 0);.X| DELA|
|00002530| 59 5f 6c 6f 6f 70 20 28 | 35 30 30 29 3b 0a 58 20 |Y_loop (|500);.X |
|00002540| 20 20 20 6f 75 74 62 79 | 74 65 20 28 44 54 52 5f | outby|te (DTR_|
|00002550| 50 4f 52 54 5f 61 64 64 | 72 20 2b 20 4d 43 52 2c |PORT_add|r + MCR,|
|00002560| 20 6d 63 72 5f 73 61 76 | 65 29 3b 0a 58 20 20 20 | mcr_sav|e);.X |
|00002570| 20 65 6e 61 62 6c 65 20 | 28 29 3b 0a 58 7d 0a 58 | enable |();.X}.X|
|00002580| 0a 58 0a 58 0a 58 0a 58 | 2f 2a 0a 58 20 2a 09 44 |.X.X.X.X|/*.X *.D|
|00002590| 54 52 38 32 35 30 5f 47 | 45 54 5f 53 54 41 54 55 |TR8250_G|ET_STATU|
|000025a0| 53 20 2d 20 72 65 74 75 | 72 6e 73 20 74 68 65 20 |S - retu|rns the |
|000025b0| 63 75 72 72 65 6e 74 20 | 4e 53 43 38 32 35 30 20 |current |NSC8250 |
|000025c0| 73 74 61 74 75 73 20 61 | 6e 64 0a 58 20 2a 09 20 |status a|nd.X *. |
|000025d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000025e0| 20 20 20 20 72 65 73 65 | 74 73 20 61 6e 79 20 65 | rese|ts any e|
|000025f0| 72 72 6f 72 20 63 6f 6e | 64 69 74 69 6f 6e 2e 0a |rror con|dition..|
|00002600| 58 20 2a 2f 0a 58 0a 69 | 6e 74 20 0a 64 74 72 38 |X */.X.i|nt .dtr8|
|00002610| 32 35 30 5f 67 65 74 5f | 73 74 61 74 75 73 20 28 |250_get_|status (|
|00002620| 76 6f 69 64 29 0a 58 7b | 0a 58 20 20 20 20 63 68 |void).X{|.X ch|
|00002630| 61 72 20 20 20 20 72 76 | 61 6c 20 3d 20 44 54 52 |ar rv|al = DTR|
|00002640| 5f 50 4f 52 54 5f 73 74 | 61 74 75 73 3b 0a 58 20 |_PORT_st|atus;.X |
|00002650| 20 20 20 44 54 52 5f 50 | 4f 52 54 5f 73 74 61 74 | DTR_P|ORT_stat|
|00002660| 75 73 20 26 3d 20 45 52 | 52 4f 52 5f 72 65 73 65 |us &= ER|ROR_rese|
|00002670| 74 3b 0a 58 20 20 20 20 | 72 65 74 75 72 6e 20 28 |t;.X |return (|
|00002680| 28 69 6e 74 29 20 72 76 | 61 6c 29 3b 0a 58 7d 0a |(int) rv|al);.X}.|
|00002690| 58 0a 58 0a 58 0a 58 0a | 58 0a 58 2f 2a 0a 58 20 |X.X.X.X.|X.X/*.X |
|000026a0| 2a 09 44 54 52 38 32 35 | 30 5f 4d 4f 44 45 4d 5f |*.DTR825|0_MODEM_|
|000026b0| 53 54 41 54 55 53 20 2d | 20 72 65 74 75 72 6e 73 |STATUS -| returns|
|000026c0| 20 74 68 65 20 63 75 72 | 72 65 6e 74 20 4e 53 43 | the cur|rent NSC|
|000026d0| 38 32 35 30 20 4d 6f 64 | 6d 20 53 74 61 74 75 73 |8250 Mod|m Status|
|000026e0| 20 52 65 67 69 73 74 65 | 72 0a 58 20 2a 09 20 20 | Registe|r.X *. |
|000026f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002700| 20 20 20 20 20 63 6f 6e | 74 65 6e 74 73 2e 0a 58 | con|tents..X|
|00002710| 20 2a 2f 0a 58 0a 69 6e | 74 20 0a 64 74 72 38 32 | */.X.in|t .dtr82|
|00002720| 35 30 5f 6d 6f 64 65 6d | 5f 73 74 61 74 75 73 20 |50_modem|_status |
|00002730| 28 76 6f 69 64 29 0a 58 | 7b 0a 58 20 20 20 20 64 |(void).X|{.X d|
|00002740| 74 72 38 32 35 30 5f 4d | 53 52 5f 72 65 67 20 3d |tr8250_M|SR_reg =|
|00002750| 20 69 6e 62 79 74 65 20 | 28 44 54 52 5f 50 4f 52 | inbyte |(DTR_POR|
|00002760| 54 5f 61 64 64 72 20 2b | 20 4d 53 52 29 3b 0a 58 |T_addr +| MSR);.X|
|00002770| 20 20 20 20 72 65 74 75 | 72 6e 20 28 28 69 6e 74 | retu|rn ((int|
|00002780| 29 20 64 74 72 38 32 35 | 30 5f 4d 53 52 5f 72 65 |) dtr825|0_MSR_re|
|00002790| 67 29 3b 0a 58 7d 0a 58 | 0a 58 0a 58 0a 58 0a 58 |g);.X}.X|.X.X.X.X|
|000027a0| 0a 58 2f 2a 0a 58 20 2a | 09 44 54 52 38 32 35 30 |.X/*.X *|.DTR8250|
|000027b0| 5f 57 52 49 54 45 5f 42 | 52 45 41 4b 20 2d 20 57 |_WRITE_B|REAK - W|
|000027c0| 72 69 74 65 20 61 20 42 | 52 45 41 4b 20 43 68 61 |rite a B|REAK Cha|
|000027d0| 72 61 63 74 65 72 0a 58 | 20 2a 2f 0a 58 0a 76 6f |racter.X| */.X.vo|
|000027e0| 69 64 20 0a 64 74 72 38 | 32 35 30 5f 77 72 69 74 |id .dtr8|250_writ|
|000027f0| 65 5f 62 72 65 61 6b 20 | 28 76 6f 69 64 29 0a 58 |e_break |(void).X|
|00002800| 7b 0a 58 20 20 20 20 69 | 6e 74 20 20 20 20 20 69 |{.X i|nt i|
|00002810| 3b 0a 58 20 20 20 20 64 | 69 73 61 62 6c 65 20 28 |;.X d|isable (|
|00002820| 29 3b 0a 58 20 20 20 20 | 77 68 69 6c 65 20 28 28 |);.X |while ((|
|00002830| 69 6e 62 79 74 65 20 28 | 44 54 52 5f 50 4f 52 54 |inbyte (|DTR_PORT|
|00002840| 5f 61 64 64 72 20 2b 20 | 4c 53 52 29 20 26 20 30 |_addr + |LSR) & 0|
|00002850| 78 34 30 29 20 3d 3d 20 | 30 29 0a 58 20 20 20 20 |x40) == |0).X |
|00002860| 20 20 20 20 3b 0a 58 20 | 20 20 20 6f 75 74 62 79 | ;.X | outby|
|00002870| 74 65 20 28 44 54 52 5f | 50 4f 52 54 5f 61 64 64 |te (DTR_|PORT_add|
|00002880| 72 20 2b 20 4c 43 52 2c | 20 69 6e 62 79 74 65 20 |r + LCR,| inbyte |
|00002890| 28 44 54 52 5f 50 4f 52 | 54 5f 61 64 64 72 20 2b |(DTR_POR|T_addr +|
|000028a0| 20 4c 43 52 29 20 7c 20 | 30 78 34 30 29 3b 0a 58 | LCR) | |0x40);.X|
|000028b0| 20 20 20 20 66 6f 72 20 | 28 69 20 3d 20 30 3b 20 | for |(i = 0; |
|000028c0| 69 20 3c 20 31 33 30 30 | 30 3b 20 69 2b 2b 29 0a |i < 1300|0; i++).|
|000028d0| 58 20 20 20 20 20 20 20 | 20 3b 0a 58 20 20 20 20 |X | ;.X |
|000028e0| 6f 75 74 62 79 74 65 20 | 28 44 54 52 5f 50 4f 52 |outbyte |(DTR_POR|
|000028f0| 54 5f 61 64 64 72 20 2b | 20 4c 43 52 2c 20 69 6e |T_addr +| LCR, in|
|00002900| 62 79 74 65 20 28 44 54 | 52 5f 50 4f 52 54 5f 61 |byte (DT|R_PORT_a|
|00002910| 64 64 72 20 2b 20 4c 43 | 52 29 20 26 20 30 78 42 |ddr + LC|R) & 0xB|
|00002920| 46 29 3b 0a 58 20 20 20 | 20 65 6e 61 62 6c 65 20 |F);.X | enable |
|00002930| 28 29 3b 0a 58 7d 0a 58 | 0a 58 0a 58 0a 58 0a 58 |();.X}.X|.X.X.X.X|
|00002940| 0a 58 2f 2a 0a 58 20 2a | 09 44 54 52 38 32 35 30 |.X/*.X *|.DTR8250|
|00002950| 5f 50 4f 52 54 5f 49 4e | 49 54 20 28 43 6d 64 29 |_PORT_IN|IT (Cmd)|
|00002960| 20 63 6f 6e 66 69 67 75 | 72 65 73 20 74 68 65 20 | configu|res the |
|00002970| 38 32 35 30 0a 58 20 2a | 20 20 20 20 20 20 20 20 |8250.X *| |
|00002980| 63 6d 64 20 69 73 20 61 | 20 73 74 72 69 6e 67 20 |cmd is a| string |
|00002990| 6f 66 20 74 68 65 20 66 | 6f 72 6d 20 62 61 75 64 |of the f|orm baud|
|000029a0| 20 70 61 72 69 74 79 20 | 73 74 6f 70 20 64 61 74 | parity |stop dat|
|000029b0| 61 20 69 2e 65 20 0a 58 | 20 2a 20 20 20 20 20 20 |a i.e .X| * |
|000029c0| 20 20 33 30 30 20 6e 20 | 31 20 38 0a 58 20 2a 0a | 300 n |1 8.X *.|
|000029d0| 58 20 2a 20 20 20 20 20 | 20 20 20 62 61 75 64 20 |X * | baud |
|000029e0| 2d 20 33 30 30 2c 20 36 | 30 30 2c 20 31 32 30 30 |- 300, 6|00, 1200|
|000029f0| 2c 20 32 34 30 30 2c 20 | 34 38 30 30 2c 20 39 36 |, 2400, |4800, 96|
|00002a00| 30 30 0a 58 20 2a 20 20 | 20 20 20 20 20 20 70 61 |00.X * | pa|
|00002a10| 72 69 74 79 20 2d 20 6e | 20 2d 3e 20 6e 6f 20 70 |rity - n| -> no p|
|00002a20| 61 72 69 74 79 20 63 68 | 65 63 6b 0a 58 20 2a 20 |arity ch|eck.X * |
|00002a30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00002a40| 6f 20 2d 3e 20 6f 64 64 | 20 70 61 72 69 74 79 0a |o -> odd| parity.|
|00002a50| 58 20 2a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X * | |
|00002a60| 20 20 20 20 65 20 2d 3e | 20 65 76 65 6e 20 70 61 | e ->| even pa|
|00002a70| 72 69 74 79 0a 58 20 2a | 20 20 20 20 20 20 20 20 |rity.X *| |
|00002a80| 73 74 6f 70 20 20 20 2d | 20 31 20 2d 3e 20 31 20 |stop -| 1 -> 1 |
|00002a90| 73 74 6f 70 20 62 69 74 | 0a 58 20 2a 20 20 20 20 |stop bit|.X * |
|00002aa0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 32 20 2d | | 2 -|
|00002ab0| 3e 20 32 20 73 74 6f 70 | 20 62 69 74 73 0a 58 20 |> 2 stop| bits.X |
|00002ac0| 2a 20 20 20 20 20 20 20 | 20 64 61 74 61 20 20 20 |* | data |
|00002ad0| 2d 20 35 2c 20 36 2c 20 | 37 2c 20 38 20 64 61 74 |- 5, 6, |7, 8 dat|
|00002ae0| 61 20 62 69 74 73 0a 58 | 20 2a 2f 0a 58 0a 76 6f |a bits.X| */.X.vo|
|00002af0| 69 64 20 0a 64 74 72 38 | 32 35 30 5f 70 6f 72 74 |id .dtr8|250_port|
|00002b00| 5f 69 6e 69 74 20 28 63 | 6d 64 29 0a 63 68 61 72 |_init (c|md).char|
|00002b10| 20 20 20 2a 63 6d 64 3b | 0a 58 7b 0a 58 20 20 20 | *cmd;|.X{.X |
|00002b20| 20 75 6e 73 69 67 6e 65 | 64 20 62 61 75 64 2c 20 | unsigne|d baud, |
|00002b30| 64 61 74 61 2c 20 6d 6f | 64 65 5f 77 6f 72 64 2c |data, mo|de_word,|
|00002b40| 20 70 61 72 69 74 79 2c | 20 73 74 6f 70 2c 20 78 | parity,| stop, x|
|00002b50| 6f 66 66 3b 0a 58 20 20 | 20 20 63 68 61 72 20 20 |off;.X | char |
|00002b60| 20 20 70 74 79 5b 32 5d | 3b 0a 58 20 20 20 20 73 | pty[2]|;.X s|
|00002b70| 73 63 61 6e 66 20 28 63 | 6d 64 2c 20 22 25 64 20 |scanf (c|md, "%d |
|00002b80| 25 31 73 20 25 64 20 25 | 64 22 2c 20 26 62 61 75 |%1s %d %|d", &bau|
|00002b90| 64 2c 20 70 74 79 2c 20 | 26 73 74 6f 70 2c 20 26 |d, pty, |&stop, &|
|00002ba0| 64 61 74 61 29 3b 0a 58 | 20 20 20 20 2a 70 74 79 |data);.X| *pty|
|00002bb0| 20 3d 20 74 6f 75 70 70 | 65 72 20 28 2a 70 74 79 | = toupp|er (*pty|
|00002bc0| 29 3b 0a 58 20 20 20 20 | 73 77 69 74 63 68 20 28 |);.X |switch (|
|00002bd0| 2a 70 74 79 29 0a 58 20 | 20 20 20 7b 0a 58 20 20 |*pty).X | {.X |
|00002be0| 20 20 20 20 20 20 63 61 | 73 65 20 27 45 27 3a 0a | ca|se 'E':.|
|00002bf0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 70 61 72 |X | par|
|00002c00| 69 74 79 20 3d 20 33 3b | 0a 58 20 20 20 20 20 20 |ity = 3;|.X |
|00002c10| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0a 58 20 20 | br|eak;.X |
|00002c20| 20 20 20 20 20 20 63 61 | 73 65 20 27 4f 27 3a 0a | ca|se 'O':.|
|00002c30| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 70 61 72 |X | par|
|00002c40| 69 74 79 20 3d 20 31 3b | 0a 58 20 20 20 20 20 20 |ity = 1;|.X |
|00002c50| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0a 58 20 20 | br|eak;.X |
|00002c60| 20 20 20 20 20 20 63 61 | 73 65 20 27 4e 27 3a 0a | ca|se 'N':.|
|00002c70| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 70 61 72 |X | par|
|00002c80| 69 74 79 20 3d 20 30 3b | 0a 58 20 20 20 20 20 20 |ity = 0;|.X |
|00002c90| 20 20 20 20 20 20 62 72 | 65 61 6b 3b 0a 58 20 20 | br|eak;.X |
|00002ca0| 20 20 20 20 20 20 64 65 | 66 61 75 6c 74 3a 0a 58 | de|fault:.X|
|00002cb0| 20 20 20 20 20 20 20 20 | 20 20 20 20 70 61 72 69 | | pari|
|00002cc0| 74 79 20 3d 20 30 3b 0a | 58 20 20 20 20 20 20 20 |ty = 0;.|X |
|00002cd0| 20 20 20 20 20 62 72 65 | 61 6b 3b 0a 58 20 20 20 | bre|ak;.X |
|00002ce0| 20 7d 0a 58 20 20 20 20 | 73 74 6f 70 20 3d 20 28 | }.X |stop = (|
|00002cf0| 2d 2d 73 74 6f 70 20 26 | 20 31 29 3b 0a 58 20 20 |--stop &| 1);.X |
|00002d00| 20 20 73 74 6f 70 20 3c | 3c 3d 20 32 3b 0a 58 20 | stop <|<= 2;.X |
|00002d10| 20 20 20 62 61 75 64 20 | 2f 3d 20 31 30 3b 0a 58 | baud |/= 10;.X|
|00002d20| 20 20 20 20 62 61 75 64 | 20 3d 20 31 31 35 32 30 | baud| = 11520|
|00002d30| 20 2f 20 62 61 75 64 3b | 0a 58 20 20 20 20 70 61 | / baud;|.X pa|
|00002d40| 72 69 74 79 20 3c 3c 3d | 20 33 3b 0a 58 20 20 20 |rity <<=| 3;.X |
|00002d50| 20 70 61 72 69 74 79 20 | 26 3d 20 30 78 30 31 38 | parity |&= 0x018|
|00002d60| 3b 0a 58 20 20 20 20 64 | 61 74 61 20 2d 3d 20 35 |;.X d|ata -= 5|
|00002d70| 3b 0a 58 20 20 20 20 64 | 61 74 61 20 26 3d 20 33 |;.X d|ata &= 3|
|00002d80| 3b 0a 58 20 20 20 20 6d | 6f 64 65 5f 77 6f 72 64 |;.X m|ode_word|
|00002d90| 20 3d 20 64 61 74 61 20 | 7c 20 73 74 6f 70 20 7c | = data || stop ||
|00002da0| 20 70 61 72 69 74 79 3b | 0a 58 20 20 20 20 64 69 | parity;|.X di|
|00002db0| 73 61 62 6c 65 20 28 29 | 3b 0a 58 20 20 20 20 6f |sable ()|;.X o|
|00002dc0| 75 74 62 79 74 65 20 28 | 44 54 52 5f 50 4f 52 54 |utbyte (|DTR_PORT|
|00002dd0| 5f 61 64 64 72 20 2b 20 | 4c 43 52 2c 20 69 6e 62 |_addr + |LCR, inb|
|00002de0| 79 74 65 20 28 44 54 52 | 5f 50 4f 52 54 5f 61 64 |yte (DTR|_PORT_ad|
|00002df0| 64 72 20 2b 20 4c 43 52 | 29 20 7c 20 4c 43 52 5f |dr + LCR|) | LCR_|
|00002e00| 44 4c 41 42 29 3b 0a 58 | 20 20 20 20 6f 75 74 62 |DLAB);.X| outb|
|00002e10| 79 74 65 20 28 44 54 52 | 5f 50 4f 52 54 5f 61 64 |yte (DTR|_PORT_ad|
|00002e20| 64 72 2c 20 62 61 75 64 | 20 25 20 32 35 36 29 3b |dr, baud| % 256);|
|00002e30| 0a 58 20 20 20 20 6f 75 | 74 62 79 74 65 20 28 44 |.X ou|tbyte (D|
|00002e40| 54 52 5f 50 4f 52 54 5f | 61 64 64 72 20 2b 20 31 |TR_PORT_|addr + 1|
|00002e50| 2c 20 62 61 75 64 20 2f | 20 32 35 36 29 3b 0a 58 |, baud /| 256);.X|
|00002e60| 20 20 20 20 6f 75 74 62 | 79 74 65 20 28 44 54 52 | outb|yte (DTR|
|00002e70| 5f 50 4f 52 54 5f 61 64 | 64 72 20 2b 20 4c 43 52 |_PORT_ad|dr + LCR|
|00002e80| 2c 20 6d 6f 64 65 5f 77 | 6f 72 64 20 26 20 30 78 |, mode_w|ord & 0x|
|00002e90| 37 46 29 3b 0a 58 20 20 | 20 20 6f 75 74 62 79 74 |7F);.X | outbyt|
|00002ea0| 65 20 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 |e (DTR_P|ORT_addr|
|00002eb0| 20 2b 20 49 45 52 2c 20 | 52 58 5f 65 6e 61 62 6c | + IER, |RX_enabl|
|00002ec0| 65 29 3b 0a 58 20 20 20 | 20 6f 75 74 62 79 74 65 |e);.X | outbyte|
|00002ed0| 20 28 44 54 52 5f 50 4f | 52 54 5f 61 64 64 72 20 | (DTR_PO|RT_addr |
|00002ee0| 2b 20 4d 43 52 2c 20 30 | 78 30 42 29 3b 0a 58 0a |+ MCR, 0|x0B);.X.|
|00002ef0| 58 20 20 20 20 69 6e 62 | 79 74 65 20 28 44 54 52 |X inb|yte (DTR|
|00002f00| 5f 50 4f 52 54 5f 61 64 | 64 72 20 2b 20 4c 53 52 |_PORT_ad|dr + LSR|
|00002f10| 29 3b 0a 58 20 20 20 20 | 64 74 72 38 32 35 30 5f |);.X |dtr8250_|
|00002f20| 4d 53 52 5f 72 65 67 20 | 3d 20 69 6e 62 79 74 65 |MSR_reg |= inbyte|
|00002f30| 20 28 28 44 54 52 5f 50 | 4f 52 54 5f 61 64 64 72 | ((DTR_P|ORT_addr|
|00002f40| 20 2b 20 4d 53 52 29 29 | 3b 0a 58 20 20 20 20 69 | + MSR))|;.X i|
|00002f50| 6e 62 79 74 65 20 28 44 | 54 52 5f 50 4f 52 54 5f |nbyte (D|TR_PORT_|
|00002f60| 61 64 64 72 29 3b 0a 58 | 20 20 20 20 65 6e 61 62 |addr);.X| enab|
|00002f70| 6c 65 20 28 29 3b 0a 58 | 7d 0a 58 0a 58 0a 58 0a |le ();.X|}.X.X.X.|
|00002f80| 58 0a 58 2f 2a 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |X.X/*---|--------|
|00002f90| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 20 64 74 72 38 |--------|--- dtr8|
|00002fa0| 32 35 30 5f 70 6f 72 74 | 5f 65 6e 61 62 6c 65 20 |250_port|_enable |
|00002fb0| 28 29 20 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |() -----|--------|
|00002fc0| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2a 2f 0a 58 2f 2a 0a |--------|-*/.X/*.|
|00002fd0| 58 20 2a 0a 58 20 2a 2f | 0a 76 6f 69 64 0a 64 74 |X *.X */|.void.dt|
|00002fe0| 72 38 32 35 30 5f 70 6f | 72 74 5f 65 6e 61 62 6c |r8250_po|rt_enabl|
|00002ff0| 65 20 28 76 6f 69 64 29 | 0a 58 7b 0a 58 09 64 69 |e (void)|.X{.X.di|
|00003000| 73 61 62 6c 65 20 28 29 | 3b 0a 58 20 20 20 20 6f |sable ()|;.X o|
|00003010| 75 74 62 79 74 65 20 28 | 44 54 52 5f 50 4f 52 54 |utbyte (|DTR_PORT|
|00003020| 5f 61 64 64 72 20 2b 20 | 49 45 52 2c 20 52 58 5f |_addr + |IER, RX_|
|00003030| 65 6e 61 62 6c 65 29 3b | 0a 58 20 20 20 20 6f 75 |enable);|.X ou|
|00003040| 74 62 79 74 65 20 28 44 | 54 52 5f 50 4f 52 54 5f |tbyte (D|TR_PORT_|
|00003050| 61 64 64 72 20 2b 20 4d | 43 52 2c 20 30 78 30 42 |addr + M|CR, 0x0B|
|00003060| 29 3b 0a 58 0a 58 20 20 | 20 20 69 6e 62 79 74 65 |);.X.X | inbyte|
|00003070| 20 28 44 54 52 5f 50 4f | 52 54 5f 61 64 64 72 20 | (DTR_PO|RT_addr |
|00003080| 2b 20 4c 53 52 29 3b 0a | 58 20 20 20 20 64 74 72 |+ LSR);.|X dtr|
|00003090| 38 32 35 30 5f 4d 53 52 | 5f 72 65 67 20 3d 20 69 |8250_MSR|_reg = i|
|000030a0| 6e 62 79 74 65 20 28 28 | 44 54 52 5f 50 4f 52 54 |nbyte ((|DTR_PORT|
|000030b0| 5f 61 64 64 72 20 2b 20 | 4d 53 52 29 29 3b 0a 58 |_addr + |MSR));.X|
|000030c0| 20 20 20 20 69 6e 62 79 | 74 65 20 28 44 54 52 5f | inby|te (DTR_|
|000030d0| 50 4f 52 54 5f 61 64 64 | 72 29 3b 0a 58 20 20 20 |PORT_add|r);.X |
|000030e0| 20 65 6e 61 62 6c 65 20 | 28 29 3b 0a 58 7d 0a 58 | enable |();.X}.X|
|000030f0| 0a 58 0a 58 0a 58 0a 58 | 2f 2a 2d 2d 2d 2d 2d 2d |.X.X.X.X|/*------|
|00003100| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00003110| 2d 2d 20 64 74 72 38 32 | 35 30 5f 6c 69 6e 65 73 |-- dtr82|50_lines|
|00003120| 20 28 29 20 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d | () ----|--------|
|00003130| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2a 2f 0a 58 |--------|----*/.X|
|00003140| 2f 2a 0a 58 20 2a 0a 58 | 20 2a 2f 0a 76 6f 69 64 |/*.X *.X| */.void|
|00003150| 0a 64 74 72 38 32 35 30 | 5f 6c 69 6e 65 73 20 28 |.dtr8250|_lines (|
|00003160| 76 6f 69 64 29 0a 58 7b | 0a 58 20 20 20 20 70 72 |void).X{|.X pr|
|00003170| 69 6e 74 66 20 28 22 38 | 32 35 30 20 44 54 52 5f |intf ("8|250 DTR_|
|00003180| 50 4f 52 54 5f 61 64 64 | 72 20 3d 20 25 30 34 78 |PORT_add|r = %04x|
|00003190| 5c 6e 22 2c 20 44 54 52 | 5f 50 4f 52 54 5f 61 64 |\n", DTR|_PORT_ad|
|000031a0| 64 72 29 3b 0a 58 20 20 | 20 20 70 72 69 6e 74 66 |dr);.X | printf|
|000031b0| 20 28 22 38 32 35 30 20 | 4d 53 52 20 3d 20 25 30 | ("8250 |MSR = %0|
|000031c0| 32 78 5c 6e 22 2c 20 69 | 6e 62 79 74 65 20 28 44 |2x\n", i|nbyte (D|
|000031d0| 54 52 5f 50 4f 52 54 5f | 61 64 64 72 20 2b 20 4d |TR_PORT_|addr + M|
|000031e0| 53 52 29 29 3b 0a 58 7d | 0a 45 4e 44 5f 4f 46 5f |SR));.X}|.END_OF_|
|000031f0| 46 49 4c 45 0a 69 66 20 | 74 65 73 74 20 31 31 32 |FILE.if |test 112|
|00003200| 35 32 20 2d 6e 65 20 60 | 77 63 20 2d 63 20 3c 27 |52 -ne `|wc -c <'|
|00003210| 38 32 35 30 64 74 72 2e | 63 27 60 3b 20 74 68 65 |8250dtr.|c'`; the|
|00003220| 6e 0a 20 20 20 20 65 63 | 68 6f 20 73 68 61 72 3a |n. ec|ho shar:|
|00003230| 20 5c 22 27 38 32 35 30 | 64 74 72 2e 63 27 5c 22 | \"'8250|dtr.c'\"|
|00003240| 20 75 6e 70 61 63 6b 65 | 64 20 77 69 74 68 20 77 | unpacke|d with w|
|00003250| 72 6f 6e 67 20 73 69 7a | 65 21 0a 66 69 0a 23 20 |rong siz|e!.fi.# |
|00003260| 65 6e 64 20 6f 66 20 27 | 38 32 35 30 64 74 72 2e |end of '|8250dtr.|
|00003270| 63 27 0a 66 69 0a 69 66 | 20 74 65 73 74 20 2d 66 |c'.fi.if| test -f|
|00003280| 20 27 38 32 35 30 78 6f | 6e 2e 63 27 20 2d 61 20 | '8250xo|n.c' -a |
|00003290| 22 24 7b 31 7d 22 20 21 | 3d 20 22 2d 63 22 20 3b |"${1}" !|= "-c" ;|
|000032a0| 20 74 68 65 6e 20 0a 20 | 20 65 63 68 6f 20 73 68 | then . | echo sh|
|000032b0| 61 72 3a 20 57 69 6c 6c | 20 6e 6f 74 20 63 6c 6f |ar: Will| not clo|
|000032c0| 62 62 65 72 20 65 78 69 | 73 74 69 6e 67 20 66 69 |bber exi|sting fi|
|000032d0| 6c 65 20 5c 22 27 38 32 | 35 30 78 6f 6e 2e 63 27 |le \"'82|50xon.c'|
|000032e0| 5c 22 0a 65 6c 73 65 0a | 65 63 68 6f 20 73 68 61 |\".else.|echo sha|
|000032f0| 72 3a 20 45 78 74 72 61 | 63 74 69 6e 67 20 5c 22 |r: Extra|cting \"|
|00003300| 27 38 32 35 30 78 6f 6e | 2e 63 27 5c 22 20 5c 28 |'8250xon|.c'\" \(|
|00003310| 31 32 31 39 30 20 63 68 | 61 72 61 63 74 65 72 73 |12190 ch|aracters|
|00003320| 5c 29 0a 73 65 64 20 22 | 73 2f 5e 58 2f 2f 22 20 |\).sed "|s/^X//" |
|00003330| 3e 27 38 32 35 30 78 6f | 6e 2e 63 27 20 3c 3c 27 |>'8250xo|n.c' <<'|
|00003340| 45 4e 44 5f 4f 46 5f 46 | 49 4c 45 27 0a 58 2f 2a |END_OF_F|ILE'.X/*|
|00003350| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|00003360| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003370| 20 20 20 38 32 35 30 58 | 4f 4e 2e 43 0a 58 20 2a | 8250X|ON.C.X *|
|00003380| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|00003390| 20 20 20 20 20 20 20 4e | 53 43 38 32 35 30 20 52 | N|SC8250 R|
|000033a0| 53 32 33 32 20 58 6f 6e | 2f 58 6f 66 66 20 49 53 |S232 Xon|/Xoff IS|
|000033b0| 52 20 52 6f 75 74 69 6e | 65 0a 58 20 2a 0a 58 20 |R Routin|e.X *.X |
|000033c0| 2a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |* | |
|000033d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 57 72 69 74 | | Writ|
|000033e0| 74 65 6e 20 66 6f 72 20 | 74 68 65 0a 58 20 2a 0a |ten for |the.X *.|
|000033f0| 58 20 2a 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X * | |
|00003400| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003410| 20 44 61 74 61 6c 69 67 | 68 74 0a 58 20 2a 20 20 | Datalig|ht.X * |
|00003420| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003430| 20 20 20 20 20 20 20 20 | 20 4d 69 63 72 6f 73 6f | | Microso|
|00003440| 66 74 20 56 20 35 2e 78 | 0a 58 20 2a 20 20 20 20 |ft V 5.x|.X * |
|00003450| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003460| 20 20 20 20 20 20 20 20 | 20 20 20 20 54 75 72 62 | | Turb|
|00003470| 6f 43 0a 58 20 2a 20 20 | 20 20 20 20 20 20 20 20 |oC.X * | |
|00003480| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003490| 20 20 20 20 20 20 20 20 | 26 0a 58 20 2a 20 20 20 | |&.X * |
|000034a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000034b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 5a 6f 72 74 | | Zort|
|000034c0| 65 63 68 0a 58 20 2a 0a | 58 20 2a 20 20 20 20 20 |ech.X *.|X * |
|000034d0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000034e0| 20 20 20 20 20 20 20 20 | 43 20 43 6f 6d 70 69 6c | |C Compil|
|000034f0| 65 72 73 0a 58 20 2a 0a | 58 20 2a 20 20 20 20 20 |ers.X *.|X * |
|00003500| 20 20 20 20 20 20 20 43 | 6f 70 79 72 69 67 68 74 | C|opyright|
|00003510| 20 28 63 29 20 4a 6f 68 | 6e 20 42 69 72 63 68 66 | (c) Joh|n Birchf|
|00003520| 69 65 6c 64 20 31 39 38 | 37 2c 20 31 39 38 38 2c |ield 198|7, 1988,|
|00003530| 20 31 39 38 39 0a 58 20 | 2a 2f 0a 58 0a 58 0a 58 | 1989.X |*/.X.X.X|
|00003540| 23 69 6e 63 6c 75 64 65 | 20 3c 73 74 64 69 6f 2e |#include| <stdio.|
|00003550| 68 3e 0a 58 23 69 6e 63 | 6c 75 64 65 20 22 64 65 |h>.X#inc|lude "de|
|00003560| 70 65 6e 64 6e 74 2e 68 | 22 0a 58 23 69 6e 63 6c |pendnt.h|".X#incl|
|00003570| 75 64 65 20 22 64 65 6c | 61 79 2e 68 22 0a 58 23 |ude "del|ay.h".X#|
|00003580| 69 6e 63 6c 75 64 65 20 | 22 38 32 35 30 6e 73 63 |include |"8250nsc|
|00003590| 2e 68 22 0a 58 23 69 6e | 63 6c 75 64 65 20 22 38 |.h".X#in|clude "8|
|000035a0| 32 35 30 78 6f 6e 2e 68 | 22 0a 58 23 69 6e 63 6c |250xon.h|".X#incl|
|000035b0| 75 64 65 20 22 71 75 65 | 75 65 2e 68 22 0a 58 23 |ude "que|ue.h".X#|
|000035c0| 69 6e 63 6c 75 64 65 20 | 22 74 69 6d 65 72 2e 68 |include |"timer.h|
|000035d0| 22 0a 58 0a 58 23 69 66 | 20 28 21 64 65 66 69 6e |".X.X#if| (!defin|
|000035e0| 65 64 20 28 54 52 55 45 | 29 29 0a 58 23 09 64 65 |ed (TRUE|)).X#.de|
|000035f0| 66 69 6e 65 20 54 52 55 | 45 20 28 31 29 0a 58 23 |fine TRU|E (1).X#|
|00003600| 09 64 65 66 69 6e 65 20 | 46 41 4c 53 45 20 28 30 |.define |FALSE (0|
|00003610| 29 0a 58 23 65 6e 64 69 | 66 0a 58 0a 58 0a 58 23 |).X#endi|f.X.X.X#|
|00003620| 64 65 66 69 6e 65 20 49 | 5f 42 55 46 5f 53 49 5a |define I|_BUF_SIZ|
|00003630| 45 20 34 30 39 36 20 2f | 2a 20 69 6e 62 79 74 65 |E 4096 /|* inbyte|
|00003640| 75 74 20 20 42 75 66 66 | 65 72 20 53 69 7a 65 20 |ut Buff|er Size |
|00003650| 20 2a 2f 0a 58 23 64 65 | 66 69 6e 65 20 4f 5f 42 | */.X#de|fine O_B|
|00003660| 55 46 5f 53 49 5a 45 20 | 34 30 39 36 20 2f 2a 20 |UF_SIZE |4096 /* |
|00003670| 6f 75 74 70 75 74 20 42 | 75 66 66 65 72 20 53 69 |output B|uffer Si|
|00003680| 7a 65 20 2a 2f 0a 58 0a | 76 6f 6c 61 74 69 6c 65 |ze */.X.|volatile|
|00003690| 20 75 6e 73 69 67 6e 65 | 64 20 58 4f 4e 5f 50 4f | unsigne|d XON_PO|
|000036a0| 52 54 5f 61 64 64 72 65 | 73 73 20 3d 20 30 78 30 |RT_addre|ss = 0x0|
|000036b0| 33 46 38 3b 0a 76 6f 6c | 61 74 69 6c 65 20 63 68 |3F8;.vol|atile ch|
|000036c0| 61 72 20 20 20 20 20 78 | 6f 66 66 5f 65 6e 61 62 |ar x|off_enab|
|000036d0| 6c 65 64 20 20 20 20 20 | 3d 20 46 41 4c 53 45 2c |led |= FALSE,|
|000036e0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|000036f0| 20 20 20 20 78 6f 66 66 | 5f 73 65 6e 74 20 20 20 | xoff|_sent |
|00003700| 20 20 20 20 20 3d 20 46 | 41 4c 53 45 2c 20 0a 58 | = F|ALSE, .X|
|00003710| 09 09 09 20 20 20 20 20 | 20 78 6f 66 66 5f 72 65 |... | xoff_re|
|00003720| 63 65 69 76 65 64 20 20 | 20 20 3d 20 46 41 4c 53 |ceived | = FALS|
|00003730| 45 2c 0a 58 09 09 09 20 | 20 20 20 20 20 58 4f 4e |E,.X... | XON|
|00003740| 5f 50 4f 52 54 5f 73 74 | 61 74 75 73 20 20 3d 20 |_PORT_st|atus = |
|00003750| 30 2c 0a 58 09 09 09 20 | 20 20 20 20 20 58 4f 4e |0,.X... | XON|
|00003760| 5f 50 4f 52 54 5f 73 74 | 61 74 65 20 20 20 3d 20 |_PORT_st|ate = |
|00003770| 30 2c 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |0,.X | |
|00003780| 20 20 20 20 20 20 58 4f | 4e 5f 50 4f 52 54 5f 63 | XO|N_PORT_c|
|00003790| 6f 6d 6d 61 6e 64 20 3d | 20 30 2c 0a 58 09 09 09 |ommand =| 0,.X...|
|000037a0| 20 20 20 20 20 20 58 4f | 4e 5f 63 68 61 72 20 20 | XO|N_char |
|000037b0| 20 20 20 20 20 20 20 3d | 20 30 78 31 31 2c 0a 58 | =| 0x11,.X|
|000037c0| 09 09 09 09 20 20 58 4f | 46 46 5f 63 68 61 72 20 |.... XO|FF_char |
|000037d0| 20 20 20 20 20 20 20 3d | 20 30 78 31 33 3b 0a 58 | =| 0x13;.X|
|000037e0| 0a 63 68 61 72 20 20 20 | 20 20 20 20 20 20 20 58 |.char | X|
|000037f0| 4f 4e 5f 50 4f 52 54 5f | 63 68 61 6e 6e 65 6c 20 |ON_PORT_|channel |
|00003800| 3d 20 31 2c 0a 58 20 20 | 20 20 20 20 20 20 20 20 |= 1,.X | |
|00003810| 20 20 20 20 53 41 56 45 | 5f 69 6e 74 5f 6d 61 73 | SAVE|_int_mas|
|00003820| 6b 20 3d 20 30 2c 20 20 | 20 20 20 20 2f 2a 20 73 |k = 0, | /* s|
|00003830| 61 76 65 64 20 69 6e 74 | 65 72 72 75 70 74 20 63 |aved int|errupt c|
|00003840| 6f 6e 74 72 6f 6c 6c 65 | 72 20 6d 61 73 6b 20 77 |ontrolle|r mask w|
|00003850| 6f 72 64 20 2a 2f 0a 58 | 0a 58 2f 2a 0a 58 20 2a |ord */.X|.X/*.X *|
|00003860| 09 38 32 35 30 20 72 65 | 67 69 73 74 65 72 20 73 |.8250 re|gister s|
|00003870| 61 76 65 20 6c 6f 63 61 | 74 69 6f 6e 73 20 61 6e |ave loca|tions an|
|00003880| 64 20 62 61 73 65 20 61 | 64 64 72 65 73 73 20 6f |d base a|ddress o|
|00003890| 66 66 73 65 74 73 0a 58 | 20 2a 2f 0a 58 20 20 20 |ffsets.X| */.X |
|000038a0| 20 20 20 20 20 49 45 52 | 5f 73 61 76 65 20 3d 20 | IER|_save = |
|000038b0| 30 2c 20 4c 43 52 5f 73 | 61 76 65 20 3d 20 30 2c |0, LCR_s|ave = 0,|
|000038c0| 20 4d 43 52 5f 73 61 76 | 65 20 3d 20 30 2c 20 44 | MCR_sav|e = 0, D|
|000038d0| 4c 5f 6c 73 62 20 3d 20 | 30 2c 20 44 4c 5f 6d 73 |L_lsb = |0, DL_ms|
|000038e0| 62 20 3d 20 30 3b 0a 58 | 0a 58 0a 58 0a 58 0a 51 |b = 0;.X|.X.X.X.Q|
|000038f0| 55 45 55 45 20 20 2a 78 | 6f 6e 38 32 35 30 5f 69 |UEUE *x|on8250_i|
|00003900| 6e 71 75 65 75 65 2c 20 | 2a 78 6f 6e 38 32 35 30 |nqueue, |*xon8250|
|00003910| 5f 6f 75 74 71 75 65 75 | 65 3b 0a 58 0a 58 2f 2a |_outqueu|e;.X.X/*|
|00003920| 0a 58 20 2a 09 58 4f 4e | 38 32 35 30 5f 49 53 52 |.X *.XON|8250_ISR|
|00003930| 20 2d 20 54 68 69 73 20 | 69 73 20 74 68 65 20 69 | - This |is the i|
|00003940| 6e 74 65 72 72 75 70 74 | 20 68 61 6e 64 6c 65 72 |nterrupt| handler|
|00003950| 20 66 6f 72 20 74 68 65 | 0a 58 20 2a 09 20 20 20 | for the|.X *. |
|00003960| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 4e 61 74 | | Nat|
|00003970| 69 6f 6e 61 6c 20 53 65 | 6d 69 63 6f 6e 64 75 63 |ional Se|miconduc|
|00003980| 74 65 72 20 38 32 35 30 | 20 53 65 72 69 61 6c 20 |ter 8250| Serial |
|00003990| 43 68 69 70 2e 0a 58 20 | 2a 09 20 20 20 20 20 20 |Chip..X |*. |
|000039a0| 20 20 20 20 20 20 20 20 | 20 20 41 66 74 65 72 20 | | After |
|000039b0| 69 6e 73 74 61 6c 6c 61 | 74 69 6f 6e 20 62 79 20 |installa|tion by |
|000039c0| 43 61 74 63 68 5f 52 74 | 2c 20 69 74 20 63 61 74 |Catch_Rt|, it cat|
|000039d0| 63 68 65 73 20 74 68 65 | 0a 58 20 2a 09 20 20 20 |ches the|.X *. |
|000039e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 38 32 35 | | 825|
|000039f0| 30 20 69 6e 74 65 72 72 | 75 70 74 73 20 61 6e 64 |0 interr|upts and|
|00003a00| 20 65 6e 5f 71 75 65 75 | 65 73 20 69 6e 63 6f 6d | en_queu|es incom|
|00003a10| 69 6e 67 20 63 68 61 72 | 61 63 74 65 72 73 0a 58 |ing char|acters.X|
|00003a20| 20 2a 09 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | *. | |
|00003a30| 20 20 20 66 72 6f 6d 20 | 74 68 65 20 53 65 72 69 | from |the Seri|
|00003a40| 61 6c 20 50 6f 72 74 20 | 2d 20 61 6e 64 20 64 65 |al Port |- and de|
|00003a50| 2d 71 75 65 75 65 73 20 | 6f 75 74 67 6f 69 6e 67 |-queues |outgoing|
|00003a60| 0a 58 20 2a 09 20 20 20 | 20 20 20 20 20 20 20 20 |.X *. | |
|00003a70| 20 20 20 20 20 63 68 61 | 72 61 63 74 65 72 73 20 | cha|racters |
|00003a80| 74 6f 20 74 68 65 20 53 | 65 72 69 61 6c 20 50 6f |to the S|erial Po|
|00003a90| 72 74 2e 20 20 54 68 65 | 20 6f 72 69 67 69 6e 61 |rt. The| origina|
|00003aa0| 6c 20 63 6f 64 65 0a 58 | 20 2a 09 20 20 20 20 20 |l code.X| *. |
|00003ab0| 20 20 20 20 20 20 20 20 | 20 20 20 77 61 73 20 77 | | was w|
|00003ac0| 72 69 74 74 65 6e 20 69 | 6e 20 61 73 73 65 6d 62 |ritten i|n assemb|
|00003ad0| 6c 65 72 20 61 6e 64 20 | 70 72 6f 76 69 64 65 64 |ler and |provided|
|00003ae0| 20 61 62 6f 75 74 20 38 | 30 25 0a 58 20 2a 09 20 | about 8|0%.X *. |
|00003af0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 6f | | o|
|00003b00| 66 20 74 68 65 20 50 6f | 72 74 27 73 20 42 61 6e |f the Po|rt's Ban|
|00003b10| 64 77 69 64 74 68 20 61 | 74 20 39 36 30 30 20 62 |dwidth a|t 9600 b|
|00003b20| 61 75 64 20 72 75 6e 6e | 69 6e 67 0a 58 20 2a 09 |aud runn|ing.X *.|
|00003b30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003b40| 41 6e 20 58 6d 6f 64 65 | 6d 20 70 72 6f 74 6f 63 |An Xmode|m protoc|
|00003b50| 6f 6c 2e 20 20 57 65 27 | 6c 6c 20 73 65 65 20 77 |ol. We'|ll see w|
|00003b60| 68 61 74 20 74 68 69 73 | 20 64 6f 65 73 2e 2e 2e |hat this| does...|
|00003b70| 0a 58 20 2a 2f 0a 58 0a | 58 23 69 66 20 28 21 64 |.X */.X.|X#if (!d|
|00003b80| 65 66 69 6e 65 64 20 28 | 44 4c 43 29 29 0a 76 6f |efined (|DLC)).vo|
|00003b90| 69 64 20 20 20 20 28 69 | 6e 74 65 72 72 75 70 74 |id (i|nterrupt|
|00003ba0| 20 66 61 72 20 2a 20 78 | 6f 6e 5f 73 61 76 65 5f | far * x|on_save_|
|00003bb0| 76 65 63 29 20 28 76 6f | 69 64 29 3b 0a 76 6f 69 |vec) (vo|id);.voi|
|00003bc0| 64 20 69 6e 74 65 72 72 | 75 70 74 20 66 61 72 20 |d interr|upt far |
|00003bd0| 0a 78 6f 6e 38 32 35 30 | 5f 69 73 72 20 28 76 6f |.xon8250|_isr (vo|
|00003be0| 69 64 29 0a 58 23 65 6c | 73 65 0a 69 6e 74 20 0a |id).X#el|se.int .|
|00003bf0| 78 6f 6e 38 32 35 30 5f | 69 73 72 20 28 29 0a 58 |xon8250_|isr ().X|
|00003c00| 23 65 6e 64 69 66 0a 58 | 7b 0a 58 20 20 20 20 69 |#endif.X|{.X i|
|00003c10| 6e 74 20 20 20 20 20 63 | 68 3b 0a 58 20 20 20 20 |nt c|h;.X |
|00003c20| 63 68 61 72 20 20 20 20 | 74 65 73 74 5f 73 74 61 |char |test_sta|
|00003c30| 74 75 73 3b 0a 58 0a 58 | 20 20 20 20 65 6e 61 62 |tus;.X.X| enab|
|00003c40| 6c 65 20 28 29 3b 0a 58 | 20 20 20 20 74 65 73 74 |le ();.X| test|
|00003c50| 5f 73 74 61 74 75 73 20 | 3d 20 69 6e 62 79 74 65 |_status |= inbyte|
|00003c60| 20 28 28 58 4f 4e 5f 50 | 4f 52 54 5f 61 64 64 72 | ((XON_P|ORT_addr|
|00003c70| 65 73 73 20 2b 20 49 49 | 52 29 29 3b 0a 58 20 20 |ess + II|R));.X |
|00003c80| 20 20 64 6f 0a 58 20 20 | 20 20 7b 0a 58 20 20 20 | do.X | {.X |
|00003c90| 20 20 20 20 20 73 77 69 | 74 63 68 20 28 74 65 73 | swi|tch (tes|
|00003ca0| 74 5f 73 74 61 74 75 73 | 29 0a 58 20 20 20 20 20 |t_status|).X |
|00003cb0| 20 20 20 7b 0a 58 20 20 | 20 20 20 20 20 20 20 20 | {.X | |
|00003cc0| 20 20 63 61 73 65 20 49 | 49 52 5f 72 6c 73 3a 0a | case I|IR_rls:.|
|00003cd0| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00003ce0| 20 58 4f 4e 5f 50 4f 52 | 54 5f 73 74 61 74 75 73 | XON_POR|T_status|
|00003cf0| 20 7c 3d 20 69 6e 62 79 | 74 65 20 28 28 58 4f 4e | |= inby|te ((XON|
|00003d00| 5f 50 4f 52 54 5f 61 64 | 64 72 65 73 73 20 2b 20 |_PORT_ad|dress + |
|00003d10| 4c 53 52 29 29 3b 0a 58 | 20 20 20 20 20 20 20 20 |LSR));.X| |
|00003d20| 20 20 20 20 20 20 20 20 | 62 72 65 61 6b 3b 0a 58 | |break;.X|
|00003d30| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 |.X | ca|
|00003d40| 73 65 20 49 49 52 5f 72 | 65 63 65 69 76 65 3a 0a |se IIR_r|eceive:.|
|00003d50| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00003d60| 20 63 68 20 3d 20 69 6e | 62 79 74 65 20 28 58 4f | ch = in|byte (XO|
|00003d70| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 29 3b |N_PORT_a|ddress);|
|00003d80| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00003d90| 20 20 69 66 20 28 28 78 | 6f 66 66 5f 65 6e 61 62 | if ((x|off_enab|
|00003da0| 6c 65 64 20 26 26 20 21 | 78 6f 66 66 5f 73 65 6e |led && !|xoff_sen|
|00003db0| 74 29 20 26 26 0a 58 20 | 20 20 20 20 20 20 20 20 |t) &&.X | |
|00003dc0| 20 20 20 20 20 20 20 20 | 20 20 20 28 63 68 20 3d | | (ch =|
|00003dd0| 3d 20 58 4f 46 46 5f 63 | 68 61 72 29 29 0a 58 20 |= XOFF_c|har)).X |
|00003de0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 7b | | {|
|00003df0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00003e00| 20 20 20 20 20 20 78 6f | 66 66 5f 72 65 63 65 69 | xo|ff_recei|
|00003e10| 76 65 64 20 3d 20 54 52 | 55 45 3b 0a 58 20 20 20 |ved = TR|UE;.X |
|00003e20| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 7d 0a 58 | | }.X|
|00003e30| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003e40| 65 6c 73 65 0a 58 20 20 | 20 20 20 20 20 20 20 20 |else.X | |
|00003e50| 20 20 20 20 20 20 20 20 | 20 20 69 66 20 28 78 6f | | if (xo|
|00003e60| 66 66 5f 72 65 63 65 69 | 76 65 64 20 26 26 0a 58 |ff_recei|ved &&.X|
|00003e70| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003e80| 20 20 20 20 20 20 20 20 | 28 63 68 20 3d 3d 20 58 | |(ch == X|
|00003e90| 4f 4e 5f 63 68 61 72 29 | 29 0a 58 20 20 20 20 20 |ON_char)|).X |
|00003ea0| 20 20 20 20 20 20 20 20 | 20 20 20 7b 0a 58 20 20 | | {.X |
|00003eb0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003ec0| 20 20 78 6f 66 66 5f 72 | 65 63 65 69 76 65 64 20 | xoff_r|eceived |
|00003ed0| 3d 20 46 41 4c 53 45 3b | 0a 58 20 20 20 20 20 20 |= FALSE;|.X |
|00003ee0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 6f 75 | | ou|
|00003ef0| 74 62 79 74 65 20 28 58 | 4f 4e 5f 50 4f 52 54 5f |tbyte (X|ON_PORT_|
|00003f00| 61 64 64 72 65 73 73 20 | 2b 20 49 45 52 2c 20 58 |address |+ IER, X|
|00003f10| 4f 4e 5f 50 4f 52 54 5f | 63 6f 6d 6d 61 6e 64 20 |ON_PORT_|command |
|00003f20| 3d 20 52 58 5f 54 58 5f | 65 6e 61 62 6c 65 29 3b |= RX_TX_|enable);|
|00003f30| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00003f40| 20 20 7d 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00003f50| 20 20 20 20 20 65 6c 73 | 65 0a 58 20 20 20 20 20 | els|e.X |
|00003f60| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 69 | | i|
|00003f70| 66 20 28 28 65 6e 5f 71 | 75 65 75 65 20 28 78 6f |f ((en_q|ueue (xo|
|00003f80| 6e 38 32 35 30 5f 69 6e | 71 75 65 75 65 2c 20 63 |n8250_in|queue, c|
|00003f90| 68 29 20 3c 20 31 30 29 | 20 26 26 0a 58 20 20 20 |h) < 10)| &&.X |
|00003fa0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00003fb0| 20 20 20 20 20 78 6f 66 | 66 5f 65 6e 61 62 6c 65 | xof|f_enable|
|00003fc0| 64 20 26 26 20 21 78 6f | 66 66 5f 73 65 6e 74 20 |d && !xo|ff_sent |
|00003fd0| 26 26 20 21 78 6f 66 66 | 5f 72 65 63 65 69 76 65 |&& !xoff|_receive|
|00003fe0| 64 29 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |d).X | |
|00003ff0| 20 20 20 20 7b 0a 58 20 | 20 20 20 20 20 20 20 20 | {.X | |
|00004000| 20 20 20 20 20 20 20 20 | 20 20 20 78 6f 66 66 5f | | xoff_|
|00004010| 73 65 6e 74 20 3d 20 54 | 52 55 45 3b 0a 58 20 20 |sent = T|RUE;.X |
|00004020| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004030| 20 20 77 68 69 6c 65 20 | 28 28 69 6e 62 79 74 65 | while |((inbyte|
|00004040| 20 28 28 58 4f 4e 5f 50 | 4f 52 54 5f 61 64 64 72 | ((XON_P|ORT_addr|
|00004050| 65 73 73 20 2b 20 4c 53 | 52 29 29 20 26 20 30 78 |ess + LS|R)) & 0x|
|00004060| 32 30 29 20 3d 3d 20 30 | 29 0a 58 20 20 20 20 20 |20) == 0|).X |
|00004070| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004080| 20 20 20 3b 0a 58 20 20 | 20 20 20 20 20 20 20 20 | ;.X | |
|00004090| 20 20 20 20 20 20 20 20 | 20 20 6f 75 74 62 79 74 | | outbyt|
|000040a0| 65 20 28 58 4f 4e 5f 50 | 4f 52 54 5f 61 64 64 72 |e (XON_P|ORT_addr|
|000040b0| 65 73 73 20 2b 20 49 45 | 52 2c 20 58 4f 4e 5f 50 |ess + IE|R, XON_P|
|000040c0| 4f 52 54 5f 63 6f 6d 6d | 61 6e 64 20 3d 20 52 58 |ORT_comm|and = RX|
|000040d0| 5f 54 58 5f 65 6e 61 62 | 6c 65 29 3b 0a 58 20 20 |_TX_enab|le);.X |
|000040e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000040f0| 20 20 6f 75 74 62 79 74 | 65 20 28 58 4f 4e 5f 50 | outbyt|e (XON_P|
|00004100| 4f 52 54 5f 61 64 64 72 | 65 73 73 2c 20 58 4f 46 |ORT_addr|ess, XOF|
|00004110| 46 5f 63 68 61 72 29 3b | 0a 58 20 20 20 20 20 20 |F_char);|.X |
|00004120| 20 20 20 20 20 20 20 20 | 20 20 7d 0a 58 20 20 20 | | }.X |
|00004130| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 62 72 65 | | bre|
|00004140| 61 6b 3b 0a 58 0a 58 20 | 20 20 20 20 20 20 20 20 |ak;.X.X | |
|00004150| 20 20 20 63 61 73 65 20 | 49 49 52 5f 74 72 61 6e | case |IIR_tran|
|00004160| 73 6d 69 74 3a 0a 58 20 | 20 20 20 20 20 20 20 20 |smit:.X | |
|00004170| 20 20 20 20 20 20 20 69 | 66 20 28 78 6f 66 66 5f | i|f (xoff_|
|00004180| 73 65 6e 74 20 26 26 20 | 28 71 75 65 75 65 5f 61 |sent && |(queue_a|
|00004190| 76 61 69 6c 20 28 78 6f | 6e 38 32 35 30 5f 69 6e |vail (xo|n8250_in|
|000041a0| 71 75 65 75 65 29 20 3e | 20 32 30 29 29 0a 58 20 |queue) >| 20)).X |
|000041b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 7b | | {|
|000041c0| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|000041d0| 20 20 20 20 20 20 78 6f | 66 66 5f 73 65 6e 74 20 | xo|ff_sent |
|000041e0| 3d 20 46 41 4c 53 45 3b | 0a 58 20 20 20 20 20 20 |= FALSE;|.X |
|000041f0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 6f 75 | | ou|
|00004200| 74 62 79 74 65 20 28 58 | 4f 4e 5f 50 4f 52 54 5f |tbyte (X|ON_PORT_|
|00004210| 61 64 64 72 65 73 73 2c | 20 58 4f 4e 5f 63 68 61 |address,| XON_cha|
|00004220| 72 29 3b 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |r);.X | |
|00004230| 20 20 20 20 20 7d 0a 58 | 20 20 20 20 20 20 20 20 | }.X| |
|00004240| 20 20 20 20 20 20 20 20 | 65 6c 73 65 0a 58 20 20 | |else.X |
|00004250| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 69 66 | | if|
|00004260| 20 28 78 6f 66 66 5f 72 | 65 63 65 69 76 65 64 29 | (xoff_r|eceived)|
|00004270| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X | |
|00004280| 20 20 20 20 20 20 6f 75 | 74 62 79 74 65 20 28 58 | ou|tbyte (X|
|00004290| 4f 4e 5f 50 4f 52 54 5f | 61 64 64 72 65 73 73 20 |ON_PORT_|address |
|000042a0| 2b 20 49 45 52 2c 20 58 | 4f 4e 5f 50 4f 52 54 5f |+ IER, X|ON_PORT_|
|000042b0| 63 6f 6d 6d 61 6e 64 20 | 3d 20 52 58 5f 65 6e 61 |command |= RX_ena|
|000042c0| 62 6c 65 29 3b 0a 58 20 | 20 20 20 20 20 20 20 20 |ble);.X | |
|000042d0| 20 20 20 20 20 20 20 65 | 6c 73 65 0a 58 20 20 20 | e|lse.X |
|000042e0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 69 66 20 | | if |
|000042f0| 28 28 63 68 20 3d 20 64 | 65 5f 71 75 65 75 65 20 |((ch = d|e_queue |
|00004300| 28 78 6f 6e 38 32 35 30 | 5f 6f 75 74 71 75 65 75 |(xon8250|_outqueu|
|00004310| 65 29 29 20 21 3d 20 2d | 31 29 0a 58 20 20 20 20 |e)) != -|1).X |
|00004320| 20 20 20 20 20 20 20 20 | 20 20 20 20 7b 0a 58 20 | | {.X |
|00004330| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00004340| 20 20 20 6f 75 74 62 79 | 74 65 20 28 58 4f 4e 5f | outby|te (XON_|
|00004350| 50 4f 52 54 5f 61 64 64 | 72 65 73 73 2c 20 63 68 |PORT_add|ress, ch|
|00004360| 29 3b 0a 58 20 20 20 20 | 20 20 20 20 20 20 20 20 |);.X | |
|00004370| 20 20 20 20 7d 0a 58 20 | 20 20 20 20 20 20 20 20 | }.X | |
|00004380| 20 20 20 20 20 20 20 65 | 6c 73 65 0a 58 20 20 20 | e|lse.X |
|00004390| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 7b 0a 58 | | {.X|
|000043a0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|000043b0| 20 20 20 20 6f 75 74 62 | 79 74 65 20 28 58 4f 4e | outb|yte (XON|
|000043c0| 5f 50 4f 52 54 5f 61 64 | 64 72 65 73 73 20 2b 20 |_PORT_ad|dress + |
|000043d0| 49 45 52 2c 20 58 4f 4e | 5f 50 4f 52 54 5f 63 6f |IER, XON|_PORT_co|
|000043e0| 6d 6d 61 6e 64 20 3d 20 | 52 58 5f 65 6e 61 62 6c |mmand = |RX_enabl|
|000043f0| 65 29 3b 0a 58 20 20 20 | 20 20 20 20 20 20 20 20 |e);.X | |
|00004400| 20 20 20 20 20 7d 0a 58 | 20 20 20 20 20 20 20 20 | }.X| |
|00004410| 20 20 20 20 20 20 20 20 | 62 72 65 61 6b 3b 0a 58 | |break;.X|
|00004420| 0a 58 20 20 20 20 20 20 | 20 20 20 20 20 20 63 61 |.X | ca|
|00004430| 73 65 20 49 49 52 5f 6d | 73 74 61 74 75 73 3a 0a |se IIR_m|status:.|
|00004440| 58 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |X | |
|00004450| 20 74 65 73 74 5f 73 74 | 61 74 75 73 20 3d 20 69 | test_st|atus = i|
|00004460| 6e 62 79 74 65 20 28 28 | 58 4f 4e 5f 50 4f 52 54 |nbyte ((|XON_PORT|
|00004470| 5f 61 64 64 72 65 73 73 | 20 2b 20 4d 53 52 29 29 |_address| + MSR))|
|00004480| 3b 0a 58 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |;.X | |
|00004490| 20 20 20 62 72 65 61 6b | 3b 0a 58 20 20 20 20 20 | break|;.X |
|000044a0| 20 20 20 7d 0a 58 20 20 | 20 20 7d 20 77 68 69 6c | }.X | } whil|
|000044b0| 65 20 28 28 74 65 73 74 | 5f 73 74 61 74 75 73 20 |e ((test|_status |
|000044c0| 3d 20 69 6e 62 79 74 65 | 20 28 58 4f 4e 5f 50 4f |= inbyte| (XON_PO|
|000044d0| 52 54 5f 61 64 64 72 65 | 73 73 20 2b 20 49 49 52 |RT_addre|ss + IIR|
|000044e0| 29 29 20 21 3d 20 49 49 | 52 5f 63 6f 6d 70 6c 65 |)) != II|R_comple|
|000044f0| 74 65 29 3b 0a 58 20 20 | 20 20 64 69 73 61 62 6c |te);.X | disabl|
|00004500| 65 20 28 29 3b 0a 58 20 | 20 20 20 6f 75 74 62 79 |e ();.X | outby|
|00004510| 74 65 20 28 49 4e 54 5f | 63 6e 74 72 6c 2c 20 45 |te (INT_|cntrl, E|
|00004520| 4f 49 5f 77 6f 72 64 29 | 3b 0a 58 23 69 66 20 28 |OI_word)|;.X#if (|
|00004530| 64 65 66 69 6e 65 64 20 | 28 44 4c 43 29 29 0a 58 |defined |(DLC)).X|
|00004540| 20 20 20 20 72 65 74 75 | 72 6e 20 28 31 29 3b 0a | retu|rn (1);.|
|00004550| 58 23 65 6e 64 69 66 0a | 58 7d 0a 58 0a 58 0a 58 |X#endif.|X}.X.X.X|
|00004560| 0a 58 0a 58 2f 2a 0a 58 | 20 2a 09 58 4f 4e 38 32 |.X.X/*.X| *.XON82|
|00004570| 35 30 5f 49 4e 49 54 20 | 2d 20 48 65 72 65 20 77 |50_INIT |- Here w|
|00004580| 65 20 67 65 74 20 74 68 | 65 20 61 64 64 72 65 73 |e get th|e addres|
|00004590| 73 20 6f 66 20 74 68 65 | 20 38 32 35 30 20 50 6f |s of the| 8250 Po|
|000045a0| 72 74 0a 58 20 2a 09 20 | 20 20 20 20 20 20 20 20 |rt.X *. | |
|000045b0| 20 20 20 20 20 20 20 77 | 68 69 63 68 20 63 6f 72 | w|hich cor|
|000045c0| 72 65 73 70 6f 6e 64 73 | 20 74 6f 20 74 68 65 20 |responds| to the |
|000045d0| 63 68 61 6e 6e 65 6c 20 | 70 61 73 73 65 64 20 69 |channel |passed i|
|000045e0| 6e 2e 0a 58 20 2a 09 20 | 20 20 20 20 20 20 20 20 |n..X *. | |
|000045f0| 20 20 20 20 20 20 20 57 | 65 20 74 68 65 6e 20 6d | W|e then m|
|00004600| 61 73 73 61 67 65 20 74 | 68 65 20 38 32 35 39 20 |assage t|he 8259 |
|00004610| 49 6e 74 65 72 72 75 70 | 74 20 43 6f 6e 74 72 6f |Interrup|t Contro|
|00004620| 6c 6c 65 72 0a 58 20 2a | 09 20 20 20 20 20 20 20 |ller.X *|. |
|00004630| 20 20 20 20 20 20 20 20 | 20 63 61 6c 63 75 6c 61 | | calcula|
|00004640| 74 65 20 74 68 65 20 50 | 68 79 73 69 63 61 6c 20 |te the P|hysical |
|00004650| 49 6e 74 65 72 72 75 70 | 74 20 61 6e 64 20 73 61 |Interrup|t and sa|
|00004660| 76 65 20 6f 66 66 0a 58 | 20 2a 09 20 20 20 20 20 |ve off.X| *. |
|00004670| 20 20 20 20 20 20 20 20 | 20 20 20 74 68 65 20 38 | | the 8|
|00004680| 32 35 30 27 73 20 63 75 | 72 72 65 6e 74 20 63 6f |250's cu|rrent co|
|00004690| 6e 74 65 6e 74 73 2e 20 | 20 54 68 65 6e 20 61 74 |ntents. | Then at|
|000046a0| 74 61 63 68 20 74 68 65 | 0a 58 20 2a 09 20 20 20 |tach the|.X *. |
|000046b0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 78 6f 6e | | xon|
|000046c0| 38 32 35 30 5f 69 73 72 | 20 72 6f 75 74 69 6e 65 |8250_isr| routine|
|000046d0| 20 74 6f 20 74 68 65 20 | 69 6e 74 65 72 72 75 70 | to the |interrup|
|000046e0| 74 20 61 6e 64 0a 58 20 | 2a 09 20 20 20 20 20 20 |t and.X |*. |
|000046f0| 20 20 20 20 20 20 20 20 | 20 20 72 65 74 75 72 6e | | return|
|00004700| 20 74 68 65 20 72 74 20 | 72 65 74 75 72 6e 65 64 | the rt |returned|
|00004710| 20 69 6e 64 65 78 20 66 | 6f 72 20 73 61 76 69 6e | index f|or savin|
|00004720| 67 20 2d 20 69 74 27 73 | 0a 58 20 2a 09 20 20 20 |g - it's|.X *. |
|00004730| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 6e 65 65 | | nee|
|00004740| 64 65 64 20 74 6f 20 74 | 65 72 6d 69 6e 61 74 65 |ded to t|erminate|
|00004750| 20 74 68 65 20 69 6e 74 | 65 72 72 75 70 74 2e 0a | the int|errupt..|
|00004760| 58 20 2a 2f 0a 58 0a 58 | 23 64 65 66 69 6e 65 20 |X */.X.X|#define |
|00004770| 58 4f 4e 38 32 35 30 5f | 53 54 41 43 4b 5f 53 49 |XON8250_|STACK_SI|
|00004780| 5a 45 20 35 31 32 0a 69 | 6e 74 20 20 20 20 20 20 |ZE 512.i|nt |
|00004790| 20 20 78 6f 6e 38 32 35 | 30 5f 69 6e 74 6e 6f 3b | xon825|0_intno;|
|000047a0| 0a 73 74 61 74 69 63 20 | 69 6e 74 20 78 6f 6e 5f |.static |int xon_|
|000047b0| 69 6e 74 6d 61 73 6b 20 | 5b 5d 20 3d 20 7b 20 30 |intmask |[] = { 0|
|000047c0| 78 65 66 2c 20 30 78 66 | 37 2c 20 30 78 65 66 2c |xef, 0xf|7, 0xef,|
|000047d0| 20 30 78 66 37 20 7d 3b | 0a 58 2f 2a 0a 58 20 2a | 0xf7 };|.X/*.X *|
|000047e0| 20 54 68 65 20 61 62 6f | 76 65 20 38 32 35 39 20 | The abo|ve 8259 |
|000047f0| 6d 61 73 6b 20 62 69 74 | 73 20 61 72 65 20 64 65 |mask bit|s are de|
|00004800| 74 65 72 6d 69 6e 65 64 | 20 66 72 6f 6d 20 74 68 |termined| from th|
|00004810| 65 20 66 6f 72 6d 75 6c | 61 0a 58 20 2a 20 20 20 |e formul|a.X * |
|00004820| 20 20 20 20 20 20 20 6d | 61 73 6b 20 3d 20 7e 28 | m|ask = ~(|
|00004830| 31 20 3c 3c 20 28 35 20 | 2d 20 50 4f 52 54 5f 43 |1 << (5 |- PORT_C|
|00004840| 48 41 4e 4e 45 4c 29 29 | 3b 0a 58 20 2a 20 54 68 |HANNEL))|;.X * Th|
|00004850| 65 20 61 72 72 61 79 20 | 61 73 73 75 6d 65 73 20 |e array |assumes |
|00004860| 74 68 61 74 20 43 4f 4d | 33 20 61 6e 64 20 43 4f |that COM|3 and CO|
|00004870| 4d 34 20 75 73 65 20 74 | 68 65 20 73 61 6d 65 20 |M4 use t|he same |
|00004880| 69 6e 74 65 72 72 75 70 | 74 73 0a 58 20 2a 20 61 |interrup|ts.X * a|
|00004890| 73 20 43 4f 4d 31 20 61 | 6e 64 20 43 4f 4d 32 2e |s COM1 a|nd COM2.|
|000048a0| 0a 58 20 2a 2f 0a 73 74 | 61 74 69 63 20 69 6e 74 |.X */.st|atic int|
|000048b0| 20 78 6f 6e 5f 69 6e 74 | 6e 6f 20 20 20 5b 5d 20 | xon_int|no [] |
|000048c0| 3d 20 7b 20 31 32 2c 20 | 31 31 2c 20 31 32 2c 20 |= { 12, |11, 12, |
|000048d0| 31 31 20 7d 3b 0a 58 2f | 2a 0a 58 20 2a 20 54 68 |11 };.X/|*.X * Th|
|000048e0| 65 20 61 62 6f 76 65 20 | 69 6e 74 65 72 72 75 70 |e above |interrup|
|000048f0| 74 20 6e 75 6d 62 65 72 | 20 61 72 72 61 79 20 69 |t number| array i|
|00004900| 73 20 62 61 73 65 64 20 | 6f 6e 20 74 68 65 20 61 |s based |on the a|
|00004910| 6c 67 6f 72 69 74 68 6d | 0a 58 20 2a 20 20 20 20 |lgorithm|.X * |
|00004920| 20 20 20 78 6f 6e 38 32 | 35 30 5f 69 6e 74 6e 6f | xon82|50_intno|
|00004930| 20 3d 20 28 31 33 20 2d | 20 50 4f 52 54 5f 63 68 | = (13 -| PORT_ch|
|00004940| 61 6e 6e 65 6c 29 3b 0a | 58 20 2a 2f 0a 58 0a 58 |annel);.|X */.X.X|
|00004950| 0a 69 6e 74 20 0a 78 6f | 6e 38 32 35 30 5f 69 6e |.int .xo|n8250_in|
|00004960| 69 74 20 28 69 6e 74 20 | 63 68 61 6e 6e 65 6c 2c |it (int |channel,|
|00004970| 20 69 6e 74 20 62 75 66 | 66 65 72 5f 73 69 7a 65 | int buf|fer_size|
|00004980| 29 0a 58 7b 0a 58 20 20 | 20 20 69 6e 74 20 20 20 |).X{.X | int |
|00004990| 20 20 44 6f 73 5f 61 64 | 64 72 65 73 73 2c 20 6d | Dos_ad|dress, m|
|000049a0| 61 73 6b 3b 0a 58 20 20 | 20 20 58 4f 4e 5f 50 4f |ask;.X | XON_PO|
|000049b0| 52 54 5f 63 68 61 6e 6e | 65 6c 20 3d 20 63 68 61 |RT_chann|el = cha|
|000049c0| 6e 6e 65 6c 3b 0a 58 20 | 20 20 20 78 6f 6e 38 32 |nnel;.X | xon82|
|000049d0| 35 30 5f 69 6e 71 75 65 | 75 65 20 3d 20 61 6c 6c |50_inque|ue = all|
|000049e0| 6f 63 5f 71 75 65 75 65 | 20 28 62 75 66 66 65 72 |oc_queue| (buffer|
|000049f0| 5f 73 69 7a 65 29 3b 0a | 58 20 20 20 20 78 6f 6e |_size);.|X xon|
|00004a00| 38 32 35 30 5f 6f 75 74 | 71 75 65 75 65 20 3d 20 |8250_out|queue = |
|00004a10| 61 6c 6c 6f 63 5f 71 75 | 65 75 65 20 28 62 75 66 |alloc_qu|eue (buf|
|00004a20| 66 65 72 5f 73 69 7a 65 | 29 3b 0a 58 20 20 20 20 |fer_size|);.X |
|00004a30| 44 6f 73 5f 61 64 64 72 | 65 73 73 20 3d 20 28 58 |Dos_addr|ess = (X|
|00004a40| 4f 4e 5f 50 4f 52 54 5f | 63 68 61 6e 6e 65 6c 20 |ON_PORT_|channel |
|00004a50| 2d 20 31 29 20 2a 20 32 | 3b 0a 58 20 20 20 20 70 |- 1) * 2|;.X p|
|00004a60| 65 65 6b 6d 65 6d 20 28 | 30 78 34 30 2c 20 44 6f |eekmem (|0x40, Do|
|00004a70| 73 5f 61 64 64 72 65 73 | 73 2c 20 58 4f 4e 5f 50 |s_addres|s, XON_P|
|00004a80| 4f 52 54 5f 61 64 64 72 | 65 73 73 29 3b 0a 58 20 |ORT_addr|ess);.X |
|00004a90| 20 20 20 6d 61 73 6b 20 | 3d 20 78 6f 6e 5f 69 6e | mask |= xon_in|
|00004aa0| 74 6d 61 73 6b 20 5b 58 | 4f 4e 5f 50 4f 52 54 5f |tmask [X|ON_PORT_|
|00004ab0| 63 68 61 6e 6e 65 6c 2d | 31 5d 3b 0a 58 20 20 20 |channel-|1];.X |
|00004ac0| 20 53 41 56 45 5f 69 6e | 74 5f 6d 61 73 6b 20 3d | SAVE_in|t_mask =|
|00004ad0| 20 69 6e 62 79 74 65 20 | 28 49 4e 54 5f 6d 61 73 | inbyte |(INT_mas|
|00004ae0| 6b 29 3b 0a 58 20 20 20 | 20 6d 61 73 6b 20 26 3d |k);.X | mask &=|
|00004af0| 20 53 41 56 45 5f 69 6e | 74 5f 6d 61 73 6b 3b 0a | SAVE_in|t_mask;.|
|00004b00| 58 09 78 6f 6e 38 32 35 | 30 5f 69 6e 74 6e 6f 20 |X.xon825|0_intno |
|00004b10| 3d 20 78 6f 6e 5f 69 6e | 74 6e 6f 20 5b 58 4f 4e |= xon_in|tno [XON|
|00004b20| 5f 50 4f 52 54 5f 63 68 | 61 6e 6e 65 6c 2d 31 5d |_PORT_ch|annel-1]|
|00004b30| 3b 0a 58 20 20 20 20 4c | 43 52 5f 73 61 76 65 20 |;.X L|CR_save |
|00004b40| 3d 20 69 6e 62 79 74 65 | 20 28 58 4f 4e 5f 50 4f |= inbyte| (XON_PO|
|00004b50| 52 54 5f 61 64 64 72 65 | 73 73 20 2b 20 4c 43 52 |RT_addre|ss + LCR|
|00004b60| 29 3b 0a 58 20 20 20 20 | 64 69 73 61 62 6c 65 20 |);.X |disable |
|00004b70| 28 29 3b 0a 58 20 20 20 | 20 6f 75 74 62 79 74 65 |();.X | outbyte|
|00004b80| 20 28 58 4f 4e 5f 50 4f | 52 54 5f 61 64 64 72 65 | (XON_PO|RT_addre|
|00004b90| 73 73 20 2b 20 4c 43 52 | 2c 20 4c 43 52 5f 73 61 |ss + LCR|, LCR_sa|
|00004ba0| 76 65 20 7c 20 4c 43 52 | 5f 44 4c 41 42 29 3b 0a |ve | LCR|_DLAB);.|
|00004bb0| 58 20 20 20 20 4d 43 52 | 5f 73 61 76 65 20 3d 20 |X MCR|_save = |
|00004bc0| 69 6e 62 79 74 65 20 28 | 58 4f 4e 5f 50 4f 52 54 |inbyte (|XON_PORT|
|00004bd0| 5f 61 64 64 72 65 73 73 | 20 2b 20 4d 43 52 29 3b |_address| + MCR);|
|00004be0| 0a 58 20 20 20 20 44 4c | 5f 6c 73 62 20 3d 20 69 |.X DL|_lsb = i|
|00004bf0| 6e 62 79 74 65 20 28 58 | 4f 4e 5f 50 4f 52 54 5f |nbyte (X|ON_PORT_|
|00004c00| 61 64 64 72 65 73 73 29 | 3b 0a 58 20 20 20 20 44 |address)|;.X D|
|00004c10| 4c 5f 6d 73 62 20 3d 20 | 69 6e 62 79 74 65 20 28 |L_msb = |inbyte (|
|00004c20| 58 4f 4e 5f 50 4f 52 54 | 5f 61 64 64 72 65 73 73 |XON_PORT|_address|
|00004c30| 20 2b 20 31 29 3b 0a 58 | 20 20 20 20 6f 75 74 62 | + 1);.X| outb|
|00004c40| 79 74 65 20 28 58 4f 4e | 5f 50 4f 52 54 5f 61 64 |yte (XON|_PORT_ad|
|00004c50| 64 72 65 73 73 20 2b 20 | 4c 43 52 2c 20 4c 43 52 |dress + |LCR, LCR|
|00004c60| 5f 73 61 76 65 20 26 20 | 30 78 37 46 29 3b 0a 58 |_save & |0x7F);.X|
|00004c70| 20 20 20 20 49 45 52 5f | 73 61 76 65 20 3d 20 69 | IER_|save = i|
|00004c80| 6e 62 79 74 65 20 28 58 | 4f 4e 5f 50 4f 52 54 5f |nbyte (X|ON_PORT_|
|00004c90| 61 64 64 72 65 73 73 20 | 2b 20 49 45 52 29 3b 0a |address |+ IER);.|
|00004ca0| 58 20 20 20 20 65 6e 61 | 62 6c 65 20 28 29 3b 0a |X ena|ble ();.|
|00004cb0| 58 23 69 66 20 28 64 65 | 66 69 6e 65 64 20 28 44 |X#if (de|fined (D|
|00004cc0| 4c 43 29 29 0a 58 20 20 | 20 20 69 6e 74 5f 69 6e |LC)).X | int_in|
|00004cd0| 74 65 72 63 65 70 74 20 | 28 78 6f 6e 38 32 35 30 |tercept |(xon8250|
|00004ce0| 5f 69 6e 74 6e 6f 2c 20 | 26 78 6f 6e 38 32 35 30 |_intno, |&xon8250|
|00004cf0| 5f 69 73 72 2c 20 58 4f | 4e 38 32 35 30 5f 53 54 |_isr, XO|N8250_ST|
|00004d00| 41 43 4b 5f 53 49 5a 45 | 29 3b 0a 58 23 65 6c 73 |ACK_SIZE|);.X#els|
|00004d10| 65 0a 58 20 20 20 20 78 | 6f 6e 5f 73 61 76 65 5f |e.X x|on_save_|
|00004d20| 76 65 63 20 3d 20 67 65 | 74 76 65 63 74 20 28 78 |vec = ge|tvect (x|
|00004d30| 6f 6e 38 32 35 30 5f 69 | 6e 74 6e 6f 29 3b 0a 58 |on8250_i|ntno);.X|
|00004d40| 20 20 20 20 73 65 74 76 | 65 63 74 20 28 78 6f 6e | setv|ect (xon|
|00004d50| 38 32 35 30 5f 69 6e 74 | 6e 6f 2c 20 78 6f 6e 38 |8250_int|no, xon8|
|00004d60| 32 35 30 5f 69 73 72 29 | 3b 0a 58 23 65 6e 64 69 |250_isr)|;.X#endi|
|00004d70| 66 0a 58 20 20 20 20 44 | 45 4c 41 59 5f 69 6e 69 |f.X D|ELAY_ini|
|00004d80| 74 20 28 29 3b 0a 58 20 | 20 20 20 6f 75 74 62 79 |t ();.X | outby|
|00004d90| 74 65 20 28 49 4e 54 5f | 6d 61 73 6b 2c 20 6d 61 |te (INT_|mask, ma|
|00004da0| 73 6b 29 3b 0a 58 7d 0a | 58 0a 58 0a 58 0a 58 0a |sk);.X}.|X.X.X.X.|
|00004db0| 58 2f 2a 0a 58 20 2a 09 | 58 4f 4e 38 32 35 30 5f |X/*.X *.|XON8250_|
|00004dc0| 54 45 52 4d 20 2d 20 54 | 68 69 73 20 72 6f 75 74 |TERM - T|his rout|
|00004dd0| 69 6e 65 20 72 65 73 74 | 6f 72 65 73 20 74 68 65 |ine rest|ores the|
|00004de0| 20 72 73 32 33 32 78 6f | 6e 20 38 32 35 30 20 62 | rs232xo|n 8250 b|
|00004df0| 61 63 6b 20 74 6f 20 69 | 74 73 0a 58 20 2a 09 20 |ack to i|ts.X *. |
|00004e00| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 73 | | s|
|00004e10| 74 61 74 65 20 62 65 66 | 6f 72 65 20 78 6f 6e 38 |tate bef|ore xon8|
|00004e20| 32 35 30 5f 49 4e 49 54 | 20 77 61 73 20 63 61 6c |250_INIT| was cal|
|00004e30| 6c 65 64 20 61 6e 64 20 | 72 65 6c 65 61 73 65 73 |led and |releases|
|00004e40| 20 74 68 65 0a 58 20 2a | 09 20 20 20 20 20 20 20 | the.X *|. |
|00004e50| 20 20 20 20 20 20 20 20 | 20 63 6f 72 72 65 73 70 | | corresp|
|00004e60| 6f 6e 64 69 6e 67 20 69 | 6e 74 65 72 72 75 70 74 |onding i|nterrupt|
|00004e70| 20 62 61 63 6b 20 74 6f | 20 74 68 65 20 73 79 73 | back to| the sys|
|00004e80| 74 65 6d 2e 0a 58 20 2a | 2f 0a 58 0a 76 6f 69 64 |tem..X *|/.X.void|
|00004e90| 20 0a 78 6f 6e 38 32 35 | 30 5f 74 65 72 6d 20 28 | .xon825|0_term (|
|00004ea0| 69 6e 74 20 72 65 73 74 | 6f 72 65 29 0a 58 7b 20 |int rest|ore).X{ |
|00004eb0| 0a 58 20 20 20 20 64 69 | 73 61 62 6c 65 20 28 29 |.X di|sable ()|
|00004ec0| 3b 0a 58 20 20 20 20 6f | 75 74 62 79 74 65 20 28 |;.X o|utbyte (|
|00004ed0| 49 4e 54 5f 6d 61 73 6b | 2c 20 53 41 56 45 5f 69 |INT_mask|, SAVE_i|
|00004ee0| 6e 74 5f 6d 61 73 6b 29 | 3b 0a 58 20 20 20 20 69 |nt_mask)|;.X i|
|00004ef0| 66 20 28 72 65 73 74 6f | 72 65 29 0a 58 20 20 20 |f (resto|re).X |
|00004f00| 20 7b 0a 58 09 20 20 20 | 20 6f 75 74 62 79 74 65 | {.X. | outbyte|
|00004f10| 20 28 58 4f 4e 5f 50 4f | 52 54 5f 61 64 64 72 65 | (XON_PO|RT_addre|
|00004f20| 73 73 20 2b 20 4c 43 52 | 2c 20 4c 43 52 5f 44 4c |ss + LCR|, LCR_DL|
|00004f30| 41 42 29 3b 0a 58 09 20 | 20 20 20 6f 75 74 62 79 |AB);.X. | outby|
|00004f40| 74 65 20 28 58 4f 4e 5f | 50 4f 52 54 5f 61 64 64 |te (XON_|PORT_add|
|00004f50| 72 65 73 73 2c 20 44 4c | 5f 6c 73 62 29 3b 0a 58 |ress, DL|_lsb);.X|
|00004f60| 09 20 20 20 20 6f 75 74 | 62 79 74 65 20 28 58 4f |. out|byte (XO|
|00004f70| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|00004f80| 20 31 2c 20 44 4c 5f 6d | 73 62 29 3b 0a 58 09 20 | 1, DL_m|sb);.X. |
|00004f90| 20 20 20 6f 75 74 62 79 | 74 65 20 28 58 4f 4e 5f | outby|te (XON_|
|00004fa0| 50 4f 52 54 5f 61 64 64 | 72 65 73 73 20 2b 20 4d |PORT_add|ress + M|
|00004fb0| 43 52 2c 20 4d 43 52 5f | 73 61 76 65 29 3b 0a 58 |CR, MCR_|save);.X|
|00004fc0| 09 20 20 20 20 6f 75 74 | 62 79 74 65 20 28 58 4f |. out|byte (XO|
|00004fd0| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|00004fe0| 20 4c 43 52 2c 20 30 78 | 37 46 29 3b 0a 58 09 20 | LCR, 0x|7F);.X. |
|00004ff0| 20 20 20 6f 75 74 62 79 | 74 65 20 28 58 4f 4e 5f | outby|te (XON_|
|00005000| 50 4f 52 54 5f 61 64 64 | 72 65 73 73 20 2b 20 49 |PORT_add|ress + I|
|00005010| 45 52 2c 20 49 45 52 5f | 73 61 76 65 29 3b 0a 58 |ER, IER_|save);.X|
|00005020| 09 20 20 20 20 6f 75 74 | 62 79 74 65 20 28 58 4f |. out|byte (XO|
|00005030| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|00005040| 20 4c 43 52 2c 20 4c 43 | 52 5f 73 61 76 65 29 3b | LCR, LC|R_save);|
|00005050| 0a 58 09 7d 0a 58 23 69 | 66 20 28 64 65 66 69 6e |.X.}.X#i|f (defin|
|00005060| 65 64 20 28 44 4c 43 29 | 29 0a 58 20 20 20 20 69 |ed (DLC)|).X i|
|00005070| 6e 74 5f 72 65 73 74 6f | 72 65 20 28 78 6f 6e 38 |nt_resto|re (xon8|
|00005080| 32 35 30 5f 69 6e 74 6e | 6f 29 3b 0a 58 23 65 6c |250_intn|o);.X#el|
|00005090| 73 65 0a 58 20 20 20 20 | 73 65 74 76 65 63 74 20 |se.X |setvect |
|000050a0| 28 78 6f 6e 38 32 35 30 | 5f 69 6e 74 6e 6f 2c 20 |(xon8250|_intno, |
|000050b0| 78 6f 6e 5f 73 61 76 65 | 5f 76 65 63 29 3b 0a 58 |xon_save|_vec);.X|
|000050c0| 23 65 6e 64 69 66 0a 58 | 7d 0a 58 0a 58 0a 58 0a |#endif.X|}.X.X.X.|
|000050d0| 58 0a 58 2f 2a 0a 58 20 | 2a 09 58 4f 4e 38 32 35 |X.X/*.X |*.XON825|
|000050e0| 30 5f 52 45 41 44 20 2d | 20 74 68 69 73 20 72 6f |0_READ -| this ro|
|000050f0| 75 74 69 6e 65 20 6c 6f | 6f 6b 73 20 69 6e 20 74 |utine lo|oks in t|
|00005100| 68 65 20 78 6f 6e 38 32 | 35 30 5f 69 6e 71 75 65 |he xon82|50_inque|
|00005110| 75 65 20 66 6f 72 20 61 | 20 63 68 61 72 61 63 74 |ue for a| charact|
|00005120| 65 72 0a 58 20 2a 2f 0a | 58 0a 69 6e 74 20 0a 78 |er.X */.|X.int .x|
|00005130| 6f 6e 38 32 35 30 5f 72 | 65 61 64 20 28 76 6f 69 |on8250_r|ead (voi|
|00005140| 64 29 0a 58 7b 0a 58 20 | 20 20 20 69 6e 74 20 20 |d).X{.X | int |
|00005150| 20 20 20 63 68 3b 0a 58 | 20 20 20 20 64 69 73 61 | ch;.X| disa|
|00005160| 62 6c 65 20 28 29 3b 0a | 58 20 20 20 20 63 68 20 |ble ();.|X ch |
|00005170| 3d 20 64 65 5f 71 75 65 | 75 65 20 28 78 6f 6e 38 |= de_que|ue (xon8|
|00005180| 32 35 30 5f 69 6e 71 75 | 65 75 65 29 3b 0a 58 20 |250_inqu|eue);.X |
|00005190| 20 20 20 65 6e 61 62 6c | 65 20 28 29 3b 0a 58 20 | enabl|e ();.X |
|000051a0| 20 20 20 69 66 20 28 28 | 58 4f 4e 5f 50 4f 52 54 | if ((|XON_PORT|
|000051b0| 5f 63 6f 6d 6d 61 6e 64 | 20 3d 3d 20 52 58 5f 65 |_command| == RX_e|
|000051c0| 6e 61 62 6c 65 29 20 26 | 26 0a 58 20 20 20 20 20 |nable) &|&.X |
|000051d0| 20 20 20 28 28 21 71 75 | 65 75 65 5f 65 6d 70 74 | ((!qu|eue_empt|
|000051e0| 79 20 28 78 6f 6e 38 32 | 35 30 5f 6f 75 74 71 75 |y (xon82|50_outqu|
|000051f0| 65 75 65 29 29 20 7c 7c | 20 78 6f 66 66 5f 73 65 |eue)) ||| xoff_se|
|00005200| 6e 74 29 29 0a 58 20 20 | 20 20 20 20 20 20 6f 75 |nt)).X | ou|
|00005210| 74 62 79 74 65 20 28 58 | 4f 4e 5f 50 4f 52 54 5f |tbyte (X|ON_PORT_|
|00005220| 61 64 64 72 65 73 73 20 | 2b 20 49 45 52 2c 20 58 |address |+ IER, X|
|00005230| 4f 4e 5f 50 4f 52 54 5f | 63 6f 6d 6d 61 6e 64 20 |ON_PORT_|command |
|00005240| 3d 20 52 58 5f 54 58 5f | 65 6e 61 62 6c 65 29 3b |= RX_TX_|enable);|
|00005250| 0a 58 20 20 20 20 72 65 | 74 75 72 6e 20 28 63 68 |.X re|turn (ch|
|00005260| 29 3b 0a 58 7d 0a 58 0a | 58 0a 58 0a 58 0a 58 2f |);.X}.X.|X.X.X.X/|
|00005270| 2a 0a 58 20 2a 09 58 4f | 4e 38 32 35 30 5f 54 49 |*.X *.XO|N8250_TI|
|00005280| 4d 45 44 5f 52 45 41 44 | 20 2d 20 61 74 74 65 6d |MED_READ| - attem|
|00005290| 70 74 73 20 74 6f 20 72 | 65 61 64 20 72 73 32 33 |pts to r|ead rs23|
|000052a0| 32 20 70 6f 72 74 20 2d | 20 69 66 20 6e 6f 20 63 |2 port -| if no c|
|000052b0| 68 61 72 0a 58 20 2a 09 | 20 20 20 20 20 20 20 20 |har.X *.| |
|000052c0| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 61 76 | | av|
|000052d0| 61 69 6c 61 62 6c 65 20 | 69 6e 20 6e 75 6d 62 65 |ailable |in numbe|
|000052e0| 72 20 6f 66 20 73 65 63 | 6f 6e 64 73 20 70 61 73 |r of sec|onds pas|
|000052f0| 73 65 64 0a 58 20 2a 09 | 20 20 20 20 20 20 20 20 |sed.X *.| |
|00005300| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 72 65 | | re|
|00005310| 74 75 72 6e 73 20 2d 31 | 0a 58 20 2a 2f 0a 58 0a |turns -1|.X */.X.|
|00005320| 69 6e 74 20 0a 78 6f 6e | 38 32 35 30 5f 74 69 6d |int .xon|8250_tim|
|00005330| 65 64 5f 72 65 61 64 20 | 28 69 6e 74 20 73 65 63 |ed_read |(int sec|
|00005340| 29 0a 58 7b 0a 58 20 20 | 20 20 69 6e 74 20 20 20 |).X{.X | int |
|00005350| 20 20 63 68 3b 0a 58 0a | 58 20 20 20 20 74 69 6d | ch;.X.|X tim|
|00005360| 65 72 5f 73 65 74 20 28 | 29 3b 0a 58 20 20 20 20 |er_set (|);.X |
|00005370| 77 68 69 6c 65 20 28 28 | 63 68 20 3d 20 78 6f 6e |while ((|ch = xon|
|00005380| 38 32 35 30 5f 72 65 61 | 64 20 28 29 29 20 3d 3d |8250_rea|d ()) ==|
|00005390| 20 2d 31 29 0a 58 20 20 | 20 20 20 20 20 20 69 66 | -1).X | if|
|000053a0| 20 28 28 74 69 6d 65 72 | 5f 72 65 61 64 20 28 29 | ((timer|_read ()|
|000053b0| 20 2f 20 31 38 29 20 3e | 20 73 65 63 29 0a 58 20 | / 18) >| sec).X |
|000053c0| 20 20 20 20 20 20 20 20 | 20 20 20 62 72 65 61 6b | | break|
|000053d0| 3b 0a 58 20 20 20 20 72 | 65 74 75 72 6e 20 28 63 |;.X r|eturn (c|
|000053e0| 68 29 3b 0a 58 7d 0a 58 | 0a 58 0a 58 0a 58 0a 58 |h);.X}.X|.X.X.X.X|
|000053f0| 2f 2a 0a 58 20 2a 09 58 | 4f 4e 38 32 35 30 5f 57 |/*.X *.X|ON8250_W|
|00005400| 52 49 54 45 20 2d 20 70 | 6c 61 69 6e 20 76 61 6e |RITE - p|lain van|
|00005410| 69 6c 6c 61 20 77 72 69 | 74 65 20 74 6f 20 74 68 |illa wri|te to th|
|00005420| 65 20 70 6f 72 74 20 2d | 20 63 68 65 63 6b 20 74 |e port -| check t|
|00005430| 6f 20 73 65 65 20 74 68 | 61 74 0a 58 20 2a 09 20 |o see th|at.X *. |
|00005440| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005450| 74 68 65 20 63 68 69 70 | 20 6d 61 79 20 6e 65 65 |the chip| may nee|
|00005460| 64 20 61 20 6b 69 63 6b | 20 69 6e 20 74 68 65 20 |d a kick| in the |
|00005470| 70 61 6e 74 73 20 62 65 | 66 6f 72 65 20 72 65 74 |pants be|fore ret|
|00005480| 75 72 6e 69 6e 67 0a 58 | 20 2a 2f 0a 58 0a 69 6e |urning.X| */.X.in|
|00005490| 74 20 0a 78 6f 6e 38 32 | 35 30 5f 77 72 69 74 65 |t .xon82|50_write|
|000054a0| 20 28 63 68 61 72 20 63 | 68 29 0a 58 7b 0a 58 20 | (char c|h).X{.X |
|000054b0| 20 20 20 69 6e 74 20 20 | 20 20 20 72 76 61 6c 20 | int | rval |
|000054c0| 3d 20 2d 31 3b 0a 58 20 | 20 20 20 64 69 73 61 62 |= -1;.X | disab|
|000054d0| 6c 65 20 28 29 3b 0a 58 | 20 20 20 20 72 76 61 6c |le ();.X| rval|
|000054e0| 20 3d 20 65 6e 5f 71 75 | 65 75 65 20 28 78 6f 6e | = en_qu|eue (xon|
|000054f0| 38 32 35 30 5f 6f 75 74 | 71 75 65 75 65 2c 20 63 |8250_out|queue, c|
|00005500| 68 29 3b 0a 58 20 20 20 | 20 65 6e 61 62 6c 65 20 |h);.X | enable |
|00005510| 28 29 3b 0a 58 20 20 20 | 20 69 66 20 28 58 4f 4e |();.X | if (XON|
|00005520| 5f 50 4f 52 54 5f 63 6f | 6d 6d 61 6e 64 20 21 3d |_PORT_co|mmand !=|
|00005530| 20 52 58 5f 54 58 5f 65 | 6e 61 62 6c 65 29 0a 58 | RX_TX_e|nable).X|
|00005540| 20 20 20 20 20 20 20 20 | 6f 75 74 62 79 74 65 20 | |outbyte |
|00005550| 28 58 4f 4e 5f 50 4f 52 | 54 5f 61 64 64 72 65 73 |(XON_POR|T_addres|
|00005560| 73 20 2b 20 49 45 52 2c | 20 58 4f 4e 5f 50 4f 52 |s + IER,| XON_POR|
|00005570| 54 5f 63 6f 6d 6d 61 6e | 64 20 3d 20 52 58 5f 54 |T_comman|d = RX_T|
|00005580| 58 5f 65 6e 61 62 6c 65 | 29 3b 0a 58 20 20 20 20 |X_enable|);.X |
|00005590| 72 65 74 75 72 6e 20 28 | 72 76 61 6c 29 3b 0a 58 |return (|rval);.X|
|000055a0| 7d 0a 58 0a 58 0a 58 0a | 58 0a 58 2f 2a 0a 58 20 |}.X.X.X.|X.X/*.X |
|000055b0| 2a 09 58 4f 4e 38 32 35 | 30 5f 44 54 52 4e 52 20 |*.XON825|0_DTRNR |
|000055c0| 2d 20 64 72 6f 70 20 44 | 61 74 61 20 54 65 72 6d |- drop D|ata Term|
|000055d0| 69 6e 61 6c 20 52 65 61 | 64 79 20 4c 69 6e 65 0a |inal Rea|dy Line.|
|000055e0| 58 20 2a 2f 0a 76 6f 69 | 64 0a 78 6f 6e 38 32 35 |X */.voi|d.xon825|
|000055f0| 30 5f 64 74 6e 72 20 28 | 76 6f 69 64 29 0a 58 7b |0_dtnr (|void).X{|
|00005600| 0a 58 20 20 20 20 63 68 | 61 72 20 6d 63 72 5f 73 |.X ch|ar mcr_s|
|00005610| 61 76 65 3b 0a 58 20 20 | 20 20 64 69 73 61 62 6c |ave;.X | disabl|
|00005620| 65 20 28 29 3b 0a 58 20 | 20 20 20 6d 63 72 5f 73 |e ();.X | mcr_s|
|00005630| 61 76 65 20 3d 20 69 6e | 62 79 74 65 20 28 58 4f |ave = in|byte (XO|
|00005640| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|00005650| 20 4d 43 52 29 3b 0a 58 | 20 20 20 20 6f 75 74 62 | MCR);.X| outb|
|00005660| 79 74 65 20 28 58 4f 4e | 5f 50 4f 52 54 5f 61 64 |yte (XON|_PORT_ad|
|00005670| 64 72 65 73 73 20 2b 20 | 4d 43 52 2c 20 30 29 3b |dress + |MCR, 0);|
|00005680| 0a 58 09 44 45 4c 41 59 | 5f 6c 6f 6f 70 20 28 35 |.X.DELAY|_loop (5|
|00005690| 30 30 29 3b 0a 58 20 20 | 20 20 6f 75 74 62 79 74 |00);.X | outbyt|
|000056a0| 65 20 28 58 4f 4e 5f 50 | 4f 52 54 5f 61 64 64 72 |e (XON_P|ORT_addr|
|000056b0| 65 73 73 20 2b 20 4d 43 | 52 2c 20 6d 63 72 5f 73 |ess + MC|R, mcr_s|
|000056c0| 61 76 65 29 3b 0a 58 20 | 20 20 20 65 6e 61 62 6c |ave);.X | enabl|
|000056d0| 65 20 28 29 3b 0a 58 7d | 0a 58 0a 58 0a 58 0a 58 |e ();.X}|.X.X.X.X|
|000056e0| 0a 58 2f 2a 0a 58 20 2a | 09 58 4f 4e 38 32 35 30 |.X/*.X *|.XON8250|
|000056f0| 5f 47 45 54 5f 53 54 41 | 54 55 53 20 2d 20 72 65 |_GET_STA|TUS - re|
|00005700| 74 75 72 6e 73 20 74 68 | 65 20 63 75 72 72 65 6e |turns th|e curren|
|00005710| 74 20 72 73 32 33 32 78 | 6f 6e 20 73 74 61 74 75 |t rs232x|on statu|
|00005720| 73 20 61 6e 64 0a 58 20 | 2a 09 20 20 20 20 20 20 |s and.X |*. |
|00005730| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 | | |
|00005740| 72 65 73 65 74 73 20 61 | 6e 79 20 65 72 72 6f 72 |resets a|ny error|
|00005750| 20 63 6f 6e 64 69 74 69 | 6f 6e 2e 0a 58 20 2a 2f | conditi|on..X */|
|00005760| 0a 58 0a 69 6e 74 20 0a | 78 6f 6e 38 32 35 30 5f |.X.int .|xon8250_|
|00005770| 67 65 74 5f 73 74 61 74 | 75 73 20 28 76 6f 69 64 |get_stat|us (void|
|00005780| 29 0a 58 7b 0a 58 20 20 | 20 20 63 68 61 72 20 20 |).X{.X | char |
|00005790| 20 20 72 76 61 6c 20 3d | 20 58 4f 4e 5f 50 4f 52 | rval =| XON_POR|
|000057a0| 54 5f 73 74 61 74 75 73 | 3b 0a 58 20 20 20 20 58 |T_status|;.X X|
|000057b0| 4f 4e 5f 50 4f 52 54 5f | 73 74 61 74 75 73 20 26 |ON_PORT_|status &|
|000057c0| 3d 20 45 52 52 4f 52 5f | 72 65 73 65 74 3b 0a 58 |= ERROR_|reset;.X|
|000057d0| 20 20 20 20 72 65 74 75 | 72 6e 20 28 28 69 6e 74 | retu|rn ((int|
|000057e0| 29 20 72 76 61 6c 29 3b | 0a 58 7d 0a 58 0a 58 0a |) rval);|.X}.X.X.|
|000057f0| 58 0a 58 0a 58 2f 2a 0a | 58 20 2a 09 58 4f 4e 38 |X.X.X/*.|X *.XON8|
|00005800| 32 35 30 5f 58 4f 46 46 | 5f 53 45 4e 54 20 2d 20 |250_XOFF|_SENT - |
|00005810| 64 69 64 20 77 65 20 73 | 65 6e 64 20 61 6e 20 58 |did we s|end an X|
|00005820| 6f 66 66 20 63 68 61 72 | 3f 0a 58 20 2a 2f 0a 58 |off char|?.X */.X|
|00005830| 0a 69 6e 74 20 0a 78 6f | 6e 38 32 35 30 5f 78 6f |.int .xo|n8250_xo|
|00005840| 66 66 5f 73 65 6e 74 20 | 28 76 6f 69 64 29 0a 58 |ff_sent |(void).X|
|00005850| 7b 0a 58 20 20 20 20 72 | 65 74 75 72 6e 20 28 78 |{.X r|eturn (x|
|00005860| 6f 66 66 5f 73 65 6e 74 | 29 3b 0a 58 7d 0a 58 0a |off_sent|);.X}.X.|
|00005870| 58 0a 58 0a 58 0a 58 0a | 58 2f 2a 0a 58 20 2a 09 |X.X.X.X.|X/*.X *.|
|00005880| 58 4f 4e 38 32 35 30 5f | 57 52 49 54 45 5f 42 55 |XON8250_|WRITE_BU|
|00005890| 46 46 45 52 5f 45 4d 50 | 54 59 0a 58 20 2a 2f 0a |FFER_EMP|TY.X */.|
|000058a0| 58 0a 78 6f 6e 38 32 35 | 30 5f 77 72 69 74 65 5f |X.xon825|0_write_|
|000058b0| 62 75 66 66 65 72 5f 65 | 6d 70 74 79 20 28 76 6f |buffer_e|mpty (vo|
|000058c0| 69 64 29 0a 58 7b 0a 58 | 20 20 20 20 72 65 74 75 |id).X{.X| retu|
|000058d0| 72 6e 20 28 71 75 65 75 | 65 5f 65 6d 70 74 79 20 |rn (queu|e_empty |
|000058e0| 28 78 6f 6e 38 32 35 30 | 5f 6f 75 74 71 75 65 75 |(xon8250|_outqueu|
|000058f0| 65 29 29 3b 0a 58 7d 0a | 58 0a 58 0a 58 0a 58 0a |e));.X}.|X.X.X.X.|
|00005900| 58 0a 58 2f 2a 0a 58 20 | 2a 09 49 4f 43 54 4c 5f |X.X/*.X |*.IOCTL_|
|00005910| 53 45 54 5f 58 4f 46 46 | 0a 58 20 2a 09 73 65 74 |SET_XOFF|.X *.set|
|00005920| 73 20 74 68 65 20 72 73 | 32 33 32 20 78 6f 6e 2f |s the rs|232 xon/|
|00005930| 78 6f 66 66 09 70 72 6f | 74 6f 63 6f 6c 2e 20 20 |xoff.pro|tocol. |
|00005940| 49 74 20 61 63 63 65 70 | 74 73 20 61 20 63 6f 6d |It accep|ts a com|
|00005950| 6d 61 6e 64 20 73 74 72 | 69 6e 67 0a 58 20 2a 09 |mand str|ing.X *.|
|00005960| 6f 66 20 74 68 65 20 66 | 6f 72 6d 0a 58 20 2a 09 |of the f|orm.X *.|
|00005970| 20 20 20 20 20 20 20 20 | 20 20 20 20 20 22 79 20 | | "y |
|00005980| 6e 22 20 6f 72 20 22 6e | 20 6e 22 20 6f 72 20 22 |n" or "n| n" or "|
|00005990| 6e 20 79 22 20 6f 72 20 | 22 79 20 79 22 20 65 69 |n y" or |"y y" ei|
|000059a0| 74 68 65 72 20 75 70 70 | 65 72 20 6f 72 0a 58 20 |ther upp|er or.X |
|000059b0| 2a 09 20 20 20 20 20 20 | 20 20 20 20 20 20 20 6c |*. | l|
|000059c0| 6f 77 65 72 20 63 61 73 | 65 2e 0a 58 20 2a 09 54 |ower cas|e..X *.T|
|000059d0| 68 65 20 31 73 74 20 63 | 68 61 72 20 65 6e 61 62 |he 1st c|har enab|
|000059e0| 6c 65 73 20 6f 72 20 64 | 69 73 61 62 6c 65 73 20 |les or d|isables |
|000059f0| 78 6f 6e 2f 78 6f 66 66 | 20 72 65 63 65 69 76 65 |xon/xoff| receive|
|00005a00| 2e 2e 2e 0a 58 20 2a 09 | 74 68 65 20 32 64 20 63 |....X *.|the 2d c|
|00005a10| 68 61 72 20 65 6e 61 62 | 6c 65 73 20 6f 72 20 64 |har enab|les or d|
|00005a20| 69 73 61 62 6c 65 73 20 | 78 6f 6e 2f 78 6f 66 66 |isables |xon/xoff|
|00005a30| 20 74 72 61 6e 73 6d 69 | 74 0a 58 20 2a 2f 0a 58 | transmi|t.X */.X|
|00005a40| 0a 69 6e 74 20 0a 69 6f | 63 74 6c 5f 73 65 74 5f |.int .io|ctl_set_|
|00005a50| 78 6f 66 66 20 28 63 68 | 61 72 20 2a 63 6d 64 29 |xoff (ch|ar *cmd)|
|00005a60| 0a 58 7b 0a 58 20 20 20 | 20 63 68 61 72 20 20 20 |.X{.X | char |
|00005a70| 20 74 65 6d 70 3b 0a 58 | 20 20 20 20 63 68 61 72 | temp;.X| char|
|00005a80| 20 20 20 20 78 72 63 76 | 5b 32 5d 3b 0a 58 20 20 | xrcv|[2];.X |
|00005a90| 20 20 73 73 63 61 6e 66 | 20 28 63 6d 64 2c 20 22 | sscanf| (cmd, "|
|00005aa0| 25 31 73 22 2c 20 78 72 | 63 76 29 3b 0a 58 20 20 |%1s", xr|cv);.X |
|00005ab0| 20 20 64 69 73 61 62 6c | 65 20 28 29 3b 0a 58 20 | disabl|e ();.X |
|00005ac0| 20 20 20 78 6f 66 66 5f | 65 6e 61 62 6c 65 64 20 | xoff_|enabled |
|00005ad0| 3d 20 28 74 6f 75 70 70 | 65 72 20 28 2a 78 72 63 |= (toupp|er (*xrc|
|00005ae0| 76 29 20 3d 3d 20 27 59 | 27 29 20 3f 20 54 52 55 |v) == 'Y|') ? TRU|
|00005af0| 45 20 3a 20 46 41 4c 53 | 45 3b 0a 58 20 20 20 20 |E : FALS|E;.X |
|00005b00| 65 6e 61 62 6c 65 20 28 | 29 3b 0a 58 7d 0a 58 0a |enable (|);.X}.X.|
|00005b10| 58 0a 58 0a 58 0a 58 2f | 2a 0a 58 20 2a 09 58 4f |X.X.X.X/|*.X *.XO|
|00005b20| 4e 38 32 35 30 5f 57 52 | 49 54 45 5f 42 52 45 41 |N8250_WR|ITE_BREA|
|00005b30| 4b 20 2d 20 57 72 69 74 | 65 20 61 20 42 52 45 41 |K - Writ|e a BREA|
|00005b40| 4b 20 43 68 61 72 61 63 | 74 65 72 0a 58 20 2a 2f |K Charac|ter.X */|
|00005b50| 0a 58 0a 76 6f 69 64 20 | 0a 78 6f 6e 38 32 35 30 |.X.void |.xon8250|
|00005b60| 5f 77 72 69 74 65 5f 62 | 72 65 61 6b 20 28 76 6f |_write_b|reak (vo|
|00005b70| 69 64 29 0a 58 7b 0a 58 | 20 20 20 20 69 6e 74 20 |id).X{.X| int |
|00005b80| 20 20 20 20 69 3b 0a 58 | 20 20 20 20 64 69 73 61 | i;.X| disa|
|00005b90| 62 6c 65 20 28 29 3b 0a | 58 20 20 20 20 77 68 69 |ble ();.|X whi|
|00005ba0| 6c 65 20 28 28 69 6e 62 | 79 74 65 20 28 58 4f 4e |le ((inb|yte (XON|
|00005bb0| 5f 50 4f 52 54 5f 61 64 | 64 72 65 73 73 20 2b 20 |_PORT_ad|dress + |
|00005bc0| 4c 53 52 29 20 26 20 30 | 78 34 30 29 20 3d 3d 20 |LSR) & 0|x40) == |
|00005bd0| 30 29 0a 58 20 20 20 20 | 20 20 20 20 3b 0a 58 20 |0).X | ;.X |
|00005be0| 20 20 20 6f 75 74 62 79 | 74 65 20 28 58 4f 4e 5f | outby|te (XON_|
|00005bf0| 50 4f 52 54 5f 61 64 64 | 72 65 73 73 20 2b 20 4c |PORT_add|ress + L|
|00005c00| 43 52 2c 20 69 6e 62 79 | 74 65 20 28 58 4f 4e 5f |CR, inby|te (XON_|
|00005c10| 50 4f 52 54 5f 61 64 64 | 72 65 73 73 20 2b 20 4c |PORT_add|ress + L|
|00005c20| 43 52 29 20 7c 20 30 78 | 34 30 29 3b 0a 58 09 44 |CR) | 0x|40);.X.D|
|00005c30| 45 4c 41 59 5f 6c 6f 6f | 70 20 28 35 30 30 29 3b |ELAY_loo|p (500);|
|00005c40| 0a 58 20 20 20 20 6f 75 | 74 62 79 74 65 20 28 58 |.X ou|tbyte (X|
|00005c50| 4f 4e 5f 50 4f 52 54 5f | 61 64 64 72 65 73 73 20 |ON_PORT_|address |
|00005c60| 2b 20 4c 43 52 2c 20 69 | 6e 62 79 74 65 20 28 58 |+ LCR, i|nbyte (X|
|00005c70| 4f 4e 5f 50 4f 52 54 5f | 61 64 64 72 65 73 73 20 |ON_PORT_|address |
|00005c80| 2b 20 4c 43 52 29 20 26 | 20 30 78 42 46 29 3b 0a |+ LCR) &| 0xBF);.|
|00005c90| 58 20 20 20 20 65 6e 61 | 62 6c 65 20 28 29 3b 0a |X ena|ble ();.|
|00005ca0| 58 7d 0a 58 0a 58 0a 58 | 0a 58 0a 58 0a 58 2f 2a |X}.X.X.X|.X.X.X/*|
|00005cb0| 0a 58 20 2a 09 58 4f 4e | 38 32 35 30 5f 58 4f 4e |.X *.XON|8250_XON|
|00005cc0| 5f 50 4f 52 54 5f 49 4e | 49 54 20 28 43 6d 64 29 |_PORT_IN|IT (Cmd)|
|00005cd0| 20 63 6f 6e 66 69 67 75 | 72 65 73 20 74 68 65 20 | configu|res the |
|00005ce0| 38 32 35 30 0a 58 20 2a | 20 20 20 20 20 20 20 20 |8250.X *| |
|00005cf0| 63 6d 64 20 69 73 20 61 | 20 73 74 72 69 6e 67 20 |cmd is a| string |
|00005d00| 6f 66 20 74 68 65 20 66 | 6f 72 6d 20 62 61 75 64 |of the f|orm baud|
|00005d10| 20 70 61 72 69 74 79 20 | 73 74 6f 70 20 64 61 74 | parity |stop dat|
|00005d20| 61 20 78 6f 6e 2f 78 6f | 66 66 2e 2e 2e 20 69 2e |a xon/xo|ff... i.|
|00005d30| 65 2e 0a 58 20 2a 20 20 | 20 20 20 20 20 20 33 30 |e..X * | 30|
|00005d40| 30 20 6e 20 31 20 38 20 | 79 0a 58 20 2a 0a 58 20 |0 n 1 8 |y.X *.X |
|00005d50| 2a 20 20 20 20 20 20 20 | 20 62 61 75 64 20 2d 20 |* | baud - |
|00005d60| 33 30 30 2c 20 36 30 30 | 2c 20 31 32 30 30 2c 20 |300, 600|, 1200, |
|00005d70| 32 34 30 30 2c 20 34 38 | 30 30 2c 20 39 36 30 30 |2400, 48|00, 9600|
|00005d80| 2c 20 31 39 32 30 30 0a | 58 20 2a 20 20 20 20 20 |, 19200.|X * |
|00005d90| 20 20 20 70 61 72 69 74 | 79 20 2d 20 6e 20 2d 3e | parit|y - n ->|
|00005da0| 20 6e 6f 20 70 61 72 69 | 74 79 20 63 68 65 63 6b | no pari|ty check|
|00005db0| 0a 58 20 2a 20 20 20 20 | 20 20 20 20 20 20 20 20 |.X * | |
|00005dc0| 20 20 20 20 20 6f 20 2d | 3e 20 6f 64 64 20 70 61 | o -|> odd pa|
|00005dd0| 72 69 74 79 0a 58 20 2a | 20 20 20 20 20 20 20 20 |rity.X *| |
|00005de0| 20 20 20 20 20 20 20 20 | 20 65 20 2d 3e 20 65 76 | | e -> ev|
|00005df0| 65 6e 20 70 61 72 69 74 | 79 0a 58 20 2a 20 20 20 |en parit|y.X * |
|00005e00| 20 20 20 20 20 73 74 6f | 70 20 20 20 2d 20 31 20 | sto|p - 1 |
|00005e10| 2d 3e 20 31 20 73 74 6f | 70 20 62 69 74 0a 58 20 |-> 1 sto|p bit.X |
|00005e20| 2a 20 20 20 20 20 20 20 | 20 20 20 20 20 20 20 20 |* | |
|00005e30| 20 20 32 20 2d 3e 20 32 | 20 73 74 6f 70 20 62 69 | 2 -> 2| stop bi|
|00005e40| 74 73 0a 58 20 2a 20 20 | 20 20 20 20 20 20 64 61 |ts.X * | da|
|00005e50| 74 61 20 20 20 2d 20 35 | 2c 20 36 2c 20 37 2c 20 |ta - 5|, 6, 7, |
|00005e60| 38 20 64 61 74 61 20 62 | 69 74 73 0a 58 20 2a 2f |8 data b|its.X */|
|00005e70| 0a 58 0a 69 6e 74 20 0a | 78 6f 6e 38 32 35 30 5f |.X.int .|xon8250_|
|00005e80| 70 6f 72 74 5f 69 6e 69 | 74 20 28 63 68 61 72 20 |port_ini|t (char |
|00005e90| 2a 63 6d 64 29 0a 58 7b | 0a 58 20 20 20 20 75 6e |*cmd).X{|.X un|
|00005ea0| 73 69 67 6e 65 64 20 62 | 61 75 64 2c 20 64 61 74 |signed b|aud, dat|
|00005eb0| 61 2c 20 6d 6f 64 65 5f | 77 6f 72 64 2c 20 70 61 |a, mode_|word, pa|
|00005ec0| 72 69 74 79 2c 20 73 74 | 6f 70 2c 20 78 6f 66 66 |rity, st|op, xoff|
|00005ed0| 3b 0a 58 20 20 20 20 63 | 68 61 72 20 20 20 20 70 |;.X c|har p|
|00005ee0| 74 79 5b 32 5d 3b 0a 58 | 20 20 20 20 73 73 63 61 |ty[2];.X| ssca|
|00005ef0| 6e 66 20 28 63 6d 64 2c | 20 22 25 64 20 25 31 73 |nf (cmd,| "%d %1s|
|00005f00| 20 25 64 20 25 64 22 2c | 20 26 62 61 75 64 2c 20 | %d %d",| &baud, |
|00005f10| 70 74 79 2c 20 26 73 74 | 6f 70 2c 20 26 64 61 74 |pty, &st|op, &dat|
|00005f20| 61 29 3b 0a 58 20 20 20 | 20 2a 70 74 79 20 3d 20 |a);.X | *pty = |
|00005f30| 74 6f 75 70 70 65 72 20 | 28 2a 70 74 79 29 3b 0a |toupper |(*pty);.|
|00005f40| 58 20 20 20 20 73 77 69 | 74 63 68 20 28 2a 70 74 |X swi|tch (*pt|
|00005f50| 79 29 0a 58 20 20 20 20 | 7b 0a 58 20 20 20 20 20 |y).X |{.X |
|00005f60| 20 20 20 63 61 73 65 20 | 27 45 27 3a 0a 58 20 20 | case |'E':.X |
|00005f70| 20 20 20 20 20 20 20 20 | 20 20 70 61 72 69 74 79 | | parity|
|00005f80| 20 3d 20 31 3b 0a 58 20 | 20 20 20 20 20 20 20 20 | = 1;.X | |
|00005f90| 20 20 20 62 72 65 61 6b | 3b 0a 58 20 20 20 20 20 | break|;.X |
|00005fa0| 20 20 20 63 61 73 65 20 | 27 4f 27 3a 0a 58 20 20 | case |'O':.X |
|00005fb0| 20 20 20 20 20 20 20 20 | 20 20 70 61 72 69 74 79 | | parity|
|00005fc0| 20 3d 20 33 3b 0a 58 20 | 20 20 20 20 20 20 20 20 | = 3;.X | |
|00005fd0| 20 20 20 62 72 65 61 6b | 3b 0a 58 20 20 20 20 20 | break|;.X |
|00005fe0| 20 20 20 63 61 73 65 20 | 27 4e 27 3a 0a 58 20 20 | case |'N':.X |
|00005ff0| 20 20 20 20 20 20 20 20 | 20 20 70 61 72 69 74 79 | | parity|
|00006000| 20 3d 20 30 3b 0a 58 20 | 20 20 20 20 20 20 20 20 | = 0;.X | |
|00006010| 20 20 20 62 72 65 61 6b | 3b 0a 58 20 20 20 20 20 | break|;.X |
|00006020| 20 20 20 64 65 66 61 75 | 6c 74 3a 0a 58 20 20 20 | defau|lt:.X |
|00006030| 20 20 20 20 20 20 20 20 | 20 70 61 72 69 74 79 20 | | parity |
|00006040| 3d 20 30 3b 0a 58 20 20 | 20 20 20 20 20 20 20 20 |= 0;.X | |
|00006050| 20 20 62 72 65 61 6b 3b | 0a 58 20 20 20 20 7d 0a | break;|.X }.|
|00006060| 58 20 20 20 20 73 74 6f | 70 20 3d 20 28 2d 2d 73 |X sto|p = (--s|
|00006070| 74 6f 70 20 26 20 31 29 | 3b 0a 58 20 20 20 20 73 |top & 1)|;.X s|
|00006080| 74 6f 70 20 3c 3c 3d 20 | 32 3b 0a 58 20 20 20 20 |top <<= |2;.X |
|00006090| 62 61 75 64 20 2f 3d 20 | 31 30 3b 0a 58 20 20 20 |baud /= |10;.X |
|000060a0| 20 62 61 75 64 20 3d 20 | 31 31 35 32 30 20 2f 20 | baud = |11520 / |
|000060b0| 62 61 75 64 3b 0a 58 20 | 20 20 20 70 61 72 69 74 |baud;.X | parit|
|000060c0| 79 20 3c 3c 3d 20 33 3b | 0a 58 20 20 20 20 70 61 |y <<= 3;|.X pa|
|000060d0| 72 69 74 79 20 26 3d 20 | 30 78 30 31 38 3b 0a 58 |rity &= |0x018;.X|
|000060e0| 20 20 20 20 64 61 74 61 | 20 2d 3d 20 35 3b 0a 58 | data| -= 5;.X|
|000060f0| 20 20 20 20 64 61 74 61 | 20 26 3d 20 33 3b 0a 58 | data| &= 3;.X|
|00006100| 20 20 20 20 6d 6f 64 65 | 5f 77 6f 72 64 20 3d 20 | mode|_word = |
|00006110| 64 61 74 61 20 7c 20 73 | 74 6f 70 20 7c 20 70 61 |data | s|top | pa|
|00006120| 72 69 74 79 3b 0a 58 20 | 20 20 20 64 69 73 61 62 |rity;.X | disab|
|00006130| 6c 65 20 28 29 3b 0a 58 | 20 20 20 20 78 6f 66 66 |le ();.X| xoff|
|00006140| 5f 72 65 63 65 69 76 65 | 64 20 3d 20 46 41 4c 53 |_receive|d = FALS|
|00006150| 45 3b 0a 58 20 20 20 20 | 6f 75 74 62 79 74 65 20 |E;.X |outbyte |
|00006160| 28 58 4f 4e 5f 50 4f 52 | 54 5f 61 64 64 72 65 73 |(XON_POR|T_addres|
|00006170| 73 20 2b 20 4c 43 52 2c | 20 69 6e 62 79 74 65 20 |s + LCR,| inbyte |
|00006180| 28 58 4f 4e 5f 50 4f 52 | 54 5f 61 64 64 72 65 73 |(XON_POR|T_addres|
|00006190| 73 20 2b 20 4c 43 52 29 | 20 7c 20 4c 43 52 5f 44 |s + LCR)| | LCR_D|
|000061a0| 4c 41 42 29 3b 0a 58 20 | 20 20 20 6f 75 74 62 79 |LAB);.X | outby|
|000061b0| 74 65 20 28 58 4f 4e 5f | 50 4f 52 54 5f 61 64 64 |te (XON_|PORT_add|
|000061c0| 72 65 73 73 2c 20 62 61 | 75 64 20 25 20 32 35 36 |ress, ba|ud % 256|
|000061d0| 29 3b 0a 58 20 20 20 20 | 6f 75 74 62 79 74 65 20 |);.X |outbyte |
|000061e0| 28 58 4f 4e 5f 50 4f 52 | 54 5f 61 64 64 72 65 73 |(XON_POR|T_addres|
|000061f0| 73 20 2b 20 31 2c 20 62 | 61 75 64 20 2f 20 32 35 |s + 1, b|aud / 25|
|00006200| 36 29 3b 0a 58 20 20 20 | 20 6f 75 74 62 79 74 65 |6);.X | outbyte|
|00006210| 20 28 58 4f 4e 5f 50 4f | 52 54 5f 61 64 64 72 65 | (XON_PO|RT_addre|
|00006220| 73 73 20 2b 20 4c 43 52 | 2c 20 6d 6f 64 65 5f 77 |ss + LCR|, mode_w|
|00006230| 6f 72 64 20 26 20 30 78 | 37 46 29 3b 0a 58 20 20 |ord & 0x|7F);.X |
|00006240| 20 20 6f 75 74 62 79 74 | 65 20 28 58 4f 4e 5f 50 | outbyt|e (XON_P|
|00006250| 4f 52 54 5f 61 64 64 72 | 65 73 73 20 2b 20 49 45 |ORT_addr|ess + IE|
|00006260| 52 2c 20 58 4f 4e 5f 50 | 4f 52 54 5f 63 6f 6d 6d |R, XON_P|ORT_comm|
|00006270| 61 6e 64 20 3d 20 52 58 | 5f 65 6e 61 62 6c 65 29 |and = RX|_enable)|
|00006280| 3b 0a 58 20 20 20 20 6f | 75 74 62 79 74 65 20 28 |;.X o|utbyte (|
|00006290| 58 4f 4e 5f 50 4f 52 54 | 5f 61 64 64 72 65 73 73 |XON_PORT|_address|
|000062a0| 20 2b 20 4d 43 52 2c 20 | 30 78 30 46 29 3b 0a 58 | + MCR, |0x0F);.X|
|000062b0| 0a 58 20 20 20 20 69 6e | 62 79 74 65 20 28 58 4f |.X in|byte (XO|
|000062c0| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|000062d0| 20 4c 53 52 29 3b 0a 58 | 20 20 20 20 69 6e 62 79 | LSR);.X| inby|
|000062e0| 74 65 20 28 58 4f 4e 5f | 50 4f 52 54 5f 61 64 64 |te (XON_|PORT_add|
|000062f0| 72 65 73 73 20 2b 20 4d | 53 52 29 3b 0a 58 20 20 |ress + M|SR);.X |
|00006300| 20 20 69 6e 62 79 74 65 | 20 28 58 4f 4e 5f 50 4f | inbyte| (XON_PO|
|00006310| 52 54 5f 61 64 64 72 65 | 73 73 29 3b 0a 58 20 20 |RT_addre|ss);.X |
|00006320| 20 20 65 6e 61 62 6c 65 | 20 28 29 3b 0a 58 7d 0a | enable| ();.X}.|
|00006330| 58 0a 58 0a 58 0a 58 0a | 58 2f 2a 2d 2d 2d 2d 2d |X.X.X.X.|X/*-----|
|00006340| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2d |--------|--------|
|00006350| 2d 20 78 6f 6e 38 32 35 | 30 5f 70 6f 72 74 5f 65 |- xon825|0_port_e|
|00006360| 6e 61 62 6c 65 20 28 29 | 20 2d 2d 2d 2d 2d 2d 2d |nable ()| -------|
|00006370| 2d 2d 2d 2d 2d 2d 2d 2d | 2d 2d 2d 2d 2d 2d 2d 2a |--------|-------*|
|00006380| 2f 0a 58 2f 2a 0a 58 20 | 2a 0a 58 20 2a 2f 0a 76 |/.X/*.X |*.X */.v|
|00006390| 6f 69 64 0a 78 6f 6e 38 | 32 35 30 5f 70 6f 72 74 |oid.xon8|250_port|
|000063a0| 5f 65 6e 61 62 6c 65 20 | 28 76 6f 69 64 29 0a 58 |_enable |(void).X|
|000063b0| 7b 0a 58 09 64 69 73 61 | 62 6c 65 20 28 29 3b 0a |{.X.disa|ble ();.|
|000063c0| 58 20 20 20 20 6f 75 74 | 62 79 74 65 20 28 58 4f |X out|byte (XO|
|000063d0| 4e 5f 50 4f 52 54 5f 61 | 64 64 72 65 73 73 20 2b |N_PORT_a|ddress +|
|000063e0| 20 49 45 52 2c 20 58 4f | 4e 5f 50 4f 52 54 5f 63 | IER, XO|N_PORT_c|
|000063f0| 6f 6d 6d 61 6e 64 20 3d | 20 52 58 5f 65 6e 61 62 |ommand =| RX_enab|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.