Knowledge (XXG)

IBM PL/S

Source đź“ť

299:, IBM, however, refused to provide its PL/S compiler to customers, claiming it was a significant competitive advantage.  Not having the compiler meant that neither competitors nor customers could modify the MVS code at the PL/S source level, and could only modify the generated assembler code.  However, modifications made at the generated assembler level were easily obsoleted when IBM modified the PL/S source code and distributed re-generated assembler code. This was particularly true of modifications to PL/S generated data structures.  Rand, therefore, decided to develop its own version of a PL/S compiler to meet both operational objectives and contractual commitments. 25: 204: 286: 328:
of its licensed intellectual property is not known. The phase names of this PL/S compiler were the same as the corresponding phase names of IBM's PL/I Optimizer compiler, with the initial "I" (IBM) in each phase name being replaced by an initial "J" (Japan). All IBM copyright notices (source and object) within the modules were deleted to hide their true origin and ownership.
282:” was developed to allow Arpanet interrupts to be handled by specially written code while all other interrupts were handled by MVT.  When the MVS operating system was announced by IBM, Rand volunteered as an early “beta” site for the operating system with the intent of porting the hypervisor and other modifications to MVS. 327:
A fully compliant PL/S compiler was "developed" by Fujitsu Ltd in the late-1970s, adapting IBM's PL/I Optimizer compiler source code as its starting point. This PL/S compiler was used internally by Fujitsu, and also by Fujitsu's external affiliates. Whether or not IBM was aware of this unlicensed use
369:
W.R. Brittenham and B.F. Melkun, "The Systems Programming Language Problem", Proceedings of the IFIP Working Conference on Machine Oriented Higher Level Languages, Trondheim, Norway, August 29–31, 1973, pp. 29–47. Amsterdam: North-Holland Publishing Co.; New York: American Elsevier, 1974. This
243:
language.  This was assured by parsing many thousands of lines of IBM written PL/S code taken from the MVS distribution files.  The assembler language code produced by the Rand RL/S compiler is not identical to the code produced by IBM’s PL/S compiler, but it is functionally equivalent.
318:
were distributed to attendees.  IBM quickly responded claiming the language was “proprietary”.  While Rand admitted no wrong doing in developing RL/S, Rand management agreed not to distribute the compiler publicly.  Rand, however, continued to use the RL/S language and compiler
232:).  The Rand RL/S compiler was developed independently of and without any assistance from IBM.  Only publicly available, non-copyrighted PL/S documentation and PL/S source and generated assembler code examples from IBM distributed source files for the 146:
By the 1970s, IBM was rewriting its flagship operating system in PL/S. Although users frequently asked IBM to release PL/S for their use, IBM refused, saying that the product was proprietary. Their concern was that open PL/S would give competitors,
186:
PL/S was succeeded by PL/S II, PL/S III and PL/AS (Programming Language/Advanced Systems), and then PL/X (Programming Language/Cross Systems). PL/DS (Programming Language/Distributed Systems) was a closely related language used to develop the
179:
vendors a competitive advantage. However, even though they refused to make available a compiler, they shipped the PL/S source code to large parts of the OS to customers, many of whom thus became familiar with reading it.
306:
and later converted to RL/S to improve performance. With few restrictions, RL/S programs could be developed using IBM’s PL/I compiler for preprocessing and debugging, with the final code then compiled by RL/S.
194:
As the market for computers and software shifted away from IBM mainframes and MVS, IBM recanted and has offered the current versions of PL/S to select customers (ISVs through the Developer Partner program.)
370:
paper explores the technical and psychological problems encountered in implementing PL/S. The language and compiler are described. The discussion that followed presentation of the paper is included.
278:, including modifications to improve the performance of the Arpanet on its IBM 360 computer.  Because MVT did not process network interrupts quickly enough to handle the Arpanet traffic, a “ 296: 54: 140: 399: 312: 417: 396:, International Business Machines Corp., 1974. GC28-6794-0 Note that this manual is very out of date with respect to the PL/X language in use today. 432: 427: 217:
was developed in the early 1970s by the Computation Center of the Rand Corporation in Santa Monica, CA.  It was implemented using the
76: 310:
The Rand RL/S language and compiler were publicly announced in August, 1976, at a Share meeting where numerous copies of the
156: 176: 152: 37: 47: 41: 33: 359:, International Business Machines Corp., 1968, Z28-6642-0. Note that BSL was renamed PL/S and replaced by PL/S II 164: 58: 274:
Rand’s interest in PL/S derived from extensive modifications that the Computation Center had made to IBM’s
240: 422: 275: 259:) and was an early pioneer in the definition and development of “packet switching” network technology ( 342: 97: 354: 136: 148: 125: 117: 256: 203: 191:
operating system, and PL/DS II was a port of the S/370 architecture for the DPPX/370 port.
386: 160: 121: 373: 183:
Closed PL/S meant that only IBM could easily modify and enhance the operating system.
411: 188: 172: 285: 247:
Rand has been a long-time contributor to computer research and development (e.g.,
382:
Proceedings of the SIGPLAN symposium on Languages for system implementation 1971
377: 260: 252: 279: 268: 264: 168: 132: 404:, The Rand Corporation, The Rand Computation Center, R-1555/11 1977 337: 202: 303: 248: 101: 221:
compiler generator system by a team of three Rand programmers (
233: 218: 105: 18: 208:
RL/S announcement button distributed by Rand at Share 1976
362:
W.R. Brittenham, "PL/S, Programming Language/Systems",
120:
on internal software projects; it included support for
263:).  Rand was also one of the early nodes on the 290:
PL/S "please" button distributed by Share attendees
131:Early projects using PL/S were the batch utility, 46:but its sources remain unclear because it lacks 8: 267:, the Defense Department’s precursor to the 16:Proprietary IBM systems programming language 380:, "Inferred SYNTAX and SEMANTICS of PL/S", 302:The RL/S compiler was initially written in 366:, GUIDE 34, May 14, 1972, pp. 540–556 215:Rand RL/S compiler for IBM’s PL/S language 77:Learn how and when to remove this message 284: 7: 239:RL/S is fully compatible with IBM’s 108:in the late 1960s, under the name 14: 418:PL/I programming language family 23: 401:RL/S Language Reference Manual 319:internally for many projects. 314:RL/S Language Reference Manual 157:Storage Technology Corporation 1: 433:IBM System/360 mainframe line 428:Systems programming languages 155:(National Advanced Systems), 94:Programming Language/Systems 356:BSL Language Specifications 96:, is a "machine-oriented" 449: 124:and explicit control over 165:Magnuson Computer Systems 116:), as a replacement for 32:This article includes a 61:more precise citations. 323:Fujitsu "Developments" 292: 228:, and the team leader 210: 199:Rand Compiler for PL/S 110:Basic Systems Language 104:. It was developed by 288: 206: 343:High-level assembler 276:MVT operating system 234:MVS operating system 98:programming language 137:Time Sharing Option 390:6(10) October 1971 293: 223:R. Lawrence Clark, 211: 34:list of references 291: 209: 118:assembly language 87: 86: 79: 440: 394:Guide to PL/S II 289: 207: 82: 75: 71: 68: 62: 57:this article by 48:inline citations 27: 26: 19: 448: 447: 443: 442: 441: 439: 438: 437: 408: 407: 387:SIGPLAN Notices 364:Proc GUIDE Intl 351: 334: 325: 226:James S. Reiley 201: 161:Trilogy Systems 122:inline assembly 83: 72: 66: 63: 52: 38:related reading 28: 24: 17: 12: 11: 5: 446: 444: 436: 435: 430: 425: 420: 410: 409: 406: 405: 397: 391: 374:Gio Wiederhold 371: 367: 360: 350: 347: 346: 345: 340: 333: 330: 324: 321: 230:David J. Smith 200: 197: 85: 84: 42:external links 31: 29: 22: 15: 13: 10: 9: 6: 4: 3: 2: 445: 434: 431: 429: 426: 424: 421: 419: 416: 415: 413: 403: 402: 398: 395: 392: 389: 388: 383: 379: 375: 372: 368: 365: 361: 358: 357: 353: 352: 348: 344: 341: 339: 336: 335: 331: 329: 322: 320: 317: 316: 315: 308: 305: 300: 298: 287: 283: 281: 277: 272: 270: 266: 262: 258: 254: 250: 245: 242: 237: 235: 231: 227: 224: 220: 216: 205: 198: 196: 192: 190: 184: 181: 178: 174: 170: 166: 162: 158: 154: 150: 144: 142: 138: 134: 129: 127: 123: 119: 115: 111: 107: 103: 99: 95: 91: 81: 78: 70: 60: 56: 50: 49: 43: 39: 35: 30: 21: 20: 423:IBM software 400: 393: 385: 381: 363: 355: 326: 313: 311: 309: 301: 294: 273: 246: 238: 229: 225: 222: 214: 212: 193: 185: 182: 175:, and other 145: 130: 113: 109: 93: 92:, short for 89: 88: 73: 64: 53:Please help 45: 378:John Ehrman 295:As is well 253:Rand tablet 236:were used. 59:introducing 412:Categories 349:References 297:documented 280:hypervisor 135:, and the 67:April 2010 100:based on 332:See also 269:Internet 126:register 265:Arpanet 241:PL/S II 173:Hitachi 169:Fujitsu 143:, TSO. 133:IEHMOVE 128:usage. 55:improve 257:WYLBUR 251:, the 149:Amdahl 384:, in 338:PL360 261:Baran 40:, or 376:and 304:PL/I 249:JOSS 213:The 189:DPPX 153:Itel 102:PL/I 90:PL/S 219:XPL 177:PCM 141:MVT 139:of 114:BSL 106:IBM 414:: 271:. 255:, 171:, 167:, 163:, 159:, 151:, 44:, 36:, 112:( 80:) 74:( 69:) 65:( 51:.

Index

list of references
related reading
external links
inline citations
improve
introducing
Learn how and when to remove this message
programming language
PL/I
IBM
assembly language
inline assembly
register
IEHMOVE
Time Sharing Option
MVT
Amdahl
Itel
Storage Technology Corporation
Trilogy Systems
Magnuson Computer Systems
Fujitsu
Hitachi
PCM
DPPX

XPL
MVS operating system
PL/S II
JOSS

Text is available under the Creative Commons Attribution-ShareAlike License. Additional terms may apply.

↑