Selective MISR data accumulation during exception processing
A plurality of test points are located at predetermined circuit nodes in a processing system. Test code which includes a set of software-controllable interrupts is executed using a multiple input shift register (MISR) to generate a MISR signature. One or more selected software-controllable interrupt types are determined. During execution of the test code, the MISR is used to also accumulate data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the MISR signature. A test control register has a plurality of fields, each for selecting or not selecting a corresponding software-controllable interrupt type.
Latest Freescale Semiconductor, Inc. Patents:
- AIR CAVITY PACKAGES AND METHODS FOR THE PRODUCTION THEREOF
- METHODS AND SYSTEMS FOR ELECTRICALLY CALIBRATING TRANSDUCERS
- SINTERED MULTILAYER HEAT SINKS FOR MICROELECTRONIC PACKAGES AND METHODS FOR THE PRODUCTION THEREOF
- CONTROLLED PULSE GENERATION METHODS AND APPARATUSES FOR EVALUATING STICTION IN MICROELECTROMECHANICAL SYSTEMS DEVICES
- SYSTEMS AND METHODS FOR CREATING BLOCK CONSTRAINTS IN INTEGRATED CIRCUIT DESIGNS
The present invention relates generally to data processors, and more particularly to testing a data processor.
BACKGROUND OF THE INVENTIONTesting of data processing systems is important to ensure proper operation. Testing may be performed in a factory following manufacture and prior to using the data processing system in a user application. The factory testing ensures an end user receives a properly functioning product. However, during operation of the data processing system by an end user, it may also be desirable to test the data processing system so that any failures which occur during normal operation of the product can be detected.
Currently, to provide a low cost method of real-time testing of the integrity of a data processor, while maintaining reasonable interrupt latency, on-line testing is performed by sampling a collected set of test points within a data processor and accumulating the sampled signals into one or more compressed results via accumulating the sample signals into one or more compressed results via MISRs. A well known technique to permit integrated circuits to be tested during operation is the use of logic testing registers, called Multiple Input Shift Registers (MISRs). Multiple input shift registers implement any of a variety of polynomials by receiving data from various internal nodes of the integrated circuit and performing signature compression and accumulation. The signature compression and accumulation is a series of logic operations which result in a single output value known as a signature value. The signature value is compared with a desired value to determine whether the integrated circuit being tested is functioning correctly. In order to reduce interrupt latency, processors may be designed such that interrupts may be injected into the pipeline, causing the results of uncompleted instructions to be discarded without compression and accumulation. The results are discarded because if the discarded results were otherwise accumulated into a compressed signature, a faulty signature value would result.
Since the testing of the integrated circuit is performed on-line or while the integrated circuit is functioning in a real-world application, it is highly desirable to have minimal impact or intrusiveness on system characteristics. A critical component of real-time systems is the interrupt latency or the amount of time required to respond to an interrupt request. Since on-line testing must not adversely affect the responsiveness of a data processing system, known systems typically completely disable the interrupt exception handling of a data processor when testing with a MISR is performed. As a result, known data processing systems also typically strictly limit the length of MISR test sequences.
The present invention is illustrated by way of example and not limitation in the accompanying figures, in which like references indicate similar elements, and in which:
Skilled artisans appreciate that elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. For example, the dimensions of some of the elements in the figures may be exaggerated relative to other elements to help to improve understanding of embodiments of the present invention.
DETAILED DESCRIPTIONIn operation, data processing system 10 is implemented as a pipelined data processing system. That means that the execution of data processing instructions occurs in discrete time intervals in which a particular function in the execution occurs during each time interval. For example, reference to a pipeline 32 in
In a first operation an instruction is fetched in a pipeline stage 34 from the bus interface unit 14 by the instruction fetch unit 20. In a pipeline stage 36, the fetched instruction is coupled to the instruction decoder 18 from the instruction fetch unit 20 and decoded. The resulting decoded instruction is then coupled to execution units 16 and instruction execution begins in a pipeline stage 38. In some forms the instruction execution occurs during two cycles of the system clock. In the illustrated form in the pipeline stage 38 a first phase of instruction execution labeled “execute 0” occurs. Alternatively for a memory operation an effective address (EA) calculation occurs. Depending upon the instruction functionality, the result of pipeline stage 38 is fed back and used as a subsequent input. In a pipeline stage 39 instruction execution is completed with a second phase labeled “execute 1”. Alternatively for a memory operation a memory access is performed. Depending upon the instruction functionality, the result of pipeline stage 39 is fed back and used as a subsequent input. In a pipeline stage 42 a result writeback, such as to register files 22, is performed. The various pipeline stages which are described herein are defined herein as “staging”. In other words, staging is the operation of a data processing system in specific pipeline stages each having a predetermined function or functions. Staging is also the association of specific hardware circuitry with the functions of each stage in the ordered sequence which forms the data processing pipeline. In general address translation from virtual addresses used by the instruction pipeline to physical addresses used to address data in cache 30 and memory 13 occurs within the MMU 29. Virtual addresses are communicated between the MMU 29 and the instruction fetch unit 20 and load/store unit 28. Physical addresses are communicated between the MMU 29 and the cache 30 and memory 13. The TLB 31 is a cache for the processor of data processing system 10 that speeds up virtual address translation. TLB 31 has a fixed number of page table entries which map virtual addresses onto physical addresses. TLB 31 is typically implemented as a content addressable memory (CAM) in which the search key is a virtual address and the search result is a physical addresses. If the requested address is present a CAM search yields a match very quickly and the physical address is used to address cache 30 or memory 13. When the requested address is not in the TLB 31, a miss occurs and an exception occurs which is sent to exception logic 26. The exception logic 26 implements a page table lookup process to obtain the missing physical address. Page tables may be located within the MMU 29 or elsewhere within data processing system 10. Other exceptions may be generated by the MMU 29 such as when a received virtual address is out-of-range of a permissible range of addresses, or when a permissions violation occurs due to insufficient access permissions.
Data processing system 10 has a real-time test capability that permits testing of various test points located at predetermined circuit nodes within the functional circuitry of the data processing system. For example, the various test points may be located within any or all of the functional blocks illustrated in
Multiple MISR registers may be implemented to allow for a larger number of test points to be captured for signature generation. Additionally, it is desirable to be able to accumulate the values of test points associated with various stages of the processing pipeline in order to allow testing of logic elements within the various stages. One difficulty that arises however is that various instructions are present in the different pipeline stages at each point in time the MISR registers are updated. A change in the relationship between the contents of the various pipeline stages can result in incorrect final accumulated signature values from the MISR registers, which would be interpreted as a failure. This change in relationship can occur due to the injection of interrupts, or due to stalling of one or more stages of the pipeline such as from varying memory access times occurring for memory accesses processed in one or more pipeline stages. To avoid this, prior art systems have required that interrupts be disabled during the accumulation of a MISR signature, and further have required that no indeterminate processor stall cycles occur during MISR signature accumulation. These restraints place a severe limitation on interrupt responsiveness since interrupts must be blocked from occurring during execution of a sequence of instructions which are used to generate a MISR signature value. Also, any indeterminacy in the number of cycles an instruction spends in each stage of the processor pipeline must be likewise avoided in order to accumulate a deterministic MISR signature. Cycle indeterminacy is especially problematic if a cache memory is used to hold the instruction stream or data operands, since a cache miss event can cause a stall of one or more pipeline stages, and cause an incorrect accumulation of the same test point values during multiple clocks while one or more portions of the pipeline are stalled. In some embodiments, load and store accesses to memory outside of or within data processing system 10 may not have deterministic timing due to common events like bus arbitration uncertainties, higher level caches, refresh events to dynamic memory, etc. In some pipeline embodiments, stages of the pipeline may be loosely coupled, such that a stall in a later pipeline stage does not directly cause an immediate stall in an earlier stage. For example, a load instruction stalled in the execute 1 pipeline stage 39 of the illustrated pipeline 32 may not cause a subsequent instruction which was delayed in the fetch pipeline stage 34 due to an extended memory access from flowing through the decode pipeline stage 36 and execute 0 pipeline stage 38 while the execute 1 pipeline stage 39 is stalled. Such changes in relationships are not readily handled by conventional systems which do not incorporate the test point staging capability provided by the staging storage elements and MISR 25.
Registers files 22 are general purpose register files and are shared between the load/store unit 28 and the execution units 16. The load/store unit 28 operates in response to the global control 24 and provides data to and receives data from the bus interface unit 14. The load/store unit 28 also provides data to and receives data from the general purpose registers within the register files 22. Exception logic 26 functions to generate any of various types of data processing exceptions. An interrupt request may be generated and provided to the exception logic 26 in response to various events either within the illustrated data processing system 10 or from sources external to the data processing system 10. For example, instruction execution latency resulting from the generation of wait states may cause the generation of an exception as may the occurrence of faults resulting from instruction execution errors. Various types of real-time interrupt requests may also be received by exception logic 26 via one or more interrupt (also referred to as exception) request inputs.
As an example of a pipelined instruction execution, refer to
Illustrated in
Illustrated in
Similarly, a multiplexor 66 is provided having a plurality of inputs that are respectively connected to one of a plurality of test points within the instruction decoder 18. An output of multiplexor 66 is sequentially clocked through a plurality of staging storage elements. Each staging storing element is correlated to a specific stage of the pipeline of the data processing system 10 subsequent to the decode stage. For example, storage element 68 corresponds to the first execute stage, execute 0, of the pipeline. Storage element 69 corresponds to the second execute stage, execute 1, of the pipeline. The output of multiplexor 66 is connected to an input of storage element 68. An output of storage element 68 is connected to an input of storage element 69. An output of storage element 69 is connected to an input of a MISR 70. The MISR 70 corresponds to the writeback stage of the pipeline. MISR 70 has a control input for receiving the MISR clock enable signal.
A multiplexor 71 is provided having a plurality of inputs that are respectively connected to one of a plurality of test points within the Execute 0 stage of execution units 16. An output of multiplexor 71 is sequentially clocked through a staging storage element 73 that is correlated to the second execute stage, execute 1, of the pipeline. The output of multiplexor 71 is connected to an input of storage element 73. An output of storage element 73 is connected to an input of a MISR 75. The MISR 75 corresponds to the writeback stage of the pipeline. MISR 75 has a control input for receiving the MISR clock enable signal. A multiplexor 72 is provided having a plurality of inputs that are respectively connected to one of a plurality of test points within the Execute 1 stage of execution units 16. A control input of multiplexor 72 is connected to the select signal. An output of multiplexor 72 is connected to an input of a MISR 74. The MISR 74 corresponds to the writeback stage of the pipeline. MISR 74 has a control input for receiving the MISR clock enable signal. In the illustrated form, storage elements 61-63, 68-69 and 73 are the staging storage elements of staging storage elements and MISR 25. A multiplexor 82 is provided having a plurality of inputs that are respectively connected to one of a plurality of exception test points within the data processing system 10. A control input of multiplexor 82 is connected to the select signal. An output of multiplexor 82 is connected to an input of a MISR 83. The MISR 83 corresponds to the writeback stage of the pipeline. The MISRs 64, 70, 74, 75 and 83 are the MISR elements of the staging storage elements and MISR 25. From the combination of the figures discussed to this point it is apparent that a MISR implementation has been provided having reduced exception handling latency because of the staging correlation of storage elements. The staging storage elements permit the use of selective MISR writebacks so that exception handling does not have to be disabled completely when testing of a data processing system occurs. Additionally, the staging storage elements allow exception processing to occur real-time without putting additional values in the MISR storage devices which would result in an incorrect value in one or more of the MISRs. Without the use of the staging storage elements and the associated control over clocking of the MISR registers by use of the MISR clock enable, the inputs to the MISRs 64, 70, 74, 75 and 83 would not be correlated to the sequential execution of the group of instructions 40. Thus the presence of an interrupt occurring during execution of the group of instructions 40 would cause accumulation of test point values from the group of instructions 50 as well as from the subsequent refetching of instructions I2 and I3, and the re-decoding of instruction I2, resulting in an incorrect signature value. It should be noted that in some embodiments the MISR clock enable signals to the various MISR registers shown in
Illustrated in
Referring to
The circuitry of global control 24 detects during cycle four that an instruction is completing execution in the second execute stage (execute 1) of the pipeline. The data associated with this executed instruction will need to be stored in the MISR of the staging storage elements and MISR 25 so the MISR Clk Enable signal transitions to an active state during the fourth clock cycle. At the beginning of the fifth clock cycle a MISR update occurs as is indicated by the darkened upward pointing arrow immediately above the MISR Clk Enable signal. Because the circuitry of global control 24 detects during cycle five that a non-interrupted instruction, instruction I1, is completing execution in the second execute stage of the pipeline, the MISR clock enable signal remains active during cycle five. Also during cycle five the instruction decoder 18 is flushed so that its contents are nulled out to a predetermined value as indicated by the “dash” mark of
As illustrated in
SC—A system call
TRAP—A Trap instruction
ILL—An illegal instruction
PRIV—A privileged instruction
TLB error—A translation lookaside buffer (TLB) miss
TLB DSI—A data storage interrupt (DSI) due to permission violation
TLB ISI—An instruction storage interrupt (ISI) due to permission violation
XTE—External precise bus error exception
Software may control the generation of one or more of the exceptions with corresponding control bits in response to instruction execution. For example, execution of a system call or trap instruction, or attempted execution of an illegal or privileged instruction may be controlled by including one or more of these instruction types in a subroutine or other instruction storage location which can be processed. TLB 31 errors may be initiated under software control by the configuring of one or more TLB 31 entries in memory management unit 29. External precise bus errors are also controllable by software in some embodiments by bus cycle generation from a load or store instruction which targets a non-existent device, which results in bus error termination on the global interconnect 12. Other bits may be included within the Exception Type Enables field to selectively enable other exception sources under software control. Another field within the test control register 90 is a MISR enable field labeled “MISR EN”. In the illustrated form the MISR enable field is a single bit. The Exception Type Enables field is a field of any number of predetermined bits based upon a number of possible exception type conditions which are software controllable for which MISR accumulation operations are desired to be conditionally enabled for internal exception processing operations. While the test control register 90 is illustrated as a thirty-two bit register, it should be understood that any number of bits may be implemented. As stated above, the bits within the Exception Type Enables field are correlated to specific exception condition types and software has control over initiating the exception types corresponding to the individual bits. These exceptions are thus classified as “synchronous” exceptions, since if they occur, they are synchronous to the program flow. Other exception types, such as receiving an external interrupt request, are classified as “asynchronous” exceptions, since their occurrence is typically asynchronous to program flow. All exceptions will implement the noted exception processing internal operations of
The Update_MSR, OLDPC_→SRR0 and OLDPC_→SRR1 exception processing internal operations are additional internal exception operations which are associated with internal state saving operations that are accumulated when a specific type of interrupt under software control occurs. These internal operations also occur for non-software controlled interrupts, such as asynchronous interrupt requests like “external interrupt request” and “critical interrupt request”. However, for asynchronous exceptions, no accumulation occurs during the internal exception processing operations. Software has no idea when in time these asynchronous interrupts will be received since they are asynchronously generated by other components within or external to data processing system 10. Thus a deterministic signature value cannot always be created if these exception types cause accumulations to occur. For these asynchronous exception types, no corresponding Exception Type Enables bit is implemented in some embodiments. When the assigned bit for one of the synchronous exception types has a logic one value, the test function is enabled for performing accumulation during certain initial internal exception processing cycles when the corresponding exception occurs. For example, both the Update_MSR signal and the OLDPC_→SRR0 exception processing signal are active at least at the rising clock edge beginning clock cycle nine. The MISR of MISR update control register and logic 27 is updated with test values associated with these internal operations for enabled exception types in the Exception Type Enables field as indicated by the darkened upward pointing arrow immediately above the MISR Clk enable signal at the rising edge of cycle nine. The test function of updating a save/restore register 0 (SRR0) is performed by updating the save/restore register 0 with the old program counter value. At the rising edge of clock cycle ten the MISR Clk enable signal is not active and thus no MISR update occurs. The OLDMSR_→SRR1 signal is active at least at the rising clock edge beginning at clock cycle eleven. As part of the internal exception processing operations associated with all exceptions, the save/restore register 1 is updated with a prior or old machine state register (MSR) value. If the particular exception type which is being processed has its corresponding Exception Type Enable bit set, then the MISR of MISR update control register and logic 27 is updated with test values associated with this internal exception processing operation as indicated by the darkened upward pointing arrow immediately above the MISR Clk enable signal at the beginning of clock cycle eleven.
The specific exception processing internal operations illustrated in
Thus it should be appreciated from the timing diagram of
Illustrated in
Illustrated in
Illustrated in
By now it should be apparent that there has been provided a method for supporting on-line testing in a data processing system. The on-line testing is user programmable and uses signal staging correlated to the stages of the pipeline to reduce exception processing latency. Exception processing is permitted to occur real-time as opposed to disabling the exception processing function. Errors in the test data are avoided even though exception processing is permitted. By providing data processor pipeline stage staging registers to hold sampled test point signals, the test points can be controllably moved through a series of storage devices which are updated as the processor pipeline advances. The stage values are accumulated into a compressed signature at or near the end of the processor pipeline. Data processing system 10 meets safety requirements when runtime assurance of processor and subsystem functionality is required. The self-test capability described herein is executed during otherwise idle portions of data processing system 10 while it is in operation. On-line testing is performed by users of the system and controlled via software programmed sequences. Data processing system 10 provides a low cost and flexible method to support capturing of various signals throughout a pipelined processor's processing stages by the signature logic while minimizing interrupt latency. Signals are captured during the various stages of the pipeline and the MISR results are updated during the writeback stage to ensure that interrupts do not affect the capability of generating a predictable signature. Test coverage above ninety percent of the system's circuitry can thus be efficiently accomplished. Additional coverage is provided by selectively updating MISR values during specific initial clock cycles of exception processing for selectable or software-identified exceptions, thus providing additional coverage for exception control logic. Debug interrupts, software interrupts, traps, system calls, TLB permission violations and other predetermined operations can be selectively enabled for accumulation during the first predetermined number of cycles of exception processing. This functionality ensures that these asynchronous interrupts can continue to be processed while testing the portions of the exception control and storage logic which can be allowed to cause updates. By controlling which exceptions are allowed to be selectively accumulated, test code may be written by a programmer to cause exceptions requiring accumulation to be triggered synchronously. Efficiency is obtained by staging early pipeline stage signals into the MISR function to minimize interrupt latency and by selectively updating MISRs on two different boundaries of the processing pipeline such as during decode and execute boundaries rather than solely on a writeback boundary.
In one form there is provided method for use in a data processing system wherein a plurality of test points located at predetermined circuit nodes is provided. Test code is executed which includes a set of software-controllable interrupts. During execution of the test code, a multiple input shift register (MISR) is used to accumulate data values from the plurality of test points to generate a MISR signature. The presence of one or more selected software-controllable interrupt types is determined. During execution of the test code, the MISR is used to also accumulate data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the MISR signature. In another form during execution of the test code, an asynchronous exception is received. The MISR is disabled when processing the asynchronous exception. In another form a test control register having a plurality of fields is provided. Each of the plurality of fields is for selecting or not selecting a corresponding software-controllable interrupt type. In another form determining the one or more selected software-controllable interrupt types is implemented by using the test control register to determine the one or more selected software-controllable interrupt types. In another form during execution of the test code, the MISR is disabled from accumulating data values during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are not of the one or more selected software-controllable interrupt types. In another form exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types is implemented by executing a corresponding exception handler in response to detecting an exception caused by the one or more of the software-controllable interrupts. During the exception processing, the MISR is used to accumulate data values during at least one clock cycle which occurs after detecting the exception and prior to executing an initial instruction of the corresponding exception handler. In another form during exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR is used to accumulate data values during one or more clock cycles which are not associated with a writeback stage of an instruction pipeline of the data processing system. In another form when not exception processing, the MISR is used to accumulate data values from the plurality of test points to generate the MISR signature by updating the MISR during a writeback stage of an instruction pipeline of the data processing system. In another form test code which includes the set of software-controllable interrupts is executed a second time. During execution of the test code the second time, the MISR is used to accumulate data values from the plurality of test points to generate a second MISR signature. During execution of the test code the second time, the MISR is used to also accumulate data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the second MISR signature. The second MISR signature is compared to the MISR signature to determine if a test error has occurred.
In another form there is provided a data processing system having a multiple input shift register (MISR) which accumulates data values from a plurality of test points located at predetermined circuit nodes to generate a MISR signature. Test control storage circuitry indicates one or more selected software-controllable interrupt types. Processing circuitry executes processor instructions, wherein the processing circuitry executes test code which includes a set of software-controllable interrupts, wherein during execution of the test code, the MISR accumulates data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the MISR signature. In another form MISR control logic is coupled to the MISR, wherein the MISR control logic disables the MISR during processing of a received asynchronous exception. In yet another form the data processing system has exception logic which, in response to detecting an exception, performs a plurality of internal operations during exception processing. During the exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR accumulates data values from the plurality of test points during one or more of the plurality of internal operations. In another form the processing circuitry implements an instruction pipeline having a writeback stage. During the exception processing of the one or more of the software-controllable interrupts within the software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR does not accumulate data values from the plurality of test points during the writeback stage. In yet another form the processing circuitry, when not exception processing, uses the MISR to accumulate data values from the plurality of test points to generate the MISR signature by updating the MISR during the writeback stage.
In another form there is provided a method in a data processing system. A plurality of test points located at predetermined circuit nodes is provided. Test code is executed which includes a set of software-controllable interrupts, each software-controllable interrupt having a corresponding exception handler. During execution of the test code, a multiple input shift register (MISR) is used to accumulate data values from the plurality of test points to generate a MISR signature. In response to executing a first software-controllable interrupt of the set of software-controllable interrupts, an exception is generated. In response to detecting the exception, at least one operation is performed prior to executing an initial instruction of a first exception handler corresponding to the first software-controllable interrupt. The MISR is also used to accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation. In another form the at least one operation saves current context information. In another form the at least one operation further includes generating a new program counter value for use in execution of the initial instruction of the first exception handler. The MISR is used to accumulate data values from the plurality of test points to generate the MISR signature when saving current context information and when generating the new program counter value. In another form the MISR is used to also accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation by determining one or more selected software-controllable interrupt types. The MISR is used to accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation when the first software-controllable interrupt is of the one or more selected software-controllable interrupt types. In another form the MISR is disabled from accumulating data values during exception processing of the first software-controllable interrupt when the first software-controllable interrupt is of the one or more selected software-controllable interrupt types and when other operations other than the at least one operation are being performed. In yet another form the MISR is disabled from accumulating data values during exception processing of the first software-controllable interrupt when other operations other than the at least one operation are being performed.
In the foregoing specification, the invention has been described with reference to specific embodiments. However, one of ordinary skill in the art appreciates that 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, it should be understood that the circuitry described herein may be implemented either in silicon or other semiconductor materials or alternatively by a software code representation of silicon or other semiconductor materials.
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 present invention.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any element(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature or element of any or all the claims. As used herein, the terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any element(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature or element of any or all the claims. As used herein, the terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. The terms a or an, as used herein, are defined as one or more than one. The term plurality, as used herein, is defined as two or more than two. The term another, as used herein, is defined as at least a second or more. The terms including and/or having, as used herein, are defined as comprising (i.e., open language). The term coupled, as used herein, is defined as connected, although not necessarily directly, and not necessarily mechanically.
Claims
1. In a data processing system, a method comprising:
- providing a plurality of test points located at predetermined circuit nodes;
- executing test code which includes a set of software-controllable interrupts;
- during execution of the test code, using a multiple input shift register (MISR) to accumulate data values from the plurality of test points to generate a MISR signature;
- determining one or more selected software-controllable interrupt types; and
- during execution of the test code, using the MISR to also accumulate data values from the plurality of test points during exception processing of one or more software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the MISR signature.
2. The method of claim 1, further comprising:
- during execution of the test code, receiving an asynchronous exception; and
- disabling the MISR when processing the asynchronous exception.
3. The method of claim 1, further comprising:
- providing a test control register having a plurality of fields, each of the plurality of fields for selecting or not selecting a corresponding software-controllable interrupt type.
4. The method of claim 3, wherein determining the one or more selected software-controllable interrupt types comprises using the test control register to determine the one or more selected software-controllable interrupt types.
5. The method of claim 1, further comprising:
- during execution of the test code, disabling the MISR from accumulating data values during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are not of the one or more selected software-controllable interrupt types.
6. The method of claim 1, wherein exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types comprises executing a corresponding exception handler in response to detecting an exception caused by the one or more of the software-controllable interrupts, and wherein during the exception processing, the MISR is used to accumulate data values during at least one clock cycle which occurs after detecting the exception and prior to executing an initial instruction of the corresponding exception handler.
7. The method of claim 1, wherein during exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR is used to accumulate data values during one or more clock cycles which are not associated with a writeback stage of an instruction pipeline of the data processing system.
8. The method of claim 7, wherein, when not exception processing, using the MISR to accumulate data values from the plurality of test points to generate the MISR signature comprises updating the MISR during a writeback stage of an instruction pipeline of the data processing system.
9. The method of claim 1, further comprising:
- executing the test code which includes the set of software-controllable interrupts a second time;
- during execution of the test code the second time, using the MISR to accumulate data values from the plurality of test points to generate a second MISR signature;
- during execution of the test code the second time, using the MISR to also accumulate data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the second MISR signature; and
- comparing the second MISR signature to the MISR signature to determine if a test error has occurred.
10. A data processing system, comprising:
- a multiple input shift register (MISR) which accumulates data values from a plurality of test points located at predetermined circuit nodes to generate a MISR signature;
- test control storage circuitry which indicates one or more selected software-controllable interrupt types; and
- processing circuitry which executes processor instructions, wherein the processing circuitry executes test code which includes a set of software-controllable interrupts, wherein during execution of the test code, the MISR accumulates data values from the plurality of test points during exception processing of one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types to generate the MISR signature.
11. The data processing system of claim 10, further comprising:
- MISR control logic coupled to the MISR, wherein the MISR control logic disables the MISR during processing of a received asynchronous exception.
12. The data processing system of 10, further comprising:
- exception logic which, in response to detecting an exception, performs a plurality of internal operations during exception processing, wherein during the exception processing of the one or more of the software-controllable interrupts within the set of software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR accumulates data values from the plurality of test points during one or more of the plurality of internal operations.
13. The data processing system of claim 12, wherein the processing circuitry implements an instruction pipeline having a writeback stage, and wherein during the exception processing of the one or more of the software-controllable interrupts within the software-controllable interrupts which are of the one or more selected software-controllable interrupt types, the MISR does not accumulate data values from the plurality of test points during the writeback stage.
14. The data processing system of claim 13, wherein the processing circuitry, when not exception processing, uses the MISR to accumulate data values from the plurality of test points to generate the MISR signature by updating the MISR during the writeback stage.
15. In a data processing system, a method comprising:
- providing a plurality of test points located at predetermined circuit nodes;
- executing test code which includes a set of software-controllable interrupts, each software-controllable interrupt having a corresponding exception handler;
- during execution of the test code, using a multiple input shift register (MISR) to accumulate data values from the plurality of test points to generate a MISR signature;
- in response to executing a first software-controllable interrupt of the set of software-controllable interrupts, generating an exception; and
- in response to detecting the exception, performing at least one operation prior to executing an initial instruction of a first exception handler corresponding to the first software-controllable interrupt, wherein the MISR is also used to accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation.
16. The method of claim 15, wherein the at least one operation comprises
- saving current context information.
17. The method of claim 16, wherein the at least one operation further
- comprises generating a new program counter value for use in execution of the initial instruction of the first exception handler, and wherein the MISR is used to accumulate data values from the plurality of test points to generate the MISR signature when saving current context information and when generating the new program counter value.
18. The method of claim 15, wherein using the MISR to also accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation further comprises:
- determining one or more selected software-controllable interrupt types; and
- using the MISR to accumulate data values from the plurality of test points to generate the MISR signature during the at least one operation when the first software-controllable interrupt is of the one or more selected software-controllable interrupt types.
19. The method of claim 18, further comprising:
- disabling the MISR from accumulating data values during exception processing of the first software-controllable interrupt when the first software-controllable interrupt is of the one or more selected software-controllable interrupt types and when other operations other than the at least one operation are being performed.
20. The method of claim 15, further comprising:
- disabling the MISR from accumulating data values during exception processing of the first software-controllable interrupt when other operations other than the at least one operation are being performed.
5485467 | January 16, 1996 | Golnabi |
5541879 | July 30, 1996 | Suh et al. |
5617021 | April 1, 1997 | Goetting et al. |
5672966 | September 30, 1997 | Palczewski et al. |
5841867 | November 24, 1998 | Jacobson et al. |
5900757 | May 4, 1999 | Aggarwal et al. |
5940605 | August 17, 1999 | Aoki |
6055660 | April 25, 2000 | Meaney |
6115763 | September 5, 2000 | Douskey et al. |
6158033 | December 5, 2000 | Wagner et al. |
6249893 | June 19, 2001 | Rajsuman et al. |
6311311 | October 30, 2001 | Swaney et al. |
6615379 | September 2, 2003 | Tripp et al. |
20020129300 | September 12, 2002 | Floyd et al. |
20020178403 | November 28, 2002 | Floyd et al. |
20040216061 | October 28, 2004 | Floyd et al. |
20050138501 | June 23, 2005 | Motika et al. |
20060282732 | December 14, 2006 | Kiryu |
20070174750 | July 26, 2007 | Borin |
- Nagle, H. T. et al., Microprocessor Testability, 1989, IEEE, IEEE Transactions on Industrial Electronics vol. 36, No. 2, pp. 151-163.
- Dey, S. et al., Using a Soft Core in a SoC Design: Experiences with PicoJava, 2000, IEEE, IEEE Design & Test of Computers, pp. 60-71.
- Huang D.C. et al., Short Paper, A Parallel Transparent BIST Method for Embedded Memory Arrays by Tolerating Redundunt Operations,2002, IEEE, IEEE Transactions on computer design of integrated circuits and systems vol. 21, No. 5, pp. 617-628.
- Lai, Wei-Cheng et al., Instruction Level DFT for Testing Processor and IP Cores in a System on a Chip, 2001, ACM, 6 pages.
- Crouch, Alfred L.; “Scan Testing (3.1.3) and Logic Built-In Self-Test”; Design for Test for Digital IC'S and Embedded Core Systems; 1999; Title page, Publication Data page, Contents and pp. 96-168; Prentice Hall; New Jersey, USA.
- Lyon, Jose A. et al.; “Testability Features of the 68HC16Z1”; International Test Conference '1991; Oct. 26-30, 1991; Cover page; Index and pp. 122-129; IEEE.
- U.S. Appl. No. 11/355,681 filed Feb. 2, 2006.
- U.S. Appl. No. 11/460,090, filed Jul. 26, 2006.
- U.S. Appl. No. 11/460,086, filed Jul. 26, 2006.
Type: Grant
Filed: May 30, 2008
Date of Patent: Nov 15, 2011
Patent Publication Number: 20090300249
Assignee: Freescale Semiconductor, Inc. (Austin, TX)
Inventors: William C. Moyer (Dripping Springs, TX), Jimmy Gumulja (Austin, TX)
Primary Examiner: Eric Coleman
Attorney: Joanna G. Chiu
Application Number: 12/130,012
International Classification: G06F 11/07 (20060101);