Computing and Communications Services Office
University of Illinois at Urbana-Champaign
User Guide 402, March 1994
Kermit: a File Transfer Protocol, da Cruz, Digital Press, 1987
fdc@columbia.edu
It may be that Kermit is popular because it is a robust file transfer protocol suitable for almost any line or network conditions. It may be that Kermit is popular because it is available for pretty much any computer you can name (and a bunch that you can't). It may be that Kermit is popular because it is free. Or, it may be that Kermit is popular because of the (written) communications skills of Christine Gianone and Frank da Cruz.
As Kermit is both protocol and communications program, so this book is an introduction to computer communications, protocol specification, introduction to the Kermit implementations and programmers' reference guide, all rolled into one. An ambitious task, but one handled with grace and skill, in this instance.
Part one gives us the basics of the development of Kermit and of data communications from the user's perspective. This confirms that, yes, the name was inspired by the Jim Henson muppet character (or, more exactly, by a Muppets wall calendar). One hopes that Jim Henson approves of this memorial. Chapter two does not get into exhaustive detail on computer (mostly PC) communications, but does cover the fundamental steps and needs with more brevity, completeness and wit than one sees in many works intended for the mass market. (I am sorry to see the confusion of "baud" and "bits per second", although the two terms are correctly defined in the glossary.)
Part two gives us two primers; one on computers and data files, and the other on data communications. The section is well named. Both chapters are easily understood by the novice and provide the minimum necessary information to proceed from. Excellent pieces, both of them.
Part three is an introduction to using Kermit. Chapter five describes a set of the most commonly used commands, including an introduction to the simplest login scripts. Chapter six discusses common problems while seven deals with the possibly thorny issue of getting Kermit into your machine in the first place. Included in this last chapter is a BASIC source code program for a "read only" Kermit protocol for downloading files.
Part four is a guide to writing a Kermit implementation. Quite a complete guide: not only does it give you the protocol specification (which is still *the* protocol specification) but also optional features, advanced options and even tips on programming style. Appendices give you the bulk of the Kermit source code (in C), a command summary, packet summary, the ASCII character set and a discussion of binary, octal and hexadecimal numbers and notation.
If you want to build your own implementation of Kermit, this is the book for
you. If you care nothing for programming, and have only bought your computer
in order to "get online", this is the book for you, too. (Be sure to get
"Using MS-DOS Kermit," too.) (cf. BKUMSKMT.RVW) For those in between, this is
an excellent resource to have around to answer those "how does
DECUS Canada Communications, Desktop, Education and Security group
newsletters Editor and/or reviewer.
Kermit, A File Transfer Protocol, by Frank da Cruz (Digital Press
1987) ... describes, as
the title states, a file transfer protocol. It was invented at
Columbia University in 1981 to transfer large amounts of data and
files between various mainframes and personal computers. A year
later, it was presented to computer user-groups. Whoever wanted
Kermit received the programs, source code and documentation at no
charge.
This started the birth of a multitude of Kermit implementations.
Today, Kermit is available for most computers and is used worldwide...
The title doesn't tell you that the book describes more than just the
Kermit protocol. The 379 page book is divided into four parts and
five appendices with a glossary and reference section. It provides
valuable information to persons of all levels of expertise, from
administrators to programmers. It is structured in a tutorial
fashion, making it unnecessary to read the book from cover to cover.
Information on specific areas can be found in one place. The book
starts at a novice level and progresses at an even pace through
various technical levels.
For those with a casual interest, Part I consists of two chapters of
basic information. These describe the history behind Kermit, how to
obtain the software, what a protocol is, how to connect to other
computers, and how to transfer files. Interesting historical tidbits
and trivia lighten the subject and relax the novice reader. It
assumes no prior knowledge of data communications.
For an introduction to communications, Part II presents a
concepts-and-facilities style section contained in two chapters. This
is a detailed primer on files and data communications. If you want to
know about handshaking, flow control, parity and the like, read this.
It contains information dealing with hardware, file structure and
management, data representation and transmission, and networks. It
covers items from pin connections to 3705 controllers.
Part III is the Kermit user's guide. These three chapters serve as a
command reference guide to Kermit's features. Here you'll find
descriptions of the major Kermit commands along with how and why to
use them. Also described are common problems and their solutions.
These are grouped by category, such as connection, data translation,
and file transfer difficulties.
Also included in this section is a discussion on bootstrapping. Once
you receive Kermit on tape, it is uploaded to the mainframe. You must
then get the programs to your PC to complete the installation. This
chapter provides the source code in Microsoft BASIC to do just that.
It is surprisingly short, only 83 lines of code, and is referred to by
the author as "the baby Kermit program". It actually uses Kermit to
receive the initial Kermit files! Following the program source code
is a detailed explanation of what function each section of the code
performs. It even explains how to bootstrap in the other direction,
from a PC to a remote mainframe. At the end of this section, da Cruz
bids farewell to the nontechnical reader with closing comments
expressing his hope that this material will help make you a
"self-sufficient creator and user of reliable data communication
links", and to that end he is successful.
The technically oriented Part IV serves as a programmers guide to
Kermit. This is the longest section, consisting of six chapters. The
first chapter discusses how to write a Kermit program. It covers
items from programming style to outlining the steps necessary in order
to contribute a program to the Kermit family of software.
The next chapter describes basic file transfer, concentrating
primarily on Kermit packets and layered protocol. A packet is a piece
of the file transfer process, or transaction. These transactions
include send initiation, data transfer, end of file notification,
receipt acknowledgement, and error notification.
Layered protocol is a method by which the process of receiving files
is broken down into functions. These functions control character
translation, ensure data integrity, and perform hardware specific
requirements. Packets are passed between these layers of function,
and each layer extracts information pertinent to itself, passing other
parts of the packet along as required. A detailed discussion of the
7-layer ISO Open Systems Interconnection (OSI) Reference Model, and a
comparison to similar Kermit processes, is provided.
The third chapter in this section describes 8-bit data transfer
through 7-bit communications media. It includes information on data
encoding and compression, as well as how to gracefully interrupt a
file transfer. There are several programming examples written in C
that perform some of the functions.
The next two chapters describe the basis for a Kermit client/server
relationship and advanced options. These are followed by a discussion
and analysis of the Kermit protocol, implementation tricks, and a
comparison of Kermit to other file transfer protocols.
Appendixes provide more programming examples, a Kermit command
summary, a Kermit packet summary, the ASCII character set in detail,
and a discussion of binary, octal, and hexadecimal numbers.
In summary, the book provides a complete reference guide to Kermit and
its current implementation. It is well written in a lighthearted and
non-condescending manner. Most diagrams are hand-scribed, giving it a
notebook style. Even if you don't use Kermit, if you're at all
interested in what goes on in the elusive process of one computer
'talking' to another, I highly recommend this book. By the way, in
case you're wondering if there is any relationship between Kermit and
the popular frog, you'll have to read the book. Hint -- the cover is
green.
Copyright Robert M. Slade, 1993
ROBERTS@decus.ca
BKKERMIT.RVW 931123
"Kermit, A File Transfer Protocol, by Frank da Cruz (Digital Press,
1987), will satisfy your appetite if you wish to learn more about this
fascinating protocol than is covered here. KERMIT is laced with green ink,
light-hearted analogies, and drawings which are often as amusing as they are
illustrative. It is also exceptionally well-written and full of sound
information. If you want to study every detail of Kermit, this book is the
best reference known to me; should you be implementing the protocol, note that
the text includes a large section specifically about writing Kermit, with most
of the C code that you'll need. I also highly recommend da Cruz' text for
anyone designing a file transfer protocol."
Pete Maclean, Desktop Communications with IBM Personal Computers, Wiley,
1987.
Review of Kermit -- A File Transfer Protocol
This review appeared in the October 1988 issue of V/UPDATE,
the VM Systems Group Newsletter. It may be quoted with attribution.
All There Is To Know About KERMIT
Tom Kumpf
Kermit Documentation / Columbia University / kermit@columbia.edu / 18 Dec 95