US20030154337A1 - Multiple operating system control method - Google Patents

Multiple operating system control method Download PDF

Info

Publication number
US20030154337A1
US20030154337A1 US10/372,219 US37221903A US2003154337A1 US 20030154337 A1 US20030154337 A1 US 20030154337A1 US 37221903 A US37221903 A US 37221903A US 2003154337 A1 US2003154337 A1 US 2003154337A1
Authority
US
United States
Prior art keywords
interrupt
inter
control software
executed
control
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US10/372,219
Inventor
Hiroshi Ohno
Tomoaki Nakamura
Shigenori Kaneko
Ryokichi Yoshizawa
Naoshi Kato
Manabu Yamauchi
Toshiaki Arai
Tomoki Sekiguchi
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Priority to US10/372,219 priority Critical patent/US20030154337A1/en
Publication of US20030154337A1 publication Critical patent/US20030154337A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4812Task transfer initiation or dispatching by interrupt, e.g. masked
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system

Definitions

  • the present invention relates to a control method of the control apparatus using a digital arithmetic processor for plant instrument control and/or various machine control, and specifically, to a control method for the multiple operating system in which plural operating systems are executed on an single processor.
  • control apparatus such as programmable logic controller (PLC) or numerical control apparatus (CNC) often used for plant instrument control and various machine controls
  • procedures for control logic are executed mainly.
  • the functions other than procedures for control logic including the function for inputting the control logic into those control apparatus (development environment) and the functions for supervisory operation for the controlled status and for allowing the user to input the data in an interactive manner (human machine interface) are often realized by another apparatus such as personal computers (PC's) connected outside the control apparatus (hereinafter referred to as user interface apparatus.)
  • PC's personal computers
  • user interface apparatus In case that those functions are embedded in a single apparatus, those functions are executed by the individual internal arithmetic processors.
  • a technology related to this kind of apparatus is disclosed, for example, in Japanese Patent Application Laid-Open Number 9-62324 (1997).
  • a software for controlling OS's is loaded in order to switch the executing OS's so that plural OS's may be operated alternately.
  • the control software is made executed on the OS with higher reliability, and the user interface program is made executed on the OS with rich functionality, and thus, OS's, each having specific characteristics are made executed on a single CPU.
  • this inter-OS control software stores and revises the context information of CPU operations (for example, register values of CPU), switches the memory spaces and restarts the OS operations in another context stored in past. In other words, the operation of the running OS is terminated and the operation of other OS's is restarted.
  • inter-OS control software has a function which monitors start-stop operations of the running OS's and controls the start-stop operation of the individual OS's independently. Owing to this configuration, it will be appreciate that the hardware and software in the control apparatus can be partially initialized and that the disabled part can be automatically recovered, which leads to higher reliability of the total system.
  • FIG. 1 is a block diagram of the embodiment using the present invention.
  • FIG. 2 is a schematic diagram of memory usage in the control apparatus.
  • FIG. 3 is a flowchart showing procedures for the interrupt operation in the execution of OS-A.
  • FIG. 4 is a flowchart showing procedures for the interrupt operation in the execution of OS-B.
  • FIG. 5 is a flowchart showing procedures for the switching operation of OS's.
  • FIG. 6 is a schematic diagram showing a function for issuing and notifying events.
  • FIG. 7 is a flowchart showing procedures for restarting OS-A exclusively.
  • FIG. 1 shows a bock diagram of the control apparatus in one embodiment of the present invention.
  • the hardware for the control apparatus 1 comprises a central processing unit (CPU) 11 , a physical memory 12 , a timer 14 , a user input output apparatus 16 , a network interface apparatus 18 and a interrupt controller 19 .
  • This structure is the same as the structure in a general purpose personal computer (PC).
  • the control apparatus 1 has a network interface apparatus 18 connected to the network 3 , and uses it for communicating with another control apparatus and reporting the control result to the host computer.
  • the control apparatus has an input and output apparatus connected to the controlled apparatus 2 for exchanging signals, and acquires the information from the controlled apparatus 2 and issues the operation instruction to the controlled apparatus 2 .
  • the interrupt controller 19 of the control apparatus 1 relays the interrupt signal from the individual components of the control apparatus 1 to CPU 11 and/or masks the interrupt signal.
  • the software of the control comprises an operating system A (OS-A) 21 and an operating system B (OS-B) both for the hardware resource management and the executive control of the program running on it, an inter-OS control software 23 for switching OS-A and OS-B, a supervisory control program 2 and a development environment program 25 both executed on OS-A, and a control program 26 executed on OS-B.
  • OS-A, OS-B and the inter-OS control software 23 are operated on an single CPU 11 in a privileged mode and enabled to execute all the instructions including the privileged instructions for controlling CPU 11 itself.
  • the programs running on the individual OS's are operated in a non-privileged mode and can not execute privileged instructions.
  • OS-A and OS-B contains device drivers operating in a privileged mode as well as the OS kernel, and in the following, those devices are discussed so as to be unified in the OS kernel.
  • the input and output apparatus 12 is controlled and occupied by OS-B.
  • the user input and output apparatus and the network interface apparatus 18 used by the programs operated on OS-A are controlled and occupied by OS-A.
  • Such a configuration is allowed that such a exigency user input and output apparatus as emergency stop button and alarm signal output and/or such a network interface apparatus as requiring real-time characteristics for communicating with another control apparatus may be controlled and occupied by OS-B and accessed by the programs running on OS-B.
  • the physical memory 13 are separated into the area 131 for OS-A and the area 132 for OS-B.
  • the hard wares accessed directly by the inter-OS control software 23 are limited to the timer 14 and the interrupt controller 19 .
  • OS-A is assumed to be a general purpose OS commonly used in PC's.
  • OS-A provides sophisticated user interfaces for the supervisory control program 24 and the development environment program 25 .
  • OS-A and the programs running on OS-A operate in the similar manner to the case that OS-B does not exist.
  • the inter-OS control software 23 interrupts the operation of OS-A, and OS-B is switched over OS-A, as the inter-OS control software 23 recovers the interrupted operation of OS-A and restarts OS-A after completing the operation of OS-B, it is not necessary for OS-A to recognize the existence of OS-B.
  • OS-B is assumed to be one that is characterized as higher real-time performance and optimized for control programs. OS-B yields its executive status to OS-A when the programs running on OS-B have no more operations to be executed (hereinafter referred to as “idle status”.)
  • the inter-OS control software 23 provides functions for switching the execution status between OS-A and OS-B, and for communicating among programs on OS's.
  • the switching operation of the execution status from OS-A to OS-B is performed in case that i) an interrupt occurs at the hardware controlled by OS-B, ii) a pre-defined period of time has passed or iii) OS-A communicates to OS-B.
  • the switching operation of the execution status from OS-B to OS-A is performed only when OS-B turns into an idle status as described above.
  • OS-B has always a execution status in preference to OS-A owing to this switching operation.
  • the inter-OS control software 23 operates only when the switching operation is initiated and the communication between OS's are requested, and the individual OS's are operated independently otherwise.
  • the privileged instructions to CPU 11 are issued by the individual OS's, but are not emulated by the inter-OS control software 23 . It is required that the inter-OS control software 23 may operates as a part of the individual OS's so as to enable to execute privileged mode instructions every time when either of OS's is executed. In particular, the inter-OS control software 23 is so embedded as to operates as a device driver for OS-A when OS-A is executed as a general purpose OS.
  • hard wares are so assigned to OS-A and OS-B as to be occupied and controlled by the individual OS's, and the operation status of OS's are switched alternately, and the individual OS's are executed independently after the switching operation.
  • the inter-OS control software 23 switches the execution of both OS's and provides the communication function between both OS's.
  • the I/O address and the interrupt number assigned to the hardware are unified and stored in the interrupt table in the inter-OS control software 23 .
  • the inter-OS control software 23 initialize the device driver of OS-A at the start-up of the control apparatus 1 .
  • the I/O address and the interrupt number of the hardware for OSB are reserved and made registered in the interrupt table.
  • the kernel of OS-A and the other device drivers of OS-A recognize that the corresponding I/O address and interrupt number are occupied, and then, the operation to those hard wares by OS-A is disabled.
  • the input and output operation to the hardware is executed by OS-A and OS-B, respectively, and is not emulated by the inter-OS control software 23 . Owing to this procedure, the additional overhead due to the emulation of the input and output operation can be prevented as well as the kernel and device drivers assumed to access directly to the hardware may not be modified.
  • the independency of the physical memory 13 is established by defining the memory areas used separately for OS-A and OS-B, respectively
  • the memory area used commonly with OS-A and OS-B is defined for sharing the data between both OS's.
  • OS-A is made started when the control apparatus 1 starts up, and then, the memory areas are so defined that the physical memory area lower than the designated address specified by the start-up option of OS-A may be occupied by OS-A.
  • OS-B is made started by loading OS-B onto the physical memory area higher than the designated address.
  • the kernel of OS-B acquires the designated address recorded on the table in the inter-OS control software 23 , and uses the area which is not used by OS-B under the memory management.
  • the memory area for the OS-A is made mapped on the address space for OS-B.
  • the inter-OS control software 23 requests the memory management mechanism of the kernel of OS-B to add the address of the physical memory to be shared to the logical address conversion table (hereinafter referred to as “page table”) for the physical memory for OS-B and to make the physical memory correspond to the logical address (hereinafter referred to as “memory mapping” or simply to “mapping”.)
  • the memory area for OS- is made mapped on the address space for OS-A.
  • the inter-OS control software 23 reserves the address of the physical memory to be shared as a device driver of OS-A.
  • a function of OS-A for realizing the device driver of the memory-mapping type physical device is used.
  • the kernel of OS-A maps the physical memory to be shared onto the page table for OS-A, which establishes the sharing of the designated common memory area.
  • OS and the programs executed on it access to the memories with reference to logical addresses, and the conversion from logical addresses to physical addresses are automated by CPU referring to the page table.
  • the individual memory management functions embedded in OS-A and OS-B operates the page table and perform the mapping operation.
  • the mapping operation can be executed independently by the individual OS.
  • the page table is a table located on the physical memory, and CPU has a register specifying the start physical address of the table. CPU obtains the address position of the page table from this register, and automates the address conversion in responsive to the obtained information. Therefore, the individual page table areas for OS-A and OS-B are defined independently on the physical memories, and the content of the register specifying the page table position is made switched so as to specify the page table for OS switched to be enabled in the OS switching operation by the inter-OS control software 23 . Owing to this procedure, both OS's can operates the mapping on the individual page tables, and thus, the independency of the logical address spaces can be established.
  • the memory usage scheme described above for the physical memory space and the logical address space is shown in FIG. 2.
  • the physical memory space 51 is made delimited into several areas including an area 52 for the kernel of OS-A, an area 54 for the OS-A programs, an area 56 for the kernel of OS-B and an area 57 for OS-B programs, which are made enabled to be accessed by the individual resources assigned to OS-A and OS-B.
  • the logical address spaces 61 and 62 for the memories recognized by OS-A and OS-B are independent logical address spaces corresponding to the independent page tables of the individual OS's.
  • OS-A is executed, the physical memory spaces 56 and 57 occupied for OS-B are not mapped onto the logical address space 61 .
  • the areas for OS-B are not accessed by OS-A with its execution enabled, which leads to preventing the data from being damaged accidentally.
  • OS-B is executed, in contrast, the physical memory spaces 52 and 54 occupied for OS-A are not mapped onto the logical address space 62 .
  • the inter-OS control software 23 should operates in either case of OS's alternate execution, the memory area 53 is mapped in either OS and accessible by the programs executed on the individual OS's and available for exchanging data between programs executed on the individual OS's.
  • the sharable area for OS-A and OS-B is limited to be used for the programs executed in a non-privileged mode, it will be appreciated that the kernel and device driver for one OS is made not affected by the other OS and its programs, and the independency and reliability of the individual OS's can be established. It is allowed that the individual area may be made segmented and distributed for the managed unit of the address conversion mechanism of CPU 11 on the physical memory area 51 .
  • inter-OS control software 23 When the inter-OS control software 23 is called explicitly by the individual OS's or their programs and an interrupt is applied to CPU, it is made started up. As the inter-OS control software 23 is embedded as a device driver of OSA, the call by OS-A or programs executed on it is realized as an operation instruction directed to the corresponding device driver (for example, IOCTL instruction). As OS-B recognizes the existence of the inter-OS control software 23 , OS-B or programs executed on it are called as a function all from the procedure in the kernel of OS-B.
  • interrupt handler As CPU 11 calls the interrupt handler by referring to the interrupt table located on the physical memory 13 when an interrupt occurs, all the interrupt handlers are defined as routines in the inter-OS control software 23 by modifying the interrupt table. Owing to this configuration, the inter-OS control software 23 is activated when any interrupt occurs, which leads to establishing adequate procedures.
  • inter-OS control software 23 Once the inter-OS control software 23 is made start up, it switches OS's in responsive to its causal event, and performs necessary procedures for communicating between OS's. Its procedural steps are described in detail below.
  • FIG. 3 shows the procedural steps for the case that an interrupt occurs while OS-A with its execution being defined with nonpriority is in operation.
  • an interrupt processing routine of the inter-OS control software 23 is called, and the procedures shown in FIG. 3 are executed.
  • the content of the register when the interrupt occurs is transferred onto the stack and a stack frame is generated (S 01 ).
  • S 01 the content of the register when the interrupt occurs is transferred onto the stack and a stack frame is generated
  • S 02 an interrupt number
  • the cause of the interrupt is either a case that an interrupt instruction is issued explicitly by the process of OS-A in operation or a case that an exception occurs due to its program operation, and in either case, the interrupt handler of OS-A itself is called.
  • the hardware interrupt which hardware makes the cause of the interrupt is judged (S 03 ).
  • the interrupt handler of OS-A itself is called in the similar manner to the software interrupt.
  • the operation environment is switched to OS-B (S 04 ), and then, the interrupt handler of OS-B itself is called.
  • the interrupt is a timer interrupt
  • the time when the interrupt occurs is identified (S 05 )
  • the timer handler of the individual OS itself is called.
  • the time-up of the timer for OS-A is made withheld, and only the timer handler of OS-B with its execution given priority is called.
  • FIG. 4 shows the procedural steps for the case that an interrupt occurs while OS-B with its execution being defined with priority is in operation.
  • an interrupt processing routine of the inter-OS control software 23 is called, and the procedures shown in FIG. 4 are executed.
  • the content of the register when the interrupt occurs is transferred onto the stack (S 11 ).
  • an interrupt number vector
  • what is judged is whether the interrupt is a software interrupt or a hardware interrupt (S 12 ).
  • the interrupt handler of OS-B in operation is called.
  • the interrupt controller 19 is made operated when enabling OS-B to be in operation, and the interrupt from the hardware managed by OS-A is masked.
  • the interrupt by the hardware managed by OS-A doe not occur while OS-B is in operation.
  • the interrupt handler of OS-B itself is called in the similar manner to the case for the software interrupt.
  • the interrupt is a timer interrupt
  • the time when the interrupt occurs is identified (S 14 ), and if the identified time is a time when the timer for OS-B should be time up, the timer handler of OS-B itself is called.
  • the identified time is a time when the timer for OS-A should be time up
  • the fact of the occurrence of the time up is recorded (S 15 )
  • the operation of OS-B is recovered.
  • the cause of the interrupt is judged to be an apparatus managed by OS-A
  • the fact of the occurrence of the interrupt is recorded when the cause of the interrupt is judged (S 13 )
  • the interrupt handler of OS-A itself may be called when enabling OS-A to be in operation.
  • the execution time for the individual OS's are estimated before hand. If a timer interrupt occurs while OS-B is in operation, whether the time for switching from OS-B to OS-A has come is judged by referring to the pre-defined execution time of OS-B (S 16 ), and then, if the time for switching to OS-A has come, OS-A is made enabled to be in operation (S 17 ) and the procedure goes to the interrupt point for OS-A. If the time for switching to OS-A has not come, the procedure visits again the interrupt point at the time when the interrupt of OS-B occurs. In contrast, a timer interrupt occurs while OS-A is in operation, in the procedure shown in FIG.
  • FIG. 5 shows a detail procedure of switching OS's in the inter-OS control software 32 .
  • the OS switching procedure is invoked in case that the switching procedure is required in the interrupt process described above, that OS-B turns into an idle state or that the stand-by state of the stand-by program of OS-B is required to be cancelled in responsive to the notification of the event which will be described later.
  • the context at the point hereinafter referred to as “interrupt point” when the interrupt occurs or the inter-OS control software 23 is invoked is stored (S 31 ).
  • the property of the interrupt controller 19 is modified so as to apply a mask for preventing the interrupt of OS-A while OS-B is in operation or to cancel a mask for the interrupt of OS-A.
  • the register indicating the top memory position of the page table is modified and the memory space is made switched (S 33 ). This operation is as same as described before.
  • the notification of the event between OS's is executed (S 34 ), which will be described later in detail.
  • the interrupt routine corresponding to the interrupt with its causal event recorded in step S 15 of the procedure shown in FIG. 4 is called and the suspended interrupt operations are made executed (S 35 ).
  • the context stored in S 31 while suspending the interrupt operations is recovered (S 38 ), and the procedure visits again the interrupt point of the switched OS.
  • All the necessary data are stored on the memory so that the content of the register may be deleted when OS-B is expected to be switched to OS-A while OS-B is staying in an idle state, and the context is made not recovered when the interrupt handler of OS-B is called (S 37 ).
  • the interrupt controller 19 can mask the individual interrupt operation by specifying its interrupt number, and in case that OS-A operates independently, the interrupt mask with lower priority is applied while processing the interrupt operation of OS-A. in case that the masked interrupt include the interrupt of OS-B, a time day occurs in the corresponding interrupt operation until the mask is released. In order to avoid this time delay, it is required to modify the interrupt controller process in the kernel of OS-A so that the interrupt operation with the interrupt number for OS-B may be made disabled.
  • the timer interrupt of OS-A is processed only in a definite time interval in responsive to the interrupt signal from the timer 14 , and thus, the timer 14 is not operated while OS-A is in operation, but operated once at the initialization process. Therefore, the interrupt signal from the timer 14 is received temporarily by the inter-OS control software 23 , and it is allowed that the interrupt handler of OS-A is only called in the steps after S 03 of the procedure shown in FIG. 3.
  • inter-OS control software 23 is called explicitly by either OS for the communication function between a couple of OS's.
  • a function for issuing and notifying events between OS's as a basic function for communicating between a couple of OS's is shown in FIG. 6.
  • OS-A event processing table 71 on the memory managed by the inter-OS control software 23 .
  • Event numbers, i 1 , i 2 , . . . iN, are assigned to the events enabled to be processed, and there exist their corresponding N entries.
  • the event table is empty at the initial state.
  • the OS-A program (Program A) specifies the event number (i 2 ) and notifies the occurrence of the event and issues the suspend request to the inter-OS control software 23 (S 41 )
  • the inter-OS control program 23 records into the entry i 2 of the corresponding event on the table 71 that the program (Program A) is in a suspended state.
  • the program issuing the suspend request stops its operation by the program interrupt function of OS-A.
  • the inter-OS control software 23 looks up the corresponding entry iN in the table 71 and judges the existence of the program suspended on OS-A. In case that there is a suspended program, the release request for the suspended program (Program B) is issued to OS-A. In responsive to this request, the program suspended on OS-A is restarted and recognized that the suspended event is activated. The notification of event activation is allowed from the program (Program C) executed on OS-A (S 44 ). Thus, the events issued on an identical OS and the events issued on the different OS's can be made stood by simultaneously. In the similar manner, there is an event processing table 72 for OS-B is defined, and the event to be issued can be watched by the program on OS-B in contrast to the previous case.
  • the interrupt and restart function of the program used in the event. notification described above can be realized by a function of OS-A for reporting that the inter-OS control software 23 operating as a device driver starts and terminates the input and output operation to the device.
  • OS-B this function can be realized by the inter-OS control software 23 calling a routine of OS-B for starting and terminating directly the program.
  • the scope of suspend operation is assumed to be on the basis of program in the explanation of the event notification in the above description, the interrupt and restart operation is applied on the thread-by-thread basis in the operating systems providing a multi-thread environment.
  • the event process table is defined so as to contain the program numbers, it is allowed that it may contain the structures in OS and their pointers for judging the suspended programs in stead.
  • the system is composed with another buffer formed on the memory managed by the inter-OS control software 23 , and it is operated so that the data may be received from the side of issuing an event and recorded onto the buffer at the same time when the event is issued, and that the data may be transferred when the suspended state is released, and thus, a message communication function having a function for waiting the event arrival can be realized.
  • the inter-OS control software 23 provides a function that allows an continuous operation of either one of OS-A or OS-B, and interrupts and restart the other OS.
  • OS-A is shut down
  • the program executed on OS-A detects the execution of shut-down operation and notifies it to the inter-OS control software 23 .
  • the interrupt handler of the inter-OS control software 23 judges the exception. In case that OS-A is shut down or an exception occurs, as the inter-OS control software 23 does not allow OS-B to be switched from its suspend state to being in operation, then OS-A continues to be in operation.
  • the content of the register and the content of all the memory area managed by OS-A are copied on the memory area managed by the inter-OS control software 23 .
  • the hard wares managed by OS-A are initialized by the individual device drivers of OS-A (S 53 ).
  • OS-A goes to an ordinary operation state, and in case that OS-A is terminated due to a shut-down operation or an exception, the inter-OS control software 23 shuts down only OS-A in the above described manner (S 54 ).
  • the inter-OS control software 23 restores the context stored at OS-A automatically or in responsive to the request from the program of OS-B (S 55 ).
  • OS-A used as a versatile OS only the process for the interrupt controller 19 is modified, and other process or components are not modified. This makes it easier to add OS-B and the inter-OS control software 23 for OS-A used as a versatile OS.
  • the area of influence of the abnormal behavior of OS's and their related programs can be localized, and the abnormal state can be transferred to an ordinary operation mode only by restarting the partial component on the basis of the individual OS's without terminating the whole control apparatus, which leads to increasing the reliability of the system in addition, the operation of OS's can be observed from the space independent of the spaces for the ordinary operation of OS's and their programs.

Abstract

An inter-OS control software for switching OS's in operation executed on a single CPU is installed, and plural OS's are made alternately executed. A control program is executed exclusively on one OS, which controls the controlled apparatus. A supervisory control program and a development environment program are executed on another OS, and a memory space is divided so as to make no effect for the operation of the control program. A higher real-time performance and reliability can be established with a single CPU architecture.

Description

    CROSS REFERENCES TO RELATED APPLICATIONS
  • This is a continuation of application No. 09/585,120 filed Jun. 1, 2000.[0001]
  • BACKGROUND OF THE INVENTION
  • The present invention relates to a control method of the control apparatus using a digital arithmetic processor for plant instrument control and/or various machine control, and specifically, to a control method for the multiple operating system in which plural operating systems are executed on an single processor. [0002]
  • In the control apparatus such as programmable logic controller (PLC) or numerical control apparatus (CNC) often used for plant instrument control and various machine controls, procedures for control logic are executed mainly. The functions other than procedures for control logic including the function for inputting the control logic into those control apparatus (development environment) and the functions for supervisory operation for the controlled status and for allowing the user to input the data in an interactive manner (human machine interface) are often realized by another apparatus such as personal computers (PC's) connected outside the control apparatus (hereinafter referred to as user interface apparatus.) In case that those functions are embedded in a single apparatus, those functions are executed by the individual internal arithmetic processors. A technology related to this kind of apparatus is disclosed, for example, in Japanese Patent Application Laid-Open Number 9-62324 (1997). [0003]
  • The performance of PC's used as a user interface apparatus has increased, and thus, computational power can be provided so that a single PC may cover the functions from the control logic operations to the development environment and the supervisory control up to a certain scale of control systems. However, in case of using a control apparatus comprising a PC-based hardware architecture supporting all of the system functions and applying an operating system (OS) generally used in PC's, the operations of the programs and the device drivers other than the control programs may affect the operation of the control programs themselves. [0004]
  • There is such a technology that computer resources are shared in common with multiple OS's and the functions-generic to the individual OS's are used by loading and running plural OS's on an single CPU. Examples of this technology are disclosed in Japanese Patent Application Laid-Open Number 5-73340 (1993), Japanese Patent Application Laid-Open Number 5-27954 (1993) and Japanese Patent Application Laid-Open Number 5-151003 (1993). [0005]
  • Privileged instructions are executed generally in OS's. Therefore, some disability occurring in one of OS's may affects the execution of the other OS's. However, this affect is not considered in the technology in which plural OS's are loaded and ran simultaneously on a single computer, and hence, even by means of isolating the influence of the disabled OS over the other OS's by emulating the disabled OS by the other OS's as described in and Japanese Patent Application Laid-Open Number 5-1510003 (1993), the influence may be propagated onto the operations of both OS's in case that some disability may occur the OS emulating the disabled OS. [0006]
  • SUMMARY OF THE INVENTION
  • In the present invention, in order to solve the above problems, a software for controlling OS's is loaded in order to switch the executing OS's so that plural OS's may be operated alternately. The control software is made executed on the OS with higher reliability, and the user interface program is made executed on the OS with rich functionality, and thus, OS's, each having specific characteristics are made executed on a single CPU. In responsive to the generation of interrupt or the request signal from OS's or the software programs running on OS's, this inter-OS control software stores and revises the context information of CPU operations (for example, register values of CPU), switches the memory spaces and restarts the OS operations in another context stored in past. In other words, the operation of the running OS is terminated and the operation of other OS's is restarted. In addition, the inter-OS control software has a function which monitors start-stop operations of the running OS's and controls the start-stop operation of the individual OS's independently. Owing to this configuration, it will be appreciate that the hardware and software in the control apparatus can be partially initialized and that the disabled part can be automatically recovered, which leads to higher reliability of the total system. [0007]
  • Individual memory spaces occupied for the individual OS's and a memory space shared and accessible commonly by plural OS's are defined on the physical memory. Owing to this configuration, the individual memory spaces for the kernel and the programs are so defined that the interference among OS's such as data destruction may be avoided and that the necessary data may be shared by the programs each executed on the:difference OS's. In addition, the system has such a function that the program running on a certain OS waits for the event issued by the other OS's and/or the programs running on those OS's and the inter-OS control software notifies this event. Owing to this configuration, a communication function between the programs running on the different OS's can be established.[0008]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram of the embodiment using the present invention. [0009]
  • FIG. 2 is a schematic diagram of memory usage in the control apparatus. [0010]
  • FIG. 3 is a flowchart showing procedures for the interrupt operation in the execution of OS-A. [0011]
  • FIG. 4 is a flowchart showing procedures for the interrupt operation in the execution of OS-B. [0012]
  • FIG. 5 is a flowchart showing procedures for the switching operation of OS's. [0013]
  • FIG. 6 is a schematic diagram showing a function for issuing and notifying events. [0014]
  • FIG. 7 is a flowchart showing procedures for restarting OS-A exclusively.[0015]
  • PREFERRED EMBODIMENTS OF THE INVENTION
  • FIG. 1 shows a bock diagram of the control apparatus in one embodiment of the present invention. [0016]
  • The hardware for the [0017] control apparatus 1 comprises a central processing unit (CPU) 11, a physical memory 12, a timer 14, a user input output apparatus 16, a network interface apparatus 18 and a interrupt controller 19. This structure is the same as the structure in a general purpose personal computer (PC). The control apparatus 1 has a network interface apparatus 18 connected to the network 3, and uses it for communicating with another control apparatus and reporting the control result to the host computer. The control apparatus has an input and output apparatus connected to the controlled apparatus 2 for exchanging signals, and acquires the information from the controlled apparatus 2 and issues the operation instruction to the controlled apparatus 2. The interrupt controller 19 of the control apparatus 1 relays the interrupt signal from the individual components of the control apparatus 1 to CPU 11 and/or masks the interrupt signal.
  • The software of the control comprises an operating system A (OS-A) [0018] 21 and an operating system B (OS-B) both for the hardware resource management and the executive control of the program running on it, an inter-OS control software 23 for switching OS-A and OS-B, a supervisory control program 2 and a development environment program 25 both executed on OS-A, and a control program 26 executed on OS-B. OS-A, OS-B and the inter-OS control software 23 are operated on an single CPU 11 in a privileged mode and enabled to execute all the instructions including the privileged instructions for controlling CPU 11 itself. On the other hand, the programs running on the individual OS's are operated in a non-privileged mode and can not execute privileged instructions. OS-A and OS-B contains device drivers operating in a privileged mode as well as the OS kernel, and in the following, those devices are discussed so as to be unified in the OS kernel.
  • The input and [0019] output apparatus 12 is controlled and occupied by OS-B. On the other hand, the user input and output apparatus and the network interface apparatus 18 used by the programs operated on OS-A are controlled and occupied by OS-A. Such a configuration is allowed that such a exigency user input and output apparatus as emergency stop button and alarm signal output and/or such a network interface apparatus as requiring real-time characteristics for communicating with another control apparatus may be controlled and occupied by OS-B and accessed by the programs running on OS-B. The physical memory 13 are separated into the area 131 for OS-A and the area 132 for OS-B. The hard wares accessed directly by the inter-OS control software 23 are limited to the timer 14 and the interrupt controller 19.
  • At first, the overall operation of the software and its relation to the hardware are described. In this embodiment, OS-A is assumed to be a general purpose OS commonly used in PC's. OS-A provides sophisticated user interfaces for the [0020] supervisory control program 24 and the development environment program 25. OS-A and the programs running on OS-A operate in the similar manner to the case that OS-B does not exist. Though the inter-OS control software 23 interrupts the operation of OS-A, and OS-B is switched over OS-A, as the inter-OS control software 23 recovers the interrupted operation of OS-A and restarts OS-A after completing the operation of OS-B, it is not necessary for OS-A to recognize the existence of OS-B.
  • On the other hand, OS-B is assumed to be one that is characterized as higher real-time performance and optimized for control programs. OS-B yields its executive status to OS-A when the programs running on OS-B have no more operations to be executed (hereinafter referred to as “idle status”.) [0021]
  • The [0022] inter-OS control software 23 provides functions for switching the execution status between OS-A and OS-B, and for communicating among programs on OS's. The switching operation of the execution status from OS-A to OS-B is performed in case that i) an interrupt occurs at the hardware controlled by OS-B, ii) a pre-defined period of time has passed or iii) OS-A communicates to OS-B. The switching operation of the execution status from OS-B to OS-A is performed only when OS-B turns into an idle status as described above. OS-B has always a execution status in preference to OS-A owing to this switching operation. The inter-OS control software 23 operates only when the switching operation is initiated and the communication between OS's are requested, and the individual OS's are operated independently otherwise. The privileged instructions to CPU 11 are issued by the individual OS's, but are not emulated by the inter-OS control software 23. It is required that the inter-OS control software 23 may operates as a part of the individual OS's so as to enable to execute privileged mode instructions every time when either of OS's is executed. In particular, the inter-OS control software 23 is so embedded as to operates as a device driver for OS-A when OS-A is executed as a general purpose OS.
  • As described above, hard wares are so assigned to OS-A and OS-B as to be occupied and controlled by the individual OS's, and the operation status of OS's are switched alternately, and the individual OS's are executed independently after the switching operation. The [0023] inter-OS control software 23 switches the execution of both OS's and provides the communication function between both OS's.
  • Next, a method for establishing the independency between OS's is described. At first, a method for protecting the hard wares controlled and supervised by the individual OS from interference by another OS's. The interaction between individual hard wares and software includes the input and output operation for the I/O addresses assigned to the individual hard wares and the response operation of the software to the interrupts with their interrupt numbers each assigned to the individual hard ware. Thus, the independency between OS's with respect to the hard ware control is established by ensuring that the input and output operation to the I/O addresses assigned to the hardware controlled and managed exclusively by one OS and the response operation to the interrupt number assigned to this hardware may not be executed by the other OS. [0024]
  • In order to specify which OS should manage and occupy the individual hardware, the I/O address and the interrupt number assigned to the hardware are unified and stored in the interrupt table in the [0025] inter-OS control software 23. The inter-OS control software 23 initialize the device driver of OS-A at the start-up of the control apparatus 1. In its initialization process, the I/O address and the interrupt number of the hardware for OSB are reserved and made registered in the interrupt table. By this process, the kernel of OS-A and the other device drivers of OS-A recognize that the corresponding I/O address and interrupt number are occupied, and then, the operation to those hard wares by OS-A is disabled. On the other hand, by means that the I/O address and the interrupt number of the hardware occupied by OS-A are made acquired by OS-B directly from the inter-OS control software 23 and registered in the interrupt table, the operation to those hard wares by OS-B is made disabled. According to the above procedures, the independency between OS's with respect to the hard ware control is established.
  • The input and output operation to the hardware is executed by OS-A and OS-B, respectively, and is not emulated by the [0026] inter-OS control software 23. Owing to this procedure, the additional overhead due to the emulation of the input and output operation can be prevented as well as the kernel and device drivers assumed to access directly to the hardware may not be modified.
  • Nest, a method for establishing the independency of the physical memory space used by the individual OS's is described. The independency of the [0027] physical memory 13 is established by defining the memory areas used separately for OS-A and OS-B, respectively The memory area used commonly with OS-A and OS-B is defined for sharing the data between both OS's.
  • In order to define the separated areas individually occupied by OS-A or OS-B, at first, OS-A is made started when the [0028] control apparatus 1 starts up, and then, the memory areas are so defined that the physical memory area lower than the designated address specified by the start-up option of OS-A may be occupied by OS-A. After start-up of OS-A, OS-B is made started by loading OS-B onto the physical memory area higher than the designated address. The kernel of OS-B acquires the designated address recorded on the table in the inter-OS control software 23, and uses the area which is not used by OS-B under the memory management.
  • There are two cases for the memory area commonly shared by OS's. In one case, the memory area for the OS-A is made mapped on the address space for OS-B. In this case, the [0029] inter-OS control software 23 requests the memory management mechanism of the kernel of OS-B to add the address of the physical memory to be shared to the logical address conversion table (hereinafter referred to as “page table”) for the physical memory for OS-B and to make the physical memory correspond to the logical address (hereinafter referred to as “memory mapping” or simply to “mapping”.) In the other case, the memory area for OS- is made mapped on the address space for OS-A. In this case, the inter-OS control software 23 reserves the address of the physical memory to be shared as a device driver of OS-A. In this case, a function of OS-A for realizing the device driver of the memory-mapping type physical device is used. Owing to this configuration, the kernel of OS-A maps the physical memory to be shared onto the page table for OS-A, which establishes the sharing of the designated common memory area.
  • Next, a method for establishing the independency of the logical address spaces of the individual OS's is described. OS and the programs executed on it access to the memories with reference to logical addresses, and the conversion from logical addresses to physical addresses are automated by CPU referring to the page table. The individual memory management functions embedded in OS-A and OS-B operates the page table and perform the mapping operation. At this time, by means that the page table is made separated into tables each used exclusively by the individual OS and switched in responsive to the OS's operation privilege, the mapping operation can be executed independently by the individual OS. [0030]
  • The page table is a table located on the physical memory, and CPU has a register specifying the start physical address of the table. CPU obtains the address position of the page table from this register, and automates the address conversion in responsive to the obtained information. Therefore, the individual page table areas for OS-A and OS-B are defined independently on the physical memories, and the content of the register specifying the page table position is made switched so as to specify the page table for OS switched to be enabled in the OS switching operation by the [0031] inter-OS control software 23. Owing to this procedure, both OS's can operates the mapping on the individual page tables, and thus, the independency of the logical address spaces can be established.
  • The memory usage scheme described above for the physical memory space and the logical address space is shown in FIG. 2. The [0032] physical memory space 51 is made delimited into several areas including an area 52 for the kernel of OS-A, an area 54 for the OS-A programs, an area 56 for the kernel of OS-B and an area 57 for OS-B programs, which are made enabled to be accessed by the individual resources assigned to OS-A and OS-B. The logical address spaces 61 and 62 for the memories recognized by OS-A and OS-B are independent logical address spaces corresponding to the independent page tables of the individual OS's. When OS-A is executed, the physical memory spaces 56 and 57 occupied for OS-B are not mapped onto the logical address space 61. Owing to this configuration, the areas for OS-B are not accessed by OS-A with its execution enabled, which leads to preventing the data from being damaged accidentally. When OS-B is executed, in contrast, the physical memory spaces 52 and 54 occupied for OS-A are not mapped onto the logical address space 62. As the inter-OS control software 23 should operates in either case of OS's alternate execution, the memory area 53 is mapped in either OS and accessible by the programs executed on the individual OS's and available for exchanging data between programs executed on the individual OS's. By means that the sharable area for OS-A and OS-B is limited to be used for the programs executed in a non-privileged mode, it will be appreciated that the kernel and device driver for one OS is made not affected by the other OS and its programs, and the independency and reliability of the individual OS's can be established. It is allowed that the individual area may be made segmented and distributed for the managed unit of the address conversion mechanism of CPU 11 on the physical memory area 51.
  • According to the methods described above, the dependency of OS's can be established. [0033]
  • Next, the operation of the [0034] inter-OS control software 23 is described in detail. When the inter-OS control software 23 is called explicitly by the individual OS's or their programs and an interrupt is applied to CPU, it is made started up. As the inter-OS control software 23 is embedded as a device driver of OSA, the call by OS-A or programs executed on it is realized as an operation instruction directed to the corresponding device driver (for example, IOCTL instruction). As OS-B recognizes the existence of the inter-OS control software 23, OS-B or programs executed on it are called as a function all from the procedure in the kernel of OS-B. As CPU 11 calls the interrupt handler by referring to the interrupt table located on the physical memory 13 when an interrupt occurs, all the interrupt handlers are defined as routines in the inter-OS control software 23 by modifying the interrupt table. Owing to this configuration, the inter-OS control software 23 is activated when any interrupt occurs, which leads to establishing adequate procedures.
  • Once the [0035] inter-OS control software 23 is made start up, it switches OS's in responsive to its causal event, and performs necessary procedures for communicating between OS's. Its procedural steps are described in detail below.
  • FIG. 3 shows the procedural steps for the case that an interrupt occurs while OS-A with its execution being defined with nonpriority is in operation. As the result of the interrupt input, an interrupt processing routine of the [0036] inter-OS control software 23 is called, and the procedures shown in FIG. 3 are executed. At first, the content of the register when the interrupt occurs is transferred onto the stack and a stack frame is generated (S01). Next, by referring to an interrupt number (vector), what is judged is whether the interrupt is a software interrupt or a hardware interrupt (S02). In case of the software interrupt, the cause of the interrupt is either a case that an interrupt instruction is issued explicitly by the process of OS-A in operation or a case that an exception occurs due to its program operation, and in either case, the interrupt handler of OS-A itself is called. On the other hand, in case of the hardware interrupt, which hardware makes the cause of the interrupt is judged (S03). In case that the interrupt comes. from the hardware managed by OS-A, the interrupt handler of OS-A itself is called in the similar manner to the software interrupt. In contrast, in case that the interrupt comes from the hardware managed by OS-B, the operation environment is switched to OS-B (S04), and then, the interrupt handler of OS-B itself is called. In case that the interrupt is a timer interrupt, the time when the interrupt occurs is identified (S05), and if the identified time is a time when the timer for OS-A or OS-B should be time up, the timer handler of the individual OS itself is called. In case that both timers reach the time for the scheduled time-up, the time-up of the timer for OS-A is made withheld, and only the timer handler of OS-B with its execution given priority is called.
  • FIG. 4 shows the procedural steps for the case that an interrupt occurs while OS-B with its execution being defined with priority is in operation. In this case, as in the similar manner to the case that an interrupt occurs while OS-A is in operation, as the result of the interrupt input, an interrupt processing routine of the [0037] inter-OS control software 23 is called, and the procedures shown in FIG. 4 are executed. At first, the content of the register when the interrupt occurs is transferred onto the stack (S11). Next, by referring to an interrupt number (vector), what is judged is whether the interrupt is a software interrupt or a hardware interrupt (S12). In case of the software interrupt, the interrupt handler of OS-B in operation is called. In case of the hardware interrupt, the interrupt controller 19 is made operated when enabling OS-B to be in operation, and the interrupt from the hardware managed by OS-A is masked. Thus, the interrupt by the hardware managed by OS-A doe not occur while OS-B is in operation. In case that an interrupt occurs at the hardware managed by OS-B, the interrupt handler of OS-B itself is called in the similar manner to the case for the software interrupt. However, in case that the interrupt is a timer interrupt, the time when the interrupt occurs is identified (S14), and if the identified time is a time when the timer for OS-B should be time up, the timer handler of OS-B itself is called. If the identified time is a time when the timer for OS-A should be time up, the fact of the occurrence of the time up is recorded (S15), and the operation of OS-B is recovered. As the system has such a hardware configuration that the operation of the interrupt controller 19 is not allowed explicitly, the cause of the interrupt is judged to be an apparatus managed by OS-A, the fact of the occurrence of the interrupt is recorded when the cause of the interrupt is judged (S13), and the interrupt handler of OS-A itself may be called when enabling OS-A to be in operation.
  • The above description refers to the operation in case that OS-B is made given priority completely. In this process, the operation for switching from OS-B to OS-A is executed only when OS-B turns into an idle state, and a process for notifying the fact of the idle state from OS-B to the [0038] inter-OS control software 23 is called. In view of the avoidance of the deadlock when OS-B gets into an infinite loop, an operation of OS-A is scheduled in a definite time fraction. Thus, an timer interrupt is made occur at the time other than the time when the timers for OS-A and OS-B are count up, and OS's are switched in the interrupt process of the inter-OS control software 23. In the inter-OS control software 23, the execution time for the individual OS's are estimated before hand. If a timer interrupt occurs while OS-B is in operation, whether the time for switching from OS-B to OS-A has come is judged by referring to the pre-defined execution time of OS-B (S16), and then, if the time for switching to OS-A has come, OS-A is made enabled to be in operation (S17) and the procedure goes to the interrupt point for OS-A. If the time for switching to OS-A has not come, the procedure visits again the interrupt point at the time when the interrupt of OS-B occurs. In contrast, a timer interrupt occurs while OS-A is in operation, in the procedure shown in FIG. 3, whether OS-B is staying in an idle state is judged (S06), and then, if OS-B is not in an idle state, whether the time has passed for going back to OS-B is judged (S07). If the time has passed for going back to OS-B, OS-B is made enabled to be in operation (S08), and the procedure goes to the interrupt point for OS-B. However,if OS-B is staying in an idle state or the time has not passed for going back to OS-B, then the procedure visits again the interrupt point at the when the interrupt of OS-A occurs again.
  • FIG. 5 shows a detail procedure of switching OS's in the inter-OS control software [0039] 32. The OS switching procedure is invoked in case that the switching procedure is required in the interrupt process described above, that OS-B turns into an idle state or that the stand-by state of the stand-by program of OS-B is required to be cancelled in responsive to the notification of the event which will be described later. At first, the context at the point (hereinafter referred to as “interrupt point”) when the interrupt occurs or the inter-OS control software 23 is invoked is stored (S31). This means that the stack frame position where the content of the register in CPU11 at the interrupt point is recorded and the values of the instruction counter and the stack pointer are recorded. Next, the property of the interrupt controller 19 is modified so as to apply a mask for preventing the interrupt of OS-A while OS-B is in operation or to cancel a mask for the interrupt of OS-A.
  • Next, the register indicating the top memory position of the page table is modified and the memory space is made switched (S[0040] 33). This operation is as same as described before. Next, the notification of the event between OS's is executed (S34), which will be described later in detail. When switching from OS-A to OS-B, the interrupt routine corresponding to the interrupt with its causal event recorded in step S15 of the procedure shown in FIG. 4 is called and the suspended interrupt operations are made executed (S35). Then, after completing all the recorded interrupt operations (S36), the context stored in S31 while suspending the interrupt operations is recovered (S38), and the procedure visits again the interrupt point of the switched OS. All the necessary data are stored on the memory so that the content of the register may be deleted when OS-B is expected to be switched to OS-A while OS-B is staying in an idle state, and the context is made not recovered when the interrupt handler of OS-B is called (S37).
  • The interrupt [0041] controller 19 can mask the individual interrupt operation by specifying its interrupt number, and in case that OS-A operates independently, the interrupt mask with lower priority is applied while processing the interrupt operation of OS-A. in case that the masked interrupt include the interrupt of OS-B, a time day occurs in the corresponding interrupt operation until the mask is released. In order to avoid this time delay, it is required to modify the interrupt controller process in the kernel of OS-A so that the interrupt operation with the interrupt number for OS-B may be made disabled. On the other hand, the timer interrupt of OS-A is processed only in a definite time interval in responsive to the interrupt signal from the timer 14, and thus, the timer 14 is not operated while OS-A is in operation, but operated once at the initialization process. Therefore, the interrupt signal from the timer 14 is received temporarily by the inter-OS control software 23, and it is allowed that the interrupt handler of OS-A is only called in the steps after S03 of the procedure shown in FIG. 3.
  • There is such a case that the [0042] inter-OS control software 23 is called explicitly by either OS for the communication function between a couple of OS's. A function for issuing and notifying events between OS's as a basic function for communicating between a couple of OS's is shown in FIG. 6.
  • There exists an OS-A event processing table [0043] 71 on the memory managed by the inter-OS control software 23. Event numbers, i1, i2, . . . iN, are assigned to the events enabled to be processed, and there exist their corresponding N entries. The event table is empty at the initial state. After the OS-A program (Program A) specifies the event number (i2) and notifies the occurrence of the event and issues the suspend request to the inter-OS control software 23 (S41), the inter-OS control program 23 records into the entry i2 of the corresponding event on the table 71 that the program (Program A) is in a suspended state. The program issuing the suspend request stops its operation by the program interrupt function of OS-A. Next, if the OS-B program (Program B) notifies an event occurrence with its event number (iN) (S42), the inter-OS control software 23 looks up the corresponding entry iN in the table 71 and judges the existence of the program suspended on OS-A. In case that there is a suspended program, the release request for the suspended program (Program B) is issued to OS-A. In responsive to this request, the program suspended on OS-A is restarted and recognized that the suspended event is activated. The notification of event activation is allowed from the program (Program C) executed on OS-A (S44). Thus, the events issued on an identical OS and the events issued on the different OS's can be made stood by simultaneously. In the similar manner, there is an event processing table 72 for OS-B is defined, and the event to be issued can be watched by the program on OS-B in contrast to the previous case.
  • The interrupt and restart function of the program used in the event. notification described above can be realized by a function of OS-A for reporting that the [0044] inter-OS control software 23 operating as a device driver starts and terminates the input and output operation to the device. For OS-B, this function can be realized by the inter-OS control software 23 calling a routine of OS-B for starting and terminating directly the program. Though the scope of suspend operation is assumed to be on the basis of program in the explanation of the event notification in the above description, the interrupt and restart operation is applied on the thread-by-thread basis in the operating systems providing a multi-thread environment. Though the event process table is defined so as to contain the program numbers, it is allowed that it may contain the structures in OS and their pointers for judging the suspended programs in stead. In addition, the system is composed with another buffer formed on the memory managed by the inter-OS control software 23, and it is operated so that the data may be received from the side of issuing an event and recorded onto the buffer at the same time when the event is issued, and that the data may be transferred when the suspended state is released, and thus, a message communication function having a function for waiting the event arrival can be realized.
  • The [0045] inter-OS control software 23 provides a function that allows an continuous operation of either one of OS-A or OS-B, and interrupts and restart the other OS.
  • At first, what is described is an operation for terminating and restarting OS-B while operating continuously OS-A. In case that OS-B is shut down, or that OS-B is made terminated forcibly due to an exception, a routine of the [0046] inter-OS control software 23 is called and is made notified. As the inter-OS control software 23 does not allow OS-B to be switched from its suspend state to being in operation from this notification onward, only OS-A continues to be in operation. As OS-B is made started in responsive to a designated initialization routine called by the inter-OS control software 23, its restart can be executed in the similar manner to its ordinary start-up.
  • Next, what is described is an operation for terminating and restarting OS-A while operating continuously OS-B. When OS-A is shut down, the program executed on OS-A detects the execution of shut-down operation and notifies it to the [0047] inter-OS control software 23. When an exception occurs in OS-A, the interrupt handler of the inter-OS control software 23 judges the exception. In case that OS-A is shut down or an exception occurs, as the inter-OS control software 23 does not allow OS-B to be switched from its suspend state to being in operation, then OS-A continues to be in operation. However, if OS-A in a suspend state is made restarted in the similar manner to an ordinary start-up, common hard wares including a bus shared with OS-B are initialized, which may prevent OS-B from operating continuously. In order to solve this problem, a restart operation is performed in the procedure shown in FIG. 7 after terminating OS-A. When an electric power is applied, OS-A initializes the common hard wares (S51). Then, the inter-OS control software 23 operating as a device driver is provided with a timing for initialization process for the hard wares managed by OS-A, in which the context is stored (S52). In storing the context, the content of the register and the content of all the memory area managed by OS-A are copied on the memory area managed by the inter-OS control software 23. Then, the hard wares managed by OS-A are initialized by the individual device drivers of OS-A (S53). After completing this initialization process, OS-A goes to an ordinary operation state, and in case that OS-A is terminated due to a shut-down operation or an exception, the inter-OS control software 23 shuts down only OS-A in the above described manner (S54). Then, the inter-OS control software 23 restores the context stored at OS-A automatically or in responsive to the request from the program of OS-B (S55). That is, by referring to the context stored at the initialization process (S52) for the hard wares managed by OS-A, the content of the memory at the initialization state is recovered and the content of the register is recovered, and then, the operation of OS-A is restarted. With this procedure, as the execution of OS-A is restarted immediately after completing the set-up of the common hard wares managed by OS-A, and OS-A can be operated in an ordinary mode after only initializing the hard wares managed by OS-A, there is no need for initializing again the common hard wares shared by OS-B.
  • In this embodiment, as for OS-A used as a versatile OS, only the process for the interrupt [0048] controller 19 is modified, and other process or components are not modified. This makes it easier to add OS-B and the inter-OS control software 23 for OS-A used as a versatile OS.
  • According to the present invention, when operating plural OS's on a single CPU in the control apparatus, the area of influence of the abnormal behavior of OS's and their related programs can be localized, and the abnormal state can be transferred to an ordinary operation mode only by restarting the partial component on the basis of the individual OS's without terminating the whole control apparatus, which leads to increasing the reliability of the system in addition, the operation of OS's can be observed from the space independent of the spaces for the ordinary operation of OS's and their programs. [0049]

Claims (1)

What is claimed:
1. An multiple operating system control method for a multiple operating system having a plurality of operating systems executed in a digital arithmetic processor in which a first operating system and a second operating system of said plurality of operating systems are alternately switched and executed on said digital arithmetic processor, wherein said multiple operating system is provided with inter-OS control software switching said first operating system and said second operating system, said inter-OS control software referring to an event processing table.
US10/372,219 2000-06-01 2003-02-25 Multiple operating system control method Abandoned US20030154337A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/372,219 US20030154337A1 (en) 2000-06-01 2003-02-25 Multiple operating system control method

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/585,120 US6715016B1 (en) 2000-06-01 2000-06-01 Multiple operating system control method
US10/372,219 US20030154337A1 (en) 2000-06-01 2003-02-25 Multiple operating system control method

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US09/585,120 Continuation US6715016B1 (en) 2000-06-01 2000-06-01 Multiple operating system control method

Publications (1)

Publication Number Publication Date
US20030154337A1 true US20030154337A1 (en) 2003-08-14

Family

ID=27663461

Family Applications (3)

Application Number Title Priority Date Filing Date
US09/585,120 Expired - Fee Related US6715016B1 (en) 2000-06-01 2000-06-01 Multiple operating system control method
US10/372,219 Abandoned US20030154337A1 (en) 2000-06-01 2003-02-25 Multiple operating system control method
US10/774,486 Expired - Fee Related US6892261B2 (en) 2000-06-01 2004-02-10 Multiple operating system control method

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US09/585,120 Expired - Fee Related US6715016B1 (en) 2000-06-01 2000-06-01 Multiple operating system control method

Family Applications After (1)

Application Number Title Priority Date Filing Date
US10/774,486 Expired - Fee Related US6892261B2 (en) 2000-06-01 2004-02-10 Multiple operating system control method

Country Status (1)

Country Link
US (3) US6715016B1 (en)

Cited By (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040117535A1 (en) * 2002-09-26 2004-06-17 Schaftlein Richard C. System and method for synchronizing system modules
US20050246487A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Non-volatile memory cache performance improvement
US20060010314A1 (en) * 2004-07-07 2006-01-12 Yongyong Xu Methods and systems for running multiple operating systems in a single mobile device
US20060059328A1 (en) * 2004-09-16 2006-03-16 Yoshihiro Toyohara Data processing system having a channel adapter shared by multiple operating systems
US20070120550A1 (en) * 2004-04-23 2007-05-31 Olympus Corporation Medical system control device
US7395421B1 (en) * 2000-11-06 2008-07-01 Intel Corporation Method and apparatus for booting a user-selectable operating system
CN100407150C (en) * 2005-03-18 2008-07-30 富士通株式会社 Information processing apparatus and operating system switchover method
US20090113423A1 (en) * 2007-10-31 2009-04-30 Vmware, Inc. Interchangeable Guest and Host Execution Environments
US20090228881A1 (en) * 2008-03-04 2009-09-10 Atul Mukker Linux matrix compilation system and method
US20100228906A1 (en) * 2009-03-06 2010-09-09 Arunprasad Ramiya Mothilal Managing Data in a Non-Volatile Memory System
US20110035513A1 (en) * 2009-08-06 2011-02-10 David Jevans Peripheral Device Data Integrity
US20110035574A1 (en) * 2009-08-06 2011-02-10 David Jevans Running a Computer from a Secure Portable Device
US20110209220A1 (en) * 2010-02-22 2011-08-25 F-Secure Oyj Malware removal
US20110219225A1 (en) * 2010-03-05 2011-09-08 Lenovo (Singapore) Pte. Ltd. Utilization of the screen image information of a primary environment for reproduction and user-interaction in a secondary environment
EP2492810A1 (en) * 2009-12-24 2012-08-29 Huawei Device Co., Ltd. Method and device for managing operating systems in embedded system
US8489815B2 (en) 2008-09-15 2013-07-16 Microsoft Corporation Managing cache data and metadata
US20130339565A1 (en) * 2011-12-22 2013-12-19 Bryan E. Veal Method, device and system for aggregation of shared address devices
US8631203B2 (en) 2007-12-10 2014-01-14 Microsoft Corporation Management of external memory functioning as virtual cache
US8909861B2 (en) 2004-10-21 2014-12-09 Microsoft Corporation Using external memory devices to improve system performance
US8914557B2 (en) 2005-12-16 2014-12-16 Microsoft Corporation Optimizing write and wear performance for a memory
US9032151B2 (en) 2008-09-15 2015-05-12 Microsoft Technology Licensing, Llc Method and system for ensuring reliability of cache data and metadata subsequent to a reboot
US20160055031A1 (en) * 2014-11-13 2016-02-25 Mediatek Inc. Dual-System Architecture With Fast Recover And Switching Of Operating System
WO2016032430A1 (en) * 2014-08-25 2016-03-03 Hewlett Packard Development Company, L.P. Selection of an operating system
US9361183B2 (en) 2008-09-19 2016-06-07 Microsoft Technology Licensing, Llc Aggregation of write traffic to a data store
CN105824631A (en) * 2016-03-16 2016-08-03 深圳市金立通信设备有限公司 Control method of application program and terminal
US9652215B2 (en) 2014-12-30 2017-05-16 Microsoft Technology Licensing, Llc Application installation/uninstallation across multiple systems
US9678903B1 (en) * 2014-10-15 2017-06-13 Intel Corporation Systems and methods for managing inter-CPU interrupts between multiple CPUs
US20180081712A1 (en) * 2016-09-16 2018-03-22 Kabushiki Kaisha Toshiba Information processing apparatus, information processing method, and computer program product
US10664588B1 (en) * 2017-12-12 2020-05-26 John Almeida Virus immune computer system and method
US20220365810A1 (en) * 2020-04-23 2022-11-17 Soochow University Thread signal operating method and system of embedded real time operating system

Families Citing this family (39)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4072271B2 (en) * 1999-02-19 2008-04-09 株式会社日立製作所 A computer running multiple operating systems
JP2001256067A (en) * 2000-03-08 2001-09-21 Mitsubishi Electric Corp Power saving control method for processor, storage medium and power saving controller for processor
US6715016B1 (en) * 2000-06-01 2004-03-30 Hitachi, Ltd. Multiple operating system control method
JP2002259155A (en) * 2001-02-26 2002-09-13 Hitachi Ltd Multiprocessor system
EP1635255A3 (en) * 2002-03-20 2006-05-24 Seiko Epson Corporation Apparatus for processing instructions of different instruction set architectures
US7370193B2 (en) * 2002-04-27 2008-05-06 Tong Shao Computing system being able to quickly switch between an internal and an external networks and a method thereof
US6782424B2 (en) * 2002-08-23 2004-08-24 Finite State Machine Labs, Inc. System, method and computer program product for monitoring and controlling network connections from a supervisory operating system
US7032107B2 (en) * 2002-10-30 2006-04-18 Symantec Corporation Virtual partition for recording and restoring computer data files
GB2396930B (en) * 2002-11-18 2005-09-07 Advanced Risc Mach Ltd Apparatus and method for managing access to a memory
GB2396451B (en) * 2002-11-18 2005-12-07 Advanced Risc Mach Ltd Delivering data processing requests to a suspended operating system
DE60323811D1 (en) * 2003-04-09 2008-11-13 Jaluna S A operating systems
US8612992B2 (en) * 2003-04-09 2013-12-17 Jaluna Sa Operating systems
US7503049B2 (en) * 2003-05-29 2009-03-10 Panasonic Corporation Information processing apparatus operable to switch operating systems
JP3952992B2 (en) * 2003-06-03 2007-08-01 ソニー株式会社 Information processing apparatus, process control method, and computer program
EP1503286B1 (en) * 2003-07-30 2014-09-03 Jaluna SA Multiple operating system networking
JP3953449B2 (en) * 2003-08-26 2007-08-08 富士通株式会社 Task management program and task control device
CN1922576A (en) * 2003-09-30 2007-02-28 扎鲁纳股份有限公司 Operating systems
US9298472B2 (en) * 2004-01-27 2016-03-29 Nec Corporation High-speed restart method, information processing device, and program
KR100673681B1 (en) * 2004-03-25 2007-01-24 엘지전자 주식회사 Method for executing instant on function in personal computer
US7676814B2 (en) * 2004-03-25 2010-03-09 Globalfoundries Inc. Four layer architecture for network device drivers
US7827558B2 (en) * 2004-06-30 2010-11-02 Devicevm, Inc. Mechanism for enabling a program to be executed while the execution of an operating system is suspended
JP2008510238A (en) * 2004-08-18 2008-04-03 ジャルナ エスアー operating system
JP2006127267A (en) * 2004-10-29 2006-05-18 Toshiba Corp Information processor and boot control method
KR100725394B1 (en) 2005-07-08 2007-06-07 삼성전자주식회사 Computer system and method for selectively installing a operating system from plural operating system
US7719132B2 (en) 2005-09-28 2010-05-18 L3 Communications Corporation Ruggedized mobile computing device
US20070104340A1 (en) * 2005-09-28 2007-05-10 Knowles Electronics, Llc System and Method for Manufacturing a Transducer Module
KR100746025B1 (en) * 2006-01-12 2007-08-06 삼성전자주식회사 Apparatus and method for switching between operating systems
JP4342576B2 (en) * 2006-07-25 2009-10-14 株式会社エヌ・ティ・ティ・ドコモ Multiple operating system switching control device and computer system
JP5028904B2 (en) * 2006-08-10 2012-09-19 ソニー株式会社 Electronic device and starting method
US7689820B2 (en) * 2006-09-27 2010-03-30 L3 Communications Corporation Rapid-boot computing device with dual operating systems
US8819483B2 (en) 2006-09-27 2014-08-26 L-3 Communications Corporation Computing device with redundant, dissimilar operating systems
US8424013B1 (en) * 2006-09-29 2013-04-16 Emc Corporation Methods and systems for handling interrupts across software instances and context switching between instances having interrupt service routine registered to handle the interrupt
US9317309B2 (en) * 2006-12-28 2016-04-19 Hewlett-Packard Development Company, L.P. Virtualized environment allocation system and method
WO2009003168A1 (en) * 2007-06-27 2008-12-31 Teletrol Systems, Inc. System and method for providing device independent control and modification
US8286195B2 (en) * 2007-10-31 2012-10-09 Microsoft Corporation Controlling hardware across two or more simultaneously running operating systems
CN103180829B (en) * 2010-10-22 2016-08-03 三菱电机株式会社 Interrupt signal receives device and computer installation
CN102467414B (en) * 2010-11-19 2015-03-18 阿里巴巴集团控股有限公司 State machine control method, device and state machine system
JP5933356B2 (en) * 2012-06-12 2016-06-08 ルネサスエレクトロニクス株式会社 Computer system
CN104516731A (en) * 2013-09-27 2015-04-15 昆山耐特康托软件科技有限公司 Rapid prototype development implementation method based on single chip

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4742447A (en) * 1986-01-16 1988-05-03 International Business Machines Corporation Method to control I/O accesses in a multi-tasking virtual memory virtual machine type data processing system
US5898875A (en) * 1995-07-20 1999-04-27 International Business Machines Corp. Method and computer system for loading objects
US5901319A (en) * 1996-06-14 1999-05-04 The Foxboro Company System and methods for generating operating system specific kernel level code from operating system independent data structures
US6199181B1 (en) * 1997-09-09 2001-03-06 Perfecto Technologies Ltd. Method and system for maintaining restricted operating environments for application programs or operating systems
US6381524B1 (en) * 2000-06-20 2002-04-30 Hitachi, Ltd. Vehicle travel control apparatus
US6393560B1 (en) * 1998-04-30 2002-05-21 Intel Corporation Initializing and restarting operating systems
US6615303B1 (en) * 1999-05-21 2003-09-02 Hitachi, Ltd. Computer system with multiple operating system operation
US6631394B1 (en) * 1998-01-21 2003-10-07 Nokia Mobile Phones Limited Embedded system with interrupt handler for multiple operating systems
US6715016B1 (en) * 2000-06-01 2004-03-30 Hitachi, Ltd. Multiple operating system control method

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
SE330455B (en) * 1969-06-17 1970-11-16 Ericsson Telefon Ab L M
FR2527401A1 (en) * 1982-05-18 1983-11-25 Philips Ind Commerciale METHOD AND DEVICE FOR EXPLICIT DETERMINISTIC ALLOCATION OF TOKEN IN A DISTRIBUTED LOCAL NETWORK OF PRIORITY TRANSMISSION
JPS5960652A (en) * 1982-09-30 1984-04-06 Fujitsu Ltd Data processing device
US4530052A (en) * 1982-10-14 1985-07-16 Honeywell Information Systems Inc. Apparatus and method for a data processing unit sharing a plurality of operating systems
US4493034A (en) * 1982-10-14 1985-01-08 Honeywell Information Systems Inc. Apparatus and method for an operating system supervisor in a data processing system
US4747040A (en) * 1985-10-09 1988-05-24 American Telephone & Telegraph Company Dual operating system computer
US5278973A (en) * 1989-03-27 1994-01-11 Unisys Corporation Dual operating system computer
JPH0527954A (en) 1991-07-18 1993-02-05 Toshiba Corp Computer system
JPH0573340A (en) 1991-09-13 1993-03-26 Hitachi Ltd Inter-operating system bridge system
JPH0799501B2 (en) 1991-11-18 1995-10-25 インターナショナル・ビジネス・マシーンズ・コーポレイション Simultaneous execution device for multiple applications
US5483647A (en) * 1992-12-17 1996-01-09 Bull Hn Information Systems Inc. System for switching between two different operating systems by invoking the server to determine physical conditions to initiate a physical connection transparent to the user
JPH06236286A (en) * 1993-02-09 1994-08-23 Seiko Epson Corp Information processor
JPH0962324A (en) 1995-08-29 1997-03-07 Fanuc Ltd Numerical control system
US6327653B1 (en) * 1995-11-07 2001-12-04 Samsung Electronics Co., Ltd. Technique for easily changing operating systems of a digital computer system using at least two pushbuttons
AU4353297A (en) * 1996-09-17 1998-04-14 Radisys Corporation Method and apparatus for encapsulating a protected-mode operating system within a real-time, protected-mode operating system
US6772419B1 (en) * 1997-09-12 2004-08-03 Hitachi, Ltd. Multi OS configuration system having an interrupt process program executes independently of operation of the multi OS
US6067618A (en) * 1998-03-26 2000-05-23 Innova Patent Trust Multiple operating system and disparate user mass storage resource separation for a computer system
US6330669B1 (en) * 1998-11-30 2001-12-11 Micron Technology, Inc. OS multi boot integrator

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4742447A (en) * 1986-01-16 1988-05-03 International Business Machines Corporation Method to control I/O accesses in a multi-tasking virtual memory virtual machine type data processing system
US5898875A (en) * 1995-07-20 1999-04-27 International Business Machines Corp. Method and computer system for loading objects
US5901319A (en) * 1996-06-14 1999-05-04 The Foxboro Company System and methods for generating operating system specific kernel level code from operating system independent data structures
US6199181B1 (en) * 1997-09-09 2001-03-06 Perfecto Technologies Ltd. Method and system for maintaining restricted operating environments for application programs or operating systems
US6631394B1 (en) * 1998-01-21 2003-10-07 Nokia Mobile Phones Limited Embedded system with interrupt handler for multiple operating systems
US6393560B1 (en) * 1998-04-30 2002-05-21 Intel Corporation Initializing and restarting operating systems
US6615303B1 (en) * 1999-05-21 2003-09-02 Hitachi, Ltd. Computer system with multiple operating system operation
US6715016B1 (en) * 2000-06-01 2004-03-30 Hitachi, Ltd. Multiple operating system control method
US6381524B1 (en) * 2000-06-20 2002-04-30 Hitachi, Ltd. Vehicle travel control apparatus

Cited By (68)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7395421B1 (en) * 2000-11-06 2008-07-01 Intel Corporation Method and apparatus for booting a user-selectable operating system
US7805725B2 (en) * 2002-09-26 2010-09-28 Siemens Industry, Inc. System and method for synchronizing system modules
US20040117535A1 (en) * 2002-09-26 2004-06-17 Schaftlein Richard C. System and method for synchronizing system modules
US7806822B2 (en) * 2004-04-23 2010-10-05 Olympus Corporation Medical system control device
US20070120550A1 (en) * 2004-04-23 2007-05-31 Olympus Corporation Medical system control device
US7644239B2 (en) * 2004-05-03 2010-01-05 Microsoft Corporation Non-volatile memory cache performance improvement
US10216637B2 (en) 2004-05-03 2019-02-26 Microsoft Technology Licensing, Llc Non-volatile memory cache performance improvement
US20050246487A1 (en) * 2004-05-03 2005-11-03 Microsoft Corporation Non-volatile memory cache performance improvement
TWI480732B (en) * 2004-05-03 2015-04-11 Microsoft Corp Method and system for non-volatile memory performance improvement
US20100077197A1 (en) * 2004-05-03 2010-03-25 Microsoft Corporation Non-volatile memory cache performance improvement
US8255645B2 (en) 2004-05-03 2012-08-28 Microsoft Corporation Non-volatile memory cache performance improvement
US8041904B2 (en) 2004-05-03 2011-10-18 Microsoft Corporation Non-volatile memory cache performance improvement
US9405693B2 (en) 2004-05-03 2016-08-02 Microsoft Technology Licensing, Llc Non-volatile memory cache performance improvement
US8090938B2 (en) 2004-07-07 2012-01-03 Intellectual Ventures Fund 63 Llc Methods and systems for running multiple operating systems in a single mobile device
US20090037649A1 (en) * 2004-07-07 2009-02-05 Yongyong Xu Methods and Systems for Running Multiple Operating Systems in a Single Mobile Device
US9164787B2 (en) * 2004-07-07 2015-10-20 Intellectual Ventures Fund 63 Llc Methods and systems for running multiple operating systems in a single mobile device
US20090037909A1 (en) * 2004-07-07 2009-02-05 Yongyong Xu Methods and Systems for Running Multiple Operating Systems in a Single Mobile Device
US20060010314A1 (en) * 2004-07-07 2006-01-12 Yongyong Xu Methods and systems for running multiple operating systems in a single mobile device
US7424601B2 (en) 2004-07-07 2008-09-09 Yongyong Xu Methods and systems for running multiple operating systems in a single mobile device
US20100235548A1 (en) * 2004-09-16 2010-09-16 Yoshihiro Toyohara Data processing system having a channel adapter shared by multiple operating systems
US8312182B2 (en) 2004-09-16 2012-11-13 Hitachi, Ltd. Data processing system having a channel adapter shared by multiple operating systems
US20060059328A1 (en) * 2004-09-16 2006-03-16 Yoshihiro Toyohara Data processing system having a channel adapter shared by multiple operating systems
US20110138089A1 (en) * 2004-09-16 2011-06-09 Yoshihiro Toyohara Data processing system having a channel adapter shared by multiple operating systems
US7877526B2 (en) * 2004-09-16 2011-01-25 Hitachi, Ltd. Data processing system having a channel adapter shared by multiple operating systems
US7680965B2 (en) * 2004-09-16 2010-03-16 Hitachi, Ltd. Data processing system having a channel adapter shared by multiple operating systems
US9317209B2 (en) 2004-10-21 2016-04-19 Microsoft Technology Licensing, Llc Using external memory devices to improve system performance
US9690496B2 (en) 2004-10-21 2017-06-27 Microsoft Technology Licensing, Llc Using external memory devices to improve system performance
US8909861B2 (en) 2004-10-21 2014-12-09 Microsoft Corporation Using external memory devices to improve system performance
CN100407150C (en) * 2005-03-18 2008-07-30 富士通株式会社 Information processing apparatus and operating system switchover method
US11334484B2 (en) 2005-12-16 2022-05-17 Microsoft Technology Licensing, Llc Optimizing write and wear performance for a memory
US9529716B2 (en) 2005-12-16 2016-12-27 Microsoft Technology Licensing, Llc Optimizing write and wear performance for a memory
US8914557B2 (en) 2005-12-16 2014-12-16 Microsoft Corporation Optimizing write and wear performance for a memory
US20090113423A1 (en) * 2007-10-31 2009-04-30 Vmware, Inc. Interchangeable Guest and Host Execution Environments
US8677352B2 (en) * 2007-10-31 2014-03-18 Vmware, Inc. Interchangeable guest and host execution environments
US8631203B2 (en) 2007-12-10 2014-01-14 Microsoft Corporation Management of external memory functioning as virtual cache
US20090228881A1 (en) * 2008-03-04 2009-09-10 Atul Mukker Linux matrix compilation system and method
US8533707B2 (en) * 2008-03-04 2013-09-10 Lsi Corporation Linux matrix compilation system and method
US8489815B2 (en) 2008-09-15 2013-07-16 Microsoft Corporation Managing cache data and metadata
US10387313B2 (en) 2008-09-15 2019-08-20 Microsoft Technology Licensing, Llc Method and system for ensuring reliability of cache data and metadata subsequent to a reboot
US9032151B2 (en) 2008-09-15 2015-05-12 Microsoft Technology Licensing, Llc Method and system for ensuring reliability of cache data and metadata subsequent to a reboot
US10509730B2 (en) 2008-09-19 2019-12-17 Microsoft Technology Licensing, Llc Aggregation of write traffic to a data store
US9448890B2 (en) 2008-09-19 2016-09-20 Microsoft Technology Licensing, Llc Aggregation of write traffic to a data store
US9361183B2 (en) 2008-09-19 2016-06-07 Microsoft Technology Licensing, Llc Aggregation of write traffic to a data store
US20100228906A1 (en) * 2009-03-06 2010-09-09 Arunprasad Ramiya Mothilal Managing Data in a Non-Volatile Memory System
US20110035574A1 (en) * 2009-08-06 2011-02-10 David Jevans Running a Computer from a Secure Portable Device
US20110035513A1 (en) * 2009-08-06 2011-02-10 David Jevans Peripheral Device Data Integrity
US8683088B2 (en) 2009-08-06 2014-03-25 Imation Corp. Peripheral device data integrity
US8745365B2 (en) * 2009-08-06 2014-06-03 Imation Corp. Method and system for secure booting a computer by booting a first operating system from a secure peripheral device and launching a second operating system stored a secure area in the secure peripheral device on the first operating system
EP2492810A4 (en) * 2009-12-24 2013-01-02 Huawei Device Co Ltd Method and device for managing operating systems in embedded system
EP2492810A1 (en) * 2009-12-24 2012-08-29 Huawei Device Co., Ltd. Method and device for managing operating systems in embedded system
US20110209220A1 (en) * 2010-02-22 2011-08-25 F-Secure Oyj Malware removal
US9785774B2 (en) * 2010-02-22 2017-10-10 F-Secure Corporation Malware removal
US20170140150A1 (en) * 2010-02-22 2017-05-18 F-Secure Corporation Malware Removal
US9665712B2 (en) * 2010-02-22 2017-05-30 F-Secure Oyj Malware removal
US20110219225A1 (en) * 2010-03-05 2011-09-08 Lenovo (Singapore) Pte. Ltd. Utilization of the screen image information of a primary environment for reproduction and user-interaction in a secondary environment
US8914623B2 (en) * 2010-03-05 2014-12-16 Lenovo (Singapore) Pte. Ltd. Utilization of the screen image information of a primary environment for reproduction and user-interaction in a secondary environment
US9460040B2 (en) * 2011-12-22 2016-10-04 Intel Corporation Method, device and system for aggregation of shared address devices
US20130339565A1 (en) * 2011-12-22 2013-12-19 Bryan E. Veal Method, device and system for aggregation of shared address devices
WO2016032430A1 (en) * 2014-08-25 2016-03-03 Hewlett Packard Development Company, L.P. Selection of an operating system
US9678903B1 (en) * 2014-10-15 2017-06-13 Intel Corporation Systems and methods for managing inter-CPU interrupts between multiple CPUs
US9965414B2 (en) 2014-10-15 2018-05-08 Intel Corporation Systems and methods for managing inter-CPU interrupts between multiple CPUs
US20160055031A1 (en) * 2014-11-13 2016-02-25 Mediatek Inc. Dual-System Architecture With Fast Recover And Switching Of Operating System
US9652215B2 (en) 2014-12-30 2017-05-16 Microsoft Technology Licensing, Llc Application installation/uninstallation across multiple systems
CN105824631A (en) * 2016-03-16 2016-08-03 深圳市金立通信设备有限公司 Control method of application program and terminal
US20180081712A1 (en) * 2016-09-16 2018-03-22 Kabushiki Kaisha Toshiba Information processing apparatus, information processing method, and computer program product
US10474494B2 (en) * 2016-09-16 2019-11-12 Kabushiki Kaisha Toshiba Information processing apparatus, information processing method, and computer program product
US10664588B1 (en) * 2017-12-12 2020-05-26 John Almeida Virus immune computer system and method
US20220365810A1 (en) * 2020-04-23 2022-11-17 Soochow University Thread signal operating method and system of embedded real time operating system

Also Published As

Publication number Publication date
US6892261B2 (en) 2005-05-10
US6715016B1 (en) 2004-03-30
US20040177193A1 (en) 2004-09-09

Similar Documents

Publication Publication Date Title
US6892261B2 (en) Multiple operating system control method
EP1162536A1 (en) Multiple operating system control method
US8201170B2 (en) Operating systems are executed on common program and interrupt service routine of low priority OS is modified to response to interrupts from common program only
EP0354899B1 (en) Multiprocessing method and arrangement
US5003466A (en) Multiprocessing method and arrangement
US9619279B2 (en) Operating systems sharing supervisor address space with same virtual to physical mapping for supervisor address space using same translation formula with different translation tree
JP2000076087A (en) Multioperating system control method
JP2000242512A (en) Computer executing plural operating systems
KR20040068600A (en) A method and a system for executing operating system functions, as well as an electronic device
EP2316091A2 (en) Protected mode scheduling of operations
JPH1021094A (en) Real-time control system
US8423681B2 (en) Control apparatus for process input-output device
JP2001282558A (en) Multi-operating computer system
JP3644042B2 (en) Multitask processing device
EP1616257B1 (en) Operating systems
Zuberi et al. EMERALDS-OSEK: a small real-time operating system for automotive control and monitoring
CN116521324B (en) Interrupt virtualization processing method and device and electronic equipment
CN115269139A (en) Dual-operating-system mixed real-time task scheduling method and system based on trusted area
CN115695079A (en) Industrial Ethernet protocol optimization method, system and readable storage medium
JP2000029850A (en) Task controlling method using inter-processor communication of operating system
CN117234678A (en) Method and device for controlling flow of program part, programming method and programming device
CN116521324A (en) Interrupt virtualization processing method and device and electronic equipment
JPH02244371A (en) Exclusive control method for multiprocessor system
Odagiri et al. Porting EPICS to L4-Linux based system
JPH03248231A (en) Multitask exclusive control method

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION