OpenVMS
Computer operating system From Wikipedia, the free encyclopedia
OpenVMS, often referred to as just VMS,[8] is a multi-user, multiprocessing and virtual memory-based operating system. It is designed to support time-sharing, batch processing, transaction processing and workstation applications.[9] Customers using OpenVMS include banks and financial services, hospitals and healthcare, telecommunications operators, network information services, and industrial manufacturers.[10][11] During the 1990s and 2000s, there were approximately half a million VMS systems in operation worldwide.[12][13][14]
Developer | VMS Software Inc (VSI)[1] (previously Digital Equipment Corporation, Compaq, Hewlett-Packard) |
---|---|
Written in | Primarily C, BLISS, VAX MACRO, DCL.[2] Other languages also used.[3] |
Working state | Current |
Source model | Closed-source with open-source components. Formerly source available[4][5] |
Initial release | Announced: October 25, 1977 V1.0 / August 1978 |
Latest release | V9.2-3 / November 20, 2024 |
Marketing target | Servers (historically Minicomputers, Workstations) |
Available in | English, Japanese.[6] Historical support for Chinese (both Traditional and Simplified characters), Korean, Thai.[7] |
Update method | Concurrent upgrades, rolling upgrades |
Package manager | PCSI and VMSINSTAL |
Platforms | VAX, Alpha, Itanium, x86-64 |
Kernel type | Monolithic kernel with loadable modules |
Influenced | VAXELN, MICA, Windows NT |
Influenced by | RSX-11M |
Default user interface | DCL CLI and DECwindows GUI |
License | Proprietary |
Official website | vmssoftware |
It was first announced by Digital Equipment Corporation (DEC) as VAX/VMS (Virtual Address eXtension/Virtual Memory System[15]) alongside the VAX-11/780 minicomputer in 1977.[16][17][18] OpenVMS has subsequently been ported to run on DEC Alpha systems, the Itanium-based HPE Integrity Servers,[19] and select x86-64 hardware and hypervisors.[20] Since 2014, OpenVMS is developed and supported by VMS Software Inc. (VSI).[21][22] OpenVMS offers high availability through clustering—the ability to distribute the system over multiple physical machines.[23] This allows clustered applications and data to remain continuously available while operating system software and hardware maintenance and upgrades are performed,[24] or if part of the cluster is destroyed.[25] VMS cluster uptimes of 17 years have been reported.[26]
History
Origin and name changes
In April 1975, Digital Equipment Corporation embarked on a project to design a 32-bit extension to its PDP-11 computer line. The hardware component was code named Star; the operating system was code named Starlet. Roger Gourd was the project lead for VMS. Software engineers Dave Cutler, Dick Hustvedt, and Peter Lipman acted as technical project leaders.[27] The Star and Starlet projects culminated in the VAX-11/780 computer and the VAX/VMS operating system. The Starlet project's code name survives in VMS in the name of several of the system libraries, including STARLET.OLB
and STARLET.MLB
.[28] VMS was mostly written in VAX MACRO with some components written in BLISS.[8]
One of the original goals for VMS was backward compatibility with DEC's existing RSX-11M operating system.[8] Prior to the V3.0 release, VAX/VMS included a compatibility layer named the RSX Application Migration Executive (RSX AME), which allowed user-mode RSX-11M software to be run unmodified on top of VMS.[29] The RSX AME played an important role on early versions of VAX/VMS, which used certain RSX-11M user-mode utilities before native VAX versions had been developed.[8] By the V3.0 release, all compatibility-mode utilities were replaced with native implementations.[30] In VAX/VMS V4.0, RSX AME was removed from the base system, and replaced with an optional layered product named VAX-11 RSX.[31]
A number of distributions of VAX/VMS were created:
- MicroVMS was a distribution of VAX/VMS designed for MicroVAX and VAXstation hardware, which had less memory and disk space than larger VAX systems of the time.[34] MicroVMS split up VAX/VMS into multiple kits, which a customer could use to install a subset of VAX/VMS tailored to their specific requirements.[35] MicroVMS releases were produced for each of the V4.x releases of VAX/VMS and was discontinued when VAX/VMS V5.0 was released.[36][37]
- Desktop-VMS was a short-lived distribution of VAX/VMS sold with VAXstation systems. It consisted of a single CD-ROM containing a bundle of VMS, DECwindows, DECnet, VAXcluster support, and a setup process designed for non-technical users.[38][39] Desktop-VMS could either be run directly from the CD or could be installed onto a hard drive.[40] Desktop-VMS had its own versioning scheme beginning with V1.0, which corresponded to the V5.x releases of VMS.[41]
- An unofficial derivative of VAX/VMS named MOS VP (Russian: Многофункциональная операционная система с виртуальной памятью, МОС ВП, lit. 'Multifunctional Operating System with Virtual Memory')[42] was created in the Soviet Union during the 1980s for the SM 1700 line of VAX clone hardware.[43][44] MOS VP added support for the Cyrillic script and translated parts of the user interface into Russian.[45] Similar derivatives of MicroVMS known as MicroMOS VP (Russian: МикроМОС ВП) or MOS-32M (Russian: МОС-32М) were also created.
With the V5.0 release in April 1988, DEC began to refer to VAX/VMS as simply VMS in its documentation.[46] In July 1992,[47] DEC renamed VAX/VMS to OpenVMS as an indication of its support of open systems industry standards such as POSIX and Unix compatibility,[48] and to drop the VAX connection since a migration to a different architecture was underway. The OpenVMS name was first used with the OpenVMS AXP V1.0 release in November 1992. DEC began using the OpenVMS VAX name with the V6.0 release in June 1993.[49]
Port to Alpha
During the 1980s, DEC planned to replace the VAX platform and the VMS operating system with the PRISM architecture and the MICA operating system.[51] When these projects were cancelled in 1988, a team was set up to design new VAX/VMS systems of comparable performance to RISC-based Unix systems.[52] After a number of failed attempts to design a faster VAX-compatible processor, the group demonstrated the feasibility of porting VMS and its applications to a RISC architecture based on PRISM.[53] This led to the creation of the Alpha architecture.[54] The project to port VMS to Alpha began in 1989, and first booted on a prototype Alpha EV3-based Alpha Demonstration Unit in early 1991.[53][55]
The main challenge in porting VMS to a new architecture was that VMS and the VAX were designed together, meaning that VMS was dependent on certain details of the VAX architecture.[56] Furthermore, a significant amount of the VMS kernel, layered products, and customer-developed applications were implemented in VAX MACRO assembly code.[8] Some of the changes needed to decouple VMS from the VAX architecture included the creation of the MACRO-32 compiler, which treated VAX MACRO as a high-level language, and compiled it to Alpha object code,[57] and the emulation of certain low-level details of the VAX architecture in PALcode, such as interrupt handling and atomic queue instructions.
The VMS port to Alpha resulted in the creation of two separate codebases: one for VAX, and another for Alpha.[4] The Alpha code library was based on a snapshot of the VAX/VMS code base circa V5.4-2.[58] 1992 saw the release of the first version of OpenVMS for Alpha AXP systems, designated OpenVMS AXP V1.0. In 1994, with the release of OpenVMS V6.1, feature (and version number) parity between the VAX and Alpha variants was achieved; this was the so-called Functional Equivalence release.[58] The decision to use the 1.x version numbering stream for the pre-production quality releases of OpenVMS AXP confused some customers, and was not repeated in the subsequent ports of OpenVMS to new platforms.[56]
When VMS was ported to Alpha, it was initially left as a 32-bit only operating system.[57] This was done to ensure backwards compatibility with software written for the 32-bit VAX. 64-bit addressing was first added for Alpha in the V7.0 release.[59] In order to allow 64-bit code to interoperate with older 32-bit code, OpenVMS does not create a distinction between 32-bit and 64-bit executables, but instead allows for both 32-bit and 64-bit pointers to be used within the same code.[60] This is known as mixed pointer support. The 64-bit OpenVMS Alpha releases support a maximum virtual address space size of 8TiB (a 43-bit address space), which is the maximum supported by the Alpha 21064 and Alpha 21164.[61]
One of the more noteworthy Alpha-only features of OpenVMS was OpenVMS Galaxy, which allowed the partitioning of a single SMP server to run multiple instances of OpenVMS. Galaxy supported dynamic resource allocation to running partitions, and the ability to share memory between partitions.[62][63]
Port to Intel Itanium
In 2001, prior to its acquisition by Hewlett-Packard, Compaq announced the port of OpenVMS to the Intel Itanium architecture.[64] The Itanium port was the result of Compaq's decision to discontinue future development of the Alpha architecture in favour of adopting the then-new Itanium architecture.[65] The porting began in late 2001, and the first boot on took place on January 31, 2003.[66] The first boot consisted of booting a minimal system configuration on a HP i2000 workstation, logging in as the SYSTEM
user, and running the DIRECTORY
command. The Itanium port of OpenVMS supports specific models and configurations of HPE Integrity Servers.[9] The Itanium releases were originally named HP OpenVMS Industry Standard 64 for Integrity Servers, although the names OpenVMS I64 or OpenVMS for Integrity Servers are more commonly used.[67]
The Itanium port was accomplished using source code maintained in common within the OpenVMS Alpha source code library, with the addition of conditional code and additional modules where changes specific to Itanium were required.[56] This required certain architectural dependencies of OpenVMS to be replaced, or emulated in software. Some of the changes included using the Extensible Firmware Interface (EFI) to boot the operating system,[68] reimplementing the functionality previously provided by Alpha PALcode inside the kernel,[69] using new executable file formats (Executable and Linkable Format and DWARF),[70] and adopting IEEE 754 as the default floating point format.[71]
As with the VAX to Alpha port, a binary translator for Alpha to Itanium was made available, allowing user-mode OpenVMS Alpha software to be ported to Itanium in situations where it was not possible to recompile the source code. This translator is known as the Alpha Environment Software Translator (AEST), and it also supported translating VAX executables which had already been translated with VEST.[72]
Two pre-production releases, OpenVMS I64 V8.0 and V8.1, were available on June 30, 2003, and on December 18, 2003. These releases were intended for HP organizations and third-party vendors involved with porting software packages to OpenVMS I64. The first production release, V8.2, was released in February 2005. V8.2 was also released for Alpha; subsequent V8.x releases of OpenVMS have maintained feature parity between the Alpha and Itanium architectures.[73]
Port to x86-64
When VMS Software Inc. (VSI) announced that they had secured the rights to develop the OpenVMS operating system from HP, they also announced their intention to port OpenVMS to the x86-64 architecture.[74] The porting effort ran concurrently with the establishment of the company, as well as the development of VSI's own Itanium and Alpha releases of OpenVMS V8.4-x.
The x86-64 port is targeted for specific servers from HPE and Dell, as well as certain virtual machine hypervisors.[75] Initial support was targeted for KVM and VirtualBox. Support for VMware was announced in 2020, and Hyper-V is being explored as a future target.[76] In 2021, the x86-64 port was demonstrated running on an Intel Atom-based single-board computer.[77]
As with the Alpha and Itanium ports, the x86-64 port made some changes to simplify porting and supporting OpenVMS on the new platform including: replacing the proprietary GEM compiler backend used by the VMS compilers with LLVM,[78] changing the boot process so that OpenVMS is booted from a memory disk,[79] and simulating the four privilege levels of OpenVMS in software since only two of x86-64's privilege levels are usable by OpenVMS.[69]
The first boot was announced on May 14, 2019. This involved booting OpenVMS on VirtualBox, and successfully running the DIRECTORY
command.[80] In May 2020, the V9.0 Early Adopter's Kit release was made available to a small number of customers. This consisted of the OpenVMS operating system running in a VirtualBox VM with certain limitations; most significantly, few layered products were available, and code can only be compiled for x86-64 using cross compilers which run on Itanium-based OpenVMS systems.[20] Following the V9.0 release, VSI released a series of updates on a monthly or bimonthly basis which added additional functionality and hypervisor support. These were designated V9.0-A through V9.0-H.[81] In June 2021, VSI released the V9.1 Field Test, making it available to VSI's customers and partners.[82] V9.1 shipped as an ISO image which can be installed onto a variety of hypervisors, and onto HPE ProLiant DL380 servers starting with the V9.1-A release.[83]
Influence
During the 1980s, the MICA operating system for the PRISM architecture was intended to be the eventual successor to VMS. MICA was designed to maintain backwards compatibility with VMS applications while also supporting Ultrix applications on top of the same kernel.[84] MICA was ultimately cancelled along with the rest of the PRISM platform, leading Dave Cutler to leave DEC for Microsoft. At Microsoft, Cutler led the creation of the Windows NT operating system, which was heavily inspired by the architecture of MICA.[85] As a result, VMS is considered an ancestor of Windows NT, together with RSX-11, VAXELN and MICA, and many similarities exist between VMS and NT.[86]
A now-defunct project named FreeVMS attempted to develop an open-source operating system following VMS conventions.[87][88] FreeVMS was built on top of the L4 microkernel and supported the x86-64 architecture. Prior work investigating the implementation of VMS using a microkernel-based architecture had previously been undertaken as a prototyping exercise by DEC employees with assistance from Carnegie Mellon University using the Mach 3.0 microkernel ported to VAXstation 3100 hardware, adopting a multiserver architectural model.[89]
Architecture
The OpenVMS operating system has a layered architecture, consisting of a privileged Executive, an intermediately privileged Command Language Interpreter, and unprivileged utilities and run-time libraries (RTLs).[90] Unprivileged code typically invokes the functionality of the Executive through system services (equivalent to system calls in other operating systems).
OpenVMS' layers and mechanisms are built around certain features of the VAX architecture, including:[90][91]
- The availability of four processor access modes (named Kernel, Executive, Supervisor and User, in order of decreasing privilege). Each mode has its own stack, and each memory page can have memory protections specified per-mode.
- A virtual address space which is partitioned between process-private space sections, and system space sections which are common to all processes.
- 32 interrupt priority levels which are used for synchronization.
- Hardware support for delivering asynchronous system traps to processes.
These VAX architecture mechanisms are implemented on Alpha, Itanium and x86-64 by either mapping to corresponding hardware mechanisms on those architectures, or through emulation (via PALcode on Alpha, or in software on Itanium and x86-64).[69]
Executive and Kernel
The OpenVMS Executive comprises the privileged code and data structures which reside in the system space. The Executive is further subdivided between the Kernel, which consists of the code which runs at the kernel access mode, and the less-privileged code outside of the Kernel which runs at the executive access mode.[90]
The components of the Executive which run at executive access mode include the Record Management Services, and certain system services such as image activation. The main distinction between the kernel and executive access modes is that most of the operating system's core data structures can be read from executive mode, but require kernel mode to be written to.[91] Code running at executive mode can switch to kernel mode at will, meaning that the barrier between the kernel and executive modes is intended as a safeguard against accidental corruption as opposed to a security mechanism.[92]
The Kernel comprises the operating system's core data structures (e.g. page tables, the I/O database and scheduling data), and the routines which operate on these structures. The Kernel is typically described as having three major subsystems: I/O, Process and Time Management, Memory Management.[90][91] In addition, other functionality such as logical name management, synchronization and system service dispatch are implemented inside the Kernel.
OpenVMS allows user-mode code with suitable privileges to switch to executive or kernel mode using the $CMEXEC
and $CMKRNL
system services, respectively.[93] This allows code outside of system space to have direct access to the Executive's routines and system services. In addition to allowing third-party extensions to the operating system, Privileged Images are used by core operating system utilities to manipulate operating system data structures through undocumented interfaces.[94]
File system
The typical user and application interface into the file system is the Record Management Services (RMS), although applications can interface directly with the underlying file system through the QIO system services.[95] The file systems supported by VMS are referred to as the Files-11 On-Disk Structures (ODS), the most significant of which are ODS-2 and ODS-5.[96] VMS is also capable of accessing files on ISO 9660 CD-ROMs and magnetic tape with ANSI tape labels.[97]
Files-11 is limited to 2 TiB volumes.[96] DEC attempted to replace it with a log-structured file system named Spiralog, first released in 1995.[98] However, Spiralog was discontinued due to a variety of problems, including issues with handling full volumes.[99] Instead, there has been discussion of porting the open-source GFS2 file system to OpenVMS.[100]
Command Language Interpreter
An OpenVMS Command Language Interpreter (CLI) implements a command-line interface for OpenVMS, responsible for executing individual commands and command procedures (equivalent to shell scripts or batch files).[101] The standard CLI for OpenVMS is the DIGITAL Command Language, although other options are available.
Unlike Unix shells, which typically run in their own isolated process and behave like any other user-mode program, OpenVMS CLIs are an optional component of a process, which exist alongside any executable image which that process may run.[102] Whereas a Unix shell will typically run executables by creating a separate process using fork-exec, an OpenVMS CLI will typically load the executable image into the same process, transfer control to the image, and ensure that control is transferred back to CLI once the image has exited and that the process is returned to its original state.[90]
Because the CLI is loaded into the same address space as user code, and the CLI is responsible for invoking image activation and image rundown, the CLI is mapped into the process address space at supervisor access mode, a higher level of privilege than most user code. This is in order to prevent accidental or malicious manipulation of the CLI's code and data structures by user-mode code.[90][102]
Features
Clustering
OpenVMS supports clustering (first called VAXcluster and later VMScluster), where multiple computers run their own instance of the operating system. Clustered computers (nodes) may be fully independent from each other, or they may share devices like disk drives and printers. Communication across nodes provides a single system image abstraction.[103] Nodes may be connected to each other via a proprietary hardware connection called Cluster Interconnect or via a standard Ethernet LAN.
OpenVMS supports up to 96 nodes in a single cluster. It also allows mixed-architecture clusters.[23] OpenVMS clusters allow applications to function during planned or unplanned outages.[104] Planned outages include hardware and software upgrades.[105]
Networking
The DECnet protocol suite is tightly integrated into VMS, allowing remote logins, as well as transparent access to files, printers and other resources on VMS systems over a network.[106] VAX/VMS V1.0 featured support for DECnet Phase II,[107] and modern versions of VMS support both the traditional Phase IV DECnet protocol, as well as the OSI-compatible Phase V (also known as DECnet-Plus).[108] Support for TCP/IP is provided by the optional TCP/IP Services for OpenVMS layered product (originally known as the VMS/ULTRIX Connection, then as the ULTRIX Communications Extensions or UCX).[109][110] TCP/IP Services is based on a port of the BSD network stack to OpenVMS,[111] along with support for common protocols such as SSH, DHCP, FTP and SMTP.
DEC sold a software package named PATHWORKS (originally known as the Personal Computer Systems Architecture or PCSA) which allowed personal computers running MS-DOS, Microsoft Windows or OS/2, or the Apple Macintosh to serve as a terminal for VMS systems, or to use VMS systems as a file or print server.[112] PATHWORKS was later renamed to Advanced Server for OpenVMS, and was eventually replaced with a VMS port of Samba at the time of the Itanium port.[113]
DEC provided the Local Area Transport (LAT) protocol which allowed remote terminals and printers to be attached to a VMS system through a terminal server such as one of the DECserver family.[114]
Programming
DEC (and its successor companies) provided a wide variety of programming languages for VMS. Officially supported languages on VMS, either current or historical, include:[115][116]
Among OpenVMS's notable features is the Common Language Environment, a strictly defined standard that specifies calling conventions for functions and routines, including use of stacks, registers, etc., independent of programming language.[117] Because of this, it is possible to call a routine written in one language (for example, Fortran) from another (for example, COBOL), without needing to know the implementation details of the target language. OpenVMS itself is implemented in a variety of different languages and the common language environment and calling standard supports freely mixing these languages.[118] DEC created a tool named the Structure Definition Language (SDL), which allowed data type definitions to be generated for different languages from a common definition.[119]
Development tools
DEC provided a collection of software development tools in a layered product named DECset (originally named VAXset).[115] This consisted of the following tools:[120]
- Language-Sensitive Editor (LSE)
- Code Management System (CMS) a version control system
- Module Management System (MMS), a build tool
- the Source Code Analyzer (SCA), a static analyzer
- the Performance and Coverage Analyzer (PCA), a profiler
- Digital Test Manager (DTM), as a test manager
- In addition, a number of text editors are included in the operating system, including EDT, EVE and TECO.[121]
The OpenVMS Debugger supports all DEC compilers and many third-party languages. It allows breakpoints, watchpoints and interactive runtime program debugging using either a command line or graphical user interface.[122] A pair of lower-level debuggers, named DELTA and XDELTA, can be used to debug privileged code in additional to normal application code.[123]
In 2019, VSI released an officially supported Integrated Development Environment for VMS based on Visual Studio Code.[75] This allows VMS applications to be developed and debugged remotely from a Microsoft Windows, macOS or Linux workstation.[124]
Database management
DEC created a number of optional database products for VMS, some of which were marketed as the VAX Information Architecture family.[125] These products included:
- Rdb – A relational database system which originally used the proprietary Relational Data Operator (RDO) query interface, but later gained SQL support.[126]
- DBMS – A database management system which uses the CODASYL network model and Data Manipulation Language (DML).
- Digital Standard MUMPS (DSM) – an integrated programming language and key-value database.[115]
- Common Data Dictionary (CDD) – a central database schema repository, which allowed schemas to be shared between different applications, and data definitions to be generated for different programming languages.
- DATATRIEVE – a query and reporting tool which could access data from RMS files as well as Rdb and DBMS databases.
- Application Control Management System (ACMS) – A transaction processing monitor, which allows applications to be created using a high-level Task Description Language (TDL). Individual steps of a transaction can be implemented using DCL commands, or Common Language Environment procedures. User interfaces can be implemented using TDMS, DECforms or Digital's ALL-IN-1 office automation product.[127]
- RALLY, DECadmire – Fourth-generation programming languages (4GLs) for generating database-backed applications.[128] DECadmire featured integration with ACMS, and later provided support for generating Visual Basic client-server applications for Windows PCs.[129]
In 1994, DEC sold Rdb, DBMS and CDD to Oracle, where they remain under active development.[130] In 1995, DEC sold DSM to InterSystems, who renamed it Open M, and eventually replaced it with their Caché product.[131]
Examples of third-party database management systems for OpenVMS include MariaDB,[132] Mimer SQL[133] (Itanium and x86-64[134]), and System 1032.[135]
User interfaces
VMS was originally designed to be used and managed interactively using DEC's text-based video terminals such as the VT100, or hardcopy terminals such as the DECwriter series. Since the introduction of the VAXstation line in 1984, VMS has optionally supported graphical user interfaces for use with workstations or X terminals such as the VT1000 series.
Text-based user interfaces
The DIGITAL Command Language (DCL) has served as the primary command language interpreter (CLI) of OpenVMS since the first release.[136][29][9] Other official CLIs available for VMS include the RSX-11 Monitor Console Routine (MCR) (VAX only), and various Unix shells.[115] DEC provided tools for creating text-based user interface applications – the Form Management System (FMS) and Terminal Data Management System (TDMS), later succeeded by DECforms.[137][138][139] A lower level interface named Screen Management Services (SMG$), comparable to Unix curses, also exists.[140]
Graphical user interfaces
Over the years, VMS has gone through a number of different GUI toolkits and interfaces:
- The original graphical user interface for VMS was a proprietary windowing system known as the VMS Workstation Software (VWS), which was first released for the VAXstation I in 1984.[141] It exposed an API called the User Interface Services (UIS).[142] It ran on a limited selection of VAX hardware.[143]
- In 1989, DEC replaced VWS with a new X11-based windowing system named DECwindows.[144] It was first included in VAX/VMS V5.1.[145] Early versions of DECwindows featured an interface built on top of a proprietary toolkit named the X User Interface (XUI). A layered product named UISX was provided to allow VWS/UIS applications to run on top of DECwindows.[146] Parts of XUI were subsequently used by the Open Software Foundation as the foundation of the Motif toolkit.[147]
- In 1991, DEC replaced XUI with the Motif toolkit, creating DECwindows Motif.[148][149] As a result, the Motif Window Manager became the default DECwindows interface in OpenVMS V6.0,[145] although the XUI window manager remained as an option.
- In 1996, as part of OpenVMS V7.1,[145] DEC released the New Desktop interface for DECwindows Motif, based on the Common Desktop Environment (CDE).[150] On Alpha and Itanium systems, it is still possible to select the older MWM-based UI (referred to as the "DECwindows Desktop") at login time. The New Desktop was never ported to the VAX releases of OpenVMS.
Versions of VMS running on DEC Alpha workstations in the 1990s supported OpenGL[151] and Accelerated Graphics Port (AGP) graphics adapters. VMS also provides support for older graphics standards such as GKS and PHIGS.[152][153] Modern versions of DECwindows are based on X.Org Server.[9]
Security
OpenVMS provides various security features and mechanisms, including security identifiers, resource identifiers, subsystem identifiers, ACLs, intrusion detection and detailed security auditing and alarms.[154] Specific versions evaluated at Trusted Computer System Evaluation Criteria Class C2 and, with the SEVMS security enhanced release at Class B1.[155] OpenVMS also holds an ITSEC E3 rating (see NCSC and Common Criteria).[156] Passwords are hashed using the Purdy Polynomial.
Vulnerabilities
- Early versions of VMS included a number of privileged user accounts (including
SYSTEM
,FIELD
,SYSTEST
andDECNET
) with default passwords which were often left unchanged by system managers.[157][158] A number of computer worms for VMS including the WANK worm and the Father Christmas worm exploited these default passwords to gain access to nodes on DECnet networks.[159] This issue was also described by Clifford Stoll in The Cuckoo's Egg as a means by which Markus Hess gained unauthorized access to VAX/VMS systems.[160] In V5.0, the default passwords were removed, and it became mandatory to provide passwords for these accounts during system setup.[37] - A 33-year-old vulnerability in VMS on VAX and Alpha was discovered in 2017 and assigned the CVE ID CVE-2017-17482. On the affected platforms, this vulnerability allowed an attacker with access to the DCL command line to carry out a privilege escalation attack. The vulnerability relies on exploiting a buffer overflow bug in the DCL command processing code, the ability for a user to interrupt a running image (program executable) with CTRL/Y and return to the DCL prompt, and the fact that DCL retains the privileges of the interrupted image.[161] The buffer overflow bug allowed shellcode to be executed with the privileges of an interrupted image. This could be used in conjunction with an image installed with higher privileges than the attacker's account to bypass system security.[162]
POSIX compatibility
Various official Unix and POSIX compatibility layers were created for VMS. The first of these was DEC/Shell, which was a layered product consisting of ports of the Bourne shell from Version 7 Unix and several other Unix utilities to VAX/VMS.[115] In 1992, DEC released the POSIX for OpenVMS layered product, which included a shell based on the KornShell.[163] POSIX for OpenVMS was later replaced by the open-source GNV (GNU's not VMS) project, which was first included in OpenVMS media in 2002.[164] Amongst other GNU tools, GNV includes a port of the Bash shell to VMS.[165] Examples of third-party Unix compatibility layers for VMS include Eunice.[166]
Hobbyist programs
In 1997, OpenVMS and a number of layered products were made available free of charge for hobbyist, non-commercial use as part of the OpenVMS Hobbyist Program.[167] Since then, several companies producing OpenVMS software have made their products available under the same terms, such as Process Software.[168] Prior to the x86-64 port, the age and cost of hardware capable of running OpenVMS made emulators such as SIMH a common choice for hobbyist installations.[169]
In March 2020, HPE announced the end of the OpenVMS Hobbyist Program.[170] This was followed by VSI's announcement of the Community License Program (CLP) in April 2020, which was intended as a replacement for the HPE Hobbyist Program.[171] The CLP was launched in July 2020, and provides licenses for VSI OpenVMS releases on Alpha, Integrity and x86-64 systems.[172] OpenVMS for VAX is not covered by the CLP, since there are no VSI releases of OpenVMS VAX, and the old versions are still owned by HPE.[173]
Release history
Version | Vendor | Release date [174][8][175] |
End of support [176][177][178] |
Platform | Significant changes, new hardware support [179][145] |
---|---|---|---|---|---|
[n 1] | X0.5DEC | April 1978[180] | ? | VAX | First version shipped to customers[28] |
V1.0 | August 1978 | First production release | |||
V1.01 | ?[n 2] | Bug fixes[181] | |||
V1.5 | February 1979[n 3] | Support for native COBOL, BLISS compilers[181] | |||
V1.6 | August 1979 | RMS-11 updates[182] | |||
V2.0 | April 1980 | VAX-11/750, new utilities including EDT | |||
V2.1 | ?[n 4] | ? | |||
V2.2 | April 1981 | Process limit increased to 8,192[184] | |||
V2.3 | May 1981[185] | Security enhancements[186] | |||
V2.4 | ? | ? | |||
V2.5 | ? | BACKUP utility[187] | |||
V3.0 | April 1982 | VAX-11/730, VAX-11/725, VAX-11/782, ASMP | |||
V3.1 | August 1982 | PL/I runtime bundled with base OS[188] | |||
V3.2 | December 1982 | Support for RA60, RA80, RA81 disks[189] | |||
V3.3 | April 1983 | HSC50 disk controller, BACKUP changes[190] | |||
V3.4 | June 1983 | Ethernet support for DECnet,[191] VAX-11/785 | |||
V3.5 | November 1983 | Support for new I/O devices[192] | |||
V3.6 | April 1984 | Bug fixes[193] | |||
V3.7 | August 1984 | Support for new I/O devices[194] | |||
V4.0 | September 1984 | VAX 8600, MicroVMS, VAXclusters[195] | |||
V4.1 | January 1985 | MicroVAX/VAXstation I, II[196] | |||
V4.2 | October 1985 | Text Processing Utility | |||
V4.3 | December 1985 | DELUA Ethernet adapter support | |||
V4.3A | January 1986 | VAX 8200 | |||
V4.4 | July 1986 | VAX 8800/8700/85xx, Volume Shadowing | |||
V4.5 | November 1986 | Support for more memory in MicroVAX II | |||
V4.5A | December 1986 | Ethernet VAXclusters | |||
V4.5B | March 1987 | VAXstation/MicroVAX 2000 | |||
V4.5C | May 1987 | MicroVAX 2000 cluster support | |||
V4.6 | August 1987 | VAX 8250/8350/8530, RMS Journalling | |||
V4.7 | January 1988 | First release installable from CD-ROM | |||
V4.7A | March 1988 | VAXstation 3200/3500, MicroVAX 3500/3600 | |||
V5.0 | April 1988 | VAX 6000, SMP, LMF, Modular Executive | |||
V5.0-1 | August 1988 | Bug fixes | |||
V5.0-2 | October 1988 | ||||
V5.0-2A | MicroVAX 3300/3400 | ||||
V5.1 | February 1989 | DECwindows | |||
V5.1-B | VAXstation 3100 30/40, Desktop-VMS | ||||
V5.1-1 | June 1989 | VAXstation 3520/3540, MicroVAX 3800/3900 | |||
V5.2 | September 1989 | Cluster-wide process visibility/management | |||
V5.2-1 | October 1989 | VAXstation 3100 38/48 | |||
V5.3 | January 1990 | Support for third-party SCSI devices | |||
V5.3-1 | April 1990 | Support for VAXstation SPX graphics | |||
V5.3-2 | May 1990 | Support for new I/O devices | |||
V5.4 | October 1990 | VAX 65xx, VAX Vector Architecture | |||
V5.4-0A | VAX 9000, bug fixes for VAX 6000 systems | ||||
V5.4-1 | November 1990 | New models of VAX 9000, VAXstation, VAXft | |||
V5.4-1A | January 1991 | VAX 6000-400 | |||
V5.4-2 | March 1991 | VAX 4000 Model 200, new I/O devices | |||
V5.4-3 | October 1991 | FDDI adapter support | |||
V5.5 | November 1991 | Cluster-wide batch queue, new VAX models | |||
A5.5 | Same as V5.5 but without new batch queue | ||||
V5.5-1 | July 1992 | Bug fixes for batch/print queue | |||
V5.5-2HW | September 1992 | VAX 7000/10000, and other new VAX hardware | |||
V5.5-2 | November 1992 | September 1995 | Consolidation of previous hardware releases | ||
V5.5-2H4 | August 1993 | New VAX 4000 models, additional I/O devices | |||
V5.5-2HF | ? | VAXft 810 | |||
[n 5] | V1.0November 1992 | Alpha | First release for Alpha architecture | ||
V1.5 | May 1993 | Cluster and SMP support for Alpha | |||
V1.5-1H1 | October 1993 | New DEC 2000, DEC 3000 models | |||
V6.0 | June 1993 | VAX | TCSEC C2 compliance, ISO 9660, Motif | ||
V6.1 | April 1994 | VAX, Alpha | Merger of VAX and Alpha releases, PCSI | ||
V6.1-1H1 | September 1994 | Alpha | New AlphaStation, AlphaServer models | ||
V6.1-1H2 | November 1994 | ||||
V6.2 | June 1995 | March 1998 | VAX, Alpha | Command Recall, DCL$PATH, SCSI clusters | |
V6.2-1H1 | December 1995 | Alpha | New AlphaStation, AlphaServer models | ||
V6.2-1H2 | March 1996 | ||||
V6.2-1H3 | May 1996 | ||||
V7.0 | January 1996 | VAX, Alpha | 64-bit addressing, Fast I/O, Kernel Threads | ||
V7.1 | January 1997 | July 2000 | Very Large Memory support, DCL PIPE, CDE | ||
V7.1-1H1 | November 1997 | Alpha | AlphaServer 800 5/500, 1200 | ||
V7.1-1H2 | April 1998 | Support for booting from third-party devices | |||
V7.1-2 | Compaq | December 1998 | Additional I/O device support | ||
V7.2 | February 1999 | June 2002 | VAX, Alpha | OpenVMS Galaxy, ODS-5, DCOM | |
V7.2-1 | July 1999 | Alpha | AlphaServer GS140, GS60, Tsunami | ||
V7.2-1H1 | June 2000 | AlphaServer GS160, GS320 | |||
V7.2-2 | September 2001 | December 2002 | Minicopy support for Volume Shadowing | ||
V7.2-6C1 | August 2001 | ? | DII COE conformance[197] | ||
V7.2-6C2 | July 2002 | ||||
V7.3 | June 2001 | December 2012 | VAX | Final release for VAX architecture | |
June 2004 | Alpha | ATM and GBE clusters, Extended File Cache | |||
V7.3-1 | HP | August 2002 | December 2004 | Alpha | Security and performance improvements |
V7.3-2 | December 2003 | December 2006 | AlphaServer GS1280, DS15 | ||
V8.0 | June 2003 | December 2003 | IA64 | Evaluation release for Integrity servers | |
V8.1 | December 2003 | February 2005 | Second evaluation release for Integrity servers | ||
V8.2 | February 2005 | June 2010 | Alpha, IA64 | Production release for Integrity servers | |
V8.2-1 | September 2005 | IA64 | Support for HP Superdome, rx7620, rx8620 | ||
V8.3 | August 2006 | December 2015 | Alpha, IA64 | Support for additional Integrity server models | |
V8.3-1H1 | November 2007 | IA64 | Support for HP BL860c, dual-core Itanium | ||
V8.4 | June 2010 | December 2020 | Alpha, IA64 | Support for HPVM, clusters over TCP/IP[198] | |
V8.4-1H1 | VSI | May 2015 | December 2022 | IA64 | Support for Poulson processors[199] |
V8.4-2 | March 2016 | Support for HPE BL890c systems, UEFI 2.3 | |||
V8.4-2L1 | September 2016 | December 2024 | OpenSSL updated to 1.0.2[200] | ||
January 2017[201] | TBA | Alpha | |||
V8.4-2L2 | July 2017 | Final release for Alpha architecture[202] | |||
V8.4-2L3 | April 2021 | December 2028 | IA64 | Final release for Integrity servers[202] | |
V9.0 | May 2020 | June 2021 | x86-64 | x86-64 Early Adopter's Kit[203] | |
V9.1 | June 2021 | September 2021 | x86-64 Field Test[82] | ||
V9.1-A | September 2021 | April 2022 | DECnet-Plus for x86-64[83] | ||
V9.2 | July 2022 | June 2023 | x86-64 Limited Production Release[204] | ||
V9.2-1 | June 2023 | December 2026 | AMD CPUs, OpenSSL 3.0, native compilers[205] | ||
V9.2-2 | January 2024 | TBA | Bug fixes[206] | ||
V9.2-3 | November 2024 | TBA | VMware vMotion, VMDirectPath | ||
V9.2-4 | June 2026 | TBA | iSCSI support | ||
Legend: Old version, not maintained Old version, still maintained Latest version Future release |
- For some of the early VAX/VMS releases where an official release date is not known, the date of the Release Notes has been used an approximation.
- While the versioning scheme reset to V1.0 for the first AXP (Alpha) releases, these releases were contemporaneous with the V5.x releases and had a similar feature set.
See also
References
Further reading
External links
Wikiwand in your browser!
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.
Welcome to Wikiwand👋
First, let's tailor Wikipedia to your needs