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:
399:
312:
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.
140:
54:
217:
was developed in the early 1970s by the
Computation Center of the Rand Corporation in Santa Monica, CA. It was implemented using the
417:
432:
427:
310:
The Rand RL/S language and compiler were publicly announced in August, 1976, at a Share meeting where numerous copies of the
76:
47:
359:, International Business Machines Corp., 1968, Z28-6642-0. Note that BSL was renamed PL/S and replaced by PL/S II
156:
274:
Rand’s interest in PL/S derived from extensive modifications that the
Computation Center had made to IBM’s
240:
176:
152:
259:) and was an early pioneer in the definition and development of “packet switching” network technology (
164:
37:
354:
41:
33:
58:
422:
275:
342:
191:
operating system, and PL/DS II was a port of the S/370 architecture for the DPPX/370 port.
97:
8:
136:
148:
125:
183:
Closed PL/S meant that only IBM could easily modify and enhance the operating system.
117:
256:
247:
Rand has been a long-time contributor to computer research and development (e.g.,
386:
160:
121:
382:
Proceedings of the SIGPLAN symposium on
Languages for system implementation 1971
260:
373:
411:
188:
172:
203:
377:
252:
279:
285:
404:, The Rand Corporation, The Rand Computation Center, R-1555/11 1977
268:
264:
168:
132:
221:
compiler generator system by a team of three Rand programmers (
337:
303:
248:
101:
208:
RL/S announcement button distributed by Rand at Share 1976
233:
218:
105:
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
322:
290:
PL/S "please" button distributed by Share attendees
131:Early projects using PL/S were the batch utility,
409:
46:but its sources remain unclear because it lacks
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
198:
77:Learn how and when to remove this message
284:
202:
410:
239:RL/S is fully compatible with IBM’s
18:
13:
108:in the late 1960s, under the name
14:
444:
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
348:
155:(National Advanced Systems),
94:Programming Language/Systems
7:
356:BSL Language Specifications
331:
96:, is a "machine-oriented"
10:
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:
436:
435:
430:
425:
420:
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:
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:
344:
341:
339:
336:
335:
329:
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:
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:.
Text is available under the Creative Commons Attribution-ShareAlike License. Additional terms may apply.