The present invention relates to a method and a system for testing microchip checkers, and in particular for testing microchip checkers outside of a full microchip environment.
A checker is a software module developed for the purpose of verifying the various functionalities of a chip. A checker operates by testing whether, upon providing a predetermined input signal to the chip, the required outputs from the various hierarchical levels of the chip are obtained. However, since the coverage data to be captured by the checker is often temporal by nature, the checkers are usually complex and the building process of the checker itself requires multiple iterations. In addition, because of its functionality, the validation of a checker generally requires a full chip environment. Accordingly, compiling and running a checker is necessarily associated with compiling and running the complete chip model. Thus, developing a correctly functioning checker is difficult and time consuming.
According to one aspect of the invention, there is provided a method for testing functionality of a chip checker. The checker is arranged for generating a predetermined verification signal in response to receiving a driving signal and a corresponding response signal generated by the chip in response to the driving signal. The method comprises;
According to a second aspect of the invention, there is provided a method for facilitating building a chip checker. The checker is arranged for generating a predetermined verification signal in response to receiving a driving signal and a corresponding response signal, generated by the chip in response to the driving signal. The method comprises;
Preferably, the method further comprises repeating at least steps c) to e) until the predetermined verification signal is generated by the checker.
According to a third aspect of the invention, there is provided an electronic system for testing functionality of a chip checker. The checker is arranged for generating a predetermined verification signal in response to receiving a driving signal and a corresponding response signal, generated by the chip in response to the driving signal. The system comprises;
wherein the system is arranged so that a failure of the checker to generate the predetermined verification signal indicates checker malfunction.
According to a fourth aspect of the invention, there is provided an electronic system for facilitating building a chip checker. The checker is arranged for generating a predetermined verification signal in response to receiving a driving signal and a corresponding response signal, generated by the chip in response to the driving signal. The system comprises;
According to a fifth aspect of the invention, there is provided the method of the first aspect of the invention the method further comprising executable code arranged to run on a processing unit, the executable code being arranged to, upon execution, effect the steps in the method.
According to a sixth aspect of the invention, there is provided a computer readable medium encoded with the executable code of the method of the fifth aspect.
According to a seventh aspect of the invention, there is provided a system for testing functionality of a chip checker. The checker is arranged for generating a predetermined verification signal in response to receiving a driving signal and a corresponding response signal generated by the chip in response to the driving signal. The system comprises;
wherein the system is arranged so that driving signals are provided to the chip model and the checker model, the checker being also supplied with the response signals generated by the chip in response to the driving signals, a failure of the checker to generate the predetermined verification signal indicating checker malfunction.
A schematic diagram of a system 20 for testing the validity of a checker is shown in
Upon receiving signals 6A from the chip 3A, the checker 1A generates coverage data output 5. The output data 5 is monitored (step 33 of
The programming modules illustrating the above discussed method are written in a “Very High Speed Integrated Circuit Hardware Description Language (VHDL). As was explained above, the aim of the proposed method is to test the functionality of a checker employed to verify the operation of a chip. In this example, the checker test the functioning of a portion of a VHDL microchip source file. The particular portion of a VHDL microchip source file is the “SLICE0” module 41 from the chip hierarchy of
The checker model is developed in view of the specific functionality test requirements of the chip. The checker receives its inputs from the VHDL source file and checks for the occurrence of the required condition/sequence/function. The checker is also written using VHDL.
For validating the checker, the chip functional hierarchy shown in
The above modules are compiled in the order of their listing. The last of these modules (node0.vhexp) includes the complete set of signals required to validate the checker. A test case driving the entire verification procedure is also prepared. The chip output signals are emulated according to the actual functionality of the SLICE0 module and are supplied to the checker. If the checker functions properly, it will produce an output for one clock cycle. The actual output of the checker is shown by the “COUNT_TICKS” waveform 51 of
Computer Platform
As seen in
The computer 601 typically includes at least one processor unit 605, and a memory unit 606 for example formed from semiconductor random access memory (RAM) and read only memory (ROM). Here, the processor unit 605 is an example of a processing/computational means which can also be realized with other forms of configuration performing similar functionality. The computer 601 also includes an number of input/output (I/O) interfaces including a video interface 607 that couples to the video display 614, an I/O interface 613 for such devices like the keyboard 602 and mouse 603, and an interface 608 for the external modem 616. In some implementations, the modem 616 may be incorporated within the computer 601, for example within the interface 608. The computer 601 may also have a local network interface 611 which, via a connection 623, permits coupling of the computer system 600 to a local computer network 622, known as a Local Area Network (LAN). As also illustrated, the local network 622 may also couple to the wide network 620 via a connection 624, which would typically include a so-called “firewall” device or similar functionality. The interface 611 may be formed by an Ethernet™ circuit card, a wireless Bluetooth™, an IEEE 802.11 wireless arrangement or a combination of thereof.
Storage devices 609 are provided and typically include a hard disk drive (HDD) 610. It should be apparent to a person skilled in the art that other devices such as a floppy disk drive, an optical disk drive and a magnetic tape drive (not illustrated) may also be used. The components 605 to 613 of the computer 601 typically communicate via an interconnected bus 604 and in a manner which results in a conventional mode of operation of the computer system 600.
Typically, the programming modules that incorporate the method for testing functionality of a chip checker are resident on the storage device 609 and read and controlled in execution by the processor 605. Thus, the processor 605 is responsible for the computational steps such as developing a model of the chip, supplying the developed chip model with the driving signal and supplying the checker with the driving signal and the corresponding response signal generated by the chip. Storage of intermediate product from the execution of such steps may be accomplished using the semiconductor memory 606, possibly in concert with the storage device 609. In some instances, the application programs may be supplied to the user encoded on one or more CD-ROM or other forms of computer readable media and read via the corresponding drive, or alternatively may be read by the user from the networks 620 or 622.
If checker testing is required on the handheld device 625, it can either utilize its own storage and processing means, similar to these described in relation to computer 601, or make use of a wireless network connection to a computer system, such as 601, on which all watermark related processing can be carried out remotely.
The discussed system and a method for testing functionality of a chip checker provide a faster way of compiling of a microchip checker and testing its functionality, thus facilitating the expeditious building of a functionally correct checker. The method provides an overall reduction in the verification and building cycle time, especially where the testing is conducted early in the design cycle.
Number | Name | Date | Kind |
---|---|---|---|
5621312 | Achor et al. | Apr 1997 | A |
6834359 | Boehm et al. | Dec 2004 | B2 |
6993736 | Syed et al. | Jan 2006 | B2 |
7047174 | Koh et al. | May 2006 | B2 |
7055113 | Broberg, III et al. | May 2006 | B2 |
7132845 | Lamson et al. | Nov 2006 | B1 |
20020143510 | Peters et al. | Oct 2002 | A1 |
20030115564 | Chang et al. | Jun 2003 | A1 |
20050229121 | Hildebrant | Oct 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
20090125292 A1 | May 2009 | US |