722 lines
40 KiB
Plaintext
722 lines
40 KiB
Plaintext
|
THE DEVELOPMENT OF DOS
|
|||
|
|
|||
|
Personal computers began appearing in the mid 1970's, initially as
|
|||
|
hobbyist toys that didn't even have keyboards or screens. The first
|
|||
|
real one, named Altair by a magazine editor's 12-year old daughter who
|
|||
|
liked a Star Trek episode that took place in that solar system, was
|
|||
|
built around a jazzed-up calculator chip, the Intel 8080.
|
|||
|
|
|||
|
Produced as a do-it-yourself kit by a company called MITS, it came with
|
|||
|
256 bytes of memory. Since it lacked a keyboard, you entered data by
|
|||
|
flipping switches on the front panel in binary sequence. Because it had
|
|||
|
no screen, you had to decode the patterns of blinking lights it
|
|||
|
produced. And it didn't let you store data permanently.
|
|||
|
|
|||
|
Two teenagers, Bill Gates and Paul Allen, who had started a company
|
|||
|
called Traf-o-Data to make Intel-based computers to measure how many
|
|||
|
cars ran across a rubber hose stretched across the road, saw a picture
|
|||
|
of the Altos on the cover of an electronics magazine and developed a
|
|||
|
version of BASIC for it. Gates upgraded AltairBasic later to include
|
|||
|
primitive file and disk-storage abilities.
|
|||
|
|
|||
|
The pair changed the comapny name to Microsoft; by 1976 the industry had
|
|||
|
progressed to the point where Gates was railing against software pirates
|
|||
|
(although back then pirates were making copies of punched paper tape
|
|||
|
rather than floppies). A few years later Gates became the worlds
|
|||
|
youngest billionaire.
|
|||
|
|
|||
|
Soon after the Altair introduction, some hard-driving salespeople became
|
|||
|
the market leaders with their Imsai 8080, another Intel-based machine,
|
|||
|
and the first computer aimed squarely at small businesses. To let users
|
|||
|
store data efficiently, Imsai developed a floppy disk drive whose motors
|
|||
|
and circuits were run by a program called CP/M (Control Program for
|
|||
|
Microcomputers), which had been licensed from Intergalactic Digital
|
|||
|
Research - later shortened to Digital Research. DR's Gary Kildall had
|
|||
|
created CP/M while working for Intel, to scale down the PL/1 programming
|
|||
|
language into a version that would fit on a microcomputer. Intel hadn't
|
|||
|
seen much value in this brand new CP/M thingy and had given Kildall all
|
|||
|
rights to it.
|
|||
|
|
|||
|
The early versions of DOS owe quite a bit to CP/M. In fact, things like
|
|||
|
the .COM formats of CP/M and DOS and the basic system calls were so
|
|||
|
similar that programmers could easily switch up from CP/M. CP/M uses a
|
|||
|
command interpreter called CCP (or Console Command Processor) and two
|
|||
|
fundamental system files called BDOS and BIOS to handle files and I/O.
|
|||
|
This arrangement is nearly identical to the DOS COMMAND.COM, IBMDOS.COM
|
|||
|
and IBMBIO.COM system trio. What was especially remarkable about CP/M
|
|||
|
was that it took up only 4k of space. DOS 1.0 doubled that and it has
|
|||
|
been mushrooming ever since.
|
|||
|
|
|||
|
Chain store magnate and leathercrafter Charles Tandy tried
|
|||
|
unsuccessfully to buy computers from Imsai, then ended up creating his
|
|||
|
own system, the TRS-80, which contained a Zilog Z-80 chip, 4096 bytes of
|
|||
|
memory, and came fully assembled rather than in a kit. To shave a few
|
|||
|
dollars off the price he designed it to work entirely in upper case
|
|||
|
letters. Customers snapped them up as fast as Tandy could make them.
|
|||
|
|
|||
|
What really kicked the microcomputer business into high gear, however,
|
|||
|
were a handful of visionary renegades from California and Florida.
|
|||
|
|
|||
|
In 1976 Steve Wozniak and Steve Jobs, whose early careers included a
|
|||
|
stint peddling "black box" devices to circumvent telephone toll billing
|
|||
|
computers, bought some 6502 chips and built a few hundred copies of a
|
|||
|
computer they christened the Apple I. It too worked only in upper case
|
|||
|
letters. Their second-generation Apple II offered an optional floppy
|
|||
|
disk drive, and sold several orders of magnitude more. On reason for
|
|||
|
its success was a revolutionary program called Visicalc. Visicalc
|
|||
|
turned Apple's little computer into a powerful financial analysis and
|
|||
|
planning machine.
|
|||
|
|
|||
|
But not all operating systems run on all chips. CP/M worked on the 8080
|
|||
|
and Z80 chips but not on Apples 6502.
|
|||
|
|
|||
|
Microsoft's Gates and Allen moved to Seattle to write programming
|
|||
|
languages for computers built around Intel and Zilog processor chips and
|
|||
|
running CP/M. Dismayed that their languages woudln't work on Apples,
|
|||
|
they considered translating them all to run on Apples proprietary
|
|||
|
operating system, an arduous job. Instead they joined the crowd,
|
|||
|
licensed CP/M, and sold it along with an add-in board that had a Zilog
|
|||
|
chip on it. Apple owners could stick the Microsoft boards in their
|
|||
|
computers and run any CP/M program.
|
|||
|
|
|||
|
But Apple was an 8-bit machine and Gates and Allen felt Intel's new
|
|||
|
16-bit processors were the wave of the future. So did a local board
|
|||
|
maker called Tim Patterson who worked for Seattle Computer Products.
|
|||
|
All earlier processor chips managed data in 8-bit chunks. Intel's new
|
|||
|
8086/8088 chips finally doubled the processor power.
|
|||
|
|
|||
|
Patterson's board had an 8086, and he needed a new 16-bit operating
|
|||
|
system to take advantage of it. Digital Reserach had announced that it
|
|||
|
was going to tweak CP/M into a 16-bit version, but Patterson couldn't
|
|||
|
wait. In early 1980 he started work on one of his own design called
|
|||
|
QDOS (Quick & Dirty Operating System) that was to become 86-DOS (or
|
|||
|
SCP-DOS) and eventually just plain DOS. To make it relatively easy for
|
|||
|
programmers to translate CP/M softwrae to his system, he retained
|
|||
|
fundamental CP/M file management structures and mimicked the way it
|
|||
|
loaded and ran programs. Patterson then added a device known as a File
|
|||
|
Allocation Table (FAT) which Gates had used in Altair disk BASIC, and a
|
|||
|
few other refinements.
|
|||
|
|
|||
|
--------------------------------------------------------------------
|
|||
|
DOS 1.0
|
|||
|
|
|||
|
In late 1980, IBM approached Microsoft and revealed that it was
|
|||
|
considering production of its own 8-bit computer. Vast helpings of
|
|||
|
money, ego, pride and general corporate paranoia have tempered details
|
|||
|
of this exchange, but the popular version is that IBM wanted Microsoft
|
|||
|
to design a version of BASIC for its new machine that would be delivered
|
|||
|
on a ROM chip inside the IBM chassis. Gates was happy to oblige and
|
|||
|
wanted to do a whole raft of languages, as the story goes, but argued
|
|||
|
that IBM should consider a 16-bit computer instead. When IBM asked who
|
|||
|
made a 16-bit operating system, Gates is said to have suggested that IBM
|
|||
|
contact Gary Kildall - and supposedly even dialled the phone to Digital
|
|||
|
Research himself.
|
|||
|
|
|||
|
Here the tale gets very fuzzy. According to the one telling it, when
|
|||
|
IBM trooped down to see Digital Research the next day, Kildall's wife
|
|||
|
and lawyer were hesitant to sign IBM's strict non-disclosure agreements.
|
|||
|
Other stories had Kildall out flying his plane while IBM executives
|
|||
|
waited impatiently for him to land. Microsoft's own publications admits
|
|||
|
that Gates and Allen had heard rumours that Kildall was about to buy a
|
|||
|
version of BASIC from one of Microsoft's competitors and give it away
|
|||
|
free with every copy of CP/M-86, which didn't exactly endear him to
|
|||
|
them.
|
|||
|
|
|||
|
In any event, Gates and Allen bought the rights to Patterson's 86-DOS
|
|||
|
for around $50,000.00 and proposed to IBM that Microsoft provide BASIC,
|
|||
|
FORTRAN, Pascal, COBOL, an 8086 Assembler, and the 86-DOS operating
|
|||
|
system for the new computer. IBM agreed in November 1980, and on August
|
|||
|
12, 1981 introduced the world to its new PC and its main operating
|
|||
|
system, Microsoft's DOS 1.0, which IBM called PC-DOS. At the
|
|||
|
announcement, IBM announced that users would someday be able to buy two
|
|||
|
competing operating systems: CP/M-86 or the UCSD-p System. But IBM
|
|||
|
priced these much higher than DOS, and since they were late reaching the
|
|||
|
market and received little support from other software vendors, they
|
|||
|
went nowhere.
|
|||
|
|
|||
|
Computer hardware isn't useful without software. And IBM initially
|
|||
|
didn't offer much software - EasyWriter, a bug-filled version of a
|
|||
|
mediocre word processor; Adventure, a mainframe text game adapted to run
|
|||
|
on microcomputers, a DOS version of VisiCalc, some artless business
|
|||
|
software, a few Microsoft languages and one or two other packages.
|
|||
|
|
|||
|
The most powerful and popular programs back then - dBase II and WordStar
|
|||
|
- ran only on CP/M systems. One of IBM's highest priorities was to make
|
|||
|
it easy for software vendors to translate programs from CP/M to DOS, and
|
|||
|
it was smart enough to know that making it easy meant making the two
|
|||
|
operating systems similar.
|
|||
|
|
|||
|
Many of the DOS features that todays users truly hate - such as overly
|
|||
|
brief eight-character filenames with three letter extensions, terse
|
|||
|
prompts like A>, and unfriendly or missing messages (such as the stony
|
|||
|
silence in response to file deletions) were directly swiped from CP/M.
|
|||
|
So were underlying structures such as File Control Blocks (FCB's),
|
|||
|
Program Segment Prefixes, and reliance on CP/M's memory loading
|
|||
|
addresses.
|
|||
|
|
|||
|
DOS did change a few CP/M quirks. File lengths that were rounded off in
|
|||
|
CP/M were reported precisely in DOS. Some commands were turned around
|
|||
|
to be more logical. Programmers could treat I/O to peripheral devices
|
|||
|
like printers and screens the same way that they handled files. DOS's
|
|||
|
variable record lengths made disk storage and retrieval far more
|
|||
|
efficient. DOS could load and run larger .EXE format files in addition
|
|||
|
to the smaller CP/M-standard COM-format files which were limited to 64k.
|
|||
|
And it could keep a program loaded but inactive in memory, so that users
|
|||
|
could pop it onto their screens whenever they needed it . DOS relied on
|
|||
|
a FAT, first used by Bill Gates and Tom Patterson, to keep track of
|
|||
|
where all the various pieces of a file were stored, and could read and
|
|||
|
write more than one piece of data at a time, which speeded up disk
|
|||
|
activity significantly.
|
|||
|
|
|||
|
DOS at least theoretically made it easier for programmers to create
|
|||
|
their own version of the COMMAND.COM user interface, although none has
|
|||
|
ever caught on. But the ability to run scripts of commands called batch
|
|||
|
files became very popular. When DOS reported inevitable errors, it did
|
|||
|
so in a slightly friendlier way than CP/M, and it handled severe
|
|||
|
hardware errors far better. DOS also sniffed out new disks automatically
|
|||
|
while CP/M forced users to log such changes manually, and it kept track
|
|||
|
of the date files were created or changed.
|
|||
|
|
|||
|
It also split the COMMAND.COM interface into several parts, a mixed
|
|||
|
blessing. When the PC was new, and IBM offered it with a maximum of 64k
|
|||
|
memory, this feature was welcome since it let other space-hungry
|
|||
|
software temporarily steal a few thousand characters of memory from DOS.
|
|||
|
When the user was finished with the software he'd have to insert his DOS
|
|||
|
disk in drive A: so that the part of DOS that hadn't been stolen could
|
|||
|
reload the part that had. Trouble was that a short time later users
|
|||
|
were buying systems with ten times that much memory, and the amount of
|
|||
|
space freed up by this technique was relatively insignificant. But
|
|||
|
floppy disk users still had to contend with keeping a DOS disk handy to
|
|||
|
reload the "transient" stolen part.
|
|||
|
|
|||
|
One of the worst things about the first IBM PC and its operating system
|
|||
|
was that it could store only 160k of data on floppy disks that were
|
|||
|
clearly capable of storing twice as much. A standard floppy has two
|
|||
|
usable sides, but the first PC - and DOS - could only use one.
|
|||
|
|
|||
|
The initial DOS release contained several nasty bugs. In mid-1982, IBM
|
|||
|
began shipping PC's with double-sided drives, and released DOS version
|
|||
|
1.1 to handle the new storage abilities and to fix several of the early
|
|||
|
bugs. Microsoft then released its own generic upgrade which it called
|
|||
|
MS-DOS 1.25.
|
|||
|
|
|||
|
The initial release of DOS was tiny and relatively crude. Version 1.0
|
|||
|
TIME and DATE commands were separate short programs rather than part of
|
|||
|
the main COMMAND.COM interface. While the DOS 1.0 directory listing
|
|||
|
noted the date a file was changed or created, it ignored the time. The
|
|||
|
MODE command couldn't set communications speeds or protocols, or let the
|
|||
|
PC's parallel printer adaptor work with the many serial printers on the
|
|||
|
market. The COPY command wouldn't join or concatenate several small
|
|||
|
files into a larger one. The onscreen messages and prompts were
|
|||
|
especially ugly and cryptic.
|
|||
|
|
|||
|
DOS 1.1 fixed all these problems, or at least made them less irritating.
|
|||
|
The biggest problem of all was that DOS was still constrained by its
|
|||
|
CP/M heritage and its clanky internal structure. And although IBM
|
|||
|
doubled the amount of disk storage space from 160k to 320k, users found
|
|||
|
this was far from enough. They demanded disks that were faster and more
|
|||
|
efficient.
|
|||
|
|
|||
|
----------------------------------------------------------------------
|
|||
|
DOS 2.0
|
|||
|
|
|||
|
In March 1983, IBM announced its PC-XT, a beefed-up version of the
|
|||
|
standard PC that came with three addtional internal expansion slots (for
|
|||
|
a total of eight), a ten-megabyte hard disk, and a new version of DOS -
|
|||
|
2.0.
|
|||
|
|
|||
|
The new hard disk - which IBM referred to as a fixed disk - could hold
|
|||
|
the equivalent of more than 31 double-sided floppies. But all that
|
|||
|
storage space introduced a new problem. DOS 1.0 and 1.1 had crammed all
|
|||
|
the file information for each floppy disk into a single directory. A
|
|||
|
single-sided floppy had room for a maximum of 64 directory entries, and
|
|||
|
you could fit only 112 on a double-sided diskette.
|
|||
|
|
|||
|
Keeping track of all the files on a hard disk meant coming up with a new
|
|||
|
DOS file management and directory system. CP/M had dealt with large
|
|||
|
disks by splitting them (or partitioning) them evenly into smaller ones,
|
|||
|
an inelegant and inefficient solution. But UNIX, an operating system
|
|||
|
developed by the phone company, could handle vast volumes of files with
|
|||
|
relative style and ease. Microsoft had licensed UNIX, and was offering a
|
|||
|
version of it called XENIX. At the heart of UNIX/XENIX was a
|
|||
|
hierarchical or tree-structured directory system that gave users lots of
|
|||
|
flexibility in dividing up the available storage space.
|
|||
|
|
|||
|
|
|||
|
Microsoft adapted this tree-structured system as the core of a
|
|||
|
significant new incarnation of DOS - version 2.0. But it blundered
|
|||
|
slightly. UNIX used a slash (/) to identify the subdirectory levels
|
|||
|
that acted as branches on the tree structure. But earlier DOS versions
|
|||
|
used slashes as switches (command suffixes such as the /s in FORMAT /s)
|
|||
|
that turned optional features on and off. Microsoft substituted a
|
|||
|
backslash (\) to identify subdirectory levels, which eneded up confusing
|
|||
|
a whole generation of DOS and UNIX users, and caused much consternation
|
|||
|
abroad where foreign keyboards often didn't come with backslash
|
|||
|
characters.
|
|||
|
|
|||
|
IBM and Microsoft also had to find a way to deal with an explosion in
|
|||
|
the number and type of devices that manufacturers were stamping out for
|
|||
|
the PC. One of DOS's main roles was to manage the communication between
|
|||
|
the PC and anything else you could hook up to it. If DOS had to contain
|
|||
|
explicit internal tables and instructions for every possible device it
|
|||
|
would end up being absurdly large and cumbersome.
|
|||
|
|
|||
|
Microsoft designed a new version of DOS with hooks in it so that
|
|||
|
manufacturers of peripheral equipment could supply installable device
|
|||
|
driver programs to hook the new hardware effortlessly into the operating
|
|||
|
system. Users could load these specific additional sets of instructions
|
|||
|
into DOS as needed, through a special CONFIG.SYS file. This file also
|
|||
|
let users customise their systems by telling DOS how much memory it
|
|||
|
should devote to disk buffers, how many files could be opened
|
|||
|
simultaneously, and how frequently DOS should check to see whether a
|
|||
|
user was hitting the Ctrl-Break panic button. It also made it easy for
|
|||
|
users to load a replacement command processor if they weren't planning
|
|||
|
on using the standard COMMAND.COM, or tell DOS if they were storing
|
|||
|
COMMAND.COM in an unusual place. And it gave users extended screen and
|
|||
|
keyboard control with ANSI.SYS, a special device driver supplied by
|
|||
|
Microsoft in an unsuccessful attempt to standardise certain parts of the
|
|||
|
user interface across different computer systems.
|
|||
|
|
|||
|
Version 2.0 introduced several new commands most users can't live
|
|||
|
without. Its hard to believe, but versions 1.0 and 1.1 didn't have any
|
|||
|
way to clear the screen. CLS now does it. This version was also the
|
|||
|
first to offer batch file commands such as ECHO, IF, FOR, SHIFT and
|
|||
|
GOTO.
|
|||
|
|
|||
|
DOS 2.0 also introduced a raft of commands and utilities to give users
|
|||
|
cintrol of hard disks although some, like the pathetic TREE command -
|
|||
|
designed to "display the entire directory structure" are a bad joke.
|
|||
|
|
|||
|
Perhaps to compensate, IBM threw in a gem that has become a power users
|
|||
|
best friend - the mini-assembler in DEBUG. You can become an absolute
|
|||
|
computer whiz without ever having to learn a single thing about hex
|
|||
|
codes or assembly language. But if you want to climb inside your system
|
|||
|
and stomp on the gas pedal, there's no better way. Its a lot easier
|
|||
|
than you think.
|
|||
|
|
|||
|
One of the most significant changes in DOS 2.0 was the way it dealt with
|
|||
|
files internally. To remain compatible with CP/M, DOS 1.0 and 1.1 kept
|
|||
|
track of critical file information with a device called a File Control
|
|||
|
Block (FCB). But as programs became more sophisticated they were forced
|
|||
|
to manipulate the data stored in FCB's directly, which was awkward and
|
|||
|
potentially dangerous. And FCB's had no provision for subdirectory
|
|||
|
names.
|
|||
|
|
|||
|
DOS 2.0 introduced file handles as an optional way to streamline disk
|
|||
|
management. Once DOS knew about a particular file in a partcular
|
|||
|
directory, it could act on that file simply by using a two-character
|
|||
|
shorthand code called a handle. In addition, DOS established five
|
|||
|
special handles that made it a snap to switch inputs and outputs.
|
|||
|
Normally the keyboard and screen (which DOS collectively refers to as
|
|||
|
CON:) act as both the input and output. But DOS 2.0 let users
|
|||
|
"redirect" input or output to or from printers, files or other devices.
|
|||
|
And it allowed users to "pipe" streams of data through filters to do
|
|||
|
things like turn uppercase files into lowercase, strip out extraneous
|
|||
|
characters, or sort records into alphabetical order.
|
|||
|
|
|||
|
The sample filters DOS 2.0 provided are actually pretty useful. They'll
|
|||
|
let you slog through files and skim out the text you want saved or
|
|||
|
discarded. They'll sort your directories (or any list of names, numbers,
|
|||
|
or items that have carriage returns at the end of each entry) lightning
|
|||
|
fast. And they'll paue your displays for you so you'll never again have
|
|||
|
text scrolling off your screen too quickly to read.
|
|||
|
|
|||
|
To top it off, DOS 2.0 provided rundimentary background processing. DOS
|
|||
|
was originally designed as a sigle-tasking operating system that let
|
|||
|
users do just one thing at a time. But the designers of version 2.0
|
|||
|
threw in a PRINT spooler command that could print out one file while a
|
|||
|
user was actively working on another.
|
|||
|
|
|||
|
While spoolers are nothing new, this one was. Spoolers normally lop off
|
|||
|
a big chunk of RAM and trick DOS into sending files to memory that were
|
|||
|
really destined for the printer. Then they wait for a quiet moment and
|
|||
|
re-route the files onto your printed page. When they're done printing,
|
|||
|
however, they still hold on to all the memory they've hogged - very
|
|||
|
inefficient. The DOS PRINT command reads files off your disks and uses
|
|||
|
your precious memory much more sparingly. It watches how you work, and
|
|||
|
about 18 times each second, if you're not doing something at that
|
|||
|
precise moment, it sneaks a few characters at a time to the printer.
|
|||
|
Your computer is so fast that this "time slicing" technique makes it
|
|||
|
appear that it's doing two things at once, when it really alternating so
|
|||
|
quickly you don't notice it. And the best part is that if you happen to
|
|||
|
be working on something that tales more of your computer's constant
|
|||
|
attention than usual, you can adjust how frequently the spooler tries to
|
|||
|
intercede.
|
|||
|
|
|||
|
In addition, DOS increased the number of 512-byte sectors from eight to
|
|||
|
nine. While DOS kept the number of tracks at 40, this upped the storage
|
|||
|
capacity of each disk from 320k to 360k. DOS 2.0 also let users add
|
|||
|
electronic volume labels to their disks, gave them access to part of the
|
|||
|
memory called the environment, in which critical system settings were
|
|||
|
maintained, made memory allocation more efficient, and threw in more
|
|||
|
than two dozen new commands.
|
|||
|
|
|||
|
With so many changes and features, you'd think a brand new version of
|
|||
|
DOS would be filled with insidious bugs. And you'd be right. In March
|
|||
|
1984, a year after the PC-XT introduction, IBM released DOS 2.1 to
|
|||
|
excise these software errors - and to handle a hardware error it
|
|||
|
produced called the PC-Jr.
|
|||
|
|
|||
|
The less said about the PC-Jr the better. While it provided more
|
|||
|
colours onscreen in graphics mode than IBM's real microcomputers, and
|
|||
|
came with three-voice sound that could play chords, it was utterly
|
|||
|
non-standard inside and out. In fact, it used such a cheap, flimsy disk
|
|||
|
drive that DOS 2.1 had to slow down the drive performance so the thing
|
|||
|
wouldn't crash.
|
|||
|
|
|||
|
What's especially sad about all this is that lots of users still rely on
|
|||
|
DOS 2.1, which means they have to put up with unacceptably slow disk
|
|||
|
access times even though the're using machines that could handle much
|
|||
|
higher speeds. A pity, and another good reason to upgrade to a more
|
|||
|
recent DOS version.
|
|||
|
|
|||
|
Microsoft ended up producing versions 2.05, 2.11, 2.2 and 2.25 with an
|
|||
|
added modicum of international time, date, keyboard and currency
|
|||
|
support. These may come in handy if you need to work with Korean
|
|||
|
Hangeul or Japanese Kanji characters; today Microsoft sells DOS in more
|
|||
|
than 60 assorted languages.
|
|||
|
|
|||
|
-----------------------------------------------------------------------
|
|||
|
DOS 3.0 and Beyond
|
|||
|
|
|||
|
IBM's PC and PC-XT brought microcomputing into the mainstream of
|
|||
|
American business. But these machines were both relatively slow and
|
|||
|
small. In fact, they weren't really even true 16-bit computers. While an
|
|||
|
Intell 8088 CPU ticked away inside each one, their system bus - the
|
|||
|
connecting pathway of wires that ties the CPU to all other parts of the
|
|||
|
system - was a bottleneck that worked in eight-bit chunks only.
|
|||
|
|
|||
|
IBM introduced its first genuine 16-bit system, the PC-AT. Compared to
|
|||
|
IBM's earlier releases, this was a real rocketship of a computer. Inside
|
|||
|
was an 80286 CPU with a trick up its sleeve - it could run everything
|
|||
|
IBM and Microsoft could throw at it and it could also accomodate
|
|||
|
Microsoft's ne operating system, OS/2. And it needed a new version of
|
|||
|
DOS - 3.0.
|
|||
|
|
|||
|
Engineers measure computer performance in many ways. Two prime
|
|||
|
indicators are the clock speed of the CPU and the average access time of
|
|||
|
the hard disk. The faster the clock, the faster a computer processes
|
|||
|
instrauctions and the faster just about everything runs. The speedier
|
|||
|
the hard disk access time, the sppedier it can read and write programs
|
|||
|
and data. The higher the clock speed and the lower the average access
|
|||
|
time, the faster the system.
|
|||
|
|
|||
|
Both the PC and the PC-XT run at 4.77 MHz. IBM sold many different
|
|||
|
brands of hard disks for the XT, and the average access time was
|
|||
|
somewhere between 80 and 115 milliseconds.
|
|||
|
|
|||
|
The official clock speed of IBM's first AT was 6MHz, but users quickly
|
|||
|
found out that by replacing a socketed $4 quartz crystal on the main
|
|||
|
system board they could boost performance to 8 or even 9 MHz without any
|
|||
|
ill effects. (IBM is famous for publishing ultraconservative
|
|||
|
specifications and holding down performance a bit on purpose.) When IBM
|
|||
|
discovered that users were hot-rodding their systems, they wrote a
|
|||
|
program that acted as a speed governor and put it on a system ROM chip
|
|||
|
to stop tampering.
|
|||
|
|
|||
|
All of IBM's AT hard disks ran at 40ms or better. Unfortunately, the
|
|||
|
first big batch of AT's came with CMI-brand drives that crashed in
|
|||
|
shockingly high numbers. Hard disks - rapidly spinning precision-crafted
|
|||
|
aluminium platters with magnetic coatings on both sides - need precise
|
|||
|
feedback on where their magnetic read/write heads are located. If the
|
|||
|
location mechanism is off by even a tiny bit the heads can write bad
|
|||
|
data over good or wipe out important tables that tell the computer where
|
|||
|
files are stored.
|
|||
|
|
|||
|
Hard disk heads actually "fly" on a cushion of air directly above the
|
|||
|
surface of the platters themselves. All decent hard disks retract or
|
|||
|
'park" the magnetic heads when the power goes off so they don't sink
|
|||
|
down and plough furrows into your data. To save money, CMI disks used
|
|||
|
what many believe was an unreliable implementation of "wedge servo"
|
|||
|
technology. Most other hard disks used a dedicated positioning surface,
|
|||
|
a whole side of a hard disk platter contained no data and instead acted
|
|||
|
as a map to those that did. But not CMI's AT drives. And these drives
|
|||
|
didn't park the heads when you turned the power off. The heads just
|
|||
|
dropped down onto the data and scarped against it.
|
|||
|
|
|||
|
IBM never really admitted doing anything wrong, but tens of thousands of
|
|||
|
users know different. If this black episode in computing history had a
|
|||
|
silver lining, it was that it taught hard disk users how absolutley
|
|||
|
imperative it is to make frequent and comprehensive backup copies of
|
|||
|
their work.
|
|||
|
|
|||
|
In any event, a PC-AT running at 8MHz was 67 percent faster than a
|
|||
|
standard PC or PC-XT. The PC-AT hard disk was twice as fast as the
|
|||
|
speediest XT disk drive, which made everything seem a lot more
|
|||
|
energetic, and ended up turbocharging disk-intensive applications such
|
|||
|
as database searches. On top of all that, the PC-AT could deal with
|
|||
|
memory in 16-bit chunks, while the PC and PC-XT had to lumber along with
|
|||
|
half that amount. Clone makers soon started producing respectable AT
|
|||
|
imitations that chugged along even faster. To avoid falling behind the
|
|||
|
competition too much, IBM eventually had to nudge the performance upward
|
|||
|
slightly each time it refined the AT design.
|
|||
|
|
|||
|
IBM's newest PS/2 line of hardware and many high-performance clones on
|
|||
|
the market make even the fastest AT look like its standing still. With
|
|||
|
CPU sppeds of up to 25MHz, hard disk access times in the high teens, and
|
|||
|
a 32-bit bus that moves data four times as efficiently as the one in the
|
|||
|
original PC, these hot new micros give refrigerator-sized minicomputers
|
|||
|
a good run for their money.
|
|||
|
|
|||
|
The PC-AT was originally delivered with a 20-megabyte hard disk,
|
|||
|
although subsequent versions have enhanced both the speed and capacity
|
|||
|
of its hard disk. Still, 20Mb storage meant that backin it all up would
|
|||
|
take 56 standard 360k floppies. The mind reels. Apparently, so did
|
|||
|
IBM's. It dropped a quad-density floppy disk drive, with 1.2Mb capacity
|
|||
|
into each AT. IBM refers to these as high-capacity drives. Unhappy users
|
|||
|
have called them something else, unprintable here.
|
|||
|
|
|||
|
The PC-AT's new DOS, version 3.0, could handle the increased floppy disk
|
|||
|
storage. But it also had to understand every other floppy format. In the
|
|||
|
space of six years IBM had introduced single-sided and double-sided
|
|||
|
drives, with eight or nine sectors, and in double or quad density, so
|
|||
|
downward compatibility meant having to deal with:
|
|||
|
|
|||
|
* 160k single-sided 5.25"
|
|||
|
* 180k " "
|
|||
|
* 320k double-sided "
|
|||
|
* 360k " "
|
|||
|
* 1.2M " "
|
|||
|
|
|||
|
Well, there's compatibility and there's compatibility. Out of the 25
|
|||
|
different possible combinations of using the DISKCOPY command to move
|
|||
|
information from one to the other, 16 won't work.
|
|||
|
|
|||
|
What's more, IBM's PS/2 hardware uses 3.5" diskettes, a whole new ball
|
|||
|
game. These smaller diskettes are sturdier, easier to transport, and
|
|||
|
vastly more efficient at storing information. IBM characteristically
|
|||
|
complicated matters by producing two different and slightly incompatible
|
|||
|
3.5" disk formats, one that holds 720k and one capable of storing 1.44Mb
|
|||
|
of data. The 5.25" 320/360k format won't go away very quickly, since so
|
|||
|
many vendors have made it the standard for program distribution. But
|
|||
|
the PC-AT's 1.2Mb drive and the low-end PS/2 720k diskette are orphans.
|
|||
|
|
|||
|
* note: This is US. 720k was very popular in NZ.
|
|||
|
|
|||
|
All IBM microcomputers gave users a clock and calendar that could stamp
|
|||
|
DOS directory listings with the time and date files were created or most
|
|||
|
recently updated. But users had to set the clock each time they started
|
|||
|
their systems, unless they had purchased an add-in board with a
|
|||
|
battery-driven clock on it (and most did). The PC-AT came with its own
|
|||
|
internal battery run clock/calendar, but it wasn't until DOS 3.3 taht
|
|||
|
users could reset it easily.
|
|||
|
|
|||
|
Program developers live by a rule: "The software is never finished."
|
|||
|
Each release of DOS or any commercial application is quickly followed by
|
|||
|
a version with bug fixes, sppedups, and forgotten utilities. Market
|
|||
|
considerations force manufacturers to ship everything at the earliest
|
|||
|
possible date. Microsoft officially admits that DOS 3.0 "wasn't quite
|
|||
|
ready" at the introduction of the PC-AT. But it went out the door
|
|||
|
anyway.
|
|||
|
|
|||
|
Today, virtually every desk in America has a telephone in one corner.
|
|||
|
IBM's vision of the future puts a computer terminal next to it, and
|
|||
|
strings all the terminals together electronically. Networking computers
|
|||
|
this way has lots of advantages. It lets users "mail" messages and
|
|||
|
files to each other, and share centralised databases of information.
|
|||
|
Networks can also let users share expensive peripherals like plotters or
|
|||
|
laser printers, but it doesn't make much sense installing three $1500
|
|||
|
network hookups to share one $1500 laser printer. Today networks are
|
|||
|
interesting to a minority of users only - although the number grows as
|
|||
|
the costs and headaches associated with using them are reduced. Networks
|
|||
|
introduce their own special set of problems. Two users may reach for
|
|||
|
the same database records at the same time, and something has to mediate
|
|||
|
the conflict. Worse, giving users access to centralised information
|
|||
|
means someone has to decide who gets access to what. And then something
|
|||
|
has to keep track of the authorisation levels and enforce it all, and
|
|||
|
make sure the right data is routed to the right place.
|
|||
|
|
|||
|
Microsoft designed DOS version 3.0 to support the official IBM PC
|
|||
|
network hardware. Unfortunately, the AT was ready before the network
|
|||
|
features of DOS were, and the Microsoft designers had to deactivate
|
|||
|
these features in the final product. They finally turned them back on
|
|||
|
again in version 3.1, released in November 1984. But DOS 3.1 was picky;
|
|||
|
it would handle only certain well-behaved networks.
|
|||
|
|
|||
|
DOS 3.0 introduced a streamlined method for integrating FCB's and
|
|||
|
handles. And while it provided a small handful of new features, none was
|
|||
|
a radical departure from DOS 2.1. In fact, IBM stated in its
|
|||
|
documentation that "DOS 3.0 does not replace DOS 2.1". But it did fix a
|
|||
|
nasty 2.1 oversight, by making it harder for users to format their hard
|
|||
|
disks if they weren't careful. (It wasn't until version 2.0 that DOS
|
|||
|
even asked for confirmation if users tried to delete all the files on
|
|||
|
their disk with a single ERASE *.* command.) Version 3.0 also let users
|
|||
|
make files read-only to prevent any inadvertent changes or deletions.
|
|||
|
|
|||
|
Version 3.1 provided better "aliasing" features to combine drives and
|
|||
|
directories and to trick DOS into treating a subdirectory like a disk
|
|||
|
drive. DOS 3.2 introduced users to 3.5" diskettes (although the tools it
|
|||
|
provided to do this were downright awful), made it easier for them to
|
|||
|
upgrade DOS versions, and gave them one of the best but least-used new
|
|||
|
commands, XCOPY.
|
|||
|
|
|||
|
DOS 3.3, tossed off by IBM pitchment at the introduction of the PS/2 as
|
|||
|
an "interim solution" and the operating system for a string of dogs
|
|||
|
including the PC Convertible, Portable PC, and PC-Jr, deftly excised a
|
|||
|
heap of user headaches, and added a few sizzling new tricks.
|
|||
|
|
|||
|
As all seasoned hard disk users are aware, working efficiently on a hard
|
|||
|
disk machine means pigeonholing related programs and data in electronic
|
|||
|
file drawers called subdirectories. But users who are currently working
|
|||
|
in one subdirectory often want to execute a program or look at data
|
|||
|
stored in another.
|
|||
|
|
|||
|
Since version 2.0, users had been able to tell the PATH command to check
|
|||
|
specified subdirectories for executable files (with filenames ending in
|
|||
|
COM, EXE or BAT). This let users run programs in other subdirectories,
|
|||
|
but it didn't let them get at distant data. Nonexecutable files remained
|
|||
|
immune to even the most comprehensive search, forcing power users to
|
|||
|
purchase commercial "path extender" programs, or struggle with the DOS
|
|||
|
3.1 SUBST command. The DOS 3.3 APPEND command made this process
|
|||
|
relatively easy - and a lot cleaner.
|
|||
|
|
|||
|
Serial ports are your system's main gateway to the world. Version 3.3
|
|||
|
let MODE cruise along with four serial ports rather than two (OS/2 can
|
|||
|
use 8) and cruise along at 19200 baud, double the previous limit. And
|
|||
|
IBM finally recognised that at least twice a year users need to reset
|
|||
|
their internal IBM clocks and provided a way of doing this without
|
|||
|
hunting down their Diagnostics disks, figure out which option adjusts
|
|||
|
the time, and grind through all the irritating preliminary screens. The
|
|||
|
3.3 TIME and DATE commands automatically adjusted IBM CMOS memory to
|
|||
|
reflect the change.
|
|||
|
|
|||
|
Another improvement was the newfound ability of the DOS 3.3 ATTRIB
|
|||
|
command to gang-process all files within a directory and its related
|
|||
|
subdirectories, which made it easier to create backups and prevent
|
|||
|
inadvertent file deletions or changes. Unfortunately, the same process
|
|||
|
used by ATTRIB can also hide files from casual snooping, but IBM's
|
|||
|
manual won't show you how.
|
|||
|
|
|||
|
The original DOS architects preferred working with 512-byte disk
|
|||
|
sectors, and used a FAT to keep track of what data was in which sector.
|
|||
|
When they designed the FAT they used 16-bit addresses, which allowed a
|
|||
|
maximum of 65,536 (64k) table entries. This clamped a firm 32Mb limit
|
|||
|
on the size of any physical hard disk (512 x 65,536 = 33,554,432 bytes).
|
|||
|
To get around this limit, manufacturers either had to increase the
|
|||
|
sector size, which made their hardware non-standard and relatively
|
|||
|
wasteful, or come up with an entirely new file management scheme, which
|
|||
|
ended up being even more non-standard.
|
|||
|
|
|||
|
IBM tuned DOS 3.3 to divide physical hard disks into smaller "logical"
|
|||
|
drives, and fixed the FDISK command to create extended DOS partitions in
|
|||
|
addition to the primary ones they were able to carve out previously.
|
|||
|
Each extended partition could be further subdivided into logical drives
|
|||
|
32Mb or smaller, with their own drive letters. Compaq quickly made it
|
|||
|
even easier to use enormous hard disks, by introducing DOS 3.31 that
|
|||
|
boasted 32-bit FAT addresses.
|
|||
|
|
|||
|
To expedite directory searches with the new generation of larger hard
|
|||
|
disks, DOS 3.3 provided a filename cache utility called FASTOPEN.
|
|||
|
Caches keep track of things in memory rather than on disk, which speeds
|
|||
|
many processes up significantly. FASTOPEN notes the location of files
|
|||
|
and subdirectories (which are really just special classes of files) the
|
|||
|
first time you hunt for them, and then directs DOS to the exact spot on
|
|||
|
the disk the next time you have to deal with them.
|
|||
|
|
|||
|
The DOS BACKUP command had always been so pathetic that an entire
|
|||
|
industry of third-party backup software has evolved to fill the gap.
|
|||
|
While the version 3.3 enhancements aren't going to put those developers
|
|||
|
out of business, they will bring some users back into the fold. Under
|
|||
|
previous DOS versions you had to format a tall stack of disks before
|
|||
|
strating the backup process. If you ran out of formatted disks halfway
|
|||
|
through you had to abort and either find a way to catch up, or start the
|
|||
|
whole elaborate, time-consuming procedure all over again.
|
|||
|
|
|||
|
In DOS 3.3 the BACKUP command can summon the FORMAT command and prepare
|
|||
|
unformatted disks if necessary - with certain irritating restrictions.
|
|||
|
And you have to limit the disks and drives you use; it still can't mix
|
|||
|
and match. The DOS 3.3 BACKUP works faster and more efficiently than
|
|||
|
older versions, by copying all smaller files into a single enormous one,
|
|||
|
and by creating a guide file that tells DOS how to take the big file
|
|||
|
apart and restore it properly again later. It also creates a log file
|
|||
|
telling you what it did where.
|
|||
|
|
|||
|
The DOS 3.3 RESTORE gives you added flexibility in restoring backed-up
|
|||
|
files by date and time, as well as those deleted or changed since you
|
|||
|
last backed up, or files that are no longer on the target disk. Better
|
|||
|
yet, while older versions of RESTORE let you accidentally obliterate
|
|||
|
your system files (IBMBIO.COM, IBMDOS.COM and COMMAND.COM or their
|
|||
|
MS-DOS counterparts) with older backed-up versions, DOS 3.3 RESTORE
|
|||
|
won't. Inadvertently mixing versions of hard disk system files is like
|
|||
|
replacing a heart surgeon in the middle of an operation, with a tree
|
|||
|
surgeon.
|
|||
|
|
|||
|
Batch files can take the anguish out of tricky or repetitive tasks. The
|
|||
|
first thing most power users do when they create a batch file is turn
|
|||
|
off the display by issuing an ECHO OFF command. This stops DOS from
|
|||
|
littering your screen with the frantic prompts, messages, and other
|
|||
|
electronic graffiti a batch file generates. But users had no authorised
|
|||
|
way of preventing this ECHO OFF command from adding to the screen
|
|||
|
clutter itself. Version 3.3 users can prevent such clutter simply by
|
|||
|
prefacing any command with an @ symbol.
|
|||
|
|
|||
|
in addition, DOS 3.3 could CALL one batch file from within another,
|
|||
|
execute it, and then return to the original batch file and continue
|
|||
|
executing it. Doing this kind of "nesting" under previous versions of
|
|||
|
DOS meant that each batch file had to load its own separate version of
|
|||
|
COMMAND.COM to do its work, exit, and drop back to yet another version -
|
|||
|
which was sort of like restarting a movie every time a latecomer walked
|
|||
|
into the theatre. DOS 3.3 also documented environment variables for the
|
|||
|
first time, which let users pass information back and forth from
|
|||
|
application to application.
|
|||
|
|
|||
|
DOS 3.0 to 3.2 came in five international flavours. By executing the
|
|||
|
appropriate KEYBxx command, users could transform the keyboard into
|
|||
|
British, German, French, Italian or Spanish modes. With version 3.3,
|
|||
|
IBM totally revamped the way DOS handled foreign alphabets. IBM's
|
|||
|
manuals have gotten a bit better over the years, but the three abtruse
|
|||
|
and seemingly contradictory chunks on this international support
|
|||
|
virtually defy comprehension. IBM prefaced its long appendix-like
|
|||
|
treatment of the topic with the caveat "You can use code page switching
|
|||
|
without fully understanding everything about it." After poring over the
|
|||
|
text, you'll know why this was included. And if you live in the United
|
|||
|
States, you'll take one look, put your hand over your heart, and say,
|
|||
|
"Thank God we're Americans."
|
|||
|
|
|||
|
For the first time, DOS 3.3 set a default number of disk buffers based
|
|||
|
on your system's configuration. Under previous versions, it assumed
|
|||
|
evert PC and XT user really wanted only two and every AT user only
|
|||
|
three. DOS will now sniff out what hardware you have available, and
|
|||
|
allocate from two buffers (minimal RAM, no hi-density floppies, 3.5"
|
|||
|
diskettes, or hard disks) to 15 (and machine with more than 512k of
|
|||
|
RAM). If you're using a big hard disk, you may want more than 15.
|
|||
|
Better yet, try a commercial file cache program.
|
|||
|
|
|||
|
The Future
|
|||
|
|
|||
|
IBM and Microsoft continue to add and adapt messages and prompts; the
|
|||
|
infamous and ubiquitous DOS error message "Abort, Retry, Ignore?" became
|
|||
|
a more chilling "Abort, Retry, Ignore, Fail?" under DOS 3.3. This isn't
|
|||
|
exactly friedly. When Microsoft originally designed DOS it published
|
|||
|
all the specifications so that other manufacturers could replace the
|
|||
|
COMMAND.COM user interface with something different, such as a visual
|
|||
|
shell. Several amateurs have tried, but nothing has come of it.
|
|||
|
Microsoft itself tried an easier interface called WINDOWS, but users
|
|||
|
have resisted, calling the interface overly large, ungainly, and slow.
|
|||
|
Microsoft and IBM have adapted Windows as a graphic front-end called
|
|||
|
Presentation Manager for OS/2.
|
|||
|
|
|||
|
DOS needs all sorts of help; way back when the EGA was first introduced,
|
|||
|
for instance, users complained that the MODE command couldn't deal with
|
|||
|
any of the new graphics settings, such as 43 or 50 lines of text, or the
|
|||
|
far better colour selection. Now that VGA is becoming the norm, DOS
|
|||
|
still doesn't directly handle anything better than CGA.
|
|||
|
|
|||
|
(PC-DOS 4.0 and 4.01 have been released since this was written; MODE now
|
|||
|
supports high resolution text displays and multiple serial ports.
|
|||
|
However few users have switched to 4.0 or 4.01 in New Zealand,
|
|||
|
particularly after the OS was slammed by the foreign press as being full
|
|||
|
of bugs, inconsistent in its user interface, and a memory hog. Some
|
|||
|
Wellington BBS users have successfully changed to DOS 4.01, and have
|
|||
|
experienced no real problems in their non-demanding environment. Most
|
|||
|
users with only 640k will probably prefer to stick with DOS 3.2 or 3.3,
|
|||
|
and those with large disks to 3.31.)
|
|||
|
|
|||
|
[And since *that* was written, most new computers are sold with a 40MB
|
|||
|
disk minimum and DOS 4.01. The product is now quite stable. DOS 5.0's
|
|||
|
release is imminent.]
|
|||
|
|
|||
|
----------------------------------------------------------------------
|
|||
|
Downloaded from The Cave III, where the SysOp had uploaded it. Don't
|
|||
|
know whether he wrote it, or found it somewhere, but it's not bad!
|
|||
|
|