The present invention relates generally to the elimination of base address collisions in computer software programs. More particularly, the present invention relates to dynamically setting the optimal base address of process components in order to eliminate base address collisions.
A computer's operating system, such as the Microsoft Windows operating system (“Windows”), may be configured to specify that each process have its own private virtual address space. By way of example, Windows uses a technique known as memory-mapping to load the components of a process (such as the executable file and any associated dynamic link libraries) from persistent storage (e.g., disk or tape) into memory (e.g., random access memory (“RAM”)). In order to allow memory-mapping to operate more efficiently, each component of a process may be assigned what is known as a preferred base address within the memory. As is known in the art, it is possible to set the base address of a component at design time.
While many developers do set base addresses at design time, this process does not ensure that a component will always load at its preferred base address. For example, an operating system may not be able to load a component of a process at its preferred base address if the operating system has already loaded some other process component at that address. If any component of the process cannot be loaded at its preferred base address, the operating system must perform additional logic to relocate that component to a different location in memory. The process of relocating a component consumes valuable time and memory resources.
Thus, there remains a need for ensuring that each component of a process loads at its preferred base address. There further remains a need for optimally determining the correct preferred base addresses of a component prior to run time.
The present invention meets the needs described above by providing systems and methods for attempting to ensure that all components of a process load at their preferred base addresses. In one embodiment, the present invention detects that a process has been loaded from persistent storage into memory. The present invention then determines if any of the components of the process have been relocated by the operating system to a memory address other than that component's preferred base address. In response to determining that a component's in-memory base address is not equivalent to the component's on-disk representation of the preferred base address, the present invention updates the on-disk representation to reflect the in-memory base address. The components of the process should thus load at their updated base addresses the next time the process is executed.
These and other aspects, features and advantages of the present invention may be more clearly understood and appreciated from a review of the following detailed description of the disclosed embodiments.
The present invention is directed to systems and methods for monitoring the initialization of a software process in order to determine if all of the components of the process load at their preferred base addresses. Should any component of the process load at a new base address, as opposed to its preferred base address, the on-disk representation of that component is updated to reflect the new base address.
The following description will hereinafter refer to the drawing, in which like numerals indicate like elements throughout the several figures. FIG. 1 and the following discussion are intended to provide a brief and general description of a suitable computing environment for implementing the present invention. Although the system shown in
The personal computer system 100 further includes a hard disk drive 127, a magnetic disk drive 128, e.g., to read from or write to a removable disk 129, and an optical disk drive 130, e.g., for reading a CD-ROM disk 131 or to read from or write to other optical media. The hard disk drive 127, magnetic disk drive 128, and optical disk drive 130 are connected to the system bus 123 by a hard disk drive interface 132, a magnetic disk drive interface 133, and an optical drive interface 134, respectively. The drives and their associated computer-readable media provide nonvolatile storage for the personal computer system 100. Although the description of computer-readable media above refers to a hard disk, a removable magnetic disk and a CD-ROM disk, it should be appreciated by those skilled in the art that other types of media that are readable by a computer system, such as magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, and the like, may also be used in the exemplary operating environment.
A number of program modules may be stored in the persistent storage devices (e.g., hard disk drive 127) and the memory 122 (e.g., RAM 125), including an operating system 135, one or more application program modules 136, and other program modules 137 and 138. Program modules 137 and 138 may comprise components of the application program module 136. An application program module is also referred to generally as a process. The methods of the present invention may also be implemented as a program module, referred to herein as Base Address Collision Monitoring Program Module 139, and comprising computer-executable instructions stored on a computer-readable medium of the computer system 100.
Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 121 through a serial port interface 146 that is coupled to the system bus 123, but may be connected by other interfaces, such as a game port or a universal serial bus (USB). A display device 147 is also connected to the system bus 123 via an interface, such as a video adapter 148. In addition to display device, personal computer systems typically include other peripheral output devices (not shown), such as speakers or printers.
The personal computer system 100 may operate in a networked environment using logical connections to one or more remote computer systems, such as a remote computer system 149. The remote computer system 149 may be a server, a router, a peer device or other common network node, and typically includes many or all of the elements described above relative to the personal computer system 100, although only a storage device 150 has been illustrated in FIG. 1. The logical connections depicted in
When used in a LAN networking environment, the personal computer system 100 is connected to the LAN 151 through a network interface 153. When used in a WAN networking environment, the personal computer system 100 typically includes a modem 154 or other means for establishing communications over the WAN 152, such as the Internet. The modem 154, which may be internal or external, is connected to the system bus 123 via the serial port interface 146. In a networked environment, program modules depicted relative to the personal computer system 100, or portions thereof, may be stored in the remote memory storage device. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computer systems may be used. It will be further appreciated that the invention could equivalently be implemented on host or server computer systems other than personal computer systems, and could equivalently be transmitted to the host computer system by means other than a CD-ROM, for example, by way of the network connection interface 153.
At step 208, a first component is selected from the list of components in the process. Then at step 210, a determination is made as to whether the in-memory base address of the selected component is equivalent to the on-disk representation of its preferred base-address. If the in-memory base address of the selected component is equivalent to the on-disk representation of its preferred base-address, the method advances to step 216 for a determination as to whether the selected component is the last component in the process. However, if at step 210 the in-memory base address of the selected component is determined not to be equivalent to the on-disk representation of its preferred base-address (i.e., the selected component has been relocated to a new in-memory base address due to a conflicting component having previously been loaded at the preferred base address of the selected component), the name of the conflicting component is determined at step 212.
From step 212, the method moves to step 214, where the name of the conflicting component, the relocated component's file name, the new in-memory base address of the relocated component and the original on-disk representation of the relocated component's preferred base address are persisted to a file for further processing and for reporting purposes (see FIG. 3). Next, at step 216 a determination is made as to whether the selected component is the last component in the process. If the selected component is not the last component in the process, the method returns to step 208 for selection of the next component. The method is repeated from step 208 to step 216, as previously described, until the selected component is determined to be the last component in the process. When the selected component is determined at step 216 to be the last component in the process, the method returns to step 202 to await detection that another process has been loaded into memory.
For example, while a component is loaded into memory, it is possible to rename the on-disk representation of the component, make a copy of the renamed on-disk representation of the component and then rename the copy back to the original component name. This technique causes the in-memory component and its associated on-disk representation to be assigned a new component name, while the original component name is assigned to a “new” on-disk representation of that component. The new on-disk representation of the component should no longer have an associated in-memory component, meaning that the preferred base address of the new on-disk representation can be modified. Subsequent calls by the operating system for the original component name, will cause the new on-disk representation to be loaded into the modified base address location.
Those skilled in the art will appreciate that other techniques may be employed to modify the preferred base address of an on-disk representation of a component. By way of example, a “copy-on-reboot” method may be employed. However, such a method may not be desirable because it requires that the computer system be restarted. In addition, the process(es) to which the component belongs may be terminated so that the on-disk representations can be modified.
Returning to
However, if it is determined at step 312 that the original relocated component name is no longer associated with an in-memory component, the renaming “trick” of steps 308-310 is deemed to have succeeded and the method proceeds to step 314 where the preferred base address of the on-disk representation having the original (i.e., selected) relocated component name is changed to match the new in-memory base address of that component (as determined from the file loaded at step 302). Those having ordinary skill in the art will know that the Microsoft Windows operating system provides the Application Programming Interface (API) call “RebaseImageEx” for the purpose of changing on-disk representations of base addresses. Other operating systems may provide similar API calls. Also familiar to those having ordinary skill in the art will be the necessity to bind the selected relocated component to its updated on-disk representation of its preferred base address. Windows provides the API call “BindImageEx” for the purpose of binding components to base addresses and other operating systems may provide similar API calls. At step 316, the selected relocated component is bound to its new preferred base address.
At step 318, a report file is written out for auditing purposes. Then, at step 320, a determination is made as to whether the selected relocated component is the last relocated component of the process. If the selected relocated component is not the last relocated component of the process, the method returns to step 304 for selection of the next relocated component. The method is repeated from step 304 to step 320, as previously described, until it is determined that the selected relocated component the last relocated component of the process. When the selected relocated component is determined at step 320 to be the last relocated component of the process, the method ends at step 322.
As may be seen from the foregoing, the present invention provides systems and methods for dynamically setting the optimal base address of a component of a process. After the optimal base address is set, the process may be loaded from persistent storage into memory without base address collisions. Those skilled in the art will appreciate that the foregoing description of the invention was provided by way of example only and that many other modifications, features, embodiments and operating environments of the present invention are possible. It should also be appreciated that the exemplary aspects of the present invention as described above are not intended to be interpreted as required or essential elements of the invention, unless explicitly stated otherwise.
The present application claims the benefit of U.S. Provisional Patent Application Ser. No. 60/265,684 filed Jan. 31, 2001, which is hereby incorporated by reference as if set forth fully herein.
Number | Name | Date | Kind |
---|---|---|---|
4314342 | McNeir et al. | Feb 1982 | A |
4758951 | Sznyter, III | Jul 1988 | A |
5119291 | Flannagan et al. | Jun 1992 | A |
5535399 | Blitz et al. | Jul 1996 | A |
5875487 | Schwartz et al. | Feb 1999 | A |
5940868 | Wagner | Aug 1999 | A |
5943066 | Thomas et al. | Aug 1999 | A |
5960466 | Belgard | Sep 1999 | A |
6047362 | Zucker | Apr 2000 | A |
6061773 | Harvey et al. | May 2000 | A |
6065104 | Tng | May 2000 | A |
6105117 | Ripley | Aug 2000 | A |
6205580 | Hirose | Mar 2001 | B1 |
6253258 | Cohen | Jun 2001 | B1 |
6304951 | Mealey et al. | Oct 2001 | B1 |
6681329 | Fetkovich et al. | Jan 2004 | B1 |
20020073082 | Duvillier et al. | Jun 2002 | A1 |
Number | Date | Country | |
---|---|---|---|
20020124150 A1 | Sep 2002 | US |
Number | Date | Country | |
---|---|---|---|
60265684 | Jan 2001 | US |