The present invention relates to integrated circuit designs, and in particular to techniques for isolating defects in such designs so as to enable identifying the defects with particular sources. The invention also relates to debugging and verification of debugging of identified defects.
Integrated circuit (IC) designers do not always design every component of an IC. While IC designers may design one or more components of a particular IC, these designers often employ IC component designs (also known as intellectual property, or IP) from one or more third-party IP providers. Sourcing of IC component designs from third-party IP providers can facilitate overall design by avoiding the need for the IC designer to design every aspect of the IC's functionality. However, out-sourcing of IC component designs also can complicate debugging, because the origin of defects in the overall IC design can be unclear, for a variety of reasons.
IC designers may employ a hardware based verification platform to perform certain operations on an IC design. Such platforms are well known in the art, and so is the usage of such platforms, so that details need not be provided here. Hardware verification platforms can enable the presentation of real runtime scenarios occurring inside an IC. Such presentations can facilitate design analysis and debugging. When defects are encountered, an IC designer can do a data dump of the information of interest, and can analyze the data in order to identify the source of any defects.
Where third-party IP providers are involved, it is desirable to place debugging responsibility with the third party who provided the functionality in question. However, in a situation in which there are multiple IP component sources in the design, it can be difficult to know which IP provider to approach, and which IP provider to whom to give the data dump, or which portion of the data dump. Also, given the amount of data and consequent analysis involved, it can be difficult to convince an IP provider that its particular IP component design was responsible for the defect(s) encountered.
Even where multiple IP components come from the same source, it can be difficult to know which portion of a data dump would be relevant to effect the necessary debugging. Moreover, without sufficient guidance as to the potential or probable source of the problems, a given IP provider will tend to resist incurring significant effort to assist in debugging, particularly when the volume of data in the data dump is substantial and generally undirected. The resulting process is inefficient.
Viewed another way, IC designers can compile a large amount of runtime state information for an IC design, and can provide that information to third-party IP providers. However, without the ability to establish that a particular third-party IP provider's design component is a source of a defect, it is difficult to get the third-party IP provider to take responsibility for the defect, and thereby take responsibility for fixing the defect.
If IC designers had access to details of the third-party IP provider design components, proving defect origins would be easier. However, those design component details often are proprietary, and consequently the third-party IP providers hold onto those details tightly. As a result, IC designers cannot reliably match design component details with the runtime state information.
Another issue with respect to compiled runtime state information is potential ambiguity with respect to paths a finite state machine (one way of viewing an IC component or group of such components) might take to get to a particular state. There may be multiple paths, one or more of which might be the source of a defect. Just looking at an appropriate portion of a data dump might not resolve the ambiguity so as to lead to resolution of the defect source.
Once the appropriate IP provider takes responsibility for a defect and sets about to fix it, the provider must overcome various obstacles. Among these is the state ambiguity referred to above.
Once the defect is fixed, it is necessary for the IP provider to convince the IP consumer that the fix will work under a sufficient number of different circumstances. Consequently, it is desirable to input the repaired IP into a suitable test bench, and run appropriate scenarios, with combinations of input states, so as to demonstrate to the IP consumer that the fix will hold, without the IP provider revealing any of its proprietary IP in the course of the interaction with the IP consumer.
In view of the foregoing, it is one object of the present invention to provide a facility for isolating defects so as to enable an IP consumer to identify reliably the IP provider responsible for the functionality that needs to be debugged, without the consumer being privy to the provider's proprietary IP.
In accordance with one aspect of the present invention, a hardware verification system contains information that enables data tracing that is specific to a particular IP provider, based on IP specific tracing requirements, or IPSTRs, that the IP provider makes available. When the hardware verification system encounters defects, the system is able to use the IPSTRs to obtain data dumps that are specific to the component or components to which the IPSTRs relate. The IC designer need not be aware of the IPSTRs, so that no proprietary information need be made visible. Moreover, in one aspect the IP provider can provide IPSTRs without making proprietary information available.
IPSTRs also may have utility in a situation in which data streams are being generated which create ambiguity as to a source of a particular defect or defects. However, in this aspect of the invention, IPSTRs are not essential, particularly where the IP at issue is being provided in connection with implementation of a hardware or software standard.
In a situation in which the IP in question is being provided in accordance with a standard, as may happen, for example, in the case of Bluetooth™, Wi-Fi, other communications, memory management, display, or other functionality in a device (e.g. a tablet, a smartphone, a notebook or desktop computer, or the like), and a defect provides or leads to an indication that the standard is not being complied with, the IP provider then can recognize the issue as stemming from the provider's own IP, and can address the issue without having to reveal proprietary information about the IP.
There may be circumstances in which compliance with a particular standard can implicate different IP providers. In accordance with one aspect of the present invention, the appropriate IP provider is identified, based on tracing that is carried out with respect to the IC component design for which the IP provider is responsible.
In accordance with another aspect of the present invention, where non-compliance with a standard becomes apparent through identification of one or more defects, and/or the IP for the standard in question is readily seen to have come from a single source, IPSTRs may not be necessary in order to enable the IC designer to route defect correction to the appropriate IP provider.
In
While some of the IP design components mentioned above may be proprietary, a number of them may be developed according to a standard, be it wired or wireless communications, audio, video, memory, or others. Different IP providers can and will have different ways of implementing a particular standard. Some of these IP design components may interrelate and/or interoperate. That is, some of these components may rely on performance of other components in order to function properly. For example, graphics processing may rely on special-purpose graphics memory, or additionally may rely on some portion of general purpose memory in order to perform in an optimal manner. The interrelation and interoperation in particular may contribute substantially to difficulties in isolating a defect and attributing it to a specific IP provider.
The verification block 220 and the test bench block 240 may be separate, as shown in
Each of the workstations referred to above may employ computer hardware of known types, including one or more processors, memory, and storage. All of these elements are well known to ordinarily skilled artisans, and may combined in any number of ways to effectuate defect isolation, attribution, and/or debugging according to aspects of the present invention. An exhaustive enumeration of the types and particular configurations of these elements is unnecessary to a proper understanding of the invention.
Verification and testing issues with respect to IP may arise in the following situation. For example, a smartphone manufacturer will want certain features and functionality in an SoC or other IC as described above, including memory management, graphics, image processing, and various forms of communications, among other things. As a result, the SoC/IC designer will incorporate different kinds of IP into the chip. Some of that IP may come from the smartphone manufacturer; in many cases, the IP will come from third party providers.
During testing, debugging invariably is necessary. When a problem is identified, it must be traced to its source, so that the entity that supplied the IP that caused the problem can fix it. However, because of the tremendous amount of data that gets input to and output from a chip, it can be very difficult to get a meaningful data dump to permit sufficient isolation of the problem source to convince the IP provider to take responsibility for fixing the problem.
Thus, it becomes necessary to present particular traffic patterns or signaling scenarios to the IP provider, so that the provider can reproduce the problem, and then fix it.
At 330, the code that the IP provider has written may be run implemented in an emulator, to verify that the coded circuitry will operate according to the specification or standard. In order to do this, the emulator will exercise the coded circuitry in numerous ways, to ensure that various input combinations do not result in erroneous or ambiguous results. Almost invariably, the emulation never runs properly the first time, and so there are errors. At 340, the errors or defects are identified, perhaps by identifying erroneous outputs or erroneous timing. Once the erroneous outputs or timing are identified, either a trace is captured (350) or a data dump performed (360), or both. The sequence in which these are performed is not critical to the invention. In one embodiment, capture of the trace at 350 enables more judicious selection of data to be dumped at 360. The trace will be discussed in more detail below.
With the trace captured and the data dump carried out, at 370 the IP provider can be identified. Debugging, which the IP provider then would perform, occurs at 380. Flow may return to 320, where further coding is performed and the remainder of the just-described steps repeated, or flow may return to 330, as indicated by the dotted line, where further verification may be performed. In some instances, the identified defect may come from the specification or standard itself, in which case flow may return to 310 instead of 320 or 330. Particularly where the IP provider is the originator of the specification or standard, when a bug is identified as related to that specification or standard, the specification or standard itself may be the source of the bug.
In
Even when the IP provider takes ownership of the problem and fixes it, it is necessary for the IP provider to demonstrate to the SoC designer, or to the ultimate customer (for example, the smartphone manufacturer), that the problem in fact is fixed, and will not recur. To do this, it is necessary to demonstrate operation of the repaired design under a number of different scenarios.
In order to ensure that a problem, once fixed, will not recur, it is important to take into account the possibility or probability that there may be different paths that a system (viewed in some respects as a finite state machine) may take to reach a certain state. The existence of these different paths can give rise to ambiguities, in which the IP provider, for example, may be able to recreate a state sequence resulting in a certain state, but still may not be able to verify that it was only that particular state sequence that yielded the result being observed.
As another part of this last aspect—proving that the defect will not recur—it is important to handle unpredictable behavior. While statistically, of course, the number of states, even in complicated systems, will be finite, though very large, there can be times when events like power disruptions or unusual actions by a user can place a system in an ambiguous state.
In one aspect of the invention, the ability of the verification equipment to employ dynamic triggering enables the setting of trigger conditions or to permit accounting for unpredictable behavior, including ambiguous states, in a design component. In an emulation, the dynamic triggering will prompt particular outputs which then may be monitored to see if they are as expected.
One way in which dynamic triggering may be effected involves the use of dynamic netlists. U.S. Pat. No. 7,379,861, incorporated herein by reference, describes dynamic netlists. A dynamic netlist can represent any type of logic or memory elements, such as combinational gates and state devices (e.g., registers) and may be used to define a trigger condition. Dynamic netlists can be loaded into an emulator and used to generate trigger signals when an IC design also is loaded into the emulator, so that the user can interact with the emulator irrespective of whether the design is presently being emulated.
As described in the above-mentioned patent, outputs of a dynamic netlist may be provided to trigger circuitry, which usually is fixed (i.e. is not changeable), and which outputs one or more trigger signals. The dynamic netlist determines the input or inputs to the fixed trigger circuitry, and so determines the outputs of that circuitry. Thus, together the dynamic netlist and the trigger circuitry constitute a dynamic trigger mechanism. In the context of a standard to be implemented, the dynamic trigger mechanism can provide standard-mandated inputs. The expected outputs from the IC design being emulated will be known from the standard. If there are bugs, then the outputs of the emulation will not be the expected outputs.
The just-discussed dynamic triggering capability, as part of an emulation, now will be discussed in more detail with respect to
In
Region 460 on the right hand side of the Figure is a flexible or programmable region in the processing space. This region may contain the dynamic netlist referenced above, as part of dynamic trigger mechanism 470 depicted in the Figure and described above. In region 460, various trigger conditions may be set, through combinations of different inputs, via the dynamic trigger mechanism 480. Lines 480-1, 480-2, 480-3, . . . 480-m-2, 480-m-1, 480-m signify lines which, when connected in various ways to lines 430-1, etc. in region 410, will trigger different output signals and/or signal combinations, or different output line states.
A useful aspect of the flexible or programmable region 460 is that trigger conditions may be modified easily, in a dynamic fashion, through manipulation of conditions within the region 460, using the dynamic trigger mechanism 470.
In the case of IP which is intended to comply with various aspects of a standard, the expected outputs largely will be known without requiring recourse to the IP provider. That is, a particular combination of inputs should yield standard-mandated outputs. The inputs may be inputs that are specified by the standard at issue. However, for purposes of identifying and resolving or avoiding potentially ambiguous states, for example, the inputs also usefully may vary from the standard, to account for unusual operating conditions. In a standards-based design, nonsensical outputs resulting from varying inputs may signify defects requiring correction.
It should be noted that there may be portions of a standard for which compliance is mandatory, and other portions for which compliance is optional. The IC designer, or the ultimate IP consumer (e.g. the smartphone manufacturer) may have a particular feature set in mind, in which compliance either with only mandatory portions of the standard, or with mandatory and certain optional portions of the standard, would be necessary. The IP provider will have received this information before designing the IP. The selection of mandatory and optional standards features may be proprietary to the IC designer or IP consumer, but need not be discernible from the IP provider's design.
In the case of IP that is designed to provide particular functionality, but in accordance with a proprietary design or feature set rather than a standard, outputs of the design will be a proprietary function of the inputs. An IP provider may be able to provide design-based sets of inputs and corresponding outputs (referred to earlier as IPSTRs), making it possible to exercise the design through selection of various combinations of inputs without revealing proprietary aspects of the IP design component. Again, it is possible to account for unusual operating conditions in emulated circuitry by programming region 460, using dynamic trigger mechanism 470, with input combinations that are different from what might occur in ordinary operation. In this fashion, it may be possible to identify ambiguous states.
As noted earlier,
As part of the process of exercising a circuit design, it is known in the electronic design automation art to use automatic test pattern generation (ATPG) to provide simulated signal sequences and combinations to identify conditions under which the design will fail. ATPG also can provide signal sequences and combinations that may be applied to fabricated circuits to determine circumstances under which the circuits will fail. One potential problem with ATPG, however, is the sheer volume of data that is presented. As circuitry becomes more and more complex, with greater numbers of inputs and outputs, the number of possible outcomes makes the task of poring through a data dump daunting and time-consuming, in many cases excessively so.
In addition and as an alternative to ATPG techniques, however, the selection of particular signal sequences and combinations may be useful in isolating defects in IP, and in debugging and proof thereof. To this end, the dynamic triggering made possible in accordance with one aspect of the present invention can limit the amount of data that needs to be reviewed. In the case of a standards-based design, the signal sets are likely to be relatively small and manageable, so that triggering is straightforward. Even in the case of proprietary designs, IP providers may have in mind particular signal sequences that would be useful in exercising the design to isolate and/or identify defects.
The IP tracing capability enables an IP consumer to locate and identify a problem within the boundary of a particular IP provider. For example, there may be situations in which IP for a particular function, e.g. graphics, may come from more than one IP provider. Setting trigger conditions (e.g. particular sets or combinations of standard-mandated inputs) appropriately enables the IP consumer to isolate the signals which are involved in the particular problem, and thereby pinpoint the source as being one IP provider and not another.
In an instance in which the various IP providers—including in some cases the IP consumer—have IP which is proprietary, and the IP consumer is seeking to debug, the trace information need not include either the IP consumer's proprietary information, or the proprietary information of any of the IP providers.
In some instances, the verification IP implementation itself may produce errors or ambiguities. Here again, the tracing capability enables a user to navigate around, or avoid the error or ambiguities.
In another aspect of the invention, where the IP at issue is protocol-specific, for example, in accordance with a particular standard or group of standards, it may be possible to avoid having to share any IP provider-specific information, thus enabling the IP provider to keep its own implementation confidential.
In accordance with one aspect of the invention, an EDA manufacturer may receive IPSTRs and make them part of appropriate EDA software, be it verification IP as for example in verification block 220 in
Because the IC designer will not have direct access to the IPSTRs, the designer is not privy to the IP provider's proprietary information. The provider need not worry that sensitive aspects of the IP will leak out to competitors.
In accordance with another aspect of the invention, the design of ICs with functionality that operates according to one or more standards also facilitates debugging, in that the outputs associated with a particular function, e.g. 802.11 wireless, Bluetooth™, or the like, will have expected or anticipated behavior. If the outputs of the provider's code turn out not to be as expected, e.g. because the code does not handle particular inputs or timings, the provider's IPSTRs can use the outputs, or a comparison between the actual and expected outputs, and trace the erroneous signals back through various states, including in some cases ambiguous states, and isolate the defect(s) to a particular IP provider.
The IP for these various components may come from a single source, but more often they come from multiple sources. In some instances, for example with various flavors of USB, other serial, parallel connectors, or video connectors, design and operation of the associated IP may be fairly readily traceable to a particular source. Consequently, if for example a USB connection fails, the device developer may be able to trace the source fairly readily to the IP provider who provided the design component for the USB portion of the device. However, in circumstances where, for example, memory operation may be involved with both general purpose processing and special purpose (e.g. video and/or graphics) processing, a video processing failure may not be readily traceable to the IP provider(s) who provided the design component(s) for video processing. Alternatively, the failure may be traceable potentially to multiple IP providers, but it may be difficult to discern, simply from the data, which of those providers is responsible for the IP causing the failure.
The approach described with respect to
Even if S2 and S3 result from the same IP provider, there is ambiguity as to which IP from that provider would be the source of the error, so that the IP provider would have to undertake a substantial effort, poring through a substantial data dump potentially encompassing irrelevant conditions, in order to trace back through both state sequences to determine the source of the error.
In
In accordance with one aspect of the invention, the ability to trace signals through different paths, and in particular, the ability to perform dynamic triggering in connection with particular states as shown in the state diagrams of
Even when the IP provider takes ownership of the problem and fixes it, it is necessary for the IP provider to demonstrate to the SoC/IC designer, or to the ultimate customer (the smartphone manufacturer), that the problem in fact is fixed, and will not recur. To do this, it is necessary to demonstrate operation of the repaired design under a number of different scenarios.
In order to ensure that a problem will not recur, it is important to take into account the possibility or probability that there may be different states through which a system may pass to reach a certain state, as exemplified in
Once the IP provider has completed debugging the relevant portion of the IP responsible for errors, the IP provider needs to be able to test the debugged design. As noted earlier, it is known to use ATPG to provide a range of signaling scenarios, to exercise the debugged design and determine whether any defect recurs. However, there can be various problems with ATPG, including the volume of resulting data, and the potential generation of ambiguous states whose origins themselves may be ambiguous or otherwise hidden. In this event, the same techniques used to isolate and identify defects as described above may be applicable here. In particular, the trace or data dump that revealed a defect may be included or added for testing purposes. In one aspect, in the case of a standard-based IP component, the IP provider may program combinations of signals as indicated by mandatory and, where applicable, optional portions of the standard in region 460 in
While particular embodiments of the present invention have been described, it is to be understood that various different modifications within the scope and spirit of the invention are possible. The invention is limited only by the scope of the appended claims.
The present application is related to commonly-assigned application Ser. No. ______, entitled “Method and Apparatus for Verifying Debugging of Integrated Circuit Designs,” Attorney Docket No. 13335/12054, filed on the same day as the present application. The contents of that related application are incorporated herein by reference.