|Publication number||US7870543 B2|
|Application number||US 11/608,629|
|Publication date||Jan 11, 2011|
|Filing date||Dec 8, 2006|
|Priority date||Dec 8, 2006|
|Also published as||US20080136832|
|Publication number||11608629, 608629, US 7870543 B2, US 7870543B2, US-B2-7870543, US7870543 B2, US7870543B2|
|Original Assignee||Hewlett-Packard Development Company, L.P.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (17), Classifications (11), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
The present invention relates generally to software and computer systems.
2. Description of the Background Art
A program environment typically includes an array of environment variables that are made available when a process begins. A general purpose of such environment variables is to customize or tune the dynamic behavior of the programs in which they are used. For example, the C/C++ programming language provides the ability to adjust a program's run-time behavior through the use of environment variables.
Environment variables may be queried by an application, such that the behavior of the application varies based on their values. As such, environment variables provide a static mechanism for tuning user-space components.
There are problems and limitations, however, in using environment variables to perform dynamic tuning of user-space components. Dynamic tuning of user-space components refers to modifying the behavior of a user-space process after startup time, i.e. while the process is executing.
Environment variables are generally effective for all programs running in an environment. In other words, modifying an environment variable affects the behavior of all programs using that variable in the environment. Hence, an environment variable cannot be used to dynamically tune a specific instance of an application without affecting other executing programs which also use that same variable.
Besides environment variables, another technique for dynamic tuning of user-space components involves allocating a shared memory segment at startup time by the process to be tuned. Subsequently, a tool program may connect to the shared memory segment to modify configuration data therein for the purpose of the dynamic tuning. Unfortunately, allocating shared memory segments is expensive in terms of resources. Furthermore, this solution is not well suited for system shared libraries.
Yet another technique for dynamic tuning in user-space may be to send some signal that causes a signal handler in user-space to read the configuration data. However, this solution leads to the restriction that these signals cannot be used for other (“real”) application needs. Moreover, this solution is not practical for system shared libraries.
One embodiment relates to a method for dynamic tuning of a user-space process. The method attaches to the user-space process. Load-time and compile-time base addresses of a data section of an object to be tuned are read. An offset to a symbol to be tuned is determined, and an effective address of the symbol is computed. A new value of the symbol is then written.
Another embodiment relates to an apparatus for dynamic tuning of a user-space process. The apparatus includes processor-executable code. Processor-executable code is configured to attach to the user-space process, and to read load-time and compile-time base addresses of a data section of an object to be tuned. In addition, processor-executable code is configured to determine an offset to a symbol to be tuned, to compute an effective address of the symbol, and to write a new value for the symbol.
Other embodiments and features are also disclosed.
The present disclosure provides an advantageous technique for performing dynamic user-space tuning.
Example Computer System
An embodiment of the invention may be implemented in the context of a computer system, such as, for example, the computer system 60 depicted in
The computer system 60 may be configured with a processing unit 62, a system memory 64, and a system bus 66 that couples various system components together, including the system memory 64 to the processing unit 62. The system bus 66 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures.
Processor 62 typically includes cache circuitry 61, which includes cache memories having cache lines, and pre-fetch circuitry 63. The processor 62, the cache circuitry 61 and the pre-fetch circuitry 63 operate with each other as known in the art. The system memory 64 includes read only memory (ROM) 68 and random access memory (RAM) 70. A basic input/output system 72 (BIOS) is stored in ROM 68.
The computer system 60 may also be configured with one or more of the following drives: a hard disk drive 74 for reading from and writing to a hard disk, a magnetic disk drive 76 for reading from or writing to a removable magnetic disk 78, and an optical disk drive 80 for reading from or writing to a removable optical disk 82 such as a CD ROM or other optical media. The hard disk drive 74, magnetic disk drive 76, and optical disk drive 80 may be connected to the system bus 66 by a hard disk drive interface 84, a magnetic disk drive interface 86, and an optical drive interface 88, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the computer system 60. Other forms of data storage may also be used.
A number of program modules may be stored on the hard disk, magnetic disk 78, optical disk 82, ROM 68, and/or RAM 70. These programs include an operating system 90, one or more application programs 92, other program modules 94, and program data 96. The other program modules 94 may include utility programs and library modules, for example.
The operating system 90 may be configured with a memory manager 120. The memory manager 120 may be configured to handle allocations, reallocations, and de-allocations of RAM 70 for one or more application programs 92, other program modules 94, or internal kernel operations. The memory manager may be tasked with dividing memory resources among these executables.
A user may enter commands and information into the computer system 60 through input devices such as a keyboard 98 and a mouse 100 or other input devices. These and other input devices are often connected to the processing unit 62 through a serial port interface 102 that is coupled to the system bus 66, but may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB). A monitor 104 or other type of display device may also be connected to the system bus 66 via an interface, such as a video adapter 106. In addition to the monitor, personal computers typically include other peripheral output devices (not shown) such as speakers and printers. The computer system 60 may also have a network interface or adapter 108, a modem 110, or other means for establishing communications over a network (e.g., LAN, Internet, etc.).
Dynamic Tuning of a User-Space Process
The method 200 may be performed by a software application tool that enables a system administrator or other user to dynamically tune such user-space processes. The software application tool may be one of the application programs 92 depicted in
In Unix-type operating systems, two modes of operation are typically provided: user mode and kernel mode. Kernel mode is a more privileged mode of operation, while user mode is a more protected mode of operation. A process executed in user mode operates in user space, while a process executed in kernel mode operates in kernel space.
At compile time 300, the text 302 of the object begins at a compile-time base address 301. The data section 304 begins at a compile-time base address 303 which is offset from the compile-time base address 301. Schematically shown within the data section 304 are example variables a, b, and c. These are located at offsets to the compile-time base address 303 of the data section 304.
At load time 310, the text 302 of the object begins at a load-time base address 311 in the virtual memory space of the process. The data section 304 begins at a load-time base address 313 which is offset from the load-time base address 311. The example variables a, b, and c are again schematically shown within the data section 304. These variables are located at offsets to the load-time base address 313 of the data section 304.
The software tool then attaches 202 to the selected user-space process while it is running. Attaching 202 to the process enables the software tool to access the user address space for that process. Advantageously, there is no need to restart the process to perform this dynamic tuning.
If objects that are tunable are to include shared libraries, then dynamic load information may be read 204 from the process executable. Using this dynamic load information, a list of the shared libraries used by the process may then be read 206. This list of shared libraries may be displayed via a user interface to the system administrator or other user. Otherwise, if the objects that are tunable do not include shared libraries, then these steps 204 and 206 are unnecessary and may be skipped.
Thereafter, the load-time base address 313 of the data section 304 of the object to be tuned may be read (or determined) 208. This base address 313 indicates the location of the data section 304 of the object within the virtual memory space of the process.
The symbol table of the object may then be read 210. The symbol table provides the symbols used in the object, whether the object is a shared library or the process executable. In one specific implementation, reading of the full symbol table is not needed, and the reading may stop once the symbol to be tuned is located.
The compile-time base address 303 of the data section 304 of the object may then be read (or determined) 212. This base address 303 indicates the location of the data section 304 of the object at compile time.
The offset to the selected tunable may then be read 214. The offset indicates the location of the tunable relative to the base address of the data section. The offset is the same at compile time and at load time.
A computation 216 may then be made as to the effective address of the tunable. The effective address of the tunable is the tunable's address in virtual memory space. The effective address may be computed as equal to the load-time base address 313 of the data section plus the offset to the tunable.
Once the effective address for the tunable is determined, then a new value may be written 218 for that tunable. The new value may be input, for example, by a user via a user interface for the software tool. The new value for the tunable is then advantageously utilized by the process so as to adjust its behavior while the process is running, without the need to restart the process. When the tuning of the process is finished, the software tool may then detach 220 for the process.
For example, one particular implementation of a command-line-based user interface for the software tool may have a usage structure as follows.
Usage: dytune -t <tunable> [-p <exe_path> -v <new_value> -s <bytes>] <pid>
where the command line tool is named “dytune” (for dynamic tuning), “tunable” refers to the name of the tunable variable, “exe_path” refers to the optional path to the executable being dynamically tuned, “new_value” refers to the optional new value for the tunable variable, “bytes” refers to the optional size of the new_value, and “pid” refers to the process identifier for the instance of the executable which is being dynamically tuned. In this particular implementation, the default number of “bytes” is four.
The following is a first specific usage example. In this example, the tunable variable “spin_limit” is read (but not changed) for the process having pid 7854 where the path to the executable is “/tmp/a.out”.
$ dytune -t spin_limit_-p /tmp/a.out 7854 Attached to pid <7854> Working on target ‘/tmp/a.out’ using libpthread </usr/lib/hpux32/libpthread.so.1> .. The tunable <spin_limit> is currently set to <1> Detaching from pid <7854> $
As seen from the above, after the command is entered, the tool reports that it has attached to pid 7854, then that it is working on the target executable file “/tmp/a.out” using a particular pthread library. The tool then reports that the tunable “spin_limit” is currently set to the value 1. The tool then detaches from the process.
The following is a second specific usage example. In this example, the tunable variable “spin_limit” is changed to a new value for the process having pid 7854, where the path to the executable is “/tmp/a.out”, and the new value is 10.
$ dytune -t spin_limit -p /tmp/a.out -v 10 7854 Attached to pid <7854> Working on target ‘/tmp/a.out’ using libpthread </usr/lib/hpux32/libpthread.so.1> .. The tunable <spin_limit> is currently set to <1>. The new value will be <10>. Is it Ok (y/n)? y [Ok, proceeding ...] Tunable <spin_limit> value changed from  to . Detaching from pid <7854> $
As seen from the above, after the command is entered, the tool reports that it has attached to pid 7854, then that it is working on the target executable file “/tmp/a.out” using a particular pthread library. The tool then reports that the tunable “spin_limit” is currently set to the value 1, and that the new value will be 10. Confirmation is requested of the user as to whether this change is okay or not (y or n). Here, the user enters “y” to confirm that the change is okay. The tool then proceeds with the change, and reports the change made when it is done. The tool then detaches from the process.
The above-described dynamic tuning technique modifies the tunable only for the running process; the actual object file remains unchanged. Hence, other instances of the executable would not be affected by tuning this particular instance.
While any symbol having a global scope may be tuned with this approach, it may not be practical to use this technique in all cases. For example, some tunings may have to be performed at the time of process startup itself until the applications are able to dynamically handle them.
The above-disclosed solution has various advantages. This solution provides true dynamic tuning in user space. The use of environment variables may be reduced or eliminated. Environment variables are often considered as error prone, because, if not used correctly, they can affect the whole environment instead of the specific application.
In addition, this solution does not require reserving a signal for configuration needs and does not require allocation of shared memory segments. This mechanism works for both shared libraries and executables.
In the above description, numerous specific details are given to provide a thorough understanding of embodiments of the invention. However, the above description of illustrated embodiments is not intended to be exhaustive or to limit the invention to the precise forms disclosed. One skilled in the relevant art will recognize that the invention can be practiced without one or more of the specific details, or with other methods, components, etc. In other instances, well-known structures or operations are not shown or described in detail to avoid obscuring aspects of the invention. While specific embodiments of, and examples for, the invention are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize.
These modifications can be made to the invention in light of the above detailed description. The terms used in the following claims should not be construed to limit the invention to the specific embodiments disclosed in the specification and the claims. Rather, the scope of the invention is to be determined by the following claims, which are to be construed in accordance with established doctrines of claim interpretation.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5953534||Dec 23, 1997||Sep 14, 1999||University Of Washington||Environment manipulation for executing modified executable and dynamically-loaded library files|
|US6059842 *||Apr 14, 1998||May 9, 2000||International Business Machines Corp.||System and method for optimizing computer software and hardware|
|US6219825 *||Jan 10, 1995||Apr 17, 2001||Hewlett-Packard Company||Profile based optimization of shared libraries|
|US6622300 *||Apr 21, 1999||Sep 16, 2003||Hewlett-Packard Development Company, L.P.||Dynamic optimization of computer programs using code-rewriting kernal module|
|US6782410||Aug 28, 2000||Aug 24, 2004||Ncr Corporation||Method for managing user and server applications in a multiprocessor computer system|
|US6829662||Jun 27, 2001||Dec 7, 2004||International Business Machines Corporation||Dynamically optimizing the tuning of sockets across indeterminate environments|
|US7000222||Aug 19, 1999||Feb 14, 2006||International Business Machines Corporation||Method, system, and program for accessing variables from an operating system for use by an application program|
|US7587510 *||Apr 21, 2003||Sep 8, 2009||Charles Schwab & Co., Inc.||System and method for transferring data between a user space and a kernel space in a server associated with a distributed network environment|
|US20040015930 *||Mar 26, 2001||Jan 22, 2004||Youfeng Wu||Method and system for collaborative profiling for continuous detection of profile phase transitions|
|US20040054992 *||Sep 17, 2002||Mar 18, 2004||International Business Machines Corporation||Method and system for transparent dynamic optimization in a multiprocessing environment|
|US20040133893||Jan 8, 2003||Jul 8, 2004||International Business Machines Corporation||Method and apparatus for managing environment variables in a multithreaded user process|
|US20040154021||Jan 30, 2003||Aug 5, 2004||Vasudevan Sangili||Apparatus and method to minimize blocking overhead in upcall based MxN threads|
|US20050028151 *||Aug 27, 2004||Feb 3, 2005||Roth Steven T.||Module symbol export|
|US20050283765 *||Jun 19, 2004||Dec 22, 2005||Apple Computer, Inc.||Software performance analysis using data mining|
|US20060010425||Oct 28, 2002||Jan 12, 2006||Willadsen Gloria J||Methods and apparatus for automated mangement of software|
|US20070061784 *||Sep 9, 2005||Mar 15, 2007||Sun Microsystems, Inc.||Automatic code tuning|
|US20070061785 *||Sep 9, 2005||Mar 15, 2007||Sun Microsystems, Inc.||Web-based code tuning service|
|U.S. Classification||717/153, 717/111, 717/151, 717/154|
|Cooperative Classification||G06F9/44505, G06F8/60, G06F9/45512|
|European Classification||G06F9/445C, G06F8/60, G06F9/455B2B|
|Feb 20, 2007||AS||Assignment|
Owner name: HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P., TEXAS
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SANGILI, VASUDEVAN;REEL/FRAME:018924/0555
Effective date: 20070212
|Jun 25, 2014||FPAY||Fee payment|
Year of fee payment: 4
|Nov 9, 2015||AS||Assignment|
Owner name: HEWLETT PACKARD ENTERPRISE DEVELOPMENT LP, TEXAS
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.;REEL/FRAME:037079/0001
Effective date: 20151027