IBM System/38

Revision as of 04:50, 26 May 2025 by imported>OAbot (Open access bot: url-access updated in citation with #oabot.)
(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)

Template:Short description

Template:Infobox information appliance The System/38<ref name=S38.NYT1986>Template:Cite news</ref><ref name=S38.PriceCutsNYT82>Template:Cite news</ref> is a discontinued minicomputer and midrange computer manufactured and sold by IBM. The system was announced in 1978.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> The System/38 has 48-bit addressing, which was unique for the time, and a novel integrated database system. It was oriented toward a multi-user system environment. At the time, the typical system handled from a dozen to several dozen terminals. Although the System/38 failed to displace the systems it was intended to replace, its architecture served as the basis of the much more successful IBM AS/400.<ref name="inside-as400" /><ref name="schleicher-interview" />

HistoryEdit

The System/38 was introduced on October 24, 1978 and delivered in 1980. Developed under the code-name "Pacific", it was made commercially available in August 1979. The system was designed by a number of engineers including Frank Soltis and Glenn Henry and offered a number of innovative features. The architecture shared many similarities with the design of the failed IBM Future Systems project, including the single-level store, the use of microcode to implement operating system functionality, and the Machine Interface abstraction.<ref name="inside-as400" /><ref name="schleicher-interview">Template:Cite interview</ref><ref name="henry-interview">Template:Cite interview</ref> It had been developed over eight years by IBM's laboratory in Rochester, Minnesota.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> The president of IBM's General Systems Division (GSD) said at the time: "The System/38 is the largest program we've ever introduced in GSD and it is one of the top three or four largest programs ever introduced in IBM."<ref name="s/38-ibm-archives">{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

The system was designed as a follow-on for the System/3,<ref name="s/38-ibm-archives"/> but it is not compatible with those computers. The predecessors to the System/38 include the System/3 (1969), System/32 (1975), and System/34 (1977). In 1983 the System/36 was released as a low-end business computer for users who found the System/38 too expensive for their needs. The System/38 was succeeded by the IBM AS/400 midrange computer family in 1988, which originally used a processor architecture similar to the System/38, before adopting PowerPC-based processors in 1995.<ref name="inside-as400" />

Hardware characteristicsEdit

Template:Multiple image The IBM 5381 System Unit contains processor, main memory, disk storage, a diskette magazine drive, and a system console with keyboard and a display. 5381 was available in Model 100 and Model 200.

The IBM 5382 System Unit is physically identical to 5381, but with more powerful processors, more memory, and more disk storage. 5382 was available in Models 300, 400, 500, 600, and 700.

Users typically interacted with the system through IBM 5250 series terminals. In 1984, IBM added the ability to attach graphics-oriented terminals that previously required a mainframe.<ref>Template:Cite news</ref>

Processing unitEdit

The system includes a central processing unit with 512K, 768K, 1024K, 1280K, or 1536K bytes of main storage. The processor is implemented across twenty-nine Schottky TTL LSI chips mounted on a 10x15" circuit board.<ref name="technical-developments" /> It includes a memory management unit supporting demand paging, used by the system software to implement a single-level store architecture.

The System/38 CPU features a 48-bit address space, which was selected as a compromise between 64-bit addressing, which certain IBM engineers wanted for the sake of future proofing, and 32-bit addressing, which other engineers wanted for cost saving purposes.<ref name="inside-as400" />

System console keyboard/displayEdit

The System/38 console incorporates a keyboard and a display screen with 16 lines of 64 characters, inconsistent with the locally attached 5250 terminals, which are either 12x40 or 24x80, depending on model. The keyboard is available to the system operator to enter Control Language commands.

Diskette magazine driveEdit

The diskette magazine drive is standard on all models.

Software architectureEdit

Machine InterfaceEdit

The System/38 and its descendants use a machine interface architecture to isolate the application software and most of the operating system from hardware dependencies, including such details as address size and register size.

Compilers for System/38 and its successors generate code in a high-level instruction set known as the Machine Interface, or MI. MI is a virtual instruction set; it is not the instruction set of the underlying CPU. MI operates on objects instead of traditional memory addresses or registers.<ref>Template:Cite book</ref>

Unlike some other virtual-machine architectures in which the virtual instructions are interpreted at runtime (see P-code machine), MI instructions are never interpreted. They constitute an intermediate compile time step and are translated into the processor's instruction set as the final compilation step. The MI instructions are stored within the final program object, in addition to the executable machine instructions. If a program is moved from a processor with one native instruction set to a processor with another native instruction set, the MI instructions will be re-translated into the native instruction set of the new machine before the program is executed for the first time on the new machine.

The TIMI (Technology Independent Machine Interface) of OS/400 is a backwards compatible extension of the System/38 MI. As a result, it is possible for a program originally developed on a System/38 to run on current IBM i hardware without ever being recompiled.<ref name="inside-as400" />

MicrocodeEdit

IBM referred to all code below the Machine Interface layer of the System/38 architecture as microcode, and treated it as part of the hardware.<ref name="technical-developments">Template:Cite book</ref> The term microcode was used to cover a wide array of low-level code, ranging from traditional microcode, up to functionality typically associated with the kernels of other operating systems, as well as the implementation of the integrated database.<ref>Template:Cite journal</ref> There were two levels of microcode in the System/38:

  • Horizontal Microcode (HMC), which implemented a register-memory/memory-memory<ref name="ibm-imp-reference">{{#invoke:citation/CS1|citation

|CitationClass=web }}</ref> instruction set architecture known as the internal microprogramming (IMP) instruction set<ref name="ibm-imp-reference" /> or the Internal Microprogrammed Interface (IMPI) using the native microcode of the System/38's processor.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> Certain low-level and performance sensitive functionality such as task (i.e. process) scheduling and message passing were implemented directly in microcode as part of the Horizontal Microcode. The Horizontal Microcode resided in control store; it corresponded to traditional microcode.

  • Vertical Microcode (VMC), which implemented the Machine Interface in terms of the IMPI architecture; this was implemented by translating MI code into IMPI code and executing it. It also implemented the integrated database, and other components of the operating system which could not be implemented in terms of MI instructions.<ref name="ibm-vmc-plm">{{#invoke:citation/CS1|citation

|CitationClass=web }}</ref> This was implemented using a mixture of PL/MP and IMPI assembly.<ref name="inside-as400" /> The Vertical Microcode resided in main memory.

The use of the term microcode stemmed from a 1969 antitrust case against IBM which resulted in IBM unbundling software from its hardware products (i.e. requiring software to be purchased separately from the hardware). By treating the low level code of the System/38 as part of the hardware, IBM was able to treat the MI as the native instruction set of the System/38, and thus have the freedom to change the IMPI and microcode as the underlying hardware evolved.<ref name="inside-as400">Template:Cite book</ref> Early AS/400 systems inherited the System/38 microcode structure, but the term microcode was dropped, leading IBM to rename the layers to the Vertical Licensed Internal Code and Horizontal Licensed Internal Code.

Control Program FacilityEdit

{{#invoke:Labelled list hatnote|labelledList|Main article|Main articles|Main page|Main pages}} The operating system of the System/38 is the Control Program Facility (CPF). CPF is not related to the System Support Program operating system of the IBM System/34 and System/36. CPF objects are files, programs, message queues, user profiles, and libraries. While CPF is considered to be the operating system of the System/38, it sits on top of the System/38 Machine Interface layer, and consequently much of the traditional operating system functionality of the platform is implemented in the Horizontal and Vertical Microcode.<ref name="inside-as400" />

The System/38 also has the distinction of being the first commercially available IBM Midrange computer to have a database management system (DBMS) integrated into the operating system.

The operational control language of the System/38 is called CL, for Control Language. CL programs, similar in concept to shell scripts, can be compiled and executed natively.

The System/38 was designed with security built in as part of its architecture. Each object or library can have access controlled on a user-by-user basis. This has been continued and expanded throughout the AS/400 and iSeries computer lines.

Successor systemEdit

{{#invoke:Labelled list hatnote|labelledList|Main article|Main articles|Main page|Main pages}} The System/38 was superseded by the AS/400, which also provided compatibility with System/36 data and software.<ref>Template:Cite book</ref> S/38 programs with 'observability' intact, that is source code embedded within the compiled binary executive at the expense of larger compiled object sizes, can still run on the AS/400 and successor systems as the restore option incorporates a recompile for the then back-version source. However, most proprietary vendor application libraries of objects were compiled without such 'observability' and require original vendor replacement and consequent expense when upgrading to an AS/400. Pricing at the time was tiered, the same exact software, but priced based upon the model, its speed and capacity, of the system to be installed upon.

SalesEdit

IBM sold an estimated 20,000 System/38s within the first five years of availability, according to articles published in industry magazines NEWS 34/38 and Midrange Computing. Although billed as a minicomputer, the S/38 was much more expensive than IBM's established best-selling System/34, and its replacement, the System/36. Of equal importance was the difficulty of upgrading from a System/34 to a S/38. IBM tacitly acknowledged this by bringing out the System/36 – an upgraded System/34 – after the launch of the S/38. Although the System/38 did not sell in large numbers, it commanded a higher profit margin than IBM's other midrange systems, and thus was a profitable product line for IBM.<ref name="schleicher-interview" />

In the marketplace, IBM thus found itself with three overlapping, but incompatible, ranges. The System/34, the System/38 and the mainframe System/370 architecture. Digital Equipment Corporation, at that time one of IBM's main competitors, was able to exploit this by offering a wide range of products based on a single architecture - specifically the VAX architecture.<ref>Template:Cite book</ref> IBM's counter to this, the 9370, was a commercial failure, and at that time, The New York Times wrote, sales of the System/36 and System/38 were "lagging."<ref>Template:Cite news</ref>

ReferencesEdit

Template:Reflist

Further readingEdit

External linksEdit

Template:Sister project

  • {{#invoke:citation/CS1|citation

|CitationClass=web }}

Template:IBM Template:Object-capability security Template:Authority control