This application is related to the following co-pending U.S. patent application Ser. No. 11/560,217, filed Nov. 15, 2006, entitled NON-INTRUSIVE, THREAD-SELECTIVE, DEBUGGING METHOD AND SYSTEM FOR A MULTI-THREAD DIGITAL SIGNAL PROCESSOR; U.S. patent application Ser. No. 11/560,323, filed Nov. 15, 2006, entitled METHOD AND SYSTEM FOR A DIGITAL SIGNAL PROCESSOR DEBUGGING DURING POWER TRANSITIONS; U.S. patent application Ser. No. 11/560,332, filed Nov. 15, 2006, entitled METHOD AND SYSTEM FOR TRUSTED/ENTRUSTED DIGITAL SIGNAL PROCESSOR DEBUGGING OPERATIONS; and U.S. patent application Ser. No. 11/560,344, filed Nov. 15, 2006, entitled METHOD AND SYSTEM FOR INSTRUCTION STUFFING OPERATIONS DURING NON-INTRUSIVE DIGITAL SIGNAL PROCESSOR DEBUGGING.
The disclosed subject matter relates to data processing systems and processes, such as may find use in data communications and similar applications. More particularly, this disclosure relates to a novel and improved method and system for digital signal processing debugging operations, including providing and making use of an embedded trace macrocell for enhance debugging operations.
Increasingly, telecommunications and other types of electronic equipment and supporting video, complex audio, videoconferencing and other rich software applications involve signal processing. Signal processing requires fast mathematical calculations and data generation in complex, but repetitive algorithms. Many applications require computations in real-time, i.e., the signal is a continuous function of time, which must be sampled and converted to digital signals for numerical processing. The processor must execute algorithms performing discrete computations on the samples as they arrive.
The architecture of a digital signal processor (DSP) is optimized to handle such algorithms. The characteristics of a good signal processing engine include fast, flexible arithmetic computation units, unconstrained data flow to and from the computation units, extended precision and dynamic range in the computation units, dual address generators, efficient program sequencing, and ease of programming.
One promising application of DSP technology includes communications systems such as a code division multiple access (CDMA) system that supports voice and data communications, as well as text messaging and other applications, between users over a satellite or terrestrial link. The use of CDMA techniques in a multiple access communication system is disclosed in U.S. Pat. No. 4,901,307, entitled “SPREAD SPECTRUM MULTIPLE ACCESS COMMUNICATION SYSTEM USING SATELLITE OR TERRESTRIAL REPEATERS,” and U.S. Pat. No. 5,103,459 entitled “SYSTEM AND METHOD FOR GENERATING WAVEFORMS IN A CDMA CELLULAR TELEHANDSET SYSTEM,” both assigned to the assignee of the claimed subject matter.
A CDMA system is typically designed to conform to one or more standards. One such first generation standard is the “TIA/EIA/IS-95 Terminal-Base Station Compatibility Standard for Dual-Mode Wideband Spread Spectrum Cellular System,” hereinafter referred to as the IS-95 standard. The IS-95 CDMA systems are able to transmit voice data and packet data. A newer generation standard that may more efficiently transmit packet data is offered by a consortium named the “3rd Generation Partnership Project” (3GPP) and embodied in a set of documents including Document Nos. 3G TS 25.211, 3G TS 25.212, 3G TS 25.213, and 3G TS 25.214, which are readily available to the public. The 3GPP standard is hereinafter referred to as the W-CDMA Standard.
Complex DSP operational software employing the W-DCMA Standard, for example, requires robust development tools. Such development tools may include those for code generation, integration, testing, debugging, and evaluating application performance. In developing and operating software or complex DSP applications, such as advanced telecommunications applications, there is the need for sophisticated, yet non-intrusive debugging software. That is, debugging software applications must be not only sufficiently robust to monitor, test, and support the correction of software defects and operational problems, but also they may operate so as not to interfere with the core processor software during debugging operations. Otherwise, any problems in the core processing software may not be detected or detected properly during the use of such debugging software.
During debugging operations, there is a need for associating the non-intrusive software debugging process software executing tracing facilities for the associated processor. Such a system may provide information on the processor's state for permitting such information to be captured both before and after a specific event. At the same time, such features cannot adding any significant burden to the processor's performance, even while the DSP operates at full speed. In combination with a non-intrusive debugging operation, such a process may provide for configuration in software for capture select trace information, for example, after a specific sequence of conditions. Such a monitoring and recording mechanism may also operate in conjunction with the non-intrusive debugging process for thread-selectable operation in a multi-threaded processor for permitting various types of configuration and breakpoint determinations and permissions.
Yet a further need exists for a non-intrusive debugging system capable of capturing in real-time detailed information about the DSP's execution flow, and to do so in a non-intrusive manner.
A further need exists for a software execution monitoring and recording system for operation in conjunction with a non-intrusive debugging mechanism, which itself provides for the limitation and focusing of the generation of trace information to one or more regions of interest within the DSP core.
Still further, there is a need for a non-intrusive debugging system that may respond to the operation of a software execution and monitoring process and system. A need clearly exists for a way to initiate the debugging system itself upon the initiation or a transition in the operation of the software execution monitoring and recording system. Accordingly, such a feature may be provided by the associated non-intrusive debugging system for such close and operationally synergistic functioning with the software execution monitoring and recording system.
Techniques for providing non-intrusive, thread-selective, debugging method and system for a digital signal processor, including a multi-threaded digital signal processor, are disclosed, which techniques cooperate with an embedded trace macrocell for initiating debugging operations in response to certain monitored events in core processor operations. The method and system here disclosed improve both the operation of a digital signal processor and the efficient use of digital signal processor instructions for increasingly powerful software applications, including applications operating in personal computers, personal digital assistants, wireless handsets, and similar electronic devices, as well as increasing the associated digital processor speed and service quality.
According to one aspect of the disclosed subject matter, a method and system are provided for improving software instruction debugging operations by capturing real-time information relating to software execution flow in a processor. The method and system include and instructions and circuitry for operating a core processor process within a core processor associated with the digital signal processor. The disclosed subject matter operates a non-intrusive debugging process within a debugging mechanism of the digital signal processor. Non-intrusively monitoring in real time predetermined aspects of software execution associated with the core processing process and occurring in real-time on the processor, using an embedded trace macrocell. The embedded trace macrocell records selectable aspects of the non-intrusively monitored software execution and generates at least one breakpoint in response to events arising within the selectable aspects of the non-intrusively monitored software execution. The present disclosure controls aspects of the non-intrusive debugging process in response to at least one breakpoint. As a result, the disclosed subject matter cooperates with the non-intrusive debugging process for multi-thread trace instruction sequencing and timing for up to all threads of a multi-threaded digital signal processor.
These and other advantages of the disclosed subject matter, as well as additional novel features, will be apparent from the description provided herein. The intent of this summary is not to be a comprehensive description of the claimed subject matter, but rather to provide a short overview of some of the subject matter's functionality. Other systems, methods, features and advantages here provided will become apparent to one with skill in the art upon examination of the following FIGUREs and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description, be within the scope of the accompanying claims.
The features, nature, and advantages of the disclosed subject matter may become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout and wherein:
The disclosed subject matter for a non-intrusive, thread-selective, debugging method and system for a multi-threaded digital signal processor has application for multi-threaded processing of any type for which the benefits here presented may be advantageous. One such application appears in telecommunications and, in particular, in wireless handsets that employ one or more digital signal processing circuits. For explaining how such a wireless handset may be used,
At a receiver unit 22, the transmitted signal is received by an antenna 24 and provided to a receiver (RCVR) 26. Within receiver 26, the received signal is amplified, filtered, down converted, demodulated, and digitized to generate in phase (I) and (Q) samples. The samples are then decoded and processed by a receive (RX) data processor 28 to recover the transmitted data. The decoding and processing at receiver unit 22 are performed in a manner complementary to the coding and processing performed at transmitter unit 12. The recovered data is then provided to a data sink 30.
The signal processing described above supports transmissions of voice, video, packet data, messaging, and other types of communication in one direction. A bi-directional communications system supports two-way data transmission. However, the signal processing for the other direction is not shown in
Output from execution data paths 62 goes to register file write circuit 64, also configured to accommodate individual threads T0:T5, for returning the results from the operations of DSP 40. Thus, the data path from circuit 54 and before to register file write circuit 64 forms a processing pipeline 66. The present embodiment may employ a hybrid of a heterogeneous element processor (HEP) system using a single processor with up to six threads, T0:T5. Processor pipeline 66 has six stages, which matches the minimum number of processor cycles necessary to fetch a data item from circuit 54 to registers 60 and 64. DSP 40 concurrently executes instructions of different threads T0:T5 within a processor pipeline 66. That is, DSP 40 provides six independent program counters, an internal tagging mechanism to distinguish instructions of threads T0:T5 within processor pipeline 66, and a mechanism that triggers a thread switch. Thread-switch overhead varies from zero to only a few cycles.
DSP 40, therefore, provides a general-purpose digital signal processor designed for high-performance and low-power across a wide variety of signal, image, and video processing applications.
Sequencer 76 provides hybrid two-way superscalar instructions and four-way VLIW instructions to S-Pipe unit 86, M-Pipe unit 88, LD[Load]-Pipe 90, and LD/ST[Store]-Pipe unit 92, all of which communicate with general registers 94. AXI Bus 74 also communicates via Bus I/F 73 with shared data cache 96 LD/ST instructions to threads T0:T5. Optional L2 Cache/TCM 98 signals include LD/ST instructions with shared data TCM 100, which LD/ST instructions further flow to threads General Registers 94. From AHB peripheral bus 102 MSM specific controller 104 communicates interrupts with T0:T5, including interrupt controller instructions, debugging instructions, and timing instructions. Global control registers 106 communicates control register instructions with threads T0:T5.
DSP 40, therefore, includes six virtual DSP cores, each containing global control registers 106 and private supervisor control registers 80. Global control registers 106 are shared between all threads. Each thread shares a common data cache and a common instruction cache. Load, store, and fetch operations are serviced by a common bus interface. High performance AXI bus 74 and a lower performance AHB bus 102 are used to connect the data and instruction traffic to off-core memory and peripherals. An integrated level two memory (cache and/or TCM) input 98 is optional. Peripheral access may be through memory-mapped loads and stores. The physical address partition between AHB and AXI may be configured at the MSM level.
Clearly, the presented architecture for DSP 40 may evolve and change over time. For example, the number of instruction caches that DSP 40 may use could change from six to one, or other numbers of caches. Superscalar dispatch, L1 data at TCM 100, and other architectural aspects may change. However, the present subject matter may have continued relevance in a wide variety of configurations and for a large family of modifications of DSP 40.
ISDB 82, through JTAG interface 84, provides a hardware debugger for DSP 40. ISDB 82 provides software debug features through JTAG interface 84 by sharing system or supervisor-only registers, that are divided into supervisor control registers 80 on a per thread basis, as well as global control registers 106 between all threads. The system control registers are used for per thread interrupt and exception control and per thread memory management activities. Global registers allow interacting with the ISDB 82 for debugging operations.
ISDB 82 enables software developers to debug their software while DSP 40 operates. ISDB 82 hardware, in combination with a software debugger program operating in ISDB 82, may be used to debug the DSP 40 operating system software. ISDB 82 supports debugging hardware threads individually. Users may suspend thread execution, view and alter thread registers, view and alter instruction and data memory, single step threads, stuff instructions to threads, and resume thread execution. Trusted users have access to all of ISDB 82 features, while untrusted users have access to a subset of features.
ISDB 82 may interface with a debugger interface card to communicate with ISDB 82 debugging software residing on a program counter, yet all through JTAG interface 84. Host debugger software may interact with the ISDB 82 by reading and writing ISDB control registers. Communication, for example, may be through a 40-bit packet which identifies the ISDB register to which read/write is to occur, as well as a 32-bit data payload. A packet format supporting this operation may be up to 64 control registers which may be 32 bits wide each.
ISDB 82 includes a trusted register for controlling security during a debugging operation. If the ISDB 82 trusted is set, then all ISDB 82 registers are visible to the debugger software, and all ISDB commands are available for use. In the case that ISDB trusted is cleared, then ISDB 82 only permits a restricted set of operations. These aspects of the present disclosure appear in more detail below.
Certain ISDB 82 registers may be made visible to core software. These are accessible via SUPERVISOR mode control register transfer instructions. The core instructions include a breakpoint instruction. When ISDB trusted is set, this instruction causes the executing thread to enter a debugging operational mode. This transition shifts thread control to ISDB 82. In addition to the thread that executed a breakpoint, other threads may optionally enter DEBUG mode 150 according to ISDB 82 programming. If ISDB 82 is not trusted or not enabled, this instruction is treated as a NOP. Preferably, the breakpoint instruction is the only instruction in a packet.
Having listed the various components of ISDB 82 what follow are a brief operational description and introduction to the constituent parts of the control or logic circuitry for performing non-intrusive trusted and untrusted debugging operations of DSP 40. ISDB controller 118 handles a variety of tasks, including (a) implementing various ISDB registers; (b) synchronizing the MCD external breakpoint and resume triggers and the ETM breakpoint trigger to DSP 40 before they are forwarded to CU 122 for further processing; (c) generating MCD breakpoint and resume triggers based on debug mode status of core; and (d) adding a pipeline stage for signals sent out to DSP 40 sub-system, such as ISDB interrupt, breakpoint event etc.
CU 122 includes circuitry and instructions capable of handling the tasks such as (a) processing breakpoints and generating breakpoint triggers to each thread; (b) generating micro-breakpoint and micro-resume commands; (c) maintaining ISDB 82 status and mailbox registers; and (d) implementing the certain ISDB 82 registers. CU 122 includes a breakpoint processing logic (BPL) block as appears in
CU ISDB controller 128 maintains the state of ISDB 82 based on the breakpoint and resume acknowledge signals received back. The mailbox functions of CU ISDB controller 126 maintain mailbox registers used for communication between the host debug software and the DSP 40 core processor. These mailbox functions also contain ISDB 82 status registers.
The per-thread mode state diagram of
Registers are available in DSP 40 in both USER mode 142 and SUPERVISOR mode 144. The user-mode registers are divided into a set of general registers and a set of control registers. General registers are used for all general purpose computation including address generation, scalar and vector arithmetic. Control registers support special-purpose functionality such as hardware loops, predicates, etc. General purpose registers are 32 bits wide and may be accessed as single registers or as aligned pairs of two registers. The general register file provides all operands for instructions, including addresses for load/store, data operands for numeric instructions, and vector operands for vector instructions.
DEBUG mode 150 provides a special state where the thread is waiting for commands from ISDB 82. Whenever an ISDB Debug Event occurs, such as by the execution of a software breakpoint instruction, a breakpoint command from ISDB 82, or occurrence of a hardware breakpoint, indicated threads may enter DEBUG mode 150. While in DEBUG mode 150, the core is controlled by ISDB 82 via commands from JTAG interface 84. When the ISDB 82 releases the thread due to execution of a resume command, the thread may resume operation according to their current mode settings. When a thread is in DEBUG mode 150, it is controlled by ISDB 82 and cannot be controlled by other threads. A Wait, Resume, Start, or Stop instruction from a running thread, targeting a thread in DEBUG mode 150, may be ignored. Similarly, a Non-Maskable Interrupt (NMI) may be ignored by threads in DEBUG mode 150.
A HARDWARE RESET mode (not shown in
In
The breakpoint triggers in BPL circuit 160 are processed along with the corresponding TNUM mask to generate macro breakpoint trigger to each of the threads. The macro breakpoint trigger 198, bpl_breakTnum_ANY[0], is maintained until the corresponding thread is resumed. The number of pipeline stages that can be used in BPL 160 is driven by hardware breakpoints which are precise breakpoints, i.e., the instruction that triggers hardware breakpoint match must not be executed. The thread switches to debug mode after executing the program until that instruction. The disclosed embodiment provides a macro breakpoint trigger one cycle after the breakpoint triggers arrive. For that reason the breakValid input 176 is logically OR'ed with its latched version input 192 to generate bpl_breakTnum_ANY[0] output 198.
Through the use of breakpoints, the six threads of DSP 40 may individually enter and exit DEBUG mode 150. A breakpoint trigger may come from five sources which correspond to the five different types of breakpoints supported in ISDB 82. Upon hitting a breakpoint, a thread transitions from its current mode (e.g., WAIT/RUN) to DEBUG mode 150. In DEBUG mode 150, the thread waits for commands from ISDB 82. A thread in OFF mode 148 is powered down and may not accept any commands from ISDB 82. The latency of entering DEBUG mode 150 is implementation defined, such as in the present disclosure as relating to the event a power collapse. For example, an implementation may choose to complete a given operation, for example finish an outstanding load request, before entering DEBUG mode 150. In one embodiment, a thread identifier register contains an 8-bit read/write field and is used for holding a software thread identifier. This field is used by the hardware debugger to match breakpoints.
There are a number of different ways to enter a breakpoint process. For example, for HWBKPT1162 and HWBKPT2164 breakpoints, if a register equals a predetermined value, then when the program counter (PC) matches the predetermined value, then the process goes into the DEBUG mode 150. ASIDs (Address Space Identifiers) are tags similar to process IDs in a process or a particular thread in a multithreaded process. So, physical address, virtual address, ASID, PC, or other qualifiers may be used to optionally obtain a fix of the location of the program in a space at which point a breakpoint may occur. The uses of breakpoints here referenced are more particularly disclosed in the commonly-assigned U.S. patent applications by L. Codrescu, et al, and entitled NON-INTRUSIVE, THREAD-SELECTIVE, DEBUGGING METHOD AND SYSTEM FOR A MULTI-THREADED DIGITAL SIGNAL PROCESSOR. The disclosed subject matter provides a path for moving into a DEBUG mode 150 in the event of a breakpoint such as those of
Of significance for the present disclosure is the embedded trace macrocell (ETM) unit of DSP 40, which enhances user debugging of code by capturing in real-time detailed information about the software execution flow. The ETM non-intrusively monitors and records selected DSP 40 execution, forms the execution information into packets, and sends out the packet stream either off-chip or to an on-chip memory known as an ETB. The ETM also contains a number of mechanisms to limit or focus the generation of trace information to the region of interest. Using the packet stream, a reconstruction of the execution can be created, giving the user direct visibility of the code's runtime behavior.
In the implementation of
ETM provides comprehensive debug and trace facilities for DSP 40 and other similar digital signal processors. They allow information on the processor's state to be captured both before and after a specific event, while adding no burden to the processor's performance, as DSP 40 runs at full speed. The ETM may be configured in software to capture only select trace information and only after a specific sequence of conditions. A dedicated, configurable, trace port and FIFO then allow the compressed trace data to be read from the chip by an external trace port analyzer without interrupting, or affecting, the processor.
The trace port can be configured from a 1- to 32-bit data bus, with trace clock independent to the core clock. For example, the data rate from the ETM can be half of the core clock and the number of pins increased to maintain the data bandwidth. Similarly, the number of pins can be halved and the data rate increased. The ETM may be used in both stand-alone and within a multi-core environment to allow the developer to view simultaneous, correlated trace from multiple, asynchronous cores.
As shown in
ETM 232 generates an instruction trace as a recording of the full progression of the program counter for a thread over a given window in time. Optionally, the timing of the program counter progression (i.e., identification of stall cycles) can also be included in an instruction trace. The event-resources mechanisms are used to define when to generate these instruction traces. The trigger and filtering functions are controlled through the programming of the event-resources. In more detail, the event-resources control filtering, triggering, and ISDB 82 breakpoint generation. Filtering includes the functions of deciding when to enable and disable an instruction trace. Triggering involves deciding when to insert a trigger marker into the packet stream. ISDB 82 breakpoint determination involves specifying the conditions under which ISDB 82 generates and responds to a breakpoint for debugging operations.
ETM 232 contains a number of primary event resources (e.g., address and data comparators) to detect when specific conditions within DSP 40 occur (e.g., whether a certain PC is executed, or if a certain memory location is read). In addition, there are secondary event resources (trigger blocks and the sequencer) which enable detection of more complex arrangements of events.
ETB trace repository 240 provides an on-chip memory area where trace information is stored during capture rather than being exported immediately through a trace port at the pins of the device. The stored information can then be read out at a reduced clock rate from ETB trace repository 240 once capture has been completed. This is done through JTAG interface 84. This two step process removes the necessity for a wide trace port that uses many, high-speed device pins. Effectively, a “zero-pin” trace port is created where the device already has a JTAG port at the pins. ETB trace repository 240 may accept data at a higher frequency and with the full 32-bit data port, exceeding trace port bandwidth limitations and may integrate with a RAM block supplied by the system integrator.
In one embodiment, ETB trace repository 240 has a size of 2 KB arranged as 512 entries, each 32-bits wide. ETB trace repository 240 interfaces with the user through a set of JTAG accessible registers. Each register can be read or written through JTAG interface 84. These registers are used to set up ETB trace repository 240 for a trace-capture session and to read out the contents of ETB trace repository 240 once trace capture is complete. ETB trace repository 240 provides a read-pointer as an index into the ETB trace repository 240 memory array. When reading out the contents of ETB trace repository 240 through JTAG interface 84, the read-pointer indicates the location to read. ETB trace repository 240 also provides a write-pointer as an index into the ETB trace repository 240 memory array. When trace data is written into ETB trace repository 240, it is written to the entry indicated by the write-pointer. Each of the write operations auto-increment the write-pointer to the next location after write occurs. ETB trace repository 240 may only capture a small window of the ETM trace stream. The ETB looks for a trigger packet from the ETM to determine when to capture data and the trigger-counter is used to specify the division between pre-trigger data and post-trigger data captured by ETB trace repository 240.
Each trigger block circuit 250 contains ASID and TID match registers to optionally limit SAC circuit 252 and DC circuit 256 matches to a particular thread or group of threads. In addition, each trigger block circuit 250 may be limited to a single hardware thread. SAC circuit 252 detects when an address generated by a memory access instruction matches a pre-programmed value. SAC circuit 252 supports 32-bit comparison. The memory source for the comparison is programmable among program counter and load/store address. For one embodiment, the comparison type may be programmable with the following options: equal (==), not-equal (!=), greater-than-or-equal (>=), or less-than (<) The access-type can be restricted to load-or-store, load-only or store-only. In such an embodiment, SAC circuit 252:254 may support only virtual address matching for each memory source.
DC circuit 256 detects when a memory access data value matches a pre-programmed value and can perform 32-bit comparisons. For 64-bit accesses, source is programmable between upper and lower-word. Supports equal (==) and not-equal (!=) comparison types. A 32-bit mask register may be used to filter out portions of the comparison. DC circuit 256 supports any-byte matching and the access-type can be set as load-or-store, load-only, or store-only. In addition, output of DC circuit 256 may be selectably disabled.
SAC circuit 252:254 and DC circuit 256 matches determine when counter circuit 258 decrements. As shown in
Counter circuit 258 contains a three-bit state enable mask that controls when the counter is reloaded. When a new state is entered, if this state matches one of the enabled states in the state-enable mask then the counter is reloaded. The counter is also automatically reloaded anytime it reaches zero. The counter can be bypassed by setting the count to 1. The match results from the two SAC circuits 252:254 are also used to enable or disable instruction flow tracing.
Filtering portion 262 permits trigger block circuit 250 to trace on individual SAC circuit 252 matches. Thus, for each SAC circuit 252:254, if the associated state-enable mask matches and if SAC circuit matches, tracing is enabled. Trace can occur also on address range match. Tracing is enabled based on the AND of SAC circuit 252:254 matches. The match is then further qualified with a state-enable-mask. Each of the three trace sources has a separate three-bit state enable mask to qualify the match with the current state. Using the above rules, the user may, for example, define different trace regions. One region may include trace instructions flow for thread i if the program counter (PC) is greater than 100 and less than 200, and only if the circuit is in state 1.
A second region may be for trace instruction flow for thread j if the PC is less than 100 and if we are in state 0 or if the PC is greater than 200 and in state 2. Because multiple trigger-blocks exist, the final trace enable is the OR of each trigger-block's trace-enable. All threads that match the combined results of the address comparison, the state-enabling, and the thread-matching may be traced. If multiple active threads match the enabling conditions, those threads may be traced concurrently.
Each trigger block circuit 250, therefore, thread-match circuit 282, which functions to limit the operation of both triggering portion 260 and filtering portion 262 to a particular thread or group of threads. Each trigger block contains TID match circuit 296, TID mask circuit 292, ASID match enable circuit 314, and TNUM match enable circuit 324. To use this capability, the match registers may be programmed with reference values that are used to compare against the current thread's identifiers. For a TID match circuit 296, the comparison can be restricted to certain portion of the TID through the TID mask circuit 292. This allows a group of TIDs to be matched. In addition, for each match type, the matching can be disabled through user programmable enable registers. trigger block circuit 250 only operates on threads that meet all of the qualifying conditions.
One aspect of ETM 232 includes a sequencer process for chaining of events and more complex event detection scenarios. To illustrate operation of the sequencer process and associated trigger block circuits 250,
Sequencer process 330, therefore, includes three states S0:S2, with the transitions between states being programmable and based on matches from trigger blocks circuits 332:338. The table of
ETM contains six counters that can record various events related to DSP 40 performance. The basic operation makes use of each counter as a programmable source. A user-programmable region counter divides execution into windows of a fixed number of cycles. During the window, the events are accumulated into counters. At the end of the window, the counter values are formed into packets and sent out through the trace port. The counters are then reset and the process begins again. When the profiling unit is operated in at the same time as the program flow tracing, this results in the program flow trace being overlaid with detailed information about performance events. In addition, the profiling unit contains a state-enable mask to limit when the unit is active.
A region counter is used to divide up the execution into windows of a fixed number of cycles. The size of the region is determined by a user-programmable register. The region counter is initialized to the user-specified value, and all of the profiling-event counters are reset. The region counter then begins counting down. When the region counter reaches zero, the value for each of the profiling-event counts is emitted in the trace stream. The process then begins again. The region-counter only counts when the state-enable matches. When the profiling is inactive, the region counter maintains its value and resumes when an enabled state is re-entered.
Different events for which a profiling counter may accumulate information include (a) d-cache misses; (b) d-cache stall cycles; (c) i-cache misses; (d) i-cache stall cycles; (e) ITLB and DTLB misses; and (f) total stall cycles. In addition, each profiling counter contains a six-thread mask to restrict the counter to events that occur in certain hardware threads.
As with the region counter, the profiling counters are only active when the state-enable mask matches the current state. During all other times the counts maintain their values and counting resumes when an enabled state is re-entered.
The functioning of ETM 232 is determined by the setting of various user-programmable registers. Each register is accessed through JTAG interface 84.
In summary, the disclosed subject matter provides a method and system for improving software instruction debugging operations by capturing real-time information relating to software execution flow in a processor. The method and system include and instructions and circuitry for operating a core processor process within a core processor associated with the digital signal processor. The disclosed subject matter operates a non-intrusive debugging process within a debugging mechanism of the digital signal processor. Non-intrusively monitoring in real time predetermined aspects of software execution associated with the core processing process and occurring in real-time on the processor, using an embedded trace macrocell. The embedded trace macrocell records selectable aspects of the non-intrusively monitored software execution and generates at least one breakpoint in response to events arising within the selectable aspects of the non-intrusively monitored software execution. The present disclosure controls aspects of the non-intrusive debugging process in response to at least one breakpoint. As a result, the disclosed subject matter cooperates with the non-intrusive debugging process for multi-thread trace instruction sequencing and timing for up to all threads of a multi-threaded digital signal processor.
The processing features and functions described herein for trusted and untrusted non-intrusive, thread-selective, debugging in a multi-threaded digital signal processor may be implemented in various manners. For example, not only may DSP 40 perform the above-described operations, but also the present embodiments may be implemented in an application specific integrated circuit (ASIC), a microcontroller, a digital signal processor, or other electronic circuits designed to perform the functions described herein. Moreover, the process and features here described may be stored in magnetic, optical, or other recording media for reading and execution by such various signal and instruction processing systems. The foregoing description of the preferred embodiments, therefore, is provided to enable any person skilled in the art to make or use the claimed subject matter. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without the use of the innovative faculty. Thus, the claimed subject matter is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
Number | Name | Date | Kind |
---|---|---|---|
4080650 | Beckett | Mar 1978 | A |
4669059 | Little et al. | May 1987 | A |
4901307 | Gilhousen et al. | Feb 1990 | A |
5093914 | Coplien et al. | Mar 1992 | A |
5103459 | Gilhousen et al. | Apr 1992 | A |
5136717 | Morley et al. | Aug 1992 | A |
5544311 | Harenberg et al. | Aug 1996 | A |
5551043 | Crump et al. | Aug 1996 | A |
5944841 | Christie | Aug 1999 | A |
5951696 | Naaseh et al. | Sep 1999 | A |
6018759 | Doing et al. | Jan 2000 | A |
6029248 | Clee et al. | Feb 2000 | A |
6052708 | Flynn et al. | Apr 2000 | A |
6067588 | Ito | May 2000 | A |
6106571 | Maxwell | Aug 2000 | A |
6199181 | Rechef et al. | Mar 2001 | B1 |
6202172 | Ponte | Mar 2001 | B1 |
6212544 | Borkenhagen et al. | Apr 2001 | B1 |
6226749 | Carloganu et al. | May 2001 | B1 |
6249907 | Carter et al. | Jun 2001 | B1 |
6314530 | Mann | Nov 2001 | B1 |
6341347 | Joy et al. | Jan 2002 | B1 |
6343371 | Flanagan et al. | Jan 2002 | B1 |
6467054 | Lenny | Oct 2002 | B1 |
6480818 | Alverson et al. | Nov 2002 | B1 |
6532553 | Gwilt et al. | Mar 2003 | B1 |
6567839 | Borkenhagen et al. | May 2003 | B1 |
6665802 | Ober | Dec 2003 | B1 |
6684348 | Edwards et al. | Jan 2004 | B1 |
6697935 | Borkenhagen et al. | Feb 2004 | B1 |
6708270 | Mayer | Mar 2004 | B1 |
6714958 | Tudor | Mar 2004 | B1 |
6757829 | Laczko, et al. | Jun 2004 | B1 |
6798713 | Yearsley et al. | Sep 2004 | B1 |
6832334 | Wojcieszak et al. | Dec 2004 | B2 |
6834360 | Corti et al. | Dec 2004 | B2 |
6915416 | Deng et al. | Jul 2005 | B2 |
6981261 | Kalafatis et al. | Dec 2005 | B2 |
7013400 | Kalla et al. | Mar 2006 | B2 |
7020871 | Bernstein et al. | Mar 2006 | B2 |
7047451 | Agarwala et al. | May 2006 | B2 |
7055139 | Balle et al. | May 2006 | B2 |
7073059 | Worely, et al. | Jul 2006 | B2 |
7076804 | Kershenbaum et al. | Jul 2006 | B2 |
7080289 | Swaine et al. | Jul 2006 | B2 |
7093236 | Swaine et al. | Aug 2006 | B2 |
7131114 | Nguyen et al. | Oct 2006 | B2 |
7185319 | Kaler et al. | Feb 2007 | B2 |
7203926 | Bogle et al. | Apr 2007 | B2 |
7210064 | Mayer | Apr 2007 | B2 |
7213134 | Soltis, Jr. | May 2007 | B2 |
7222262 | Prasadh et al. | May 2007 | B2 |
7254716 | Giles et al. | Aug 2007 | B1 |
7278058 | Narisi | Oct 2007 | B1 |
7318017 | Swoboda | Jan 2008 | B2 |
7321957 | Khan et al. | Jan 2008 | B2 |
7360117 | Boike et al. | Apr 2008 | B1 |
7369954 | Levine et al. | May 2008 | B2 |
7370210 | Symes | May 2008 | B2 |
7380112 | Okabayashi et al. | May 2008 | B2 |
7380276 | Saha et al. | May 2008 | B2 |
7383537 | Darweesh et al. | Jun 2008 | B2 |
7383540 | Kalra | Jun 2008 | B2 |
7421571 | Shoemaker | Sep 2008 | B2 |
7437619 | McCullough et al. | Oct 2008 | B2 |
7461407 | Little et al. | Dec 2008 | B2 |
7472378 | Bennett et al. | Dec 2008 | B2 |
7475303 | Edgar et al. | Jan 2009 | B1 |
7512954 | Srivastava et al. | Mar 2009 | B2 |
7577878 | Baradie et al. | Aug 2009 | B2 |
7594146 | Horikawa et al. | Sep 2009 | B2 |
7600221 | Rangachari | Oct 2009 | B1 |
7657791 | Codrescu et al. | Feb 2010 | B2 |
7657875 | Alexander, III et al. | Feb 2010 | B2 |
7770155 | Bates et al. | Aug 2010 | B2 |
7770156 | Thekkath | Aug 2010 | B2 |
7823131 | Gard et al. | Oct 2010 | B2 |
7890316 | Swoboda et al. | Feb 2011 | B2 |
7917907 | Ahmed et al. | Mar 2011 | B2 |
8136097 | Konishi et al. | Mar 2012 | B2 |
8185879 | Thekkath et al. | May 2012 | B2 |
8196109 | Fung et al. | Jun 2012 | B2 |
8239838 | Yim et al. | Aug 2012 | B2 |
20020004933 | Dzoba et al. | Jan 2002 | A1 |
20020035721 | Swoboda | Mar 2002 | A1 |
20020065646 | Waldie et al. | May 2002 | A1 |
20020099977 | Wong | Jul 2002 | A1 |
20030014643 | Asami et al. | Jan 2003 | A1 |
20030014736 | Nguyen et al. | Jan 2003 | A1 |
20030037226 | Tsuruta et al. | Feb 2003 | A1 |
20030061550 | Ng et al. | Mar 2003 | A1 |
20030065963 | Gregg | Apr 2003 | A1 |
20030074650 | Akgul et al. | Apr 2003 | A1 |
20030135720 | DeWitt, Jr. et al. | Jul 2003 | A1 |
20040024995 | Swaine | Feb 2004 | A1 |
20040103397 | Agarwala et al. | May 2004 | A1 |
20040103398 | Agarwala et al. | May 2004 | A1 |
20040117768 | Chang et al. | Jun 2004 | A1 |
20040123274 | Inagaki et al. | Jun 2004 | A1 |
20040133823 | Swoboda et al. | Jul 2004 | A1 |
20040170046 | Belnet et al. | Sep 2004 | A1 |
20040170168 | Dedek | Sep 2004 | A1 |
20040177269 | Belnet et al. | Sep 2004 | A1 |
20040260910 | Watt et al. | Dec 2004 | A1 |
20050034024 | Alverson et al. | Feb 2005 | A1 |
20050108689 | Hooper et al. | May 2005 | A1 |
20050177703 | Norden et al. | Aug 2005 | A1 |
20050177819 | Ober et al. | Aug 2005 | A1 |
20050188358 | Johnson et al. | Aug 2005 | A1 |
20050246691 | Hsieh et al. | Nov 2005 | A1 |
20050268168 | Ishihara | Dec 2005 | A1 |
20060026594 | Yoshida et al. | Feb 2006 | A1 |
20060048099 | Templin et al. | Mar 2006 | A1 |
20060069953 | Lippett et al. | Mar 2006 | A1 |
20060129999 | Hiraoka et al. | Jun 2006 | A1 |
20060179281 | Jensen et al. | Aug 2006 | A1 |
20060184835 | Al-Omari et al. | Aug 2006 | A1 |
20060206902 | Jamil et al. | Sep 2006 | A1 |
20060212759 | Campbell et al. | Sep 2006 | A1 |
20060248394 | McGowan | Nov 2006 | A1 |
20060248395 | McGowan | Nov 2006 | A1 |
20060248401 | Carroll et al. | Nov 2006 | A1 |
20060253894 | Bookman et al. | Nov 2006 | A1 |
20060259831 | Sohm et al. | Nov 2006 | A1 |
20060279439 | Swoboda | Dec 2006 | A1 |
20060282419 | Sen et al. | Dec 2006 | A1 |
20060282734 | Milne et al. | Dec 2006 | A1 |
20070016959 | Ikeda et al. | Jan 2007 | A1 |
20070043861 | Baron et al. | Feb 2007 | A1 |
20070089095 | Thekkath et al. | Apr 2007 | A1 |
20070180333 | Thekkath et al. | Aug 2007 | A1 |
20070180431 | Agarwala et al. | Aug 2007 | A1 |
20070220360 | Weinert et al. | Sep 2007 | A1 |
20070234306 | Klinger et al. | Oct 2007 | A1 |
20070240125 | Degenhardt et al. | Oct 2007 | A1 |
20070271461 | Hardy et al. | Nov 2007 | A1 |
20070288906 | Agarwala et al. | Dec 2007 | A1 |
20080010640 | Foo | Jan 2008 | A1 |
20080027961 | Arlitt et al. | Jan 2008 | A1 |
20080028196 | Kailas | Jan 2008 | A1 |
20080034350 | Conti | Feb 2008 | A1 |
20080052681 | Yang | Feb 2008 | A1 |
20080059963 | Foo | Mar 2008 | A1 |
20080080651 | Edgar | Apr 2008 | A1 |
20080098207 | Reid et al. | Apr 2008 | A1 |
20080114972 | Codrescu et al. | May 2008 | A1 |
20080115011 | Codrescu et al. | May 2008 | A1 |
20080115113 | Codrescu et al. | May 2008 | A1 |
20080209176 | Singh et al. | Aug 2008 | A1 |
20080256339 | Xu et al. | Oct 2008 | A1 |
20080256396 | Giannini et al. | Oct 2008 | A1 |
20080288808 | Moyer | Nov 2008 | A1 |
20090007076 | Al-Omari et al. | Jan 2009 | A1 |
20090132863 | Ashfield et al. | May 2009 | A1 |
20090199162 | Choi et al. | Aug 2009 | A1 |
Number | Date | Country |
---|---|---|
1411434 | Apr 2004 | EP |
2183362 | Jul 1990 | JP |
04145544 | May 1992 | JP |
8055023 | Feb 1996 | JP |
8087366 | Apr 1996 | JP |
9167105 | Jun 1997 | JP |
2001154873 | Jun 2001 | JP |
2001519947 | Oct 2001 | JP |
2001331340 | Nov 2001 | JP |
2001521215 | Nov 2001 | JP |
2003177938 | Jun 2003 | JP |
2004171563 | Jun 2004 | JP |
2004171564 | Jun 2004 | JP |
2006285430 | Oct 2006 | JP |
20010031167 | Apr 2001 | KR |
20060049710 | May 2006 | KR |
200625070 | Jul 2006 | TW |
WO9921089 | Apr 1999 | WO |
WO0068780 | Nov 2000 | WO |
01018651 | Mar 2001 | WO |
WO2006030195 | Mar 2006 | WO |
Number | Date | Country | |
---|---|---|---|
20080115115 A1 | May 2008 | US |