Talk:IBM System/370

Latest comment: 5 months ago by Guy Harris in topic Multiple operating systems

Separate pages for the S/370 family and the S/370 architecture?

edit

We have two separate pages for S/360 - IBM System/360, which talks about the history of S/360, enumerates models, gives release dates, etc., and IBM System/360 architecture, which purely discusses architectural details, mentioning only the Models 20, 44, and 67 in passing because of their exceptions/extensions.

Should we do something similar for S/370?

A similar split for the 64-bit machines arguably exists, with IBM Z and z/Architecture. Guy Harris (talk) 06:54, 28 December 2020 (UTC)Reply

Yes, if someone is willing to do the work a split is desirable. Shmuel (Seymour J.) Metz Username:Chatul (talk) 05:18, 1 January 2021 (UTC)Reply

I/O Evolutions

edit

There is an I/O Evolutions section, but it does not discuss the I/O changes in the S/360 line and has a {{main article|IBM System/360#Channels}} hatnote; It does not discuss, e.g., channel set switching, 4.5 MB/s B&T, ESCON, FICON, the new channel susbsystem of XA; essentially the section only discusses what changed from the initial S/360 to the initial S/370. Shmuel (Seymour J.) Metz Username:Chatul (talk) 05:34, 1 January 2021 (UTC)Reply

@Chatul: good point. I added ESCON to the section and will add FICON later. Note I had to first improve ESCON before linking here. May I suggest u take a hack at the other evolutions? Tom94022 (talk) 18:18, 1 January 2021 (UTC)Reply

Unexplained change to citation

edit

@Guy Harris: Edit https://en.wikipedia.org/w/index.php?title=IBM_System/370&oldid=1153105243 changed a citation for the block multiplexor channel from section Types of Channels on pages 13-4 – 13-5 of PoOps to Start I/O Fast Release on pages 26-27. The new citation belongs on Start-I/O-Fast Queuing, not on the block mx channel. The original {{sfn}} should have specified the URL http://bitsavers.org/pdf/ibm/370/princOps/GA22-7000-10_370_Principles_of_Operation_Sep87.pdf#page=355 for the -11 PoOps but was otherwise appropriate. The -0 PoOps does not include the relevant material, although a citation of the channel to CU OEMI[1] would have been legitimate. -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 12:16, 4 May 2023 (UTC)Reply

So the problem is that IBM didn't give enough details about block multiplexor channels in the -0 PoOps? Guy Harris (talk) 19:06, 4 May 2023 (UTC)Reply
I guess so - the first edition is, according to its cover, a manual that "describes extensions to the functional design of the System/360 that are incorporated in models of the System/370", so it's an addendum to a (sufficiently-recent) S/360 Principles of Operation, rather than a full independent Principles of Operation manual, as later editions (which had a lot more "extensions" to describe, such as "I haz MMUDAT box").
I'm not sure why they didn't describe block multiplexor channels, though. For what it's worth, the 2880 Block Multiplexor Channel was announced in February 1970 for the Models 85 and 195; the Model 85 was announce in 1968 and shipped in late 1969, so that was before the announcement of the first block multiplexor channel, and System/370 was announced in June 1970, which was after the announcement of the first block multiplexor channel. The block multiplexor channel appears to be mentioned in "IBM's 360 and Early 370 Systems" only in a footnote, and that book also speaks of S/370 being intended to come out in two phases, with phase 1 being a "small delta from S/360" (and a smaller delta from S/360 Model 85) phase and phase 2 being the larger "now with added DAT!" phase, so perhaps either 1) the block multiplexor channel was a late addition and there wasn't time to document it more fully, 2) they documented it in a manual about the 2880, or 3) they thought it wasn't important enough to mention in the first edition and deferred it to a later edition that was a stand-alone Principles of Operation for phrase 2.
In any case, I've updated the reference to point to the Eleventh Edition section describing block multiplexor channel operation. Guy Harris (talk) 10:04, 13 May 2023 (UTC)Reply
Right pages, wrong section - I've corrected that. Meanwhile, I ran into a problem: {{snd}} was displaying what looked like an HTML character attribute; I'm assuming that under some circumstances it doesn't generate trailing semicolns. IAC, I used a - to bypass the problem. -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 01:24, 14 May 2023 (UTC)Reply

References

  1. ^ IBM System/360 and System/370 I/O Interface - Channel to Control Unit - Original Equipment Manufacturers' Information (PDF) (Tenth ed.). IBM. June 1968. GA22-6974-09. Retrieved May 4, 2023. {{cite book}}: |work= ignored (help)

Multiple operating systems

edit

The statement The 390, which was based on a new ESA/390 model, expanded the multiple memory concept to include full hardware virtualization that allowed it to run multiple operating systems at the same time. is anachronistic; Virtual Machine Facility/370[a] (VM/370) allowed running multiple operating systems on the same machine in 1972 and PR/SM on the 3090 offered similar support in 1988 as a processor option, while ESA/390 didn't come out until 1990.

There were certainly incremental improvements in PR/SM for S/390, but the basic capability had been around for two decades. -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 17:55, 26 April 2024 (UTC)Reply

Perhaps that's referring to the ESA/370 (not 390) interpretive-execution facility, with the SIE instruction. But even that wasn't a requirement to "run multiple operating systems at the same time"; that was done on boring old IBM System/360 Model 67 machines, with only the MMU and the privileged operation exception as hardware assists. Guy Harris (talk) 22:57, 5 May 2024 (UTC)Reply
Maybe he was thinking of PR/SM, which looks as if it came out at the same time as ESA/370 on the "E" models of the IBM 3090. I think that's the first hypervisor that ran below the Principles of Operation+SIE etc. level, rather than running atop that level. But, again, that's ESA/370, not ESA/390. Guy Harris (talk) 23:09, 5 May 2024 (UTC)Reply
Actually, the implementation of PR/SM on the 3090 has a custom version of CP running under the covers, and it uses SIE. — Preceding unsigned comment added by Chatul (talkcontribs) 14:30, 6 May 2024 (UTC)Reply
unning under the covers T's what I meant by "running below...". "+SIE" means "I don't remember whether the Principles of Operation include SIE or not, and I'm too lazy to look it up in the ESA/370 Principles of Operation, so I'll add it."
Looking at the ESA/370 Principles of Operation on Bitsavers, it looks as if it mentions the interpretive-execution facility in passing and points the reader to IBM 370-XA Interpretive Execution, SA22-7095. It dates back to the 370-XA era, so it's not the feature that supports full hardware virtualization.
But I just noticed that what the article says is

The 390, which was based on a new ESA/390 model, expanded the multiple memory concept to include full hardware virtualization that allowed it to run multiple operating systems at the same time.

(italics mine). I'm not sure what "the multiple memory concept" is; about the only thing that comes to mind is the multiple address space concept. IBM Enterprise Systems Architecture § ESA/390 architecture says

A machine may be divided into Logical Partitions (LPARs), each with its own virtual system memory so that multiple operating systems may run concurrently on one machine.

which seems to suggest that LPARs are new with ESA/390. However, the ESA/390 Principles of Operation speaks of LPARs as having been introduced with ESA/370, so I'll fix that. Perhaps that's the source of the confusion. Guy Harris (talk) 18:56, 6 May 2024 (UTC)Reply
The vast majority of the code in CP uses the instructions in PoOps, although in a few cases PoOps defines parameters to be model dependent. SIE has its own manual, and only the initial version is available to the general public.
BTW, does IBM consider PR/SM to be part of ESA? -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 16:13, 7 May 2024 (UTC)Reply
SIE has its own manual, and only the initial version is available to the general public. So PR/SM may use some facility that's not a fully-specified part of the architecture.
BTW, does IBM consider PR/SM to be part of ESA? It doesn't appear to be mentioned in the first edition of the ESA Principles of Operation. However, the ninth edition of the ESA/390 Principles of Operation says, in the "The ESA/370 and 370-XA Base" section of Chapter 1, that
The facilities that were new in ESA/370 are as follows:
...
The Processor Resource/Systems Manager* (PR/SM*) feature provides support for multiple preferred guests under VM/XA and provides the logically partitioned (LPAR) mode, with the latter providing flexible partitioning of processor resources among multiple logical partitions. Certain aspects of the LPAR use of PR/SM are described in the publication IBM ES/3090 Processor Complex Processor Resource/Systems Manager Planning Guide, GA22-7123.
Perhaps a later edition of the ESA/370 Principles of Operation mentioned it as being part of the architecture.
The impression I have is that, starting at least with the 3090, there are layers of the architecture are implemented by "licensed internal" machine code (or whatever they've called it in the past), rather than hardware or microcode. The CMOS processors implement some instructions and facilities in millicode, and some processors had another layer atop that with "i370" or "i390" code (I've seen at least one mention to "i390" code in z/Architecture machines); PR/SM is, I think, another such layer. Guy Harris (talk) 17:24, 7 May 2024 (UTC)Reply
Microcode, millicode and the version of CP used by PR/SM are all licensed internal code. Basically, any code loaded from the internal 3370 drives is LIC. -- Shmuel (Seymour J.) Metz Username:Chatul (talk) 09:05, 8 May 2024 (UTC)Reply
Microcode, millicode and the version of CP used by PR/SM are all licensed internal code. As, presumably, is the i370/i390 code. I think i370 originated in a multichip microprocessor designed at IBM Böblingen for some 9370 models.[1][2] i390 is presumably the equivalent for 390 machines; IBM appear not to have used "iz" or whatever for the z/Architecture machines, sticking with "i390".[3][4][5] (I'd love to see the equivalent of datasheets for the various CMOS single-chip CPUs, indicating what happens on power-on reset, as well as an internal description of the LIC and the way it's loaded - is there a boot ROM?)
Basically, any code loaded from the internal 3370 drives is LIC. Or from the equivalent storage, e.g. flash memory on more modern machines. Guy Harris (talk) 18:19, 8 May 2024 (UTC)Reply

Notes

  1. ^ To say nothing of CP-67, which was available earlier on the S/360-67.

References

  1. ^ Wilhelm Spruth, ed. (6 December 2012). "7.2 High Level Microprogramming in I370". The Design of a Microprocessor. Springer-Verlag. ISBN 978-3-642-74918-6.
  2. ^ "i370 - A New Dimension of Microprogramming". ACM SIGMICRO Newsletter. pp. 24–31. doi:10.1145/62185.62189.
  3. ^ "Open-standard development environment for IBM System z9 host firmware". IBM Journal of Research and Development. 51 (1/2): 195–205. January 2007.
  4. ^ "System z Architecture" (PDF).
  5. ^ "IBM System z10 Introduction and Hardware Overview" (PDF).