|Publication number||US4675814 A|
|Application number||US 06/686,596|
|Publication date||Jun 23, 1987|
|Filing date||Dec 26, 1984|
|Priority date||Dec 26, 1983|
|Publication number||06686596, 686596, US 4675814 A, US 4675814A, US-A-4675814, US4675814 A, US4675814A|
|Inventors||Masami Murai, Masanori Hashio, Yousuke Tsuyuki, Tsutomu Kaneko|
|Original Assignee||Hitachi, Ltd.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (1), Referenced by (30), Classifications (6), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
The present invention relates to a method of switching operating systems (hereinafter simply referred to as "OS") for a data processing system and, more particularly, to an OS switching method for a data processing system in which one of the operating systems stored in the auxiliary storage is selectively loaded into the main storage depending on the usage of the data processing system so that it is operated for many purposes.
2. Description of the Prior Art
The recent advances in semiconductor technology have brought increased use of office automation facilities such as word processors and personal computers using sophisticated microprocessors integrated in a tiny chip. As for the computerization of the business office, there are generally installed several on-line terminal devices connected to a host computer, and other office automation facilities such as word processors as mentioned above are used for local data processing in each office independently of the on-line computer system. However, in order to avoid the multiple installation of similar hardware devices including on-line terminals, word processors and personal computers for much efficient use of the office, it is desirable for an on-line terminal device to have multi-purpose functions including capabilities of a word processor and personal computer for dealing with local data processing.
In order for the data processing system to perform such multi-functional operations, it is necessary to replace the operating system in the main storage for each purpose. For example, an operating system EMP (Emulation Program*) is used when a terminal device is used for real time data processing in a interactive mode, MS-DOS (trademark of Microsoft Inc., U.S.A.) is used when a terminal device is used as a personal computer, WPS (Word Processing System*) including the character conversion function and learning function is used when it is used as a word processor, or BTOS (Business Terminal Operating System*) is used when it is used as an intelligent terminal for entering local data into the data base of the host computer. (Note: Operating systems marked by "*" are products of Hitachi Ltd., Japan)
Conventionally, the operating system stored in the auxiliary storage is loaded to the main storage by the Initial Program Loader (IPL). Accordingly, when the system is intended to operate under one of several operating systems stored in the auxiliary storage depending on each usage, the overall contents of the main storage are renewed each time in such a way that the operator resets the system, activates the IPL, and specifies through the keyboard the operation system to be loaded, so that the system starts with the execution of IPL. After the operating system has been loaded to the main storage, data sets associated with the OS such as dictionary data and data for character generation are also loaded from the auxiliary storage to the main storage.
According to the conventional method for dealing with operating systems, a data set needed by a new operating system is automatically loaded from the auxiliary storage to the main storage even if it already resides in the main storage as an accompaniment of the previous operating system. In addition, even though the main storage has been checked at the loading of the previous operating system, it is checked again in the new OS loading operation beginning with IPL. That is, the conventional method involves unnecessary steps of start-up procedure each time the operating system is replaced. The operator's system reset action abruptly terminates a job in execution, resulting possibly in an improper abortion of the processing.
An object of the present invention is to provide an improved method of switching operating systems for providing multi-purpose functions for a single data processing system.
Another object of the invention is to provide a method of switching operating systems capable of loading a new operating system to the main storage of a data processing system automatically or through a simple operator's action.
Still another object of the invention is to provide a method of switching operating systems capable of replacing the operating system in a minimal time needed for the OS switching operation.
In order to achieve the above objectives, the present invention resides characteristically in a method of switching operating systems for a data processing system having first memory means for storing a plurality of operating systems each having a specific file name and a plurality of data sets, second memory means having a first area for storing an operating system, a second area for storing a data set used by the operating system, a third area for temporarily storing a processing program to be executed and a fourth area for storing a program which loads a selected operating system from the first memory means to the first area, and third means for instructing the loading of an operating system with a specified file name from the first memory means to the second memory means, so that the processing program stored in the third area of the second memory means is executed under control of the operating system loaded to the first area, wherein the method comprises: the first step of checking the load instruction issued by the third means using a first program section in the operating system stored in the second memory means and, if the load instruction is acceptable, preparing a parameter indicating the content of the second area of the second memory means, the second step of executing the program in the fourth area so that a new operating system with a file name specified by the third means is loaded from the first memory means to the first area of the second memory means, and the third step carried out by the second program section of the newly loaded operating system prior to the execution of the processing program, of loading a data set, which is necessary for the new operating system and has not been loaded yet, from the first memory means to the second area of the second means, while making reference to the parameter prepared by the previous operating system.
In the above OS switching method, the third means is, for example, a keyboard unit, the OS switching instruction is entered as an operator command, and the first step is executed in response to a keyboard interrupt event.
According to another form the present invention, for example, in case the next operating system to be loaded is already determined when data processing by one operating system is completed, the above third means is formed by a job control statement in a cataloged procedure used for indicating the control sequence of a program processed by the previous operating system, and a new operating system is loaded automatically without operator intervention at the execution of the job control statement.
These and other objects, advantages and features of the present invention will become more apparent from the following detailed description taken in conjunction with the accompanying drawings.
FIG. 1 is a block diagram showing the general arrangement of the data processing system to which this invention is applied, and also explaining the concept of an OS switching operation;
FIG. 2 is a block diagram used to explain the relationship between the processing program and the operating system;
FIG. 3 is a chart used to explain the allocation of the main storage;
FIG. 4 is a flow chart showing the operation of the initial program loader (IPL);
FIG. 5 is a flow chart showing the operation of the initializing routine which is loaded together with the operating system to the main storage;
FIG. 6 is a flow chart showing the operation of the subroutine carrying out the switching of operating systems; and
FIG. 7 is a flow chart showing changes in functions of the data processing system accomplished by the switching of operating systems.
The general arrangement of the data processing system, to which this invention is applied, as shown in FIG. 1, includes a CPU 1, a main storage 2 (2A, 2B), a system reset key 3, a CRT display unit 4, a keyboard 5 for entering data and commands, and a disk type auxiliary storage 6.
The initial program loader (IPL), which is stored in a certain location of the main storage 2, is executed immediately after the system has been turned on or the reset key 3 has been pressed, and the IPL operates to load an operating system (OS-1) 7 from the auxiliary storage 6 to the main storage 2B, as shown in FIG. 1.
A processing program 10 describing the procedure of a user's job and a cataloged procedure 11 made up of job control statements specifying the job control procedure of the processing program are stored in the auxiliary storage 6 as shown in FIG. 2, and they are loaded to the main storage by the OS-1 when necessary. Each operating system is made to have a job control 7A which generates tasks in accordance with the job control statements 11' and a program execute control 7B which executes the tasks for the processing program 10'.
In this embodiment, the job control 7A is provided with the OS switching function. For example, in case the operation of the data processing system has been scheduled in advance and OS-1 is automatically followed by OS-2, the OS switching to OS-2 is specified by the last job control statement of the cataloged procedure, so that the new operating system is loaded to the main storage successively, as shown by the dashed arrows 201, 202 and 203 in FIG. 1, when the statement is executed by the job control 7A. The operating system to be loaded next may also be specified by the operator command through the keyboard 5, or by selecting an item in the menu displayed on the CRT unit 4. According to this invention, when the OS switching is instructed by the operator command, the acceptance of the command can be determined depending on whether or not a job is still in execution at this moment.
The following describes in detail the OS loading operation with reference to the flow charts embodying the present invention. In this embodiment, the initial program loader is split into IPL-1 and IPL-2. The IPL-1 is resident in an end section 26 of the main storage 2 as shown in FIG. 3, while the IPL-2 is stored in the auxiliary storage 6 and it is loaded to an area 22 between a parameter storage area 21 and an OS storage area 23 in the main storage by execution of the IPL-1. Parameters in the area 21 indicate the state of a data storage area 25 used by the operating system and they are referenced when a new operating system is loaded to the area 23 by the OS switching operation so as to avoid the unnecessary loading of the same data set to the area 25.
Following the power-on operation or reset operation, the last address of area 26 is pointed. This address location stores the jump instruction to the top of the area 26, and thus the program IPL-1 is executed. As shown in the flow chart of FIG. 4, the IPL-1 verifies and initializes the areas 21 and 22 of the main storage in routine 100, and subsequently tests the entry of OS specification by the operator command in routine 102. If the entry of OS specification is sensed, file name "OS-XX" of the entered OS is set to one of general-purpose registers in routine 106, then in the subsequent routine 108 the IPL-2 stored in the auxiliary storage 6 is loaded to the area 22 of the main storage, and control is transferred to the top of the IPL-2. If the entry of the OS specification is not sensed in the decision routine 102, the file name of the predetermined standard operating system, i.e., "OS-1" in this example, is set to the register in routine 104.
In the IPL-2, the first routine 110 verifies the remaining portion of the main storage 6, and subsequently an operating system with the file name set in the general-purpose register is retrieved from the auxiliary storage 6 and loaded to the area 23 of the main storage in routine 112. At this time, a program INITIALIZER which loads data for the OS to the area 25 is stored in the end section 23' of the OS storage area. Following the OS loading operation, the OS-2 transfers control to the top of the INITIALIZER in routine 114.
In the INITIALIZER, the first routine 120 fetches parameters from the area 21, and the next routine 122 initializes the system hardware and OS program, as shown in FIG. 5. Subsequently, routine 124 loads data sets, which are needed for the operation of the OS and are not yet loaded in the region 25, from the auxiliary storage 6 to the main storage. Finally, in routine 126, the program transfers control to the top of the operating system in region 23. The OS loading operation is now completed, and the system is ready to run the processing program which is allocated in an area 24 of the main storage.
FIG. 6 shows in a flow chart the control program executed when the OS switching is instructed by the job control statement. In response to the detection of the OS switching statement by the job control, two routines OSCHK and OSCHG are executed successively. The routine OSCHK verifies the specified OS file name and device address in routine 130, and then the routine OSCHG is executed.
The routine OSCHG sets the specified OS file name to the general-purpose register in routine 140, and sets up parameters referenced by the INITIALIZER in the area 21 in routine 142. Thereafter, if the area 22 of the main storage still retains the IPL-2, control is transferred to routine 112 of IPL-2 in FIG. 4. However, the IPL-2 is not used any longer once the OS has been loaded and this area 22 can possibly be used as a work area of some operating system, and in this case the routine OSCHG, at least the portion of routines 146 and 148, is copied to the area 22 in routine 144 and these routines are executed successively. The routines 146 and 148 are identical to the routines 112 and 114 in IPL-2, and accordingly an operating system with the file name set in the general-purpose register is retrieved from the auxiliary storage 6 and loaded to the area 23 of the main storage, and finally control is transferred to the top of the INITIALIZER.
In the OS loading operation by the OSCHG routine, memory verification identical to routine 110 in IPL-2 is skipped. Since the state of the data area 25 is indicated by parameters during the execution of the routine OSCHG, the routine 124 in the INITIALIZER of FIG. 5 loads the area 25 with only data needed additionally by the new OS.
For switching operating systems using the operator command, the procedure is designed such that the routine OSCHK and OSCHG in FIG. 6 are executed in response to the detection of the OS switching command by the interrupt source analyzing routine. In this case, if a keyboard interrupt occurs during the execution of a job, the command may be ignored or may be responded to by the execution of OSCHK upon completion of the job, thereby preventing an improper job abortion.
FIG. 7 shows changes in the function of data processing system through the switching of operating system according to the present invention. At the initial start-up of the system, the IPL-1 and IPL-2 work the loading of OS-1 to the main storage, and a processing program 20 is run under control of the OS-1. When the replacement of operating system is instructed with the specification of a new OS name (OS-2) through the job control statement or the operator command 21, an OS switching routine 8' is executed under control of the OS-1 so that the OS-2 is loaded to the main storage. Under the new operating system OS-2, another processing program 20' is run. The OS-2 is also sensitive to the OS switching command, and when the switching to OS-3 is instructed, it executes OSCHG 8" so that the OS-3 is loaded to the main storage. Under the new operating system OS-3, another processing program 20" is run.
According to this invention, as described above, a single terminal device in on-line connection with the host computer can be used for multi-functional purposes through the selective use of several operating systems, in such a way that BTOS is used for an application program which needs a file transfer, EMP is used for running an application program which resides in the host computer, MS-DOS is used for dealing with data within a local office even though data from the host computer is possibly utilized subsidiarily, and WPS is used for documentation in an off-line mode. In operation, a job executed under way is protected from being aborted when OS switching is instructed abruptly, and the operator is rendered minimal waiting time in replacing the operating system.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4493034 *||Oct 14, 1982||Jan 8, 1985||Honeywell Information Systems Inc.||Apparatus and method for an operating system supervisor in a data processing system|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US4799145 *||Sep 21, 1987||Jan 17, 1989||Honeywell Bull Inc.||Facility for passing data used by one operating system to a replacement operating system|
|US5117496 *||May 23, 1988||May 26, 1992||Hewlett-Packard Company||Method for recording and replaying mouse commands by recording the commands and the identities of elements affected by the commands|
|US5134580 *||Mar 22, 1990||Jul 28, 1992||International Business Machines Corporation||Computer with capability to automatically initialize in a first operating system of choice and reinitialize in a second operating system without computer shutdown|
|US5414860 *||Jan 29, 1991||May 9, 1995||International Business Machines Incorporated||Power management initialization for a computer operable under a plurality of operating systems|
|US5519870 *||Jun 6, 1995||May 21, 1996||International Business Machines Corporation||System and method for performing a continuous multi-stage function|
|US5557799 *||Nov 7, 1990||Sep 17, 1996||International Business Machines||Computer determination of operating system or data|
|US5604890 *||Aug 16, 1994||Feb 18, 1997||Miller; Paul B.||Coupling device for the switching of data lines between a data storage device controller and a plurality of bootable data storage devices|
|US5870756 *||Nov 12, 1996||Feb 9, 1999||Fujitsu Limited||Interchangeable storage medium containing program for processing data files thereupon to match a data file format to a computer system|
|US5987536 *||May 22, 1997||Nov 16, 1999||International Business Machines Corporation||Computer system having flash memory bios which can be accessed while protected mode operating system is running|
|US6282643||Nov 20, 1998||Aug 28, 2001||International Business Machines Corporation||Computer system having flash memory BIOS which can be accessed remotely while protected mode operating system is running|
|US6327653||Nov 23, 1998||Dec 4, 2001||Samsung Electronics Co., Ltd.||Technique for easily changing operating systems of a digital computer system using at least two pushbuttons|
|US6357000 *||Nov 13, 1995||Mar 12, 2002||Microsoft Corporation||Method and system for specified loading of an operating system|
|US6678712||Jan 19, 1996||Jan 13, 2004||International Business Machines Corporation||Method and system for executing a program under one of a plurality of mutually exclusive operating environments|
|US6727920 *||Mar 11, 1999||Apr 27, 2004||Micron Technology, Inc.||Multiple operating system quick boot utility|
|US6795912 *||Sep 27, 2000||Sep 21, 2004||International Business Machines Corporation||Method for controlling computer, computer, and storage medium|
|US7127723 *||Mar 2, 2001||Oct 24, 2006||Hitachi, Ltd.||Information processing apparatus with multiple operating systems|
|US7281104 *||Mar 21, 2005||Oct 9, 2007||Acronis Inc.||System and method for online data migration|
|US7533350||Mar 23, 2004||May 12, 2009||Micron Technology, Inc.||Multiple operating system quick boot utility|
|US7853926 *||Dec 14, 2010||International Business Machines Corporation||Automated context-sensitive operating system switch|
|US8554439 *||Jun 25, 2009||Oct 8, 2013||Kawasaki Jukogyo Kabushiki Kaisha||Slip suppression control for a motorcycle with an on/off input device|
|US20010029550 *||Mar 2, 2001||Oct 11, 2001||Yoshinori Endo||Information processing apparatus|
|US20020116632 *||Nov 7, 2001||Aug 22, 2002||Hitachi, Ltd.||Tamper-resistant computer system|
|US20040210848 *||Mar 23, 2004||Oct 21, 2004||Vineyard James L.||Multiple operating system quick boot utility|
|US20040225864 *||Jun 3, 2004||Nov 11, 2004||Burriss Michael Lee||Generic software interface for hardware environments|
|US20040226020 *||Jun 16, 2004||Nov 11, 2004||Ati Technologies, Inc.||Method and system for using general and appliance operating systems in a single information handling device|
|US20070162901 *||Dec 28, 2006||Jul 12, 2007||Samsung Electronics Co., Ltd.||Operating system switching device and operating system switching method|
|US20070168728 *||Nov 21, 2005||Jul 19, 2007||Blouin Eric E||Automated context-sensitive operating system switch|
|US20070214345 *||Mar 10, 2006||Sep 13, 2007||Fleming John C||System and method for porting an operating system|
|US20090326779 *||Jun 25, 2009||Dec 31, 2009||Kawasaki Jukogyo Kabushiki Kaisha||Slip Suppression Control System for Vehicle|
|WO1992017845A1 *||Apr 8, 1992||Oct 15, 1992||Atlantix Corporation||Method for remotely accessing service-programs of a local processing system supporting multiple protocol stacks and multiple device-drivers|
|International Classification||G06F9/445, G06F9/06, G06F9/46|
|Dec 26, 1984||AS||Assignment|
Owner name: HITACHI,LTD. 6,KANDA SURUGADAI 4-CHOME,CHIYODA-KU,
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNORS:MURAI, MASAMI;HASHIO, MASANORI;TSUYUKI, YOUSUKE;AND OTHERS;REEL/FRAME:004353/0692
Effective date: 19841217
|Oct 4, 1990||FPAY||Fee payment|
Year of fee payment: 4
|Sep 28, 1994||FPAY||Fee payment|
Year of fee payment: 8
|Sep 28, 1998||FPAY||Fee payment|
Year of fee payment: 12