Cray Operating System
The Cray Operating System (COS) is a Cray Research operating system for its now-discontinued Cray-1 (1976) and Cray X-MP supercomputers. It succeeded the Chippewa Operating System (shipped with earlier Control Data Corporation CDC 6000 series and 7600 computer systems), and was the Cray main OS until replaced by UNICOS in the late 1980s. COS was delivered with Cray Assembly Language (CAL), Cray FORTRAN (CFT), and Pascal.
|  | |
| Developer | Cray Research[1] | 
|---|---|
| Working state | Discontinued | 
| Initial release | 1975[1] | 
| Latest release | 1.17.2 / July 1990 | 
| Marketing target | Supercomputers | 
| Available in | English | 
| Platforms | Cray-1, Cray X-MP line | 
| Influenced by | CDC SCOPE | 
| License | Proprietary | 
| Preceded by | Chippewa Operating System | 
| Succeeded by | UNICOS | 
Design
    
As COS was written by ex-Control Data employees, its command language and internal organization bore strong resemblance to the CDC SCOPE operating system on the CDC 7600 and before that EXEC*8 from CDC's earlier ERA/Univac pedigree. User jobs were submitted to COS via front-end computers via a high-speed channel interface, and so-called station software. Front end stations were typically large IBM or Control Data mainframes. However the DEC VAX was also a very popular front-end. Interactive use of COS was possible through the stations, but most users simply submitted batch jobs.
Disk-resident datasets used by a user program were 'local' to the individual job. Once a job completed, its local datasets would be released and space reclaimed. In order to retain the data between jobs, datasets had to be explicitly made 'permanent'. Magnetic tape datasets were also supported on Cray systems which were equipped with an I/O Subsystem.
COS also provided job scheduling and checkpoint/restart facilities to manage large workloads, even across system downtimes (both scheduled and unscheduled.)
Internally, COS was divided into a very small message-passing EXEC, and a number of System Task Processors (STP tasks). Each STP task was similar in nature to the peripheral processor programs in earlier Control Data operating systems, but since the Cray machines did not have peripheral processors, the main central processor executed the operating system code.
List of STP tasks
    
| STP Task | Description | 
|---|---|
| Z, ZY | Startup Prep | 
| STARTUP | Startup | 
| EXP | User Exchange Processor | 
| MSP | Message Processor | 
| DQM | Disk Queue Manager | 
| TQM | Tape Queue Manager | 
| JSH | Job Scheduler | 
| PDM | Permanent Dataset Manager | 
| JCM | Job Class Manager | 
| SCP | Station Call Processor | 
While the source for version 1.13 was released as public domain, 1.17 is available at archive.org.[2]
