1. Field
This disclosure generally relates to a computing environment. More particularly, the disclosure relates to sampling technology.
2. General Background
Either time-based or hardware event-based sampling technology is typically utilized in application profiling tools to determine the specific usage of resources. The sampling technology samples by periodically generating interrupts. At each interrupt the current process/thread, the instruction being executed and, optionally, the data address being accessed, may be identified and recorded. At a later time the collected data is aggregated, and reports are generated showing sample distribution by address, symbol, process, etc. The full execution context of the sample is not typically recorded and not available in reports.
Embodiments of the invention include a computer program product and a method for causing a computer system to generate a plurality of samples in the computer system to profile and record a plurality of events associated with the computer system, accumulate, for each of the plurality of samples, a plurality of partial samples prior to occurrence of each of the plurality of events, and process a current sample of the plurality of samples in response to (i) a completion of a previous sample of the plurality of samples and (ii) a predetermined threshold quantity of partial samples being accumulated.
In another embodiment of the invention, a system includes a data storage device that accumulates, for each of a plurality of samples, a plurality of partial samples prior to the occurrence of each of a plurality of events. Further, the system includes a processor that (i) generates a plurality of samples in a computer system to profile and record a plurality of events associated with the computer system and (ii) processes a current sample of the plurality of samples in response to a completion of a previous sample of the plurality of samples and a predetermined threshold quantity of partial samples being accumulated.
In another embodiment of the invention, a computer program product is provided to generate a plurality of samples to profile and record a plurality of events, to accumulate, for each of the plurality of samples, a plurality of partial samples prior to occurrence of each of the plurality of events, and to process a current sample of the plurality of samples in response to (i) a completion of a previous sample of the plurality of samples and (ii) a predetermined threshold quantity of partial samples being accumulated, the previous sample having a predetermined previous sample rate, the current sample having a predetermined current sample rate that is determined by increasing the previous sample rate by a factor such that the predetermined current sample rate is greater than the predetermined previous sample rate.
The above-mentioned features of the present invention will become more apparent with reference to the following description taken in conjunction with the accompanying drawings wherein like reference numerals denote like elements and in which:
According to an embodiment of the present invention, a sampling configuration is provided that determines why a processor is being utilized in a particular manner. In one embodiment, a call stack is gathered at each sample. As a result, a determination may be made as to how functions were called in contrast with a profiler that is typically utilized to provide sample distribution reports of recorded addresses of instructions being executed during samples and is unable to make such a determination. Further, a determination may be made as to what was the call stack that was utilized to invoke a particular function. Such a determination may help an analyst determine if a problem exists with how a particular function is being invoked, what calling sequence is being utilized the most frequently, and whether the calling sequence is necessary. In one embodiment, a report may be generated to show the different ways in which a function was called.
In gathering calls stacks for interrupted threads, there is a migration issue. That is, while the call stacks are gathered, the thread may have migrated to a different processor. It is possible to prevent thread migration by keeping all processors busy, other than the one on which the call stack will be gathered. This could be accomplished by having sampler threads spin on those processors, until the call stack is obtained for the thread of interest. However, this severely affects overall application performance. Instead, the thread of interest may be prevented from migrating to a different processor, by setting its affinity to restrict it to only running on one processor. In this way, the other processors do not have to be spun so that the other processors are free to continue running the application. Thus there is minimal application performance degradation. To reiterate, thread migration is prevented by setting the processor affinity of the interrupted/target thread to allow it to run only on the current processor.
After the call stack is retrieved the interrupted/target thread's original affinity is restored. Setting a thread's affinity, sometimes also known as binding, causes the thread to run only on the specified processor(s). Because the sampler thread runs at high priority and on the same processor on which the interrupted thread is intended to run, the interrupted thread may not migrate to a different processor.
As samples are processed, the kernel mode component 120 handling the interrupt may be able to set the interrupted thread's affinity immediately within the interrupt handler. In one embodiment, setting the affinity may occur outside the interrupt handler when interrupts are enabled. For example, a second level interrupt handler (“SLIH”) or an interrupt back-end may perform this action. While handling the samples, e.g., interrupts, the interrupted thread may not make forward progress until the SLIH or the interrupt back-end has completed its processing, which would include scheduling the sampling thread(s) for the interrupted process.
In an alternative embodiment, all user-mode sampler threads, one for each processor, may spin until the interrupted threads' affinity is set. This method could be used if the operating system's support for binding or setting a thread's affinity is only supported from user mode. In another embodiment, the target thread is suspended either in the interrupt handler or in an interrupt back-end. Once the sampler thread gets control, it will set the target thread's affinity and resume (i.e., un-suspend) it. In yet another embodiment, the profiler installs a global signal handler for the application being profiled. At interrupt time, the interrupt handler signals the target thread using a predefined signal, which causes the signal handler to run in the context of the target thread. The signal handler then sets the processor affinity of the target thread, in which context it is executing, to the current processor. Subsequently, the signal handler signals the sampler thread on the current processor. The sampler runs after the signal handler signals the sampler thread.
In any of these embodiments it is advantageous to guarantee that a certain amount of time or number of events have been reached after a sample has been completed before the next sample is processed. In other words, event processing is paced. An accounting for time during the sampling is provided. The quantity of the sample can be determined, which allows for the time of the sample to be determined. As a result, call stack sampling for a fixed range may be ensured.
In one embodiment, a sample rate is increased by a factor. Further, a sample is only processed after a predetermined threshold is reached. For example, the predetermined threshold may be a number of events. There could be separate factors for different profiling needs, for example, different factors for a profiling program and sample call stack events.
Sampler threads are listening for commands to cause them to retrieve the call stack or a thread of interest, which is performed by the profiler 104. A sampler thread is a profiler thread. Many sampler threads may be utilized as a plurality of processors may be utilized. Each sampler thread has an affinity to a single processor. Sampler threads may be very high priority threads so that they run immediately when signaled to do work such as retrieving a target thread's call stack. The target thread is the thread that has the call stack of interest to be obtained. Further, a target processor is the processor on which the target thread was running and on which affinity is set so that the target thread remains on that processor for a duration.
Once a determination is made as a result of sampling, a target thread's call stack is to be obtained. The target thread is prevented from making any forward progress during that time. In other words, the target thread is kept where it is until the call stack is gathered. Afterward, the target thread may resume.
In a multi-processor environment, an issue arises in gathering calls stacks. That is, since call stacks are gathered by profiler sampler threads, the target thread could potentially be running on another available processor, i.e., a different processor than the target processor. By the time the sampler thread gathers the call stack, the target thread may no longer be at the point where it was sampled, and the call stack would not accurately reflect where the target thread was at the time of the sample. It would be possible to address this issue by boxing out all of the processors other than the target processor, i.e. giving all the other processors busy work that is not useful to make them spin so that they do not have the sampler thread. However, this tends to significantly hinder application performance. So instead, the set of processors on which the target thread may run is restricted to the target processor, according to an embodiment of the present invention. In this way, the remaining processors may continue to do real work. Only the target processor is affected while the target thread's call stack is being retrieved. The affinity is set so that the target thread may run only on the one processor to which it has affinity. Once the target's call stack is obtained, the target thread's affinity is restored and the target thread may run on any available processor again.
The sampling system 100 may have a plurality of processors. For example, the sampling system 100 may have a first processor 112, a second processor 114, . . . , and an nth processor 116. Only one thread may run on each processor at a given time. However, that thread may potentially run on a different processor and at a different time. In the sampling system 100, at least one processor generates an interrupt. In one embodiment, a sample may be driven by an interrupt. In one embodiment, the sample is based on an event. For example, the event may be time based so that the sample is generated at a constant rate for predetermined time intervals. Accordingly, each of the processors may generate an interrupt at a constant rate irrespective of the status of each of the processors, e.g., being idle or not being idle. The interrupt for each processor is generated by hardware and handled by an interrupt handler 110, which determines if the interrupted thread is one for which a call stack should be obtained. The interrupt handler 110 initiates the gathering of call stacks. Further, the interrupt handler may notify or signal a profiler sampler thread. To avoid thread migration during sampling, the affinity of a thread to a particular processor may be established.
If the threshold for the desired profiling is not reached, then no further processing for that function occurs. For example, if the profiling program tick rate has been increased by a factor of two and the sample call stack rate has been increase by a factor of eight, then the profiling processing will occur at every second interrupt. However, because sample call stack processing has an indeterminate amount of processing time to retrieve the call stack, the process ensures that 8 interrupts occur after the last sample completes before processing the next sample. This approach can be applied to other sampling events, such as monitoring processor idle events. In that case, after a call stack has been processed related to a processor detected being idle, a new sample call stack will not be initiated until after some fixed amount of events has completed.
In one embodiment, a previous sample has a predetermined previous sample rate. An example is a standard sample rate for call stack sampling of, thirty two samples per second and a profiling rate of one hundred twenty eight samples per second. Further, in one embodiment, a current sample may have a predetermined current sample rate. An example of a predetermined current sample rate is a sample rate that is distinct from the predetermined previous sample rate. In one embodiment, the current sample has a predetermined current sample rate that is determined by increasing the previous sample rate by a factor such that the predetermined current sample rate is greater than the predetermined previous sample rate. For instance, the factor may be a multiple such as eight so that the predetermined current sample rate is eight times the predetermined previous sample rate, e.g., thirty two samples per second times the factor of eight to result in two hundred fifty six interrupts per second, but only when eight interrupts are taken In one embodiment, the predetermined threshold quantity is the factor. In the exampled provided, the predetermined threshold quantity may be eight as the predetermined threshold quantity is the factor. Further, a counter that is incremented or decremented may be utilized for the predetermined threshold quantity. As a result, a paced sample that is paced from the completion of the previous sample is processed. Assuming a decrement, the profiling counter starts at two and is decrement on each tick till zero is reached. When zero is reached, the trace record is written and the profiling counter is set back to two. In the case of call stack sampling, the counter is set to eight and decremented on each sample and a new sample is taken when the counter is zero. When the call stack is retrieved and a sample is completed, partial tick counts are accumulated and the counter is set to eight. In this example, the profiling trace record is written every second interrupt, but the sample call stack sampler thread is only notified after at least eight interrupts after the completion of the previous sample has occurred.
Logic, which may be provided through hardware and/or software, may indicate the completion of the previous sample. A sampler thread may not be notified for a predetermined threshold quantity before receiving control to retrieve the call stack. After retrieving and processing the call stack, the sampler thread notifies the device driver indicating completion of the previous sample. A component processing the sample, e.g., a processor, then indicates to a portion of code that controls the sampling that the operation has been completed. In one embodiment, the completion resets a counter. After the completion, the partial accumulations may be added. Profiling may also be run concurrently so that the two tools may be run simultaneously.
In one embodiment, the accounting is performed by a processor. The interrupt handler 110 may have separate divisors for tracing and call stack sampling. As an example, on the interrupt, a “temp_tick_count” is decremented and only if the value is 0 does processing continue. Further, at sample completion, the following code may be utilized:
When selecting a process to notify, called by the interrupt handler when the temp_scs_tick_count reaches zero, the following code may be utilized:
The busy_adjust count may then be added to the process statistics.
The any_sampler_busy routine checks if the interrupted thread is a sampler thread for any of the processes being monitored. The check may only be for sampler threads that are bound to the interrupted processor.
In another embodiment, a component such as an interrupt back-end worker, offlevel processing worker, interrupt backend worker, or the like may be utilized as only some things may be done at the interrupt level, and the rest of the work is deferred until a subsequent time.
The profiler 104 may retrieve the call stack, i.e., the execution context. Further, the profiler 104 may restore the affinity.
In one embodiment, the call stack sampling tool contains a kernel mode component 120 and a user mode component 118 that work together. In one configuration, the underlying operating system 106 provides application program interfaces (“APIs”) that allow setting a thread's affinity from kernel-mode. The user mode component 118 creates a high priority sampling thread for each processor and sets its affinity to only that processor. Each sampler thread is responsible for gathering call stacks for one interrupted thread that was running in that processor. Each sampler thread waits for notification from the kernel mode component. The kernel mode component 110 enables the sampling, e.g., interrupt mechanism. Interrupts will occur on each processor at a predetermined rate. The interrupt handler 110 handles the sampling interrupts. For example, the interrupt handler 110 may perform the following: (1) collect the interrupted thread's information, e.g., thread id, process id, user-mode and kernel-mode instruction and stack pointers, etc.); (2) set the interrupted thread's affinity to only the processor on which it is running, e.g., the interrupted processor; (3) notify the user-mode sampler thread to collect the call stack; and (4) indicate that no more samples will be handled on this processor until the user-mode sampler thread completes. Further, the user-mode sampler thread wakes up and performs the following: (1) utilizes a virtual machine tools interface to obtain the interrupted thread's call stack or walks the interrupted thread's call stack directly; (2) restores the original interrupted thread's affinity to allow for the operating system 106 as seen in
In another configuration, the underlying operating system 106 as seen in
Variations of the configurations provided herein may be utilized to allow for collecting the call stacks asynchronously. Instead of making a synchronous call to a virtual machine tools interface to collect the call stack, a sampler would request that the call stack be collected for the interrupted thread asynchronously, e.g., by setting a notification flag, at the next convenient time, and then wait for a notification from the virtual machine when the request is completed. At that time, the sampler would restore the interrupted thread's affinity. Because collecting a call stack may be a lengthy operation, once the request is made to the virtual machine to collect the call stack, the sampler would yield the processor. The interrupted thread will not migrate away from that processor. In order to get the call stack from the interrupted thread as soon as possible, after setting the notification flag, the sampler thread could increase the priority of the interrupted thread and block. When the notification occurs, the profiler 104 would retrieve and process the call stack and before restore the thread's original priority.
In one embodiment, the signal handler is installed when the processing is registered for call stack sampling and its sampler threads are allocated. After the hardware is set up to generate one or more interrupts for the requested events, the interrupt is signaled and the interrupt handler handles the interrupt. The interrupt handler then signals the interrupted thread, which may be effectuated by an SLIH or an interrupt back-end as long as they occur on the same processor as the interrupting processor. The signal handler is then executed before the interrupted thread is allowed to resume normal execution. The signal handler may then perform various actions to cause the interrupted thread to be bound to the processor and allow the sampler thread to retrieve the call stack. In one embodiment, the signal handler binds (i.e., sets the affinity of the interrupted thread to the processor on which it was interrupted and then signals the sampler thread for that processor to get the interrupted thread's call stack). Because the signal handler may run on any processor, care must be taken to make sure the interrupted thread is bound to the correct processor, not necessarily the one on which the signal handler is running. In one embodiment, the interrupt handler maintains a per-processor entry containing the interrupted thread identifier. The signal handler searches the processor entry for its thread id and binds the thread to that processor. Other variations may be utilized.
When the sampler thread has determined that the interrupted thread is bound to the interrupted process, the sampler thread then requests or gets the call stack. In one embodiment, the sampler thread may set the affinity or know that the affinity was set by the signal handler.
With respect to native call stacks, one approach is to have the monitored application link with a library that supports the registration of monitoring and the installation of a signal handler. Alternatively, support may be added dynamically for an interrupted process using a mechanism similar to the process debuggers use to attach to an already running program. Although this may not be possible on the first interrupt, a daemon process may be scheduled to initiate the attachment in an expedited manner for subsequent interrupts against that process to be handled via this disclosed method.
When the call stack is retrieved, various actions may take place. In one embodiment, the retrieved call stack is walked into a tree and the leaf node of the tree has its base count incremented, which allows for utilization of the technology to produce reports or to view the collected information. After processing the call stack, the kernel mode component is notified and the kernel mode component accumulates any monitored partial samples and updates any monitored partial sample counters to indicate that the threshold accounting must restart to ensure the desired number of events occur before the next sample is taken
In yet another embodiment, profiling static and dynamic code may be utilized.
In another embodiment, the data recorded by the profiler 104 is handed to a component handling Address to Name (“A2N”) resolution. The component may have specialized support for code that is generated dynamically and may be overlaid.
After retrieving a call stack, the sampler thread determines if the instruction pointer received from the interrupt handler falls within the address for the function being executed at the leaf node of a tree. If the instruction pointer falls within the leaf node, the sampler thread indicates that the target thread did not drift (I.e., execute instructions) since the time the target thread was interrupted. If the instruction pointer does not fall within the leaf function, the target thread drifted since the time the target thread was interrupted. The target thread was interrupted at the address given by the instruction pointer. However, that address is not within the function being executed as indicated by the retrieved call stack. In other words, the target thread is not where it was interrupted and has drifted. The sampler inspects other functions near the leaf node. In other words, the functions that appear in the tree as immediate callers of the leaf functions (i.e., functions that directly call the leaf function or functions directly called by the leaf function.) The functions that directly call the leaf function are callers, and the functions that are directly called by the leaf function are callees. If the instruction pointer is resolved to either a caller or a callee then the exact location of the drifted target thread may be determined. Accordingly, corrections may be made in the tree by incrementing the occurrence counts in the actual caller or callee node, which is where the target thread was actually interrupted. If the instruction pointer is not resolved to either a caller or a callee, then the occurrence count on the leaf node is increment because that is the location of the target thread regardless of where the target thread was interrupted.
Subsequently, a report regarding the address range match is generated. While generating the report, the address ranges are converted to symbols. The conversion is performed by identifying functions in the address range and utilizing the A2N component to retrieve start addresses and lengths. When the report is generated, the A2N information is utilized to identify function names. In addition, names that are added to the reports are also determined along with identifying which leaves bases should be incremented to reflect an accurate picture of the call stack samples.
Accordingly, static and dynamic code is profiled utilizing the data collected by a device driver and data gathered for generated code. The profiling determines if an instruction address range collected by the device driver falls within the range of the generated code as specified by a virtual machine. This data may be utilized to determine the name of a routine that was executing at the time of an interrupt.
Further, in one embodiment, the address change is resolved in real time. Therefore, dynamic code may also be accounted for during post processing. Similarly, static code may be profiled utilizing a real time analysis
In one embodiment, each of the plurality of events is based on predetermined events. An example of a predetermined event is an event that is time based. The time based event may generate an interrupt.
In an alternative embodiment, the values of the counters when the sample is completed are collected. In one configuration, the values are collected when the values of the counters are sent to initialize for the new event.
The processes described herein may be implemented in a general, multi-purpose or single purpose processor. Such a processor will execute instructions, either at the assembly, compiled or machine-level, to perform the processes. Those instructions can be written by one of ordinary skill in the art following the description of the figures corresponding to the processes and stored or transmitted on a computer readable medium. The instructions may also be created using source code or any other known computer-aided design tool.
The processor 702 is coupled, either directly or indirectly, to the memory 712 through a system bus. The memory 712 may include local memory employed during actual execution of the program code, bulk storage, and/or cache memories which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution.
The input/output devices 704 may be coupled directly to the system 700 or through intervening input/output controllers. Further, the input/output devices 704 may include a keyboard, a keypad, a mouse, a microphone for capturing speech commands, a pointing device, and other user input devices that will be recognized by one of ordinary skill in the art. Further, the input/output devices 704 may include a receiver, transmitter, speaker, display, image capture sensor, biometric sensor, etc. In addition, the input/output devices 604 may include storage devices such as a tape drive, floppy drive, hard disk drive, compact disk (“CD”) drive, digital video disk (“DVD”) drive, etc.
Network adapters may also be coupled to the system 900 to enable the system 900 to become coupled to other systems, remote printers, or storage devices through intervening private or public networks. Modems, cable modems, and Ethernet cards are just a few of the currently available types of network adapters.
For any of the configurations described herein, various actions may take place when the call stack is retrieved. In one embodiment, the retrieved call stack is walked into a tree and the leaf node of the tree has its base count incremented, which allows for utilization of technology to produce reports or to view the collected information.
Any of the configurations described herein may be utilized with a virtual machine. A virtual machine may be configured to keep track of calling state and return that state referring to a virtual machine supported interface to return call stacks. For instance, information about execution of threads may be obtained through trace data. This information may include call stack information obtained from call stacks associated with threads of interest. A virtual machine may be utilized to obtain the call stack information. Various approaches may be utilized by the virtual machine to obtain the call stack information. For example, entry/exit events, an application timer tick, or instrumenting codes that sample the instrumented values may be utilized. A selected sampling thread may send a call to the virtual machine to obtain the call stack information. The selected sampling thread may make the call to the virtual machine through a virtual machine interface. The virtual machine interfaces may return call stack information to the sampling thread or may store the call stack information in some work area. The obtained information may be placed into a tree for later analysis.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method, or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that may contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that may communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (“LAN”) or a wide area network (“WAN”), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, may be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The “processor” of a general purpose computer, special purpose computer, or other programmable data processing apparatus may be referred to herein as a “microprocessor.” However, the term “microprocessor” should not be interpreted as being limited to a single-chip central processing unit or any other particular type of programmable data processing apparatus, unless explicitly so stated.
These computer program instructions may also be stored in a computer readable medium that may direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, may be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
Reference throughout this Specification to “one embodiment,” “an embodiment,” or similar language means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus, appearances of the phrase “in one embodiment,” “in an embodiment,” and similar language throughout this Specification may, but do not necessarily, all refer to the same embodiment. Furthermore, the described features, structures, or characteristics of the invention may be combined in any suitable manner in one or more embodiments. Correspondingly, even if features are initially claimed as acting in certain combinations, one or more features from a claimed combination may in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
While the computer program product, method and system have been described in terms of what are presently considered to be the most practical and preferred embodiments, it is to be understood that the disclosure need not be limited to the disclosed embodiments. The disclosure is intended to cover various modifications and similar arrangements included within the spirit and scope of the claims, the scope of which should be accorded the broadest interpretation so as to encompass all such modifications and similar structures. The present disclosure includes any and all embodiments of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5305454 | Record et al. | Apr 1994 | A |
5379432 | Orton et al. | Jan 1995 | A |
5404529 | Chernikoff et al. | Apr 1995 | A |
5465328 | Dievendorff et al. | Nov 1995 | A |
5473777 | Moeller et al. | Dec 1995 | A |
5475845 | Orton et al. | Dec 1995 | A |
5544318 | Schmitz et al. | Aug 1996 | A |
5682537 | Davies et al. | Oct 1997 | A |
5751789 | Farris et al. | May 1998 | A |
5764241 | Elliott et al. | Jun 1998 | A |
5768500 | Agrawal et al. | Jun 1998 | A |
5913213 | Wikstrom et al. | Jun 1999 | A |
5930516 | Watts et al. | Jul 1999 | A |
6002872 | Alexander, III et al. | Dec 1999 | A |
6012094 | Leymann et al. | Jan 2000 | A |
6055492 | Alexander, III et al. | Apr 2000 | A |
6108654 | Chan et al. | Aug 2000 | A |
6112225 | Kraft et al. | Aug 2000 | A |
6125363 | Buzzeo et al. | Sep 2000 | A |
6128611 | Doan et al. | Oct 2000 | A |
6158024 | Mandal | Dec 2000 | A |
6178440 | Foster et al. | Jan 2001 | B1 |
6199075 | Ungar et al. | Mar 2001 | B1 |
6233585 | Gupta et al. | May 2001 | B1 |
6338159 | Alexander, III et al. | Jan 2002 | B1 |
6438512 | Miller | Aug 2002 | B1 |
6442572 | Leymann et al. | Aug 2002 | B2 |
6449614 | Marcotte | Sep 2002 | B1 |
6553564 | Alexander, III et al. | Apr 2003 | B1 |
6601233 | Underwood | Jul 2003 | B1 |
6625602 | Meredith et al. | Sep 2003 | B1 |
6633897 | Browning et al. | Oct 2003 | B1 |
6651243 | Berry et al. | Nov 2003 | B1 |
6654948 | Konuru et al. | Nov 2003 | B1 |
6658652 | Alexander, III et al. | Dec 2003 | B1 |
6662358 | Berry et al. | Dec 2003 | B1 |
6662359 | Berry et al. | Dec 2003 | B1 |
6681230 | Blott et al. | Jan 2004 | B1 |
6697802 | Ma et al. | Feb 2004 | B2 |
6697935 | Borkenhagen et al. | Feb 2004 | B1 |
6728955 | Berry et al. | Apr 2004 | B1 |
6728959 | Merkey | Apr 2004 | B1 |
6742016 | Bhoj et al. | May 2004 | B1 |
6751789 | Berry et al. | Jun 2004 | B1 |
6857120 | Arnold et al. | Feb 2005 | B1 |
6874074 | Burton et al. | Mar 2005 | B1 |
6880086 | Kidder et al. | Apr 2005 | B2 |
6904594 | Berry et al. | Jun 2005 | B1 |
6931354 | Jones et al. | Aug 2005 | B2 |
6941552 | Beadle et al. | Sep 2005 | B1 |
6954922 | Liang | Oct 2005 | B2 |
6976263 | Delaney | Dec 2005 | B2 |
6993246 | Pan et al. | Jan 2006 | B1 |
7000047 | Nguyen et al. | Feb 2006 | B2 |
7020696 | Perry et al. | Mar 2006 | B1 |
7028298 | Foote | Apr 2006 | B1 |
7047258 | Balogh et al. | May 2006 | B2 |
7093081 | DeWitt, Jr. et al. | Aug 2006 | B2 |
7114036 | DeWitt, Jr. et al. | Sep 2006 | B2 |
7114150 | Dimpsey et al. | Sep 2006 | B2 |
7162666 | Bono | Jan 2007 | B2 |
7178145 | Bono | Feb 2007 | B2 |
7206848 | Zara et al. | Apr 2007 | B1 |
7222119 | Ghemawat et al. | May 2007 | B1 |
7257657 | DeWitt, Jr. et al. | Aug 2007 | B2 |
7278141 | Accapadi et al. | Oct 2007 | B2 |
7284238 | Inagaki et al. | Oct 2007 | B2 |
7296130 | Dimpsey et al. | Nov 2007 | B2 |
7321965 | Kissell | Jan 2008 | B2 |
7325108 | Tuel | Jan 2008 | B2 |
7398518 | Dichter | Jul 2008 | B2 |
7426730 | Mathews et al. | Sep 2008 | B2 |
7458078 | DeWitt, Jr. et al. | Nov 2008 | B2 |
7474991 | DeWitt et al. | Jan 2009 | B2 |
7496918 | Dice et al. | Feb 2009 | B1 |
7526757 | Levine et al. | Apr 2009 | B2 |
7529914 | Saha et al. | May 2009 | B2 |
7574587 | DeWitt, Jr. et al. | Aug 2009 | B2 |
7584332 | Kogge et al. | Sep 2009 | B2 |
7587364 | Crumbach et al. | Sep 2009 | B2 |
7610585 | Shpeisman et al. | Oct 2009 | B2 |
7624137 | Bacon et al. | Nov 2009 | B2 |
7653895 | James-Roxby et al. | Jan 2010 | B1 |
7688867 | Kizhepat | Mar 2010 | B1 |
7689867 | Rosenbluth et al. | Mar 2010 | B2 |
7716647 | Loh et al. | May 2010 | B2 |
7721268 | Loh et al. | May 2010 | B2 |
7779238 | Kosche et al. | Aug 2010 | B2 |
7788664 | Janakiraman et al. | Aug 2010 | B1 |
7921075 | Herness et al. | Apr 2011 | B2 |
7921875 | Moriiki et al. | Apr 2011 | B2 |
7925473 | DeWitt, Jr. et al. | Apr 2011 | B2 |
7962913 | Accapadi et al. | Jun 2011 | B2 |
7962924 | Kuiper et al. | Jun 2011 | B2 |
7996593 | Blackmore et al. | Aug 2011 | B2 |
7996629 | Wan et al. | Aug 2011 | B2 |
8018845 | Ruello et al. | Sep 2011 | B2 |
8024735 | Rudd et al. | Sep 2011 | B2 |
8117599 | Edmark et al. | Feb 2012 | B2 |
8117618 | Holloway et al. | Feb 2012 | B2 |
8132170 | Kuiper et al. | Mar 2012 | B2 |
8136124 | Kosche et al. | Mar 2012 | B2 |
8141053 | Levine | Mar 2012 | B2 |
8156495 | Chew et al. | Apr 2012 | B2 |
8191049 | Levine et al. | May 2012 | B2 |
8286134 | Jones et al. | Oct 2012 | B2 |
8381215 | Johnson et al. | Feb 2013 | B2 |
8566795 | Dewitt, Jr. et al. | Oct 2013 | B2 |
20020007363 | Vaitzblit | Jan 2002 | A1 |
20020016729 | Breitenbach et al. | Feb 2002 | A1 |
20020038332 | Alverson et al. | Mar 2002 | A1 |
20020073103 | Bottomley et al. | Jun 2002 | A1 |
20030004970 | Watts | Jan 2003 | A1 |
20030023655 | Sokolov et al. | Jan 2003 | A1 |
20030061256 | Mathews et al. | Mar 2003 | A1 |
20030083912 | Covington, III et al. | May 2003 | A1 |
20030233394 | Rudd et al. | Dec 2003 | A1 |
20040068501 | McGoveran | Apr 2004 | A1 |
20040093510 | Nurmela | May 2004 | A1 |
20040142679 | Kearns et al. | Jul 2004 | A1 |
20040148594 | Williams | Jul 2004 | A1 |
20040162741 | Flaxer et al. | Aug 2004 | A1 |
20040163077 | Dimpsey et al. | Aug 2004 | A1 |
20040178454 | Kuroda et al. | Sep 2004 | A1 |
20040193510 | Catahan, Jr. et al. | Sep 2004 | A1 |
20040215614 | Doyle et al. | Oct 2004 | A1 |
20040215768 | Oulu et al. | Oct 2004 | A1 |
20040216112 | Accapadi et al. | Oct 2004 | A1 |
20040220931 | Guthridge et al. | Nov 2004 | A1 |
20040220932 | Seeger et al. | Nov 2004 | A1 |
20040220933 | Walker | Nov 2004 | A1 |
20040268316 | Fisher et al. | Dec 2004 | A1 |
20050021354 | Brendle et al. | Jan 2005 | A1 |
20050080806 | Doganata et al. | Apr 2005 | A1 |
20050086455 | DeWitt, Jr. et al. | Apr 2005 | A1 |
20050091663 | Bagsby | Apr 2005 | A1 |
20050102493 | DeWitt, Jr. et al. | May 2005 | A1 |
20050102673 | DeWitt, Jr. et al. | May 2005 | A1 |
20050138443 | Cooper | Jun 2005 | A1 |
20050149585 | Bacon et al. | Jul 2005 | A1 |
20050155018 | DeWitt, Jr. et al. | Jul 2005 | A1 |
20050155019 | Levine et al. | Jul 2005 | A1 |
20050166187 | Das et al. | Jul 2005 | A1 |
20050204349 | Lewis et al. | Sep 2005 | A1 |
20050256961 | Alon et al. | Nov 2005 | A1 |
20050262130 | Mohan | Nov 2005 | A1 |
20050273757 | Anderson | Dec 2005 | A1 |
20050273782 | Shpeisman et al. | Dec 2005 | A1 |
20060004757 | Watts | Jan 2006 | A1 |
20060023642 | Roskowski et al. | Feb 2006 | A1 |
20060031837 | Theurer | Feb 2006 | A1 |
20060059486 | Loh et al. | Mar 2006 | A1 |
20060072563 | Regnier et al. | Apr 2006 | A1 |
20060080486 | Yan | Apr 2006 | A1 |
20060095571 | Gilgen et al. | May 2006 | A1 |
20060130001 | Beuch et al. | Jun 2006 | A1 |
20060136914 | Marascio et al. | Jun 2006 | A1 |
20060149877 | Pearson | Jul 2006 | A1 |
20060167955 | Vertes | Jul 2006 | A1 |
20060184769 | Floyd et al. | Aug 2006 | A1 |
20060212657 | Tuel | Sep 2006 | A1 |
20060218290 | Lin et al. | Sep 2006 | A1 |
20060259911 | Weinrich et al. | Nov 2006 | A1 |
20060282400 | Kalavacharla et al. | Dec 2006 | A1 |
20060282707 | Rosenbluth et al. | Dec 2006 | A1 |
20070006168 | Dimpsey et al. | Jan 2007 | A1 |
20070033589 | Nicholas et al. | Feb 2007 | A1 |
20070150904 | Kim et al. | Jun 2007 | A1 |
20070169003 | Branda et al. | Jul 2007 | A1 |
20070171824 | Ruello et al. | Jul 2007 | A1 |
20070220495 | Chen et al. | Sep 2007 | A1 |
20070220515 | Dewitt, Jr. et al. | Sep 2007 | A1 |
20070226139 | Crumbach et al. | Sep 2007 | A1 |
20080082761 | Herness et al. | Apr 2008 | A1 |
20080082796 | Merten et al. | Apr 2008 | A1 |
20080091679 | Herness et al. | Apr 2008 | A1 |
20080091712 | Daherkar et al. | Apr 2008 | A1 |
20080148240 | Jones et al. | Jun 2008 | A1 |
20080148241 | Jones et al. | Jun 2008 | A1 |
20080148299 | Daherkar et al. | Jun 2008 | A1 |
20080177756 | Kosche et al. | Jul 2008 | A1 |
20080189687 | Levine et al. | Aug 2008 | A1 |
20080196030 | Buros et al. | Aug 2008 | A1 |
20080263325 | Kudva et al. | Oct 2008 | A1 |
20080307441 | Kuiper et al. | Dec 2008 | A1 |
20090007075 | Edmark et al. | Jan 2009 | A1 |
20090044198 | Kuiper et al. | Feb 2009 | A1 |
20090083002 | DeWitt et al. | Mar 2009 | A1 |
20090100432 | Holloway et al. | Apr 2009 | A1 |
20090106762 | Accapadi et al. | Apr 2009 | A1 |
20090178036 | Levine | Jul 2009 | A1 |
20090187909 | Russell et al. | Jul 2009 | A1 |
20090187915 | Chew et al. | Jul 2009 | A1 |
20090204978 | Lee et al. | Aug 2009 | A1 |
20090210649 | Wan et al. | Aug 2009 | A1 |
20090235247 | Cho et al. | Sep 2009 | A1 |
20090235262 | Ceze et al. | Sep 2009 | A1 |
20090241095 | Jones et al. | Sep 2009 | A1 |
20090271549 | Blackmore et al. | Oct 2009 | A1 |
20090292846 | Park et al. | Nov 2009 | A1 |
20090300224 | Duffy et al. | Dec 2009 | A1 |
20100017447 | Jones et al. | Jan 2010 | A1 |
20100017581 | Clift et al. | Jan 2010 | A1 |
20100017583 | Kuiper et al. | Jan 2010 | A1 |
20100017584 | Jones et al. | Jan 2010 | A1 |
20100017789 | Dewitt, Jr. et al. | Jan 2010 | A1 |
20100017804 | Gupta et al. | Jan 2010 | A1 |
20100036981 | Ganesh et al. | Feb 2010 | A1 |
20100333071 | Kuiper et al. | Dec 2010 | A1 |
20110289361 | Kuiper et al. | Nov 2011 | A1 |
20110307640 | Jones et al. | Dec 2011 | A1 |
20120191893 | Kuiper et al. | Jul 2012 | A1 |
Number | Date | Country |
---|---|---|
1614555 | May 2005 | CN |
649084 | Apr 1995 | EP |
000689141 | Dec 1995 | EP |
1603307 | Dec 2005 | EP |
11-327951 | Nov 1999 | JP |
2002-055848 | Feb 2002 | JP |
2004-199330 | Jul 2004 | JP |
2005-141392 | Jun 2005 | JP |
2008-257287 | Oct 2008 | JP |
2009098500 | Sep 2009 | KR |
WO2009014868 | Jan 2009 | WO |
Entry |
---|
US 8,589,928, 11/2013, Kuiper et al. (withdrawn) |
Harkema, et al. Performance Monitoring of Java Applications, Jul. 2002. |
Alexander, et al. A unifying approach to performance analysis in the Java environment, IBM Systems Journal, vol. 39, No. 1, 2000. |
IBM, “Process and Thread Sampling—Target Selection in Interrupt Mode,” ip.com, Jul. 16, 2008. |
Cao, Zhongbo, et al., “A Study of Java Virtual Machine Scalability issues on SMP Systems,” IEEE, Proceedings of the 2005 IEEE International Symposium on Workload Characterization, Oct. 6-8, 2005, pp. 119-128. |
Chen, Liang, et al., “Resource Allocation in a Middleware for Streaming Data,” Middleware 2004 Companion, 2nd Workshop on Middleware for Grid Computing, ACM, 2004, pp. 5-10. |
Korochkin, Dmitry, et al., “Experimental Performance Analysis of the Ada95 and java Parallel Program on SMP Systems,” SIGAda'02, Dec. 8-12, 2002, ACM, pp. 53-56. |
Tam, David, et al., “Thread Clustering: Sharing-Aware Scheduling on SMP-CMP-SMT Multiprocessors,” EuroSys'07, Mar. 21-23, 2007, pp. 47-58. |
International Search Report and Written Opinion dated Sep. 3, 2010 for International Application No. PCT/EP2010/058486, 8 pages. |
USPTO U.S. Appl. No. 11/834,779. |
Whaley, John, “A Portable Sampling-Based Profiler for Java Virtual Machines.” Proceedings of the ACM 2000 Java Grande Conference, Jun. 3, 2000, pp. 78-87. |
International Search Report and Written Opinion for PCT/EP2011/057574 dated Aug. 2, 2011. |
Asokan-et al.; “Providing Time-and Space—Efficient Procedure Calls for Asynchronous Software Thread Integration”; pp. 167-187; Sep. 2004. |
Mohanty-et al.; “A Hierarchical Approach for Energy Efficient Application Design Using Heterogeneous Embedded Systems”; pp. 243-255; Oct.-Nov. 2003. |
Von Behren-et al.; “Capriccio: Scalable Threads for Internet Services”; ACM Digital Library; pp. 268-280; Oct. 2003. |
Foong-et al.; “Architectural Characterization of Processor Affinity in Network Processing”; IEEE; 2005. |
Milton, Scott; “Thread Migration in Distributed Memory Multicomputers”, The Australian National University, Joint Computer Science Technical Report Series, Feb. 1998. |
Abdel-Shafi, et al.; “Efficient User-Level Thread Migration and Checkpointing on Windows NT Clusters”, Proceedings of the 3rd USENIX Windows NT Symposium, Jul. 12-13, 1999. |
Tullsen, et al. “Handling Long-latency Loads in a Simultaneous Multithreading Processor,” IEEE, 2001, pp. 318-327. |
Purser, et al. “A Study of Slipstream Processors,” IEEE, 2000, pp. 269-280. |
Choi, et al. “Deterministic Replay of Java Mulithreaded Applications,” ACM SIGMETRICS Symposium on Parallel and Distributed Tools (SPDT), Aug. 1998, pp. 48-59. |
Alkalaj, et al. “Performance of Multi-Threaded Execution in a Shared-Memory Multiprocessor,” IEEE, 1991, p. 330-333. |
IBM, “Pacing support for Time Based Context Sampling,” ip.com, Jan. 22, 2009. |
Arpaci-Dusseau, Andrea Carol, “Implicit Coscheduling: Coordinated Scheduling with Implicit Information in Distributed Systems”, ACM Transactions on Computer Systems, vol. 19, No. 3, Aug. 2011, pp. 283-331 [Also Total 49 pp.]. |
Barcia, R. and J. Brent, “IBM WebSphere Developer Technical Journal: Building SOA Solutions with the Service Component Architecture—Part 1”, Oct. 26, 2005, Total. |
Cerami, Ethan, “Web Services Essentials”, Feb. 2002, O'Reilly, First Edition, Total 286 pp. |
Office Action 1, Jun. 27, 2012, for U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 21 pp. |
Response to Office Action 1, Feb. 20, 2012, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 17 pp. |
Amendment 1, Nov. 13, 2008, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 8 pp. |
Amendment 2, Jan. 8, 2009, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 18 pp. |
Amendment 3, Aug. 11, 2009, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 24 pp. |
Amendment 4, Mar. 1, 2010, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 22 pp. |
Amendment 5, Aug. 19, 2010, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 11 pp. |
Final Office Action 1, May 14, 2009, for U.S. Appl. No 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 42 pp. |
Final Office Action 2, May 28, 2010, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 49 pp. |
Notice of Allowance 1, Sep. 7, 2010, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 24 pp. |
Notice of Allowance 2, Nov. 23, 2010, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 27 pp. |
Office Action 1, Oct. 27, 2008, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 11 pp. |
Office Action 2, Dec. 24, 2008, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 8 pp. |
Office Action 3, Dec. 1, 2009, for U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 39 pp. |
Amendment 1, Dec. 8, 2008, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 7 pp. |
Amendment 2, Apr. 13, 2009, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 9 pp. |
Notice of Allowance 1, Jan. 14, 2009, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 9 pp. |
Notice of Allowance 2, May 15, 2009, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 11 pp. |
Notice of Allowance 3, Jun. 22, 2009, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 10 pp. |
Office Action 1, Nov. 14, 2008, for U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 18 pp. |
Office Action 1, Feb. 17, 2011, for U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K.G. Kuiper et al., Total 38 pp. |
Final Office Action 1, Jul. 15, 2011, for U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K.G. Kuiper et al., Total 17 pp. |
Notice of Allowance 1, Oct. 25, 2011, for U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K.G. Kuiper et al., Total 51 pp. |
Response to Office Action 1, May 17, 2011, for U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K.G. Kuiper et al., Total 13 pp. |
Response to Final Office Action 1, Oct. 17, 2011, for U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K. G. Kuiper et al., Total 8 pp. |
Office Action 1, Nov. 21, 2011, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 19 pp. |
Amendment 1, Feb. 5, 2013, for U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by K.G. Kuiper et al., Total 11 pp. |
U.S. Appl. No. 11/549,609, filed Oct. 13, 2006 by A.R. Daherkar et al., Total 3 pp. |
U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 2 pp. |
U.S. Appl. No. 11/549,613, filed Oct. 13, 2006 by A.R. Daherkar et al., Total 3 pp. |
U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 3 pp. |
U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by K.G. Kuiper et al., Total 2 pp. |
U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 4 pp. |
U.S. Appl. No. 11/536,962, filed Sep. 29, 2006 by E.N. Herness et al., Total 1 p. |
U.S. Appl. No. 11/536,941, filed Sep. 29, 2006 by E.N. Herness et al., Total 2 pp. |
Mansouri-Samani, M. and M. Sloman, “A Configurable Event Service for Distributed Systems”, © 1996 IEEE, Total 8 pp. |
Meyer, K., B. Gas, and J. Doughty, “The Devolution of Functional Analysis”, Oct. 26, 1982, Total 26 pp. |
Rinard, M.C. and P.C. Diniz, “Eliminating Synchronization Bottlenecks Using Adaptive Replication”, © 2003 ACM, ACM Transactions on Programming Languages and Sysems, vol. 25, Nol. 3, May 2003, pp. 316-359. |
Tidwell, D., J. Snell, and P. Kulchenko, “Programming Web Services with SOAP”, O'Reilly, First Edition Dec. 2001, ISBN: 0-596-00095-2, 216 pages, Total 225 pp. |
Websphere 6.0.2, “Processing Events in a Sequence”, IBM, [online], [Retrieved on May 12, 2011]. Retrieved from the Internet at <URL: http://publib.boulder.ibm.com/infocenter/dmndhelp/v6rxmx/topic/com.ibm.wbit.help.wirin...>, Oct. 7, 2005, Total 9 pp. |
Amendment 1, May 30, 2012, for U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 11 pp. |
Amendment 1, Sep. 25, 2012, for U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 15 pp. |
Office Action 1, Oct. 9, 2012, for U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by K.G. Kuiper et al., Total 25 pp. |
Amendment 1, Dec. 27, 2012, for U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 11 pp. |
Office Action 1, Sep. 19, 2012, for U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 28 pp. |
Office Action 1, Mar. 2, 2012, for U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 21 pp. |
Amendment 2, Jan. 3, 2013, for U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 12 pp. |
Final Office Action 1, Jun. 14, 2012, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 22 pp. |
Response to Final Office Action 1, Sep. 14, 2012, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K. G. Kuiper et al., Total 19 pp. |
Notice of Allowance 1, Aug. 20, 2012, for U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 8 pp. |
Final Office Action 1, Nov. 6, 2012, for U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 10 pp. |
Notice of Allowance 1, Jan. 17, 2013, for U.S. Appl. No. 12/494,469, filed Jun. 30, 2009 by K.G. Kuiper et al., Total 7 pp. |
Amendment 2, Jul. 3, 2013, for U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 9 pp. |
Amendment 2, Jun. 13, 2013, for U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by Kuiper et al., Total 7 pp. |
Notice of Allowance 1, Aug. 28, 2013, for U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 17 pp. |
Notice of Allowance 1, Jul. 9, 2013, for U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by Kuiper et al., Total 11 pp. |
Response to Office Action, Jul. 22, 2013, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 12 pp. |
Final Office Action 1, Mar. 18, 2013, for U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by K.G. Kuiper et al., Total 30 pp. |
U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 2 pp. |
U.S. Appl. No. 11/834,779, filed Aug. 7, 2007 by K. G. Kuiper et al., Total 2 pp. |
U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 4 pp. |
U.S. Appl. No. 13/011,621, filed Jan. 21, 2011 by K.G. Kuiper et al., Total 3 pp. |
U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 4 pp. |
Final Office Action 1, Apr. 3, 2013, for U.S. Appl. No. 12/786,381, filed May 24, 2010 by K.G. Kuiper et al., Total 55 pp. |
Notice of Allowance 2, May 24, 2013, for U.S. Appl. No. 12/813,706, filed Jun. 11, 2010 by S.T. Jones et al., Total 14 pp. |
Office Action, Apr. 25, 2013, for U.S. Appl. No. 12/173,047, filed Jul. 15, 2008 by K.G. Kuiper et al., Total 45 pp. |
Notice of Allowance 1 for U.S. Appl. No. 12/173,047, dated Sep. 11, 2013, 22 pp. |
Notice of Allowance 3 for U.S. Appl. No. 12/813,706, dated Sep. 13, 2013, 11 pp. |
Notice of Allowance 4, dated Jan. 17, 2014, for U.S. Appl. No. 12/813,706, 13 pp. |
Response to Examination Report for GB Application No. 1212738.7, dated Dec. 11, 2013, 7 pp. |
Notice of Allowance 2, dated Dec. 19, 2013, for U.S. Appl. No. 12/786,381, 10 pp. |
AIX Versions 3.2 and 4 Performance Tuning Guide, Performance Overview of the Virtual Memory Manager (VMM), Apr. 1997 http://nfosolutions.com/doc—link/C/a—doc—lib/aixbman/prftungd/vmmov.htm, 8 pp. |
Binder, “Portable and Accurate Sampling Profiling for Java”, Software—Practice and Experience, vol. 36, Issue 6, May 2006, pp. 615-650. |
Chanda et al., “Whodunit: Transactional Profiling for Multi-Tier Applications”, ACM, EuroSys'07, Mar. 2007 Lisboa, Portugal, pp. 17-30. |
Dunlavey, “Performance Tuning with Instruction-Level Cost Derived from Call-Stack Sampling”, ACM SIGPLAN Notices, vol. 42(8), Aug. 2007, pp. 4-8. |
Froyd et al., “Low-Overhead Call Path Profiling of Unmodified, Optimized Code”, ACM, ICS'05 Cambridge, Massachusetts, pp. 81-90, 2005. |
Graham et al., “gprof: a Call Graph Execution Profiler,” Proceedings of the 1982 SIGPLAN Symposium on Compiler Construction, Jun. 1982m pp. 120-126. |
Sun Java Real-Time System 2.0—01, Garbage Collection Guide, Nov. 21, 2007 http://download.oracle.com/javase/realtime/doc—2.0—u1/release/JavaRTSGarbageCollection.html, 12 pp. |
Office Action 1, dated Dec. 19, 2011, for U.S. Appl. No. 12/173,053, 15 pp. |
Response to Office Action 1, dated Mar. 19, 2012, for U.S. Appl. No. 12/173,053, 17 pp. |
Final Office Action 1, dated May 2, 2012, for U.S. Appl. No. 12/173,053, 16 pp. |
Appeal Brief, dated Jul. 23, 2012, for U.S. Appl. No. 12/173,053, 23 pp. |
Notice of Allowance, dated Jun. 13, 2013, for U.S. Appl. No. 12/173,053, 13 pp. |
Office Action 1, dated Jan. 5, 2012, for U.S. Appl. No. 12/173,107, 21 pp. |
Response to Office Action 1, dated Mar. 30, 2012, for U.S. Appl. No. 12/173,107, 15 pp. |
Notice of Allowance, dated Jun. 6, 2012, for U.S. Appl. No. 12/173,107, 10 pp. |
Office Action 1, dated Feb. 2, 2011, for U.S. Appl. No. 12/235,302, 16 pp. |
Response to Office Action 1, dated Apr. 20, 2011, for U.S. Appl. No. 12/235,302, 24 pp. |
Final Office Action 1, dated Jul. 20, 2011, for U.S. Appl. No. 12/235,302, 17 pp. |
Appeal Brief, dated Dec. 13, 2011, for U.S. Appl. No. 12/235,302, 35 pp. |
Examiner's Answer, dated Feb. 27, 2012, for U.S. Appl. No. 12/235,302, 20 pp. |
Reply Brief, dated Apr. 27, 2012, for U.S. Appl. No. 12/235,302, 5 pp. |
Notice of Allowance 2, dated Dec. 9, 2013, for U.S. Appl. No. 13/011,621, 11 pp. |
Office Action 1 for CN Application No. 201080010002.9, dated Sep. 4, 2013, 9 pp. |
Notice of Allowance, dated Nov. 12, 2013, for U.S. Appl. No. 12/494,469, filed on Jun. 30, 2009, 14 pp. |
U.S. Patent No. 7,458,078, dated Nov. 25, 2008, is an English language equivalent of CN1614555, dated May 11, 2005. |
U.S. Publication No. 2005/0102673, dated May 12, 2005, is an English language equivalent of CN1614555, dated May 11, 2005. |
Notice of Allowance 3, Mar. 20, 2014, for Application No. U.S. Appl. No. 13/011,621, filed on Jan. 21, 2011 by K.G. Kuiper et al., Total 20 pp. |
Amendment 3, Mar. 18, 2014, for U.S. Appl. No. 12/786,381, filed on May 24, 2010 by K.G. Kuiper et al., Total 9 pp. |
U.S. Patent No. 6,002,872, dated Dec. 14, 1999, is an English language equivalent of JP11-327951, dated Nov. 30, 1999. |
U.S. Patent No. 7,284,238, dated Oct. 16, 2007, is an English language equivalent of JP2004-199330, dated Jul. 15, 2004. |
Machine Translation of JP Publication No. 2002-055848, dated Feb. 20, 2002, 23 pp. |
Machine Translation of JP Publication No. 2005-141392, dated Jun. 2, 2005, 18 pp. |
Machine Translation of JP Publication No. 2008-257287, dated Oct. 23, 2008, 32 pp. |
Office Action 3, Apr. 14, 2014, for U.S. Appl. No. 12/786,381, filed on May 24, 2010 by K.G. Kuiper et al., Total 16 pp. |
Number | Date | Country | |
---|---|---|---|
20110320173 A1 | Dec 2011 | US |