A method and system are provided for updating an utilizing the contents of a non-essential region in a memory device in a computer system. A computer program is utilized to build an image file. The image file may include program code and data for operating a computer system. The image file includes an essential region for storing program code required to boot the computer system and a non-essential region for storing program code and data which is not required to boot the computer system. The non-essential program code may include graphics data, a language module, or diagnostic tools for the computer system. After building the image file, the image file is then copied to a memory device in the computer system. Finally, only the non-essential region in the memory device is updated. A method may also be utilized to execute program code contained in the non-essential region prior to executing program code contained in the essential region.
|
10. A computer-implemented method for updating and utilizing the contents of a non-essential region in a non-volatile memory device, the computer-implemented method comprising:
maintain a list of modules to be executed;
searching the non-essential region in the non-volatile memory device for at least one module identified in the list, wherein the non-volatile memory device comprises a plurality of modules containing program code for the computer system, wherein the at least one module in the non-essential region does not contain boot code;
upon finding the at least one module in the non-essential region, executing the program code in the at least one module from the non-essential region, wherein the at least one module in the non-essential region contains an updated version of the program code for the computer system;
upon not finding the at least one module in the non-essential region, searching an essential region in the non-volatile memory device for the at least one module, wherein the at least one module in the essential region contains a current version of the program code for the computer system, wherein the at least one module in the essential region does not contain boot code; and
upon finding the at least one module in the essential region, executing the program code in the at least one module found in the essential region.
1. A computer-readable storage medium that is not a signal having computer-executable instructions stored thereon that, when executed by a computer system, cause the computer system to:
maintain a list of modules to be executed by the computer system;
search for at least one module identified in the list in a non-essential region in a non-volatile memory device included within the computer system, wherein the non-volatile memory device comprises a plurality of modules containing program code for the computer system, wherein the at least one module in the non-essential region does not contain boot code;
upon finding the at least one module in the non-essential region, execute the program code in the at least one module from the non-essential region of the non-volatile memory device, wherein the at least one module in the non-essential region contains an updated version of the program code for the computer system;
upon not finding the at least one module in the non-essential region, search an essential region in the non-volatile memory device for the at least one module, wherein the at least one module in the essential region contains a current version of the program code for the computer system, wherein the at least one module in the essential region does not contain boot code; and
upon finding the at least one module in the essential region, execute the program code in the at least one module found in the essential region.
16. A computer system, comprising:
a non-volatile memory device comprising a plurality of modules containing program code for the computer system and having a non-essential region;
a memory for storing a program containing code for updating and utilizing the contents of the non-essential region in the non-volatile memory device; and
a processor, functionally coupled to the memory and the non-volatile memory device, wherein the processor is responsive to computer-executable instructions contained in the program and configured to
maintain a list of modules to be executed on the computer system;
search the non-essential region in the non-volatile memory device included within the computer system for at least one module identified in the list, wherein the at least one module in the non-essential region does not contain boot code,
upon finding the at least one module in the non-essential region, to execute the program code in the at least one module found in the non-essential region, wherein the at least one module in the non-essential region contains an updated version of the program code for the computer system,
upon not finding at least one module in the non-essential region, search an essential region in the non-volatile memory device for the at least one module, wherein the at least one module in the essential region contains a current version of the program code for the computer system, wherein the at least one module in the essential region does not contain boot code, and
upon finding the at least one module in the essential region, execute the program code in the at least one module found in the essential region.
2. The computer-readable storage medium of
3. The computer-readable storage medium of
upon not finding the at least one module in the essential region, determine if there is at least one more module identified in the list to be found; and
upon determining that there is at least one more module to be found, search the non-essential region to find the at least one more module.
4. The computer-readable storage medium of
5. The computer-readable storage medium of
6. The computer-readable storage medium of
7. The computer-readable storage medium of
8. The computer-readable storage medium of
9. The computer-readable storage medium of
11. The computer-implemented method of
upon not finding the at least one module in the essential region, determining based upon the list if there is at least one more module to be found; and
upon determining that there is at least one more module to be found, searching the non-essential region to find the at least one more module.
12. The computer-implemented method of
13. The computer-implemented method of
14. The computer-implemented method of
15. The computer-implemented method of
17. The computer system of
upon not finding the at least one module in the essential region, determine based upon the list if there is at least one more module to be found; and
upon determining that there is at least one more module to be found, search the non-essential region to find the at least one more module.
18. The computer system of
19. The computer system of
20. The computer system of
|
This application is a continuation of U.S. patent application Ser. No. 10/736,380 filed Dec. 15, 2003, entitled “Method, System, and Computer Readable Medium for Updating and Utilizing the Contents of a Non-Essential Region of a Memory Device,” now U.S. Pat. No. 7,536,536, which is expressly incorporated herein in its entirety by reference.
The present invention is related to computer system configuration. More particularly, the present invention is related to partially updating an image in a memory device.
Some computer systems have a firmware basic input/output system (“BIOS”) containing basic routines which are accessed to boot the computer as well as to initialize and interface hardware with operating system software. The BIOS code is stored as groups of memory “blocks” in one or more non-volatile memory devices. These groups of memory blocks which are stored in the non-volatile memory devices are collectively known as an image. In many modern computer systems, the non-volatile memory devices are re-programmable. These re-programmable memory devices, which are typically known as “flash” memory devices or parts, are a type of non-volatile random access memory (“NVRAM”) that allows the BIOS code to be updated by using software to erase and program each flash memory device.
The image stored in a flash memory device is typically divided into at least two main sections or regions. One such region is known as the “boot block” region and contains the first program code executed by the computer system after it is turned on. Another region is known as the “main BIOS” region which is built as a single unit and includes the program code for the power-on self test (“POST”) portion of the computer startup sequence as well as for managing computer system resources when the computer is running (i.e., “runtime”). The main BIOS region of the image may also contain optional program code and data which is not essential to the computer startup or runtime sequences. This “non-essential” program code may include language modules for providing foreign language support in the computer system or a graphic image which may be displayed to a user during the computer startup sequence.
Occasionally a user may wish to update only a portion of the code in the main BIOS region without having to re-program the entire region. For example, a user may wish to add custom graphics data so that a picture of the user is displayed instead of a default graphic provided by the manufacturer of the computer startup sequence. However, updating this region in a memory device currently requires creating an entirely new image and re-programming each memory block in the main BIOS region, regardless of whether each block actually needs updating. Thus, in updating the main BIOS region, blocks remaining unchanged from a previous version would still be updated by the conventional update process. Furthermore, since the main BIOS region of an image is built as a single unit, errors or corrupted data in even non-essential program modules may cause the computer system to become unbootable.
It is with respect to these considerations and others that the present invention has been made.
In accordance with the present invention, the above and other problems are solved by a method and system for updating and utilizing the contents of a non-essential region of one or more flash memory devices in a computer system. The non-essential region may include non-essential BIOS code or data for the computer system.
According to the method, a computer program is utilized to build an image file. The image file may include critical program code and data for operating a computer system. The image file defines a non-essential region for storing non-essential program code and data which is not required to boot the computer system. After building the image file, the image file is then copied to a memory device in the computer system. Finally, only the non-essential region is updated in the memory device. The method may further include executing the program code in the non-essential region of the memory device prior to executing the critical program code. The non-essential region may include one or more non-essential blocks for storing program code and data. The non-essential blocks may be updated in the memory device by mapping each non-essential block to one or more reserved sectors in the memory device. Each non-essential block may also be mapped to a portion of a sector in the memory device. Each non-essential block may include a header and one or more modules. The header may include a pointer to a first module in the non-essential block. Each module may include a module header and module data. The module data may include program code or data. The data included in each module may be a graphics data, a language module, or diagnostic tools for the computer system.
According to another method, a computer program routine utilizes a non-essential region in a memory device for executing updated program code in a computer system. The memory device may store a BIOS image for the computer system. The BIOS image may include program code for starting and operating the computer system. The memory device is divided into an essential region and a non-essential region. The essential region of the memory device may include modules storing current program code for the BIOS image. The non-essential region of the memory device may include modules storing updated program code for the BIOS image. When the computer system is started, the routine first searches the non-essential region in the memory device for one or more modules containing program code to execute. If the modules are found in the non-essential region, then the updated program code in these modules is executed. If the modules are not found, then the routine searches the essential region in the memory device for the modules. If the modules are found in the essential region, then the current program code in these modules is executed. The routine may search for a header contained in each module to identify the module.
In accordance with other aspects, the present invention relates to a computer system for updating and utilizing the contents of a non-essential region in a memory device. The computer system includes a memory device for storing an image file. The image file includes a non-essential region for storing non-essential program code and data. The computer system also includes a memory for storing a program containing code for updating the memory device. The computer system further includes a processor, functionally coupled to the memory and associated with the memory device. The processor is responsive to computer-executable instructions contained in the program and operative to copy the image file to the memory device and update only the non-essential region in the memory device.
Aspects of the invention may be implemented as a computer process, a computing system, or as an article of manufacture such as a computer program product or computer-readable medium. The computer program product may be a computer storage media readable by a computer system and encoding a computer program of instructions for executing a computer process. The computer program product may also be a propagated signal on a carrier readable by a computing system and encoding a computer program of instructions for executing a computer process.
These and various other features as well as advantages, which characterize the present invention, will be apparent from a reading of the following detailed description and a review of the associated drawings.
Embodiments of the present invention provide a method, system, and computer-readable medium for updating and utilizing the contents of a non-essential region in one or more memory devices in a computer system. In the following detailed description, references are made to the accompanying drawings that form a part hereof, and in which are shown by way of illustrating specific embodiments or examples. Referring now to the drawings, in which like numerals represent like elements through the several figures, aspects of the present invention and the exemplary operating environment will be described.
Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Turning now to
The ROM 10 further comprises a memory device 11 which may store a basic input/output system (“BIOS”) or other program code or data. As is known to those skilled in the art, the BIOS includes basic routines that help to transfer information between elements within a computer. These basic routines are accessed to boot the CPU as well as to initialize and interface hardware with operating system software. One such routine is the power-on self test (“POST”) routine. The POST routine is executed after the computer is turned on for performing diagnostics and initializing system components. It will be appreciated that the contents of the memory device 11 may be organized as multiple blocks or sectors in which are stored the program code or data. It will be further appreciated that the memory device 11 may be a re-programmable or “flash” memory device. As is known to those skilled in the art, flash memory devices enable blocks of data to be erased and reprogrammed so that data can be easily updated. The contents of the memory device 11 will be described in greater detail below with respect to
The computer system 2 further includes a mass storage device 14 for storing an operating system 16, an update utility 29, a build utility 30, an image file 31, an update file 32, and other application programs 36. The mass storage device 14 is connected to the CPU 4 through a mass storage controller (not shown) connected to the bus 13. The mass storage device 14 and its associated computer-readable media, provide non-volatile storage for the computer system 2. Although the description of computer-readable media contained herein refers to a mass storage device, such as a hard disk or CD-ROM drive, it should be appreciated by those skilled in the art that computer-readable media can be any available media that can be accessed by the computer system 2.
By way of example, and not limitation, computer-readable media may comprise computer storage media and communication media. Computer storage media includes volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, DVD, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer.
According to various embodiments of the invention, the computer system 2 may operate in a networked environment using logical connections to remote computers through the network 18. The computer system 2 may connect to the network 18 through a network interface unit 20 connected to the bus 13. It should be appreciated that the network interface unit 20 may also be utilized to connect to other types of networks and remote computer systems. The computer system 2 may also include an input/output controller 22 for receiving and processing input from a number of devices, including a keyboard, mouse, or electronic stylus (not shown in
As discussed briefly above, the mass storage device 14 stores the build utility 30 and the update utility 29. The build utility 30 includes program code for defining the layout of content (i.e., program code and data) in the image file 31. The update utility 29 includes program code and/or data for updating the memory device 11 with new content such as the image file 31 and the update file 32. The image file 31 and the update file 32 may be utilized to update or add new functionality to the BIOS in the memory device 11. The layout of the image file 31 will be described in greater detail with respect to
According to various embodiments of the invention, the computer system 2 may operate in a networked environment using logical connections to remote computers through the network 18. The computer system 2 may connect to the network 18 through a network interface unit 20 connected to the bus 13. It should be appreciated that the network interface unit 20 may also be utilized to connect to other types of networks and remote computer systems. The computer system 2 may also include an input/output controller 22 for receiving and processing input from a number of devices, including a keyboard, mouse, or electronic stylus (not shown in
The main BIOS region 40 follows the boot block region 37 and contains the POST and runtime program code of the BIOS. It will be appreciated that the locations of the main BIOS region 40 and the non-essential region 50 in the image file 31 may be arbitrary. That is, the non-essential region 50 may be placed above the main BIOS region 40 or vice-versa. It will further be appreciated that the image file 31 may include more than one non-essential region 50.
As is known to those skilled in the art, the program code in the main BIOS region 40 may be stored as a linked list of executable modules. Each module is prefaced with a header that contains a pointer to the next module in the list. It will be appreciated that the ordering of the modules in the list may be arbitrary as each module is identified by an identification code stored in its header.
The non-essential region 50 follows the main BIOS region 40. In one embodiment of the invention, the non-essential region 50 contains non-essential or optional blocks such that, in their absence, the program code in the boot block 37 and the main BIOS region 40 required for booting the CPU (e.g., the POST program code) will still execute. The contents of the non-essential blocks in the non-essential region 50 may include, but are not limited to, option ROM for onboard devices, graphics data, language modules, setup clients, and user-defined modules. It will be appreciated that when the image file 31 is built, the non-essential region 50 is defined to be independent of the main BIOS region 40. That is, none of the program code in the main BIOS region 40 is linked to the optional program code in the non-essential region 50. The contents of the non-essential region 50 will be discussed in greater detail in the description of
It will be appreciated that the non-essential blocks may be stored in one or more sectors depending on the sector size relative to the size of each non-essential block (including the header) when the BIOS program code is updated. For example, if the size of a non-essential block is 128 kilobytes and the size of each of the sectors in the memory device 11 is 64 kilobytes, then the non-essential block would be stored in both of the sectors 97-98. If will further be appreciated that multiple non-essential blocks may be stored in a single sector if their combined size is less than a sector size minus a paragraph multiple (i.e., 16 bytes). For example, if the combined size of three non-essential blocks is 48 kilobytes and the size of the sector 97 in the memory device 11 is 64 kilobytes, then all three of the non-essential blocks may be stored in the sector 97.
It will be appreciated by those skilled in the art that memory space in a computer system may be allocated into “paragraphs.” For example, the 8086 processor architecture divides a 1 MB address space into paragraphs of 16 bytes each. Each paragraph may be uniquely identified by a 16-bit “paragraph address.” The 8086 processor addressing model further defines 65,536 (64 kilobyte) “segments,” each starting on a paragraph boundary identified by a 16-bit “segment register.” Under the 8086 memory allocation scheme, all memory is allocated in multiples of 16 bytes such that all memory segments can be identified by a paragraph address and the full 1 MB address space can be dynamically allocated.
Turning now to
After the image file 31 is copied to the memory device 11, the logical operations 700 then continue from operation 710 to operation 715 where the update utility 31 is utilized to update the non-essential region in the memory device 11 with program code and/or data contained in the update file 32. It will be appreciated that, similar to the image file 31, the update file 32 may contain non-essential program code and/or data in blocks. In updating the memory device 11, only the non-essential sectors 97 and 98 in the memory device 11 are re-programmed. An illustrative operational flow for updating the non-essential sectors in the memory device 11 will be described in greater detail with respect to
Continuing now with
In an alternative embodiment of the invention, the non-essential region may also be utilized for executing updated modules containing program code for the main BIOS region. In this embodiment, the BIOS program code may be updated to first look for and execute modules in the non-essential region (i.e., by searching for a specific module identification in the header of each module) and then in the main BIOS region. In this manner, updated modules for the main BIOS region may be executed without having to update the entire main BIOS region. Furthermore, by placing updated modules in the non-essential region, the program code in the essential region will still execute in the event the program code in the non-essential region is corrupted.
After the BIOS program code has started executing at operation 902, the logical operations 900 continue from operation 902 to operation 905 where a routine in the BIOS program code searches the non-essential region in the memory device 11 for a module in the linked list. The logical operations 900 then continue from operation 905 to operation 910. At operation 910, if the module being searched for is found, the logical operations 900 continue from operation 910 to operation 915 where the updated version of the program code contained in the module is executed. It will be appreciated that a module may be found or identified from the module header contained in each module. The logical operations 900 then continue from operation 915 to operation 935 where the routine determines if there are any more modules to be found (i.e., more modules in the linked list). If it is determined at operation 935 that there are more modules to be found, the logical operations 900 return from operation 935 to operation 905 to search the non-essential region for the module. If it is determined at operation 935 that there are no more modules to be found then the logical operations 900 then end.
If at operation 910, the module being searched for is not found, then the logical operations 900 continue from operation 910 to operation 920 where the routine in the BIOS program code searches the essential region in the memory device 11 for the module in the linked list. It will be appreciated that a module may be found or identified from the module header contained in each module. The logical operations 900 then continue from operation 920 to operation 925. At operation 925, if the module being searched for is found, the logical operations 900 continue from operation 925 to operation 930 where the current version of the program code contained in the module is executed. The logical operations 900 then end. If at operation 925, the module being searched for is not found, then the logical operations 900 continue to operation 935 where the routine determines if there are any more modules to be found (i.e., more modules in the linked list). If it is determined at operation 935 that there are more modules to be found, the logical operations 900 return from operation 935 to operation 905 to search the non-essential region for the module where the routine continues to the next module in the linked list. The logical operations 900 then return from operation 935 to operation 905 where the routine searches for the module in the non-essential region. If it is determined at operation 935 that there are no more modules to be found then the logical operations 900 then end.
As discussed above, embodiments of the present invention enable the update and utilize the contents of a non-essential region in one or more memory devices in a computer system. The non-essential region may be updated using an update utility without effecting critical program code in other regions of the image. Although the invention has been described in language specific to computer structural features, methodological acts and by computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific structures, acts or media described. Therefore, the specific structural features, acts and mediums are disclosed as exemplary embodiments implementing the claimed invention.
The various embodiments described above are provided by way of illustration only and should not be construed to limit the invention. Those skilled in the art will readily recognize various modifications and changes that may be made to the present invention without following the example embodiments and applications illustrated and described herein, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.
Patent | Priority | Assignee | Title |
10615967, | Mar 20 2014 | Microsoft Technology Licensing, LLC | Rapid data protection for storage devices |
8874935, | Aug 30 2011 | Microsoft Technology Licensing, LLC | Sector map-based rapid data encryption policy compliance |
9430220, | Jul 22 2014 | GM Global Technology Operations LLC | Method, medium, and apparatus for re-programming flash memory of a computing device |
9430664, | May 20 2013 | Microsoft Technology Licensing, LLC | Data protection for organizations on computing devices |
9477614, | Aug 30 2011 | Microsoft Technology Licensing, LLC | Sector map-based rapid data encryption policy compliance |
9740639, | Aug 30 2011 | Microsoft Technology Licensing, LLC | Map-based rapid data encryption policy compliance |
9825945, | Sep 09 2014 | Microsoft Technology Licensing, LLC | Preserving data protection with policy |
9853812, | Sep 17 2014 | Microsoft Corporation | Secure key management for roaming protected content |
9853820, | Jun 30 2015 | Microsoft Technology Licensing, LLC | Intelligent deletion of revoked data |
9900295, | Nov 05 2014 | Microsoft Technology Licensing, LLC | Roaming content wipe actions across devices |
9900325, | Oct 09 2015 | Microsoft Technology Licensing, LLC | Passive encryption of organization data |
Patent | Priority | Assignee | Title |
5864698, | Aug 24 1994 | NEC Corporation | Disk based bios |
6581157, | Apr 26 1999 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | System and method for detecting and updating non-volatile memory on an electronic adapter board installed in a computing system |
6665813, | Aug 03 2000 | International Business Machines Corporation | Method and apparatus for updateable flash memory design and recovery with minimal redundancy |
6892297, | Mar 16 2000 | LENOVO SINGAPORE PTE LTD | Method and system for searching an updated version of boot code for updating current running boot code prior to loading an operating system |
6990577, | Aug 10 2001 | Intel Corporation | Updating a BIOS image by replacing a portion of the BIOS image with a portion of another BIOS image |
7017040, | Dec 04 2003 | Intel Corporation | BIOS update file |
7536536, | Dec 15 2003 | American Megatrends, Inc. | Method, system, and computer readable medium for updating and utilizing the contents of a non-essential region of a memory device |
20030110472, | |||
20030167373, | |||
20040088534, | |||
20060080650, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 26 2003 | DIAZ, JUAN F | American Megatrends, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022503 | /0273 | |
Dec 03 2003 | JOSHI, ANAND | American Megatrends, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022503 | /0273 | |
Mar 27 2009 | American Megatrends, Inc. | (assignment on the face of the patent) | / | |||
Feb 11 2019 | American Megatrends, Inc | AMERICAN MEGATRENDS INTERNATIONAL, LLC | ENTITY CONVERSION | 049091 | /0973 | |
Apr 01 2019 | AMERICAN MEGATRENDS INTERNATIONAL, LLC | MIDCAP FINANCIAL TRUST, AS COLLATERAL AGENT | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 049087 | /0266 | |
Oct 17 2024 | MIDCAP FINANCIAL TRUST | AMERICAN MEGATRENDS INTERNATIONAL, LLC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 069205 | /0795 |
Date | Maintenance Fee Events |
Mar 27 2017 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
May 24 2021 | REM: Maintenance Fee Reminder Mailed. |
Nov 08 2021 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Oct 01 2016 | 4 years fee payment window open |
Apr 01 2017 | 6 months grace period start (w surcharge) |
Oct 01 2017 | patent expiry (for year 4) |
Oct 01 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Oct 01 2020 | 8 years fee payment window open |
Apr 01 2021 | 6 months grace period start (w surcharge) |
Oct 01 2021 | patent expiry (for year 8) |
Oct 01 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Oct 01 2024 | 12 years fee payment window open |
Apr 01 2025 | 6 months grace period start (w surcharge) |
Oct 01 2025 | patent expiry (for year 12) |
Oct 01 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |