-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathREADME.TXT
161 lines (111 loc) · 6.2 KB
/
README.TXT
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
mTCP Source Code Readme
2013-04-26 Version
Home page: http://www.brutman.com/mTCP
Google Project Hosting: http://code.google.com/p/mtcp/
Introduction
Welcome!
If you are reading this you have probably already seen some of the
applications and are interested in modifying something or starting
a new application. This readme will be helpful in getting you started.
Project goals
The primary goal of the project is to bring the joy of TCP/IP
networking to older IBM PC compatible machines. These machines
include the original IBM PC from 1981 and everything derived
from it and relatively compatible with it.
Design decisions need to be carefully made to ensure that the right
mix of features is included. The target machines are small and
constrained in many ways, so features like large TCP windows and
exotic options are never even going to be considered. In general
the 80/20 rule is a good guide - most people can live happily with
80% of the features, while the other 20% of the features are probably
not needed.
Performance is important; an application that is slow enough to make
a user gripe will not be used more than once. The 80/20 rule applies
here as well - 20% of the code probably is responsible for 80% of the
performance, so make that 20% run well and keep the rest clean and
easy to maintain.
And finally, the code has to be stable. Nobody wants to deal with
data corruption or a system that crashes or malfunctions. DOS is
a challenging environment to work in because there are so many ways
to trash the machine. Code defensively and test extensively.
Target machines
As noted above the target machines are everything from the IBM PC 5150
to current day virtual machine environments. That means that we are
dealing with classic 16 bit x86 code. Examples include:
IBM PC, PC XT, AT, PCjr, Convertible, PS/2 series, etc.
Clones ranging from x86 machines to Pentiums IVs
DOSBox running under Windows (requires a special build w/ networking)
Windows XP DOS window with SwsVPkt
VirtualBox and VMWare Player
If it runs DOS or something like DOS and it has Ethernet, then mTCP
should be able to run on it.
I didn't target machines with small memories. Most of the applications
can run on a 256K machine, but more memory makes things easier and gives
you room to improve performance. There are other TCP/IP stacks you can
use if you are targeting 64KB or 128KB machines.
One important assumption that mTCP makes is that you are using
Ethernet. All of the data structures leave room for an Ethernet
header and the stack assumes that you are using ARP to find other
machines on the network. Packet drivers that emulate Ethernet but
use other underlying technology should be fine. (The most common
example of this would be SLIP and PPP packet drivers using serial
ports.) Porting to other networking technologies (Token Ring,
IBM Cluster, etc.) is possible but not done yet.
Code structure
There are two major parts to mTCP - the TCP/IP code and the
applications.
The TCP/IP code is built into each application. Instead of creating
one library that does everything each application links against
the individual OBJ files. It is basically the same as a library
structure, but the library gets customized for every application.
The base TCP/IP code is not expected to change often, and it could
be built and packaged as a library if desired.
Each application is a stand-alone unit from the other applications.
Each application configures the TCP/IP features that it needs using
#defines, and links directly to the TCP/IP code.
I chose the "customized library" approach for the following reasons:
- Each application can configure TCP/IP the way it needs to.
- Calls into the library are as fast.
- The approach is easy to understand
- It is easy to run the programs; you don't need a TSR anywhere
The disadvantage to this approach is that every application is carrying
around a lot of common code, which wastes space on disk. And you can
not interface arbitrary languages or programs to the TCP/IP code; you
have to compile and link against it. The TSR approach used by other
stacks makes the TCP/IP stack more available to other languages, but
at the cost of performance and stability.
Compilers
I started the mTCP project using Borland's Turbo C++ for DOS version 3.0.
It worked well enough for a few years but I decided to look for a
compiler that produced better code. (The code generation of that
compiler is very simplisted.) I settled on Open Watcom 1.8 and ported
all of the code to it.
Initially I maintained the code so that it would build in both
environments. I have since abandoned that strategy and have moved
exclusively to Open Watcom. It would be possible to make things
compile and run under Turbo C++ but that requires a lot of extra work.
For now, plan on using Open Watcom 1.8 or 1.9. Ports to other
compilers are possible, but it might make a mess of the code with
#defines.
Open Watcom can be found at: http://www.openwatcom.org/index.php/Main_Page
File and Directory structure
README.TXT This file
COPYING.TXT The GNU General Public License, Version 3
APPS mTCP applications live in this directory. Each application
should have its own subdirectory.
DEVDOCS Implementation notes
INCLUDE Includes that might be useful across multiple applications
TCPINC Includes for the TCP/IP library
TCPLIB Code for the TCP/IP library
USERDOCS End user documentation for the mTCP applications
UTILS Useful programs, some of which are used in the build process
Future direction
I would like to spread the joy of DOS TCP/IP programming to more people.
Opening up this code should help that goal by enabling more people
to write applications, provide enhancements and help me fix bugs
and improve the code.
Send me your comments and questions. If things get busy enough I will
create a mailing list.
Enjoy!
Mike