After development of the first UNIX systems in research, Joe Maranzano
of Murray Hill created a UNIX support group. This group would package,
fix bugs, and enhance the research version periodically. A year after
this new group was formed, Heiz Lacklama and Doug Bayer of Holmdel
modified UNIX for a PDP 11/70 using the 3 memory management registers so
that UNIX ran as a supervisor. This product, called MERT for Mult
Environment Real-Time operating system, was eventually support by the same
UNIX support group.
The third major entry was UNIX/PWD. The programmers workbench contained
programs which controlled remote job entry, and source control. These were
developed at Piscataway N. J. In this time period, new PDP processors such
as the PDP 11/34, and PDP 11/23 and even a PDP 11/55 were released and off-
springs to UNIX developed for them. The PCC (Portable C Compiler) and satellite
library for UNIX was generated and new MINI UNIX products arose. On the
other hand, UNIX for a HONEYWELL and UNIVAC 1100 series was also started.
Around 1978, the UNIX support group in conjunction with a computer task force
decided to support two major releases. UNIX/TS and UNIX/RT. UNIX/TS was USG
UNIX and PWD UNIX combined. The UNIX/RT was basically supported MERT. Columbus
had modifyed a version of MERT extensively, and called their product
CB UNIX. Another version of MERT formed the basis for DMERT, a Duplex operating
system. The thrust of only two supported versions was that UNIX/RT showed
very good promise as being the more used version and anything that could
be done in UNIX/TS would work in UNIX/RT.
The advent of the PDP VAX computer now created four products. UNIX/RT and
UNIX/TS for both PDP 111/70 and VAX 780 computers. In 1979 UNIX/RT was
announced as 1 year to freeze, with UNIX/RT VAX officially dead. The
remaining UNIX/TS VAX was again modified by the Indian Hill computer center
into another product called UNIX/TS Augmented. Finally, the product
internal to AT&T Bell Labs call UNIX/TS was the only major product supported.
I hope this little history was interesting. If you have further questions
I will try and answer them within company constraints.
Patrick A. Fargo
MERT was actually a separate OS from UNIX, which had a UNIX overlay on
top of it (so the first case of putting a UNIX-compatible interface on
top of a different OS was Bell's own MERT!).
	In this time period, new PDP processors such as the PDP 11/34,
and PDP 11/23 and even a PDP 11/55 were released and offsprings
	to UNIX developed for them.
The 11/55 was just an 11/45 with faster memory and a faster floating point
unit, so the standard UNIX that ran on an 11/45 would run on the 11/55.
The 11/34 and 11/23 would, by and large, run versions of UNIX that ran on
the 11/40, except that they could support the floating point instructions.
(They also had other features, like the 11/34's cache and the 11/23+'s
22-bit UNIBUS, but standard UNIX know about them.)
UNIX/TS was USG UNIX and PWD UNIX combined.
And was derived from a version of UNIX that was mostly Research V7, although
it was, I believe, slightly earlier than the released V7 (it had a V6-ish)
terminal driver, for instance) - the original USG UNIX and PWB/UNIX were
derived from V6 or from V6es later than the released V6 - a set of "50 changes"
that would turn V6 into what was running at Research at the time when the
changes were sent out was done by Ken Thompson, and there was a
"Phototypesetter, Version 7" distribution that contained the "modern"
nroff/troff/eqn/tbl, the "modern" C compiler with "long", "typedef", etc.,
the "modern" linker and archiver, and the Standard I/O library.  Most of the
"50 changes" and "Phototypesetter, Version 7" stuff was in PWB/UNIX 1.0.
	Another version of MERT formed the basis for DMERT, a Duplex operating
	system.
For the 3B20-D; the D stood for Duplex and meant there were two CPUs in a
redundant configuration.
	In 1979 UNIX/RT was announced as 1 year to freeze, with UNIX/RT
	VAX officially dead.
Just out of curiosity, why was UNIX/RT canned if, as stated earlier, it was
felt that UNIX/RT could do everything UNIX/TS could and more?
	The remaining UNIX/TS VAX was again modified by the Indian Hill
	computer center into another product called UNIX/TS Augmented.
Was there also *another* UNIX/TS variant called UNIX/TS+ (plus)?
	Finally, the product internal to AT&T Bell Labs call UNIX/TS
	was the only major product supported.
And was named just UNIX as of release 3.0 (release 3.0.1 was publicly
released as System III); it incorporated stuff from TS Augmented and
TS+.
Was CB-UNIX based on UNIX or MERT, and how much stuff going into the
mainstream UNIX (S3, S5) came from CB-UNIX?
	Guy Harris
	{seismo,ihnp4,allegra}!rlgvax!guy
	1). Why was UNIX/RT canned instead of TS? Good question! I believe
	    because of staffing a choice had to be made. Since DMERT was RT
	    based and would be supported, USG felt UNIX/TS had more potential
 	    from a computer center standpoint.
	2). Was UNIX/TS+ another modified UNIX/TS?  Yes, the UNIX/TS Augmented
	    that I spoke of was actually called UNIX/TS++. Modifications were
	    made that were mostly hidden from the user interface.
	3). What was CB-UNIX based on?  CB-UNIX was a modified MERT. The
	    SCCS project modified extensively, the version of MERT they had.
	    Later, they incorporated the MERT changes in UNIX/RT releases.
	    Eventually, an agreement to take the requested CB modifications
	    into the standard UNIX/RT product was reached and that line of
	    modified O.S. ceased.
Thanks again for the corrections,
P. A. Fargo
AT&T Bell Laboratories IH
Another point is that the whole system was riddled with bugs.  I had the
opportunity to work with some of the RT folks (on a few of the bugs) and my
impression was that they were a small group of people that were just
overloaded.  Apparently the "management" decision was that RT wasn't worth the
effort to "rescue" it.
-- 
		Larry Marek
		 ihnp4!ihuxf!larry
P. A. Fargo
BTL -IH
Any old USGer's care to add to this.
I hope some one is collecting all of this UNIX folklore and plans to
print it paperback.
Jim Farrell
AT&T Bell Labs
The UNIX System V IPC was already present in USG UNIX 4.1.
(Not related to 4.1BSD.)
It appears to me that these features must have been in UNIX/RT.
Guy Harris has given much more accurate UNIX history notes than most
of what has filtered into the ARPAnet on this topic.  I would like to
add a couple of comments:
It was fairly easy to take the 6th Edition UNIX 11/45 floating-point
processor (FP11) support and add it into the 11/40 version for a
PDP-11/34.  One subtle problem with using the 11/40 kernel on an 11/34
is that the faulted-instruction restart code was not entirely correct
for the 11/34, although later the 11/23 was again 11/40-compatible in
this regard.  The 6th Edition UNIX floating-point support also had
some bugs that needed to be fixed if one was going to make heavy use
of floating-point on an 11/34 or 11/23, as we did at Geotronics Corp.
The most important Columbus product to appear in USG UNIX would
probably be the augmented "make", which is much nicer than the
7th Edition UNIX version, although still not perfect.
All it takes to make UNIX quite usable for real-time data acquisition
is:
	(1) plock(2) or equivalent to ensure that user-mode code is
	    memory-resident when needed.
	(2) strict priority scheduling, which can be as simple as
	    adding a privileged "real-time process queue" to the
	    existing scheduler.
	(3) data acquisition device driver and user-mode dual-buffered
	    program that cooperate nicely.
One of the past USENIX tapes contained Geotronics contributions for
items (1) and (2) for 6th Edition UNIX.  John Quarterman, now with the
University of Texas Dept. of CS, did a really nice job of making (3)
work for the proprietary 11/23-based system used in the field by
Geotronics Corp.
Guess again guy, there is no such thing as a 22 bit UNIBUS.
23's have Q-Buses. 24's have unibuses.  The 23+ was a documented
processor with 22 bit addressing (those of us with plain 23's found
that they were inherently 22 bits two and it was easy to make us
of it.
-Ron
For you real UNIX trivia freaks, the USG 4.0 IPC was different
from the USG 4.1 IPC.  The original message send/receive system calls sent
to a process ID; they were changed to send to message queues, which had a
32-bit unique ID, instead (which makes more sense, as it permits you to
transparently replace servers).  (It might be interesting to see how many
changes to the Berkeley IPC mechanism would be needed to provide yet another
domain which provides compatibility with the S5 IPC mechanism; obviously,
the socket addresses would be the unique IDs.  The trick is that the S5
messages have a "long" which is a "message type", and the S5 "msgrcv"
call can ask to be delivered only messages of a certain type, or messages with
a certain type number or lower number.  Also, message queues (and other
"IPC objects") have an owner UID, owner GID, and permission bit set
associated with them.)  The semaphore code was also very different (it may
have been descended from semaphore code done for the pre-UNIX/TS USG systems),
and the shared memory code was the MAUS code which used a dedicated part
of physical memory for the shared space.  The history of Bell UNIX IPC
mechanisms looks rather multi-branched; anybody out there with the full
story?
It's also interesting to see mention of various such branches in the BSTJ
issue on UNIX (the July-August 1978 issue, Vol. 57, No. 6, Part 2).  They
make casual reference to "the UNIX interprocess message facility", "the
semaphore capability of the UNIX system", and to "run levels" in "the standard
UNIX 'init' program" in the article on the Network Operations Control System,
and also describe the MAUS shared-memory facility which was originally done
for that system.  (Another aside: the MAUS was credited to Dale DeJager
and R. J. Perdue; I remember seeing some code from Gould which was part of
their driver and support code for their 5000 series electrostatic printer-
plotter for DEC systems which was also credited to R. J. Perdue - was this
the same guy?)  A lot of those features probably came out of Columbus but
never made it into the UNIXes released to the outside world until System III
(the 'init') or System V (the messages and semaphores).  Andy Tannenbaum sent
me a "man" page for an "init" from a pre-UNIX/TS USG system which also had
the run levels, and Hal Pierson (ex-Labs, now working here) mentioned that
they had done both a semaphore system and the run-level based 'init' for a
system they did which collected output from the console terminal ports of
Electronic Switching Systems processors and allowed "craftsmen" (which I
think is AT&Tese for "field engineer") to peruse that output for maintenance
purposes.  They also realized that these craftsmen wouldn't know an inode if
it came up and bit them in the *ss, so they had to replace "icheck" and "dcheck"
with a new program which would do most of the dirty work of file system repair
for them - Hal wrote one called "fcheck", which cleaned V6 file systems, and
which appeared in source-code form on the PWB/UNIX 1.0 distribution tape.
Unfortunately, PWB/UNIX 1.0 modified the V6 file system so that it didn't
support "huge" files, and the eighth indirect pointer pointed directly to
a block as the other seven did, so the "fcheck" there wouldn't fix a vanilla
PWB/UNIX file system, but it worked just fine on a vanilla V6 FS.  When I
discovered it, quite by accident, I looked at it and it sure looked like
a super-duper file system fixer; once we got it up, we never went back to
"icheck" and "dcheck" again.  Later on, of course, Ted Kowalski rewrote it
to work on a V7 filesystem, added some extra checks, gave it the ability
to reconnect files with no directory entries, put comments into the
code (something Hal still has trouble doing :-)), cleaned it up some, and
renamed it "fsck".
It appears to me that these features must have been in UNIX/RT.
MERT had its own set of new features, including yet *another* message facility
which didn't look like any of the "Ken&Dennis-derived" UNIX systems'
facilities, but I don't know what they did in UNIX/RT.
A lot of source material is in the BSTJ UNIX article, and may appear in some
issues of Bell Labs' "UNIX Systems Newsletter" which was distributed to
UNIX sites within AT&T & operating companies.
Anybody for a "net.unix.history" newsgroup - at the end of the year, maybe
we gather up all the articles, give them to some editor (maybe Dennis, who
certainly doesn't have anything more important to do :-)) who can cull out
the chaff, and publish it somewhere?
	Guy Harris
	{seismo,ihnp4,allegra}!rlgvax!guy
	Guy Harris
	{seismo,ihnp4,allegra}!rlgvax!guy
The SCCS version of UNIX had a number of unique features for the times:
semaphores and line disciplines (in 1974!) for example. Hal Pearson
was responsible for semaphores, and Bill Snider for line disciplines.
Messages and shared memory were first added to CB-UNIX in about 1975 or
1976. Shared memory was called MAUS (pronounced moss, standing for
Multiple Access User Space) and was derived from an earlier version
done by R. J. Purdue.  CB-UNIX became rather widely accepted within BTL
as a base for turnkey Operations Systems--many of which have been
described in the BSTJ. Note that CB-UNIX was not a derivative of UNIX/RT, but
of Version 6 and Version 7.  PWB UNIX was also a derivative of Version 7.
USG UNIX was originally a derivative of Version 6 and 7 with some CB-UNIX
facilities added.  Eventaully a decision was made to consoldate to two
versions of UNIX:  UNIX/TS and UNIX/RT. RT was a derivative of MERT, and
TS a derivative of PWB UNIX. RT was to be used by Operations Systems, but
was never too widely accepted. Eventually, UNIX/TS was augmented to have
many of the features present in CB-UNIX (this was done by Roger Faulkner
at Indian Hill, BTL. This, in turn, became the base for UNIX 4.0, which
was never released externally. While this augmentation was going on, UNIX/TS
was being changed into UNIX 3.0 which was release externally as SYSTEM III.
In more recent history, CB-UNIX has been eliminated entirely in favor of
UNIX 5.0. (one reason is because it never ran on anything other than the 11/70)
I once had a viewgraph with all this on it which I had great fun trying to
explain.
Now for trivia: How many know where in UNIX lore you would find the following
quote:  "Values of beta will result in dom!"
			Dale DeJager
			AT&T Information Systems
			Lincroft, N.J.
Sooner or later, in /usr/games/lib/fortunes.dat .
-- 
   Jim ({ihnp4,kpno,ut-ngp}!ut-sally!crandell or cran...@ut-sally.UUCP)