[go: up one dir, main page]

KR101944270B1 - Recording Medium, Method and Device For Program Operation - Google Patents

Recording Medium, Method and Device For Program Operation Download PDF

Info

Publication number
KR101944270B1
KR101944270B1 KR1020120019407A KR20120019407A KR101944270B1 KR 101944270 B1 KR101944270 B1 KR 101944270B1 KR 1020120019407 A KR1020120019407 A KR 1020120019407A KR 20120019407 A KR20120019407 A KR 20120019407A KR 101944270 B1 KR101944270 B1 KR 101944270B1
Authority
KR
South Korea
Prior art keywords
program
processor
boot loader
memory
operating system
Prior art date
Application number
KR1020120019407A
Other languages
Korean (ko)
Other versions
KR20130097827A (en
Inventor
장준호
홍종철
Original Assignee
인포뱅크 주식회사
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 인포뱅크 주식회사 filed Critical 인포뱅크 주식회사
Priority to KR1020120019407A priority Critical patent/KR101944270B1/en
Publication of KR20130097827A publication Critical patent/KR20130097827A/en
Application granted granted Critical
Publication of KR101944270B1 publication Critical patent/KR101944270B1/en

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/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • G06F9/4405Initialisation of multiprocessor systems
    • 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/22Microcontrol or microprogram arrangements
    • G06F9/24Loading of the microprogram
    • 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3802Instruction prefetching
    • G06F9/3804Instruction prefetching for branches, e.g. hedging, branch folding
    • 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/4401Bootstrapping
    • G06F9/4406Loading of operating system
    • G06F9/441Multiboot arrangements, i.e. selecting an operating system to be loaded
    • 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/445Program loading or initiating
    • 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/448Execution paradigms, e.g. implementations of programming paradigms

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

본 발명은 프로그램 운영 장치 및 방법과 프로그램 기록매체에 관한 것으로, 본 발명에 따른 프로그램 운영 장치는, 전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리 상에 기록하는 저장부와, 전원 입력시, 제2프로세서를 구동하기 위한 멀티프로세서 분기처리 부트로더(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더를 실행하되, 상기 메모리 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 제1프로세서와, 상기 제1프로세서의 분기처리 부트로더를 통해 구동된 후, 프로그램 부트로더를 실행하여, 상기 프로그램 부트로더를 통해 상기 제1프로세서를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-이전 전원 오프시 사용자가 최종 이용한 프로그램-이 실행되도록 처리하는 제2프로세서를 구비한다.The present invention relates to an apparatus and method for operating a program, and a program recording medium, and a program operating apparatus according to the present invention includes: a storage unit for storing user's last used program information on a memory after power off; 2 processor for booting a multiprocessor branch processing boot loader and a kernel boot loader for booting an operating system. When the user turns off the previous power off recorded in the memory, A first processor for loading a program boot loader corresponding to the verified program information through the branch processing boot loader into a memory; and a program execution unit for executing a program boot loader after being driven through a branch processing boot loader of the first processor, The operating system is not booted before booting the operating system via the first processor through the program boot loader And a second processor for processing the program to be executed so as to execute the program last used by the user when the previous power is turned off.

Description

프로그램 운영 방법 및 장치와 이를 위한 기록매체{Recording Medium, Method and Device For Program Operation}[0001] The present invention relates to a method and an apparatus for operating a program,

본 발명은 2개 이상의 프로세서가 구비된 프로그램 운영 장치에서 최초 프로그램 실행 전 운영체제 부팅과정에 따른 사용자 대기시간을 크게 줄일 수 있도록 하며, 운영체제 부팅 전 실행 프로그램을 일정 시간 이전 전원 오프 시 사용자의 최종 이용 프로그램으로 결정함으로써, 사용자가 전원 오프시 최종 이용했던 프로그램을 전원 재입력시 보다 빠르게 재이용할 수 있도록 하는 것이다.
The present invention can greatly reduce a user's waiting time according to the operating system boot process before executing the first program in a program operating device provided with two or more processors, So that the program that was last used by the user when the power is turned off can be reused more quickly when the power is re-input.

일반적으로, 대부분의 프로그램 운영 장치들은 전원이 입력되고 사용자가 이용하고자 하는 프로그램이 실행되기 전에 운영체제 부팅과정이 선행되며, 사용자는 운영체제 부팅과정이 완료될 때까지 대기할 수 밖에 없다.
Generally, most program operating devices are booted before an operating system is booted before a program is executed and a user enters a power source, and the user has to wait until the operating system booting process is completed.

특히, 운영체제의 기능과 용량이 확대되면서 이러한 운영체제 부팅 시간은 점점 더 길어지게 되고, 이에 따른 사용자 불만과 불편이 점점 더 커지고 있는 실정이다.
Especially, as the function and capacity of the operating system are expanded, the operating system boot time becomes longer and the user complaints and inconvenience are increasing.

도면 1은 프로그램 운영 장치에서의 시스템에 전원이 들어오는 시점부터 부팅이 완료되는 시점까지 전체적인 운영체제 부팅과정의 흐름을 보여주는 흐름도이다.
FIG. 1 is a flowchart showing a flow of an entire operating system booting process from the time when power is supplied to the system in the program operating apparatus to when the booting is completed.

먼저, 시스템에 전원이 들어오면, 시스템에 존재하는 모든 프로세서들은 부트 모니터를 실행하도록 되어 있다. 부트모니터는 시스템에 전원이 들어온 이후 처음 실행되는 프로그램이다. 이 프로그램은 시스템 운영체제의 커널(kernel)을 메모리에 적재(load)하기에는 너무 작고, 제한적인 기능만을 수행할 수 있기 때문에 커널을 메인 메모리에 적재해줄 부트로더(bootloader)가 필요하고, 이 부트로더를 찾아 실행시켜주는 것이 부트모니터의 가장 중요한 역할이다.
First, when the system is powered on, all processors in the system are configured to run the boot monitor. The boot monitor is the first program that runs after the system is powered on. This program is too small to load the kernel of the system operating system into memory and can perform only limited functions. Therefore, a boot loader is required to load the kernel into the main memory, and this boot loader Finding and running is the most important role of the boot monitor.

부트모니터는 먼저 현재 자신을 실행하는 프로세서가 첫 번째 프로세서(CPU0)인지 아닌지를 알아내는 작업을 수행하고, 현재 프로세서가 첫 번째 프로세서라면 부트모니터는 메인 코드를 실행하고, 나머지 프로세서(CPUx)라면 WFI(wait for interrupt)를 수행하며 첫 번째 프로세서가 나머지 프로세서들을 초기화해서 사용될 수 있을 때까지 기다리게 한다. 이 때 부팅을 담당하게 되는 첫 번째 프로세서를 부트 프로세서(boot processor)라고 한다. 이와 같은 방법으로 부팅 초반에 멀티 프로세서에서도 CPU가 하나인 것처럼 부팅을 진행할 수 있게 된다. WFI를 수행하는 다른 프로세서들은 무한루프(infinite loop)을 돌면서 계속 SYS_FLAGS 레지스터에 변화가 있는지 체크하고, 부트 프로세서에 의해 레지스터 값이 바뀌면, 레지스터에 저장된 주소로 점프를 한다.
If the current processor is the first processor, the boot monitor executes the main code. If the remaining processor (CPUx) is the WFI (CPUx), the boot monitor performs a task of determining whether or not the processor currently executing the current processor is the first processor (wait for interrupt) and wait for the first processor to initialize the remaining processors before they can be used. The first processor responsible for booting is called the boot processor. In this way, it is possible to boot up as if there is one CPU in multi-processor at the beginning of boot. Other processors running WFI continue to loop through the infinite loop to check for changes to the SYS_FLAGS register and jump to the address stored in the register when the register value is changed by the boot processor.

부트로더는 비휘발성 메모리의 MBR(비휘발성 메모리의 0번 섹터(sector))에서 찾을 수 있는데, MBR에 저장된 부트로더가 올바른지는 MBR 섹터 내에 마지막 2바이트(byte)에 존재하는 매직코드(magic code)를 통해 확인할 수 있다. 부트모니터는 MBR을 읽어서 매직코드를 확인하고, 부트로더임이 확인되었을 때 부트로더의 시작 주소로 점프(jump)하여 이후 부팅과정을 부트로더에게 맡긴다.
The boot loader can be found in the MBR (nonzero sector of nonvolatile memory) of the nonvolatile memory. The boot loader can be found in the magic code in the last 2 bytes (byte) in the MBR sector, ). The boot monitor reads the MBR, checks the magic code, and when it is confirmed to be the boot loader, it jumps to the start address of the boot loader and leaves the boot process to the boot loader.

부트모니터로부터 호출된 부트로더의 주된 역할은 비휘발성 메모리에 저장된 커널 이미지(kernel image)를 찾아 메인 메모리의 정해진 위치에 적재하고, 커널 이미지의 시작위치로 점프함으로써 제어를 커널에게 넘기는 것이다.
The main function of the boot loader called from the boot monitor is to find the kernel image stored in the nonvolatile memory, load it in the main memory location, and jump to the beginning of the kernel image to give control to the kernel.

부트로더는 커널 이미지를 메인 메모리에 적재하기에 앞서서 메인 메모리를 초기화하는 기능을 수행한다. 메인 메모리 설정이 완료되면 캐시(cache)와 SCU를 초기화하고, 사용 가능한 모든 메모리를 바탕으로 레이아웃 정보를 만든다. 이 메인 메모리 레이아웃 정보는 이후 커널에게 부트파라미터(boot parameter)를 통해서 넘겨주게 된다.
The boot loader initializes the main memory prior to loading the kernel image into main memory. When the main memory configuration is completed, the cache and SCU are initialized, and layout information is created based on all available memory. This main memory layout information is then passed to the kernel via a boot parameter.

커널 이미지를 메모리에 적재 후, 콘솔 초기화와 부트파라미터 초기화를 수행하고, 커널 이미지 압축을 해제하고, 커널 이미지의 압축이 해제되면, 커널 초기화 과정을 수행하고, init 스크립트를 실행한다.
After loading the kernel image into memory, initialize the console, initialize the boot parameters, uncompress the kernel image, unzip the kernel image, perform the kernel initialization process, and run the init script.

init 스크립트는 커널 초기화가 완료되었을 때, 어플리케이션(Application) 레벨에서 실행되며, init 스크립트에는 실행되어야 할 프로그램들이 순차적으로 기록되어 있는데, 이는 시스템의 목적에 따라 매우 다양하다. init 스크립트를 실행시키고, 쉘 프로그램이 실행되면, 모든 부팅과정을 마치게 된다.
The init script is run at the application level when the kernel initialization is complete, and the init scripts contain a sequence of programs to be executed, which can vary greatly depending on the purpose of the system. When you run the init script and the shell program runs, it completes all the booting process.

도면 2에서 보는 바와 같이, 상기 도면 1의 과정을 거쳐 운영체제의 부팅이 완료된 후, 사용자가 원하는 프로그램을 실행하는데 까지 소요되는 사용자 대기시간은 수십초까지 걸리게 된다.
As shown in FIG. 2, after the booting of the operating system is completed through the process of FIG. 1, the waiting time for the user to execute the desired program takes up to several tens of seconds.

또한, 도면 3에서 보는바와 같이, 프로세서가 두 개 이상인 멀티 프로세서를 구비한 프로그램 운영 장치에서도 프로세서(1)에서 운영체제 부팅을 처리하는 시간동안 프로세서(2)는 유효 상태로 대기중인 바, 사용자 대기시간의 단축은 멀티 프로세서 체제에서도 마찬가지의 사용자 불편함을 지니고 있다.
Also, as shown in FIG. 3, in a program operating device having a multiprocessor having two or more processors, the processor 2 is in a standby state for a period of time during which the processor 1 performs booting of the operating system, The same shortcomings in the multi-processor system.

예를들어, 운전자가 자동차에 시동을 걸었을 때, 자동차에 구비된 프로그램 운영 장치에서 제공해줘야 할 가장 우선적인 서비스는 운전자에게 후방 상황을 보여주는 것이나, 현재 자동차에 구비된 프로그램 운영 장치는 운영체제 부팅과정을 마치는데 15초 이상이 소요되기 때문에, 운전자는 적어도 15초 이상을 기다려야 후방 상황을 파악하고, 운전을 할 수가 있다.
For example, when a driver starts a car, the most important service to be provided by a program operating device provided in a vehicle is to show a rear view to a driver, The driver must wait at least 15 seconds before he / she can identify the rear situation and drive.

이에, 종래 기술상에 운영체제의 부팅시간을 단축하여 사용자 대기시간을 단축시키기 위한 여러종류의 패스트 부팅 기술-하이버네이션 (Hibernation), XIP (Execute-in-place), 비압축 커널 (Uncompressed kernel), 콘솔 비활성화 (Disable console), initcall 재배치 (Reordering initcalls), 전담 하드웨어 추가 등-이 연구되어 왔다.
In order to shorten the boot time of the operating system and shorten the waiting time of the user in the prior art, various kinds of fast boot technologies such as Hibernation, Execute-in-place, Uncompressed kernel, (Disable console), initcall relocation (reordering initcalls), dedicated hardware additions - have been studied.

하이버네이션 기법은 메인 메모리 이미지를 비휘발성 메모리에 저장하고(suspend), 시스템에 전원이 다시 들어왔을 때, 비휘발성 메모리에 저장된 메인 메모리 이미지를 그대로 복원함으로써(resume) 부팅을 마치는 기법으로, suspend & resume 방식과 이를 개선한 snapshot 방식이 있다.
The hibernation technique suspends and resumes the main memory image in nonvolatile memory and resumes by resuming the main memory image stored in the nonvolatile memory when the system is powered on again. And a snapshot method to improve it.

Suspend & resume 방식은 시스템 종료직전의 메인 메모리 이미지를 비휘발성 메모리에 저장하고(suspend), 시스템에 전원이 다시 들어왔을 때, 비휘발성 메모리에 저장된 메인 메모리 이미지를 그대로 복원함으로써(resume) 종료직전의 시스템 상태로 복원하는 기술로서, 시스템을 정상적으로 종료하고 일반적인 부팅과정을 거치는 것보다 빠르기 때문에 사용자가 체감하는 대기시간을 줄일 수 있다.
The suspend and resume method suspends the main memory image immediately before the system shutdown in nonvolatile memory and resumes the main memory image stored in the nonvolatile memory when the system is powered on again. This is a technique for restoring to the system state. Since it is faster than the normal shutdown of the system and the normal booting process, the waiting time experienced by the user can be reduced.

그러나, Suspend & resume 방식의 단점은 기존 커널의 부팅이 거의 완료된 후에 이미지를 찾아 복원을 시작하기 때문에 일반적인 부팅과 비교하여 부팅시간 단축을 기대하기 힘들며, 종료할 때마다 이전 상태를 비휘발성 매체에 저장해야 하기 때문에 종료시간이 길어지는 문제점이 있고, 하이버네이션 이미지가 저장되기 전에 전원이 끊기는 경우 resume하지 못하고, 일반적인 부팅과정을 거쳐야 하는 문제점이 있다.
However, the disadvantage of the Suspend & Resume method is that it is difficult to expect to shorten the boot time compared with the normal boot because the image is found and restored after the booting of the existing kernel is almost completed and the previous state is stored in the nonvolatile medium There is a problem that the ending time becomes long, and when the power is cut off before the hibernation image is stored, the resume can not be performed, and a general booting process is required.

Snapshot 기술은 suspend & resume의 단점을 보완한 기술로 부트로더 레벨에서 하이버네이션 복원을 수행하여 기존 suspend & resume이 커널 부팅이 거의 완료된 상태에서 복원하는 것보다 빠른 시점에 복원을 시작함으로써 부팅시간을 단축하는 것이다.
Snapshot technology complements the disadvantages of suspend & resume by performing a hibernation restore at the boot loader level to reduce the boot time by allowing the existing suspend & resume to begin restoring at a faster time than restoring the kernel with almost complete boot will be.

Suspend & resume 방식처럼 시스템을 종료할 때만 하이버네이션 이미지를 생성하는 것이 아니라 정상적인 부팅 완료 후에 특정 시점의 하이버네이션 이미지를 생성하여 항상 같은 하이버네이션 이미지로 복원하는 것도 가능하다.
It is possible not only to generate a hibernation image only when the system is shut down like the Suspend & resume method, but also to generate a hibernation image at a certain point after the normal boot completion and always restore the same hibernation image.

그러나, Snapshot 기술에서는 일반적인 장치 드라이버 초기화 과정 없이 resume되는 것을 고려하지 않고 구현되어 있기 때문에, 하드웨어에 따라 복구가 되지 않는 경우가 많으며, 이처럼 하드웨어 의존도가 높아 snapshot을 적용할 수 있는 시스템이 매우 제한적이다.
However, since Snapshot technology is implemented without considering resume without a general device driver initialization process, it can not be restored according to hardware, and the system which can apply snapshot is very limited due to high hardware dependency.

또한, 항상 동일한 이미지로 복원하는 경우, 사용 중에 수정되어 부팅과정에 반영되어야 할 사항들이 모두 초기화된다는 문제점이 있어서 수정사항이 부팅에 영향을 주지 않는 시스템에서만 사용 가능하다는 문제점이 있다.
Also, there is a problem in that, when the image is always restored to the same image, all the items to be reflected in the booting process are initialized during use, so that the modification can be used only in a system that does not affect booting.

XIP (Execute In-Place)는 프로그램 코드를 메인메모리에 적재하는 과정 없이 비휘발성 메모리에서 직접 실행하는 기술로서, 커널 부팅에서 커널이미지를 비휘발성 메모리로부터 메인메모리로 적재하는 과정과, 압축된 커널이미지를 해제하는 과정과, 압축해제하는 과정에서 압축해제되는 커널을 메인메모리에 쓰는 과정을 생락할 수 있다.
Execute In-Place (XIP) is a technology that executes directly from nonvolatile memory without loading program code into main memory. It processes loading kernel image from non-volatile memory to main memory at kernel boot, And a process of writing the decompressed kernel to the main memory during the decompression process may be omitted.

그러나, 현재까지 개발된 비휘발성 메모리는 메인 메모리로 사용되는 DRAM과 비교하여 읽기/쓰기 속도가 떨어지기 때문에 부팅 과정에서 XIP를 사용하지 않았을 때보다 더 빠르게 부팅하였을지라도, 이후에 커널이 계속 사용될 때 시스템 성능은 메인 메모리에 적재된 커널과 비교하여 떨어지는 성능을 보인다는 문제점이 있다.
However, since the nonvolatile memory developed so far has a lower read / write speed than the DRAM used as the main memory, the boot process is faster than when the XIP is not used, The system performance is degraded compared with the kernel loaded in the main memory.

비압축 커널(Uncompressed kernel)방식은 커널 이미지를 압축해제하는 과정을 제거함으로써 부팅 시간을 줄이는 방법이나, 일반적으로 현존하는 비휘발성 메모리의 속도는 메인 메모리와 비하여 매우 낮은 성능을 갖기 때문에, 비압축 커널을 사용했을 때 얻을 수 있는 경우가 많지 않고, 오히려 시간이 더 많이 소요되는 경우가 많아 적용할 수 있는 시스템이 매우 제한적인 문제점을 지니고 있다.
Uncompressed kernel method is a method of reducing boot time by eliminating the process of decompressing the kernel image. However, since the existing nonvolatile memory speed is very low compared to main memory, The system can not be applied in many cases and it takes much more time. Therefore, the applicable system has a very limited problem.

콘솔 비활성화(Disable console)방식은 콘솔로 출력되는 메시지를 사용하지 않음으로써 시간을 절약하는 방법으로서, 일반적으로 리눅스에서 부팅시에 quiet 옵션을 두면 콘솔 메시지를 출력하지 않는데, 이는 콘솔 상에 부팅 메시지를 출력하고 스크롤링하는 시간을 줄일 수 있다.
Disable console is a way to save time by not using messages output to the console. Normally when Linux is booted with quiet option, it does not output a console message, Output and scrolling time can be reduced.

그러나, 이와 같은 방법으로 절약 가능한 시간은 여러 요인에 의해 결정되며, 얻을 수 있는 절약시간은 수백 밀리초 정도 된다. 시리얼 콘솔을 사용하는 경우 절약 시간은 시리얼 포트의 속도에 좌우되지만, VGA 콘솔을 사용하는 경우 문자열 출력 시간은 프로세서 속도에 의해 결정된다. 그러므로 콘솔 출력이 많고, 속도가 느린 프로세서를 사용하는 경우에만 효과를 얻을 수 있고, 콘솔 출력이 그리 많지 않다면, 큰 효과를 거둘 수 없다.
However, the time that can be saved in this way is determined by various factors, and the saving time that can be obtained is several hundred milliseconds. When using a serial console, the saving time depends on the speed of the serial port, but when using the VGA console, the string output time is determined by the processor speed. Therefore, you can get the effect only if you have a lot of console output and a slow processor, and if you do not have a lot of console output, you can not get a big effect.

initcall 재배치 방식은 init 스크립트를 실행할 때 초기화 순서를 바꿔서 우선적으로 실행될 모듈들을 먼저 초기화하는 기술로서, 운영체제 부팅 이후 초기화 되는 프로그램의 순서를 미리 결정하는 것이다.
The initcall relocation method is a technique for initializing the modules to be executed first by changing the initialization order when the init script is executed, and determines the order of programs to be initialized after the operating system is booted.

initcall 재배치 기술은 운영체제 부팅이 완료된 이후의 과정을 최적화한 것으로, 운영체제의 부팅이 완료되는 시간보다 더 단축시킬 수는 없으며, 우선순위가 높은 모듈을 사용하기 위해서는 운영체제 커널의 부팅이 선행되어야 하기 때문에, 운영체제의 크기가 커진다면, 운영체제 부팅 시간이 증가하는 만큼 사용자 대기 시간이 증가하게 되는 문제점을 지니고 있다.
The initcall relocation technique optimizes the process since the booting of the operating system is completed. It can not shorten the booting completion time of the operating system. In order to use the higher priority module, the booting of the operating system kernel must precede, If the size of the operating system increases, the waiting time of the user increases as the operating system boot time increases.

결론적으로, 프로그램이 실행되어 사용자에게 서비스할 수 있는 시점까지 소요되는 시간을 사용자 대기시간이라고 할 때, 운영체제 부팅시간을 단축시키는 것이 사용자 대기시간을 단축시키는 것을 의미하기 때문에 기존 부팅 속도 개선 기술들의 대부분은 운영체제 부팅 시간 단축에 초점을 맞춰서 연구되어 왔다.
As a result, when the time required for the program to be able to be serviced to the user is called the user's waiting time, shortening the boot time of the operating system means shortening the user's waiting time. Has been studied focusing on reducing operating system boot time.

하지만, 운영체제 부팅 시간을 단축시키는 것만으로는 한계가 있기 때문에, 부팅 시간 단축보다 사용자 대기시간 단축을 통한 사용자의 불편과 불만을 해결할 수 있는 새로운 방식이 필요하다.
However, since there is a limit to shortening the operating system boot time, a new method that can solve the inconvenience and complaint of the user by shortening the waiting time of the user rather than shortening the boot time is needed.

또한, 사용자 대기시간이 단축되더라도, 사용자가 전원 입력 후 최초 이용하는 프로그램의 종류는 사용자마다 제각기 다 틀리기 때문에 사용자 대기시간을 줄여도 사용자별 최초 이용하고자 하는 프로그램이 획일적으로 정해져 있다면, 사용자는 운영체제 부팅 완료 후 본인이 원하는 프로그램을 다시 선택해서 실행해야 하는 불편함이 있으며, 특히, 자동차에 구비된 프로그램 운영 장치의 경우, 휴게소 등에 들러 잠시 시동을 껐다가 다시 켜는 상황이 발생하는 경우, 운전자는 시동을 끄기 전 프로그램을 재선택해야 하는 불편함이 있다.
In addition, even if the user wait time is shortened, since the kinds of programs to be used first after the user inputs power are different for each user, if the programs to be used for the first time are determined uniformly even though the user wait time is reduced, In particular, in the case of a program operating device provided in an automobile, when a situation occurs in which the automobile is temporarily turned off and then turned on again by stopping at a rest area, etc., There is an inconvenience to re-select the program.

상기한 종래 기술의 문제점 및 과제에 대한 인식은 본 발명의 기술 분야에서 통상의 지식을 가진 자에게 자명한 것이 아니므로 이러한 인식을 기반으로 선행기술들과 대비한 본 발명의 진보성을 판단하여서는 아니 됨을 밝혀둔다.The recognition of the problems and problems of the prior art is not obvious to a person having ordinary skill in the art, so that the inventive step of the present invention should not be judged based on the recognition based on such recognition I will reveal.

상기와 같은 문제점을 해소하기 위한 본 발명의 목적은, 기존 멀티 프로세서 부팅 방법에서의 문제점이 부트 프로세서를 제외한 다른 프로세서들이 부팅 과정에서 대부분의 시간을 유휴상태로 보내는 것인 바, 부팅 과정에 유휴상태에 있는 다른 프로세서들을 활용하여 부팅이 모두 완료되기 전에 사용자가 우선적으로 필요로 하는 프로그램을 실행시키되, 운영체제 부팅 전 실행 프로그램을 일정 시간 이전 전원 오프 시 사용자의 최종 이용 프로그램으로 설정함으로써, 사용자 대기시간을 혁신적으로 줄일 수 있도록 하는 동시에 사용자가 전원 오프시 최종 이용했던 프로그램을 전원 재입력시 보다 빠르게 재이용할 수 있도록 하는 장치와 방법, 프로그램 기록매체를 제공함에 있다.
An object of the present invention to overcome the above problems is to provide a booting method and a booting method in which other processors except for the boot processor send most of the time in the idle state during the booting process, It is possible to execute the program that the user needs first before booting is completed by using other processors in the boot program, And more particularly, to a device, a method, and a program recording medium for enabling a user to reuse a program that was last used when a user turns off the power source when the power source is re-input.

또한, 기존 멀티 프로세서 상의 부팅방식만 바꿈으로써, 별도의 하드웨어 추가 필요없이 사용자 대기시간을 혁신적으로 줄일 수 있도록 하는 장치와 방법, 프로그램 기록매체를 제공함에 있다.
Another object of the present invention is to provide an apparatus, a method, and a program recording medium that can innovatively reduce the waiting time of a user without requiring additional hardware by changing only the booting method on the existing multiprocessor.

또한, 운영체제 부팅 완료 후, 각각의 프로세서들이 각각 다른 작업을 수행할 수 있도록 하여, 프로세서 운영 효율을 극대화 시킬 수 있도록 하는 장치와 방법, 프로그램 기록매체를 제공함에 있다.
The present invention also provides an apparatus, a method, and a program recording medium that enable each processor to perform a different task after the booting of an operating system is completed, thereby maximizing the processor operating efficiency.

본 발명에서 이루고자 하는 기술적 과제들은 이상에서 언급한 기술적 과제로 제한되지 않으며, 언급하지 않은 또 다른 기술적 과제들은 아래의 기재로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not intended to limit the invention to the precise forms disclosed. Other objects, which will be apparent to those skilled in the art, There will be.

본 발명에 따른 두 개 이상의 프로세서를 구비하는 프로그램 운영 장치는, 전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리 상에 기록하는 저장부와, 전원 입력시, 제2프로세서를 구동하기 위한 멀티프로세서 분기처리 부트로더(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더를 실행하되, 상기 메모리 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 제1프로세서와, 상기 제1프로세서의 분기처리 부트로더를 통해 구동된 후, 프로그램 부트로더를 실행하여, 상기 프로그램 부트로더를 통해 상기 제1프로세서를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-이전 전원 오프시 사용자가 최종 이용한 프로그램-이 실행되도록 처리하는 제2프로세서를 구비한다.
A program operating device including two or more processors according to the present invention includes: a storage unit that records user's last-used program information after a power-off operation on a memory; a multiprocessor branch A boot loader for booting the operating system and a kernel boot loader for booting the operating system, wherein after confirming the program information last used by the user when the previous power written on the memory is turned off, A first processor for loading a program boot loader corresponding to the program information into a memory; a first processor for executing a program boot loader after being driven through a branch processing boot loader of the first processor, Programs that run without an operating system before booting the operating system - And a second processor for processing so that the running-end party based program.

일측에 따르면, 상기 제1프로세서는, 상기 메모리 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재시, 이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하고, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더를 통해 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하며, 기 설정된 시간을 초과하는 경우, 사용자가 설정하거나, 또는 제1프로세서 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더를 메모리에 적재할 수 있다.
According to one aspect of the present invention, the first processor checks the program information last used by the user when the previous power is turned off on the memory, and then, through the branch processing boot loader, loads the program boot loader corresponding to the verified program information into the memory When it is determined that the time taken from the previous power-off to the current power-supply is within a preset time, when the power is turned off through the branch processing boot loader, If the program boot loader is loaded into the memory and exceeds a preset time, the program is set by the user or a second program preset on the first processor The program boot loader can be loaded into memory.

또 다른 측면에 따르면, 상기 분기처리 부트로더는, 상기 제1프로세서가 실행할 커널 부트로더를 특정 메모리 주소에 적재시키고, 상기 제2프로세서가 실행할 프로그램 부트로더를 상기 커널 부트로더와 다른 메모리 주소에 적재시킨 후, 상기 프로그램 부트로더가 메모리 상에 적재되면, 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소정보를 제공할 수 있다.
According to another aspect, the branch processing boot loader loads the kernel boot loader to be executed by the first processor at a specific memory address, and loads the program boot loader to be executed by the second processor at a memory address different from that of the kernel boot loader If the program boot loader is loaded on the memory, the second program can interrupt the second processor and provide the address information on which the program boot loader is located.

또 다른 측면에 따르면, 상기 프로그램 부트로더는, 실행 대상 프로그램 코드들을 메모리에 적재하되, 상기 프로그램 코드들은, 운영체제 없이 실행되는 Stand-alone 프로그램인 것을 특징으로 한다.
According to another aspect of the present invention, the program boot loader is a stand-alone program that loads execution-target program codes into a memory, wherein the program codes are executed without an operating system.

또 다른 측면에 따르면, 상기 운영체제 없이 실행되는 프로그램은, 실행에 요구되는 자원들을 직접 초기화하고, 직접 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지할 수 있다.
According to another aspect, a program executing without the operating system directly initializes the resources required for execution, and displays the resources directly initialized, thereby preventing the resources from being redundantly initialized in the booting process in the first processor have.

또 다른 측면에 따르면, 상기 제1프로세서는, 커널 초기화 과정에서 초기화할 자원들이 상기 제2프로세서에 의해 초기화되었는지 확인한 후, 확인결과, 초기화되지 않은 경우, 상기 자원들을 직접 초기화하고, 초기화 된 경우, 상기 초기화된 자원들의 초기화를 건너뛸 수 있다.
According to another aspect of the present invention, the first processor determines whether resources to be initialized in the kernel initialization process are initialized by the second processor, and if the initialization is not performed, directly initializes the resources, The initialization of the initialized resources can be skipped.

또 다른 측면에 따르면, 상기 제1프로세서는, 운영체제 부팅 과정이 완료되면, 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하고, 상기 제2프로세서로 인터럽트를 걸어 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리할 수 있다.
According to another aspect of the present invention, the first processor loads the program running on the operating system into the memory while performing the same function as the program currently being executed through the second processor when the operating system booting process is completed, And the program being executed can be processed to be replaced with a program running on the operating system.

또 다른 측면에 따르면, 상기 제1프로세서는, 운영체제 부팅을 처리하는 부트 프로세서인 것을 특징으로 하며, 상기 제1프로세서 및 제2프로세서는, 씨피유(CPU) 또는 코어(Core)인 것을 특징으로 한다.
According to another aspect of the present invention, the first processor is a boot processor for processing an operating system boot, and the first processor and the second processor are a CPU or a core.

본 발명에 따른 두 개 이상의 프로세서를 구비하는 프로그램 운영 방법은, 전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리 상에 기록하는 정보 기록단계와, 전원 입력시, 제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계와, 상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 이전 전원 오프시 최종 이용 프로그램 정보를 확인한 후, 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계와, 상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계와, 상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하는 프로그램 실행단계를 포함한다.
A program operating method having two or more processors according to the present invention includes: an information recording step of recording user's last used program information after a power is turned off in a memory; And a program boot loader to be executed by the second processor in the branch processing boot loader is loaded into a memory address through the information recording step, A program boot loader loading step of loading the program boot loader corresponding to the confirmed program information after confirming the last-used program information when the previous power is turned off, and when the program boot loader is loaded, When the program boot loader is located at the position And a program executing step of executing the program after loading the program codes executed without the operating system through the program boot loader in the second processor into the memory .

일측에 따르면, 상기 프로그램 부트로더 적재단계는, 이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하는 단계를 더 포함할 수 있으며, 확인결과, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더를 통해 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하며, 기 설정된 시간을 초과하는 경우, 사용자가 설정하거나, 또는 제1프로세서 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 것을 특징으로 한다.
According to one aspect of the present invention, the loading step of the program boot loader may further include checking whether the time taken from the previous power-off to the current power-on is within a preset time, The program boot loader corresponding to the program information finally used by the user when the power is turned off is loaded into the memory via the branch processing boot loader. If the program boot loader exceeds the predetermined time, The program boot loader corresponding to the information of the program of the second program which can be used by the user when the power is turned off,

또 다른 측면에 따르면, 상기 프로그램 실행단계는, 실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 단계를 더 포함할 수 있다.
According to another aspect, the program executing step further includes initializing resources required for execution, indicating initialized resources, and preventing the resources from being redundantly initialized in the booting process in the first processor .

또 다른 측면에 따르면, 상기 프로그램 운영 방법은, 운영체제 부팅 과정이 완료되면, 상기 제1프로세서에서 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하는 단계와, 상기 제1프로세서에서 상기 제2프로세서로 인터럽트를 걸어 상기 프로그램 실행단계를 통해 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 단계를 더 포함할 수 있다.
According to another aspect of the present invention, there is provided a method for operating a program, the method comprising the steps of: when the operating system booting process is completed, performing a same function as a program currently running in the first processor through the second processor, And interrupting the second processor from the first processor to process the program being executed through the program execution step to be replaced with a program operating on the operating system.

또한, 본 발명에 따르면, 상기 프로그램 운영 방법의 각각의 단계는 프로그램 형태로 구현 가능하며, 본 발명은 상기 프로그램 운영 방법을 실행하기 위한 프로그램을 기록한 것을 특징으로 하는 컴퓨터로 판독 가능한 기록매체를 포함한다.
According to the present invention, each step of the program operating method can be implemented in the form of a program, and the present invention includes a computer-readable recording medium having recorded thereon a program for executing the program operating method .

본 발명에 따르면, 멀티 프로세서가 구비된 프로그램 운영 장치에서 별도의 하드웨어의 추가 없이 부팅방식 만을 개선하여 사용자가 원하는 프로그램 실행까지의 사용자 대기시간을 혁신적으로 줄일 수 있도록 하는 효과와 운영체제 부팅 완료 후, 각각의 프로세서들이 각각 다른 작업을 수행할 수 있도록 하여, 멀티 프로세서의 병렬성을 최대한 활용할 수 있는 효과를 지니고 있다.
According to the present invention, it is possible to improve the booting method without adding any additional hardware in the program operating device provided with the multiprocessor, thereby allowing the user to innovatively reduce the waiting time for the user to execute the desired program, Processors can perform different tasks, thereby maximizing the parallelism of the multiprocessor.

또한, 본 발명에 따르면, 운영체제 부팅 전 실행 프로그램을 일정 시간 이전 전원 오프 시 사용자의 최종 이용 프로그램으로 설정함으로써, 사용자가 전원 오프시 최종 이용했던 프로그램을 전원 재입력시 보다 빠르게 재이용할 수 있도록 하는 효과를 지니고 있다.(예를 들면, A사용자가 휴게소에 잠깐 들리는 경우, 수십분 내에 시동을 다시 켜면, 시동을 끄기 전 프로그램을 자동으로 최우선 실행함으로서, 사용자가 시동을 끄기 전 프로그램을 다시 선택해야하는 불편함을 해결 가능)
In addition, according to the present invention, it is possible to reuse a program that was last used by the user when the user turns off the power source, faster than when the power source is re-input, by setting the execution program before booting the operating system to the user's last- (For example, when the user A is in the rest area for a while, if the power is turned on again within several tens of minutes, the program is automatically put to the top priority before the power is turned off so that the user must select the program again before turning off the power) However,

또한, 본 발명은 운영체제의 크기가 커짐에 상관없이 사용자 대기시간을 단축할 수 있으며, 기존 부팅 개선 기법들을 중복하여 적용할 수 있는 효과를 지니고 있다.
In addition, the present invention can reduce the user waiting time regardless of the size of the operating system, and has the effect of applying the existing boot improvement techniques in a redundant manner.

또한, 본 발명을 차량용 시스템에 적용한다면, 운전자가 후방 카메라를 사용하기 위해 15초 이상 기다려야 하는 문제를 해결할 수 있다.
Further, if the present invention is applied to a vehicle system, it is possible to solve the problem that the driver has to wait more than 15 seconds to use the rear camera.

즉, 차량에 전원이 공급되면, 부팅 과정 중 유휴 상태의 다른 프로세서를 활용하여 운전자에게 후방 상황을 보여줌으로써, 운전자는 즉시 운전할 수 있게 되고, 주행 중 후방 카메라를 사용하지 않을 때는 전담 프로세서가 반환되어 다른 서비스를 제공하는데 사용되어 멀티 프로세서의 효율적인 운영이 가능케 한다.
In other words, when power is supplied to the vehicle, the driver is able to drive immediately by showing the rear situation to the driver by using another processor in the idle state during the booting process, and when the rear camera is not used during driving, It is used to provide other services to enable efficient operation of multi-processors.

본 명세서에 첨부되는 다음의 도면들은 본 발명의 바람직한 실시예를 예시하는 것이며, 전술한 발명의 상세한 설명과 함께 본 발명의 기술사상을 더욱 이해시키는 역할을 하는 것이므로, 본 발명은 그러한 도면에 기재된 사항에만 한정되어 해석되지 않아야 한다.
도 1은 종래 프로그램 운영 장치에서의 운영체제 부팅과정 흐름을 보여주는 흐름도이다.
도 2는 종래 단일 프로세서가 구비된 프로그램 운영 장치에서 운영체제 부팅과정 이후 프로그램 실행에 따른 프로세스를 보여주는 일실시예도이다.
도 3은 종래 멀티 프로세서가 구비된 프로그램 운영 장치에서 운영체제 부팅과정 이후 프로그램 실행에 따른 프로세스를 보여주는 일실시예도이다.
도 4는 본 발명의 실시 방법에 따른 프로그램 운영 장치의 주요 구성을 보여주는 도면이다.
도 5는 본 발명의 실시 방법에 따른 운영체제 부팅 전 실행 프로그램을 전원 오프 시 사용자의 최종 이용 프로그램으로 설정하는 프로세스를 보여주는 도면이다.
도 6은 본 발명의 실시 방법에 따른 운영체제 부팅과 프로그램 실행 프로세스를 보여주는 도면이다.
도 7은 종래 기술과 본 발명의 실시 방법에 따른 사용자 대기시간을 대비하여 보여주는 도면이다.
도 8은 본 발명의 실시 방법에 따른 운영체제 부팅 전 프로그램 실행 프로세스를 도시한 도면이다.
도 9는 본 발명의 실시 방법에 따른 운영체제 부팅 후 프로그램 실행 프로세스를 도시한 도면이다.
도 10은 본 발명의 실시 방법에 따른 일실시예도 이다.
BRIEF DESCRIPTION OF THE DRAWINGS The accompanying drawings, which are incorporated in and form a part of the specification, illustrate preferred embodiments of the invention and, together with the description of the invention given above, serve to further the understanding of the technical idea of the invention. And should not be construed as interpretation.
FIG. 1 is a flowchart illustrating an operating system boot process flow in a conventional program operating device.
FIG. 2 is a diagram illustrating a process according to the execution of a program after an operating system boot process in a program operating device including a conventional single processor.
FIG. 3 is a diagram illustrating a process according to the execution of a program after an operating system boot process in a conventional program operating device provided with a multiprocessor.
FIG. 4 is a diagram illustrating a main configuration of a program operating apparatus according to an embodiment of the present invention.
5 is a diagram illustrating a process of setting an execution program before operating system boot according to an embodiment of the present invention as a final use program of a user when power is turned off.
6 is a diagram illustrating an operating system boot process and a program execution process according to an embodiment of the present invention.
FIG. 7 is a diagram illustrating a comparison of user latency according to the prior art and the method of the present invention.
8 is a diagram illustrating a program execution process before booting an operating system according to an embodiment of the present invention.
9 is a diagram illustrating a program execution process after an operating system boot according to an embodiment of the present invention.
10 is an embodiment according to an embodiment of the present invention.

이하 첨부된 도면과 설명을 참조하여 본 발명의 바람직한 실시예에 대한 동작 원리를 상세히 설명한다. 다만, 하기에 도시되는 도면과 후술되는 설명은 본 발명의 특징을 효과적으로 설명하기 위한 여러 가지 방법 중에서 바람직한 실시 방법에 대한 것이며, 본 발명이 하기의 도면과 설명만으로 한정되는 것은 아니다. 또한, 하기에서 본 발명을 설명함에 있어 관련된 공지 기능 또는 구성에 대한 구체적인 설명이 본 발명의 요지를 불필요하게 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명을 생략할 것이다. 그리고 후술되는 용어들은 본 발명에서의 기능을 고려하여 정의된 용어들로서, 이는 사용자, 운용자의 의도 또는 관례 등에 따라 달라질 수 있다. 그러므로 그 정의는 본 발명에서 전반에 걸친 내용을 토대로 내려져야 할 것이다.
The operation principle of the preferred embodiment of the present invention will be described in detail with reference to the accompanying drawings and description. It should be understood, however, that the drawings and the following detailed description are exemplary and explanatory and are intended to provide further explanation of the invention, and are not to be construed as limiting the present invention. In the following description of the present invention, a detailed description of known functions and configurations incorporated herein will be omitted when it may make the subject matter of the present invention rather unclear. The terms used below are defined in consideration of the functions of the present invention, which may vary depending on the user, intention or custom of the operator. Therefore, the definition should be based on the contents throughout the present invention.

결과적으로, 본 발명의 기술적 사상은 청구범위에 의해 결정되며, 이하 실시예는 진보적인 본 발명의 기술적 사상을 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 효율적으로 설명하기 위한 일 수단일 뿐이다.
As a result, the technical idea of the present invention is determined by the claims, and the following embodiments are merely means for effectively explaining the technical idea of the present invention to a person having ordinary skill in the art to which the present invention belongs Only.

도 4는 본 발명의 실시 방법에 따른 프로그램 운영 장치(100)의 세부 구성을 도시한 도면이다.
FIG. 4 is a diagram showing a detailed configuration of a program operating apparatus 100 according to an embodiment of the present invention.

보다 상세하게 본 도면 4는 2개 이상의 멀티 프로세서를 구비한 프로그램 운영 장치(100) 구성을 도시한 것으로서, 도면 4는 본 발명에 따른 주요 구성요소만 도시하였으며, 본 도면상에 구체적인 도시는 생략하였으나, 당업자의 의도에 따라 상기 프로그램 운영 장치(100)의 구성은 추가 또는 삭제될 수 있다.
4 shows a configuration of a program operating apparatus 100 having two or more multiprocessors. FIG. 4 shows only major components according to the present invention, and a detailed illustration thereof is omitted. , The configuration of the program operating apparatus 100 may be added or deleted according to the intention of those skilled in the art.

바람직하게, 본 발명에 따른 프로그램 운영 장치(100)의 주요 기능구성은, 도시된 바와 같이, 제1프로세서(110)와 제2프로세서(120)와 비휘발성 메모리(130)와 메인 메모리(140)와, 저장부(150)를 포함하여 구성될 수 있으며, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 더 포함하여 구성될 수 있으며, 프로그램 운영 장치(100)의 종류와 특성에 따라 상기 각 구성부는 추가 또는 제외될 수 있다.
The main functional configuration of the program operating apparatus 100 according to the present invention is that the first processor 110 and the second processor 120, the nonvolatile memory 130 and the main memory 140, And a storage unit 150. The system further includes a boot monitor 11,21, a branch processing boot loader 12, a kernel boot loader 13, and a program boot loader 22 And the respective components may be added or excluded depending on the type and characteristics of the program operating device 100. [

또한, 도면 상 상기 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)는 제1프로세서(110)와 제2프로세서(120) 내 포함된 것으로 도시되었으나, 상기 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)는 비휘발성 메모리(130)와 메인 메모리(140)에 포함되어 구성될 수도 있으며, 별개의 구성으로 이루어질 수도 있으며, 그 일부는 생략도 가능하다.
The boot monitors 11 and 21, the branch processing boot loader 12 and the kernel boot loader 13 and the program boot loader 22 are connected to the first processor 110 and the second processor 120, The branch processing loader 12 and the kernel boot loader 13 and the program boot loader 22 are connected to the nonvolatile memory 130 and the main memory 140, or may have a separate structure, and some of them may be omitted.

본 발명의 실시방법에 따르면, 상기 저장부(150)는, 전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리(130 또는 140) 상에 기록하는 역할을 수행한다.
According to the embodiment of the present invention, the storage unit 150 records the last used program information of the user on the memory 130 or 140 after the power is turned off.

즉, 상기 저장부(150)는, 프로그램 운영 장치(100)의 전원이 오프되는 시점에 전원 오프 직전 사용자가 이용한 프로그램에 대한 정보를 메모리(130 또는 140) 상에 저장함으로써, 운영체제 부팅 전 실행 프로그램을 일정 시간 이전 전원 오프 시 사용자의 최종 이용 프로그램으로 설정할 수 있도록 한다.
That is, the storage unit 150 stores information on a program used by the user immediately before the power is turned off at the time when the power of the program operating device 100 is turned off, Can be set as the end use program of the user when the power is turned off before the predetermined time.

예를 들면, A사용자가 휴게소에 잠깐 들리는 경우, 자동차 시동을 끄기 전 사용자가 이용한 프로그램이 네비게이션 프로그램임을 메모리(130 또는 140)에 기록함으로써, 사용자가 휴게소 이용을 마치고 수십분 내에 시동을 다시 켜면, 시동을 끄기 전 프로그램을 메모리를 통해 확인하여 자동으로 최우선 실행하여, 사용자가 시동을 끄기 전 프로그램을 다시 선택해야하는 불편함을 해결 가능하도록 한다.
For example, when the user A briefly hears a rest in the rest area, it records in the memory 130 or 140 that the program used by the user before turning off the vehicle is a navigation program. When the user finishes using the rest area and turns on the power again within several minutes, The program is checked through the memory and automatically executes the highest priority so that the user can solve the inconvenience of selecting the program again before turning off the power.

본 발명의 실시방법에 따르면, 상기 제1프로세서(110)는 전원 입력시, 제2프로세서(120)를 구동하기 위한 멀티프로세서 분기처리 부트로더(12)(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더(13)를 실행하되, 상기 메모리(130 또는 140) 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더(12)를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더(22)를 메모리(140)에 적재하는 역할을 수행하며, 상기 제2프로세서(120)는 상기 제1프로세서(110)의 분기처리 부트로더(12)를 통해 구동된 후, 프로그램 부트로더(22)를 실행하여, 상기 프로그램 부트로더(22)를 통해 상기 제1프로세서(110)를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-이전 전원 오프시 사용자가 최종 이용한 프로그램-이 실행되도록 처리하는 역할을 수행한다.
According to an embodiment of the present invention, the first processor 110 includes a multiprocessor branch processing boot loader 12 for booting the second processor 120 and a kernel for booting the operating system, ) Executes the boot loader 13 and confirms the program information last used by the user when the previous power is turned off on the memory 130 or 140 and confirms the program information last used by the user through the branch processing boot loader 12 The second processor 120 loads the corresponding program boot loader 22 into the memory 140. The second processor 120 is driven through the branch processing boot loader 12 of the first processor 110, A program executed without the operating system before the operating system is booted through the first processor 110 through the program boot loader 22 by executing the program boot loader 22, It serves to process run.

즉, 상기 프로그램 운영 장치(100)에 전원이 들어오면, 제1프로세서(110)는 운영체제 부팅을 담당하고, 제2프로세서(120)는 운영체제 없이 동작할 수 있는 Stand-alone 프로그램을 실행하여 사용자 대기시간을 줄이는 역할을 수행하며, 제1프로세서(110)에 의해 부팅이 완료되면, 제2프로세서(120)를 포함하는 모든 프로세서들은 운영체제의 지배를 받아 스케줄러가 할당해주는 작업을 수행한다.
That is, when the program operating apparatus 100 is powered on, the first processor 110 performs booting of the operating system, the second processor 120 executes a stand-alone program capable of operating without an operating system, When all the processors including the second processor 120 are booted by the first processor 110, the processors are controlled by the operating system and perform tasks assigned by the scheduler.

또한, 본 발명에 따르면, 상기 제1프로세서(110)는, 상기 메모리(130 또는 140) 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더(12)를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더(22)를 메모리에 적재시, 이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하고, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더(12)를 통해 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더(22)를 메모리(140)에 적재하며, 기 설정된 시간을 초과하는 경우, 사용자가 설정하거나, 또는 제1프로세서(110) 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더(22)를 메모리(140)에 적재할 수 있다.
In addition, according to the present invention, the first processor 110 may check the program information last used by the user when the previous power off, which is recorded on the memory 130 or 140, is turned off and then the branch processing boot loader 12 When the program boot loader 22 corresponding to the verified program information is loaded into the memory, it is checked whether the time taken from the previous power-off to the current power-on is within a preset time, The program boot loader 22 corresponding to the program information finally used by the user when the power is turned off is loaded into the memory 140 via the processing boot loader 12. If the program boot loader 22 exceeds the predetermined time, 1 processor 110. The program boot loader 22 corresponding to the second program previously set on the processor 110, Can be loaded into the memory 140.

또한, 본 발명에 따르면, 상기 제1프로세서(110)는, 운영체제 부팅 과정이 완료되면, 상기 제2프로세서(120)를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리(140)에 적재하고, 상기 제2프로세서(120)로 인터럽트를 걸어 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 역할을 더 수행한다.
In addition, according to the present invention, when the booting process of the operating system is completed, the first processor 110 performs the same function as the currently executing program through the second processor 120, 140, and interrupts the second processor 120 to perform a process of replacing a running program with a program running on the operating system.

또한, 상기 제1프로세서(110)는 커널 초기화 과정에서 초기화할 자원들이 상기 제2프로세서(120)에 의해 초기화되었는지 확인한 후, 확인결과, 초기화되지 않은 경우, 상기 자원들을 직접 초기화하고, 초기화 된 경우, 상기 초기화된 자원들의 초기화를 건너뛰는 역할을 더 수행할 수 있다.
In addition, the first processor 110 determines whether resources to be initialized in the kernel initialization process are initialized by the second processor 120. If the resources are not initialized, the first processor 110 directly initializes the resources, , And skipping the initialization of the initialized resources.

상기 제1프로세서(110)는, 운영체제 부팅을 처리하는 부트 프로세서인 것을 특징으로 하며, 상기 제1프로세서(110) 및 제2프로세서(120)는, 씨피유(CPU) 또는 코어(Core)인 것을 특징으로 한다.
The first processor 110 and the second processor 120 are boot processors that process booting of an operating system and the first processor 110 and the second processor 120 are CPUs or cores .

본 발명에 따른 비휘발성 메모리(130)는 전원 오프시, 직전 사용자가 최종 이용한 프로그램 정보와, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 하나 이상 저장하며, 사용자가 실행하고자 하는 프로그램 코드들을 하나 이상 저장한다.
The nonvolatile memory 130 according to the present invention is a nonvolatile memory 130 that stores program information that has been used by the user immediately before the power off, boot monitors 11 and 21, branch processing boot loader 12 and kernel boot loader 13, Stores one or more boot loaders 22, and stores one or more program codes to be executed by the user.

본 발명에 따른 메인 메모리(140)는 사전원 오프시, 직전 사용자가 최종 이용한 프로그램 정보와, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 하나 이상 로딩하여 저장하며, 사용자가 실행하고자 하는 프로그램 코드들을 하나 이상 로딩하여 저장한다.
The main memory 140 according to the present invention stores the program information last used by the immediately preceding user and the boot monitors 11 and 21, the branch processing boot loader 12 and the kernel boot loader 13, One or more boot loaders 22 are loaded and stored, and one or more program codes to be executed by the user are loaded and stored.

상기 비휘발성 메모리(130)와 메인 메모리(140)는 도면 상에 분리되어 도시되었으나, 당업자의 실시방식에 따라 단일 메모리로 구성될 수 있다.
Although the non-volatile memory 130 and the main memory 140 are shown separately in the drawing, they may be configured as a single memory according to a method of a person skilled in the art.

본 발명에 따른 제1프로세서(110) 상의 부트 모니터(11)는, 먼저 현재 자신을 실행하는 프로세서가 첫 번째 프로세서인지 아닌지를 알아내는 작업을 수행하고, 현재 프로세서가 첫 번째 프로세서라면 분기처리 부트로더(12)를 실행하는 역할을 수행한다.
The boot monitor 11 on the first processor 110 according to the present invention performs an operation of first determining whether or not the processor currently executing itself is the first processor and if the current processor is the first processor, (12).

본 발명에 따른 제2프로세서(120) 상의 부트 모니터(21)는, WFI(wait for interrupt)를 수행하면서, 제1프로세서(110)를 통한 인터럽트가 수행되면, 프로그램 부트로더(22)를 실행하는 역할을 수행한다.
The boot monitor 21 on the second processor 120 according to the present invention executes the program boot loader 22 when an interrupt is performed through the first processor 110 while performing a wait for interrupt Role.

본 발명에 따른 분기처리 부트로더(12)는, 커널 이미지를 메인 메모리(140)에 적재하는 작업을 수행하기 전에, 제2의 프로세서를 깨우는 작업을 먼저 수행한다.
The branch processing boot loader 12 according to the present invention performs a task of waking up the second processor before performing the task of loading the kernel image into the main memory 140. [

즉, 상기 분기처리 부트로더(12)는 제1프로세서(110)가 실행할 커널 부트로더(13)(커널이미지를 적재해줄 부트로더)를 특정한 메인 메모리(140) 주소에 적재시키고, 제2프로세서(120)가 실행할 프로그램 부트로더(22)(상기 메모리(130 또는 140) 상에 기록된 전원 오프시 직전 사용자가 최종 이용한 프로그램을 적재해줄 부트로더)를 커널 부트로더(13)와는 다른 메모리(140) 주소에 적재시킨 후, 상기 프로그램 부트로더(22)가 적재되면, 상기 제2프로세서(120)로 인터럽트를 걸면서 상기 프로그램 부트로더(22)가 위치한 주소를 제2프로세서(120)로 전달하는 역할을 수행한다.
That is, the branch processing boot loader 12 loads the kernel boot loader 13 (boot loader for loading the kernel image) to be executed by the first processor 110 at a specific address of the main memory 140, The program boot loader 22 to be executed by the kernel boot loader 120 (a boot loader for loading a program last used immediately before power-off recorded on the memory 130 or 140) Address of the program boot loader 22 to the second processor 120 while interrupting the second processor 120 when the program boot loader 22 is loaded .

본 발명에 따른 커널 부트로더(13)는, 기존 부팅에서 사용되는 일반적인 부트로더와 동일한 역할을 수행하는 바, 그 상세한 설명은 생략한다.
The kernel boot loader 13 according to the present invention plays the same role as a general boot loader used in conventional boot, and a detailed description thereof will be omitted.

본 발명에 따른 프로그램 부트로더(22)는, 실행 대상 프로그램 코드들을 메인 메모리(140)에 적재한 뒤 프로그램을 실행하는 역할을 수행한다.(이 때, 적재되는 프로그램 코드들은 운영체제의 도움 없이 실행될 수 있는 Stand-alone 프로그램이다.)
The program boot loader 22 according to the present invention plays the role of loading the execution target program codes into the main memory 140 and executing the program (in this case, the loaded program codes can be executed without the help of the operating system It is a stand-alone program.)

즉, 상기 제1프로세서(110)가 운영체제 부팅을 수행하는 과정에서 동시에 수행되는 프로그램 부트로더(22)의 역할을 통해, 상기 제2프로세서(120)가 담당하는 실행 대상 프로그램은 커널 부팅을 기다릴 필요 없이 사용자에게 서비스를 제공할 수 있어서 사용자 대기시간을 단축시킬 수 있도록 한다.
That is, through the role of the program boot loader 22 performed simultaneously with the execution of the operating system boot by the first processor 110, the execution target program managed by the second processor 120 needs to wait for the kernel boot It is possible to provide the service to the user without the user, thereby shortening the waiting time of the user.

본 발명에 따른 Stand-alone 프로그램은 운영체제 없이 상기 제2프로세서(120)에서 실행될 수 있는 프로그램으로 사용자에게 서비스를 제공하며, Stand-alone 프로그램이 실행되는 시점이 사용자 대기시간이 된다.
The stand-alone program according to the present invention is a program that can be executed by the second processor 120 without an operating system and provides a service to the user, and the time when the stand-alone program is executed becomes a user waiting time.

즉, 상기 Stand-alone 프로그램은 프로그램 부트로더(22)에 의해 적재된 후, 상기 제1프로세서(110)가 운영체제 부팅을 진행하는 동안 프로그램 실행을 위한 자원들을 직접 초기화하고, 사용자에게 서비스를 제공하기 때문에 커널 부팅을 기다릴 필요가 없다.
That is, after the stand-alone program is loaded by the program boot loader 22, the first processor 110 directly initializes the resources for executing the program during the booting of the operating system, So you do not have to wait for the kernel to boot.

본 발명에 따르면, 상기 Stand-alone 프로그램은 직접 초기화한 자원들을 표시하는 역할을 더 수행하여, 상기 제1프로세서(110)가 부팅 과정에서 동일한 자원의 중복 초기화를 방지한다.
According to the present invention, the stand-alone program further performs a function of displaying resources directly initialized, thereby preventing the first processor 110 from duplicatively initializing the same resource during the booting process.

본 발명에 따르,면, 상기 부트 모니터(11, 21)와, 분기처리 부트로더(12)와, 커널 부트로더(13)와, 프로그램 부트로더(22)의 기능과 역할은 상기 제1프로세서(110)와 제2프로세서(120)로 대체 가능하다.
According to the present invention, the functions and roles of the boot monitors 11 and 21, the branch processing boot loader 12, the kernel boot loader 13, and the program boot loader 22 are controlled by the first processor 110 and the second processor 120, respectively.

도 5는 본 발명의 실시 방법에 따른 운영체제 부팅 전 실행 프로그램을 전원 오프 시 사용자의 최종 이용 프로그램으로 설정하는 프로세스를 보여주는 도면이다.
5 is a diagram illustrating a process of setting an execution program before operating system boot according to an embodiment of the present invention as a final use program of a user when power is turned off.

우선, 프로그램 운영 장치(100)는 저장부(150)를 통해 전원 오프 전 사용자가 이용하는 프로그램 정보를 메모리(130 또는 140) 상에 임시 저장한다(S510).
First, the program operating device 100 temporarily stores program information used by the user in the memory 130 or 140 through the storage unit 150 in step S510.

전원 오프 전까지 사용자가 이용하는 프로그램이 변경되면, 상기 (S510)과정은 변경시 마다, 사용자가 이용하는 프로그램 정보를 메모리(130 또는 140) 상에 임시 저장하는 과정을 반복한다.
If the program to be used by the user is changed until the power is turned off, the process of S510 repeats the process of temporarily storing the program information used by the user in the memory 130 or 140 every time the process is changed.

전원 오프 후(S520), 다시 전원이 입력되면(S530), 프로그램 운영 장치(100)는 제1프로세서(110)를 통해 상기 메모리(130 또는 140) 상에 저장된 전원 오프 직전 사용자가 이용한 프로그램 정보를 확인한다(S540).
After the power is turned off (S520), when the power is again inputted (S530), the program operating device 100 transmits program information used by the user immediately before power off stored in the memory 130 or 140 via the first processor 110 (S540).

만약, 전원이 오프되지 않으면, 상기 프로그램 운영 장치(100)는 저장부(150)를 통해 전원 오프 전 사용자가 이용하는 프로그램 정보를 메모리(130 또는 140) 상에 임시 저장하는 과정을 반복한다(S550)
If the power is not turned off, the program operating device 100 repeats the process of temporarily storing the program information used by the user in the memory 130 or 140 through the storage unit 150 (S550)

이후, 프로그램 운영 장치(100)는 제1프로세서(110)를 통해 (S540)과정을 통해 확인한 전원 오프 전 사용자가 이용하는 프로그램 정보를 분기처리 부트로더(12)로 전달하여(S560), 분기처리 부트로더(12)가 전원 오프시 직전 사용자가 최종 이용한 프로그램을 운영체제 부팅 전 실행시킬 프로그램으로 확정할 수 있도록 한다.
Thereafter, the program operating apparatus 100 transmits program information, which is checked by the user through the first processor 110 in step S540, to the branch processing load loader 12 (S560) So that the loader 12 can finally determine the program that was last used by the user immediately before power-off as a program to be executed before booting the operating system.

도면 상에 별도로 도시하지는 않았으나, 상기 (S530) 과정 내지 (S540)과정은, 상기 제12프로세서(110)에서 이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하고, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더(12)로 전원 오프 전 사용자가 이용하는 프로그램 정보를 전달하여 분기처리 부트로더(12)가 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더(22)를 메모리(140)에 적재하도록 하며, 기 설정된 시간을 초과하는 경우, 상기 분기처리 부트로더(12)로 전원 오프 전 사용자가 이용하는 프로그램 정보를 전달하는 과정을 생략하여, 사용자가 설정하거나, 또는 제1프로세서(110) 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더(22)가 메모리(140)에 적재되도록 한다.
Although it is not shown in the drawing, the process from S530 to S540 is to check whether the time taken from the previous power-off to the current power-on in the 12th processor 110 is within a preset time, The branch processing loader 12 transfers the program information to be used by the user before the power is turned off to the branch processing boot loader 12 so that the branch processing loader 12 can control the program boot loader corresponding to the program information finally used by the user 22 is loaded in the memory 140 and the process of transferring the program information used by the user to the branch processing boot loader 12 before the power is turned off may be omitted, Or a second program preset on the first processor 110 in response to the information that the user last used the program that can be used when the power is turned off Such that the boot loader program 22 is loaded into the memory 140.

도 6은 본 발명의 실시 방법에 따른 운영체제 부팅과 프로그램 실행 프로세스를 보여주는 도면이다.
6 is a diagram illustrating an operating system boot process and a program execution process according to an embodiment of the present invention.

도면 6에 따르면, 제1프로세서(110)와 제2프로세서(120)를 통한 운영체제 부팅과정과 사용자가 이용하고자 하는 프로그램 실행과정을 동시 진행함에 따라, 사용자 대기시간을 크게 줄일 수 있도록 하는 것을 보여주고 있다.
Referring to FIG. 6, the operating system booting process through the first processor 110 and the second processor 120 and the program execution process to be used by the user are simultaneously performed, have.

도면 6에 따른 각각의 과정을 간략하게 기술하면, ①전원이 연결된 후, 부트 모니터(11)에 의해 제1프로세서(110)는 분기처리 부트로더(12)를 실행하고, 분기처리 부트로더(12)는 커널 부트로더(13)를 특정 메모리(140) 주소에 적재시키고, 제2프로세서(120)가 실행할 프로그램-상기 도면 5의 (S560)과정을 통해 확정된 프로그램- 부트로더(22)를 커널 부트로더(13)와는 다른 메모리(140) 주소에 적재시킨 후, 상기 제2프로세서(120)로 인터럽트를 걸면서 상기 프로그램 부트로더(22)가 위치한 주소를 전달한다.
6 will be briefly described. (1) After the power source is connected, the first processor 110 executes the branch processing boot loader 12 by the boot monitor 11, and the branch processing boot loader 12 Loads the kernel boot loader 13 at the address of the specific memory 140 and transfers the program-boot loader 22 determined by the process to be executed by the second processor 120 (S560) Loads the program loader 22 at an address different from that of the boot loader 13 and then transfers the address where the program boot loader 22 is located while interrupting the second processor 120.

이후, ②~⑤상기 제1프로세서(110)는 커널 부트로더(13) 주소로 점프하여 커널 부팅과정을 수행하고, 제2프로세서(120)는 메모리(140)에 프로그램 코드들을 로딩한 후, 프로그램 실행을 수행한다.
The first processor 110 jumps to the address of the kernel boot loader 13 to perform a kernel boot process. The second processor 120 loads the program codes into the memory 140, Perform the execution.

이후, 운영체제 부팅이 완료되면, ⑥~⑦상기 제1프로세서(110)는 운영체제 위에서 동작하는 프로그램을 메모리(140)에 로딩하고, 제2프로세서(120)로 인터럽트를 걸어 기 실행중인 운영체제 없이 실행되던 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리한다.
When the booting of the operating system is completed, the first processor 110 loads the program running on the operating system into the memory 140, interrupts the second processor 120, Process the program so that it is replaced by a program running on the operating system.

도 7은 종래 기술과 본 발명의 실시 방법에 따른 사용자 대기시간을 대비하여 보여주는 도면이다.
FIG. 7 is a diagram illustrating a comparison of user latency according to the prior art and the method of the present invention.

도면 7에 따르면, 종래 멀티 프로세서가 구비된 프로그램 운영 장치(100)와 본 발명에 따른 멀티 프로세서가 구비된 프로그램 운영 장치(100) 간 사용자 대기시간이 크게 줄어드는 것을 볼 수 있다.
Referring to FIG. 7, it can be seen that the user waiting time between the program operating apparatus 100 having the conventional multiprocessor and the program operating apparatus 100 having the multi-processor according to the present invention is greatly reduced.

이하, 도면 8 내지 9을 통해 본 발명에 따른 프로그램 실행 프로세스를 보다 상세히 설명하기로 한다.(다만, 운영체제 부팅과정 중 일반적인 부팅기술은 그 상세한 설명을 생략한다.)
Hereinafter, the program execution process according to the present invention will be described in more detail with reference to FIGS. 8 to 9. (Hereinafter, a general description of a booting technique during an operating system booting process will be omitted.

도 8은 본 발명의 실시 방법에 따른 운영체제 부팅 전 프로그램 실행 프로세스를 도시한 도면이다.
8 is a diagram illustrating a program execution process before booting an operating system according to an embodiment of the present invention.

우선, 제1프로세서(110)는 제2프로세서(120)를 구동하기 위한 분기처리 부트로더(12)를 실행한다(S810).
First, the first processor 110 executes a branch processing boot loader 12 for driving the second processor 120 (S810).

이후, 상기 제1프로세서(110)는 분기처리 부트로더(12)를 통해 제1프로세서(110)가 실행할 커널 부트로더(13)를 특정한 메인 메모리(140) 주소에 적재시키고, 상기 도면 5의 프로세스를 통해 확정되어 메모리(130 또는 140)에 기록된 전원 오프시 직전 사용자가 최종 이용한 프로그램 정보를 확인한다(S820).
The first processor 110 loads the kernel boot loader 13 to be executed by the first processor 110 into the address of the main memory 140 via the branch processing boot loader 12, And the user immediately confirms the program information last used immediately before power off, which is recorded in the memory 130 or 140 (S820).

이후, 상기 제1프로세서(110)는 분기처리 부트로더(12)를 통해 상기 제2프로세서(120)가 실행할 프로그램-상기 (S820)과정을 통해 확인된 프로그램- 부트로더(22)를 커널 부트로더(13)와는 다른 메모리(140) 주소에 적재시킨다(S830).
The first processor 110 then transmits a program to be executed by the second processor 120 through the branch processing boot loader 12 to the kernel boot loader 22 via the program boot loader 22, (Step S830).

이후, 상기 프로그램 부트로더(22)가 메인 메모리(140)에 적재되면, 상기 제1프로세서(110)는 상기 제2프로세서(120)로 인터럽트를 걸면서 상기 프로그램 부트로더(22)가 위치한 주소를 제2프로세서(120)로 전달하고(S840), 커널 부트로더(13) 주소로 점프하여 일반적인 커널 부팅과정을 수행한다(S850).
Thereafter, when the program boot loader 22 is loaded in the main memory 140, the first processor 110 interrupts the second processor 120 and transmits the address where the program boot loader 22 is located (Step S840), and the general kernel boot process is performed by jumping to the address of the kernel boot loader 13 (S850).

도면 상에 별도로 도시하지는 않았지만, 상기 (S850)과정은 일반적인 운영체제 부팅과정으로 처리되나, 커널 초기화 과정에서 초기화할 자원들이 상기 제2프로세서(120)를 통해 초기화되었는지 확인한 후, 아직 초기화되지 않았다면 직접 해당 자원을 초기화하고, 이미 제2프로세서(120)에 의해 초기화된 경우에는 해당 자원 초기화를 건너뛰어 중복 초기화를 방지하는 과정이 포함될 수 있음을 명기하는 바이다.
Although not shown in the drawing, the process of step S850 is performed by a general OS booting process. However, if it is determined that resources to be initialized in the kernel initialization process are initialized through the second processor 120, And a process of preventing duplicate initialization by skipping the resource initialization if the resource has already been initialized by the second processor 120. [

이후, 상기 제2프로세서(120)는 프로그램 부트로더(22)의 주소를 확인한 후, 프로그램 부트로더(22)를 구동시킨 후(S860), 프로그램 부트로더(22)를 통해 실행 대상 프로그램 코드들을 메인 메모리(140)에 적재하고(S870), 프로그램 실행을 위한 자원들을 직접 초기화하여 운영체제 없이 구동되는 프로그램을 실행한다(S880).
Thereafter, the second processor 120 checks the address of the program boot loader 22, and then drives the program boot loader 22 (S860) (S870), directly initializes resources for executing the program, and executes a program running without the operating system (S880).

도면 상에 별도로 도시하지는 않았지만, 상기(S880)과정은 직접 초기화한 자원들을 표시하는 과정을 더 포함하여, 상기 제1프로세서(110)가 부팅 과정에서 동일한 자원의 중복 초기화를 방지할 수 있음을 명기하는 바이다.
Although not shown separately in the drawing, the step (S880) further includes a step of displaying resources that have been directly initialized, thereby indicating that the first processor 110 can prevent the duplicate initialization of the same resource during the booting process I do.

도 9는 본 발명의 실시 방법에 따른 운영체제 부팅 후 프로그램 실행 프로세스를 도시한 도면이다.
9 is a diagram illustrating a program execution process after an operating system boot according to an embodiment of the present invention.

우선, 상기 제1프로세서(110)는 운영체제 부팅이 완료되었는지 여부를 확인한다(S910).
First, the first processor 110 determines whether the booting of the operating system is completed (S910).

(S910)과정을 통한 확인결과, 부팅이 완료된 경우(S920), 상기 제1프로세서(110)는 상기 제2프로세서(120)를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리(140)에 적재하고(S930), 상기 제2프로세서(120)로 인터럽트를 걸어 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리한다(S940).
(S910), if the booting is completed (S920), the first processor 110 performs the same function as the currently running program through the second processor 120, but executes a program running on the operating system The program is loaded into the memory 140 (S930), an interrupt is made to the second processor 120, and a program being executed is replaced with a program running on the operating system (S940).

만약, (S910)과정을 통한 확인결과, 부팅이 완료되지 않은 경우(S950), 상기 제1프로세서(110)는 (S910)과정을 반복한다.
If it is determined in step S910 that booting is not completed in step S950, the first processor 110 repeats step S910.

이후, 상기 제1프로세서(110)는 부팅이 완료된 운영체제의 스케줄링 정책에 의해 각 작업들을 할당받아 수행한다(S960).
Thereafter, the first processor 110 allocates each task according to the scheduling policy of the operating system that has been booted (S960).

상기 제2프로세서(120)는 상기 제1프로세서(110)의 (S940)과정을 통한 인터럽트를 근거로 하여 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체한다(S970).
In step S970, the second processor 120 replaces the currently running program with a program running on the operating system based on the interrupt through the first processor 110 (S940).

이후, 프로그램이 종료되면(S980), 상기 제2프로세서(120)는 제1프로세서(110)와 마찬가지로 운영체제의 스케줄링 정책에 의해 각 작업들을 할당받아 수행한다(S990).
Thereafter, when the program is terminated (S980), the second processor 120 allocates each task according to the scheduling policy of the operating system in the same manner as the first processor 110 (S990).

도 10은 본 발명의 실시 방법에 따른 일실시예도 이다.
10 is an embodiment according to an embodiment of the present invention.

도면 10에 따르면, 본 발명에 따른 프로그램 운영 장치(100)가 자동차에 구비되는 텔레메틱스 장치인 경우를 사례로 설정한 것이다.
Referring to FIG. 10, the case where the program operating device 100 according to the present invention is a telematics device provided in an automobile is set as an example.

우선, A운전자가 자동차에 시동을 끄기 전, 마지막으로 이용하는 프로그램이 후방 상황을 보여주는 후방 카메라이나, 시동을 다시 걸 때, 현재 텔레메틱스 장치는 부팅과정을 마치는데 15초 이상이 소요되기 때문에, A운전자는 적어도 15초 이상을 기다려야 후방 카메라를 실행시킨 후 후방 상황을 파악하고, 운전을 할 수가 있었다.
First, since the last camera, which is used for the last time before the driver turns off the vehicle, shows a rear view of the vehicle or when the vehicle is restarted, the current telematics device takes more than 15 seconds to complete the booting process. The driver had to wait at least 15 seconds or more for the rear camera to recognize the rear position and to drive.

그러나, 본 발명을 텔레메틱스 장치에 적용한다면, A운전자가 후방 카메라를 사용하기 위해 15초 이상 기다려야 하는 문제를 해결할 수 있다.
However, if the present invention is applied to a telematics device, it is possible to solve the problem that the driver A has to wait more than 15 seconds to use the rear camera.

제1프로세서(110)가 시동 걸기 직전 시동을 끌 때 운전자가 최종 이용한 프로그램 정보를 확인하여 제2프로세서(120)가 실행할 프로그램을 확정하고, 부팅을 담당하는 동안, 제2프로세서(120)가 부팅 과정 중 상기 시동 끄기 직전 운전자가 이용한 후방 카메라 프로그램을 담당하게 함으로써, A운전자가 자동차에 시동을 걸면, 부팅을 담당하는 제1프로세서(110)는 부팅을 진행하고, 후방 카메라를 담당하는 제2프로세서(120)는 후방카메라 프로그램을 준비한 뒤에 곧 디스플레이에 후방 상황을 보여줄 수 있어, A운전자는 텔레메틱스 장치의 완전한 부팅을 기다릴 필요 없이 바로 운전을 할 수 있게 되는 것이다.
When the first processor 110 turns off the start immediately before start-up, the driver confirms the program information finally used and confirms the program to be executed by the second processor 120. While the boot processor is in charge of the second processor 120, The first processor 110, which is responsible for booting, proceeds to boot up the A-driver, and the second processor 110, which is responsible for the rear camera, The driver 120 can display the rear situation on the display immediately after preparing the rear camera program so that the driver A can start driving without having to wait for the complete booting of the telematics device.

그리고, 주행 중에는 후방카메라를 거의 사용하지 않기 때문에, 후방카메라를 담당하던 제2프로세서(120)는 스케줄러에게 반환되어 텔레메틱스 장치의 다른 기능들을 수행함으로써 텔레메틱스 장치의 여러 작업들을 효율적으로 처리할 수 있게 된다.
Since the rear camera is rarely used during driving, the second processor 120 responsible for the rear camera is returned to the scheduler to perform other functions of the telematics device, thereby efficiently processing various tasks of the telematics device .

100 : 프로그램 운영 장치 110 : 제1프로세서
120 : 제2프로세서 130 : 비휘발성 메모리
140 : 메인 메모리 150 : 저장부
11 : 부트 모니터 12 : 분기처리 부트로더
13 : 커널 부트로더 21 : 부트 모니터
220 : 프로그램 부트로더
100: program operating device 110: first processor
120: second processor 130: nonvolatile memory
140: main memory 150: storage unit
11: Boot monitor 12: Branch processing boot loader
13: Kernel Boot Loader 21: Boot Monitor
220: Program boot loader

Claims (14)

두 개 이상의 프로세서를 구비하는 프로그램 운영 장치에 있어서,
전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리 상에 기록하는 저장부;
전원 입력시, 제2프로세서를 구동하기 위한 멀티프로세서 분기처리 부트로더(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더를 실행하되, 상기 메모리 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 제1프로세서; 및
상기 제1프로세서의 분기처리 부트로더를 통해 구동된 후, 프로그램 부트로더를 실행하여, 상기 프로그램 부트로더를 통해 상기 제1프로세서를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-이전 전원 오프시 사용자가 최종 이용한 프로그램-이 실행되도록 처리하는 제2프로세서;를 구비하되,
운영체제 부팅 과정이 완료되면, 상기 제1프로세서는, 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하고, 상기 제2프로세서로 인터럽트를 걸어 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 프로그램 운영 장치.
A program operating device having two or more processors,
A storage unit for recording the last used program information of the user on the memory after the power is turned off;
A multiprocessor branch processing boot loader for booting the second processor and a kernel boot loader for booting the operating system when the power is input, A first processor for loading the program boot loader corresponding to the verified program information into the memory via the branch processing boot loader after confirming the information; And
A program boot loader that is run through a branch processing boot loader of the first processor and executes a program boot loader to execute a program without an operating system before booting the operating system via the first processor via the program boot loader; And a second processor for processing the used program to be executed,
When the operating system booting process is completed, the first processor performs the same function as the program currently being executed through the second processor, but loads a program operating on the operating system into the memory, and interrupts the execution of the second processor The program being processed by the program running on the operating system.
제 1항에 있어서, 상기 제1프로세서는,
상기 메모리 상에 기록된 이전 전원 오프시 사용자가 최종 이용한 프로그램 정보를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재시, 이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하고, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더를 통해 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하며, 기 설정된 시간을 초과하는 경우, 사용자가 설정하거나, 또는 제1프로세서 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는,
프로그램 운영 장치.
2. The apparatus of claim 1,
When the program boot loader corresponding to the verified program information is loaded into the memory via the branch processing boot loader after confirming the program information last used by the user when the previous power is written on the memory, The program boot loader corresponding to the program information finally used by the user when the power is turned off through the branch processing boot loader is loaded into the memory, and if the time is less than the predetermined time, A program boot loader corresponding to the second program set on the first processor, which is set by the user or is capable of including the program last used by the user when the power is turned off,
Program operating device.
제 1항에 있어서, 상기 분기처리 부트로더는,
상기 제1프로세서가 실행할 커널 부트로더를 특정 메모리 주소에 적재시키고, 상기 제2프로세서가 실행할 프로그램 부트로더를 상기 커널 부트로더와 다른 메모리 주소에 적재시킨 후, 상기 프로그램 부트로더가 메모리 상에 적재되면, 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소정보를 제공하는,
프로그램 운영 장치.
2. The boot loader according to claim 1,
Loading the kernel boot loader to be executed by the first processor at a specific memory address, loading the program boot loader to be executed by the second processor at a memory address different from that of the kernel boot loader, and if the program boot loader is loaded on the memory , Providing an address to which the program boot loader is located while interrupting the second processor,
Program operating device.
제 1항에 있어서, 상기 프로그램 부트로더는,
실행 대상 프로그램 코드들을 메모리에 적재하되,
상기 프로그램 코드들은,
운영체제 없이 실행되는 Stand-alone 프로그램인 것을 특징으로 하는,
프로그램 운영 장치.
The program boot loader according to claim 1,
The program codes to be executed are loaded into the memory,
The program codes,
Wherein the program is a stand-alone program executed without an operating system.
Program operating device.
제 1항 또는 제 4항에 있어서, 상기 운영체제 없이 실행되는 프로그램은,
실행에 요구되는 자원들을 직접 초기화하고, 직접 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는,
프로그램 운영 장치.
The method according to claim 1 or 4, wherein the program executed without the operating system includes:
The method comprising: directly initializing resources required for execution; and displaying resources that have been directly initialized, thereby preventing the resources from being redundantly initialized in a booting process in the first processor,
Program operating device.
제 1항에 있어서, 상기 제1프로세서는,
커널 초기화 과정에서 초기화할 자원들이 상기 제2프로세서에 의해 초기화되었는지 확인한 후, 확인결과, 초기화되지 않은 경우, 상기 자원들을 직접 초기화하고, 초기화 된 경우, 상기 초기화된 자원들의 초기화를 건너뛰는,
프로그램 운영 장치.
2. The apparatus of claim 1,
The method of claim 1, further comprising: determining whether resources to be initialized in the kernel initialization process are initialized by the second processor, and if the initialized resources are not initialized, directly initializing the resources,
Program operating device.
삭제delete 제 1항에 있어서, 상기 제1프로세서는,
운영체제 부팅을 처리하는 부트 프로세서인 것을 특징으로 하는,
프로그램 운영 장치.
2. The apparatus of claim 1,
And a boot processor for processing an operating system boot,
Program operating device.
제 1항에 있어서, 상기 제1프로세서 및 제2프로세서는,
씨피유(CPU) 또는 코어(Core)인 것을 특징으로 하는,
프로그램 운영 장치.
2. The apparatus of claim 1, wherein the first processor and the second processor are configured to:
(CPU) or a core.
Program operating device.
두 개 이상의 프로세서를 구비하는 프로그램 운영 장치에서의 프로그램 운영 방법에 있어서,
전원 오프 후, 사용자의 최종 이용 프로그램 정보를 메모리 상에 기록하는 정보 기록단계;
전원 입력시, 제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계;
상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 이전 전원 오프시 최종 이용 프로그램 정보를 확인한 후, 상기 확인한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계;
상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계;
상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하는 프로그램 실행단계; 및
상기 프로그램 실행 후, 실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 중복 초기화 방지단계;를 포함하는 프로그램 운영 방법.
A method of operating a program in a program operating device having two or more processors,
An information recording step of recording end-use program information of a user on a memory after power-off;
A branch processing boot loader execution step of executing a branch processing boot loader for driving the second processor in the first processor when the power is inputted;
The program boot loader to be executed by the second processor in the branch processing boot loader is loaded at a memory address, and after the last power-off program information recorded on the memory is confirmed through the information recording step, A program that loads the program's boot loader into memory;
A second processor interruption step of, when the program boot loader is loaded, the first processor interrupting the second processor and transferring the address where the program boot loader is located to the second processor;
A program executing step of loading program codes executed in the second processor without an operating system through the program boot loader into a memory and executing the program; And
And a redundant initialization prevention step of initializing resources required for execution after the execution of the program and displaying initialized resources to prevent the resources from being redundantly initialized in the booting process in the first processor.
제 10항에 있어서, 상기 프로그램 부트로더 적재단계는,
이전 전원 오프에서 현재 전원 입력까지 소요된 시간이 기 설정한 시간 이내인지 확인하는 단계를 더 포함하며,
확인결과, 기 설정된 시간 이내인 경우, 상기 분기처리 부트로더를 통해 전원 오프시 사용자가 최종 이용한 프로그램 정보에 대응하는 프로그램 부트로더를 메모리에 적재하며, 기 설정된 시간을 초과하는 경우, 사용자가 설정하거나, 또는 제1프로세서 상에 기 설정된 제2의 프로그램-상기 전원 오프시 사용자가 최종 이용한 프로그램 포함 가능- 정보에 대응하는 프로그램 부트로더를 메모리에 적재하는 것을 특징으로 하는,
프로그램 운영 방법.
11. The method of claim 10, wherein the loading of the program boot loader comprises:
Further comprising the step of confirming whether the time from the previous power-off to the current power-input is within a predetermined time,
If it is determined within the predetermined time, the program loader corresponding to the program information finally used by the user is loaded into the memory when the power is turned off through the branch processing boot loader. If the program loader exceeds the preset time, , Or a second program preset on the first processor, the program boot loader corresponding to the information that the user last used the program upon power-off, into the memory.
How to operate the program.
삭제delete 제 10항에 있어서,
운영체제 부팅 과정이 완료되면, 상기 제1프로세서에서 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하는 단계;
상기 제1프로세서에서 상기 제2프로세서로 인터럽트를 걸어 상기 프로그램 실행단계를 통해 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 단계;를 더 포함하는,
프로그램 운영 방법.
11. The method of claim 10,
Loading a program running on the operating system into the memory while performing the same function as the program currently being executed through the second processor in the first processor when the operating system booting process is completed;
Further comprising: interrupting the second processor from the first processor, and processing the currently running program to be replaced with a program running on the operating system through the execution of the program.
How to operate the program.
제 10항 내지 제 11항 및 제 13항 중 어느 한 항의 방법을 실행하기 위한 프로그램을 기록한 것을 특징으로 하는 컴퓨터로 판독 가능한 기록매체.
A computer-readable recording medium having recorded thereon a program for executing the method according to any one of claims 10 to 11 and 13.
KR1020120019407A 2012-02-26 2012-02-26 Recording Medium, Method and Device For Program Operation KR101944270B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020120019407A KR101944270B1 (en) 2012-02-26 2012-02-26 Recording Medium, Method and Device For Program Operation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020120019407A KR101944270B1 (en) 2012-02-26 2012-02-26 Recording Medium, Method and Device For Program Operation

Publications (2)

Publication Number Publication Date
KR20130097827A KR20130097827A (en) 2013-09-04
KR101944270B1 true KR101944270B1 (en) 2019-04-17

Family

ID=49449963

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020120019407A KR101944270B1 (en) 2012-02-26 2012-02-26 Recording Medium, Method and Device For Program Operation

Country Status (1)

Country Link
KR (1) KR101944270B1 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2002525745A (en) * 1998-09-24 2002-08-13 フィーニックス テクノロジーズ リミテッド Using Other Processors During the BIOS Boot Sequence to Minimize Boot Time
US20110023026A1 (en) * 2009-07-24 2011-01-27 Dhairesh Oza Pattern-based operating systems

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101118111B1 (en) * 2005-07-08 2012-03-12 엘지전자 주식회사 Mobile communication terminal and booting method thereof
KR100763198B1 (en) * 2006-02-06 2007-10-04 삼성전자주식회사 Boot Device and Method of Embedded System

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2002525745A (en) * 1998-09-24 2002-08-13 フィーニックス テクノロジーズ リミテッド Using Other Processors During the BIOS Boot Sequence to Minimize Boot Time
US20110023026A1 (en) * 2009-07-24 2011-01-27 Dhairesh Oza Pattern-based operating systems

Also Published As

Publication number Publication date
KR20130097827A (en) 2013-09-04

Similar Documents

Publication Publication Date Title
CN102207881B (en) Quick operation system start-up method based on Android
US9189248B2 (en) Specialized boot path for speeding up resume from sleep state
USRE40092E1 (en) Method for quickly booting a computer system
US7584374B2 (en) Driver/variable cache and batch reading system and method for fast resume
KR101780052B1 (en) Method for switching the operating system in information processing system
US8312256B2 (en) Display of a basic input/output system (BIOS) productivity display
US10007552B2 (en) System and method for dual OS memory switching
CN109408122B (en) Equipment starting method, electronic equipment and computer storage medium
KR20130026739A (en) Partial rebooting recovery apparatus and method
KR101863250B1 (en) Recording Medium, Method and Device For Program Execution
US7793127B2 (en) Processor state restoration and method for resume
KR20130068630A (en) Method for initializing embedded device and apparatus thereof
KR101212273B1 (en) Apparatus and method for fast booting based on virtualization technique
CN103927196A (en) Apparatus And Method For Booting
KR101984558B1 (en) Recording Medium, Method and Device For Program Operation
US20120311312A1 (en) Fast Boot Via State Recreation
KR101984564B1 (en) Recording Medium, Method and Device For Program Operation
KR100994723B1 (en) Optional Suspension Reset Method and Recording Media for Shortening Initial Run Time in System
KR101944270B1 (en) Recording Medium, Method and Device For Program Operation
KR101984568B1 (en) Recording Medium, Method and Device For Program Operation
CN116028129B (en) UEFI (unified extensible firmware interface) quick starting method based on Feiteng platform and Feiteng platform
JP2006099704A (en) Information processor and startup control method
KR101869425B1 (en) Recording Medium, Method and Device For Program Operation
US9207747B2 (en) Method and device for advanced configuration and power interface (ACPI) sleep-state support using CPU-only reset
JP2010079572A (en) Information processor, external memory and control method

Legal Events

Date Code Title Description
PA0109 Patent application

Patent event code: PA01091R01D

Comment text: Patent Application

Patent event date: 20120226

PG1501 Laying open of application
PA0201 Request for examination

Patent event code: PA02012R01D

Patent event date: 20170131

Comment text: Request for Examination of Application

Patent event code: PA02011R01I

Patent event date: 20120226

Comment text: Patent Application

E902 Notification of reason for refusal
PE0902 Notice of grounds for rejection

Comment text: Notification of reason for refusal

Patent event date: 20180719

Patent event code: PE09021S01D

E701 Decision to grant or registration of patent right
PE0701 Decision of registration

Patent event code: PE07011S01D

Comment text: Decision to Grant Registration

Patent event date: 20190120

PR0701 Registration of establishment

Comment text: Registration of Establishment

Patent event date: 20190125

Patent event code: PR07011E01D

PR1002 Payment of registration fee

Payment date: 20190125

End annual number: 3

Start annual number: 1

PG1601 Publication of registration
PR1001 Payment of annual fee

Payment date: 20220104

Start annual number: 4

End annual number: 4

PC1903 Unpaid annual fee

Termination category: Default of registration fee

Termination date: 20231105