US8104022B2 - Automated method for historical analysis of a memory state - Google Patents

Automated method for historical analysis of a memory state Download PDF

Info

Publication number
US8104022B2
US8104022B2 US11/556,715 US55671506A US8104022B2 US 8104022 B2 US8104022 B2 US 8104022B2 US 55671506 A US55671506 A US 55671506A US 8104022 B2 US8104022 B2 US 8104022B2
Authority
US
United States
Prior art keywords
memory location
memory
update
node
updated
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US11/556,715
Other versions
US20080109469A1 (en
Inventor
Kirk J. Krauss
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Priority to US11/556,715 priority Critical patent/US8104022B2/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: KRAUSS, KIRK J.
Publication of US20080109469A1 publication Critical patent/US20080109469A1/en
Application granted granted Critical
Publication of US8104022B2 publication Critical patent/US8104022B2/en
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • G06F11/3636Software debugging by tracing the execution of the program
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/448Execution paradigms, e.g. implementations of programming paradigms
    • G06F9/4482Procedural
    • G06F9/4484Executing subprograms

Definitions

  • IDM® is a registered trademark of International Business Machines Corporation, Armonk, N.Y., U.S.A. Other names used herein may be registered trademarks, trademarks or product names of International Business Machines Corporation or other companies.
  • This invention relates in general to software, and more particularly, to software debugging.
  • a common and often challenging problem in software debugging is backtracking to understand how the system has arrived at a particularly state. This is generally not the first step in the debugging process.
  • the real challenge comes after this step, when one must next understand how the system has come to be in this misbehaving state.
  • Software developers may spend hours or days, using hit-or-miss techniques, to pin down the entire chain of events leading up to the misbehavior they are trying to debug.
  • a host of development tools is marketed to help circumvent or address this breaktracking challenge.
  • Some tools point our programmatic errors or race conditions that can lead to certain classes of problems, but none of these tools will identify every sort of problem so that it can be circumvented.
  • Other tools capture total state information throughout the run, but such tools must record an overwhelming amount of state data, making them inadvisable for some complex programs. Developers often simply log selected program state data, but the data logging mechanism must be developed, and appropriate data must be selected for logging. Deploying any of the foregoing tools or techniques in the field may result in customer frustration if the source of the problem is not readily diagnosed that way.
  • the shortcomings of the prior art are overcome and additional advantages are provided through the provision of an automated method for historical analysis of a memory state.
  • the method includes tracking all memory write accesses by an application under test; recording a directed graph having values in a plurality of memory locations, such values being derived from values previously stored in at least one of, (i) the same memory location, and (ii) another memory location, each memory location being updated by a computer operation occurring at a verifiable time; displaying a portion of the graph that led to the update of a user-specified memory location by the application under test; and traversing backward from any node located on the directed graph via an arc utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by that node, displaying the arc so that one end of the displayed arc ends at the node representing the user-specified first memory location and the other end of the displayed arc ends at another node representing a second memory location whose value was utilized during the computation of the value presently stored in
  • FIG. 1 illustrates one example of an automated method for historical analysis of a memory state
  • FIG. 2 illustrates one example of a plurality of nodes associated with the automated method for historical analysis of a memory state shown in FIG. 1 ;
  • FIG. 3 illustrates one example of a graphical representation of the plurality of nodes shown in FIG. 2 ;
  • FIG. 4 illustrates one example of a directed graph that reveals the associated memory locations of the nodes shown in FIG. 3 .
  • the various functions described herein maybe implemented with a software runtime analysis tool.
  • the various functions described herein maybe implemented as part of a tool that analyzes a software application under test.
  • the various functions described herein may alternatively be implemented as part of the software application under test.
  • step 100 an automated method for historical analysis of a memory state is shown.
  • all memory accesses are tracked by an application under test.
  • Each node represents a memory location at particular time and there is one node per memory update.
  • a directed graph having values in a plurality of memory locations is recorded.
  • the values are derived from values that have been previously stored in at least one of, (i) the same memory location, and (ii) another memory location.
  • Each memory location being updated by a computer operation occurring at a verifiable time.
  • step 120 a portion of the graph that led to the update of a user specified memory location by the application under test is displayed.
  • a backward traversal occurs from any node located on the directed graph via an utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by the node.
  • One end of a first displayed arc ends at the node representing the user-specified first memory location and the other end of the first displayed arc ends at another node representing a second memory location whose value was utilized during the computation of the value presently stored in the user-specified memory location.
  • the node representing the first memory location is expandable to reveal the information about how data was acquired and redistributed from the second memory location to the first memory location.
  • Each node is further expandable to reveal the call chain and the executed computer instruction that led to the update of the memory location associated with that node.
  • the call chain is a plurality of linked stackframes
  • the stackframe is a data structure that represents a position in a call graph.
  • One stackframe data structure will be recorded the first time the application under test enters a particular function may be updated each time the application under test re-enters that function, if the call chain leading to that re-entry is the same.
  • the stackframe data structures will form a directed graph representing the set of relationships between the caller and callee functions during the run of the application under test.
  • a call graph maybe represented by a set of nodes, with two pointers being associated with each node.
  • Each stackframe structure may also contain timestamps for the purpose of validating the respective stackframe's associated with a particular node in a set of update structures.
  • call graphs maybe recorded in a variety of ways. The foregoing description of the recording of a call graph is meant to be illustrative as an example, and not limiting because alternative embodiments of the disclosure may vary for recording the call graph or for recording the call chains associated with each node in the directed graph of memory updates.
  • a history memory update maybe represented as a directed graph, the directed graph being different than the call graph. At one end of the graph we have the current memory content at our good breakpoint. Choosing a particular memory location (m 1 ), the user may desire to be able to follow the path of events that has led that memory location to have its current content. Each arc of the graph would then represent a step along that path.
  • FIG. 3 a graphical representation of a set of nodes utilized in the following example is shown.
  • the memory location (m 1 ) was last updated by a simple copy operation, at time (t 1 )
  • the other side of the arc would end at a node that could be expanded to reveal the memory location (m 2 ) from which the data was copied, along with the call chain and instruction at which that copy occurred. From there, the user might follow a subsequent arc that takes the user further backward into the history of the memory location (m 2 ) that served as the source of copy.
  • this memory location (m 2 ) was updated, at time (t 2 ), by an operation that added two values that had earlier been stored in two separate memory locations (m 3 and m 4 ), then the user might follow either of these two arcs that represent those two memory locations at still earlier times (t 3 and t 4 ). Following those arcs further back, the user might learn something about how those memory locations came to contain those respective values at those times.
  • earlier times are represented with higher number—that is, t 3 was earlier than t 1 . This was solely an illustration, and in fact actual time stamps may be shown that are successively earlier as the user travels backward along the described arcs.
  • FIG. 4 a directed graph of FIG. 3 is shown.
  • the directed graph of FIG. 4 reveals the associated memory location of each node.
  • the dotted connections between the nodes indicated the first-in-first-out (FIFO) queuing arrangement provided for eventual deallocation of the structures as described in the following paragraph.
  • the user may traverse backward from the node representing a user specified first memory location to a second node representing a second memory location via another arc.
  • One end of the arc ends at the user-specified node and the other end of the arc ends at the node representing the second memory location, such that the traversal reveals historical data about the user-specified memory location.
  • the second memory location is updated by a computer operation occurring at a verifiable time earlier than that associated with the user-specified node.
  • the user may optionally traverse further backward from the node representing the second memory location to nodes representing third and fourth memory locations at still earlier times, to reveal historical data about the second memory location.
  • An additional core data structure besides the stackframe structure, shall be allocated at each memory update to represent the update itself.
  • the core data structure includes (i) the memory address being updated; (ii) an instruction pointer for the code that is updating tat address; (iii) a pointer to a previous memory update structure representing a precursor to this update; (iiii) a second pointer to a previous update structure in case the update involves two values previously stored in memory; (iv) a time stamp; and (v) a link to the structure representing the update that has occurred immediately prior to this update in time.
  • the reason for such a link would be to allow purging of old updates as less storage space for these structures becomes available. This suggested link will allow these structures to be deallocated in first-in-first-out (FIFO) fashion, so the application under test may run indefinitely.
  • Each node in the displayed directed graph shall be associated with a unique update structure.
  • a difficulty in deallocating these structures is that there are pointers to then in newer update structures. If these structures are allocated in heap memory that's not used for storage of any other data, and if they are zero'd out when they are deallocated, then a time stamp reasonability check should be enough to ensure data consistency when these structures are traversed.
  • a first previous pointer to an update structure in the stored directed graph will be all that'needed to represent the situation where the update is a straightforward copy or a hard-coded value that'written out to memory.
  • a second previous pointer to a second update structure will be useful for more complex updates, such as two-operator arithmetic operations. If there is a relatively rare need for three or more operator updates to be recorded, these could be represented by two linked updates with a common time stamp. If that turns out to be a frequent need, more previous pointers in this structure may be appropriate.
  • Some overhead-saving measure may be utilized in embodiments of the invention. For example, if a large block of memory is updated via a memory copy, this may be represented using one or two update structures. An additional field in the structure may be used to indicate circumstances such as a memory copy.
  • Embodiments of the invention may store a set of these update data structures in thread-local storage (TLS), one for each register.
  • TLS thread-local storage
  • the structure in TLS shall have its pointers to previous update structures filled in when the associated register is loaded.
  • Two pointers to stackframes may also be stored in the update data structure in TLS to address this scenario.
  • These pointers may include a first pointer for when a register is loaded from memory, and a second pointer for when it's stored (e.g., when memory if updated).
  • the stackframe pointer corresponding to the memory update itself may be preferred for display, though there may be situations where the second stackframe pointer (representing the register load) may be useful for display as well.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Debugging And Monitoring (AREA)

Abstract

An automated method for historical analysis of a memory state includes tracking all memory write accesses by an application under test; recording a directed graph having values in a plurality of memory locations, such values being derived from values previously stored in at least one of, (i) the same memory location, and (ii) another memory location, each memory location being updated by a computer operation occurring at a verifiable time; displaying a portion of the graph that led to the update of a user-specified memory location by the application under test; and traversing backward from any node located on the directed graph via an arc utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by that node.

Description

TRADEMARKS
IDM® is a registered trademark of International Business Machines Corporation, Armonk, N.Y., U.S.A. Other names used herein may be registered trademarks, trademarks or product names of International Business Machines Corporation or other companies.
BACKGROUND OF THE INVENTION
1. Field of Invention
This invention relates in general to software, and more particularly, to software debugging.
2. Description of Background
A common and often challenging problem in software debugging is backtracking to understand how the system has arrived at a particularly state. This is generally not the first step in the debugging process. First, particularly for complex programs, a lot of study is sometimes needed just to understand what the system's state is when misbehavior becomes apparent. The result of this study is called setting a good breakpoint. The real challenge comes after this step, when one must next understand how the system has come to be in this misbehaving state. There's often no clear way to identify relevant breakpoints that will trigger before there's any apparent misbehavior. Software developers may spend hours or days, using hit-or-miss techniques, to pin down the entire chain of events leading up to the misbehavior they are trying to debug.
A host of development tools is marketed to help circumvent or address this breaktracking challenge. Some tools point our programmatic errors or race conditions that can lead to certain classes of problems, but none of these tools will identify every sort of problem so that it can be circumvented. Other tools capture total state information throughout the run, but such tools must record an overwhelming amount of state data, making them inadvisable for some complex programs. Developers often simply log selected program state data, but the data logging mechanism must be developed, and appropriate data must be selected for logging. Deploying any of the foregoing tools or techniques in the field may result in customer frustration if the source of the problem is not readily diagnosed that way.
Thus, there is a need for partial program state capture that does not require stepping backward in the debugging.
SUMMARY OF THE INVENTION
The shortcomings of the prior art are overcome and additional advantages are provided through the provision of an automated method for historical analysis of a memory state. The method includes tracking all memory write accesses by an application under test; recording a directed graph having values in a plurality of memory locations, such values being derived from values previously stored in at least one of, (i) the same memory location, and (ii) another memory location, each memory location being updated by a computer operation occurring at a verifiable time; displaying a portion of the graph that led to the update of a user-specified memory location by the application under test; and traversing backward from any node located on the directed graph via an arc utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by that node, displaying the arc so that one end of the displayed arc ends at the node representing the user-specified first memory location and the other end of the displayed arc ends at another node representing a second memory location whose value was utilized during the computation of the value presently stored in the user-specified memory location; wherein the node representing the second memory location is expandable to reveal information about how data was acquired and redistributed from the second memory location to the first memory location; wherein when each memory location is updated a core data structure is allocated and utilized to represent the update, wherein the core data structure includes (i) the memory address being updated, (ii) an instruction pointer for the code that is updating that address, (iii) a pointer to a previous memory update structure representing a recursor to this update, (iiii) a second pointer to a previous update structure in case the date involves two values reviouslv stored in memory, (iv) a time stamp, and (v) a link to the structure representing the update that has occurred immediately prior to this update in time.
Additional features and advantages are realized through the techniques of the present invention. Other embodiments and aspects of the invention are described in detail herein and are considered a part of the claimed invention. For a better understanding of the invention with advantages and features, refer to the description and to the drawings.
TECHNICAL EFFECTS
As a result of the summarized invention, technically we have achieved a solution for an automated method for historical analysis of a memory state.
BRIEF DESCRIPTION OF THE DRAWINGS
The subject regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other objects, features, and advantages of the invention are apparent from the following detailed description taken in conjunction with the accompanying drawing in which:
FIG. 1 illustrates one example of an automated method for historical analysis of a memory state;
FIG. 2 illustrates one example of a plurality of nodes associated with the automated method for historical analysis of a memory state shown in FIG. 1;
FIG. 3 illustrates one example of a graphical representation of the plurality of nodes shown in FIG. 2; and
FIG. 4 illustrates one example of a directed graph that reveals the associated memory locations of the nodes shown in FIG. 3.
The detailed description explains an exemplary embodiments of the invention, together with advantages and features, by way of example with reference to the drawings.
One skilled in the art should know that the various functions described herein maybe implemented with a software runtime analysis tool. In the exemplary embodiment, for example, the various functions described herein maybe implemented as part of a tool that analyzes a software application under test. In another embodiment the various functions described herein may alternatively be implemented as part of the software application under test.
DETAILED DESCRIPTION OF THE INVENTION
Referring to FIG. 1, an automated method for historical analysis of a memory state is shown. At step 100, all memory accesses are tracked by an application under test.
Referring to FIG. 2, a plurality of nodes is shown. Each node represents a memory location at particular time and there is one node per memory update.
At step 110, a directed graph having values in a plurality of memory locations is recorded. The values are derived from values that have been previously stored in at least one of, (i) the same memory location, and (ii) another memory location. Each memory location being updated by a computer operation occurring at a verifiable time.
At step 120, a portion of the graph that led to the update of a user specified memory location by the application under test is displayed.
At step 130, a backward traversal occurs from any node located on the directed graph via an utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by the node.
One end of a first displayed arc ends at the node representing the user-specified first memory location and the other end of the first displayed arc ends at another node representing a second memory location whose value was utilized during the computation of the value presently stored in the user-specified memory location. The node representing the first memory location is expandable to reveal the information about how data was acquired and redistributed from the second memory location to the first memory location.
Each node is further expandable to reveal the call chain and the executed computer instruction that led to the update of the memory location associated with that node. The call chain is a plurality of linked stackframes, and the stackframe is a data structure that represents a position in a call graph. One stackframe data structure will be recorded the first time the application under test enters a particular function may be updated each time the application under test re-enters that function, if the call chain leading to that re-entry is the same. The stackframe data structures will form a directed graph representing the set of relationships between the caller and callee functions during the run of the application under test. A call graph maybe represented by a set of nodes, with two pointers being associated with each node.
One pointer shall serve as a link between each function and the function's next descendent function in the call graph. The other pointer will serve as a link between each function and the function's next sibling function. Each stackframe structure may also contain timestamps for the purpose of validating the respective stackframe's associated with a particular node in a set of update structures. One familiar with the art should know that call graphs maybe recorded in a variety of ways. The foregoing description of the recording of a call graph is meant to be illustrative as an example, and not limiting because alternative embodiments of the disclosure may vary for recording the call graph or for recording the call chains associated with each node in the directed graph of memory updates.
A history memory update maybe represented as a directed graph, the directed graph being different than the call graph. At one end of the graph we have the current memory content at our good breakpoint. Choosing a particular memory location (m1), the user may desire to be able to follow the path of events that has led that memory location to have its current content. Each arc of the graph would then represent a step along that path.
Referring to FIG. 3, a graphical representation of a set of nodes utilized in the following example is shown. For example and not meant to be limiting, if the memory location (m1) was last updated by a simple copy operation, at time (t1), then the other side of the arc would end at a node that could be expanded to reveal the memory location (m2) from which the data was copied, along with the call chain and instruction at which that copy occurred. From there, the user might follow a subsequent arc that takes the user further backward into the history of the memory location (m2) that served as the source of copy. To continue the example, if this memory location (m2) was updated, at time (t2), by an operation that added two values that had earlier been stored in two separate memory locations (m3 and m4), then the user might follow either of these two arcs that represent those two memory locations at still earlier times (t3 and t4). Following those arcs further back, the user might learn something about how those memory locations came to contain those respective values at those times. In this example, earlier times are represented with higher number—that is, t3 was earlier than t1. This was solely an illustration, and in fact actual time stamps may be shown that are successively earlier as the user travels backward along the described arcs.
Referring to FIG. 4, a directed graph of FIG. 3 is shown. The directed graph of FIG. 4 reveals the associated memory location of each node. The dotted connections between the nodes indicated the first-in-first-out (FIFO) queuing arrangement provided for eventual deallocation of the structures as described in the following paragraph. The user may traverse backward from the node representing a user specified first memory location to a second node representing a second memory location via another arc. One end of the arc ends at the user-specified node and the other end of the arc ends at the node representing the second memory location, such that the traversal reveals historical data about the user-specified memory location. The second memory location is updated by a computer operation occurring at a verifiable time earlier than that associated with the user-specified node. The user may optionally traverse further backward from the node representing the second memory location to nodes representing third and fourth memory locations at still earlier times, to reveal historical data about the second memory location.
An additional core data structure besides the stackframe structure, shall be allocated at each memory update to represent the update itself. The core data structure includes (i) the memory address being updated; (ii) an instruction pointer for the code that is updating tat address; (iii) a pointer to a previous memory update structure representing a precursor to this update; (iiii) a second pointer to a previous update structure in case the update involves two values previously stored in memory; (iv) a time stamp; and (v) a link to the structure representing the update that has occurred immediately prior to this update in time. The reason for such a link would be to allow purging of old updates as less storage space for these structures becomes available. This suggested link will allow these structures to be deallocated in first-in-first-out (FIFO) fashion, so the application under test may run indefinitely. Each node in the displayed directed graph shall be associated with a unique update structure.
A difficulty in deallocating these structures is that there are pointers to then in newer update structures. If these structures are allocated in heap memory that's not used for storage of any other data, and if they are zero'd out when they are deallocated, then a time stamp reasonability check should be enough to ensure data consistency when these structures are traversed.
When a memory location is updated, a first previous pointer to an update structure in the stored directed graph will be all that'needed to represent the situation where the update is a straightforward copy or a hard-coded value that'written out to memory. A second previous pointer to a second update structure will be useful for more complex updates, such as two-operator arithmetic operations. If there is a relatively rare need for three or more operator updates to be recorded, these could be represented by two linked updates with a common time stamp. If that turns out to be a frequent need, more previous pointers in this structure may be appropriate.
Some overhead-saving measure may be utilized in embodiments of the invention. For example, if a large block of memory is updated via a memory copy, this may be represented using one or two update structures. An additional field in the structure may be used to indicate circumstances such as a memory copy.
If a data structure, as previously described, is produced for each memory update, there will quickly be a large graph of these structures. This graph represents all of the memory updates that have occurred over some time interval. Typically, there is no need to present the entire graph to the user at once. Instead, the user might enter a memory address to view the arcs leading up to the current content of memory at that user-specified address. The view, at that point, might look like a tree of nodes, fanning out into past memory updates. The user might then click on the nodes to inspect the call chain and source code for each node. The user would presumably be using embodiments of the invention in tandem with a debugger, which would help the user to derive relevant memory addresses to be historically analyzed.
There are situations when a value in memory is loaded into a register, retained there for awhile, and then written back out to memory, perhaps with some modification. Embodiments of the invention may store a set of these update data structures in thread-local storage (TLS), one for each register. The structure in TLS shall have its pointers to previous update structures filled in when the associated register is loaded. Two pointers to stackframes may also be stored in the update data structure in TLS to address this scenario. These pointers may include a first pointer for when a register is loaded from memory, and a second pointer for when it's stored (e.g., when memory if updated). The stackframe pointer corresponding to the memory update itself may be preferred for display, though there may be situations where the second stackframe pointer (representing the register load) may be useful for display as well.
While the preferred embodiment to the invention has been displayed, it will be understood that those skilled in the art, both now and in the future, may make various improvements and enhancements which fall within the scope of the claims which follow. These claims should be construed to maintain the proper protection for the invention first described.

Claims (6)

1. An automated method for historical analysis of a memory state, comprising:
tracking all memory write accesses by an application under test;
recording a directed graph having values in a plurality of memory locations, such values being derived from values previously stored in at least one of, (i) the same memory location, and (ii) another memory location, each memory location being updated by a computer operation occurring at a verifiable time;
displaying a portion of the graph that led to the update of a user-specified memory location by the application under test; and
traversing backward from any node located on the directed graph via an arc utilized to follow the path of events that led to the content of the memory location represented by that node at the time represented by that node, displaying the arc so that one end of the displayed arc ends at the node representing the user-specified first memory location and the other end of the displayed arc ends at another node representing a second memory location whose value was utilized during the computation of the value presently stored in the user-specified memory location;
wherein the node representing the second memory location is expandable to reveal information about how data was acquired and redistributed from the second memory location to the first memory location;
wherein when each memory location is updated a core data structure is allocated and utilized to represent the update, wherein the core data structure includes (i) the memory address being updated, (ii) an instruction pointer for the code that is updating that address, (iii) a pointer to a previous memory update structure representing a precursor to this update, (iiii) a second pointer to a previous update structure in case the update involves two values previously stored in memory, (iv) a time stamp, and (v) a link to the structure representing the update that has occurred immediately prior to this update in time.
2. The method of claim 1, wherein each node is further expandable to reveal a call chain of the executed computer instruction that led to the update of the memory location associated with that node.
3. The method of claim 2, wherein each node is further expandable to reveal the executed computer instruction that led to the update of the memory location associated with that node.
4. The method of claim 3, wherein the second memory location is updated by a computer operation occurring at a verifiable time.
5. The method of claim 4, wherein the call chain is a plurality of linked stackframes.
6. The method of claim 5, wherein a stackframe is a data structure that represents
a position in a call graph.
US11/556,715 2006-11-06 2006-11-06 Automated method for historical analysis of a memory state Active 2030-09-27 US8104022B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/556,715 US8104022B2 (en) 2006-11-06 2006-11-06 Automated method for historical analysis of a memory state

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/556,715 US8104022B2 (en) 2006-11-06 2006-11-06 Automated method for historical analysis of a memory state

Publications (2)

Publication Number Publication Date
US20080109469A1 US20080109469A1 (en) 2008-05-08
US8104022B2 true US8104022B2 (en) 2012-01-24

Family

ID=39360926

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/556,715 Active 2030-09-27 US8104022B2 (en) 2006-11-06 2006-11-06 Automated method for historical analysis of a memory state

Country Status (1)

Country Link
US (1) US8104022B2 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110016358A1 (en) * 2007-09-14 2011-01-20 Airbus Operations (Societe Par Actions Simplifiee) Method for debugging operational software of a system onboard an aircraft and device for implementing the same
US10037263B1 (en) * 2016-07-27 2018-07-31 Intuit Inc. Methods, systems, and articles of manufacture for implementing end-to-end automation of software services
US20180329802A1 (en) * 2016-09-29 2018-11-15 International Business Machines Corporation Identification and handling of nested breakpoints during debug session

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7752170B2 (en) * 2007-01-03 2010-07-06 International Business Machines Corporation Implementing dynamic copy-on-write (COW) storage compression in COW storage through zero and deleted blocks

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0359254A2 (en) 1988-09-14 1990-03-21 Kabushiki Kaisha Toshiba Method of back-tracking in computer processing
US5408650A (en) 1993-06-29 1995-04-18 Digital Equipment Corporation Memory analysis system for dynamically displaying memory allocation and de-allocation events associated with an application program
US5428618A (en) 1993-01-27 1995-06-27 Kabushiki Kaisha Toshiba Debugger apparatus and method having an event history recording capability
US5845125A (en) 1993-06-21 1998-12-01 Kabushiki Kaisha Toshiba Debugger using class information and dynamic instance inter-relationships
US6003143A (en) * 1994-06-30 1999-12-14 Compaq Computer Corporation Tool and method for diagnosing and correcting errors in a computer program
US6212653B1 (en) 1998-02-18 2001-04-03 Telefonaktiebolaget Lm Ericsson (Publ) Logging of events for a state driven machine
US6327699B1 (en) * 1999-04-30 2001-12-04 Microsoft Corporation Whole program path profiling
US6345383B1 (en) 1994-09-14 2002-02-05 Kabushiki Kaisha Toshiba Debugging support device and debugging support method
US6353924B1 (en) 1999-02-08 2002-03-05 Incert Software Corporation Method for back tracing program execution
US6904594B1 (en) * 2000-07-06 2005-06-07 International Business Machines Corporation Method and system for apportioning changes in metric variables in an symmetric multiprocessor (SMP) environment
US6951011B1 (en) 1999-10-21 2005-09-27 Oracle International Corp. Diagnostic method and article for identifying significant events
US20050273757A1 (en) * 2004-06-07 2005-12-08 Anderson Craig D Methods, systems, and computer program products for summarizing operational behavior of a computer program

Patent Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0359254A2 (en) 1988-09-14 1990-03-21 Kabushiki Kaisha Toshiba Method of back-tracking in computer processing
US5428618A (en) 1993-01-27 1995-06-27 Kabushiki Kaisha Toshiba Debugger apparatus and method having an event history recording capability
US5845125A (en) 1993-06-21 1998-12-01 Kabushiki Kaisha Toshiba Debugger using class information and dynamic instance inter-relationships
US5408650A (en) 1993-06-29 1995-04-18 Digital Equipment Corporation Memory analysis system for dynamically displaying memory allocation and de-allocation events associated with an application program
US6003143A (en) * 1994-06-30 1999-12-14 Compaq Computer Corporation Tool and method for diagnosing and correcting errors in a computer program
US6345383B1 (en) 1994-09-14 2002-02-05 Kabushiki Kaisha Toshiba Debugging support device and debugging support method
US6212653B1 (en) 1998-02-18 2001-04-03 Telefonaktiebolaget Lm Ericsson (Publ) Logging of events for a state driven machine
US6353924B1 (en) 1999-02-08 2002-03-05 Incert Software Corporation Method for back tracing program execution
US6327699B1 (en) * 1999-04-30 2001-12-04 Microsoft Corporation Whole program path profiling
US6951011B1 (en) 1999-10-21 2005-09-27 Oracle International Corp. Diagnostic method and article for identifying significant events
US6904594B1 (en) * 2000-07-06 2005-06-07 International Business Machines Corporation Method and system for apportioning changes in metric variables in an symmetric multiprocessor (SMP) environment
US20050273757A1 (en) * 2004-06-07 2005-12-08 Anderson Craig D Methods, systems, and computer program products for summarizing operational behavior of a computer program

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
"An Execution Backtracking Approach to Program Debugging" by Hiralal Agrawal, Richard DeMillo, and Eugene Spafford published 2004. *
Agrawal, Hiralal; Demillo, Richard; Spafford, Eugene. "Debugging with Dynamic Slicing and Backtracking." Copyright 1993. *
De Sutter, Bjorn; De Bus, Bruno; Ronsse, Michiel; De Bosschere, Koen. "Backtracking and Dynamic Patching for Free." Copyright 2005. *
Richard A. DeMillo and Eugene H. Spafford, Debugging with Dynamic Slicing and Backtracking, Hiralal Agrawal Bellcore, pp. 1-29.

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110016358A1 (en) * 2007-09-14 2011-01-20 Airbus Operations (Societe Par Actions Simplifiee) Method for debugging operational software of a system onboard an aircraft and device for implementing the same
US8650547B2 (en) * 2007-09-14 2014-02-11 Airbus Operations Sas Method for debugging operational software of a system onboard an aircraft and device for implementing the same
US10037263B1 (en) * 2016-07-27 2018-07-31 Intuit Inc. Methods, systems, and articles of manufacture for implementing end-to-end automation of software services
US20180329802A1 (en) * 2016-09-29 2018-11-15 International Business Machines Corporation Identification and handling of nested breakpoints during debug session
US10628287B2 (en) * 2016-09-29 2020-04-21 International Business Machines Corporation Identification and handling of nested breakpoints during debug session

Also Published As

Publication number Publication date
US20080109469A1 (en) 2008-05-08

Similar Documents

Publication Publication Date Title
US11494287B2 (en) Scalable execution tracing for large program codebases
US10621068B2 (en) Software code debugger for quick detection of error root causes
US6353924B1 (en) Method for back tracing program execution
US5274811A (en) Method for quickly acquiring and using very long traces of mixed system and user memory references
US7770155B2 (en) Debugger apparatus and method for indicating time-correlated position of threads in a multi-threaded computer program
US7950001B2 (en) Method and apparatus for instrumentation in a multiprocessing environment
US6964036B2 (en) Descriptive variables while debugging
US5428618A (en) Debugger apparatus and method having an event history recording capability
US8418149B2 (en) Differential comparison system and method
US20070250820A1 (en) Instruction level execution analysis for debugging software
US7131115B2 (en) Unwinding instrumented program code
EP2261802A1 (en) Automated debugging system and method
US5799143A (en) Multiple context software analysis
KR20060044639A (en) Method and system for detecting potential races in multithreaded program
US7627857B2 (en) System and method for visualizing exception generation
EP2975527A2 (en) A method for tracing computer software
US20110029819A1 (en) System and method for providing program tracking information
US7251810B1 (en) Minimal instrumentation for lossless call profiling
US8104022B2 (en) Automated method for historical analysis of a memory state
US6367036B1 (en) Fast trace log
US7698690B2 (en) Identifying code that wastes time performing redundant computation
CN110431536B (en) Implementing breakpoints across an entire data structure
US8826233B2 (en) Graphical representation of a JAVA bytecode
JP2008059402A (en) Real-time diagnostic system and real-time diagnostic method
Stewart et al. Non-stop monitoring and debugging on shared-memory multiprocessors

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:KRAUSS, KIRK J.;REEL/FRAME:018482/0576

Effective date: 20061019

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12