A data processing system and method includes a data processor and memory that are coupled to debug circuitry that generates debug messages including address translation trace messages. A memory management unit (MMU) includes a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms. The debug circuitry includes message generation circuitry coupled to the MMU for receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information. The branch history information is a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken. The instruction count information is a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB.
|
8. A method comprising:
providing a data processor for executing a plurality of data processing instructions;
coupling a memory to the data processor for storing and providing information to the data processor;
coupling a memory management unit to the data processor and the memory, the memory management unit comprising a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms;
coupling debug circuitry to the data processor and memory management unit for generating debug messages including address translation trace messages, the debug circuitry receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information, the branch history information comprising a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information being a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB.
1. A data processing system comprising:
a data processor for executing a plurality of data processing instructions;
a memory coupled to the data processor for storing and providing information to the data processor;
debug circuitry coupled to the data processor for generating debug messages including address translation trace messages;
a memory management unit coupled to the debug circuitry, data processor and the memory, the memory management unit comprising a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms, wherein:
the debug circuitry comprises:
message generation circuitry coupled to the memory management unit for receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information, the branch history information comprising a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information being a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB.
14. A data processing system comprising:
an instruction fetch unit for receiving and storing a plurality of data processing instructions;
an instruction decoder coupled to the instruction fetch unit for receiving the plurality of data processing instructions and decoding each of the plurality of data processing instructions;
an execution unit coupled to the instruction decoder for executing the plurality of data processing instructions;
a memory coupled to the instruction fetch unit and the execution unit for storing information from the execution unit and providing information to the instruction fetch unit;
debug circuitry coupled to the instruction fetch unit, the instruction decoder and the execution unit for generating debug messages including address translation trace messages;
a memory management unit coupled to the debug circuitry, data processor and the memory, the memory management unit comprising a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms, wherein:
the debug circuitry comprises:
message generation circuitry coupled to the memory management unit for receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information, the branch history information comprising a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information being a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB.
2. The data processing system of
3. The data processing system of
4. The data processing system of
5. The data processing system of
6. The data processing system of
7. The data processing system of
9. The method of
providing the corresponding program correlation message before providing the address translation trace message.
10. The method of
detecting a need to generate a second program correlation message at a same point in time as generating the program correlation message due to an event other than modification of a TLB entry; and
combining the program correlation message and the second program correlation message to form a merged program correlation message that contains the branch history information, the instruction count information and at least one field of merged information that is common to both the program correlation message and the second program correlation message.
11. The method of
compressing a length of the address translation trace message and replacing a portion of the address translation trace message that is removed by compression with at least one of branch history information and instruction count information of one or more data processing instructions executed up to the point in time when the new TLB entry is established in the TLB.
12. The method of
forming the corresponding program correlation message contains both branch history information and instruction count information.
13. The method of
the memory management unit providing notice to the debug circuitry in response to performing a TLB write entry operation.
15. The data processing system of
16. The data processing system of
17. The data processing system of
18. The data processing system of
19. The data processing system of
20. The data processing system of
|
This application is related to U.S. Ser. No. 12/389,153 entitled “Address Translation Trace Message Generation for Debug” filed of even date herewith and assigned to the assignee hereof.
1. Field
This disclosure relates generally to semiconductors, and more specifically, to data processing systems that implement address translation and generate address translation trace messages.
2. Related Art
An IEEE standard known as IEEE ISTO5001, or the Nexus debug standard, is an established real-time debug standard that supports real-time debug message generation. The Nexus debug standard specifies a mechanism for identifying to an external trace reconstruction tool a predetermined operating condition within the system. Debugging processes are also used in the development of code for a data processing system. Providing debug information in real-time, without intrusion on the normal operation of the data processing system is highly desirable to remain transparent to operation of the system.
Debug messages are generated by the data processing system that contain address and data information for either program events (program trace messaging), or data events (data read messaging, data write messaging), as well as other debug information. The address information is typically virtual address information which is a format that must be translated to identify a physical memory location known as a physical address. Correlation of the address to a program undergoing execution is an important part of the debugging process so that actual program flow and the dynamic values of system data variables can be monitored. Virtual to physical address mapping or translation must be performed. However, an external debugger typically does not have the necessary virtual to physical mapping information to quickly translate the address portions of the debug messages, particularly when these mappings are dynamically changing due to demand paging or other remapping operations. The use of the virtual addresses allows a debug user a straightforward way to trace a computer program via a program listing obtained by a compile and link function which uses virtual addresses for text and data sections of the software application. The user typically has no knowledge of how the virtual addresses are translated to physical addresses by an operating system (OS). Therefore, tracing is required to indicate virtual addresses. Unfortunately certain program listings are unavailable, such as program listings for pre-compiled software modules which are executed at runtime. Examples of such modules are OS calls and library functions. In such an example, no program listing is available. Thus it is very difficult to properly trace and interpret these sections of the executed program. Correct translation of a virtual address to a physical address requires knowing where a program counter is and examining physical memory to determine where the address is. For systems executing multiple programs the memory mapping varies dynamically and readily transitions between memory pages. In such situations, the address translation significantly precludes debug message generation and interpretation from being performed real-time.
The present invention is illustrated by way of example and is not limited by the accompanying figures, in which like references indicate similar elements. Elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale.
Many data processing systems typically use address translation logic, such as translation lookaside buffers (TLBs) to map virtual addresses to physical addresses. Entries within this address translation logic (such as TLB entries) may be modified or invalidated through the use of processor instructions or by hardware within the data processing system which dynamically maintains address translations by performing address translation table searches and TLB updates as required by software execution, such as by performing hardware “table-walking” or similar types of hardware searches. According to one aspect of the present invention, debug messages, such as address translation trace messages, are generated in response to modification or invalidation of an entry within the address translation logic. These address translation trace messages can then be provided to an external development system for improved debugging capability. Furthermore, in cases in which the virtual address mapping is changed, program correlation messages may also be generated with the appropriate timing so as to provide more accurate information with respect to branch history information and sequence count information. Also, according to another aspect of the present invention, efficiency may be further improved by compressing one or more fields of the debug messages, by field-compressing the debug messages, or by merging multiple messages (such as program correlation messages) when possible.
Illustrated in
A memory 30 is coupled to global interconnect 12 via a bidirectional coupling. Debug circuitry 26 has a second input/output terminal coupled to a plurality of debug terminals 40 via bidirectional multiple conductors. The plurality of debug terminals 40 are coupled to an external development system 36 that is commonly referred to as a debugger or external debugger. In the illustrated form BIU 14, MMU 16, global control circuit 18, instruction fetch unit 20, instruction decoder 22, execution units 24 with register files 25, debug circuitry 26 and load/store unit 28 collectively form a data processor 42 as indicated by the dashed line grouping in
In operation, data processing system 10 communicates with devices (not shown) via global interconnect 12. Information communicated with data processor 42 transfers through BIU 14. Instruction fetch unit 20 retrieves data processor instructions (i.e. processor instructions) from BIU 14 under control of global control circuit 18. The retrieved instructions are sequentially communicated to instruction decoder 22 for decoding under control of global control circuit 18. Execution units 24 execute instructions and generate data that is either stored in a cache (not shown) or placed in the memory 30 via coupling through global control circuit 18, BIU 14 and global interconnect 12. Debugging of the operation of data processor 42 and data processing system 10 is performed by the use of debug circuitry 26 that generates debug messages for analysis by external development system 36. A test or debug mode of operation is entered in response to activation of such from external development system 36. In the illustrated form, debug circuitry 26 is configured to receive data addresses and instruction addresses, where the addresses may be virtual addresses or physical addresses. A data address is an address where data resides whereas an instruction address is an address where an instruction resides. Instruction virtual addresses are provided from instruction fetch unit 20 to the debug circuitry 26 and MMU 16. A virtual address is an untranslated address which requires some further processing or translating to obtain the translated address of the physical storage location where the information is residing. This translated address is referred to as the physical address. MMU 16 provides instruction physical addresses to BIU 14 and debug circuitry 26. In one form, the virtual or untranslated addresses may be logical addresses. In another form the untranslated addresses may be effective addresses. Effective addresses must first be translated into virtual addresses before being translated into physical addresses. Load/store unit 28 provides data virtual addresses to debug circuitry 26 and to MMU 16. MMU 16 provides data physical addresses to BIU 14 and debug circuitry 26.
Debug circuitry 26 then forms a debug message for external development system 36 using at least a portion of one or more of the received addresses, as will be discussed in more detail below. The format of debug messages may vary and examples will discussed below in connection with
Illustrated in
In operation, entries 0 through N store address mapping information used to translate virtual addresses to physical addresses. For example, an instruction or data virtual address is provided to MMU 16 (such as from instruction fetch unit 20 or load/store unit 28) where it is compared against the virtual addresses 209 stored in address translation logic 205. If a matching entry is found (where a matching entry is also a valid entry, as indicated by valid field 215), then the corresponding physical address 211 is provided as the instruction or data physical address to debug circuitry 26 and BIU 14. The corresponding TSIZ 210 of the matching entry provides the page size corresponding to the translated address and the corresponding TID 212 of the matching entry provides an address space identifier. When the TID field is 0, the matching entry applies to all processes because this entry is global. However, when the TID 212 is non-zero, a matching entry is only determined when both the received virtual address and the received PID match the virtual address 209 and the TID 212, respectively, of a valid entry in address translation logic 205. Also, through the use of MMU update registers 204, control 203, in response to processor instructions executed by processor 42, can update or modify entries within address translation logic 205, as will be discussed in more detail below in reference to
Illustrated in
In operation, message generation logic 64 is the logic circuitry which implements the function of forming debug messages pursuant to a selected one of a plurality of predetermined formats. Message generation logic 64 forms the debug messages, where compression logic 68 may perform message compression on parts or all of the messages, and these debug messages are then provided to debug control circuitry 60 where they are stored in message FIFO 70. From message FIFO 70, the debug messages are routed to debug terminals 40 via I/O logic 66. In one embodiment, each time an entry in address translation logic 205 is modified or updated, message generation logic 64 generates an address translation trace message. For example, each time control 203 asserts the modification indicator which indicates to both address translation logic 205 and message generation logic 64 that an entry in address translation logic 205 is being modified, message generation logic 64 generates an address translation trace message based on address translation information received from control 203. Note that modification of an entry, as used herein, may also include invalidation of an entry. The format of these address translation trace messages will be described in more detail below in reference to
Illustrated in
For example,
In one embodiment of the present invention, when an entry of address translation logic 205 is updated, such as whenever either a TLBWE or a TLB_INV instruction is executed, control 203 notifies debug circuitry 26 via the modification indicator and, in response thereto, message generation logic 64 in debug circuitry 26 generates an address translation trace message which may be provided (from FIFO 70, via I/O logic 66) to debug terminals 40. In this manner, debugger 26 need not explicitly request address translation information from address translation logic 205 since the information is automatically sent when a modification occurs. An example of TLBWE-based address translation trace messages and a TLB_INV-based address translation trace message will be described in reference to
Illustrated in
Referring to
Referring to
Referring to
Referring first to
Referring back to
In one embodiment, for field-compressed address translation trace messages, those fields which contain a predetermined prevalent value are the fields that are not included in the message. For example, in one embodiment, both the TID and TSIZE fields tend to have a prevalent value and thus need not be transmitted in each address translation trace message. For example, in one embodiment, a TID value of 00000000 indicates that the address translation entry is to be available to all process ID values, rather than restricted to matching a single process ID (PID) value. In this embodiment, an all-zero TID value may be considered a prevalent TID value. In alternate embodiments, a different TID value representing a predominant process with a predetermined non-zero TID value may be defined to be a prevalent value. In one embodiment, a particular page size for virtual and physical pages may be prevalent. For example, in many systems, a page size of 4 kilobytes (4 Kbytes) is a predominant page size value and may thus be defined as a predetermined prevalent value, since a majority of address translation entries will have such a value encoded in the TSIZ field of the stored TLB entry. For these common cases, field compression allows for a reduction in the maximum message length that must be transmitted to the external development system 36. Such a reduction may improve bandwidth of debug messages, and may also be of benefit in optimizing the size of message FIFO 70 of debug control circuitry 60. In one embodiment, the predetermined prevalent value of a field that is to be removed from the message or not transmitted to external development system 36 is controlled by a user of system 10. That is, this value can be stored in user programmable storage location, such as, for example, within MMU update registers 204.
As discussed above in reference to
In the illustrated embodiment of
In one embodiment, the determination of whether to provide a program correlation message with history delimitation 92 and an address translation trace message at the point that a change of mapping occurs in address translation logic 205 or whether to provide a single address translation trace message with history delimitation 90 may be based on whether field compression can occur to limit the maximum size of a message. If prevalent values are present in the address translation modification, then in one embodiment, a single address translation trace message with history delimitation 90 is generated. If prevalent values are not present, which requires that the TSIZ and/or TID information be provided to external development system 36, the determination may be made to send both a program correlation message with history delimitation (such as message 92) and an address translation trace message (such as message 86). In one embodiment, a single address translation trace message with history delimitation which was not field compressed would exceed the size of the entries in message FIFO 70, and thus would require a larger than optimal FIFO. By selectively generating program correlation message with history delimitation message 92 based on whether message compression is inadequate to allow a single address translation trace message with history delimitation to fit in a predetermined message bit-length, optimization of the width of the entries in message FIFO 70 may be performed, since in some embodiments, the majority of messages require fewer bits than address translation trace messages 86 and 90, and much of the storage capacity of FIFO 70 is unused within a given entry. A better optimization may be to increase the number of entries in FIFO 70 while narrowing the width of the entries. Note that in some embodiments, the determination of whether one or more fields may be eliminated from an address translation trace message due to containing a predetermined prevalent value may be used to select between a single address translation trace message with history delimitation, or both a program correlation message with history delimitation and an address translation trace message without history delimitation. In other embodiments, additional factors, such as the degree of compression of one or both of compressed virtual address and compressed physical address fields may be used in determining the optimal messaging decision strategy.
In one embodiment, additional triggering events (in addition to a change in virtual memory mapping as is caused by modification of an entry of address translation logic 205) may result in the need for a program correlation message (PCM) which provides branch history and a sequence count (i.e. instruction count) up to the point of the triggering event. In one embodiment, processor 42 may be capable of transparently executing multiple instruction sets with unique binary encodings, such as a normal fixed length instruction set, and an alternate variable length encoded (VLE) instruction set. In one embodiment, the instruction set being executed is constant within an instruction page, but may differ in different pages of memory, and thus the interpretation of the stored binary values in the physical memory by the external debugger depends on an accurate knowledge of which instruction set is present in a given page. For example, when processor 42 crosses a page boundary that results in an execution mode switch into or out of a sequence of VLE instructions, a PCM is generated which effectively breaks up any running instruction count and history information between the two modes of operation, thus needing a program correlation message to provide the branch history and sequence count up to the point at which the execution mode switch occurs. Also, in another example, when using program traces in history mode (such as when generating trace messages like trace message 81), when a direct branch results in an execution mode switch into or out of VLE instructions, a PCM is also generated. In addition to these PCM type triggers, another example occurs when program trace messaging becomes masked due to reaching a predetermined instruction mask, or when certain predetermined processor 42 exceptions or other system events within data processing system 10 occur. In these cases, rather than generating a program correlation message due to each of these events which may occur (such as when a change in virtual mapping occurs at the same time as crossing a page boundary resulting in an execution mode switch), a single program correlation message representing both triggering events can be generated. In this example, a format such as that of program correlation message 92 of
By now it should be appreciated that there has been provided a data processing system having efficient real-time debug addressing. By generating address translation trace messages in response to modification or invalidation of an entry within address translation logic 205, debug circuitry 26 need not explicitly request this type of address translation information. In one embodiment, any modification of any of the one or more fields of the entry is sufficient to result in generation of an address translation trace message. In this manner, improved debugging may be performed in systems which utilize address translation, such as in systems which utilize one or more TLBs for translating addresses. Furthermore, in cases in which the virtual address mapping is changed, program correlation messages may be generated with the appropriate timing so as to provide more accurate information with respect to branch history information and sequence count information. Also, efficiency may be further improved by compressing one or more fields of the debug messages, by field-compressing the debug messages, or by merging multiple messages (such as program correlation messages) when possible. Changes to address translation mappings may be caused by processor instruction execution of control instructions for modification of TLB contents, or in alternate embodiments may be caused by memory management unit hardware which autonomously maintains the TLB via translation table searches such as by performing table-walks to obtain new translations when TLB misses occur.
Because the various apparatus implementing the present invention are, for the most part, composed of electronic components and circuits known to those skilled in the art, circuit details have not been explained in any greater extent than that considered necessary as illustrated above, for the understanding and appreciation of the underlying concepts of the present invention and in order not to obfuscate or distract from the teachings of the present invention.
Some of the above embodiments, as applicable, may be implemented using a variety of different information processing systems. For example, although
Thus, it is to be understood that the architectures depicted herein are merely exemplary, and that in fact many other architectures can be implemented which achieve the same functionality. In an abstract, but still definite sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermedial components. Likewise, any two components so associated can also be viewed as being “operably connected,” or “operably coupled,” to each other to achieve the desired functionality.
Furthermore, those skilled in the art will recognize that boundaries between the functionality of the above described operations are merely illustrative. The functionality of multiple operations may be combined into a single operation, and/or the functionality of a single operation may be distributed in additional operations. Moreover, alternative embodiments may include multiple instances of a particular operation, and the order of operations may be altered in various other embodiments.
Although the invention is described herein with reference to specific embodiments, various modifications and changes can be made without departing from the scope of the present invention as set forth in the claims below. For example, any number of integrated circuit chips may be used. Accordingly, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of the present invention. Any benefits, advantages, or solutions to problems that are described herein with regard to specific embodiments are not intended to be construed as a critical, required, or essential feature or element of any or all the claims.
The term “coupled,” as used herein, is not intended to be limited to a direct coupling or a mechanical coupling.
Furthermore, the terms “a” or “an,” as used herein, are defined as one or more than one. Also, the use of introductory phrases such as “at least one” and “one or more” in the claims should not be construed to imply that the introduction of another claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an.” The same holds true for the use of definite articles.
Unless stated otherwise, terms such as “first” and “second” are used to arbitrarily distinguish between the elements such terms describe. Thus, these terms are not necessarily intended to indicate temporal or other prioritization of such elements.
The following are various embodiments of the present invention.
Item 1 includes a data processing system having a data processor for executing a plurality of data processing instructions; a memory coupled to the data processor for storing and providing information to the data processor; debug circuitry coupled to the data processor for generating debug messages including address translation trace messages; and a memory management unit coupled to the debug circuitry, data processor and the memory, the memory management unit comprising a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms. The debug circuitry includes message generation circuitry coupled to the memory management unit for receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information. The branch history information includes a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information includes a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB. Item 2 includes the data processing system of item 1 wherein the message generation circuitry provides the corresponding program correlation message before providing the address translation trace message. Item 3 includes the data processing system of item 1 wherein the message generation circuitry detects a need to generate a second program correlation message at the same point in time due to an event other than modification of a TLB entry, and the message generation circuitry combines the program correlation message and the second program correlation message to form a merged program correlation message that contains the branch history information, the instruction count information and at least one field of merged information that is common to both the program correlation message and the second program correlation message. Item 4 includes the data processing system of item 1 wherein the message generation circuitry compresses a length of the address translation trace message and replaces a portion of the address translation trace message that is removed by compression with at least one of branch history information and instruction count information of one or more data processing instructions executed up to the point in time when the new TLB entry is established in the TLB. Item 5 includes the data processing system of item 1 wherein the corresponding program correlation message contains both branch history information and instruction count information. Item 6 includes the data processing system of item 1 wherein the message generation circuitry receives notice from the memory management unit in response to performing a TLB write entry operation. Item 7 includes the data processing system of item 1 wherein a debugger is coupled to the data processing system for receiving both the address translation trace message and the corresponding program correlation message from the debug circuitry, and the data processing system is within an integrated circuit and the debugger is external to the integrated circuit.
Item 8 includes a method which includes providing a data processor for executing a plurality of data processing instructions; coupling a memory to the data processor for storing and providing information to the data processor; coupling a memory management unit to the data processor and the memory, the memory management unit comprising a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms; and coupling debug circuitry to the data processor and memory management unit for generating debug messages including address translation trace messages. the debug circuitry receives notice when TLB entries are modified and generates both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information. The branch history information includes a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information includes a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB. Item 9 includes the method of item 8 and further includes providing the corresponding program correlation message before providing the address translation trace message. Item 10 includes the method of item 8 and further includes detecting a need to generate a second program correlation message at a same point in time as generating the program correlation message due to an event other than modification of a TLB entry; and combining the program correlation message and the second program correlation message to form a merged program correlation message that contains the branch history information, the instruction count information and at least one field of merged information that is common to both the program correlation message and the second program correlation message. Item 11 includes the method of item 8 and further includes compressing a length of the address translation trace message and replacing a portion of the address translation trace message that is removed by compression with at least one of branch history information and instruction count information of one or more data processing instructions executed up to the point in time when the new TLB entry is established in the TLB. Item 12 includes the method of item 8 and further includes forming the corresponding program correlation message contains both branch history information and instruction count information. Item 13 includes the method of item 8 and further includes the memory management unit providing notice to the debug circuitry in response to performing a TLB write entry operation.
Item 14 includes a data processing system having an instruction fetch unit for receiving and storing a plurality of data processing instructions; an instruction decoder coupled to the instruction fetch unit for receiving the plurality of data processing instructions and decoding each of the plurality of data processing instructions; an execution unit coupled to the instruction decoder for executing the plurality of data processing instructions; a memory coupled to the instruction fetch unit and the execution unit for storing information from the execution unit and providing information to the instruction fetch unit; debug circuitry coupled to the instruction fetch unit, where the instruction decoder and the execution unit generate debug messages including address translation trace messages; and a memory management unit coupled to the debug circuitry, data processor and the memory, wherein the memory management unit includes a translation lookaside buffer (TLB) for implementing address translation to translate addresses between virtual and physical forms. The debug circuitry includes message generation circuitry coupled to the memory management unit for receiving notice when TLB entries are modified and generating both an address translation trace message and a corresponding program correlation message containing at least one of branch history information and instruction count information. The branch history information includes a history of direct branch instructions that are executed and whether, when executed, the direct branch instructions were taken, and the instruction count information includes a count of one or more data processing instructions executed up to a point in time when a new TLB entry is established in the TLB. Item 15 includes the data processing system of item 14 wherein the message generation circuitry provides the corresponding program correlation message before providing the address translation trace message. Item 16 includes the data processing system of item 14 wherein the message generation circuitry detects a need to generate a second program correlation message at the same point in time due to an event other than modification of a TLB entry, and the message generation circuitry combines the program correlation message and the second program correlation message to form a merged program correlation message that contains the branch history information, the instruction count information and at least one field of merged information that is common to both the program correlation message and the second program correlation message. Item 17 includes the data processing system of item 14 wherein the message generation circuitry compresses a length of the address translation trace message and replaces a portion of the address translation trace message that is removed by compression with at least one of branch history information and instruction count information of one or more data processing instructions executed up to the point in time when the new TLB entry is established in the TLB. Item 18 includes the data processing system of item 14 wherein the corresponding program correlation message contains both branch history information and instruction count information. Item 19 includes the data processing system of item 14 wherein the message generation circuitry receives notice from the memory management unit in response to performing a TLB write entry operation. Item 20 includes the data processing system of item 14 wherein a debugger is coupled to the data processing system for receiving both the address translation trace message and the corresponding program correlation message from the debug circuitry, the data processing system being within an integrated circuit and the debugger being external to the integrated circuit.
Moyer, William C., Collins, Richard G., Gamoneda, Jonathan J.
Patent | Priority | Assignee | Title |
9058421, | Jun 16 2009 | SHENZHEN XINGUODU TECHNOLOGY CO , LTD | Trace correlation for profiling subroutines |
9626279, | Jul 01 2013 | SHENZHEN XINGUODU TECHNOLOGY CO , LTD | Debug method and device for providing indexed trace messages |
9626280, | Jul 01 2013 | SHENZHEN XINGUODU TECHNOLOGY CO , LTD | Debug method and device for handling exceptions and interrupts |
Patent | Priority | Assignee | Title |
5127103, | Oct 14 1987 | North American Philips Corporation | Real-time tracing of dynamic local data in high level languages in the presence of process context switches |
5630049, | Nov 30 1994 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method and apparatus for testing software on a computer network |
5913923, | Dec 06 1996 | GLOBALFOUNDRIES Inc | Multiple bus master computer system employing a shared address translation unit |
6779145, | Oct 01 1999 | STMicroelectronics Limited | System and method for communicating with an integrated circuit |
6883162, | Jun 06 2001 | Oracle America, Inc | Annotations for transaction tracing |
6918065, | Oct 01 1999 | Renesas Electronics Corporation | Method for compressing and decompressing trace information |
7296137, | May 27 2005 | GOOGLE LLC | Memory management circuitry translation information retrieval during debugging |
7299335, | May 27 2005 | GOOGLE LLC | Translation information retrieval transparent to processor core |
20060117224, | |||
20060271919, | |||
20070130119, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 18 2009 | GAMONEDA, JONATHAN J | Freescale Semiconductor, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022324 | /0650 | |
Feb 18 2009 | COLLINS, RICHARD G | Freescale Semiconductor, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022324 | /0650 | |
Feb 19 2009 | Freescale Semiconductor, Inc. | (assignment on the face of the patent) | / | |||
Feb 19 2009 | MOYER, WILLIAM C | Freescale Semiconductor, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 022324 | /0650 | |
Apr 28 2009 | Freescale Semiconductor, Inc | CITIBANK, N A | SECURITY AGREEMENT | 022703 | /0405 | |
Mar 15 2013 | Freescale Semiconductor, Inc | MOSAID TECHNOLOGIES INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 030878 | /0824 | |
Mar 15 2013 | CITIBANK N A | Freescale Semiconductor, Inc | SECURITY AGREEMENT RELEASE | 030744 | /0754 | |
Jan 01 2014 | Mosaid Technologies Incorporated | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 032439 | /0638 | |
Jun 11 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | ROYAL BANK OF CANADA, AS LENDER | U S PATENT SECURITY AGREEMENT FOR NON-U S GRANTORS | 033706 | /0367 | |
Jun 11 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CPPIB CREDIT INVESTMENTS INC , AS LENDER | U S PATENT SECURITY AGREEMENT FOR NON-U S GRANTORS | 033706 | /0367 | |
Aug 20 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CHANGE OF ADDRESS | 033678 | /0096 | |
Dec 07 2015 | CITIBANK, N A , AS COLLATERAL AGENT | Freescale Semiconductor, Inc | PATENT RELEASE | 037354 | /0793 | |
Jul 31 2018 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CPPIB CREDIT INVESTMENTS, INC | AMENDED AND RESTATED U S PATENT SECURITY AGREEMENT FOR NON-U S GRANTORS | 046900 | /0136 | |
Jul 31 2018 | ROYAL BANK OF CANADA, AS LENDER | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | RELEASE OF U S PATENT AGREEMENT FOR NON-U S GRANTORS | 047645 | /0424 | |
Oct 28 2020 | CPPIB CREDIT INVESTMENTS INC | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 054445 | /0503 | |
Apr 01 2021 | CONVERSANT INTELLECTUAL PROPERTY INC | Mosaid Technologies Incorporated | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 057857 | /0193 | |
Apr 01 2021 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Mosaid Technologies Incorporated | CORRECTIVE ASSIGNMENT TO CORRECT THE CONVEYING PARTY S NAME PREVIOUSLY RECORDED AT REEL: 057857 FRAME: 0193 ASSIGNOR S HEREBY CONFIRMS THE CHANGE OF NAME | 064741 | /0939 |
Date | Maintenance Fee Events |
Jan 14 2015 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 23 2019 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Feb 01 2023 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 02 2014 | 4 years fee payment window open |
Feb 02 2015 | 6 months grace period start (w surcharge) |
Aug 02 2015 | patent expiry (for year 4) |
Aug 02 2017 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 02 2018 | 8 years fee payment window open |
Feb 02 2019 | 6 months grace period start (w surcharge) |
Aug 02 2019 | patent expiry (for year 8) |
Aug 02 2021 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 02 2022 | 12 years fee payment window open |
Feb 02 2023 | 6 months grace period start (w surcharge) |
Aug 02 2023 | patent expiry (for year 12) |
Aug 02 2025 | 2 years to revive unintentionally abandoned end. (for year 12) |