ICT 1900 series


ICT 1900 was the name given to a series of mainframe computers released by International Computers and Tabulators and later International Computers Limited during the 1960s and '70s. The 1900 series was notable for being one of the few non-American competitors to the IBM System/360, enjoying significant success in the European and British Commonwealth markets.

Origins

In early 1963, ICT was engaged in negotiations to buy the computer business of Ferranti. In order to sweeten the deal, Ferranti demonstrated to ICT the Ferranti-Packard 6000 machine, which had been developed by its Canadian subsidiary Ferranti-Packard, to a design known as Harriac that had been initiated in Ferranti by Harry Johnson and fleshed out by Stanley Gill and John Iliffe.
The FP6000 was an advanced design, notably including hardware support for multiprogramming. ICT considered using the FP6000 as their medium-sized processor in the 1965–1968 timeframe, replacing the ICT 1302. Another plan being considered was to license a new range of machines being developed by RCA, probably compatible with the expected IBM 8000.
On 7 April 1964 IBM announced the System/360 series, a family of compatible machines spanning nearly the complete range of customer needs. It was immediately obvious that ICT would need a coherent response. Two paths were available: develop a range of machines based on the FP6000, using the flexibility of its design to produce smaller or larger machines, or cooperate with RCA who were re-targeting their development to a System/360 compatible range to be known as the RCA Spectra 70.
One major consideration was that the FP6000 was already running, while the RCA Spectra range would take some years to become available. In the end the decision was made to go with a range of machines based on the FP6000. The centrepiece of the new range was the ICT 1904, a version of the FP6000 with the ICT standard peripheral interface. For higher-end machines a new larger processor, the ICT 1906, was to be developed by the ICT West Gorton unit. To meet the needs of smaller customers, smaller machines, the ICT 1901 and ICT 1902/3, were developed by the ICT Stevenage unit, based on the PF182 and PF183 processors already in development.
On 29 September 1964 the ICT 1900 range was announced in a filmed presentation, scripted by Antony Jay. The following week two working systems were demonstrated at the Business Equipment Exhibition, Olympia.
The first commercial sale was made in 1964 to the Morgan Crucible Company, comprising a 16K word 1902 with an 80-column 980-card/minute reader, a card punch, a 600 line/min printer and 4 x 20kchar/s tape drives. It was soon upgraded to a 32K word memory and a floating point unit to allow for some scientific work. The same company had also been the first to order ICT's first computer, the HEC4, in 1955.
The first system delivered was a 1904, for the Northampton College of Advanced Technology, London in January 1965.

Architecture

The ICT 1900 was a word addressing machine using a register-to-memory architecture with eight accumulator registers. Three of the accumulators could be used as modifier registers. The word length was 24 bits, which could be used as four 6 bit characters. Two instructions were provided for copying single characters to and from memory.
The accumulators were addressable as if they were the first eight words of memory, giving the effect of register-to-register instructions with no extra operation codes being needed. In fact the hardware registers were an optional feature and if not fitted the accumulators were the first eight words of memory. The large number of optional features in the FP6000 design gave ICT great flexibility in pricing.
A notable feature of the series was the hardware support for running multiple processes – every process ran in an independent address space, enforced by datum and limit registers. No user process could access the memory of any other process. Later models added paging hardware, allowing true virtual memory with the GEORGE 4 operating system.
On the original models the address size was 15 bits, allowing up to 32Kwords of memory. Later models added 22 bit addressing, allowing a theoretical 4Mword maximum memory. Instructions contained a 12 bit operand, either fixed or offset from an index register. Branch instructions held a 15 bit offset, allowing access to all memory on the initial range. When the address size was increased to 22 bits replaced and relative branches were added to the instruction set to allow access to the larger address space.
The largest change between the original FP6000 and the 1900 series was the inclusion of the ICT standard interface for connection of peripherals. This allowed connection of any ICT peripheral to any processor of the series, and users could upgrade their processors while keeping the same peripherals or vice versa.
All I/O operations were initiated by a privileged supervisor process, known as the executive. User processes communicated with executive using extracodes, instructions that caused a trap into the executive when run. Executive would then communicate with the appropriate peripheral via the Standard Interface, using functions not available to user processes. The subsequent data transfers would then occur across this interface, autonomously without further program involvement. The conclusion of the transfers would similarly be indicated back to the executive.
On smaller members of the series some expensive instructions were also implemented as extracodes. The combination of the executive and hardware provided the same interface to programs running on any model of the range.
The hardware floating-point unit, if fitted, ran autonomously. When a floating-point operation was started integer instructions could be run in parallel until the result of the floating-point operation was needed.

Data formats

The instruction set supported the following data formats:
Since the ICT 1900 used a six-bit character it was largely limited to a 64-character repertoire, with only upper case letters and no control characters.
In order to deal with data on paper tape or from communications equipment a system of shifts could be used to represent the full 128 characters of ASCII.
Character #74 was considered an alpha shift and indicated subsequent characters were to be considered upper case, #75 was a beta shift and indicated subsequent characters were in lower case, #76 the delta shift, indicating the next character was a control character and #77 used as a fill character. For example, the ASCII string "Hello World" would be encoded as "αHβELLO αWβORLD".
The 1900 used a variant of ASCII-63, known by ICT as the ECMA character set, with some characters in different positions:
ASCII$\^_`
ECMA£$_

Comparison with [System/360]

Both the 1900 series and System/360 provided hardware support for multi-programming. On the 1900 all user memory addresses were modified by a datum register and checked against a limit register, preventing one program interfering with another. The System/360 gave each process and every 2048 byte block of memory a four-bit key, and if a process key did not match the memory block key an exception would result. The 1900 system required programs to occupy a contiguous area of memory but allowed processes to be relocated during execution, simplifying the work of the operating system. The 1900 also allowed any process direct access to the first 4096 words of its address space. .
The System/360 had the advantage of a larger word and character size; its 32-bit words were large enough for floating point numbers where the 1900 needed at least two words. The eight-bit byte of the System/360 allowed manipulation of lowercase characters without the complex shift sequences of the 1900. However, in the early days the smaller word size of the 1900 was seen as a cost advantage, as the memory could be 25% cheaper for the same number of words.

1900 range

Initial range

The initial range of machines was:
The execution time for an addition instruction ranged from 2.5 μs for a 1906 or 1907 with 1.1 μs core store, to 34 μs for a 1901 with 6 μs core store.
All machines except the 1901 were operated from a modified Teletype Model 33 ASR used to give commands to the executive. The 1901 was operated from console switches, with a console available as an optional extra.
A range of peripherals was available, including 80-column card punches and readers, 8 track paper tape punches and readers and solid barrel line printers. Data could be stored on half-inch magnetic tape. Magnetic disk storage became available in 1966.

The 1900 E/F series

In 1968 ICT introduced the E series machines:
Improvements to the memory subsystems of these machines, replacing the 1.8µs core with 0.75µs core, were introduced as the F series.
.

1900 A series

In 1969 the 1900 A series was delivered, replacing the remaining machines from the initial series and the E/F machines. The original discrete germanium semiconductor implementations were replaced by Texas Instruments 7400 series TTL integrated circuits in most of the range and Motorola MECL 10K ECL integrated circuits in the new 1906A. There was a proposal to build a multiprocessor version of the 1906A, the 1908A, which would allow ICL to compete with the large CDC and IBM machines in Universities and research centers but it was eventually abandoned in favor of accelerating work on the New Range which was being designed to replace both the 1900 series and the ICL System 4.
With the A series a hardware floating point unit was made an optional feature of all machines, instead of having a different model number for floating point equipped machines.
The 22-bit addressing mode and extended branch mode introduced by the 1906 was extended to the 1902A and 1903A, but not the much smaller 1901A.
ICL introduced a paging unit to the higher end machines and a new version of the GEORGE operating system, GEORGE 4 which was compatible with GEORGE 3 but used paged virtual memory in place of the simple base/limit system of the earlier machines.
In April 1971 ICL announced the S series of machines, replacing the core store of the earlier machines with semiconductor memory in most of the range and very fast Plessey nickel plated wire memory for the top of the range 1906S.
As the larger models of the new range were being introduced it was decided that the lower models of the 1900 range were becoming uncompetitive. To refresh the range new models were released. In each case the model was simply based on the next higher model of the previous range, the 1903T being based on the 1904S for example.
During and after the production of the 1900 series a number of compatible machines were produced by ICL licensees, and competitors.

2903/2904

In 1969 IBM had introduced the System/3 entry-level machine, which began to cut into sales of the ICL 1901 and 1902 models. To recapture the market an ICL project known internally as PF73 was started, based on an ICL Stevenage-developed microprogrammed machine known as MICOS-1. PF73 was eventually sold in 1973 as the ICL 2903 and 2904; despite their New Range numbering these machines used the ICL 1900 instruction set and ran 1900 software. The 2903/2904 were released with an RPG compiler to better compete with System/3. It was a major commercial success; almost 3000 machines were sold.

ME29

Based on a fully microprogrammed CPU, the Stanford EMMY commercialised by Palyn Associates, the ME29 was sold as a replacement for the 2903 and 2904, still executing the 1900 order code.
An EMMY processor emulating the IBM 360 order code was estimated to be around the speed of an IBM System/360 Model 50, implying that the ME29 was faster than the original ICT 1904, approaching the speed of the ICT 1906.

IBM 370/145

In an effort to increase sales to ICL customers, and to profit from the difficulties ICL were having moving customers from the 1900 to the New Range, IBM introduced a microcode package for the 370/145 allowing execution of 1900 series programs.

Odra 1300 series

The Odra 1300 series were a range of 1900 compatible machines built by Elwro in Wrocław, Poland between 1971 and 1978. By agreement with ICL the Odra machines ran standard ICL software.

ICL 2900 (New Range) systems

Second generation "S3E" versions of the larger New Range systems, could run 1900 series code under DME as an emulation as well as the New Range instruction set under the newer VME. Later CME microcode was developed, which allowed DME and VME to co-exist concurrently on the same platform, similar to the functionality offered by virtualisation software such as VMware today.

Operating systems

Executive

The FP6000 ran under the control of operators executive, a simple operating system that allowed the operator using the system console to load programs from magnetic tape, cards or paper tape, allocate peripherals to programs and attribute priorities to running programs. Executive performed all the I/O operations on behalf of user programs, allowing allocation of different peripherals as needed.
Despite its simplicity executive was, for the time, quite powerful, allocating memory to programs as needed. This was possible because the FP6000 design contained hardware to aid multi-programming, datum and limit registers which made programs address independent and avoided one program accessing the memory allocated to another.
To allow more efficient use of peripherals, as well running multiple programs simultaneously, executive allowed a limited multi-threading within programs.
An extended version of the FP6000 executive was provided with the ICT 1904/1905, and new versions were written for the ICT 1906/7 and ICT 1901/2/3. An important task of these different versions was to hide the hardware differences between the different machines, providing emulation of missing instructions as extracodes. The concept was that applications, and later operating systems, were written to run on the combination of the hardware and the executive, and so would run on any member of the series, no matter how different the underlying hardware was.
With the introduction of magnetic disk systems executive became more complex, using overlaying to reduce its memory footprint. Disk based executives included features to simplify disk operations, handling file management on behalf of user programs. Files were identified by 12 character names and a user program did not need to know which physical disk was being used for a file.

GEORGE

In December 1964 ICT set up an Operating Systems Branch to develop a new operating system for the 1906/7. The branch was initially staffed with people being released by the end of work on the OMP operating system for the Ferranti Orion. The initial design of the new system, named George in part after George E. Felton, head of the Basic Programming Division, was based on ideas from the Orion and the spooling system of the Atlas computer.
The initial versions, George 1 was a simple batch processing system. Job descriptions were read in from cards or paper tape, peripherals and magnetic tape files were dynamically allocated to the job which was then run, producing output on the line printer.
George 2 added the concept of spooling. Jobs and input data were read in from cards or paper tape to an input well on disk or tape. The jobs were then run, writing output to disk or tape spool files, which were then written to the output peripherals. The input/processing/output stages were run in parallel, increasing machine utilisation. On larger machines it was possible to run multiple jobs simultaneously.
George 1 and 2 ran as simple programs under executive. George 3 was a complete operating system in itself, it used a much reduced executive responsible only for handling low level hardware access. George 3 implemented both batch processing and Multiple online programming – interactive use from terminals.
George 4 was introduced with the availability of paging hardware on the later machines and implemented paged virtual memory instead of the simple swapping used by George 3.

Minimop and Maximop

Programming languages

ICT initially provided the PLAN assembly language and later the "big three" high-level languages: ALGOL 60, COBOL and FORTRAN 66.
The compilers were released in various versions, of increasing sophistication. Initially paper tape and cards were used for input and output; later magnetic tape and finally disk files. The first versions of the compilers ran in very limited space, starting around 4K words for PLAN and NICOL and as little as 16K words for FORTRAN and ALGOL. Later versions for the George 3 and 4 operating systems expanded to sizes as large as 48K words.
Other languages available included:
Like many contemporary machines much application software was bundled with the basic system, including the compilers and utility programs. Other software was available as paid options from ICT or other sources, including such exotic packages as Storm Sewer Design and Analysis.