TWI497414B - File executing method and system - Google Patents
File executing method and system Download PDFInfo
- Publication number
- TWI497414B TWI497414B TW098121008A TW98121008A TWI497414B TW I497414 B TWI497414 B TW I497414B TW 098121008 A TW098121008 A TW 098121008A TW 98121008 A TW98121008 A TW 98121008A TW I497414 B TWI497414 B TW I497414B
- Authority
- TW
- Taiwan
- Prior art keywords
- execution
- computer
- loader
- file
- storage area
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44557—Code layout in executable memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44568—Immediately runnable code
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Stored Programmes (AREA)
Description
本發明是有關於一種檔案執行方法及系統,且特別是有關於一種用以執行儲存在儲存裝置之隱藏儲存區中的電腦執行碼組(computer executable code set)的檔案執行方法及系統。The present invention relates to a file execution method and system, and more particularly to a file execution method and system for executing a computer executable code set stored in a hidden storage area of a storage device.
數位相機、手機與MP3在這幾年來的成長十分迅速,使得消費者對儲存媒體的需求也急速增加。由於快閃記憶體(Flash Memory)具有資料非揮發性、省電、體積小與無機械結構等的特性,最適合用作為可攜式儲存裝置。此外,隨著即插即用之連接介面(例如,通用序列匯流排(Universal Serial Bus,USB))的發展,使得可攜式儲存裝置已廣泛應用於數位內容的儲存上。Digital cameras, mobile phones and MP3s have grown very rapidly in recent years, and the demand for storage media has increased rapidly. Because Flash Memory has the characteristics of non-volatile data, power saving, small size and no mechanical structure, it is most suitable as a portable storage device. In addition, with the development of plug-and-play connection interfaces (for example, Universal Serial Bus (USB)), portable storage devices have been widely used for storage of digital content.
儲存裝置的製造商為了能夠使所販售之可攜式儲存裝置更具市場競爭力,往往會於所販售之可攜式儲存裝置中儲存應用程式以供購買此可攜式儲存裝置的使用者使用。例如,製造商開發用於可攜式儲存裝置的磁碟管理程式並預儲存在可攜式儲存裝置,以使得使用者可使用此磁碟管理程式來管理可攜式儲存裝置的儲存狀態。In order to be able to make the portable storage devices sold in the market more competitive, the storage device is often stored in the portable storage device sold for the purchase of the portable storage device. Use. For example, a manufacturer develops a disk management program for a portable storage device and pre-stores it in a portable storage device so that a user can use the disk management program to manage the storage state of the portable storage device.
目前來說,為使使用者的電腦主機可執行此類製造商所提供的應用程式,此應用程式會預先儲存在可攜式儲存裝置的可正常儲存資料的分割區(或儲存區)中,以利電腦主機存取。由於應用程式可由電腦主機以一般存取檔案之方式來存取,因此應用程式亦可輕易地被複製與散播,由此應用程式開發者的智慧財產將無法有效地被保障。儘管已由可攜式儲存裝置的製造商於可攜式儲存裝置中配置隱藏儲存區(即,電腦主機無法存取之儲存區)來儲存欲保密的資料,然此類應用程式必須由電腦主機的作業系統執行方可運作,因此將應用程式儲存在隱藏儲存區雖可達到避免被複製與散佈的目的,但同時亦使使用者無法使用此應用程式。因此,有需要開發能夠直接執行儲存於隱藏儲存區之電腦執行碼組的方法。At present, in order to enable the user's computer host to execute an application provided by such a manufacturer, the application is pre-stored in a partition (or storage area) of the portable storage device that can normally store data. Eli computer host access. Since the application can be accessed by the host computer by means of general access to the file, the application can be easily copied and distributed, so that the intellectual property of the application developer cannot be effectively protected. Although the manufacturer of the portable storage device has configured a hidden storage area (ie, a storage area that the host computer cannot access) in the portable storage device to store the data to be kept secret, such an application must be hosted by the computer. The operating system executive can operate, so storing the application in a hidden storage area can avoid copying and distributing, but it also prevents users from using the application. Therefore, there is a need to develop a method for directly executing a computer execution code group stored in a hidden storage area.
本發明提供一種檔案執行方法,其能夠直接地執行儲存在儲存裝置之隱藏儲存區中的電腦執行碼組。The present invention provides a file execution method capable of directly executing a computer execution code group stored in a hidden storage area of a storage device.
本發明提供一種檔案執行系統,其能夠直接地執行儲存在儲存裝置之隱藏儲存區中的電腦執行碼組。The present invention provides a file execution system that is capable of directly executing a computer executable code group stored in a hidden storage area of a storage device.
本發明範例實施例提出一種檔案執行方法,用以在電腦主機的作業系統中執行儲存在儲存裝置中的電腦執行碼組(computer executable file),其中此儲存裝置包括一般儲存區與隱藏儲存區並且此電腦執行碼組是儲存在隱藏儲存區中。根據本範例實施例的檔案執行方法包括將儲存裝置連接至電腦主機,其中電腦主機具有主記憶體。此檔案執行方法還包括提供載入器,以管理儲存在隱藏儲存區中的電腦執行碼組。此檔案執行方法更包括在主記憶體中運轉(Run)載入器;請求作業系統在主機記憶體中分配(Allocate)用於運轉載入器的第一位址區段;由載入器從隱藏儲存區中將電腦執行碼組載入至第一位址區段中;由載入器將所載入之電腦執行碼組轉換為可由作業系統執行的可執行內容並將所轉換之可執行內容的至少一部分儲存在第一位址區段中;以及由載入器建立一衍生執行程序(derivative execution procedure)來執行所轉換之可執行內容。An exemplary embodiment of the present invention provides a file execution method for executing a computer executable file stored in a storage device in an operating system of a host computer, wherein the storage device includes a general storage area and a hidden storage area. This computer execution code group is stored in a hidden storage area. The file execution method according to this exemplary embodiment includes connecting a storage device to a computer host, wherein the computer host has a main memory. The file execution method also includes providing a loader to manage the computer execution code group stored in the hidden storage area. The file execution method further includes running a loader in the main memory; requesting the operating system to allocate (Allocate) the first address segment for running the loader in the host memory; Loading the computer execution code group into the first address field in the hidden storage area; the loader converts the loaded computer execution code group into executable content executable by the operating system and converts the executable executable At least a portion of the content is stored in the first address section; and a derivative execution procedure is established by the loader to execute the converted executable content.
在本發明之一實施例中,上述之由載入器建立衍生執行程序來執行所轉換之可執行內容的步驟包括:由載入器請求作業系統在主記憶體中建立用於再次運轉載入器的衍生執行程序並請求作業系統在主記憶體中分配用於此衍生執行程序的第二位址區段;由載入器暫停執行衍生執行程序;由載入器將上述之可執行內容寫入至第二位址區段中;以及由載入器繼續執行衍生執行程序。In an embodiment of the present invention, the step of establishing a derivative executable program by the loader to execute the converted executable content includes: requesting, by the loader, the operating system to establish a load for rerunning in the main memory. Derivative executor and requesting the operating system to allocate a second address segment for the derived executor in the main memory; suspend execution of the derived executor by the loader; write the above executable content by the loader Entering into the second address section; and continuing execution of the derived executable by the loader.
在本發明之一實施例中,上述之檔案執行方法更包括:由載入器判斷第二位址區段的大小是否小於可執行內容的大小,其中當第二位址區段的大小小於可執行內容的大小時,則由載入器請求作業系統在主記憶體中分配一第三位址區段,以使第二位址區段與第三位址區段的大小大於可執行內容的大小。In an embodiment of the present invention, the file execution method further includes: determining, by the loader, whether the size of the second address segment is smaller than a size of the executable content, wherein when the size of the second address segment is smaller than When the size of the content is executed, the loader requests the operating system to allocate a third address segment in the main memory so that the size of the second address segment and the third address segment are larger than the executable content. size.
在本發明之一實施例中,上述之檔案執行方法更包括在儲存裝置中配置自動執行檔並且由作業系統自動地執行此自動執行檔,其中自動執行檔會在主記憶體中運轉載入器。In an embodiment of the present invention, the file execution method further includes configuring an automatic execution file in the storage device and automatically executing the automatic execution file by the operating system, wherein the automatic execution file runs the loader in the main memory. .
在本發明之一實施例中,上述之檔案執行方法更包括將載入器配置在儲存裝置的一般儲存區中。In an embodiment of the invention, the file execution method further includes configuring the loader in a general storage area of the storage device.
在本發明之一實施例中,上述之檔案執行方法更包括在該儲存裝置中配置一特殊儲存區並且將自動執行檔與載入器配置在儲存裝置的特殊儲存區中,其中此特殊儲存區相容於ISO 9660標準。In an embodiment of the present invention, the file execution method further includes configuring a special storage area in the storage device and configuring the automatic execution file and the loader in a special storage area of the storage device, wherein the special storage area Compatible with the ISO 9660 standard.
在本發明之一實施例中,上述之檔案執行方法更包括將載入器配置在電腦主機中。In an embodiment of the present invention, the file execution method further includes configuring the loader in a computer host.
在本發明之一實施例中,上述之檔案執行方法更包括將上述電腦執行碼組解密。In an embodiment of the invention, the file execution method further includes decrypting the computer-executed code group.
在本發明之一實施例中,上述之檔案執行方法更包括藉由載入器初始化隱藏儲存區。In an embodiment of the present invention, the file execution method further includes initializing a hidden storage area by a loader.
在本發明之一實施例中,上述之可執行內容相容於一可攜式可執行檔案格式(portable executable file format)。In an embodiment of the invention, the executable content is compatible with a portable executable file format.
本發明範例實施例提出一種檔案執行系統,用以執行儲存在儲存裝置中的電腦執行碼組,其中儲存裝置包括一般儲存區與隱藏儲存區並且電腦執行碼組是儲存在隱藏儲存區中。根據本發明範例實施例的檔案執行系統包括電腦主機與載入器。電腦主機包括作業系統與主記憶體。載入器耦接或可存取地連結至電腦主機與儲存裝置並且具有一應用程式執行單元,其中應用程式執行單元用以執行儲存在隱藏儲存區中的電腦執行碼組。作業系統在主記憶體中運轉載入器並且在主機記憶體中分配用於運轉此載入器的第一位址區段。應用程式執行單元從隱藏儲存區中將電腦執行碼組載入至第一位址區段中,將所載入之電腦執行碼組轉換為可由作業系統執行的可執行內容,將所轉換之可執行內容儲存在第一位址區段中,以及建立一衍生執行程序來執行該可執行內容。An exemplary embodiment of the present invention provides a file execution system for executing a computer execution code group stored in a storage device, wherein the storage device includes a general storage area and a hidden storage area, and the computer execution code group is stored in the hidden storage area. A file execution system according to an exemplary embodiment of the present invention includes a computer host and a loader. The host computer includes the operating system and main memory. The loader is coupled or removably coupled to the host computer and the storage device and has an application execution unit, wherein the application execution unit is configured to execute a computer execution code group stored in the hidden storage area. The operating system runs the loader in the main memory and allocates a first address section for running the loader in the host memory. The application execution unit loads the computer execution code group from the hidden storage area into the first address area, and converts the loaded computer execution code group into executable content executable by the operating system, and converts the converted code to The execution content is stored in the first address section and a derivative executable is created to execute the executable content.
在本發明之一實施例中,上述之應用程式執行單元請求作業系統在主記憶體中建立用於再次運轉該載入器的衍生執行程序並請求作業系統在主記憶體中分配用於此衍生執行程序的第二位址區段。此外,應用程式執行單元暫停執行衍生執行程序,將可執行內容寫入至第二位址區段中,並且繼續執行衍生執行程序。In an embodiment of the present invention, the application execution unit requests the operating system to establish a derivative executable program in the main memory for re-running the loader and requests the operating system to allocate the primary memory for the derivative. Execute the second address section of the program. In addition, the application execution unit suspends execution of the derived executor, writes the executable content into the second address section, and continues to execute the derived executor.
在本發明之一實施例中,上述之應用程式執行單元判斷第二位址區段的大小是否小於可執行內容的大小,其中當第二位址區段的大小小於可執行內容的大小時,則應用程式執行單元請求作業系統在該主記憶體中分配第三位址區段,以使第二位址區段與第三位址區段的大小大於可執行內容的大小。In an embodiment of the present invention, the application execution unit determines whether the size of the second address segment is smaller than the size of the executable content, wherein when the size of the second address segment is smaller than the size of the executable content, The application execution unit requests the operating system to allocate the third address segment in the main memory such that the size of the second address segment and the third address segment is greater than the size of the executable content.
在本發明之一實施例中,上述之檔案執行系統更包括一自動執行檔,配置在儲存裝置中,其中當儲存裝置耦接至電腦主機時,作業系統自動地執行自動執行檔並且自動執行檔會在主記憶體中運轉上述之載入器。In an embodiment of the present invention, the file execution system further includes an automatic execution file configured in the storage device, wherein when the storage device is coupled to the computer host, the operating system automatically executes the automatic execution and automatically executes the file. The above loader will be run in the main memory.
在本發明之一實施例中,上述之載入器配置在儲存裝置的一般儲存區中。In one embodiment of the invention, the loader described above is disposed in a general storage area of the storage device.
在本發明之一實施例中,上述之儲存裝置更包括特殊儲存區,並且上述之自動執行檔與載入器配置在儲存此特殊儲存區中,其中特殊儲存區相容於ISO 9660標準。In an embodiment of the invention, the storage device further includes a special storage area, and the automatic execution and loader configuration described above is stored in the special storage area, wherein the special storage area is compatible with the ISO 9660 standard.
本發明範例實施例提出一種檔案執行方法,用以在電腦主機的作業系統中執行儲存在儲存裝置中的電腦執行碼組,其中儲存裝置包括一般儲存區與隱藏儲存區並且此電腦執行碼組儲存在隱藏儲存區中。本檔案執行方法包括提供一載入器,以管理儲存在隱藏儲存區中的電腦執行碼組。本檔案執行方法亦包括使用載入器從隱藏儲存區中將電腦執行碼組直接載入至電腦主機中,並且將所載入之電腦執行碼組轉換為可由作業系統執行的可執行內容。本檔案執行方法更包括複製此可執行內容,以及執行此可執行內容。An exemplary embodiment of the present invention provides a file execution method for executing a computer execution code group stored in a storage device in an operating system of a computer host, wherein the storage device includes a general storage area and a hidden storage area, and the computer performs code group storage. In the hidden storage area. This file execution method includes providing a loader to manage computer execution code groups stored in hidden storage areas. The file execution method also includes using the loader to load the computer execution code group directly from the hidden storage area into the host computer, and converting the loaded computer execution code group into executable content executable by the operating system. This file execution method further includes copying this executable content and executing this executable content.
本發明範例實施例提出一種可程式儲存裝置,本可程式儲存裝置記錄可被一電腦主機執行之程式碼,當電腦主機載入此程式碼並執行後可實施上述之檔案執行方法。The exemplary embodiment of the present invention provides a programmable storage device. The programmable storage device records a code that can be executed by a computer host. After the computer host loads the code and executes the file execution method, the file execution method can be implemented.
基於上述,本發明範例實施例可直接地執行儲存在儲存裝置之隱藏儲存區中的電腦執行碼組,並且使用者無法輕易地複製與散佈儲存在隱藏儲存區中的電腦執行碼組,由此可。Based on the above, the exemplary embodiment of the present invention can directly execute a computer execution code group stored in a hidden storage area of the storage device, and the user cannot easily copy and distribute the computer execution code group stored in the hidden storage area, thereby can.
為讓本發明之上述特徵和優點能更明顯易懂,下文特舉實施例,並配合所附圖式作詳細說明如下。The above described features and advantages of the present invention will be more apparent from the following description.
圖1是根據本發明第一範例實施例所繪示的檔案執行系統的概要方塊圖。1 is a schematic block diagram of a file execution system according to a first exemplary embodiment of the present invention.
請參照圖1,檔案執行系統100能夠執行儲存在儲存裝置150的隱藏儲存區152中之電腦執行碼組160。具體來說,儲存裝置150包括隱藏儲存區152與一般儲存區154,其中隱藏儲存區152是電腦之作業系統無法存取的儲存區(即,電腦之作業系統無法依一般程序直接在隱藏儲存區中讀取與寫入資料),而一般儲存區154是電腦之作業系統可存取的儲存區。在本範例實施例中,儲存裝置150為以快閃記憶體作為儲存媒體的可攜式儲存裝置(例如,隨身碟、行動硬碟等)。例如,儲存裝置150包括控制器156與快閃記憶體晶片158,其中控制器156用以控制儲存裝置150的整體運作,快閃記憶體晶片158包括用以儲存資料與電腦應用程式的隱藏儲存區152與一般儲存區154。然而,必須瞭解的是,本發明不限於此,儲存裝置150可以是磁帶、軟碟、光學資料儲存裝置或其他儲存裝置。此外,值得一提的是,控制器156更可以將資料或應用程式加密後儲存至隱藏儲存區152,由此提供資料或應用程式更進一步的保護。此外,此電腦執行碼組160可不在儲存裝置150的檔案配置表(File Allocation Table,FAT)中顯示相關資訊,也就是說,作業系統118a無法辨視此電腦執行碼組160為一檔案。Referring to FIG. 1, the file execution system 100 is capable of executing a computer executable code group 160 stored in a hidden storage area 152 of the storage device 150. Specifically, the storage device 150 includes a hidden storage area 152 and a general storage area 154, wherein the hidden storage area 152 is a storage area that cannot be accessed by the operating system of the computer (ie, the operating system of the computer cannot directly be in the hidden storage area according to a general procedure. The medium is read and written, and the general storage area 154 is a storage area accessible to the operating system of the computer. In the present exemplary embodiment, the storage device 150 is a portable storage device (for example, a flash drive, a mobile hard disk, etc.) that uses a flash memory as a storage medium. For example, the storage device 150 includes a controller 156 and a flash memory chip 158. The controller 156 is used to control the overall operation of the storage device 150. The flash memory chip 158 includes a hidden storage area for storing data and computer applications. 152 and general storage area 154. However, it must be understood that the present invention is not limited thereto, and the storage device 150 may be a magnetic tape, a floppy disk, an optical data storage device, or other storage device. In addition, it is worth mentioning that the controller 156 can encrypt the data or application and store it in the hidden storage area 152, thereby providing further protection of the data or the application. In addition, the computer execution code group 160 may not display related information in the File Allocation Table (FAT) of the storage device 150, that is, the operating system 118a cannot recognize the computer execution code group 160 as a file.
檔案執行系統100包括電腦主機110與載入器120。The file execution system 100 includes a computer host 110 and a loader 120.
電腦主機110是用以執行電腦執行碼組160的平台。在本範例實施例中,電腦主機110為一桌上型個人電腦。必須瞭解的是,本發明不限於此,在本發明另一範例實施 例中,電腦主機110亦可以是筆記型電腦、伺服器或其他任何能夠執行地電腦程式的電腦主機。The host computer 110 is a platform for executing a computer executable code group 160. In the present exemplary embodiment, the computer main unit 110 is a desktop personal computer. It must be understood that the present invention is not limited thereto, and is embodied in another example of the present invention. In the example, the host computer 110 can also be a notebook computer, a server, or any other computer host capable of executing a computer program.
電腦主機110包括中央處理單元112、主記憶體114、輸入與輸出單元116以及存有作業系統118a的儲存單元118。The mainframe 110 includes a central processing unit 112, a main memory 114, an input and output unit 116, and a storage unit 118 in which the operating system 118a is stored.
中央處理單元112用以解釋電腦指令以及處理電腦軟體中的資料。The central processing unit 112 is used to interpret computer instructions and process data in the computer software.
主記憶體114是耦接至中央處理單元112並且用以載入各式各樣的程式與資料以供中央處理單元112直接執行與運用。具體來說,主記憶體114具可隨時讀寫且較快之讀寫速度等特性,因此主記憶體114是用以作為作業系統118或其他正在執行中的程式的臨時資料儲存媒介。在本範例實施例中,主記憶體114為動態隨機存取記憶體(Dynamic Random Access Memory,DRAM)。此外,必須瞭解的是,在本發明另一範例實施例中,作業系統亦可藉由儲存裝置的儲存空間所模擬的虛擬記憶體來作為執行應用程式之臨時資料儲存媒介,在此例子中,主記憶體更包括此類虛擬記憶體。The main memory 114 is coupled to the central processing unit 112 and is used to load a wide variety of programs and materials for direct execution and operation by the central processing unit 112. Specifically, the main memory 114 has characteristics such as read/write speed and fast read/write speed, and thus the main memory 114 is a temporary data storage medium used as the operating system 118 or other programs being executed. In the present exemplary embodiment, the main memory 114 is a Dynamic Random Access Memory (DRAM). In addition, it should be understood that, in another exemplary embodiment of the present invention, the operating system may also use the virtual memory simulated by the storage space of the storage device as a temporary data storage medium for executing the application, in this example, The main memory further includes such virtual memory.
輸入與輸出單元116耦接至中央處理單元112用以提供一介面以供使用者輸入資料或指令至電腦主機110或者從電腦主機110中輸出資料。在本範例實施例中,輸入/輸出單元116包括鍵盤、滑鼠與顯示器(未繪示)。The input and output unit 116 is coupled to the central processing unit 112 for providing an interface for the user to input data or instructions to or output data from the host computer 110. In the present exemplary embodiment, the input/output unit 116 includes a keyboard, a mouse, and a display (not shown).
儲存單元118耦接至中央處理器單元112用以作為電腦主機110的主要儲存媒體。在本範例實施例中,儲存單元118為一硬碟,然而,必須瞭解的是,本發明不限於此。儲存單元118存有作業系統118a用以管理電腦硬體(Computer hardware)與電腦軟體(Computer software)資源的程式,同時也是電腦主機110的核心與基石。具體來說,作業系統118a用以管理與配置主記憶體114、決定系統資源(例如,中央處理單元112、主記憶體114、輸入與輸出單元116)供需的優先次序、控制輸入與輸出裝置116、管理檔案系統等運作。在本範例實施例中,作業系統118a為微軟(Microsoft)公司的視窗(Windows)作業系統。然而,必須瞭解的是,本發明不限於此,本發明亦可應用於其他作業系統中。The storage unit 118 is coupled to the central processing unit 112 for use as a primary storage medium for the computer host 110. In the present exemplary embodiment, the storage unit 118 is a hard disk, however, it must be understood that the present invention is not limited thereto. The storage unit 118 stores a program for operating the computer hardware and computer software resources, and is also the core and foundation of the computer host 110. Specifically, the operating system 118a is used to manage and configure the main memory 114, determine the priority of supply and demand of system resources (eg, central processing unit 112, main memory 114, input and output unit 116), and control input and output devices 116. Management of file systems and other operations. In the present exemplary embodiment, the operating system 118a is a Windows (Windows) operating system of Microsoft Corporation. However, it must be understood that the present invention is not limited thereto, and the present invention is also applicable to other operating systems.
載入器120可耦接或可儲存於電腦主機110與儲存裝置150,並且具有以硬體型式或韌/軟體型式實作的多個邏輯閘或控制指令來管理儲存在儲存裝置150之隱藏儲存區152中的應用程式(例如,電腦執行程式160)。更詳細來說,在本範例實施例中,載入器120是由儲存裝置150的製造商所提供,並且能夠依據隱藏儲存區152的規格來存取儲存在隱藏儲存區152中的資料或應用程式。The loader 120 can be coupled to or can be stored in the computer host 110 and the storage device 150, and has a plurality of logic gates or control commands implemented in a hard type or a tough/soft type to manage hidden storage stored in the storage device 150. The application in area 152 (e.g., computer execution program 160). In more detail, in the present exemplary embodiment, the loader 120 is provided by the manufacturer of the storage device 150 and is capable of accessing data or applications stored in the hidden storage area 152 according to the specifications of the hidden storage area 152. Program.
在本範例實施例中,載入器120的控制指令是以軟體型式來實作,並且事先儲存於儲存裝置150的一般儲存區154中。也就是說,當使用者操作電腦主機110來瀏覽與電腦主機110連接的儲存裝置150時,使用者可點選儲存在一般儲存區154的載入器120以使載入器120的控制指令在作業系統180中運轉(Run),由此對隱藏儲存區152來進行存取。其中,詳細地說,載入器120的控制指令在作業系統180中運轉(Run)後,會對儲存裝置150發送一預定之指令,儲存裝置150在接受此指令時即會至隱藏儲存區152中讀取預定的資料。此外,在本發明另一範例實施例中,以軟體型式來實作的載入器120亦可儲存在光碟或電腦主機110的硬碟(未繪示)中,由此於使用者點選時載入器120可於作業系統180中運轉。In the present exemplary embodiment, the control instructions of the loader 120 are implemented in a software version and are stored in advance in the general storage area 154 of the storage device 150. That is, when the user operates the computer host 110 to browse the storage device 150 connected to the computer host 110, the user can click on the loader 120 stored in the general storage area 154 to make the control command of the loader 120 The operating system 180 is operated (Run), thereby accessing the hidden storage area 152. In detail, after the control command of the loader 120 is run in the operating system 180, a predetermined command is sent to the storage device 150, and the storage device 150 will go to the hidden storage area 152 when accepting the command. Read the predetermined data. In addition, in another exemplary embodiment of the present invention, the loader 120 implemented in a software type may also be stored in a hard disk (not shown) of the optical disk or the host computer 110, thereby being selected by the user. The loader 120 can operate in the operating system 180.
值得一提的是,在本發明另一範例實施例中,載入器120亦可以一硬體型式實作在儲存裝置150或電腦主機110中。It should be noted that in another exemplary embodiment of the present invention, the loader 120 can also be implemented in the storage device 150 or the host computer 110 in a hardware format.
圖2是根據本發明第一範例實施例所繪示的載入器的概要方塊圖。2 is a schematic block diagram of a loader according to a first exemplary embodiment of the present invention.
請參照圖2,載入器120包括主控單元122、初始化單元124、應用程式新增單元126、應用程式編輯單元128、應用程式刪除單元130與應用程式執行單元132。Referring to FIG. 2, the loader 120 includes a main control unit 122, an initialization unit 124, an application adding unit 126, an application editing unit 128, an application deleting unit 130, and an application executing unit 132.
主控單元122用以控制載入器120的整體運作。The main control unit 122 is used to control the overall operation of the loader 120.
初始化單元124耦接(couple)或連結(link)至主控單元122並且用以初始化儲存裝置150的隱藏儲存區152。具體來說,當初始化單元124運作時,初始化單元124會確認隱藏儲存區152的位址、大小等資訊,並且對隱藏儲存區152進行抹除與格式化。The initialization unit 124 is coupled or linked to the main control unit 122 and is used to initialize the hidden storage area 152 of the storage device 150. Specifically, when the initialization unit 124 operates, the initialization unit 124 confirms the information such as the address, size, and the like of the hidden storage area 152, and erases and formats the hidden storage area 152.
應用程式新增單元126耦接或連結至主控單元122並且用以將使用者欲儲存的應用程式(例如,電腦執行碼組160)寫入至隱藏儲存區152中。The application adding unit 126 is coupled or linked to the main control unit 122 and is used to write an application (for example, the computer execution code group 160) that the user wants to store into the hidden storage area 152.
應用程式編輯單元128耦接或連結至主控單元122並且用以編輯一應用程式清單(Application List)以瀏覽儲存在儲存裝置150之隱藏儲存區152中的應用程式。The application editing unit 128 is coupled or linked to the main control unit 122 and is used to edit an application list to browse applications stored in the hidden storage area 152 of the storage device 150.
應用程式刪除單元130耦接或連結至主控單元122並且用以刪除儲存在儲存裝置150之隱藏儲存區152中的應用程式。例如,應用程式刪除單元130可將電腦執行碼組160從隱藏儲存區152中刪除。The application deletion unit 130 is coupled or coupled to the main control unit 122 and is used to delete an application stored in the hidden storage area 152 of the storage device 150. For example, the application deletion unit 130 may delete the computer execution code group 160 from the hidden storage area 152.
應用程式執行單元132耦接或連結至主控單元122用以執行儲存在儲存裝置150之隱藏儲存區152中的應用程式。例如,應用程式執行單元132會將電腦執行碼組160載入至主記憶體114中並且在電腦主機110的作業系統118a上執行電腦執行碼組160。The application execution unit 132 is coupled or coupled to the main control unit 122 for executing an application stored in the hidden storage area 152 of the storage device 150. For example, the application execution unit 132 loads the computer execution code group 160 into the main memory 114 and executes the computer execution code group 160 on the operating system 118a of the computer host 110.
圖3是根據本發明第一範例實施例所繪示運轉載入器來執行隱藏儲存區中之電腦執行碼組時主記憶體的運作示意圖。FIG. 3 is a schematic diagram showing the operation of the main memory when the operation loader is executed to execute the computer execution code group in the hidden storage area according to the first exemplary embodiment of the present invention.
請參照圖3,當使用者透過輸入與輸出單元116操作電腦主機110的作業系統118a來點選載入器120時,作業系統118a會在主記憶體114中指定用以執行載入器的一個執行點302並且以此執行點為起始點分配(allocate)一第一位址區段310(如圖3的(a)所示)用於載入載入器120的控制指令及暫存載入器120運轉時所使用的資料。Referring to FIG. 3, when the user clicks on the loader 120 by operating the operating system 118a of the computer host 110 through the input and output unit 116, the operating system 118a specifies a one of the main memory 114 for executing the loader. Execution point 302 and allocating a first address section 310 (shown in (a) of FIG. 3) as a starting point for loading control instructions and temporary storage of loader 120 The data used when the feeder 120 is operating.
另外,當使用者藉由已運轉之載入器120執行儲存在隱藏儲存區152中的電腦執行碼組160時,應用程式執行單元132會將儲存在隱藏儲存區152中的電腦執行碼組160載入到第一位址區段310中(如圖3的(b)所示之電腦執行碼組160’)並且將所載入之電腦執行碼組160’轉換為可由作業系統118a執行的可執行內容162。同時,應用程式執行單元132會將可執行內容162儲存在第一位址區段310中(如圖3的(c)所示)。在本範例實施例中,對應電腦執行碼組160的可執行內容162是相容於視窗作業系統的一可攜式可執行檔案格式(portable executable(PE)file format)。In addition, when the user executes the code execution group 160 stored in the hidden storage area 152 by the loaded loader 120, the application execution unit 132 executes the code group 160 of the computer stored in the hidden storage area 152. Loading into the first address field 310 (such as the computer execution code group 160' shown in FIG. 3(b)) and converting the loaded computer execution code group 160' into executable by the operating system 118a. Execution of content 162. At the same time, the application execution unit 132 stores the executable content 162 in the first address section 310 (as shown in (c) of FIG. 3). In the present exemplary embodiment, the executable content 162 of the corresponding computer execution code group 160 is a portable executable (PE) file format compatible with the Windows operating system.
在本範例實施例中,應用程式執行單元132更用以向作業系統118a請求用於再次運轉載入器120之衍生執行程序350的一個執行點304及衍生執行程序350所需的第二地位區段320,其中,在本範例實施例中,衍生執行程序(derivative execution procedure)350是使用分叉進程(fork process)方式來再次運轉載入器120,但亦可使用如多線程(multi-thread)等其他多工執行方式來實施。具體來說,作業系統118a會在應用程式執行單元132的請求下於主記憶體114中指定執行衍生執行程序350的起始點(即,執行點304)以及分配用於此衍生執行程序350的第二位址區段320(如圖3的(d)所示)。In the present exemplary embodiment, the application execution unit 132 is further configured to request, from the operating system 118a, an execution point 304 for re-running the derivative executable program 350 of the loader 120 and a second status area required to derive the execution program 350. Section 320, wherein, in the present exemplary embodiment, the derivative execution procedure 350 uses the fork process to run the loader 120 again, but may also use multi-threads. ) and other multiplex implementation methods to implement. In particular, the operating system 118a, at the request of the application execution unit 132, specifies in the main memory 114 the starting point (ie, execution point 304) at which the derivative executable program 350 is executed and the allocation for the derivative execution program 350. The second address section 320 (shown in (d) of FIG. 3).
特別是,根據本範例實施例的應用程式執行單元132會使用衍生執行程序350來執行對應電腦執行碼組160的可執行內容162。In particular, the application execution unit 132 in accordance with the present exemplary embodiment will use the derived executable 350 to execute the executable content 162 of the corresponding computer executable code set 160.
具體來說,當應用程式執行單元132建立衍生執行程序350後,應用程式執行單元132會暫停執行衍生執行程序350、將對應電腦執行碼組160的可執行內容162從執行點304開始覆寫至第二位址區段320中(即,可執行內容162')並且繼續執行衍生執行程序350。此時,由於衍生執行程序350中的程式碼已被對應電腦執行碼組160的可執行內容162’所置換,因此電腦執行碼組160就可成功地由電腦主機110所執行。具體來說,應用程式執行單元132將電腦執行碼組160轉換為可執行內容162時,其會在可執行內容162的標頭加入關於電腦執行碼組160的資訊(例如,程式碼大小),因此作業系統118a從執行點304開始執行由可執行內容162’寫入之衍生執行程序350時,其可正確地執行對應的程式碼。Specifically, when the application execution unit 132 establishes the derivative execution program 350, the application execution unit 132 suspends execution of the derivative execution program 350, and overwrites the executable content 162 of the corresponding computer execution code group 160 from the execution point 304 to The second address section 320 (ie, the executable content 162') may continue to execute the derived executable 350. At this time, since the code in the derivative executable 350 has been replaced by the executable content 162' of the corresponding computer execution code group 160, the computer execution code group 160 can be successfully executed by the computer host 110. Specifically, when the application execution unit 132 converts the computer execution code group 160 into the executable content 162, it may add information about the computer execution code group 160 (eg, the code size) to the header of the executable content 162. Thus, when the operating system 118a executes the derived executable 350 written by the executable content 162' from the execution point 304, it can correctly execute the corresponding code.
值得一提的是,由於衍生執行程序350是用以再次執行載入器120,因此第二位址區段320的大小是相同於第一位址區段310。在本發明另一範例實施例中,應用程式執行單元132更用以判斷第二位址區段320的大小是否足以容納可執行內容162’,其中當第二位址區段320的容量小於可執行內容162’的大小時,應用程式執行單元132會向作業系統118a請求主記憶體114中的第三位址區段(未繪示)以確保在主記憶體114中有足夠的記憶體位址來寫入可執行內容162’。It is worth mentioning that since the derived executable 350 is used to execute the loader 120 again, the size of the second address section 320 is the same as the first address section 310. In another exemplary embodiment of the present invention, the application execution unit 132 is further configured to determine whether the size of the second address section 320 is sufficient to accommodate the executable content 162 ′, wherein the capacity of the second address section 320 is less than When the size of the content 162' is executed, the application execution unit 132 requests the third address segment (not shown) in the main memory 114 from the operating system 118a to ensure that there is sufficient memory address in the main memory 114. To write executable content 162'.
圖4是根據本發明第一範例實施例所繪示的檔案執行方法的流程圖。FIG. 4 is a flowchart of a file execution method according to a first exemplary embodiment of the present invention.
請參照圖4,首先,在步驟S401中將儲存裝置150連接至電腦主機110,並且在步驟S403中在主記憶體114中分配第一位址區段310與運轉載入器120,其中載入器120的運轉已詳細描述如上,在此不重複描述。Referring to FIG. 4, first, the storage device 150 is connected to the host computer 110 in step S401, and the first address segment 310 and the run loader 120 are allocated in the main memory 114 in step S403, where the loading is performed. The operation of the device 120 has been described in detail above, and the description will not be repeated here.
之後,在步驟S405中使用載入器120從儲存裝置150的隱藏儲存區152中載入電腦執行碼組160至第一位址區段320成為電腦執行碼組160’。然後,在步驟S407中使用載入器120將所載入的電腦執行碼組160’轉換為可執行內容162並且將可執行內容162儲存於第一位址區段320中。Thereafter, the computer executable code group 160 is loaded from the hidden storage area 152 of the storage device 150 to the first address portion 320 using the loader 120 in step S405 to become the computer executable code group 160'. The loaded computer executable code group 160' is then converted to executable content 162 using the loader 120 in step S407 and the executable content 162 is stored in the first address field 320.
然後,在步驟S409中使用載入器120執行可執行內容。具體來說,步驟S409-1中向作業系統118a請求在主記憶體114中建立用於再次運轉載入器120的衍生執行程序350並請求作業系統118a在主記憶體114中分配用於衍生執行程序350的第二位址區段320。然後,在步驟S409-3中使用載入器120暫停執行衍生執行程序350,並且在步驟S409-5中將可執行內容162寫入至第二位址區段320中成為可執行內容162’。最後,在步驟S409-7中繼續執行衍生執行程序350。Then, the executable content is executed using the loader 120 in step S409. Specifically, in step S409-1, the operating system 118a is requested to establish a derivative execution program 350 for re-running the loader 120 in the main memory 114 and request the operating system 118a to be allocated for execution in the main memory 114. The second address section 320 of the program 350. Then, the execution execution program 350 is suspended using the loader 120 in step S409-3, and the executable content 162 is written into the second address portion 320 into the executable content 162' in step S409-5. Finally, the derivative execution program 350 continues to be executed in step S409-7.
如上所述,在本發明另一範例實施例中,步驟S409中可更包括判斷第二位址區段320的大小是否小於可執行內容162’的大小,並且倘若第二位址區段320的大小小於可執行內容162’的大小時請求作業系統118a在主記憶體114中更分配第三位址區段。As described above, in another exemplary embodiment of the present invention, step S409 may further include determining whether the size of the second address section 320 is smaller than the size of the executable content 162', and if the second address section 320 is The requesting operating system 118a is more likely to allocate a third address segment in the main memory 114 when the size is less than the size of the executable content 162'.
圖5是根據本發明第二範例實施例所繪示的檔案執行系統的概要方塊圖。FIG. 5 is a schematic block diagram of a file execution system according to a second exemplary embodiment of the present invention.
請參照圖5,第二範例實施例的檔案執行系統與第一範例實施例的檔案執行系統的不同之處在於第二範例實施例的檔案執行系統是配置自動執行檔502來自動地執行載入器120。具體來說,當儲存裝置150耦接至電腦主機110時,自動執行檔502會被自動地執行並且自動執行檔502會在主記憶體114中運轉載入器120。例如,在本範例實施例中,儲存裝置150更包括相容於ISO 9660標準的一特殊儲存區550,並且特殊儲存區550中儲存以autorun.inf之型式實作的自動執行檔502和載入器120,因此當儲存裝置150耦接至電腦主機110時作業系統118a會自動地執行自動執行檔502並由此運轉載入器120。特別是,使用者可於載入器120中預先設定欲執行的應用程式(例如,電腦執行碼組160),並且當載入器120運轉時,預先設定的應用程式即可自動地被執行。Referring to FIG. 5, the file execution system of the second exemplary embodiment is different from the file execution system of the first exemplary embodiment in that the file execution system of the second exemplary embodiment configures the automatic execution file 502 to automatically perform loading. 120. Specifically, when the storage device 150 is coupled to the host computer 110, the automatic execution file 502 is automatically executed and the automatic execution file 502 runs the loader 120 in the main memory 114. For example, in the present exemplary embodiment, the storage device 150 further includes a special storage area 550 compatible with the ISO 9660 standard, and the special storage area 550 stores the automatic execution file 502 and loading implemented in the form of autorun.inf. The operating system 118a automatically executes the automatic execution of the file 502 and thereby operates the loader 120 when the storage device 150 is coupled to the host computer 110. In particular, the user can pre-set the application to be executed (for example, the computer execution code group 160) in the loader 120, and when the loader 120 is running, the preset application can be automatically executed.
圖6是根據本發明第二範例實施例所繪示的檔案執行方法的流程圖。FIG. 6 is a flowchart of a file execution method according to a second exemplary embodiment of the present invention.
請參照圖6,首先,在步驟S601中將儲存裝置150連接至電腦主機110,並且在步驟S603中作業系統118a自動地執行自動執行檔502。之後,在步驟S605中載入器120被自動地執行並且在步驟S607中自動地執行隱藏儲存區152中的預設應用程式(例如,電腦執行碼組160),其中執行載入器120及執行儲存在隱藏儲存區152中之應用程式的步驟是相同於圖4的步驟S403、S405、S407、S409-1、S409-3、S409-5與S409-7,在此不重複描述。Referring to FIG. 6, first, the storage device 150 is connected to the computer host 110 in step S601, and the automatic execution file 502 is automatically executed by the work system 118a in step S603. Thereafter, the loader 120 is automatically executed in step S605 and the preset application (for example, the computer execution code group 160) in the hidden storage area 152 is automatically executed in step S607, in which the loader 120 is executed and executed. The steps of storing the application in the hidden storage area 152 are the same as steps S403, S405, S407, S409-1, S409-3, S409-5, and S409-7 of FIG. 4, and the description will not be repeated here.
在本發明另一範例實施例中,載入器120會於自動地執行預設之應用程式之後自動地關閉(即,結束載入器120的運作)。In another exemplary embodiment of the present invention, the loader 120 will automatically close (ie, end the operation of the loader 120) after automatically executing the preset application.
本發明範例實施例的檔案執行方法可實作為電腦可讀記錄媒體(或可程式儲存裝置)上的電腦可讀碼。電腦可讀記錄媒體可以是任何資料儲存裝置,其之後可藉由電腦系統讀取。電腦可讀記錄媒體的範例包括唯讀記憶體(read-only memory,ROM)、隨機存取記憶體(random-access memory,RAM)、CD-ROM、磁帶、軟碟、光學資料儲存裝置以及載波(例如透過網際網路的資料傳輸)。The file execution method of the exemplary embodiment of the present invention can be implemented as a computer readable code on a computer readable recording medium (or a programmable storage device). The computer readable recording medium can be any data storage device that can thereafter be read by a computer system. Examples of computer readable recording media include read-only memory (ROM), random-access memory (RAM), CD-ROM, magnetic tape, floppy disk, optical data storage device, and carrier wave. (for example, data transmission over the Internet).
綜上所述,本發明藉由載入器來讀取儲存裝置之隱藏儲存區中的電腦執行碼組,在電腦主機的主記憶體中將電腦執行碼組轉換為可執行內容,並且以置換之衍生執行程序來執行所轉換的可執行內容,由此可成功地在電腦主機上執行儲存在電腦主機無法存取之隱藏儲存區中的電腦執行碼組。再者,由於電腦執行碼組與對應電腦執行碼組的可執行內容是以非檔案型式暫存於主記憶體中,因此使用者無法輕易地複製與散佈儲存在隱藏儲存區中的電腦執行碼組。In summary, the present invention reads a computer execution code group in a hidden storage area of a storage device by a loader, converts a computer execution code group into executable content in a main memory of the computer host, and replaces The derivative execution program executes the converted executable content, thereby successfully executing the computer execution code group stored in the hidden storage area that the host computer cannot access on the host computer. Moreover, since the executable content of the computer execution code group and the corresponding computer execution code group is temporarily stored in the main memory in a non-file type, the user cannot easily copy and distribute the computer execution code stored in the hidden storage area. group.
雖然本發明已以實施例揭露如上,然其並非用以限定本發明,任何所屬技術領域中具有通常知識者,在不脫離本發明之精神和範圍內,當可作些許之更動與潤飾,故本發明之保護範圍當視後附之申請專利範圍所界定者為準。Although the present invention has been disclosed in the above embodiments, it is not intended to limit the invention, and any one of ordinary skill in the art can make some modifications and refinements without departing from the spirit and scope of the invention. The scope of the invention is defined by the scope of the appended claims.
100...檔案執行系統100. . . File execution system
110...電腦主機110. . . Computer host
112...中央處理單元112. . . Central processing unit
114...主記憶體114. . . Main memory
116...輸入與輸出單元116. . . Input and output unit
118...儲存單元118. . . Storage unit
118a...作業系統118a. . . working system
120...載入器120. . . Loader
122...主控單元122. . . Master unit
124...初始化單元124. . . Initialization unit
126...應用程式新增單元126. . . Application addition unit
128...應用程式編輯單元128. . . Application editing unit
130...應用程式刪除單元130. . . Application removal unit
132...應用程式執行單元132. . . Application execution unit
150...儲存裝置150. . . Storage device
152...隱藏儲存區152. . . Hidden storage area
154...一般儲存區154. . . General storage area
156...控制器156. . . Controller
158...快閃記憶體晶片158. . . Flash memory chip
160、160’...電腦執行碼組160, 160’. . . Computer execution code group
162、162’...對應電腦執行碼組的可執行內容162, 162’. . . Corresponding content of the computer execution code group
302、304...執行點302, 304. . . Execution point
310...第一位址區段310. . . First address section
320...第二地位區段320. . . Second status section
350...衍生執行程序350. . . Derivative executive
502...自動執行檔502. . . Automatic execution
550...特殊儲存區550. . . Special storage area
S403、S405、S407、S409-1、S409-3、S409-5、S409-7...檔案執行的步驟S403, S405, S407, S409-1, S409-3, S409-5, S409-7. . . File execution steps
S601、S603、S605、S607...檔案執行的步驟S601, S603, S605, S607. . . File execution steps
圖1是根據本發明第一範例實施例所繪示的檔案執行系統的概要方塊圖。1 is a schematic block diagram of a file execution system according to a first exemplary embodiment of the present invention.
圖2是根據本發明第一範例實施例所繪示的載入器的概要方塊圖。2 is a schematic block diagram of a loader according to a first exemplary embodiment of the present invention.
圖3是根據本發明第一範例實施例所繪示運轉載入器來執行隱藏儲存區中之電腦執行碼組時主記憶體的運作示意圖。FIG. 3 is a schematic diagram showing the operation of the main memory when the operation loader is executed to execute the computer execution code group in the hidden storage area according to the first exemplary embodiment of the present invention.
圖4是根據本發明第一範例實施例所繪示的檔案執行方法的流程圖。FIG. 4 is a flowchart of a file execution method according to a first exemplary embodiment of the present invention.
圖5是根據本發明第二範例實施例所繪示的檔案執行系統的概要方塊圖。FIG. 5 is a schematic block diagram of a file execution system according to a second exemplary embodiment of the present invention.
圖6是根據本發明第二範例實施例所繪示的檔案執行方法的流程圖。FIG. 6 is a flowchart of a file execution method according to a second exemplary embodiment of the present invention.
S403、S405、S407、S409-1、S409-3、S409-5、S409-7...檔案執行的步驟S403, S405, S407, S409-1, S409-3, S409-5, S409-7. . . File execution steps
Claims (20)
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW098121008A TWI497414B (en) | 2009-06-23 | 2009-06-23 | File executing method and system |
US12/542,167 US8667485B2 (en) | 2009-06-23 | 2009-08-17 | Method and system for executing a file stored in a hidden storage area of a storage device |
JP2009237080A JP2011008753A (en) | 2009-06-23 | 2009-10-14 | Method and system for executing file stored in hidden storage area of storage device |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
TW098121008A TWI497414B (en) | 2009-06-23 | 2009-06-23 | File executing method and system |
Publications (2)
Publication Number | Publication Date |
---|---|
TW201101182A TW201101182A (en) | 2011-01-01 |
TWI497414B true TWI497414B (en) | 2015-08-21 |
Family
ID=43355201
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW098121008A TWI497414B (en) | 2009-06-23 | 2009-06-23 | File executing method and system |
Country Status (3)
Country | Link |
---|---|
US (1) | US8667485B2 (en) |
JP (1) | JP2011008753A (en) |
TW (1) | TWI497414B (en) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
DE102010043445B3 (en) * | 2010-11-05 | 2012-04-19 | Semikron Elektronik Gmbh & Co. Kg | Capacitor assembly for power electronic apparatus, has spacer and electrical isolating capping material that are arranged such that capacitor is in non contact with metal structure |
CN102592085B (en) * | 2011-12-27 | 2015-09-16 | 中兴通讯股份有限公司 | A kind of wireless communication terminal and development method for safe operation |
US9239869B1 (en) * | 2013-05-08 | 2016-01-19 | Ca, Inc. | Replication and synchronization for protecting NTFS deduplication volumes |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI226609B (en) * | 2003-08-26 | 2005-01-11 | Mitac Technology Corp | Media instant play system and its method |
TWI283347B (en) * | 2000-09-15 | 2007-07-01 | Matrix Semiconductor Inc | Method for storing a file in a contiguous set of memory cells in a memory device, method for partitioning memory cells in a write-once memory device, method for writing file system structures of two file systems into a partition of memory cells of a ... |
TWI292125B (en) * | 2003-06-02 | 2008-01-01 | Alcor Micro Corp | |
TW200917256A (en) * | 2007-10-04 | 2009-04-16 | Super Talent Electronics Inc | Using various flash memory cells to build USB data flash cards with multiple partitions and autorun function |
Family Cites Families (38)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6141756A (en) | 1998-04-27 | 2000-10-31 | Motorola, Inc. | Apparatus and method of reading a program into a processor |
US7409694B2 (en) * | 1998-09-09 | 2008-08-05 | Microsoft Corporation | Highly componentized system architecture with loadable virtual memory manager |
US8434099B2 (en) * | 1998-09-09 | 2013-04-30 | Microsoft Corporation | Efficient linking and loading for late binding and platform retargeting |
US20020083318A1 (en) * | 2000-12-26 | 2002-06-27 | Larose Gordon Edward | Method and system for software integrity control using secure hardware assist |
US6778974B2 (en) * | 2001-02-02 | 2004-08-17 | Matrix Semiconductor, Inc. | Memory device and method for reading data stored in a portion of a memory device unreadable by a file system of a host device |
JP3513147B2 (en) * | 2002-05-29 | 2004-03-31 | 株式会社ハギワラシスコム | USB storage device and its control device |
JP3767818B2 (en) | 2002-10-28 | 2006-04-19 | 株式会社サスライト | Detachable device and program startup method |
US20040172526A1 (en) * | 2003-02-27 | 2004-09-02 | Tann Johnathan P. | Universal loader for portable electronic devices |
US20050010918A1 (en) * | 2003-07-11 | 2005-01-13 | International Business Machines Corporation | Autonomic image migration/deployment appliance |
US20050015540A1 (en) * | 2003-07-18 | 2005-01-20 | Hung-Chou Tsai | Auto-executable portable data storage device and the method of auto-execution thereof |
TWI282940B (en) * | 2003-12-02 | 2007-06-21 | Aimgene Technology Co Ltd | Memory storage device with a fingerprint sensor and method for protecting the data therein |
US8069192B2 (en) * | 2004-03-22 | 2011-11-29 | Microsoft Corporation | Computing device with relatively limited storage space and operating / file system thereof |
US7913248B1 (en) * | 2004-03-26 | 2011-03-22 | Adobe Systems Incorporated | System and method for installing one or more programs, and at least a portion of their environment |
TWI238355B (en) * | 2004-05-06 | 2005-08-21 | Lite On It Corp | Firmware updating method |
KR100604877B1 (en) * | 2004-07-03 | 2006-07-31 | 삼성전자주식회사 | Apparatus and method for controlling memory address mapping in embedded system |
US7712086B2 (en) * | 2004-12-15 | 2010-05-04 | Microsoft Corporation | Portable applications |
US8234638B2 (en) * | 2004-12-28 | 2012-07-31 | Hercules Software, Llc | Creating a relatively unique environment for computing platforms |
US20060294356A1 (en) * | 2005-06-27 | 2006-12-28 | Xipkey, Inc. | Apparatus and method of an executable-in-place flash device |
TWI263901B (en) * | 2005-07-28 | 2006-10-11 | Lite On Technology Corp | Program initiation methods and embedded systems utilizing the same |
US20070113279A1 (en) * | 2005-11-14 | 2007-05-17 | Phison Electronics Corp. | [portable storage device] |
US20070112979A1 (en) * | 2005-11-16 | 2007-05-17 | Phison Electronics Corp. | [portable storage device with auto-executable program] |
US20100174902A1 (en) * | 2005-12-23 | 2010-07-08 | Phison Electronics Corp. | Portable storage media with high security function |
US7849454B2 (en) * | 2006-01-13 | 2010-12-07 | Dell Products L.P. | Automatic firmware corruption recovery and update |
US8028148B2 (en) * | 2006-09-06 | 2011-09-27 | Microsoft Corporation | Safe and efficient allocation of memory |
JP5052878B2 (en) * | 2006-12-12 | 2012-10-17 | 株式会社バッファロー | Storage device and user authentication method |
KR101196431B1 (en) * | 2007-03-27 | 2012-11-01 | 삼성전자주식회사 | An external storage apparatus and method for executing automatically an external storage apparatus |
CN101286121B (en) | 2007-04-12 | 2011-04-06 | 深圳市顶星数码网络技术有限公司 | Method for installing computer drivers without optical disc |
EP2015194A1 (en) * | 2007-06-29 | 2009-01-14 | Thomson Licensing | Method for data transfer between host and device |
US20100050166A1 (en) * | 2008-08-22 | 2010-02-25 | Inventec Corporation | Updating system and method of portable executable programs |
TW201019113A (en) * | 2008-11-06 | 2010-05-16 | Genesys Logic Inc | Authenticable USB storage device and method thereof |
US8069324B2 (en) * | 2008-12-19 | 2011-11-29 | Seagate Technology Llc | Storage device with manual learning |
US8328104B2 (en) * | 2009-03-30 | 2012-12-11 | Condel International Technologies Inc. | Storage device management systems and methods |
TWI396994B (en) * | 2009-05-05 | 2013-05-21 | Phison Electronics Corp | Controller capable of preventing spread of computer viruses and storage system and metho thereof |
TWI462014B (en) * | 2009-08-31 | 2014-11-21 | Phison Electronics Corp | Method and system for executing applicaton programs, storage medium controller and stotage device |
US8276188B2 (en) * | 2009-12-03 | 2012-09-25 | Condel International Technologies Inc. | Systems and methods for managing storage devices |
US8555017B2 (en) * | 2010-02-22 | 2013-10-08 | Red Hat, Inc. | In-place physical to virtual (P2V) migration of an existing operating system during installation of a new operating system |
TWI421686B (en) * | 2010-04-12 | 2014-01-01 | Phison Electronics Corp | Data access method and system, storage medium controller and storage system |
TWI432987B (en) * | 2011-03-15 | 2014-04-01 | Phison Electronics Corp | Memory storage device, memory controller thereof, and method for virus scanning |
-
2009
- 2009-06-23 TW TW098121008A patent/TWI497414B/en active
- 2009-08-17 US US12/542,167 patent/US8667485B2/en active Active
- 2009-10-14 JP JP2009237080A patent/JP2011008753A/en active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI283347B (en) * | 2000-09-15 | 2007-07-01 | Matrix Semiconductor Inc | Method for storing a file in a contiguous set of memory cells in a memory device, method for partitioning memory cells in a write-once memory device, method for writing file system structures of two file systems into a partition of memory cells of a ... |
TWI292125B (en) * | 2003-06-02 | 2008-01-01 | Alcor Micro Corp | |
TWI226609B (en) * | 2003-08-26 | 2005-01-11 | Mitac Technology Corp | Media instant play system and its method |
TW200917256A (en) * | 2007-10-04 | 2009-04-16 | Super Talent Electronics Inc | Using various flash memory cells to build USB data flash cards with multiple partitions and autorun function |
Also Published As
Publication number | Publication date |
---|---|
US20100325180A1 (en) | 2010-12-23 |
JP2011008753A (en) | 2011-01-13 |
US8667485B2 (en) | 2014-03-04 |
TW201101182A (en) | 2011-01-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101650660B (en) | Booting a computer system from central storage | |
JP2007172586A (en) | Method, apparatus and computer program for sharing computer data among computers | |
US9164919B2 (en) | Method and apparatus for inputting/outputting virtual operating system from removable storage device on a host using virtualization technique | |
US20100077396A1 (en) | Portable storage device for supporting portable computing system and portable computing based system using the same | |
TW201025050A (en) | Device and method for filtering a file system | |
WO2018000300A1 (en) | Data operation method for electronic device, and electronic device | |
US9348819B1 (en) | Method and system for file data management in virtual environment | |
US20050044330A1 (en) | System, apparatus and method for controlling a storage device | |
TWI497414B (en) | File executing method and system | |
US8090927B2 (en) | Method and system for executing applicatons, storage medium controller and storage device | |
JP4714291B2 (en) | Information recording apparatus, information recording method, and information recording program | |
US20220374256A1 (en) | Information processing system, information processing apparatus, method of controlling the same, and storage medium | |
JP7522775B2 (en) | Non-volatile storage partition identifier | |
CN101944034B (en) | File executing method and system | |
RU2666334C2 (en) | Method of data processing | |
US9154543B2 (en) | Multiple file transfer speed up | |
JP5161989B2 (en) | Information recording apparatus, information recording method, and information recording program | |
US11853610B2 (en) | Pass-through command queues for unmodified storage drivers | |
WO2023077519A1 (en) | Storage device supporting multiple operation systems, and configuration method and computer system | |
US20090132228A1 (en) | Tape management method and tape management system | |
WO2008069480A1 (en) | Portable storage device for supporting portable computing system and portable computing based system using the same | |
EP4446886A1 (en) | Input/output processing of container application data by module addition | |
JP2010257250A (en) | Electronic device, storage area allocation method for file system, and storage area allocation program | |
JP2009110183A (en) | Computer startup method and computer system | |
JP5212289B2 (en) | Information processing system, application program, and storage medium |