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

Recording Medium, Method and Device For Program Operation Download PDF

Info

Publication number
KR101984564B1
KR101984564B1 KR1020180032701A KR20180032701A KR101984564B1 KR 101984564 B1 KR101984564 B1 KR 101984564B1 KR 1020180032701 A KR1020180032701 A KR 1020180032701A KR 20180032701 A KR20180032701 A KR 20180032701A KR 101984564 B1 KR101984564 B1 KR 101984564B1
Authority
KR
South Korea
Prior art keywords
program
processor
boot loader
memory
operating system
Prior art date
Application number
KR1020180032701A
Other languages
Korean (ko)
Other versions
KR20180034354A (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 KR1020180032701A priority Critical patent/KR101984564B1/en
Publication of KR20180034354A publication Critical patent/KR20180034354A/en
Application granted granted Critical
Publication of KR101984564B1 publication Critical patent/KR101984564B1/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/4406Loading of operating system
    • 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

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. The apparatus for operating a program according to the present invention comprises: an analysis unit for analyzing a user's initial program use pattern after power input; A storage unit configured to determine a type of a program first used by a user after power input, and to record the determined program type information on a memory; and a multiprocessor branch processing boot loader for driving a second processor when the power is input. And a kernel boot loader for booting the operating system, and after confirming the type of the program used by the user recorded in the memory for the first time after power-up, the branched boot loader corresponds to the checked program type. A first processor for loading a program boot loader into a memory; After running through the branch processing boot loader, the program boot loader is executed, and the program boot loader is executed without the operating system before booting the operating system through the first processor. And a second processor for processing a program corresponding to the type to be executed.

Description

프로그램 운영 방법 및 장치와 이를 위한 기록매체{Recording Medium, Method and Device For Program Operation}Method and apparatus for program operation and recording medium therefor {Recording Medium, Method and Device For Program Operation}

본 발명은 2개 이상의 프로세서가 구비된 프로그램 운영 장치에서 최초 프로그램 실행 전 운영체제 부팅과정에 따른 사용자 대기시간을 크게 줄일 수 있도록 하며, 운영체제 부팅 전 실행 프로그램을 전원 입력 후 사용자의 최초 프로그램 이용 패턴을 통해 결정토록 하는 것이다.The present invention can greatly reduce the user waiting time according to the operating system booting process before the first program execution in the program operating device equipped with two or more processors, and through the user's initial program use pattern after the power input to run the program before booting the operating system It is to decide.

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

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

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

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

부트모니터는 먼저 현재 자신을 실행하는 프로세서가 첫 번째 프로세서(CPU0)인지 아닌지를 알아내는 작업을 수행하고, 현재 프로세서가 첫 번째 프로세서라면 부트모니터는 메인 코드를 실행하고, 나머지 프로세서(CPUx)라면 WFI(wait for interrupt)를 수행하며 첫 번째 프로세서가 나머지 프로세서들을 초기화해서 사용될 수 있을 때까지 기다리게 한다. 이 때 부팅을 담당하게 되는 첫 번째 프로세서를 부트 프로세서(boot processor)라고 한다. 이와 같은 방법으로 부팅 초반에 멀티 프로세서에서도 CPU가 하나인 것처럼 부팅을 진행할 수 있게 된다. WFI를 수행하는 다른 프로세서들은 무한루프(infinite loop)을 돌면서 계속 SYS_FLAGS 레지스터에 변화가 있는지 체크하고, 부트 프로세서에 의해 레지스터 값이 바뀌면, 레지스터에 저장된 주소로 점프를 한다.The bootmonitor first performs a task of determining whether the processor currently running itself is the first processor (CPU0), if the current processor is the first processor, the bootmonitor executes the main code, and if the remaining processors (CPUx) are WFI (wait for interrupt) and wait for the first processor to initialize and use the remaining processors. The first processor responsible for booting at this time is called a boot processor. In this way, you can boot as if you had a single CPU on a multiprocessor early in the boot. Other processors running WFI continue to loop through the infinite loop to check for changes in 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 of nonvolatile memory (sector 0 of nonvolatile memory). The boot code stored in the MBR is correct and the magic code exists in the last 2 bytes of the MBR sector. Can be checked with The boot monitor reads the MBR to check the magic code, and when it is confirmed that it is a boot loader, it jumps to the start address of the boot loader and leaves the boot process to boot.

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

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

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

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

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

또한, 도면 3에서 보는바와 같이, 프로세서가 두 개 이상인 멀티 프로세서를 구비한 프로그램 운영 장치에서도 프로세서(1)에서 운영체제 부팅을 처리하는 시간동안 프로세서(2)는 유효 상태로 대기중인 바, 사용자 대기시간의 단축은 멀티 프로세서 체제에서도 마찬가지의 사용자 불편함을 지니고 있다.In addition, as shown in FIG. 3, even in a program operating apparatus including a multiprocessor having two or more processors, the processor 2 waits for a valid state during processing of booting an operating system by the processor 1, and thus a user waiting time. The shortening has the same user inconvenience in a multiprocessor system.

예를들어, 운전자가 자동차에 시동을 걸었을 때, 자동차에 구비된 프로그램 운영 장치에서 제공해줘야 할 가장 우선적인 서비스는 운전자에게 후방 상황을 보여주는 것이나, 현재 자동차에 구비된 프로그램 운영 장치는 운영체제 부팅과정을 마치는데 15초 이상이 소요되기 때문에, 운전자는 적어도 15초 이상을 기다려야 후방 상황을 파악하고, 운전을 할 수가 있다.For example, when the driver starts the car, the first service to be provided by the program operating device of the vehicle is to show the driver the rear situation, but the current operating program of the vehicle is the operating system boot process. Because it takes more than 15 seconds to finish, the driver must wait at least 15 seconds to understand the situation behind and drive.

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

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

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

그러나, Suspend & resume 방식의 단점은 기존 커널의 부팅이 거의 완료된 후에 이미지를 찾아 복원을 시작하기 때문에 일반적인 부팅과 비교하여 부팅시간 단축을 기대하기 힘들며, 종료할 때마다 이전 상태를 비휘발성 매체에 저장해야 하기 때문에 종료시간이 길어지는 문제점이 있고, 하이버네이션 이미지가 저장되기 전에 전원이 끊기는 경우 resume하지 못하고, 일반적인 부팅과정을 거쳐야 하는 문제점이 있다.However, the disadvantage of the Suspend & resume method is that it is difficult to expect the boot time to be shortened compared to the normal boot because the existing kernel almost completes booting and restores the image, and saves the previous state on nonvolatile media at every shutdown. There is a problem that the end time is long because it has to be done, and if the power is cut off before the hibernation image is stored, there is a problem that the general booting process cannot be resumed.

Snapshot 기술은 suspend & resume의 단점을 보완한 기술로 부트로더 레벨에서 하이버네이션 복원을 수행하여 기존 suspend & resume이 커널 부팅이 거의 완료된 상태에서 복원하는 것보다 빠른 시점에 복원을 시작함으로써 부팅시간을 단축하는 것이다. Snapshot technology compensates for the shortcomings of suspend & resume, which performs hibernation restoration at the bootloader level, which reduces boot time by initiating a restore earlier than when suspend & resume restores from a nearly complete kernel boot. will be.

Suspend & resume 방식처럼 시스템을 종료할 때만 하이버네이션 이미지를 생성하는 것이 아니라 정상적인 부팅 완료 후에 특정 시점의 하이버네이션 이미지를 생성하여 항상 같은 하이버네이션 이미지로 복원하는 것도 가능하다.In addition to creating a hibernation image only when the system is shut down, such as suspend & resume, it is also possible to create a hibernation image at a specific point in time after normal booting and restore the same hibernation image.

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

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

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

그러나, 현재까지 개발된 비휘발성 메모리는 메인 메모리로 사용되는 DRAM과 비교하여 읽기/쓰기 속도가 떨어지기 때문에 부팅 과정에서 XIP를 사용하지 않았을 때보다 더 빠르게 부팅하였을지라도, 이후에 커널이 계속 사용될 때 시스템 성능은 메인 메모리에 적재된 커널과 비교하여 떨어지는 성능을 보인다는 문제점이 있다. However, non-volatile memory developed to date has a lower read / write speed compared to DRAM used as main memory, so even if the kernel is continuously used even after booting faster than without using XIP during the booting process. There is a problem that the system performance is lower than the kernel loaded in the main memory.

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

콘솔 비활성화(Disable console)방식은 콘솔로 출력되는 메시지를 사용하지 않음으로써 시간을 절약하는 방법으로서, 일반적으로 리눅스에서 부팅시에 quiet 옵션을 두면 콘솔 메시지를 출력하지 않는데, 이는 콘솔 상에 부팅 메시지를 출력하고 스크롤링하는 시간을 줄일 수 있다.Disable console is a way to save time by not using the messages printed to the console. In general, setting the quiet option at boot time on Linux does not print console messages. You can save time printing and scrolling.

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

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

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

결론적으로, 프로그램이 실행되어 사용자에게 서비스할 수 있는 시점까지 소요되는 시간을 사용자 대기시간이라고 할 때, 운영체제 부팅시간을 단축시키는 것이 사용자 대기시간을 단축시키는 것을 의미하기 때문에 기존 부팅 속도 개선 기술들의 대부분은 운영체제 부팅 시간 단축에 초점을 맞춰서 연구되어 왔다.In conclusion, when the time it takes for a program to run and service a user is called user latency, most of the existing boot speed improvement techniques mean that reducing the operating system boot time means reducing the user latency. Has been focused on reducing operating system boot times.

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

또한, 사용자 대기시간이 단축되더라도 사용자가 전원 입력 후 최초 이용하는 프로그램의 종류는 사용자마다 제각기 다 틀리기 때문에 사용자 대기시간을 줄여도 사용자별 최초 이용하고자 하는 프로그램이 획일적으로 정해져 있다면, 사용자는 운영체제 부팅 완료 후 본인이 원하는 프로그램을 다시 선택해서 실행해야 하는 불편함이 있다. In addition, even if the user's waiting time is shortened, the type of the program used by the user for the first time after the power input is different for each user. Therefore, even if the user's waiting time is uniformly determined, the user must complete the operating system after completing the booting of the operating system. The inconvenience is that you have to select and run this program again.

상기한 종래 기술의 문제점 및 과제에 대한 인식은 본 발명의 기술 분야에서 통상의 지식을 가진 자에게 자명한 것이 아니므로 이러한 인식을 기반으로 선행기술들과 대비한 본 발명의 진보성을 판단하여서는 아니 됨을 밝혀둔다.Recognition of the problems and problems of the prior art described above is not obvious to those of ordinary skill in the art of the present invention and should not judge the progress of the present invention compared to the prior art based on such recognition. Reveal it.

상기와 같은 문제점을 해소하기 위한 본 발명의 목적은, 기존 멀티 프로세서 부팅 방법에서의 문제점이 부트 프로세서를 제외한 다른 프로세서들이 부팅 과정에서 대부분의 시간을 유휴상태로 보내는 것인 바, 부팅 과정에 유휴상태에 있는 다른 프로세서들을 활용하여 부팅이 모두 완료되기 전에 사용자가 우선적으로 필요로 하는 프로그램을 실행시키되, 사용자가 우선적으로 필요로 하는 프로그램의 종류를 사용자의 최초 프로그램 이용 패턴 분석결과를 토대로 설정함으로써, 사용자 대기시간을 혁신적으로 줄일 수 있도록 하는 동시에 사용자별 맞춤형 최초 실행 프로그램을 설정토록 하는 장치와 방법, 프로그램 기록매체를 제공함에 있다.An object of the present invention for solving the above problems is that the problem in the conventional multi-processor booting method is that other processors except the boot processor spend most of the time idle in the booting process. By using other processors in the system, the user first executes the program before the booting is completed, and sets the type of the program that the user needs first based on the analysis result of the user's initial program usage pattern. In addition to providing innovative ways to reduce latency, we also provide a device, method, and program record medium that allow users to set up their own custom launch programs.

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

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

본 발명에서 이루고자 하는 기술적 과제들은 이상에서 언급한 기술적 과제로 제한되지 않으며, 언급하지 않은 또 다른 기술적 과제들은 아래의 기재로부터 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에게 명확하게 이해될 수 있을 것이다.Technical problems to be achieved in the present invention are not limited to the technical problems mentioned above, and other technical problems not mentioned above may be clearly understood by those skilled in the art from the following description. There will be.

본 발명에 따른 두 개 이상의 프로세서를 구비하는 프로그램 운영 장치는, 전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 분석부와, 상기 분석부의 분석결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 저장부와, 전원 입력시, 제2프로세서를 구동하기 위한 멀티프로세서 분기처리 부트로더(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더를 실행하되, 상기 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 제1프로세서와, 상기 제1프로세서의 상기 분기처리 부트로더를 통해 구동된 후, 프로그램 부트로더를 실행하여, 상기 프로그램 부트로더를 통해 상기 제1프로세서를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류에 대응하는 프로그램-이 실행되도록 처리하는 제2프로세서를 구비하되, 상기 분기처리 부트로더는 상기 제1프로세서가 실행할 상기 커널 부트로더를 특정 메모리 주소에 적재시키고, 상기 제2프로세서가 실행할 상기 프로그램 부트로더를 상기 커널 부트로더와 다른 메모리 주소에 적재시킨 후, 상기 프로그램 부트로더가 메모리 상에 적재되면, 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소정보를 제공한다.A program operating apparatus including two or more processors according to the present invention includes an analysis unit for analyzing a user's initial program use pattern after power input and a program used by a user for the first time after power input in response to an analysis result of the analysis unit. A storage unit for determining the type of the program, and recording the determined program type information in the memory, a multiprocessor branch processing bootloader for driving the second processor when the power is input, and a kernel for booting the operating system. After the boot loader is executed, the user recorded in the memory checks the type of the program to be used for the first time after the power is input, and then loads the program boot loader corresponding to the checked program type into the memory through the branch processing boot loader. A first processor and the branch boot loader of the first processor. After that, a program boot loader is executed to execute a program that is executed without an operating system before booting an operating system through the first processor through a program boot loader, such that a program corresponding to the type of a program that a user first uses after power-on is executed. And a second processor for processing, wherein the branch processing boot loader loads the kernel boot loader to be executed by the first processor at a specific memory address, and replaces the program boot loader to be executed by the second processor with the kernel boot loader. After the program boot loader is loaded on the memory, the program boot loader interrupts the second processor and provides the address information where the program boot loader is located.

일측에 따르면, 상기 분석부는, 일정 기간 사용자가 전원 입력 후 최초 이용하는 프로그램별 이용 횟수를 카운팅하고, 카운팅 결과를 이용하여, 이용 횟수별 내림차순으로 프로그램 목록을 생성하며, 상기 저장부는, 상기 이용 횟수별 내림차순으로 정렬된 프로그램 목록을 근거로 하여, 최상위 프로그램을 사용자가 전원 입력 후 최초 이용하는 프로그램으로 확정할 수 있다.According to one side, the analysis unit, the user counts the number of times of use of the program first used after power input for a period, using the counting result, generates a list of programs in descending order by the number of use, the storage unit, by the number of use Based on the list of programs sorted in descending order, the top-level program can be determined as the first program used by the user after power-up.

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

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

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

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

본 발명에 따른 두 개 이상의 프로세서를 구비하는 프로그램 운영 방법은, 전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 패턴 분석단계와, 상기 패턴 분석 결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 정보 기록단계와, 제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계와, 상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계와, 상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계와, 상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하는 프로그램 실행단계와, 운영체제 부팅 과정이 완료되면, 상기 제1프로세서에서 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하는 단계와, 상기 제1프로세서에서 상기 제2프로세서로 인터럽트를 걸어 상기 프로그램 실행단계를 통해 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 단계를 포함한다.A program operating method including two or more processors according to the present invention includes a pattern analysis step of analyzing a user's first program use pattern after power input and a program first used by a user after power input in response to the pattern analysis result. An information recording step of confirming the type of the program, and recording the determined program type information on the memory; and executing the branching boot loader for executing a branching boot loader for driving the second processor from the first processor. And loading the program boot loader to be executed by the second processor in the branched boot loader at a memory address, and after confirming the type of the program used by the user recorded in the memory for the first time after the power is input through the information recording step, Write the program boot loader that corresponds to the identified program type into memory. A program boot loader loading step, and when the program boot loader is loaded, the first processor interrupts the second processor and delivers the address where the program boot loader is located to the second processor. And a program executing step of executing a program after loading program codes to be executed without an operating system through the program boot loader in the memory in the second processor, and executing the operating program. Loading a program that executes the same function as a previously executed program through a processor but operates on an operating system into a memory, interrupts the program from the first processor to the second processor, and executes the previously executed program through the program execution step. Program that runs on top of operating system And a step of processing to replace the program.

일측에 따르면, 상기 프로그램 실행단계는, 실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 단계를 더 포함할 수 있다.According to one side, the program execution step, may further include the step of initializing the resources required for execution, by displaying the initialized resources, to prevent the resources are repeatedly initialized during the booting process in the first processor. .

본 발명에 따른 두 개 이상의 프로세서를 구비하는 프로그램 운영 방법은, 전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 패턴 분석단계와, 상기 패턴 분석 결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 정보 기록단계와, 제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계와, 상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계와, 상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계와, 상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하되, 실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서의 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 프로그램 실행단계를 포함한다.A program operating method including two or more processors according to the present invention includes a pattern analysis step of analyzing a user's first program use pattern after power input and a program first used by a user after power input in response to the pattern analysis result. An information recording step of confirming the type of the program, and recording the determined program type information on the memory; and executing the branching boot loader for executing a branching boot loader for driving the second processor from the first processor. And loading the program boot loader to be executed by the second processor in the branched boot loader at a memory address, and after confirming the type of the program used by the user recorded in the memory for the first time after the power is input through the information recording step, Write the program boot loader that corresponds to the identified program type into memory. A program boot loader loading step, and when the program boot loader is loaded, the first processor interrupts the second processor and delivers the address where the program boot loader is located to the second processor. And loading program codes executed without an operating system into a memory through the program boot loader in the second processor, executing a program, initializing resources required for execution, and displaying the initialized resources. And executing a program to prevent the resources from being repeatedly initialized in the process of booting the processor.

일측에 따르면, 상기 프로그램 운영 방법은, 운영체제 부팅 과정이 완료되면, 상기 제1프로세서에서 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하는 단계와, 상기 제1프로세서에서 상기 제2프로세서로 인터럽트를 걸어 상기 프로그램 실행단계를 통해 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 단계를 더 포함할 수 있다.According to one side, the program operating method, when the operating system booting process is completed, performing the same function as the program already running through the second processor in the first processor, but loading a program operating on the operating system in the memory and The method may further include interrupting the first processor from the first processor to process the previously executed program to be replaced with a program operating on an operating system through the program execution step.

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

본 발명에 따르면, 멀티 프로세서가 구비된 프로그램 운영 장치에서 별도의 하드웨어의 추가 없이 부팅방식 만을 개선하여 사용자가 원하는 프로그램 실행까지의 사용자 대기시간을 혁신적으로 줄일 수 있도록 하는 효과와 운영체제 부팅 완료 후, 각각의 프로세서들이 각각 다른 작업을 수행할 수 있도록 하여, 멀티 프로세서의 병렬성을 최대한 활용할 수 있는 효과를 지니고 있다.According to the present invention, in the program operating device equipped with a multi-processor to improve the boot method only without the addition of additional hardware to the user to innovatively reduce the user waiting time until the desired program execution and after the completion of operating system boot, respectively Each processor can perform different tasks, making the most of the parallelism of multiprocessors.

또한, 본 발명에 따르면, 사용자 대기시간을 줄여도 사용자별 최초 이용하고자 하는 프로그램이 획일적으로 정해져 있다면, 사용자는 운영체제 부팅 완료 후 본인이 원하는 프로그램을 다시 선택해서 실행해야 하는 불편함을 해결하여, 사용자별 맞춤형 최초 이용 프로그램 운영이 가능한 효과를 지니고 있다.(예를 들면, A사용자는 자동차에 탑승 후 시동을 건 후, 주로 후방카메라를 최초 이용하는 경우, 후방 카메라 프로그램을 최초 실행하고, B사용자는 자동차에 탑승 후 시동을 건 후, 주로 네비게이션을 최초 이용하는 경우, 네비게이션 프로그램을 최초 실행함으로서, 사용자별 맞춤형 최초 이용 프로그램 설정 가능) In addition, according to the present invention, even if the user waiting time is reduced uniformly determined by the user for the first time to use the program, the user solves the inconvenience of having to select and run the desired program again after the completion of operating system boot, by user It has the effect of operating a customized first use program (for example, A user starts the car after starting the vehicle and mainly uses the rear camera for the first time. If you use the navigation system for the first time after starting the boarding, you can run the navigation program for the first time, so you can set a customized program for each user.)

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

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

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

본 명세서에 첨부되는 다음의 도면들은 본 발명의 바람직한 실시예를 예시하는 것이며, 전술한 발명의 상세한 설명과 함께 본 발명의 기술사상을 더욱 이해시키는 역할을 하는 것이므로, 본 발명은 그러한 도면에 기재된 사항에만 한정되어 해석되지 않아야 한다.
도 1은 종래 프로그램 운영 장치에서의 운영체제 부팅과정 흐름을 보여주는 흐름도이다.
도 2는 종래 단일 프로세서가 구비된 프로그램 운영 장치에서 운영체제 부팅과정 이후 프로그램 실행에 따른 프로세스를 보여주는 일실시예도이다.
도 3은 종래 멀티 프로세서가 구비된 프로그램 운영 장치에서 운영체제 부팅과정 이후 프로그램 실행에 따른 프로세스를 보여주는 일실시예도이다.
도 4는 본 발명의 실시 방법에 따른 프로그램 운영 장치의 주요 구성을 보여주는 도면이다.
도 5는 본 발명의 실시 방법에 따른 사용자의 최초 프로그램 이용 패턴 분석 프로세스를 보여주는 도면이다.
도 6은 본 발명의 실시 방법에 따른 운영체제 부팅과 프로그램 실행 프로세스를 보여주는 도면이다.
도 7은 종래 기술과 본 발명의 실시 방법에 따른 사용자 대기시간을 대비하여 보여주는 도면이다.
도 8은 본 발명의 실시 방법에 따른 운영체제 부팅 전 프로그램 실행 프로세스를 도시한 도면이다.
도 9는 본 발명의 실시 방법에 따른 운영체제 부팅 후 프로그램 실행 프로세스를 도시한 도면이다.
도 10은 본 발명의 실시 방법에 따른 일실시예도이다.
The following drawings, which are attached to this specification, illustrate preferred embodiments of the present invention, and together with the detailed description of the present invention serve to further understand the technical spirit of the present invention. It should not be construed as limited to.
1 is a flowchart illustrating an operating system booting process flow in a conventional program operating apparatus.
2 is a diagram illustrating a process according to program execution after an operating system booting process in a program operating apparatus equipped with a conventional single processor.
3 is a diagram illustrating a process according to program execution after an OS booting process in a program operating apparatus equipped with a conventional multiprocessor.
4 is a diagram illustrating a main configuration of a program operating apparatus according to an embodiment of the present invention.
5 is a view illustrating a process of analyzing a user's initial program use pattern according to an embodiment of the present invention.
6 is a diagram illustrating an operating system booting and program execution process according to an embodiment of the present invention.
7 is a view showing a user waiting time according to the prior art and the embodiment 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 booting an operating system according to an embodiment of the present invention.
10 is an embodiment diagram according to an embodiment of the present invention.

이하 첨부된 도면과 설명을 참조하여 본 발명의 바람직한 실시예에 대한 동작 원리를 상세히 설명한다. 다만, 하기에 도시되는 도면과 후술되는 설명은 본 발명의 특징을 효과적으로 설명하기 위한 여러 가지 방법 중에서 바람직한 실시 방법에 대한 것이며, 본 발명이 하기의 도면과 설명만으로 한정되는 것은 아니다. 또한, 하기에서 본 발명을 설명함에 있어 관련된 공지 기능 또는 구성에 대한 구체적인 설명이 본 발명의 요지를 불필요하게 흐릴 수 있다고 판단되는 경우에는 그 상세한 설명을 생략할 것이다. 그리고 후술되는 용어들은 본 발명에서의 기능을 고려하여 정의된 용어들로서, 이는 사용자, 운용자의 의도 또는 관례 등에 따라 달라질 수 있다. 그러므로 그 정의는 본 발명에서 전반에 걸친 내용을 토대로 내려져야 할 것이다. Hereinafter, with reference to the accompanying drawings and description will be described in detail the operating principle of the preferred embodiment of the present invention. However, the drawings and the following description shown below are for the preferred method among various methods for effectively explaining the features of the present invention, the present invention is not limited only to the drawings and description below. In addition, in the following description of the present invention, if it is determined that a detailed description of a related known function or configuration may unnecessarily obscure the subject matter of the present invention, the detailed description thereof will be omitted. Terms to be described later are terms defined in consideration of functions in the present invention, which may vary according to intentions or customs of users or operators. Therefore, the definition should be made based on the contents throughout the present invention.

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

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

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

바람직하게, 본 발명에 따른 프로그램 운영 장치(100)의 주요 기능구성은, 도시된 바와 같이, 제1프로세서(110)와 제2프로세서(120)와 비휘발성 메모리(130)와 메인 메모리(140)와, 분석부(150)와, 저장부(160)를 포함하여 구성될 수 있으며, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 더 포함하여 구성될 수 있으며, 프로그램 운영 장치(100)의 종류와 특성에 따라 상기 각 구성부는 추가 또는 제외될 수 있다.Preferably, the main functional configuration of the program operating apparatus 100 according to the present invention, as shown, the first processor 110 and the second processor 120, the nonvolatile memory 130 and the main memory 140 And, it may be configured to include the analysis unit 150, the storage unit 160, the boot monitor (11, 21), branch processing boot loader 12, kernel boot loader 13, program boot loader It may be configured to further include (22), each of the components may be added or excluded according to 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)에 포함되어 구성될 수도 있으며, 별개의 구성으로 이루어질 수도 있으며, 그 일부는 생략도 가능하다.In addition, the boot monitors 11 and 21, the branched boot loader 12, the kernel boot loader 13, and the program boot loader 22 in the drawing may include a first processor 110 and a second processor 120. Although shown as included in the boot monitor 11 and 21, the branch boot loader 12, the kernel boot loader 13, and the program boot loader 22 may include a nonvolatile memory 130 and a main memory ( It may be included in the 140, may be configured as a separate configuration, a part thereof may be omitted.

본 발명의 실시방법에 따르면, 상기 분석부(150)는, 전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 역할을 수행한다.According to the exemplary embodiment of the present invention, the analyzer 150 analyzes the user's initial program usage pattern after power input.

즉, 상기 분석부(150)는, 일정 기간 사용자가 전원 입력 후 최초 이용하는 프로그램별 이용 횟수를 카운팅하고, 카운팅 결과를 이용하여, 이용 횟수별 내림차순으로 프로그램 목록을 생성함으로서, 사용자의 최초 프로그램 이용 패턴을 도출한다.That is, the analysis unit 150 counts the number of times of use for each program used by the user for the first time after power input for a predetermined period of time, and generates a list of programs in descending order by the number of times of use by using the counting result, so that the user's initial program use pattern To derive

본 발명의 실시방법에 따르면, 상기 저장부(160)는, 상기 분석부(150)의 분석결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리(130 또는 140) 상에 기록하는 역할을 수행한다.According to an exemplary embodiment of the present invention, the storage unit 160 determines a type of a program that is first used by a user after power input in response to an analysis result of the analysis unit 150, and provides the determined program type information. Write to the memory 130 or 140.

본 발명에 따르면, 상기 저장부(160)는, 상기 분석부(150)가 생성한 이용 횟수별 내림차순으로 정렬된 프로그램 목록을 근거로 하여, 최상위 프로그램을 사용자가 전원 입력 후 최초 이용하는 프로그램으로 확정할 수 있다.According to the invention, the storage unit 160, based on the list of programs sorted in descending order by the number of uses generated by the analysis unit 150, to determine the highest program as the first program used by the user after power input. Can be.

예를 들면, A사용자의 경우, 일정 기간 자동차에 탑승 후 시동을 건 후 최초 사용하는 프로그램의 횟수가 네비게이션 프로그램이 가장 많으면, A사용자의 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 네비게이션 프로그램으로 확정하고, B사용자의 경우, 일정 기간 자동차에 탑승 후 시동을 건 후 최초 사용하는 프로그램의 횟수가 후방카메라 프로그램이 가장 많으면, A사용자의 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 후방 카메라 프로그램으로 확정한다.For example, in the case of user A, if the number of the first programs to be used after the vehicle is started after starting a car for a certain period is the most, the type of the first program to be used after the user A is input is determined as a navigation program. In the case of user B, if the number of the first programs used after the start-up after starting a car for a certain period is the largest number of rear camera programs, the type of the first program used after the user A is input is determined as the rear camera program.

본 발명의 실시방법에 따르면, 상기 제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 exemplary embodiment of the present invention, the first processor 110, upon input of power, a multiprocessor branch processing boot loader 12 for driving the second processor 120 and a kernel for booting an operating system. The boot loader 13 is executed, and after confirming the type of the program used by the user recorded on the memory 130 or 140 for the first time after inputting power, the checked program type through the branch processing boot loader 12 is performed. Loads the program boot loader 22 corresponding to the memory 140 in the memory 140, and the second processor 120 is driven through the branch processing boot loader 12 of the first processor 110. By executing the program boot loader 22, a program that is executed without an operating system before booting the operating system through the first processor 110 through the program boot loader 22 for the first time after power input by a user Program corresponding to the type of the - this serves to processing to be executed.

즉, 상기 프로그램 운영 장치(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 is responsible for booting the operating system, and the second processor 120 executes a stand-alone program that can operate without an operating system, waiting for a user. When the booting is completed by the first processor 110, all the processors including the second processor 120 are controlled by the operating system to perform tasks assigned by the scheduler.

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

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

상기 제1프로세서(110)는, 운영체제 부팅을 처리하는 부트 프로세서인 것을 특징으로 하며, 상기 제1프로세서(110) 및 제2프로세서(120)는, 씨피유(CPU) 또는 코어(Core)인 것을 특징으로 한다.The first processor 110 is characterized in that the boot processor for processing the operating system boot, the first processor 110 and the second processor 120, characterized in that the CPU (Core) or Core (Core) It is done.

본 발명에 따른 비휘발성 메모리(130)는 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류 정보와, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 하나 이상 저장하며, 사용자가 실행하고자 하는 프로그램 코드들을 하나 이상 저장한다.The nonvolatile memory 130 according to the present invention includes type information on a program used first by a user after power input, boot monitors 11 and 21, branched boot loader 12, kernel boot loader 13, One or more program boot loaders 22 are stored, and one or more program codes to be executed by the user are stored.

본 발명에 따른 메인 메모리(140)는 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류 정보와, 부트 모니터(11, 21)와, 분기처리 부트로더(12)와 커널 부트로더(13)와, 프로그램 부트로더(22)를 하나 이상 로딩하여 저장하며, 사용자가 실행하고자 하는 프로그램 코드들을 하나 이상 로딩하여 저장한다.The main memory 140 according to the present invention includes information on the type of a program used by a user for the first time after power input, a boot monitor 11 and 21, a branch processing boot loader 12, a kernel boot loader 13, and a program. One or more boot loaders 22 are loaded and stored, and one or more program codes that the user wants to execute are loaded and stored.

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

본 발명에 따른 제1프로세서(110) 상의 부트 모니터(11)는, 먼저 현재 자신을 실행하는 프로세서가 첫 번째 프로세서인지 아닌지를 알아내는 작업을 수행하고, 현재 프로세서가 첫 번째 프로세서라면 분기처리 부트로더(12)를 실행하는 역할을 수행한다.The boot monitor 11 on the first processor 110 according to the present invention first performs a task of determining whether the processor currently executing itself is the first processor, and if the current processor is the first processor, the branched boot loader. It performs the role of executing (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 through the first processor 110 is performed while performing a wait for interrupt (WFI). Play a role.

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

즉, 상기 분기처리 부트로더(12)는 제1프로세서(110)가 실행할 커널 부트로더(13)(커널이미지를 적재해줄 부트로더)를 특정한 메인 메모리(140) 주소에 적재시키고, 제2프로세서(120)가 실행할 프로그램 부트로더(22)(상기 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램을 적재해줄 부트로더)를 커널 부트로더(13)와는 다른 메모리(140) 주소에 적재시킨 후, 상기 프로그램 부트로더(22)가 적재되면, 상기 제2프로세서(120)로 인터럽트를 걸면서 상기 프로그램 부트로더(22)가 위치한 주소를 제2프로세서(120)로 전달하는 역할을 수행한다.That is, the branch processing boot loader 12 loads the kernel boot loader 13 (the boot loader for loading the kernel image) to be executed by the first processor 110 at a specific main memory 140 address, and the second processor ( 120 loads a program boot loader 22 to be executed (a boot loader that loads a program first used by a user recorded on the memory) in a memory 140 address different from that of the kernel boot loader 13. When the program boot loader 22 is loaded, it interrupts the second processor 120 and delivers the address where the program boot loader 22 is located to the second processor 120.

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

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

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

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

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

본 발명에 따르면, 상기 Stand-alone 프로그램은 직접 초기화한 자원들을 표시하는 역할을 더 수행하여, 상기 제1프로세서(110)가 부팅 과정에서 동일한 자원의 중복 초기화를 방지한다.According to the present invention, the stand-alone program further performs a role of directly initializing resources, so that the first processor 110 prevents duplicate initialization of the same resources 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 branched boot loader 12, the kernel boot loader 13, and the program boot loader 22 may be determined by the first processor. 110 and the second processor 120 may be replaced.

도 5는 본 발명의 실시 방법에 따른 사용자의 최초 프로그램 이용 패턴 분석 프로세스를 보여주는 도면이다.5 is a view illustrating a process of analyzing a user's initial program use pattern according to an embodiment of the present invention.

우선, 프로그램 운영 장치(100)는 분석부(150)를 통해 전원 입력 후 사용자가 최초 이용하는 프로그램 종류를 확인한 후(S510), 확인한 프로그램 종류에 대응하는 프로그램 정보를 메모리(130 또는 140) 상에 저장한다(S520).First, the program operating apparatus 100 checks a program type first used by a user after inputting power through the analyzer 150 (S510), and stores program information corresponding to the checked program type on the memory 130 or 140. (S520).

사용자의 최초 프로그램 이용 패턴을 분석하기 위한 충분한 정보가 누적되기까지 일정 기간이 경과하면(S530), 상기 프로그램 운영 장치(100)는 분석부(150)를 통해 메모리(130 또는 140) 상에 누적되어 저장된 사용자가 전원 입력 후 최초 이용하는 프로그램별 이용 횟수를 카운팅한다(S540).If a predetermined time elapses until sufficient information for analyzing the user's initial program usage pattern is accumulated (S530), the program operating apparatus 100 is accumulated on the memory 130 or 140 through the analyzer 150. The stored user counts the number of times of use of the program for the first time after power input (S540).

만약, 사용자의 최초 프로그램 이용 패턴을 분석하기 위한 충분한 정보가 누적되기까지 일정 기간이 경과하지 않으면, 상기 (S520)과정을 일정 기간 동안 반복한다(S550).If the predetermined period has not elapsed until sufficient information for analyzing the user's initial program use pattern has accumulated, the process (S520) is repeated for a predetermined period (S550).

상기 프로그램 운영 장치(100)는 상기 (S540)과정을 통한 카운팅 결과를 근거로 하여, 이용 횟수별 내림차순으로 프로그램 목록을 생성함으로서, 사용자의 최초 프로그램 이용 패턴을 도출한다(S560).The program operating apparatus 100 derives an initial program use pattern of the user by generating a program list in descending order by the number of times based on the counting result through the process (S540) (S560).

이후, 상기 프로그램 운영 장치(100)는 저장부(160)를 통해 상기 (S560)과정을 통해 도출된 전원 입력 후 사용자가 최초 이용하는 횟수가 가장 많은 프로그램 정보를 메모리 상에 기록함으로써, 운영체제 부팅 전 실행시킬 프로그램 종류를 확정한다(S570). Thereafter, the program operating apparatus 100 executes before booting the operating system by recording program information having the most number of times of first use by the user after inputting power through the storage unit 160 through the storage unit 160 in the memory. The type of program to be confirmed is determined (S570).

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

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

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

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

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

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

도면 7에 따르면, 종래 멀티 프로세서가 구비된 프로그램 운영 장치(100)와 본 발명에 따른 멀티 프로세서가 구비된 프로그램 운영 장치(100) 간 사용자 대기시간이 크게 줄어드는 것을 볼 수 있다.According to FIG. 7, it can be seen that the user waiting time between the program operating apparatus 100 having a conventional multi processor and the program operating apparatus 100 having a 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. (However, a general booting technique of the 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 the branch processing boot loader 12 for driving the second processor 120 (S810).

이후, 상기 제1프로세서(110)는 분기처리 부트로더(12)를 통해 제1프로세서(110)가 실행할 커널 부트로더(13)를 특정한 메인 메모리(140) 주소에 적재시키고, 상기 도면 5의 프로세스를 통해 확정되어 메모리(130 또는 140)에 기록된 사용자의 최초 프로그램 이용 패턴에 대응하는 프로그램 정보를 확인한다(S820).Subsequently, the first processor 110 loads the kernel boot loader 13 to be executed by the first processor 110 at a specific main memory 140 address through the branched boot loader 12, and the process of FIG. 5. Confirming through the program information corresponding to the user's initial program use pattern recorded in the memory 130 or 140 is confirmed (S820).

이후, 상기 제1프로세서(110)는 분기처리 부트로더(12)를 통해 상기 제2프로세서(120)가 실행할 프로그램-상기 (S820)과정을 통해 확인된 프로그램- 부트로더(22)를 커널 부트로더(13)와는 다른 메모리(140) 주소에 적재시킨다(S830).Subsequently, the first processor 110 executes the program to be executed by the second processor 120 through the branch processing boot loader 12-the program-boot loader 22 identified through the process S820. In step S830, the memory 140 is loaded at a different address from the memory 140 (13).

이후, 상기 프로그램 부트로더(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 to determine the address where the program boot loader 22 is located. Transferring to the second processor 120 (S840), jumps to the kernel boot loader 13 address to perform a general kernel boot process (S850).

도면 상에 별도로 도시하지는 않았지만, 상기 (S850)과정은 일반적인 운영체제 부팅과정으로 처리되나, 커널 초기화 과정에서 초기화할 자원들이 상기 제2프로세서(120)를 통해 초기화되었는지 확인한 후, 아직 초기화되지 않았다면 직접 해당 자원을 초기화하고, 이미 제2프로세서(120)에 의해 초기화된 경우에는 해당 자원 초기화를 건너뛰어 중복 초기화를 방지하는 과정이 포함될 수 있음을 명기하는 바이다.Although not shown separately on the drawing, the process (S850) is processed as a general operating system booting process, but after confirming whether resources to be initialized in the kernel initialization process are initialized through the second processor 120, if not already initialized, the corresponding process is directly performed. If the resource is initialized and already initialized by the second processor 120, the process may include skipping the resource initialization to prevent duplicate initialization.

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

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

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

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

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

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

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

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

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

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

*도면 10에 따르면, 본 발명에 따른 프로그램 운영 장치(100)가 자동차에 구비되는 텔레메틱스 장치인 경우를 사례로 설정한 것이다.According to FIG. 10, the case in which 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, when driver A starts up the car, the first program used is the rear camera, which shows the rear view, and driver A needs at least 15 seconds because the current telematics device takes more than 15 seconds to complete the booting process. I had to wait until the rear camera was running so I could grasp the situation and drive.

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

제1프로세서(110)가 부팅을 담당하고, 제2프로세서(120)가 부팅 과정 중 우선적으로 실행되어야 할 후방 카메라 프로그램을 담당하게 함으로써, A운전자가 자동차에 시동을 걸면, 부팅을 담당하는 제1프로세서(110)는 부팅을 진행하고, 후방 카메라를 담당하는 제2프로세서(120)는 후방카메라 프로그램을 준비한 뒤에 곧 디스플레이에 후방 상황을 보여줄 수 있어, A운전자는 텔레메틱스 장치의 완전한 부팅을 기다릴 필요 없이 바로 운전을 할 수 있게 되는 것이다.The first processor 110 is in charge of booting, and the second processor 120 is in charge of the rear camera program to be executed first during the booting process. The processor 110 proceeds to boot, and the second processor 120 in charge of the rear camera can show the rear situation on the display soon after preparing the rear camera program, so that the driver A does not have to wait for the full boot up of the telematics device. You will be able to drive immediately.

그리고, 주행 중에는 후방카메라를 거의 사용하지 않기 때문에, 후방카메라를 담당하던 제2프로세서(120)는 스케줄러에게 반환되어 텔레메틱스 장치의 다른 기능들을 수행함으로써 텔레메틱스 장치의 여러 작업들을 효율적으로 처리할 수 있게 된다.In addition, since the rear camera is rarely used while driving, the second processor 120 which is in charge of the rear camera returns 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 : 분석부
160 : 저장부 11 : 부트 모니터
12 : 분기처리 부트로더 13 : 커널 부트로더
21 : 부트 모니터 220 : 프로그램 부트로더
100: program operating device 110: first processor
120: second processor 130: nonvolatile memory
140: main memory 150: analysis unit
160: storage unit 11: boot monitor
12: Branch Boot Boot Loader 13: Kernel Boot Loader
21: boot monitor 220: program boot loader

Claims (12)

두 개 이상의 프로세서를 구비하는 프로그램 운영 장치에 있어서,
전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 분석부;
상기 분석부의 분석결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 저장부;
전원 입력시, 제2프로세서를 구동하기 위한 멀티프로세서 분기처리 부트로더(Bootloader)와 운영체제 부팅을 위한 커널(kernel) 부트로더를 실행하되, 상기 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 분기처리 부트로더를 통해 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 제1프로세서; 및
상기 제1프로세서의 상기 분기처리 부트로더를 통해 구동된 후, 프로그램 부트로더를 실행하여, 상기 프로그램 부트로더를 통해 상기 제1프로세서를 통한 운영체제 부팅 전 운영체제 없이 실행되는 프로그램-사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류에 대응하는 프로그램-이 실행되도록 처리하는 제2프로세서;를 구비하되,
상기 분기처리 부트로더는
상기 제1프로세서가 실행할 상기 커널 부트로더를 특정 메모리 주소에 적재시키고, 상기 제2프로세서가 실행할 상기 프로그램 부트로더를 상기 커널 부트로더와 다른 메모리 주소에 적재시킨 후, 상기 프로그램 부트로더가 메모리 상에 적재되면, 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소정보를 제공하는
프로그램 운영 장치.
In the program operating device having two or more processors,
An analysis unit for analyzing a user's initial program use pattern after power input;
A storage unit for determining a type of a program first used by a user after inputting power, and recording the determined program type information on a memory in response to an analysis result of the analysis unit;
When the power is input, the multiprocessor branching boot loader for driving the second processor and the kernel boot loader for booting the operating system are executed. A first processor configured to load a program boot loader corresponding to the identified program type into a memory through the branch processing boot loader after confirming the type of the program; And
After being driven through the branched boot loader of the first processor, a program boot loader is executed, and the program-user running without an operating system before booting an operating system through the first processor through the program boot loader is first inputted after power-on. And a second processor for processing a program corresponding to the type of the program to be executed.
The branch processing boot loader
Load the kernel boot loader to be executed by the first processor at a specific memory address, load the program boot loader to be executed by the second processor at a different memory address than the kernel boot loader, and then load the program boot loader into memory. When loaded, interrupt the second processor and provide the address information where the program boot loader is located.
Program operating device.
삭제delete 제 1항에 있어서, 상기 프로그램 부트로더는,
실행 대상 프로그램 코드들을 메모리에 적재하되,
상기 프로그램 코드들은,
운영체제 없이 실행되는 Stand-alone 프로그램인 것을 특징으로 하는,
프로그램 운영 장치.
The method of claim 1, wherein the program boot loader,
Load the target program codes into memory,
The program codes,
Characterized in that the stand-alone program that runs without an operating system,
Program operating device.
제 1항 또는 제 3항에 있어서, 상기 운영체제 없이 실행되는 프로그램은,
실행에 요구되는 자원들을 직접 초기화하고, 직접 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는,
프로그램 운영 장치.
The program of claim 1 or 3, wherein the program executed without the operating system includes:
Directly initialize the resources required for execution and indicate the directly initialized resources, to prevent the resources from being duplicated during the booting process in the first processor;
Program operating device.
삭제delete 삭제delete 제 1항에 있어서, 상기 제1프로세서는,
운영체제 부팅을 처리하는 부트 프로세서인 것을 특징으로 하는,
프로그램 운영 장치.
The method of claim 1, wherein the first processor,
Characterized in that the boot processor for handling the operating system boot,
Program operating device.
두 개 이상의 프로세서를 구비하는 프로그램 운영 장치에서의 프로그램 운영 방법에 있어서,
전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 패턴 분석단계;
상기 패턴 분석 결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 정보 기록단계;
제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계;
상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계;
상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계;
상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하는 프로그램 실행단계;
운영체제 부팅 과정이 완료되면, 상기 제1프로세서에서 상기 제2프로세서를 통해 기 실행중인 프로그램과 동일한 기능을 수행하지만 운영체제 위에서 동작하는 프로그램을 메모리에 적재하는 단계;
상기 제1프로세서에서 상기 제2프로세서로 인터럽트를 걸어 상기 프로그램 실행단계를 통해 기 실행중인 프로그램을 운영체제 위에서 동작하는 프로그램으로 대체되도록 처리하는 단계;
를 포함하는 프로그램 운영 방법.
In the program operating method having a program operating device having two or more processors,
A pattern analysis step of analyzing a user's initial program use pattern after power input;
An information recording step of determining a type of a program first used by a user after inputting power, and recording the determined program type information on a memory in response to the pattern analysis result;
A branching boot loader executing step of executing a branching boot loader for driving the second processor in the first processor;
In the branched boot loader, a program boot loader to be executed by a second processor is loaded in a memory address, and after confirming the type of a program that is first used by a user recorded in memory through the information recording step after power input, the checked program A program boot loader loading step of loading a program boot loader corresponding to a type into a memory;
A second processor interrupting step, when the program boot loader is loaded, the first processor interrupts the second processor and transmits the address where the program boot loader is located to the second processor;
A program executing step of executing a program after loading program codes executed without an operating system into a memory through the program boot loader in the second processor;
When the operating system booting process is completed, loading a program in the memory which performs the same function as a program already running through the second processor but operates on the operating system;
Interrupting the first processor from the first processor to process the previously executed program to be replaced with a program operating on an operating system through the program execution step;
Program operation method comprising a.
제 8항에 있어서, 상기 프로그램 실행단계는,
실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서에서 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 단계를 더 포함하는,
프로그램 운영 방법.
The method of claim 8, wherein the program execution step,
Initializing the resources required for execution and indicating the initialized resources, thereby preventing the resources from being duplicated and initialized during the booting process in the first processor;
How the program works.
두 개 이상의 프로세서를 구비하는 프로그램 운영 장치에서의 프로그램 운영 방법에 있어서,
전원 입력 후, 사용자의 최초 프로그램 이용 패턴을 분석하는 패턴 분석단계;
상기 패턴 분석 결과에 대응하여, 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확정하고, 확정된 프로그램 종류 정보를 메모리 상에 기록하는 정보 기록단계;
제1프로세서에서 제2프로세서를 구동하기 위한 분기처리 부트로더(Bootloader)를 실행하는 분기처리 부트로더 실행단계;
상기 분기처리 부트로더에서 제2프로세서가 실행할 프로그램 부트로더를 메모리 주소에 적재시키되, 상기 정보 기록단계를 통해 메모리 상에 기록된 사용자가 전원 입력 후 최초 이용하는 프로그램에 대한 종류를 확인한 후, 상기 확인한 프로그램 종류에 대응하는 프로그램 부트로더를 메모리에 적재하는 프로그램 부트로더 적재단계;
상기 프로그램 부트로더가 적재되면, 상기 제1프로세서는 상기 제2프로세서로 인터럽트를 걸면서 상기 프로그램 부트로더가 위치한 주소를 상기 제2프로세서로 전달하는 제2프로세서 인터럽트 단계;
상기 제2프로세서에서 상기 프로그램 부트로더를 통해 운영체제 없이 실행되는 프로그램 코드들을 메모리에 적재한 후, 프로그램을 실행하되, 실행에 요구되는 자원들을 초기화하고, 초기화된 자원들을 표시하여, 상기 제1프로세서의 부팅 과정에서 상기 자원들이 중복 초기화되는 것을 방지하는 프로그램 실행단계;
를 포함하는 프로그램 운영 방법.
In the program operating method having a program operating device having two or more processors,
A pattern analysis step of analyzing a user's initial program use pattern after power input;
An information recording step of determining a type of a program first used by a user after inputting power, and recording the determined program type information on a memory in response to the pattern analysis result;
A branching boot loader executing step of executing a branching boot loader for driving the second processor in the first processor;
In the branched boot loader, a program boot loader to be executed by a second processor is loaded in a memory address, and after confirming the type of a program that is first used by a user recorded in memory through the information recording step after power input, the checked program A program boot loader loading step of loading a program boot loader corresponding to a type into a memory;
A second processor interrupting step, when the program boot loader is loaded, the first processor interrupts the second processor and transmits the address where the program boot loader is located to the second processor;
After loading the program codes executed without an operating system into the memory through the program boot loader in the second processor, the program is executed, the resources required for execution are initialized, and the initialized resources are displayed to display the initialized resources of the first processor. Executing a program to prevent the resources from being repeatedly initialized during a booting process;
Program operation method comprising a.
삭제delete 제 8항 내지 제 10항 중 어느 한 항의 방법을 실행하기 위한 프로그램을 기록한 것을 특징으로 하는 컴퓨터로 판독 가능한 기록매체.A computer-readable recording medium having recorded thereon a program for executing the method of any one of claims 8 to 10.
KR1020180032701A 2018-03-21 2018-03-21 Recording Medium, Method and Device For Program Operation KR101984564B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020180032701A KR101984564B1 (en) 2018-03-21 2018-03-21 Recording Medium, Method and Device For Program Operation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020180032701A KR101984564B1 (en) 2018-03-21 2018-03-21 Recording Medium, Method and Device For Program Operation

Related Parent Applications (1)

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

Publications (2)

Publication Number Publication Date
KR20180034354A KR20180034354A (en) 2018-04-04
KR101984564B1 true KR101984564B1 (en) 2019-09-03

Family

ID=61975374

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020180032701A KR101984564B1 (en) 2018-03-21 2018-03-21 Recording Medium, Method and Device For Program Operation

Country Status (1)

Country Link
KR (1) KR101984564B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102261009B1 (en) * 2019-06-27 2021-06-04 주식회사 텔레칩스 Multi core system and method thereof

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5748957A (en) 1995-06-27 1998-05-05 Klein; Dean A. Computer system usage determination based on hard disk drive activity
JP2002525745A (en) 1998-09-24 2002-08-13 フィーニックス テクノロジーズ リミテッド Using Other Processors During the BIOS Boot Sequence to Minimize Boot Time
US20090037718A1 (en) 2007-07-31 2009-02-05 Ganesh Perinkulam I Booting software partition with network file system
US20110023026A1 (en) 2009-07-24 2011-01-27 Dhairesh Oza Pattern-based operating systems

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20060067076A (en) * 2004-12-14 2006-06-19 한국전자통신연구원 Method for loading program in master-slave processor system and apparatus thereof
US7461247B2 (en) * 2005-06-03 2008-12-02 Qnx Software Systems Gmbh & Co. Kg Method for transitioning control of a peripheral device from a first device driver to a second device driver during operating system initialization
KR20080057688A (en) * 2006-12-20 2008-06-25 주식회사 대우일렉트로닉스 Method for booting operating system using of non volatile memory

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5748957A (en) 1995-06-27 1998-05-05 Klein; Dean A. Computer system usage determination based on hard disk drive activity
JP2002525745A (en) 1998-09-24 2002-08-13 フィーニックス テクノロジーズ リミテッド Using Other Processors During the BIOS Boot Sequence to Minimize Boot Time
US20090037718A1 (en) 2007-07-31 2009-02-05 Ganesh Perinkulam I Booting software partition with network file system
US20110023026A1 (en) 2009-07-24 2011-01-27 Dhairesh Oza Pattern-based operating systems

Also Published As

Publication number Publication date
KR20180034354A (en) 2018-04-04

Similar Documents

Publication Publication Date Title
US9189248B2 (en) Specialized boot path for speeding up resume from sleep state
US8769256B2 (en) Fast switching between multiple operating systems using standby state
USRE40092E1 (en) Method for quickly booting a computer system
KR101702700B1 (en) Fast computer startup
US8898495B2 (en) Method and apparatus for switching an operating system by determining whether a boot-up mode is a general mode or a switch mode
US20140164751A1 (en) Multi-phase resume from hibernate
US20100100719A1 (en) Method for reducing booting time and computer using the same
US10007552B2 (en) System and method for dual OS memory switching
KR101780052B1 (en) Method for switching the operating system in information processing system
US8312256B2 (en) Display of a basic input/output system (BIOS) productivity display
JP6399916B2 (en) Information processing apparatus and control method thereof
KR101673299B1 (en) Operating system recovery method and apparatus, and terminal device
US20130061090A1 (en) Partial rebooting recovery apparatus and method
KR101813641B1 (en) Image forming apparatus and method for booting the same having hibernation function
KR101863250B1 (en) Recording Medium, Method and Device For Program Execution
JP2002132741A (en) Processor adding method, computer and recording medium
KR101984564B1 (en) Recording Medium, Method and Device For Program Operation
US20120144182A1 (en) Apparatus and method for fast booting based on virtualization technique
US9852029B2 (en) Managing a computing system crash
KR101984558B1 (en) Recording Medium, Method and Device For Program Operation
US20120311312A1 (en) Fast Boot Via State Recreation
CN116028129B (en) UEFI (unified extensible firmware interface) quick starting method based on Feiteng platform and Feiteng platform
KR100994723B1 (en) selective suspend resume method of reducing initial driving time in system, and computer readable medium thereof
KR101984568B1 (en) Recording Medium, Method and Device For Program Operation
KR101869425B1 (en) Recording Medium, Method and Device For Program Operation

Legal Events

Date Code Title Description
A107 Divisional application of patent
A201 Request for examination
E902 Notification of reason for refusal
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant