home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 4 Drivers / 04-Drivers.zip / sio160d.zip / SIOUSER.TXT < prev    next >
Text File  |  1997-03-17  |  74KB  |  1,612 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  
  11.  
  12.  
  13.  
  14.  
  15.  
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.                                   USERS MANUAL
  24.  
  25.             SIO.SYS and VSIO.SYS, Serial Communications Device Driver
  26.             for OS/2 V2 (and up) and its Virtual DOS Machines (VDM).
  27.  
  28.                      Copyright (c) 1995 by Raymond L. Gwinn
  29.                                 26 Tanager Place
  30.                           Beckley, West Virginia 25801
  31.                                All Rights Reserved
  32.  
  33.                                  January 1, 1997
  34.  
  35.                                       Email
  36.                               CompuServe 72662,3547
  37.                              Internet ray@gwinn.com
  38.  
  39.                            VOICE ORDERS 1-304-255-7900
  40.                                FAX 1-304-255-7902
  41.                         BBS 1-255-7903 or vmbbs.gwinn.com
  42.                             WEB http://www.gwinn.com
  43.  
  44.  
  45.  
  46.  
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56.  
  57.  
  58.  
  59.  
  60.  
  61.  
  62.  
  63.  
  64.  
  65.                                   INTRODUCTION
  66.  
  67.      SIO.SYS and VSIO.SYS are companion device drivers for Version 2 (and
  68.      up) of the OS/2 operating system.
  69.  
  70.      Both drivers (SIO/VSIO) have been coded with performance in mind,
  71.      possibly sacrificing some compatibility.  For this reason, SIO and
  72.      VSIO are not exact replacements for the OS/2 drivers COM and VCOM. 
  73.      However, all serial communications programs tested by the author work
  74.      correctly using SIO/VSIO.
  75.  
  76.      This manual is intended for the SIO user.  A separate SIO Technical
  77.      Reference Manual is included in the distribution zip.  The Technical
  78.      Reference Manual also documents some advanced options and features
  79.      that are not documented here.
  80.  
  81.      This manual and the software distributed with it is provided with no
  82.      guarantees.  Use it at your own risk.
  83.  
  84.  
  85.  
  86.  
  87.                                                                          ii
  88.  
  89.                                 TABLE OF CONTENTS
  90.  
  91.  
  92.      INTRODUCTION  . . . . . . . . . . . . . . . . . . . . . . . . . .    i
  93.           SIO Technical Reference Manual . . . . . . . . . . . . . . .    i
  94.  
  95.      WHAT IS SIO . . . . . . . . . . . . . . . . . . . . . . . . . . .    1
  96.  
  97.      WHAT IS VSIO  . . . . . . . . . . . . . . . . . . . . . . . . . .    2
  98.  
  99.      DISTRIBUTION AND SUPPORT  . . . . . . . . . . . . . . . . . . . .    3
  100.           Distribution and Ordering  . . . . . . . . . . . . . . . . .    3
  101.                SIO Distribution and Support BBS  . . . . . . . . . . .    3
  102.           Support  . . . . . . . . . . . . . . . . . . . . . . . . . .    3
  103.                OS/2 Vendor Forum on
  104.                     CompuServe . . . . . . . . . . . . . . . . . . . .    3
  105.           Updates  . . . . . . . . . . . . . . . . . . . . . . . . . .    4
  106.  
  107.      GETTING STARTED . . . . . . . . . . . . . . . . . . . . . . . . .    5
  108.           Installing SIO/VSIO  . . . . . . . . . . . . . . . . . . . .    5
  109.           Quick Start  . . . . . . . . . . . . . . . . . . . . . . . .    5
  110.  
  111.      COMMAND LINE OPTIONS  . . . . . . . . . . . . . . . . . . . . . .    6
  112.           COM1 thru
  113.                COMn  . . . . . . . . . . . . . . . . . . . . . . . . .    6
  114.           I/O port address . . . . . . . . . . . . . . . . . . . . . .    6
  115.           IRQ number . . . . . . . . . . . . . . . . . . . . . . . . .    6
  116.           Forced 16550A  . . . . . . . . . . . . . . . . . . . . . . .    6
  117.  
  118.      Development and Debugging Tools . . . . . . . . . . . . . . . . .    8
  119.           The Poor Man's Line Monitor (PMLM.EXE) . . . . . . . . . . .    8
  120.           VIEWPMLM.EXE . . . . . . . . . . . . . . . . . . . . . . . .    9
  121.           SIO's Utility (SU.EXE) . . . . . . . . . . . . . . . . . . .    9
  122.                IRQs that are currently free  . . . . . . . . . . . . .    9
  123.  
  124.      Intelligent Cards Supported . . . . . . . . . . . . . . . . . . .   10
  125.           Hayes ESP  . . . . . . . . . . . . . . . . . . . . . . . . .   10
  126.                ESP in Compatibility Mode . . . . . . . . . . . . . . .   10
  127.           Telcor Tport . . . . . . . . . . . . . . . . . . . . . . . .   10
  128.  
  129.      . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   11
  130.  
  131.      AUTOMATIC IRQ ASSIGNMENT  . . . . . . . . . . . . . . . . . . . .   11
  132.  
  133.      DOS SETTINGS  . . . . . . . . . . . . . . . . . . . . . . . . . .   12
  134.           SIO_Allow_Access_COMn  . . . . . . . . . . . . . . . . . . .   12
  135.           SIO_Virtualize_COM_Ports . . . . . . . . . . . . . . . . . .   12
  136.           SIO_Virtualize_16550A  . . . . . . . . . . . . . . . . . . .   12
  137.           SIO_Share_Access_With_OS/2 . . . . . . . . . . . . . . . . .   12
  138.           SIO_Screen_Sync_Kludge . . . . . . . . . . . . . . . . . . .   13
  139.           SIO_Mode_DTR . . . . . . . . . . . . . . . . . . . . . . . .   13
  140.           SIO_Mode_IDSR  . . . . . . . . . . . . . . . . . . . . . . .   14
  141.           SIO_Mode_OCTS  . . . . . . . . . . . . . . . . . . . . . . .   15
  142.           SIO_Mode_ODSR  . . . . . . . . . . . . . . . . . . . . . . .   15
  143.           SIO_Mode_RTS . . . . . . . . . . . . . . . . . . . . . . . .   15
  144.  
  145.  
  146.  
  147.  
  148.                                                                         iii
  149.  
  150.           SIO_Mode_XON/XOFF  . . . . . . . . . . . . . . . . . . . . .   16
  151.           SIO_Mode_FIFO_Load_Count . . . . . . . . . . . . . . . . . .   17
  152.  
  153.      Configuration Profiles  . . . . . . . . . . . . . . . . . . . . .   18
  154.           Seiko Smart Label Printer  . . . . . . . . . . . . . . . . .   18
  155.           IBM's SLIP . . . . . . . . . . . . . . . . . . . . . . . . .   18
  156.  
  157.      Differences between SIO/VSIO and COM/VCOM . . . . . . . . . . . .   19
  158.  
  159.      PROBLEMS AND SOLUTIONS  . . . . . . . . . . . . . . . . . . . . .   21
  160.           IRQ for a port appears to be wrong . . . . . . . . . . . . .   21
  161.           The modem will not initialize  . . . . . . . . . . . . . . .   21
  162.           WinFax locks up during install . . . . . . . . . . . . . . .   21
  163.           Telemate does not recognize VX00 as a FOSSIL . . . . . . . .   21
  164.           Comm output is very slow from DOS  . . . . . . . . . . . . .   21
  165.            . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   21
  166.           Procomm stops receiving  . . . . . . . . . . . . . . . . . .   22
  167.           Procomm For Windows download errors  . . . . . . . . . . . .   22
  168.           WinFax does not work well. . . . . . . . . . . . . . . . . .   23
  169.                Class 1 FAX modem . . . . . . . . . . . . . . . . . . .   23
  170.                Class 2 FAX modem . . . . . . . . . . . . . . . . . . .   23
  171.           Serial Printer messes up on last page. . . . . . . . . . . .   23
  172.  
  173.      IRQ SHARING ON ISA  . . . . . . . . . . . . . . . . . . . . . . .   24
  174.  
  175.      Appendix A, Hardware Port and IRQ Assignments . . . . . . . . . .   25
  176.           Addresses and IRQs for COM1 and COM2 . . . . . . . . . . . .   25
  177.           Defacto standard for COM3 and COM4 . . . . . . . . . . . . .   25
  178.           Addresses and IRQ for COM3 through COM8 on the PS/2  . . . .   25
  179.  
  180.      Appendix B, SIO Chips . . . . . . . . . . . . . . . . . . . . . .   26
  181.           8250 . . . . . . . . . . . . . . . . . . . . . . . . . . . .   26
  182.           8250A  . . . . . . . . . . . . . . . . . . . . . . . . . . .   26
  183.           16450  . . . . . . . . . . . . . . . . . . . . . . . . . . .   26
  184.           16C451 . . . . . . . . . . . . . . . . . . . . . . . . . . .   27
  185.           16550 (Non A)  . . . . . . . . . . . . . . . . . . . . . . .   27
  186.           16550A . . . . . . . . . . . . . . . . . . . . . . . . . . .   27
  187.           16550AF  . . . . . . . . . . . . . . . . . . . . . . . . . .   27
  188.           16550AFN . . . . . . . . . . . . . . . . . . . . . . . . . .   27
  189.           16550s Made by Western Digital . . . . . . . . . . . . . . .   28
  190.           16C551 . . . . . . . . . . . . . . . . . . . . . . . . . . .   28
  191.           16C552 . . . . . . . . . . . . . . . . . . . . . . . . . . .   28
  192.           16C554 . . . . . . . . . . . . . . . . . . . . . . . . . . .   28
  193.           82510  . . . . . . . . . . . . . . . . . . . . . . . . . . .   28
  194.           16650  . . . . . . . . . . . . . . . . . . . . . . . . . . .   29
  195.           16750 from Texas Instruments . . . . . . . . . . . . . . . .   29
  196.           ComBic . . . . . . . . . . . . . . . . . . . . . . . . . . .   30
  197.  
  198.      Appendix C, Multi-Port Serial I/0 Cards . . . . . . . . . . . . .   31
  199.           STB 4COM . . . . . . . . . . . . . . . . . . . . . . . . . .   31
  200.           Connect Tech Dflex-8 . . . . . . . . . . . . . . . . . . . .   31
  201.           Gtek BBS550  . . . . . . . . . . . . . . . . . . . . . . . .   32
  202.           Neotech Quad Serial  . . . . . . . . . . . . . . . . . . . .   32
  203.  
  204.      INDEX . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   33
  205.  
  206.  
  207.  
  208.  
  209.                                                                          iv
  210.  
  211.  
  212.  
  213.  
  214.                                                                           1
  215.  
  216.                                    WHAT IS SIO
  217.  
  218.      SIO is a Serial Input/Output (SIO) communications driver.  It provides
  219.      an interface between application programs and the serial
  220.      communications hardware.
  221.  
  222.      SIO had been designed as a high performance replacement for the OS/2
  223.      device driver COM.SYS.  See the Technical Reference Manual for
  224.      information about the known differences between COM.SYS and SIO.SYS.
  225.  
  226.      SIO works with 8250 (type) serial I/O devices.  Such devices include,
  227.      but are not limited to the 8250A, 16450, 16550, 16550A and the 82510. 
  228.      If you have a PC that is an IBM or near compatible which has a serial
  229.      communication port, it is likely that it contains one of these
  230.      devices.  In addition, SIO supports some intelligent serial I/O cards. 
  231.      See "Intelligent Cards Supported" for additional information.  SIO
  232.      will identify the type of serial devices that it finds and display
  233.      them at load time.
  234.  
  235.      Like other Device Drivers, SIO will do very little standing alone. 
  236.      There must be an application(s) program that makes use of SIO's
  237.      functions before one will benefit from SIO.
  238.  
  239.  
  240.  
  241.  
  242.                                                                           2
  243.  
  244.                                   WHAT IS VSIO
  245.  
  246.      VSIO is a Virtual Device Driver (VDD).  Virtual device drivers provide
  247.      services for DOS programs executing under OS/2.  Most Virtual Device
  248.      Drivers emulate a specific hardware device and/or BIOS service.  The
  249.      primary job of a Virtual Device Driver is to convert misbehaved DOS
  250.      input/output into well behaved input/output that can be accepted by
  251.      the OS/2 driver SIO.SYS.
  252.  
  253.      Using the protection mechanism of the 386 (and up) processor, a
  254.      Virtual Device Driver can instruct OS/2 to trap all input/output for
  255.      given hardware ports.  Once trapped, the Virtual Device Driver (VDD)
  256.      appropriately routes information to/from the Physical Device Driver
  257.      (PDD) and to/from the DOS program.
  258.  
  259.      VSIO creates a virtual (imaginary) 16550A or 16450 (UART) in software. 
  260.      Additionally VSIO emulates the BIOS INT 14h services.  All of the
  261.      hardware registers of the virtual UART are simulated by VSIO.  VSIO
  262.      does not attempt to simulate the timing of the real UARTs.  DOS
  263.      programs that depend on the timing of real hardware UARTs may have
  264.      problems executing under VSIO.
  265.  
  266.      All DOS programs that execute under VSIO should have RTS/CTS
  267.      handshaking enabled (in the application) even if SIO proper is not
  268.      using RTS/CTS handshake.  
  269.  
  270.      The virtualization (simulation) provided by VSIO is not (and can not
  271.      be) exact.  However, most well written DOS programs should not have
  272.      problems.
  273.  
  274.      VSIO will only work with SIO installed and the versions of SIO/VSIO
  275.      must match.  If VSIO refuses to install, you most likely have a
  276.      version mismatch or COM.SYS is still installed.  VSIO will not work
  277.      with any other device driver like COM.SYS.
  278.  
  279.  
  280.  
  281.  
  282.                                                                           3
  283.  
  284.                             DISTRIBUTION AND SUPPORT
  285.  
  286.      Distribution and Ordering
  287.      The entire package collectively known as SIO is ShareWare.  It is not
  288.      free software or freeware.  See LICENSE.TXT and ORDER.TXT for
  289.      additional information.  The ShareWare version of SIO is distributed
  290.      electronically and supports only 4 ports (registered versions can be
  291.      ordered supporting up to 16 ports).  One may check their favorite
  292.      electronic hangout for the latest version of SIO.  The latest copy of
  293.      the ShareWare version is always posted for downloading from the BBS at
  294.      1-304-255-7903 or vmbbs.gwinn.com and www.gwinn.com
  295.  
  296.      Registered versions of SIO are distributed by US Mail, electronically
  297.      mail and from the SIO Distribution and Support BBS.  Users desiring to
  298.      register electronically, may call the BBS and register on line (1-304-
  299.      255-7903 or vmbbs.gwinn.com) or www.gwinn.com and immediately download
  300.      their registered version of SIO.  Use the ORDER command at the main
  301.      BBS prompt.
  302.  
  303.      Registrations/Orders can also be placed by phone, mail, FAX, and
  304.      email.  See the front cover of this manual for the phone numbers and
  305.      addresses.  Also see ORDER.TXT for and order form that may be used.
  306.  
  307.      Support
  308.      Extensive testing has been done to insure that this product works on
  309.      the widest possible range of OS/2 V2 (and up) systems.  In most cases,
  310.      problems can be resolved by reading this manual carefully.
  311.  
  312.      Support is provided in section 4 of the OS/2 Vendor Forum on
  313.      CompuServe (GO OS2BVEN).  Section 4 of the OS2BVEN Forum is dedicated
  314.      to the support of SIO.
  315.  
  316.      In addition, support is provided by BBS, Email and FAX.  Voice support
  317.      would overwhelm the author and is not available.  If, after reading
  318.      the manual carefully, you are unable to resolve a problem, you may
  319.      submit a problem report to one of the following: 
  320.                                       Email
  321.                               CompuServe 72662,3547
  322.                              Internet ray@gwinn.com
  323.                                FAX 1-304-255-7902
  324.                       BBS 1-304-255-7903 or vmbbs.gwinn.com
  325.  
  326.      Users should note that Support does not always result in a correction
  327.      of a problem.  In addition, the support provided is support of SIO,
  328.      and not the applications that use SIO.  Questions and/or problems
  329.      about applications programs (such as terminal or FAX programs) should
  330.      be directed to the available support for the application.
  331.  
  332.  
  333.  
  334.  
  335.                                                                           4
  336.  
  337.  
  338.      Updates
  339.  
  340.      In general, updates/upgrades of SIO are free of charge for all
  341.      releases of SIO with the same major version number.  However, there
  342.      may be a handling charge if the user requires the upgrade to be mailed
  343.      or emailed.
  344.  
  345.      Registered users of SIO can update to the latest version FREE of
  346.      charge using the BBS and its UPDATE command.  Be sure to have your SIO
  347.      serial number when you first log onto the BBS.  All variations (number
  348.      of ports) of SIO are available for immediate download from the BBS by
  349.      registered users.
  350.  
  351.      Users that have a registered copy of SIO can also use REREG.EXE to
  352.      transfer the registration information to a new version of SIO.  Simply
  353.      unzip the new SIO files into a temporary directory, change to that
  354.      directory, execute REREG and answer the questions.  After doing the
  355.      above, all of the files in the temporary directory will have been
  356.      registered.  You must then copy all the SYS and EXE files from the
  357.      temporary directory to their normal directory (overlaying the old
  358.      registered version) or execute the SIO install program (INSTALL.EXE). 
  359.      Then you must reboot.  You may also want to check your CONFIG.SYS for
  360.      the path of the SIO/VSIO being loaded and make sure both the new ones
  361.      are being loaded.
  362.  
  363.      If REREG will not transfer your registration information from a
  364.      previous version of SIO to the new version, then an upgrade must be
  365.      ordered on disk or obtained from the support BBS.
  366.  
  367.  
  368.  
  369.  
  370.                                                                           5
  371.  
  372.                                  GETTING STARTED
  373.  
  374.      Installing SIO/VSIO
  375.  
  376.      SIO is distributed as a ZIP file.  To extract the individual files
  377.      from the distribution file you need the program PKUNZIP or an
  378.      equivalent.  PKUNZIP is a product of PKWARE and can be downloaded from
  379.      almost any bulletin board system (BBS).  You probably already have
  380.      PKUNZIP and know how to use it, otherwise I doubt that you would be
  381.      reading this.  When PKUNZIP is used to extract the various files, -AV
  382.      should appear after each file name as it is extracted.  In addition,
  383.      the message:
  384.  
  385.           Authentic files Verified!
  386.  
  387.      should appear after the extraction process.  If this message does not
  388.      appear, or appears with a name other than Raymond L. Gwinn, the file
  389.      is not an original SIO distribution file.
  390.  
  391.      The only file that the basic user actually needs is SIO.SYS.  Virtual
  392.      DOS machine (VDM) users will also want VSIO.SYS.  Copy one or both of
  393.      these files to a convenient directory or subdirectory on your system. 
  394.      An installation program (INSTALL.EXE) is provided to install the SIO
  395.      files and modify your CONFIG.SYS
  396.  
  397.      Quick Start
  398.  
  399.      Create a temporary directory, change into that directory and unzip the
  400.      SIO distribution zip there.  Type INSTALL followed by the enter key. 
  401.      For a basic setup, that is all that is needed.
  402.  
  403.      If you choose to install SIO manually, the following should be done.
  404.  
  405.      BE SURE THAT ANY SERIAL MOUSE DRIVER APPEARS IN THE CONFIG.SYS BEFORE
  406.      SIO.SYS
  407.  
  408.      If you are going to use standard communications ports, either COM1 or
  409.      COM2 on an ISA bus (AT or clone), or COM1 through COM4 on a PS/2, then
  410.      add the following line to your CONFIG.SYS file:
  411.  
  412.           DEVICE=SIO.SYS
  413.           DEVICE=VSIO.SYS
  414.  
  415.      Be sure to REMark out the COM.SYS and VCOM.SYS device drivers if they
  416.      exist in your CONFIG.SYS.
  417.  
  418.      With the above statements you will be able to use standard COM1 and/or
  419.      COM2 (if they exist) on any PC system known to the author.
  420.  
  421.      If your setup is more complex, you must read on.
  422.  
  423.  
  424.  
  425.  
  426.                                                                           6
  427.  
  428.                               COMMAND LINE OPTIONS
  429.  
  430.      The command line options are included in the command line that loads
  431.      SIO in the CONFIG.SYS file.  VSIO has no command line options. 
  432.      Command line options are usually grouped by port within parenthesis.
  433.  
  434.      If you use only COM1 and/or COM2, at the standard IRQ and port
  435.      addresses, you will not need any command line options.  However, up to
  436.      four serial communications ports, COM1 thru COM4, can be specified at
  437.      any base port address and any IRQ.  On PS/2 systems and some ISA
  438.      cards, SIO/VSIO supports multiple communications devices sharing the
  439.      same IRQ.
  440.  
  441.      The basic command line syntax is as follows:
  442.  
  443.           DEVICE=SIO.SYS (Cn, An, In, Ig, Fc) [(Cn, An, In, Ig, Fc)]
  444.  
  445.      Where
  446.           "Cn" is the comm port number (1 thru 4) or the string COM1 thru
  447.           COMn.  The port number may preceeded by an asterisk "*" to
  448.           indicate that the port may be used as a PCMCIA comm port (eg *1
  449.           or *COM1).  Note that it is normal for SIO to display a warning
  450.           about not finding anything at PCMCIA ports.
  451.  
  452.           "An" is a hexadecimal number that defines the base hardware I/O
  453.           port address for the communications port.  If this field is left
  454.           blank, the default I/O port address is used for the comm port. 
  455.           Note that default I/O addresses exist only for COM1 through COM4
  456.           on AT type systems and for COM1 through COM8 on PS/2 systems.
  457.  
  458.           "In" is an IRQ number (0 thru 15) or the string IRQ0 thru IRQ15
  459.           or the string NONE.  It is best if one leaves this field blank
  460.           and allows SIO to determine the IRQ, see AUTOMATIC IRQ ASSIGNMENT
  461.           below.  The IRQ choice of NONE is provided for cards that can
  462.           work either with or without an IRQ like the Hayes ESP.
  463.  
  464.           "Ig" is an ignored parameter.  If exists for compatibility with
  465.           COM.SYS.
  466.  
  467.           "Fc" is the Forced 16550A chip parameter.  If an F is placed in
  468.           this position, a 16550A UART chip type is forced regardless of
  469.           the automatically detected chip type.
  470.  
  471.  
  472.  
  473.  
  474.                                                                           7
  475.  
  476.  
  477.      For a PC with COM1 and COM2 of standard configuration, the following
  478.      command line will load SIO correctly:
  479.  
  480.           DEVICE=SIO.SYS (1, 3F8, 4) (2, 2f8, 3)
  481.  
  482.      A more readable, but identical, command line is:
  483.  
  484.           DEVICE=SIO.SYS (COM1,3F8,IRQ4) (COM2,2F8,IRQ3)
  485.  
  486.      Forcing a 16550A on COM1 would be as follows:
  487.  
  488.           DEVICE=SIO.SYS (COM1,3F8,IRQ4,,F) (COM2,2F8,IRQ3)
  489.  
  490.      In a similar manner, up to sixteen serial communications ports (four
  491.      in the Shareware version) can be defined and supported by SIO and
  492.      VSIO.
  493.  
  494.  
  495.  
  496.  
  497.                                                                           8
  498.  
  499.                          Development and Debugging Tools
  500.  
  501.      The Poor Man's Line Monitor (PMLM.EXE)
  502.  
  503.      PMLM is basically of interest to developers of comm applications and
  504.      those providing technical support for those applications.  This SIO
  505.      utility is released largely (in self defense) in the hope that some
  506.      users can diagnose their own problems.  PMLM's feature of saving trace
  507.      information to disk will only work with registered and beta versions
  508.      of SIO.
  509.  
  510.      PMLM provides basic line monitoring for OS/2, DOS and Windows comm
  511.      programs.  All characters sent or received by application programs are
  512.      displayed in the upper portion of the screen.  Receive characters are
  513.      displayed as "white on blue" and transmitted characters are displayed
  514.      "yellow on violet".  Line signals, such as CTS are displayed as "dim
  515.      white on red" when turned off and "bright white on red" when turned
  516.      on.  In addition, a signal's transition to OFF is displayed in lower
  517.      case and a signal's transition to ON is displayed in upper case.
  518.  
  519.      Status information is displayed in the lower part of the screen.  A
  520.      bright white display means the signal is on, a dim white indicates
  521.      that the signal is off.  In addition, when bright,  Rxoff and Txoff
  522.      indicate the SIO has sent (Txoff) or received (Rxoff) an Xoff, and an
  523.      Xon is pending.
  524.  
  525.      When a DOS or Windows session uses a comm port, an additional line of
  526.      signal status appears.  This status line shows the state of the
  527.      virtual UART's signals.  Only the signals which MAY be different from
  528.      the real UART's signals are shown.
  529.  
  530.      "Rx Chars" and "Tx Chars" reflects the number of characters in SIO's
  531.      receive and transmit buffers respectively.
  532.  
  533.      The last line on the screen shows the keys (from the keyboard) that
  534.      PMLM will recognize.  The bright character shows the key to hit for
  535.      the associated function.  The font keys will not work in a windowed
  536.      OS/2 session.
  537.  
  538.      PMLM's command line requires one parameter, the comm port number, and
  539.      optionally accepts an additional parameter giving a save trace file
  540.      name.  For example, PMLM 1 COM1INFO.TRC will monitor COM1 and save ALL
  541.      of the communications traffic in the file COM1INFO.TRC.  The trace
  542.      files created by PMLM contain exactly the same information that is
  543.      displayed by PMLM, video attributes and all.
  544.  
  545.  
  546.  
  547.  
  548.                                                                           9
  549.  
  550.  
  551.      VIEWPMLM.EXE may be used to view trace files created by PMLM. 
  552.      VIEWPMLM.EXE requires one parameter, the trace file name.  The user
  553.      can use the keys UP, DOWN, PAGEUP, PAGEDOWN, HOME, and END to navigate
  554.      the saved trace file.  Registered SIO users may send VIEWPMLM.EXE
  555.      (along with saved trace files) to anyone for technical support
  556.      purposes.
  557.  
  558.      VIEWPMLM can be used in native DOS, in DOS sessions under OS/2, and in
  559.      OS/2 sessions.  This means that even those developers and support
  560.      people need not have OS/2 to view the captured communications data
  561.      created by PMLM.
  562.  
  563.      SIO's Utility (SU.EXE)
  564.  
  565.      This utility program has several useful commands.  You can obtain a
  566.      list of the available commands by typing SU at any command line prompt
  567.      without any parameters.  One very useful command is SU IRQS.  This
  568.      command will show IRQs that are currently free for use.  Commands are
  569.      provided allowing user control (missing from MODE) are available. 
  570.      Status commands provide a wealth of diagnostic information.
  571.  
  572.  
  573.  
  574.  
  575.                                                                          10
  576.  
  577.                            Intelligent Cards Supported
  578.  
  579.  
  580.      Hayes ESP
  581.  
  582.      The original ESP (ESP V1) is not supported.  The SIO command line must
  583.      contain the ESP's enhanced I/O port address.  For bit rates exceeding
  584.      180000bps the IRQ MUST be specified for the master port. For lower
  585.      data rates NONE may be specified for the IRQ.  SIO does not search for
  586.      the ESP ports as the Hayes drivers do under DOS/Windows.  This
  587.      searching can (will) break things under OS/2.  The SIO command line
  588.      for an ESP at I/O port 180h using IRQ14 would be as follows:
  589.  
  590.      DEVICE=path\SIO.SYS (COM1,180,IRQ14) (COM2,188,NONE)
  591.  
  592.      If you would like the above reflected to DOS sessions as a standard
  593.      COM1 and COM2, then use the following command line:
  594.  
  595.      DEVICE=path\SIO.SYS (COM1,180:3F8,IRQ14:IRQ4) (COM2,188:2F8,NONE:IRQ3)
  596.  
  597.      Note that the numbers after the colons ":" are the address and IRQ of
  598.      where the port appears to DOS software running under OS/2.  
  599.      Any IRQ specified for an ESP slave port is ignored.  For those that
  600.      like to have a clean looking CONFIG.SYS, SIO will accept NONE as the
  601.      IRQ specification of an ESP slave port.
  602.  
  603.      If you wish to use the ESP in Compatibility Mode, simply specify the
  604.      base port address that the ESP's compatibility mode is configured for
  605.      (ie 3F8 when configured for COM1).
  606.  
  607.      Telcor Tport
  608.  
  609.      The Telcor Tport is supported in both burst mode and 16450 emulation
  610.      mode.  When in burst mode, the Tport's 16k FIFOs are enabled. 
  611.      Additionally in burst mode, no IRQ is used by the Tport.  In burst
  612.      mode, any IRQ specified for the Tport is ignored.  For those that like
  613.      to have a clean looking CONFIG.SYS, SIO will accept NONE as the IRQ
  614.      specification of a Tport.  An example command line defining a Tport
  615.      card to be used in burst mode; and that is configured for COM1
  616.      follows:
  617.  
  618.      DEVICE=path\SIO.SYS (COM1,Tport@3F8,NONE:IRQ4)
  619.  
  620.      The Tport's 16450 Emulation mode simply uses a normal SIO command
  621.      line. eg:
  622.  
  623.      DEVICE=path\SIO.SYS (COM1,3F8,IRQ4:IRQ4)
  624.  
  625.      In both examples the "IRQ4" following the colon above, means that the
  626.      virtual IRQs are to be sent to a VDM on IRQ4.
  627.  
  628.  
  629.  
  630.  
  631.                                                                          11
  632.  
  633.  
  634.                             AUTOMATIC IRQ ASSIGNMENT
  635.  
  636.      SIO will automatically locate the IRQ that a comm port is attached to. 
  637.      The IRQ used by SIO for a given comm port is assigned in the following
  638.      manner:
  639.  
  640.      1 - If an IRQ is specified in the SIO command line then that IRQ is
  641.      used.  However, SIO will display a warning message if the IRQ seems to
  642.      be other than specified.
  643.  
  644.      2 - If no IRQ is specified in the command line, and if SIO detected
  645.      the IRQ then the detected IRQ is used.
  646.  
  647.      3 - If no IRQ is specified in the command, and if SIO could NOT detect
  648.      an IRQ then the default IRQ for the comm port is used.  SIO will also
  649.      display a warning message in this case.
  650.  
  651.      The following STYLE command line is recommended for all but the most
  652.      unusual systems.  That is, specify only the port number for those
  653.      above COM2 (to tell SIO to support those ports) and let SIO do the
  654.      rest.
  655.  
  656.      DEVICE=SIO.SYS (COM3) (COM4)
  657.  
  658.      If you do not have a COM3 or COM4, or if the mouse is using the only
  659.      comm port above COM2 then the following command line should be used.
  660.  
  661.      DEVICE=SIO.SYS
  662.  
  663.  
  664.  
  665.  
  666.                                                                          12
  667.  
  668.                                   DOS SETTINGS
  669.  
  670.      VSIO gets its operational characteristics from DOS Settings.  Several
  671.      basic DOS Settings are provided.  They specify the type of access (if
  672.      any) that a DOS program is to have to a communication port that SIO
  673.      controls.
  674.  
  675.      All of the DOS Settings default to what most users should use most of
  676.      the time (which is ON).  Also, all of the DOS Settings are prefixed
  677.      with SIO_.
  678.  
  679.      If any of the DOS settings are changed, then the DOS session must be
  680.      restarted from the Work Place Shell for the changed setting to take
  681.      affect.
  682.  
  683.      The provided DOS Settings and their meaning follow:
  684.  
  685.           "SIO_Allow_Access_COMn" (where n is 1 thru 4).  This DOS setting
  686.           defaults to ON.  If this setting is turned OFF for any or all of
  687.           the ports, the DOS program will not be allowed any access to that
  688.           port(s).
  689.  
  690.           "SIO_Virtualize_COM_Ports"  This Dos setting defaults to ON and
  691.           it applies to all communications ports used by the DOS session. 
  692.           When ON, this DOS setting means VSIO is to act as an interface
  693.           between the SIO and the DOS program.  When OFF, the DOS program
  694.           is given direct access to the hardware ports of the UART(s).
  695.  
  696.           "SIO_Virtualize_16550A"  This DOS setting defaults to ON and it
  697.           applies to all communications ports used by the DOS session. 
  698.           When ON, VSIO will simulate a 16550A.  When OFF, VSIO will
  699.           simulate a 16450.  Some DOS programs may not work when a 16550A
  700.           is simulated.  Turning this setting off may allow the program to
  701.           work (but slower).
  702.  
  703.           "SIO_Share_Access_With_OS/2"  This DOS setting defaults to ON and
  704.           it applies to all communications ports used by the DOS session. 
  705.           When ON, SIO will allow an OS/2 session to access a
  706.           communications port which the DOS session first opened (and has
  707.           not closed).  If set to OFF, then the DOS session will have
  708.           exclusive use of the communications port(s) that it uses.
  709.  
  710.           This setting does not apply to a second DOS session attempting to
  711.           access a communications port,  two different DOS sessions are
  712.           never allowed to access the same port at the same time. 
  713.           Additionally, this setting has no affect upon the access to a
  714.           communications port which is first opened by an OS/2 session.
  715.  
  716.  
  717.  
  718.  
  719.                                                                          13
  720.  
  721.  
  722.           "SIO_Screen_Sync_Kludge" DOS setting.  This DOS setting defaults
  723.           to off and it applies to all communications ports used by the DOS
  724.           session.  Some DOS BBS programs (such as Wildcat) and many DOS
  725.           Door programs attempt to synchronize the screen output with
  726.           transmitted data.  This plays havoc with a multi tasking system
  727.           like OS/2 and results in very slow transmitted data.  When this
  728.           setting is on, an attempt is made to fake out these misbehaved
  729.           programs and allow them to run at normal transmit speed.  This
  730.           setting should not be turned on unless you experience VERY slow
  731.           transmission from a DOS program.
  732.  
  733.      All of the DOS Settings that begin with "SIO_Mode"  allows one to
  734.      construct a MODE command for a DOS session.  These settings apply to
  735.      SIO proper, and not necessarily to the DOS program itself.  For
  736.      example, if you set XON/XOFF handshake with the appropriate SIO_Mode
  737.      setting, you are specifying that SIO is to implement the handshaking. 
  738.      The DOS application itself will be unaware of this handshaking.  This
  739.      can be very confusing, so think it through before you start changing
  740.      the defaults.
  741.  
  742.      The "SIO_Mode" settings WILL NOT BE APPLIED IF THE COMM PORT IS
  743.      ALREADY OPEN WHEN THE DOS SESSION FIRST ACCESSES THE COMM PORT.  This
  744.      means that the "SIO_Mode" settings will NOT be asserted for spawned
  745.      DOS comm programs.  That is, for spawned DOS comm programs, the mode
  746.      of operation that is already in effect will continue to be in effect
  747.      and the "SIO_Mode" settings are ignored.
  748.  
  749.           "SIO_Mode_DTR"  This setting has three options that specify how
  750.           SIO and VSIO are to treat the DTR signal.  The there available
  751.           option are:
  752.                     No Change at OPEN or CLOSE.
  753.                     Turn ON at OPEN, OFF at CLOSE.
  754.                     HandShake Signal, as in DTR/DSR.
  755.  
  756.                If either of the first two settings is selected, then
  757.                basically the DOS application has direct control over the
  758.                DTR signal.  If the second option is selected, then DTR will
  759.                be turned on by SIO when the DOS program first touches the
  760.                comm port.
  761.  
  762.                If the third option is selected, then SIO will use DTR as a
  763.                handshaking signal.  That is, DTR will be turned off if SIO
  764.                can not accept any further receive data.  In addition, if
  765.                the DOS application program turns off the Virtual DTR, VSIO
  766.                will stop supplying the DOS application with receive data.
  767.  
  768.  
  769.  
  770.  
  771.                                                                          14
  772.  
  773.  
  774.           "SIO_Mode_IDSR"  This setting specifies how SIO is to react to
  775.           received data and the DSR signal.  The two available options are:
  776.                     Ignore DSR During Receive.
  777.                     Required for Valid Receive Data.
  778.  
  779.                If the first option (the default) is selected, then SIO will
  780.                ignore DSR and accept all received data.  If the second
  781.                option is selected, then SIO will ignore received data when
  782.                the DSR signal is off.  VSIO ignores this DOS setting.
  783.  
  784.  
  785.  
  786.  
  787.                                                                          15
  788.  
  789.  
  790.           "SIO_Mode_OCTS"  This setting specifies how SIO will react to the
  791.           CTS signal when transmitting data.  The two available options
  792.           are:
  793.                     HandShake Signal, as in RTS/CTS.
  794.                     Ignore CTS During Transmit.
  795.  
  796.                If the first option (the default) is selected, then SIO will
  797.                not transmit data when the CTS signal is off.  If the second
  798.                option is selected, then SIO will ignore CTS during
  799.                transmit.  Note that this setting should be set to "Ignore"
  800.                for 3 wire connections like the Seiko Smart Label Printer,
  801.                and Laplink.  VSIO ignores this setting.
  802.  
  803.           "SIO_Mode_ODSR"  This setting specifies how SIO is to react to
  804.           the DSR signal during transmit.  The two available options are:
  805.                     Ignore DSR During Transmit.
  806.                     HandShake Signal, as in DTR/DSR.
  807.  
  808.                If the first option (the default) is selected, then SIO will
  809.                ignore DSR during transmit.  If the second option is
  810.                selected, then SIO will not transmit data when the DSR
  811.                signal is off.  VSIO ignores this setting.
  812.  
  813.  
  814.           "SIO_Mode_RTS" This setting has three options that specify how
  815.           SIO and VSIO are to treat the RTS signal.  The there available
  816.           option are:
  817.                     HandShake Signal, as in RTS/CTS.
  818.                     No Change at OPEN or CLOSE.
  819.                     Turn ON at OPEN, OFF at CLOSE.
  820.  
  821.                If either of the last two settings is selected, then
  822.                basically the DOS application has direct control over the
  823.                RTS signal.  If the last option is selected, then RTS will
  824.                be turned on by SIO when the DOS program first touches the
  825.                comm port.
  826.  
  827.                If the first option (the default) is selected, then SIO will
  828.                use RTS as a handshaking signal.  That is, RTS will be
  829.                turned off if SIO can not accept any further receive data. 
  830.                In addition, if the DOS application program turns off the
  831.                virtual RTS signal, VSIO will stop supplying the DOS
  832.                application with receive data.
  833.  
  834.  
  835.  
  836.  
  837.                                                                          16
  838.  
  839.  
  840.           "SIO_Mode_XON/XOFF"  This setting specifies if (and how) SIO is
  841.           to use XON/XOFF flow control.  The four options are:
  842.                     No XON/XOFF flow control by SIO.
  843.                     Received XON is flow control.
  844.                     Sent XON is flow control.
  845.                     Rcvd and Sent XON is flow control.
  846.  
  847.                The first option (the default) specifies that SIO is not to
  848.                use XON/XOFF flow control at all.  The second option
  849.                specifies that SIO is to treat received XON/XOFF as flow
  850.                control, but that SIO must not send XON/XOFF as flow control
  851.                characters.  The third option specifies that SIO may send
  852.                XON/XOFF as flow control characters, but that received
  853.                XON/XOFF characters are to be treated as normal data.  The
  854.                fourth option turns on XON/XOFF flow control in both
  855.                directions, meaning that all sent and received XON/XOFF
  856.                characters are flow control.
  857.  
  858.  
  859.  
  860.  
  861.                                                                          17
  862.  
  863.  
  864.           "SIO_Mode_FIFO_Load_Count"  This setting specifies how many
  865.           characters that SIO will load into a 16550A UART at one time. 
  866.           The choices are 1 and 16 (16 is the default).  The only case
  867.           known to the author where one would select a setting of 1, is
  868.           when very fast reaction to flow control is needed.  One such case
  869.           is the Seiko Smart Label Printer which uses XON/XOFF flow control
  870.           and a 3 wire connection.  If one is using a 16550 with a load
  871.           count of 16, then 16 additional characters may be sent after an
  872.           XOFF is received.  This condition will overrun the Seiko Printer. 
  873.           If the "Load Count" is set to 1, then SIO will transmit (at most)
  874.           two additional characters following a received XOFF which allows
  875.           the Seiko Printer to work.  A setting of 1 will cause additional
  876.           system overhead due to additional transmit interrupts.
  877.  
  878.  
  879.  
  880.  
  881.                                                                          18
  882.  
  883.  
  884.                              Configuration Profiles
  885.  
  886.      I will attempt to provide the DOS Settings that one should try for DOS
  887.      communications programs in this section.  The settings may not work on
  888.      all systems.  I will add to this section as I receive information from
  889.      users.  All DOS Settings that are not given should be at their
  890.      defaults.
  891.  
  892.      Seiko Smart Label Printer.
  893.           I tested the Seiko printer successfully using the following DOS
  894.           settings for SIO:
  895.  
  896.           SIO_Mode_DTR                No Change at OPEN or CLOSE
  897.           SIO_Mode_FIFO_Load_Count    1.
  898.           SIO_Mode_IDSR               Ignore DSR During Receive
  899.           SIO_Mode_OCTS               Ignore CTS During Transmit
  900.           SIO_Mode_ODSR               Ignore DSR During Transmit
  901.           SIO_Mode_RTS                No Change at OPEN or CLOSE
  902.           SIO_Mode_XON/XOFF"          Received XON is flow control
  903.  
  904.      In addition, you should run the printer in its own separate Win-OS/2
  905.      session.
  906.  
  907.      IBM's SLIP
  908.           I have been told by many users that a MODE command is required
  909.           for IBM's SLIP program to work correctly.  The recommended MODE
  910.           command is as follows:
  911.  
  912.           MODE DTR=ON
  913.  
  914.  
  915.  
  916.  
  917.                                                                          19
  918.  
  919.                     Differences between SIO/VSIO and COM/VCOM
  920.  
  921.      What follows is some of the differences between SIO/VSIO and COM/VCOM
  922.      that are known to the author.
  923.  
  924.      1 -  COM.SYS will automatically seek out and support four comm
  925.           ports, COM1 through COM4.  SIO.SYS will automatically seek
  926.           out and support only COM1 and COM2.  If SIO.SYS is to
  927.           support more than two comm ports, they must be defined in
  928.           the command line that loads SIO.SYS.  For example,
  929.           DEVICE=SIO.SYS (COM3) (COM4) will cause SIO.SYS to support
  930.           four comm ports.
  931.  
  932.      2 -  In the absence of overrides in the command line, COM.SYS
  933.           will seek out four comm ports in the sequence of I/O ports
  934.           3F8h, 2F8h, 3E8h and 2E8h.  The first port found in this
  935.           sequence is given the logical name COM1, the second is COM2
  936.           etc.  This means that the comm port at 2F8h could become
  937.           COM1.  In the opinion of the author, this confuses some
  938.           users to frustration.
  939.  
  940.           With no command line overrides, SIO.SYS uses a fixed I/O
  941.           port concept.  That is, COM1 is always at I/O port 3F8h,
  942.           COM2 is always at 2F8h, etc.  Another way of looking at this
  943.           is;  if no comm port exists at port 3F8h, then you do not
  944.           have a COM1.  SIO.SYS will not move another (found) comm
  945.           port into the logical COM1 slot.
  946.  
  947.      3 -  VSIO opens a comm port for a DOS session with sharing allowed. 
  948.           VCOM uses an "exclusive use" open for DOS sessions.
  949.  
  950.      4 -  SIO.SYS always controls the FIFOs of the 16550 UART.  SIO.SYS
  951.           will not allow an application program (OS2 or DOS) to disable the
  952.           FIFOs of a real 16550.  The application may specify the transmit
  953.           fifo load count.
  954.  
  955.      5 -  SIO.SYS will accept any number between 50 and 115200 (921600 if a
  956.           Hayes ESP) as a valid baud rate.  For example, if an application
  957.           program attempts to set a baud rate of 9990 bps, COM.SYS will
  958.           reject it and SIO.SYS will accept it.
  959.  
  960.      6 -  SIO/VSIO execute faster than COM/VCOM.  This means that some
  961.           applications, that are timing dependent, may not work under
  962.           SIO/VSIO that do work under COM/VCOM.
  963.  
  964.  
  965.  
  966.  
  967.                                                                          20
  968.  
  969.  
  970.      7 -  SIO/VSIO provides more reliable active flow control for DOS
  971.           sessions.  For example, if RTS/CTS handshaking is in use, VSIO
  972.           processes the RTS settings by the DOS program while SIO
  973.           completely controls the real RTS signal.  COM/VCOM simply passes
  974.           the RTS signal directly to the hardware.
  975.  
  976.      8 -  COM.SYS will block an application until a write completes.  SIO
  977.           will return to the application program immediately if all of the
  978.           write data will fit into SIO's internal buffers.
  979.  
  980.  
  981.  
  982.  
  983.                                                                          21
  984.  
  985.  
  986.                              PROBLEMS AND SOLUTIONS
  987.  
  988.      1 -  Port already in use is displayed.
  989.  
  990.           This message is displayed when the comm port or the IRQ is in
  991.           use.  If the comm port is not actually in use, the IRQ is most
  992.           likely in use.
  993.  
  994.      2 -  SIO displays a warning message that the IRQ for a port appears to
  995.           be wrong, but the port works.
  996.  
  997.           SIO probably detected more than one IRQ attached to the comm
  998.           port.  This indicates a possible hardware problem with your
  999.           system that you may want to have checked.
  1000.  
  1001.      3 - The modem will not initialize.
  1002.  
  1003.           Configure your comm program(s) to insert a delay between modem
  1004.           initialization characters as they are sent to the modem.
  1005.  
  1006.      4 - WinFax locks up during install.
  1007.  
  1008.           During the WinFax install, temporarily turn OFF the DOS setting
  1009.           SIO_Virtualize_COM_Ports.  Once installation is complete, the
  1010.           setting SIO_Virtualize_COM_Ports can be restored.
  1011.  
  1012.      5 - Telemate does not recognize VX00 as a FOSSIL.
  1013.  
  1014.           Set the baud rate in Telemate to less than 57600.
  1015.  
  1016.      6 -  Comm output is very slow from DOS.
  1017.  
  1018.           This is a problem common to many DOS BBS and Door programs.  They
  1019.           attempt to synchronize the local screen with the transmitted
  1020.           data.  That is, they send a character, wait until it is sent and
  1021.           then display the character on the local screen.  This does not
  1022.           cause a problem for the single tasking DOS environment.  However,
  1023.           this procedure causes at least two (probably more) context
  1024.           switches in the multi-tasking environment of OS2, which in turn
  1025.           brings the processor to its knees.  One possible solution is for
  1026.           the programmer to synchronize line by line instead of character
  1027.           by character.
  1028.  
  1029.  
  1030.  
  1031.  
  1032.                                                                          22
  1033.  
  1034.  
  1035.  
  1036.      7 -  Procomm stops receiving
  1037.  
  1038.           Procomm seems to have a bug in its implementation of RTS/CTS
  1039.           handshaking.  The problem shows up most often when Procomm is
  1040.           windowed.  Under certain conditions, Procomm will turn the
  1041.           virtual RTS OFF and does not turn it ON again.  This prevents
  1042.           VSIO from sending further data to Procomm if SIO_Mode_RTS is set
  1043.           for RTS/CTS handshake.  A solution to the problem that seems to
  1044.           work is to set SIO_Mode_RTS to other than RTS/CTS handshake. 
  1045.           Note that SIO_Mode_RTS should be set for RTS/CTS handshake under
  1046.           almost all other conditions.
  1047.  
  1048.      8 -  Procomm For Windows download errors
  1049.  
  1050.           You should find the file PW2.INI in you main WINDOWS directory. 
  1051.           Locate the statement DropRTSAroundDiskWrites=1 and change it to:
  1052.  
  1053.                DropRTSAroundDiskWrites=0
  1054.  
  1055.  
  1056.  
  1057.  
  1058.                                                                          23
  1059.  
  1060.  
  1061.      9 - WinFax does not work well.
  1062.  
  1063.           a- Connect problems with recipient's fax station
  1064.  
  1065.           b- Cannot send more than one page of a multiple page fax
  1066.  
  1067.           c- Transmission fails between pages
  1068.  
  1069.           d- Transmitted pages are corrupted, missing parts, or cut off.
  1070.  
  1071.           Class 1 FAX modem.
  1072.                     The modem init strings set by WinFax 3.0 will work in
  1073.                     the single-layered comm world of DOS and Windows. 
  1074.                     However, these modem init strings will not work in the
  1075.                     multi-layered comm environment used by OS/2. 
  1076.                     Specifically, WinFax 3.0 sets the modem to use only
  1077.                     Xon/Xoff flow control.  Ideally, both Xon/Xoff and
  1078.                     Hardware handshaking needs to be set.  If only one
  1079.                     handshake can be set, set the modem to Hardware
  1080.                     handshake.  For USR FAX modems, use &H3, for many other
  1081.                     modems, the setting is &K3.  Additionally, for WinFax
  1082.                     3.04 and up, place the following in your WINFAX.INI
  1083.                     file:
  1084.                          HdwFlowControl=1
  1085.  
  1086.           Class 2 FAX modem.
  1087.                     It seems to the author that hardware handshake screws
  1088.                     up some (possibly all) class 2 FAX modems.  Therefore,
  1089.                     when using a class 2 modem, WinFax should be configured
  1090.                     to use XON/XOFF handshaking.  For WinFax 3.04 and up,
  1091.                     place the following in your WINFAX.INI file:
  1092.                          HdwFlowControl=0
  1093.  
  1094.                     The author feels that the inability to use hardware
  1095.                     handshake with class 2 FAX modems is a serious design
  1096.                     deficiency.
  1097.  
  1098.      10 - Serial Printer messes up on last page.
  1099.  
  1100.           Add the following command line to your CONFIG.SYS file:
  1101.                RUN=MODE COM1 TO=ON
  1102.  
  1103.  
  1104.  
  1105.  
  1106.                                                                          24
  1107.  
  1108.                                IRQ SHARING ON ISA
  1109.  
  1110.      Sharing the same IRQ for multiple communications ports on ISA systems
  1111.      is not for the weak of heart (or mind).  If you have problems with
  1112.      shared IRQs, DO NOT contact the author.  Contact the board or computer
  1113.      manufacturer for help.
  1114.  
  1115.      Some general rules are as follows:
  1116.  
  1117.      1 - Two different boards (plugged into different slots) can not share
  1118.      the same IRQ.  This is a hardware limitation of ISA systems and can
  1119.      not be corrected by software.  This means that you can not plug in two
  1120.      internal modems, set them for the same IRQ and expect them to work. 
  1121.      This does not apply to PS/2 systems.  The problem of multiple boards
  1122.      sharing the same IRQ was corrected in the PS/2's bus design.
  1123.  
  1124.      2 - SIO can not (will not) share an IRQ with other device drivers at
  1125.      the same time.  SIO releases IRQs that it is currently not using. 
  1126.      This is different form how COM.SYS works.  This difference may show up
  1127.      as an unexpected "port already in use" error that does not occur with
  1128.      COM.SYS.  I have received reports that the SDLC drivers try to
  1129.      concurrently share IRQs with the ASYNC driver.  SIO.SYS will not allow
  1130.      this while COM.SYS will.
  1131.  
  1132.  
  1133.  
  1134.  
  1135.                                                                          25
  1136.  
  1137.                   Appendix A, Hardware Port and IRQ Assignments
  1138.  
  1139.      I have obtained the following information from various sources. 
  1140.      Accuracy is not guaranteed.  In fact, nothing in this document is
  1141.      guaranteed.
  1142.  
  1143.      Addresses and IRQs for COM1 and COM2
  1144.  
  1145.           COM1 uses 03F8h and IRQ4
  1146.           COM2 uses 02F8h and IRQ3
  1147.  
  1148.      Defacto standard for COM3 and COM4 for PC, XT and AT
  1149.  
  1150.           COM3 uses 03E8h and IRQ4
  1151.           COM4 uses 02E8h and IRQ3
  1152.  
  1153.      Addresses and IRQ for COM3 through COM8 on the PS/2
  1154.  
  1155.           COM3 uses 3220h and IRQ3
  1156.           COM4 uses 3228h and IRQ3
  1157.           COM5 uses 4220h and IRQ3
  1158.           COM6 uses 4228h and IRQ3
  1159.           COM7 uses 5220h and IRQ3
  1160.           COM8 uses 5228h and IRQ3
  1161.  
  1162.      All PCs (known to the author) prior to the PS/2 and EISA only use 10
  1163.      bits to address hardware I/0 ports.  Systems prior to the PS/2 and
  1164.      EISA can not address the standard PS/2 addresses for COM3 through
  1165.      COM8.  If an AT or below attempts to address COM3 through COM8 using
  1166.      the PS/2 addresses, only the low 10 bits of the address are used. 
  1167.      That is, the high digit of the hexadecimal address will be ignored. 
  1168.      This means that any reference to COM3 through COM8 will actually
  1169.      address ports 220h through 22Fh on older PCs.
  1170.  
  1171.      One should avoid expansion boards that use ports 220h through 22Fh
  1172.      unless the expansion board is a serial I/O board. 
  1173.  
  1174.      SIO will (attempt to) determine the hardware architecture (ISA/EISA
  1175.      and PS/2) that it is being executed on and use the appropriate
  1176.      hardware port addresses for COM1 thru COM4 as defaults.
  1177.  
  1178.  
  1179.  
  1180.  
  1181.                                                                          26
  1182.  
  1183.                               Appendix B, SIO Chips
  1184.  
  1185.  
  1186.      The following is a collection of comments developed from hearsay,
  1187.      random documents, experience, and technical specifications. So, take
  1188.      it with a grain of salt.  Order information from the various
  1189.      manufactures if you want accurate information.
  1190.  
  1191.      Very good reference books are available from National Semiconductor
  1192.      Corporation.  They cover most of the SIO devices (also called UARTs)
  1193.      that you will find in many PCs and clones.  I am not sure that books
  1194.      can be ordered directly from National semiconductor. They may require
  1195.      that you get it from a distributor.  In any case, the address on the
  1196.      back of the one manual is:
  1197.  
  1198.           National Semiconductor Corporation
  1199.           2900 Semiconductor Drive
  1200.           P.O. Box 58090
  1201.           Santa Clara, CA 95052-8090
  1202.  
  1203.           Tel:(408)721-5000
  1204.           TWX:(910)339-9240
  1205.  
  1206.      8250
  1207.  
  1208.      As best that I know, the 8250 was the first SIO chip (integrated
  1209.      circuit) that was used by the IBM PC and many clones.  In my opinion,
  1210.      it was a poor choice on the part of IBM.  I feel many superior
  1211.      devices, at comparable prices, were readily available.  At that time,
  1212.      I feel the 8251A or the 8530 would have been better choices.  But,
  1213.      they used the 8250 and therefore we must use it.
  1214.  
  1215.      From a hardware standpoint the 8250 is a relatively slow device.  It
  1216.      is advisable that programmers not perform successive inputs or outputs
  1217.      to this device.  It seems that software programs can load the various
  1218.      registers of the 8250 faster than it can process the information.  The
  1219.      8250 had a total of 7 registers.  The specifications state that 56kb
  1220.      is the maximum baud rate.
  1221.  
  1222.      8250A
  1223.  
  1224.      I believe the 8250A is the 8250 with some bug fixes.  I have no idea
  1225.      what the bugs may have been.  A quick glance at the specifications
  1226.      shows the speed of the 8250 and 8250A to be much the same.  The 8250A
  1227.      added an 8th register.  This additional register enables software to
  1228.      detect if an 8250 is installed.  The specifications state that 56kb is
  1229.      the maximum baud rate.
  1230.  
  1231.      16450
  1232.  
  1233.      The 16450 seems to be a speeded up version of the 8250A.  There is no
  1234.      direct way (that I know of) for software to detect the difference
  1235.      between an 8250A and a 16450.  I believe the 16450 was developed to
  1236.      eliminate the need for software to insert delays between successive
  1237.      accesses to the device.  The specifications indicate the 16450 is a
  1238.  
  1239.  
  1240.  
  1241.  
  1242.                                                                          27
  1243.  
  1244.      much faster device than its predecessors.  The additional speed is
  1245.      only the speed at which the processor can access the device.  The
  1246.      maximum baud rate for the 16450 is still stated at 56kb.  However, I
  1247.      have been told by some people that they have run the 16450
  1248.      successfully at much higher speeds. I do not believe there was ever a
  1249.      16450A.
  1250.  
  1251.      16C451
  1252.  
  1253.      The 16C451 is a CMOS version of the 16450.  CMOS is a term for the
  1254.      material and manufacturing process used to make the part.  CMOS
  1255.      typically uses less power than other technologies.  If you are not
  1256.      designing hardware, you should view the 16C451 as a 16450.
  1257.  
  1258.      16550 (Non A)
  1259.  
  1260.      It is hard to find a 16550 (Non A).  I was told by National
  1261.      Semiconductor that they did everything they could to get all 16550s
  1262.      back.  SIO will detect a 16550 and tell you if you have one.  I am
  1263.      told that the 16550 was installed in early PS/2 systems.
  1264.  
  1265.      The 16550 was the first shot at a FIFOed version of the 8250 family
  1266.      from National semiconductor.  However, I was told by National
  1267.      Semiconductor that the FIFOs of the 16550 are not reliable and they
  1268.      should not be enabled.  SIO will treat a 16550 like a 16450.  In this
  1269.      mode, they are reliable.  National Semiconductor would not provide me
  1270.      with a specification for the 16550.  However, I suspect its maximum
  1271.      baud rate is the same as the 16550A which is 256kb.
  1272.  
  1273.      16550A, 16550AF and 16550AFN
  1274.  
  1275.      In the manuals that I have, National Semiconductor does not explain
  1276.      the differences between the 16550A and the 16550AF.  I suspect the AF
  1277.      part may have a few bug fixes.  I believe the N in AFN describes
  1278.      packaging, ceramic versus plastic, DIP versus surface mount etc.
  1279.  
  1280.      In the opinion of the author, there is no substitute for the 16550A
  1281.      (and its successors) in the 8250 type series.  The 16550A is
  1282.      compatible with most software written for the entire family of 8250
  1283.      type devices.  Programs that are 16550A aware can provide much
  1284.      improved performance over previous devices.
  1285.  
  1286.  
  1287.      The maximum baud rate for the 16550A is specified at 256kb.  However,
  1288.      due to the hardware design of the PC et al, 115kb is the maximum baud
  1289.      rate that can be programmed by software.
  1290.  
  1291.      The 16550A can be plugged into the same socket that contains an 8250,
  1292.      8250A or 16450.  If your SIO expansion board has the SIO chips in
  1293.      sockets, you can upgrade to the 16550A by simply removing the old
  1294.      chips and replacing them with 16550As.
  1295.  
  1296.      The key to the performance increase of the 16550A is its FIFOs.  It
  1297.      has 16 byte FIFOs for both transmit and receive data.
  1298.  
  1299.  
  1300.  
  1301.  
  1302.                                                                          28
  1303.  
  1304.      16550s Made by Western Digital
  1305.  
  1306.      I have been told, but I have not verified for myself, that 16550s made
  1307.      by Western Digital have a problem with their FIFOs when working at
  1308.      2400 baud or below.
  1309.  
  1310.      16C551
  1311.  
  1312.      The 16C551 is a CMOS version of the 16550AF.  See the above
  1313.      description of the 16C451 for a discussion of CMOS.  Do not feel you
  1314.      need to upgrade from a 16550A or AF to a 16C551.  There is no gain
  1315.      from an existing users point of view.
  1316.  
  1317.      16C552
  1318.  
  1319.      The 16C552 is two 16C551s on a single chip.
  1320.  
  1321.      16C554
  1322.  
  1323.      The 16C554 is four 16C551s on a single chip.
  1324.  
  1325.      82510
  1326.  
  1327.      I believe Intel is the only company that manufactures the 82510.  The
  1328.      82510 is feature rich with several modes of operation.  Its default
  1329.      mode is to operate as a 16450.  The 82510 has a 4 byte FIFO for both
  1330.      transmit and receive data.  A 4 byte FIFO is sufficient to provide
  1331.      significant performance over a basic 16450.
  1332.  
  1333.      The 82510 is small in size.  Therefore, it is found in many lap tops.
  1334.  
  1335.      The 82510 is somewhat of a sleeper.  I believe it would be much more
  1336.      widely used if Intel had promoted it more.  However, given a choice
  1337.      between the 82510 and the 16550A, I would select the 16550A.
  1338.  
  1339.  
  1340.  
  1341.  
  1342.                                                                          29
  1343.  
  1344.  
  1345.      16650
  1346.  
  1347.      The 16650 by Startech seems a good logical step in the evolution of
  1348.      the 8250 type UARTs.  One of the many flavors of the 16650 is a
  1349.      package that is pin compatible with the 40 pin (DIP) 16550s.  This
  1350.      means that the 16650 can be placed into the same socket as any 16550,
  1351.      8250, etc.
  1352.  
  1353.      The 16650 has enhanced the FIFOs to 32 bytes, added on chip flow
  1354.      control ability, and increases the maximum bit rate to 460800.  The on
  1355.      chip flow control is a really nice feature.  On chip flow control
  1356.      practically eliminates the possibility of missed receive characters. 
  1357.      On chip flow control also means that some devices that require
  1358.      immediate attention when it sends Xoff, like the Seiko Label Printer,
  1359.      will work much better in environments like OS/2 and Windows.
  1360.  
  1361.      The 32 byte FIFOs of the 16650 is an improvement over the 16550, but
  1362.      is still a disappointment.  I feel that 1k, or larger, FIFOs would
  1363.      have been a much better choice.  When I quizzed Startech about this,
  1364.      they replied that the 32 byte FIFOs were chosen to keep the cost down. 
  1365.      They added that if the 16650 is successful, they plan a 16750 with
  1366.      larger FIFOs.
  1367.  
  1368.      The 16650 powers up in a 16550 compatible mode, meaning most software
  1369.      written for the 16550 should work.
  1370.  
  1371.      16750 from Texas Instruments
  1372.  
  1373.      The 16750 from TI is an improvement over the 16550, but the omission
  1374.      of software flow control (Xon/Xoff) makes it inferior to the 16650, in
  1375.      the opinion of the author.  The 16750 has a 64 byte fifo and hardware
  1376.      flow control.  It is a good choice for a uart.
  1377.  
  1378.  
  1379.  
  1380.  
  1381.                                                                          30
  1382.  
  1383.  
  1384.      ComBic
  1385.  
  1386.      The ComBic is a very impressive UART used on the Hayes ESP card and
  1387.      some others.  The ComBic is basically a 16550 UART with on chip flow
  1388.      control and 1k FIFOs and a maximum bit rate of 921600.   Like the
  1389.      16650, on chip flow control practically eliminates the possibility of
  1390.      missed receive characters.  On chip flow control also means that some
  1391.      devices that require immediate attention when it sends Xoff, like the
  1392.      Seiko Label Printer, will work much better in environments like OS/2
  1393.      and Windows.
  1394.  
  1395.      The ComBic has two modes of operation, compatibility mode and enhanced
  1396.      mode.  In compatibility mode, the UART acts as a 16550.  However, when
  1397.      in compatibility mode, the 1k FIFOs and on chip flow control can still
  1398.      be used.  In enhanced mode, software gains the ability to look into
  1399.      the FIFOs and determine the exact number of bytes loaded.  This
  1400.      feature enables software the use block input and output to the ComBic
  1401.      which greatly reduces processor overhead.
  1402.  
  1403.  
  1404.  
  1405.  
  1406.                                                                          31
  1407.  
  1408.                      Appendix C, Multi-Port Serial I/0 Cards
  1409.  
  1410.      I have received many requests for information about multi-port serial
  1411.      I/O card.  I will describe the boards that I know about (or have heard
  1412.      about) here.  I will add to the list as I receive precise information
  1413.      from manufactures, users, or I develop it myself.
  1414.  
  1415.      Please do not contact me for support on the following boards, contact
  1416.      the manufacturer.  The following tells of my experiences with the
  1417.      boards and does not imply support.  Your experiences with a given
  1418.      board may be different.
  1419.  
  1420.  
  1421.      NOTE:     The Hayes ESP and Telcor Tport are described in the
  1422.                "Intelligent Cards Supported" section of this manual.
  1423.  
  1424.  
  1425.      STB 4COM  (ISA bus)
  1426.  
  1427.      I am very impressed with the STB 4COM card, they have almost got it. 
  1428.      Yes, its the same company that makes the VGA cards.  The 4COM card
  1429.      uses a 16554 which is the equivalent of four 16550A.  Comm ports can
  1430.      use IRQs 2/9, 3, 4, 5, 10, 11, 12, and 15.  Any or all ports can share
  1431.      IRQs, and they have done this right.  I tested SIO with all four ports
  1432.      of the 4COM on IRQ12 and they worked correctly.  The user can select
  1433.      any of the following I/O port address for a comm port: 3F8, 2F8, 3E8,
  1434.      2E8, 1A8, 1E8, 1F8, 2A8.
  1435.  
  1436.      The 4COM card is priced at $110 and I ordered mine from Prerapture
  1437.      Solutions which can be reached by telephone at 1-919-286-1502 for
  1438.      information and foreign callers.  In the US orders can be placed by
  1439.      calling 1-800-735-5266.  Their mailing address is:
  1440.           Prerapture Solutions
  1441.           1806 Albany St.
  1442.           Durham NC 27705-3135
  1443.  
  1444.      Connect Tech Dflex-8
  1445.  
  1446.      This is one of the most configure able communications cards that I
  1447.      have ever seen.  It has on board simms to configure the electrical
  1448.      characteristics (RS232, RS442 etc).  The board that I tested was
  1449.      configured for RS232 and has 8 Startech 16550 on it.  All 8 ports can
  1450.      be jumpered to the same IRQ and the IRQ sharing seems to work well
  1451.      with SIO and I detected no performance problems.
  1452.  
  1453.      I have no pricing information, the Dflex was supplied to me at no
  1454.      charge.  Connect Tech can be reached at 519-836-1291.  Their mailing
  1455.      address is:
  1456.  
  1457.      Connect Tech Inc.
  1458.      727 Speedvale Ave. West
  1459.      Guelph, Ontario, Canada
  1460.      N1K 1E6
  1461.  
  1462.  
  1463.  
  1464.  
  1465.                                                                          32
  1466.  
  1467.  
  1468.      Gtek BBS550 (ISA bus)
  1469.  
  1470.      The Gtek BBS550 is a communications card with the equivalent of 8
  1471.      16550s (in reality two 16554s) UARTs.  Where were these cards 5 years
  1472.      ago!  Like the STB 4COM, I am very impressed with the BBS550.  It has
  1473.      a wide range of selectable I/O port address, some in the 16 bit range
  1474.      (above 3FFh) which can be very useful.  I tested the board with all 8
  1475.      ports installed using IRQ3 (although I never had more than 3 ports
  1476.      active at the same time).  The board performed well using shared IRQs.
  1477.  
  1478.      The BBS550 has 8 RJ-45 connectors (10 pin), 6 of which comes directly
  1479.      off the back of the card.  The other two RJ-45 connectors are internal
  1480.      and special cables with grommets are supplier for these 2 ports.  The
  1481.      cables supplied with the BBS550 expands the RJ-45 out to standard DB-
  1482.      25 connectors.
  1483.  
  1484.      Gtek is located in St. Louis Mississippi.  Their phone number is 800-
  1485.      282-4835 or 601-467-8048.
  1486.  
  1487.      Neotech Quad Serial (MCA bus)
  1488.  
  1489.      Well, I just got my first PS/2 system (for testing of SIO) and I am
  1490.      using the NeoTech Quad Serial card in that system.  What can I say, it
  1491.      works beautifully and interrupt sharing has never been a problem on
  1492.      MCA systems.  This card (as shipped) came with four individual 16450
  1493.      chips installed, but they were in sockets so I installed 16550 UARTs
  1494.      before I installed the card.  The card has one large connector on the
  1495.      back of the card and the supplied cable expands that to 4 standard DB-
  1496.      25 connectors.  Those of you needing a good 4 port card for an MCA
  1497.      system contact:
  1498.  
  1499.           Neotech Inc
  1500.           30295 Solon Industrial Pkwy.
  1501.           Solon, Ohio 44139
  1502.  
  1503.           Voice     (216) 248-4114
  1504.           FAX       (216) 248-5701
  1505.  
  1506.  
  1507.  
  1508.  
  1509.                                                                          33
  1510.  
  1511.                                       INDEX
  1512.  
  1513.      16450 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
  1514.      16550 (Non A) . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1515.      16550A  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1516.      16550AF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1517.      16550AFN  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1518.      16550s Made by Western Digital  . . . . . . . . . . . . . . . . . . 28
  1519.      16650 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
  1520.      16750 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
  1521.      16C451  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1522.      16C551  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
  1523.      16C552  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
  1524.      16C554  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
  1525.      8250  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
  1526.      8250A . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
  1527.      82510 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
  1528.      Addresses and IRQ for COM3 through COM8 on the PS/2 . . . . . . . . 25
  1529.      Addresses and IRQs for COM1 and COM2  . . . . . . . . . . . . . . . 25
  1530.      Allow_Access_COMn . . . . . . . . . . . . . . . . . . . . . . . . . 12
  1531.      Appendix A, Hardware Notes  . . . . . . . . . . . . . . . . . . . . 25
  1532.      Appendix B, SIO Chips . . . . . . . . . . . . . . . . . . . . . . . 26
  1533.      Appendix C, Multi-Port Serial I/0 Cards . . . . . . . . . . . . . . 31
  1534.      AUTOMATIC IRQ ASSIGNMENT  . . . . . . . . . . . . . . . . . . . . . 11
  1535.      BBS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1536.      ComBic  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
  1537.      COMn already in use . . . . . . . . . . . . . . . . . . . . . . . . 21
  1538.      CompuServe  . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1539.      CONFIG.SYS  . . . . . . . . . . . . . . . . . . . . . . . . . . . .  5
  1540.      Connect Tech Dflex-8  . . . . . . . . . . . . . . . . . . . . . . . 31
  1541.      Defacto standard for COM3 and COM4  . . . . . . . . . . . . . . . . 25
  1542.      Development and Debugging Tools . . . . . . . . . . . . . . . . . .  8
  1543.      Differences between SIO/VSIO and COM/VCOM . . . . . . . . . . . . . 19
  1544.      Distribution  . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1545.      DOS SETTINGS  . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
  1546.      Email . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1547.      ESP in Compatibility Mode . . . . . . . . . . . . . . . . . . . . . 10
  1548.      Exclusive use . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
  1549.      FAX . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1550.      FAX Modems
  1551.           Class 1 FAX modem  . . . . . . . . . . . . . . . . . . . . . . 23
  1552.           Class 2 FAX modem  . . . . . . . . . . . . . . . . . . . . . . 23
  1553.      FaxWorks  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
  1554.      FIFO  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
  1555.      FMD.SYS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
  1556.      GETTING STARTED . . . . . . . . . . . . . . . . . . . . . . . . . .  5
  1557.      Gtek BBS550 . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
  1558.      Hayes ESP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
  1559.      Installing SIO/VSIO . . . . . . . . . . . . . . . . . . . . . . . .  5
  1560.      Intellegent Cards Supported . . . . . . . . . . . . . . . . . . . . 10
  1561.      IRQ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  6, 11
  1562.      IRQ SHARING ON ISA  . . . . . . . . . . . . . . . . . . . . . . . . 24
  1563.      ISA buss  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
  1564.      MCA buss  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
  1565.      National Semiconductor Corporation  . . . . . . . . . . . . . . . . 26
  1566.  
  1567.  
  1568.  
  1569.  
  1570.                                                                          34
  1571.  
  1572.      Neotech Quad Serial . . . . . . . . . . . . . . . . . . . . . . . . 32
  1573.      Ordering  . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1574.      OS2BVEN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1575.      PCMCIA  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
  1576.      PDD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  2
  1577.      Physical Device Driver  . . . . . . . . . . . . . . . . . . . . . .  2
  1578.      PKUNZIP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  5
  1579.           Authentic files  . . . . . . . . . . . . . . . . . . . . . . .  5
  1580.      PMLM.EXE  . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  8
  1581.      PROBLEMS AND SOLUTIONS  . . . . . . . . . . . . . . . . . . . . . . 21
  1582.      Quick Start . . . . . . . . . . . . . . . . . . . . . . . . . . . .  5
  1583.      RTS/CTS handshaking . . . . . . . . . . . . . . . . . . . . . . . .  2
  1584.      Seiko Smart Label Printer . . . . . . . . . . . . . . . . . 15, 17, 18
  1585.      Serial Printer  . . . . . . . . . . . . . . . . . . . . . . . . . . 23
  1586.      SIO Chips . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
  1587.      SIO Technical Reference Manual  . . . . . . . . . . . . . . . . . .  i
  1588.      SIO's Utility (SU.EXE)  . . . . . . . . . . . . . . . . . . . . . .  9
  1589.      SIO_Mode_DTR  . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
  1590.      SIO_Mode_FIFO_Load_Count  . . . . . . . . . . . . . . . . . . . . . 17
  1591.      SIO_Mode_IDSR . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
  1592.      SIO_Mode_OCTS . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
  1593.      SIO_Mode_ODSR . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
  1594.      SIO_Mode_RTS  . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
  1595.      SIO_Mode_XON/XOFF . . . . . . . . . . . . . . . . . . . . . . . . . 16
  1596.      SIO_Screen_Sync_Kludge  . . . . . . . . . . . . . . . . . . . . . . 13
  1597.      SIO_Share_Access_With_OS/2  . . . . . . . . . . . . . . . . . . . . 12
  1598.      SLIP  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
  1599.      STB 4COM  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
  1600.      Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  3
  1601.      Telcor Tport  . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
  1602.      UART  . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
  1603.      Updates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  4
  1604.      VDD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .  2
  1605.      VIEWPMLM.EXE  . . . . . . . . . . . . . . . . . . . . . . . . . . .  9
  1606.      Virtual Device Driver . . . . . . . . . . . . . . . . . . . . . . .  2
  1607.      Virtualize_16550A_For_COM . . . . . . . . . . . . . . . . . . . . . 12
  1608.      Virtualize_COM_Ports  . . . . . . . . . . . . . . . . . . . . . . . 12
  1609.      WHAT IS SIO . . . . . . . . . . . . . . . . . . . . . . . . . . . .  1
  1610.      WHAT IS VSIO  . . . . . . . . . . . . . . . . . . . . . . . . . . .  2
  1611.      WinFax  . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21, 23
  1612.