SIMMON ("SIM"ulation "MON"itor) was a
proprietary software testingsystem developed in the late 1960s in the IBM Product Test Laboratory, then at Poughkeepsie, N.Y. It was designed for the then-new line of System/360 computers as a vehicle for testing the software that IBM was developing for that architecture.SIMMON was first described at the IBM "SimSymp 1968" symposium, held at Rye, New York. [Lehman MM (ed) "Proc. SimSymp 1968", IBM Res. Div., Yorktown Heights, NY; Nov. 1968, 3 vols.]
SIMMON was a
hypervisor, similar to the IBM CP-40system that was being independently developed at the Cambridge Scientific Centerat about that same time. The chief difference from CP-40 was that SIMMON supported a single virtual machinefor testing of a single guest programrunning there. CP-40 supported many virtual machines for time-sharingproduction work. CP-40 evolved by many stages into the present VM/CMS operating system. SIMMON was a useful test vehicle for many years.
SIMMON was designed to dynamically include independently developed programs (test tools) for testing the target guest program. The SIMMON kernel maintained control over the hardware (and the guest) and coordinated invocation of the test tools.
Two modes of operation were provided:
# Full simulation
Full simulation mode
In this mode, each instruction in the
guest programwas simulated without ever passing control directly to the guest. As an Instruction Set Simulator, SIMMON was unusual in that it simulated the same architecture as that on which it was running, i.e. that of the IBM System/360/370. While an order of magnitude slower than Interrupt mode (below), it allowed close attention to the operation of the guest. This would be the mode used by various instruction tracetest tools.
Interrupt mode (a/k/a Bump mode) constrained the
guest programto run in user program state, with the SIMMON kernal handling all hardware interrupts and simulating all privileged instructions the guest attempted to execute. This mode could be used, for example, by a test tool to simulate hardware devices.
ome SIMMON test tools
These were some test tools that were developed for use with SIMMON.
("ER"ror "GEN"eration and "T"est)This test tool was developed to test the device support error recovery in IBM's PCP (Primary Control Program) operating system, then being developed. It used a novel and very efficient
table-driven finite state machine(FSM) to inject simulated errors and verify that the operating system followed the detailed specifications of actions to be taken to attempt recovery.
The table driven FSM aspect was granted U.S.
Patent[http://xrint.com/patents/us/3702007 3,702,007] in October, 1972.
MAPPER was a
statistical performance analysistool.It operated by allowing the program under test to run in Interrupt mode, but also used the system timer to periodically interrupt it. The addresses where the tested program was interrupted were recorded and later summarized and tabulated in the form of a map, showing the density of interrupts over the memory addresses. The result resembled nuclear scintigraphy images, showing the parts of the program most frequently used under the test conditions.
HOTSPOTS was an
instruction tracetool written to help identify performance problem areas in IBM's MFT operating system. Branch tracedata was written to tape, then summarized. The report took the form of a listing similar to a storage dump, with program entry points and exit points identified, including frequency of use for each instruction sequence.
These data identified the Memory Management component as consuming about 20% of CPU resources, and was used to justify a
task forceto try to improve the performance.
While not a specific test tool, the distorted timing relationships while running under SIMMON found a number of problems, particularly in the
input/outputsections. Unless a SIMMON tool was put in place to normalize and delay I/O events, these would appear to the guest program as happening unnaturally quickly.
Programs under test -- so-called "guest programs" -- had to be capable of stand-alone operation on the bare hardware. SIMMON provided services for the test tools, but not the guest.
These were some of the programs that had been run under SIMMON:
Customer Engineer(CE) stand-alone diagnostic programs
DOS/360(including BOS and TOS)
OS/360(PCP. MFT and MVS)
* A number of Product Test tools
* SIMON -- a similar program, independently developed, with an amazingly similar name!
Wikimedia Foundation. 2010.