Houston Automatic Spooling Priority Explained

See also: Spooling.

The Houston Automatic Spooling Priority Program, commonly known as HASP, is an extension of the IBM OS/360 operating system and its successors providing extended support for "job management, data management, task management, and remote job entry."

History

OS/360 included spooling routines, called reader/interpreters and output writers.[1] Each reader/interpreter was "responsible for reading one input job stream" – that is one input device. Likewise each output writer was responsible for controlling one printer or punch. Spooled data were stored in OS temporary datasets controlled by standard OS services. Each reader/interpreter or output writer was a separate operating system task in its own partition or region.[2] A system with a large number of readers, printers, and punches might have a large number of spooling tasks.

HASP was developed by IBM Federal Systems Division contractors at the Lyndon B. Johnson Space Center in Houston. The developers were Tom Simpson and Bob Crabtree. HASP was a program that ran on a mainframe, and performed functions such as: scheduling, control of job flow, spooling and printing/punching. HASP had no support for IBM System/360 Operating System Remote Job Entry, 360S-RC-536, but provided roughly equivalent facilities of its own.

In HASP II V3, Roger Fajman, Bill Jones, and Jim Oberthaler of NIH created the shared spool capability for HASP that was used by many mainframe sites. It allowed each HASP system to share a common spool and checkpoint. This enabled workload balancing in a multi-mainframe environment. In HASP II V4, Don Greb and Dave Miko of Mellon Bank moved shared spool to this version. Roger Fajman and Bill Jones of NIH carried it forward into JES2 multi-access spool (IBM's formal support of HASP in MVS). Over 350 copies of the HASP II V4 shared spool mods were distributed around the world. The shared spool Mellon Mods were added to the SHARE distribution process so they could be more widely accessed.

The program was sometimes referred to under various other names, but there is no indication of IBM ever using them in official documents.

The program became classified as part of the IBM Type-III Library. It had a competitor, ASP (Attached Support Processor), which ran on one mainframe and controlled scheduling of other attached mainframes. ASP later became JES3.

In MVS, HASP became JES2, one of two Job Entry Subsystems. It was many years before the HASP labels were removed from the JES2 source, and the messages issued by JES2 are still prefixed with "$HASP".

A modified version of HASP was used to provide batch spooling and remote job entry services for the Michigan Terminal System during the late 1960s, 1970s, and 1980s.[3] [4]

Program organization

HASP bypassed most operating system services with code specially tailored for efficiency. HASP operated as a single operating system task[5] and used cooperative multitasking internally to run processors to perform tasks such as running card readers, printers, and punches, managing the spool files, communicating with the system operator, and driving multiple communication lines for remote job entry.

Hasp was written entirely in System/360 assembler and a typical HASP system might require 86KB of memory, which could be virtual memory on OS/VS systems.[6]

pre-JES JECL

Much of what would become JES2's JECL was a part of HASP.

Remote job entry

Hasp originally supported IBM Synchronous Transmit-Receive (STR) batchterminals; however, HASP II dropped support for STR and only supported theBinary Synchronous Communications (BSC) protocol. HASP II supportedIBM terminals such as2770,2780,3770,3780,but additionally provided support for multi-leaving[7] communication with intelligent workstations such as the IBM 1130, IBM System/3 and the System/360 Model 20. Multi-leaving is "fully synchronous, pseudo-simultaneous, bi-directional transmission of a variable number of data streams between two or more computers utilizing binary-synchronous communications facilities."[5]

Third party vendors developed a variety of 2770/2780/3780 simulators and Multi-leaving implementations for use with HASP and ASP. Some of these vendors incorrectly referred to their products as HASP emulators, but the products were actually terminals that talked to HASP; they did not perform any of the functions of HASP.

Operator Commands

The RJE console operator could enter a restricted set of HASP Console Operator Commands. These HASP commands were the precursor of JES2's Job Entry Control Language (JES2 JECL).

Operands were restricted to those from this remote site, hence DJ1-999 (below) would only display typically a few, those still outstanding from the operator's remote site.

Some of the HASP RJE Console commands, which could be entered in short (single letter) form, or spelled out, are:

data-sort-type="text"Shortdata-sort-type="text"LongOperand(s)Example
data-sort-value="E"Edata-sort-value="restart"restartdevice_name E rm1.rdr
data-sort-value="Z"Zdata-sort-value="stop"stopdevice_nameZ rm1.pr1
data-sort-value="D"Ddata-sort-value="display"display(J,I,& others)e.g.
data-sort-value="DJ"DJdata-sort-value="display job"display jobJob Number (or range)DJ345 or DJ1-999
data-sort-value="DA"DAdata-sort-value="display active"display active(displayed active jobs)DA
data-sort-value="DI"DIdata-sort-value="display initiators"display initiators(displayed initiator letters)DI
data-sort-value="C"Cdata-sort-value="cancel"cancel(Job or device_name)e.g.
data-sort-value="c J"CJdata-sort-value="cancel job"cancel jobJob NumberCJ678
data-sort-value="c"Cdata-sort-value="cancel"canceldevice_nameC rm1.rdr

A command line "C rm1.rdr" was meant to cancel rather than submit the current deck of cards being read. This might have been of use if a card jam made it more sensible to let other jobs go ahead while one or more cards were replaced at a nearby keypunch.

Job log

HASP job log output provided a summary of the resources used for the job (output appeared in all caps):

See also

References

Notes and References

  1. IBM . IBM Operating System/360 Concepts and Facilities . C28-6535-0 . 1965 . 59–62 .
  2. However, RJE and the later CRJE called the Reader/Interpreter as a subroutine and performed the functions of an output writer within its own partition/region.
  3. https://docs.google.com/file/d/0B4t_NX-QeWDYNWRmNjE3OTQtYjk4Yy00ZTFlLWJjYTEtMjU5MDUxMmU0YjQ0/edit?pli=1 HASP II (MTS Version) Operator's Guide
  4. http://hdl.handle.net/2027/mdp.39015072618724?urlappend=%3Bseq=23 "Resource Manager Printing Comes to U-M (replacing HASP)"
  5. IBM . OS/VS2 HASP II Version 4 Logic, Program Number 370H-TX -001 . GY27-7255-0 . March 1973 . First Edition, Revised September 15, 1976, by TNLs SN25-0122 and SN27-1555 .
  6. IBM . OS/VS2 HASP II Version 4 System Programmer's Guide, Program Number 370H-TX-001 . GC27-6992-0 . March 1973 . First Edition revised September 15, 1976, by TNLs GN25-0121 and GN27-1553 .
  7. OS/VS2 HASP II Version 4 Logic - Program Number 370H-TX-001 VS2 - SVS Release 1.7 . GY27-7255 . March 1973 . First Edition, Revised September 15, 1976, by TNLs SN25-0122 and SN27-1555 . Appendix B MULTI-LEAVING . http://bitsavers.org/pdf/ibm/370/hasp/GY27-7255-0_HASP_II_Version_4_Logic_Sep76.pdf#page=493 . 7-59-7-68 . March 17, 2022 . IBM .