home *** CD-ROM | disk | FTP | other *** search
/ Beijing Paradise BBS Backup / PARADISE.ISO / software / BBSDOORW / IZM110.ZIP / IZM.DOC < prev    next >
Encoding:
Text File  |  1995-05-15  |  36.3 KB  |  736 lines

  1.                  IceZmodem File Transfer Protocol Documentation
  2.  
  3.                                By Alan Caruana
  4.  
  5.                       Copyright (C) 1995 IceSoft Software
  6.                               All Rights Reserved
  7.  
  8.                         Documentation for Version 1.1
  9.  
  10.    Mail:  IceSoft Software       E-Mail: IceNET......: 3@1 or 1@3
  11.           215 Labelle Ave.               WWIV/WW4net.: 3@12194
  12.           Blasdell, NY 14219             Internet....: Icefreez@localnet.com
  13.  
  14.                 IceSoft Software Support BBS: (716) 823-0424
  15.     Latest version of IceZmodem always online, access on your first call
  16.  
  17.  * Order IceZmodem with your Mastercard or VISA, call voice (716) 823-5280 *
  18.  
  19. ----------------------------< Table of Contents >-----------------------------
  20.  
  21.  Introduction...:  1. Shareware Notice
  22.                       License
  23.  
  24.                    2. Disclaimer
  25.                       Description
  26.  
  27.                    3. What is included
  28.                       Distribution
  29.                       Getting Started
  30.  
  31.  IceZmodem Usage:  4. The IceZmodem Command Line
  32.  
  33.                    6. Hardware Requirements
  34.                       The IZMSETUP Program
  35.  
  36.                    7. IceZmodem Functions
  37.  
  38.  You Should Know: 10. TurboTrans
  39.                       Handshaking
  40.  
  41.                   11. The 16550A UART
  42.                       Acknowledgements
  43.  Appendixes.....:     Appendix A: Freeing Your Memory
  44.  
  45.                   12. Appendix B: Error Messages
  46.  
  47.                   13. Appendix C: IceZmodem Command Line Examples
  48.                       Appendix D: Performance
  49.  
  50.                   14. Appendix E: Revision History
  51.  
  52. --- PAGE 1 -----------------< Shareware Notice >------------------------------
  53.  
  54.  IceZmodem is distributed as an unregistered shareware product. This means
  55.  that an unregistered copy of IceZmodem may be freely distributed to any
  56.  individuals, businesses or organizations for evaluation purposes to decide
  57.  if the product is worth purchasing. If you like IceZmodem and decide to use
  58.  it, you must register (purchase) it. IceZmodem is NOT free software!
  59.  
  60.  Using this shareware system, you will be able to try out the software before
  61.  you make a commitment to purchase it. If you have paid any money for this
  62.  program, it has gone to the distributor of the program and not to IceSoft
  63.  Software.
  64.  
  65.  BENEFITS OF REGISTRATION (Purchase)
  66.  """""""""""""""""""""""""""""""""""
  67.  Registration costs only $25 and will remove all annoying screens and sounds
  68.  and will enable enhanced features such as extended system information and
  69.  other future features. You also get telephone technical support. The best
  70.  part is, $25 will register this and ALL future versions of IceZmodem. You
  71.  will NEVER have to pay for an upgrade! To register, print the file
  72.  REGISTER.FRM or send a check or money order of $25 to:
  73.  
  74.                                 IceSoft Software
  75.                                 215 Labelle Ave.
  76.                                 Blasdell, NY 14219
  77.  
  78. ---------------------------------< License >----------------------------------
  79.  
  80.  IceZmodem, although it is on this computer, is not the property of the owner
  81.  of the computer. It is the property of IceSoft Software. It may be freely
  82.  distributed as long as all files are intact in the original ZIP package.
  83.  This distribution is for evaluation purposes only. Once it is established
  84.  that the operator of the computer is going to use IceZmodem continuously,
  85.  it must be registered. This applies to home, school, business or government
  86.  use.
  87.  
  88.  An UNREGISTERED VERSION (as freely distributed) may be shared freely.
  89.  
  90.  A REGISTERED VERSION of IceZmodem may NOT be distributed. A registered
  91.  version is for use on only ONE computer and may not be shared freely.
  92.  
  93.  If this program is to be used on more than one computer (such as in a
  94.  school or business) then the copies should be purchased in volume or a
  95.  site license should be obtained. Please contact IceSoft Software for more
  96.  information on volume discounts and site licenses.
  97.  
  98. --- PAGE 2 --------------------< Disclaimer >--------------------------------
  99.  
  100.  IceSoft Software is not responsible for any damages to your computer as a
  101.  result of using (or inability to use) IceZmodem. This includes loss of data,
  102.  files, and disk drives. This also includes loss of profit, savings and other
  103.  various damages aroused by the use of IceZmodem.
  104.  
  105.  IceZmodem is thoroughly tested on a variety of computer platforms before
  106.  beta or initial release to perform as stated in the documentation. However,
  107.  no warranty or guarantee may be stated due to the varying hardware systems
  108.  the software will run on.
  109.  
  110. -------------------------------< Description >--------------------------------
  111.  
  112.  IceZmodem is a 100% Zmodem compatible external file transfer protocol with
  113.  several enhancements that will increase your productivity while transfering
  114.  files and make the file transfer process less boring:
  115.  
  116.             * You can chat with the remote user during the file transfer.
  117.  
  118.             * You can shell to DOS and execute DOS commands and programs.
  119.                        (transfer pauses while programs are executed)
  120.  
  121.             * You can edit text files during the file transfer.
  122.  
  123.             * You can play MOD digital music files through a Sound Blaster,
  124.               DAC, or PC Speaker.
  125.  
  126.             * You can get 2 pages of system information about the remote
  127.               computer that you are transfering files with.
  128.  
  129.             * You can play built-in arcade games during the file transfer.
  130.  
  131.  It doesn't end here! IceZmodem also boasts:
  132.  
  133.             * A Screen Saver which shows, in large numbers, the percentage
  134.               the transfer has completed.
  135.  
  136.             * TurboTrans, a Zmodem speed booster which has helped to get
  137.               peaks of 99% efficiency during some file transfers.
  138.  
  139.             * Maximum Block size of 6144 bytes, compared to the standard
  140.               Zmodem maximum size of 1024 bytes.
  141.  
  142.             * An option for BBS Sysops to view information within their
  143.               BBS dropfile.
  144.  
  145.             * One of the most informative status displays found on any
  146.               file transfer protocol.
  147.  
  148. --- PAGE 3 ----------------< What is included >------------------------------
  149.  
  150.    IZM.DOC      - The IceZmodem documentation you are reading now
  151.    IZM.EXE      - The actual IceZmodem protocol
  152.    IZMSETUP.EXE - The setup program which reads/writes the configuration to
  153.                   IZM.EXE.
  154.    INSTALL.DOC  - A text file that explains how to set up IceZmodem with
  155.                   many popular BBS systems and terminal programs.
  156.    REGISTER.FRM - A text file that you can print out to simplify registration
  157.                   of IceZmodem
  158.    IZM-U.BAT,
  159.    IZM-D.BAT    - Batch files for uploading and downloading files using
  160.                   IceZmodem. These batch files will work with most terminal
  161.                   programs, however you may need to modify the batch file.
  162.                   (Refer to INSTALL.DOC for more information)
  163.  
  164. -------------------------------< Distribution >-------------------------------
  165.  
  166.  The unregistered version of IceZmodem may be freely distributed unmodified
  167.  in its original ZIP package. You may charge a fee of no more than $5 for
  168.  distribution costs of IceZmodem. IceZmodem may not be bundled with any
  169.  hardware or software unless written permission is obtained from IceSoft
  170.  Software. IceZmodem program code and IceZmodem setup program may not be
  171.  edited, modified, disassembled or reverse-engineered by any means
  172.  whatsoever. IceZmodem documentation may not be modified, reproduced, edited
  173.  or translated by any means whatsoever.
  174.  
  175. -----------------------------< Getting Started >------------------------------
  176.  
  177.  IceZmodem can easily be configured to work with any BBS or terminal program.
  178.  The command lines that are used to operate IceZmodem are similar to the
  179.  popular DSZ external protocol. INSTALL.DOC contains instructions on how to
  180.  set up IceZmodem with many popular BBS and terminal programs. Refer to this
  181.  file now if you do not know how to get started with your particular BBS or
  182.  Terminal program. Also, be sure to run IZMSETUP.EXE! (see page 6)
  183.  
  184. --- PAGE 4 -------------< The IceZmodem Command Line >------------------------
  185.  
  186.                IZM [OPTIONS] <File Transfer Type> <File/Pathname>
  187.  
  188.  OPTIONS    (See Appendix C for examples on using IceZmodem)
  189.  """""""
  190.    O    -  Put O on the the command line by itself to switch IceZmodem
  191.            into offline mode. This will let you use IceZmodem features
  192.            without having a modem connection.
  193.  
  194.    port - This tells IceZmodem what COM PORT you would like to communicate
  195.           with. It can be any value from 1 to 4.  You do not need to specify
  196.           the port if you have already set up your default port in IZMSETUP
  197.           and the default port is the one you would like to use. Specifying
  198.           this option will override your default port in IZMSETUP, but it
  199.           will NOT override your default address/IRQ nonstandard port in
  200.           IZMSETUP.
  201.  
  202.            * Do not use the PORT option combined with the adrirq option *
  203.  
  204.           Below are the standard addresses and IRQs that IceZmodem recognizes
  205.           when you specify the port command. If your address/IRQ is different
  206.           than these, you need to use the adrirq option or set up your
  207.           default address/IRQ in IZMSETUP.
  208.  
  209.                            PORT 1:  Address 3F8   Irq 4
  210.                            PORT 2:  Address 2F8   Irq 3
  211.                            PORT 3:  Address 3E8   Irq 4
  212.                            PORT 4:  Address 2E8   Irq 3
  213.  
  214.    **** EXAMPLE FOR PORT: IZM port 2
  215.  
  216.  adrirq -  This tells IceZmodem the ADDRESS and the IRQ of your NONSTANDARD
  217.            COM PORT if you have one. If upon examining the chart above, you
  218.            do not find your port address/IRQ, you use this command to specify
  219.            the address/IRQ of your port. It uses the syntax:
  220.  
  221.                             adrirq address,irq
  222.  
  223.            This option will override the address/IRQ you specify in IZMSETUP
  224.                   * DO NOT USE ADRIRQ COMBINED WITH THE PORT OPTION *
  225.  
  226.    **** EXAMPLE FOR ADRIRQ: IZM adrirq 3F8,4
  227.  
  228.  speed  - This tells IceZmodem the speed (bits per second) that the COM PORT
  229.           is operating at. If this option is not specified, IceZmodem will
  230.           assume that the COM PORT is already set at the proper speed (which
  231.           it always should be before IceZmodem is executed) and should work
  232.           properly.
  233.  
  234.    **** EXAMPLE FOR SPEED: IZM port 2 speed 2400
  235.  
  236. --- PAGE 5 ------------------------------------------------------------------
  237.  
  238.  node   - If you are running a multi-node BBS and you have specified the
  239.           location of your BBS dropfile in IZMSETUP with the * macro, you
  240.           must use this command line to tell IceZmodem what node you would
  241.           like to replace the * macro with.
  242.  
  243.    **** EXAMPLE FOR NODE: IZM port 2 speed 38400 node 5 rz C:\BBS\UPLOADS\
  244.  
  245.    flow - After the word flow, you may use SLOW or HARD. Specifying SLOW
  246.           will cause IceZmodem to stop the sender from sending data during
  247.           disk writes. This is good if the receiver is writing the file to
  248.           a floppy disk or a slow hard disk. Specifying HARD will turn the
  249.           hardware handshaking on. This means if the sender is sending data
  250.           too fast and the receiver can't keep up, the receiver will tell the
  251.           sender to stop sending data until the receiver catches up. ALL high
  252.           speed modems MUST use flow hard.  These options override the
  253.           defaults that you specify in IZMSETUP.
  254.  
  255.           To make this plain and simple, if the receiver is writing to a slow
  256.           hard disk or floppy disk, you MUST use flow slow. If you are using
  257.           greater than 2400 bps, you MUST use flow hard.
  258.  
  259.           You may combine both flow slow and flow hard. See below:
  260.  
  261.      **** EXAMPLE FOR FLOW: IZM port 2 speed 2400 flow slow
  262.      **** EXAMPLE FOR FLOW: IZM speed 19200 flow hard
  263.      **** EXAMPLE FOR FLOW: IZM speed 38400 flow slow flow hard
  264.  
  265.    page - Use either PAGE ON or PAGE OFF to allow the remote to page you with
  266.           a loud beep or not. This will override your default selection in
  267.           IZMSETUP. If PAGE OFF is specified, the screen will flash on and
  268.           off instead of making an audible noise.
  269.  
  270.  File Transfer Type
  271.  """"""""""""""""""
  272.      RZ - Use this to receive data. If you do not specify anything after the
  273.           RZ, all files received will go into the current directory. After
  274.           the RZ you may specify a pathname and/or a filename. If a pathname
  275.           is specified, all files will go into that directory. If a filename
  276.           is specified, all received files will be renamed to that filename.
  277.           If a pathname AND filename is specified, all files will go into
  278.           that path and be renamed to the filename specified.
  279.  
  280.      SZ - This is the command to send data. This command must always be
  281.           followed by either:
  282.  
  283.                   A filename: SZ program.zip
  284.                   A pathname: SZ c:\bbs\dloads\sysop\program.zip
  285.                   Many Names: SZ program.zip c:\bbs\log.txt a:\program.exe
  286.                   Wildcards : SZ *.zip
  287.                   File Lists: SZ @file.lst
  288.  
  289. --- PAGE 6 ------------------------------------------------------------------
  290.  
  291.           OR a combination of ANY of the above things. The File List at the
  292.           end is an @ sign followed by a filename. In this file is a list of
  293.           path/filenames to send - one on each line of the file.
  294.  
  295.               For example, if the file LIST.TXT contained the following:
  296.                               \PROGRAMS\QUADL10.ZIP
  297.                               \BBS\DLOADS\SYSOP\MAIL.ZIP
  298.                               IZM110.ZIP
  299.                 ...You could send all 3 of those files with the line:
  300.                          IZM port 1 speed 2400 sz @list.txt
  301.  
  302.    Environment Variables
  303.    """""""""""""""""""""
  304.    If you set the environment variable DSZLOG equal to a filename, IceZmodem
  305.    will create a DSZ-compatible log for programs which require it to run.
  306.                   Example: SET DSZLOG=C:\BBS\DSZLOG.TXT
  307.  
  308. ----------------------------< Hardware Requirements >-------------------------
  309.  
  310.    Processor: 8086 or better. You will need at least an 80286 to use the
  311.               Digital MOD Music or to utilize 16800+ bps reliably.
  312.  
  313.    DOS......: Version 3.0 or better. Any earlier versions will not work.
  314.               IceZmodem will work perfectly under DesqView, OS/2, Windows
  315.               95 and to a lesser degree - Windows 3.1. However some features
  316.               (such as MOD player) will not work.
  317.  
  318.    Memory...: At least 200k to transfer files. To play music, edit text files
  319.               and shell to dos, you must have from 200k-300k. This amount of
  320.               memory must be present on top of all the other memory taken by
  321.               terminal programs or BBS systems. (See Appendix A for
  322.               information on gaining more memory)
  323.  
  324.    Display..: Any display will work, but a color monitor is highly
  325.               recommended.
  326.  
  327.    Optional.: Sound Blaster, Disney Sound Source, or a parallel port D/A
  328.               converter for best sounding Digital Music.
  329.  
  330. ----------------------------< The IZMSETUP Program >--------------------------
  331.  
  332.  The IZMSETUP program included with the IceZmodem package lets you set up
  333.  many of the default options in IceZmodem and sets several options which are
  334.  not adjustable anywhere else in the program. I recommend that you run the
  335.  IZMSETUP.EXE program when you first install your IceZmodem and whenever you
  336.  upgrade to a newer version of IceZmodem. The configuration options are
  337.  stored within the IZM.EXE file itself - eliminating the need for more files
  338.  cluttering up your hard disk and causing more headaches. The only problem
  339.  with this is that you will need to run IZMSETUP whenever you receive an
  340.  IZM.EXE upgrade.
  341.  
  342. --- PAGE 7 --------------------------------------------------------------------------
  343.  
  344.  When you first execute IZMSETUP, it will want to know where the IZM.EXE
  345.  file is located. If it is in the current directory, simply hit enter
  346.  otherwise tell it where it is. I am not going to document each option in
  347.  IZMSETUP because there is already documentation within the program. I
  348.  suggest that you go through each option and read what each option does and
  349.  choose wisely to get the best performance and reliability out of IceZmodem.
  350.  
  351. -----------------------------< IceZmodem Functions >--------------------------
  352.  
  353.  Alt-A - Abort File Transfer
  354.  """""""""""""""""""""""""""
  355.     This will abort the file transfer and return an Exit Code of 1.
  356.  
  357.  F1 - Main Screen
  358.  """"""""""""""""
  359.     The main screen is the heart of IceZmodem. Here you will see how the
  360.     transfer is progressing by the numerous indicators and graphs.
  361.  
  362.   Download/Upload Status Window
  363.   """""""""""""""""""""""""""""
  364.     Block Size - This is the number of bytes that are transferred before a
  365.                  checksum takes place. The greater this number, the more
  366.                  efficient the transfer will be. IceZmodem uses up to 6144
  367.                  byte blocks when connected to another IceZmodem. You may
  368.                  increase this number in IZMSETUP. Whatever block size that
  369.                  the SENDING compiter has specified is what will be used.
  370.  
  371.     CPS - This stands for characters per second, how efficient your file
  372.           transfer is going. Please be aware that this is an estimate and
  373.           is NOT very accurate. The actual CPS is usually a bit higher.
  374.  
  375.     TurboTrans - This tells wether TurboTrans is in use or not. (See page 10)
  376.  
  377.       Messages - Information about the transfers progress and remote user
  378.                  status appears here.
  379.  
  380.     Completion - A graph and a percentage that tells how complete the file
  381.                  transfer is.
  382.  
  383.         Method - Usually CRC-32 or CRC-16. Tells what method of CRC is being
  384.                  used to check each block. The CRC-16 method is barely
  385.                  faster and offers half the protection against data errors.
  386.  
  387.     Efficiency - A percentage that will tell how efficient the transfer is
  388.                  going. 99% is the highest ever obtained with IceZmodem. If
  389.                  you are using locked com ports, this feature will read N/A.
  390.  
  391. --- PAGE 8 ------------------------------------------------------------------
  392.  
  393.       Time Total - IceZmodem analyzes the rate of characters comming in to the
  394.                  computer to predict the total time of the transfer, giving
  395.                  IceZmodem very accurate total time prediction.
  396.  
  397.     Batch Status Window - This window contains the same as above with the
  398.                           exception that the Batch is the information on
  399.                           all the files you are transferring if you are
  400.                           transferring multiple files.
  401.  
  402.       User Status Window
  403.       """"""""""""""""""
  404.            User - The name of the person who is operating the IceZmodem
  405.            Regs - Their registration name (if registered)
  406.            Vers - The version of Zmodem or IceZmodem being used
  407.  
  408.  F2 - Chat
  409.  """""""""
  410.      You may chat with the remote user on this screen. If they are not in
  411.      chat, hit F10 to page them. When somebody is paged in IceZmodem, either
  412.      a beeping noise will come out their speaker or (if the page is turned
  413.      off) the screen will flash. Once both people are in chat, just type a
  414.      sentence and hit enter. The message will appear in the upper window.
  415.  
  416.  F3 - DOS Shell
  417.  """"""""""""""
  418.      Using DOS Shell, you may execute any DOS commands or small programs
  419.      without greatly disturbing the transfer. Whenever you execute a
  420.      command or program in the DOS Shell, the file transfer temporarily
  421.      stops and then resumes when the prompt reappears. Knowing this,
  422.      you can execute small commands like DIR, RENAME, DEL, COPY, etc. and
  423.      the transfer wouldn't be harmed at all. You can load small utility
  424.      programs as well providing you dont remain in them for too long.
  425.      I wouldn't recommend staying in any executable file for more than
  426.      15-25 seconds. Especially if you are paying for long distance charges.
  427.      IceZmodem DOS Shell does not multitask. You cannot load up your favorite
  428.      text editor and expect the transfer to continue. There will be a certain
  429.      point where the buffer can no longer hold the incoming data and you
  430.      will loose data. This wont affect the file you are transfering.
  431.  
  432.  F4 - Screen Saver
  433.  """""""""""""""""
  434.      This will print the percentage complete in large numbers on a black
  435.      screen. To exit it, hit F1-F7.
  436.  
  437. --- PAGE 9 ------------------------------------------------------------------
  438.  
  439.  F5 - Text Editor
  440.  """"""""""""""""
  441.      This is a simple text editor that I threw in at the last minute to see
  442.      if it could be done. There are some bugs in the text editor and I am
  443.      going to completely re-write the text editor in a future version.
  444.      Select a file to load. If you wish to create a new file, hit T and then
  445.      type in a filename. If you get an error message, refer to Appendix B.
  446.      The text editor can currently only load files 64k or less. The file must
  447.      not contain more than 78 characters per line. When you are done editing
  448.      the file, hit F9 to save it. If you dont want to save it, hit F8 to
  449.      unload the text file. You must either save or unload the text file
  450.      before IceZmodem will exit when the transfer is complete.
  451.  
  452.  F6 - Module Player
  453.  """"""""""""""""""
  454.      The Module Player will play Amiga Digital MOD music files. These should
  455.      be available on one of your local BBSs or any information service. They
  456.      are quite popular on many platforms these days, especially on the PC.
  457.      You may play the files using a PC Speaker, a D/A converter, a Sound
  458.      Blaster, or a Disney Sound Source. The PC Speaker provides very poor
  459.      sound reproduction and some sort of additional hardware is required to
  460.      hear true high fidelity sound. Assuming you have enough memory and you
  461.      have correctly configured your sound device and sampling rate in
  462.      IZMSETUP, you will now be able to select a file to play. If you get an
  463.      error message, refer to Appendix B. You may adjust the MOD volume, turn
  464.      channels 1,2,3,4 on and off and skip forward/backward in the song while
  465.      it is playing. You can go to any of the other functions in IceZmodem
  466.      and the MOD will continue playing (the sound will stop during DOS Shell)
  467.      including System Info, text editor and Chat. The MOD Player may not work
  468.      properly with LANtastic software or other Local Area Network Operating
  469.      Systems.
  470.  
  471.  F7 - System Information
  472.  """""""""""""""""""""""
  473.      This will present a page or two of system information about the local
  474.      and remote computers. Find out what kind of computer that guy REALLY is
  475.      using. Great for online technical support. Registered users can also
  476.      view the remote device drivers, TSRs, and open file handles. Future
  477.      versions may be expanded in this area even further.
  478.  
  479.  F8 - Games
  480.  """"""""""
  481.      Just for fun, this will give you something to do during the transfer!
  482.      Speedboat Willy is a simple game where you use the left and right arrow
  483.      keys to avoid the bouys and other obstacles comming at you as you speed
  484.      down the river. There are four waves, if you complete the first group of
  485.      four waves you will go back to wave 1, although the game will be faster
  486.      this time! Good luck. WARNING: Excessive playing of this game will make
  487.      the room look like it is elevating when the game ends! SpaceShooter is
  488.      a simple but fun shoot-em-up. The instructions are in IceZmodem!
  489.  
  490. --- PAGE 10 -----------------------------------------------------------------
  491.  
  492.  F9 - User Screen
  493.  """"""""""""""""
  494.      If you are a sysop of a BBS and have told IceZmodem the filename of
  495.      your BBS dropfile in IZMSETUP, you may view your BBS dropfile using
  496.      this option. If you have used the * macro in the path/name, be sure
  497.      you are using the node option on the command line!
  498.  
  499. --------------------------------< TurboTrans >--------------------------------
  500.  
  501.   TurboTrans is a Zmodem speed booster which will enhance the efficiency of
  502.   your file transfer from 2 to 5 percent over standard Zmodem. It does this
  503.   by eliminating a 'feature' built into the original Zmodem standard. This
  504.   feature will not allow certain characters to flow through to avoid problems
  505.   with packet switching networks. These illegal characters must be sent as
  506.   TWO legal characters. This adds a decent amount of overhead to the file
  507.   transfer. When two IceZmodems are connected together they will usually be
  508.   connected by a direct modem connection, not a packet switching network.
  509.   Knowing this, IceZmodem will allow all but 2 characters to be sent through
  510.   as one character when TurboTrans is set to on. TurboTrans automatically
  511.   turns itself on when connected to another IceZmodem.
  512.  
  513. -------------------------------< Handshaking >--------------------------------
  514.  
  515.   There are thousands of different types of PCs out there, and along with
  516.   that, there are thousands of different speeds of PCs. Speed is dependant
  517.   on not only the processor and computer architecture, but also the software
  518.   that is running. For example, a memory manager slows down the speed of your
  519.   PC by a noticeable factor. Because modems allow us to hook faster PCs up
  520.   to slower ones, we need some way to let the slower PCs tell the faster
  521.   ones that they are sending data too fast for them to handle. That is
  522.   basically what Handshaking is. If the receiver cannot receive data as
  523.   fast as the sender is sending it, it has to tell the receiver to stop.
  524.   Handshaking is needed on ALL modems that run faster than 2400 bps. If
  525.   you use 2400 bps, you don't need to read this (now). If you are using
  526.   9600 bps or faster, you MUST understand handshaking. There are two
  527.   types of handshaking - hardware and software. All modems can use
  528.   software handshaking, but IceZmodem doesn't because it is inefficient
  529.   and adds overhead to the transfer, so lets ignore that for right now.
  530.   Hardware Handshaking. Most high speed modems transmit the CTS/RTS
  531.   (clear to send/request to send) signal on the phone line along with the
  532.   data that is being transmitted/received.  IceZmodem can manipulate this
  533.   signal to tell the sender to stop sending data when the receiver cannot
  534.   keep up. When the receiver catches up, it will resume the data
  535.   transmission. So, if you are using a high speed modem, BE SURE to set
  536.   HARDWARE HANDSHAKING to on - otherwise you will get a lot of errors
  537.   in the data transmission.
  538.  
  539. --- PAGE 11 ----------------< The 16550A UART >------------------------------
  540.  
  541.   If you are going to use over 9600 bps, I recommend you use a 16550A UART
  542.   chip. This will eliminate a lot of errors and problems you may have down
  543.   the road. You will be able to use over 9600 bps without a 16550A, but
  544.   in practice, it is not a good idea - especially on slower computers.
  545.  
  546. -----------------------------< Acknowledgements >-----------------------------
  547.  
  548.  IceZmodem as it is today would not have been possible without the code that
  549.  has been written by 1) the person who wrote the Source Code for Pascal
  550.  Zmodem. There was no author listed in the public domain code. 2) Mark J. Cox
  551.  who wrote the module playing routines. 3) Chuck Forsberg who developed the
  552.  original Zmodem protocol which is pretty much the standard protocol for
  553.  file transfers now. 4) TurboPower Software
  554.  
  555.  I would like to thank all Beta testers, including Jim Nunn, Mark Niedziela,
  556.  Yaser Behbehani, George Wheeler, and all others who have helped to make
  557.  IceZmodem what it is today. And for support from God, Mom, and all
  558.  IceZmodem users who support this product.
  559.  
  560. -----------------------< Appendix A: Freeing your Memory >--------------------
  561.  
  562.     IceZmodem is by no means a memory hog - however, when you load up a 200k
  563.     MOD file and a 50k text file and expect to shell to DOS you better have
  564.     a sufficient amount of memory available! If you dont have at least 400k
  565.     of free memory when you start up IceZmodem, your terminal program or BBS
  566.     program is chewing up all your memory. To get around this, set your
  567.     terminal program or BBS program to 'Maximum DOS Shell' or 'Shrink BBS' or
  568.     'Swap to Disk/EMS' or something to that effect. If your Terminal Program
  569.     or BBS doesn't support a shrink feature, tell the author to include one.
  570.     Most BBS and terminal programs have one nowadays anyway.
  571.  
  572. --- PAGE 12 -----------< Appendix B: Error Messages >------------------------
  573.  
  574. Error 45    This error means you are trying to tell IceZmodem to use both a
  575. """"""""    standard and a nonstandard COM port. You are probably using the
  576. PORT option on the command line when you already have an IRQ and ADDRESS set
  577. up in IZMSETUP. To get around this, set up a standard port in IZMSETUP and
  578. use the ADRIRQ option on the command line. Another cause of this problem
  579. is trying to use the PORT and ADRIRQ options at the same time.
  580.  
  581. Cannot load file. The file size is greater than 64k!
  582. """"""""""""""""""""""""""""""""""""""""""""""""""""
  583. The text editor is currently limited to editing files 64k or less. This will
  584. be corrected in a future version of IceZmodem.
  585.  
  586. Cannot load file. Line length is greater than 78 characters!
  587. """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""
  588. The text editor is currently limited to editing files with a line length of
  589. 78 characters or less. This will be corrected in a future version of
  590. IceZmodem.
  591.  
  592. You have reached the maximum text file size. No more data may be added!
  593. """""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
  594. You are attempting to add more than 64k of data to a large text file.
  595.  
  596. Not a valid ASCII text file!
  597. """"""""""""""""""""""""""""
  598. The text file cannot be parsed as a standard text file would. Either it is
  599. too intricate or it is not a text file.
  600.  
  601. Cannot LOAD or CREATE the filename you have specified!
  602. """"""""""""""""""""""""""""""""""""""""""""""""""""""
  603. An invalid filename has been specified. You may have accidentally typed in
  604. a pathname instead of a filename.
  605.  
  606. Not enough memory to load file
  607. """"""""""""""""""""""""""""""
  608. You must free up some memory by closing an open text file or turn off a MOD
  609. file. If nothing is open, then refer to Appendix A - suggestions for gaining
  610. more free memory.
  611.  
  612. Not enough memory to shell out to DOS!
  613. """"""""""""""""""""""""""""""""""""""
  614. You must free up some memory by closing an open text file or turn off a MOD
  615. file. If nothing is open, then refer to Appendix A - suggestions for gaining
  616. more free memory.
  617.  
  618. Not a 31 instrument MOD file!
  619. """""""""""""""""""""""""""""
  620. The MOD file that you are trying to load either 1) doesn't exist, 2) is not
  621. a MOD music file, or more commonly 3) Is an older 15 instrument MOD. If you
  622. run across a 15 instrument MOD, you will need to convert it to a newer 31
  623. instrument MOD before it can be played with IceZmodem. This can be done very
  624. easily with the program MODEDIT by Norman Lin. Simply load the MOD into this
  625. program (as if you were going to modify it) and then save it. The resulting
  626. save will be a 31 channel version of your older 15 channel MOD.
  627.  
  628. Can't Initialize Protocol (Error #8)
  629. """"""""""""""""""""""""""""""""""""
  630. IceZmodem doesn't have enough memory to install the 7k communications
  631. buffer. Just free up a few more kilobytes of conventional memory..
  632.  
  633. Disk Read Error (or the transfer aborts when you hit F7)
  634. """"""""""""""""""""""""""""""""""""""""""""""""""""""""
  635. Either there is something wrong with your disk drive or you do not have
  636. enough FILES specified in your CONFIG.SYS. Add the line FILES=25 to correct.
  637.  
  638. --- PAGE 13 ---------< Appendix C: Command Line Examples >-------------------
  639.  
  640.  
  641. IZM RZ  - Will open the COM port specified in IZMSETUP at the baud rate that
  642.           the port is currently at. It will then receive files and put them
  643.           in the current directory.
  644.  
  645. IZM port 1 speed 2400 RZ c:\downloads - Will open COM1 at 2400 baud and
  646.                                         receive files into the directory
  647.                                         C:\DOWNLOADS.
  648.  
  649. IZM port 2 SZ F.TXT F2.EXE C.COM - Opens COM2 at the current baud rate and
  650.                                    sends F.TXT, F2.EXE, and C.COM.
  651.  
  652. IZM SZ @FILE.LST - Opens the COM port specified in IZMSETUP at the current
  653.                    baud rate. It then opens the file called FILE.LST and
  654.                    reads the path/filenames stored within and proceeds to
  655.                    send all files.
  656.  
  657. IZM port 3 speed 9600 SZ *.EXE - Opens COM3 at 9600 baud and transmits all
  658.                                  the files ending with EXE.
  659.  
  660. IZM adrirq 3e8,2 RZ - Opens a nonstandard port located at address 3E8(hex)
  661.                       using IRQ 2. It then receives files into the current
  662.                       directory.
  663.  
  664. IZM port 2 speed 57600 flow hard SZ C:\UPLOADS\START???.EXE - Opens COM2 at
  665.             57600 baud and turns hardware handshaking on. It will then send
  666.             all EXE files in the directory C:\UPLOADS that begin with
  667.             START.
  668.  
  669. --------------------------< Appendix D: Performance >-------------------------
  670.  
  671.  On a 2400 bps modem connection, IceZmodem averages about 238 CPS with peaks
  672.  of 239 CPS on 80386 class systems transferring a maximally compressed ZIP
  673.  file.
  674.  
  675.  On a 14400 bps modem connection with the com ports locked at 38400 bps,
  676.  IceZmodem averages about 1640-1660 CPS on 80386 class systems transfering
  677.  a maximally compressed ZIP file.
  678.  
  679.  On a 57600 bps direct null-modem cable connection, IceZmodem averages
  680.  about 5300 CPS on 80386 class systems transferring a maximally compressed
  681.  ZIP file.
  682.  
  683. --- PAGE 14 ----------< Appendix E: Revision History >-----------------------
  684.  
  685.  6/1/1994  Version Beta1 - First public Beta Test Release
  686.  
  687.  7/08/1994 Version Beta2 - Second Beta Test Release (LIMITED RELEASE)
  688.                 BUGS - Corrected too many bugs to mention here (over 30)
  689.             FEATURES - Added large number percent complete in Screen Saver
  690.                      - Added extended system information
  691.                      - Improved CPS
  692.                      - Added Turbo Options
  693.                      - Added Overwrite/Recover/Don't transfer options
  694.  
  695.  7/09/1994 Version Beta3 - Fixed major bug in version Beta2 (LIMITED RELEASE)
  696.  
  697.  7/15/1994 Version Beta4 - Fixed major bug in version Beta3 (Public Release)
  698.  
  699.  7/27/1994 Version Beta5 - Fixed minor bugs in version Beta4 (Public Release)
  700.                          - Fixed Crash Recovery
  701.                          - Fixed Chat Screen Flash
  702.                          - Efficiency "N/A" with locked baud rates
  703.                          - Added Speedboat Willy Game
  704.                          - Added adjustable block size
  705.  
  706.  9/14/1994 Version Beta6 - **** NEW MODEM ROUTINES!
  707.                            Reliability/Stability Greatly Improved
  708.                            Now uploads to DELPHI work
  709.                            DesqView, OS/2, and Windows Time Slice Aware
  710.                            BBS Dropfile Support (F9)
  711.                            Offline Interactive Mode (O on the command line)
  712.                            BIOS Video Support
  713.                            Startup Screen Selection
  714.                            IRQ Rotation
  715.                            System Information Disabling Permitted
  716.                            16550A FIFO Trigger Level Select
  717.  
  718.  11/24/1994 Version 1.00 - First OFFICIAL Release
  719.                            Now works with Procomm Plus v2.01
  720.                            Now works with MajorBBS
  721.                            Doesn't "freeze" up anymore
  722.                            Searches other directories for duplicate files
  723.                            Reg Code Auto Save to IZM.KEY
  724.  
  725.   2/17/1995 Version 1.01 - (LIMITED RELEASE)
  726.                            Fixes function key lockup problems in v1.00
  727.  
  728.   2/20/1995 Version 1.02 -  Fixes Stack Overflow Error in v1.01
  729.                             Duplicate File Check now actually works!
  730.  
  731.   5/15/1995 Version 1.1  -  Added SpaceShooter Game
  732.                             Fixed file access problems
  733.                             Fixed TMP file deletion problems
  734.  
  735.   v1.5 which will be out soon will have all IceZmodem user suggestions
  736.                        installed! Look for it soon!