Method and apparatus for isolating faulty semiconductor devices in a multiple format graphics system

Information

  • Patent Application
  • 20040088638
  • Publication Number
    20040088638
  • Date Filed
    October 09, 2002
    22 years ago
  • Date Published
    May 06, 2004
    20 years ago
Abstract
A method and an apparatus are provided for isolating faulty semiconductor devices in a multiple format graphics system. The apparatus includes a buffer adapted to receive at least one data stream in at least one of a plurality of formats and a convolver comprising at least one signature register, wherein the convolver is adapted to determine the format of the at least one data stream. The apparatus further includes a router adapted to route the data stream from the buffer to the convolver and an analyzer adapted to access the signature register, wherein the analyzer is capable of isolating at least one of a faulty semiconductor device and a faulty interconnect based upon the contents of the signature register and the determined format.
Description


BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention


[0002] This invention relates generally to computer hardware and, more particularly, to a method and apparatus for isolating faulty semiconductor devices in a multiple format graphics system.


[0003] 2. Description of the Related Art


[0004] In modern video graphics systems, streams of digital bits have taken the place of the traditional reel of celluloid film composed of individual still photographs. The laborious task of processing video data may now be done with the assistance of processors in the video graphics systems, which may be capable of working on multiple streams of data from a variety of sources at once. For example, a single video graphics system may receive streams of data from devices such as a digital camera, a graphics rendering device, a computer-assisted design program, and the like. The video graphics system may also provide post-processed video data to a variety of output devices, including video projectors, televisions, monitors, and the like.


[0005] Video graphics systems may include tens or hundreds of semiconductor devices designed to perform various functions. Like all complex semiconductor devices, the semiconductor devices in the video graphics system may occasionally have intrinsic defects that cause the video graphics system to operate in an undesirable manner. The semiconductor devices may also become faulty during operation of the video graphics system. Even a single faulty semiconductor device can cause the video graphics system to operate in an incorrect or undesirable manner, so it is desirable to isolate faults to a single failing semiconductor device.


[0006] However, the increasing complexity of video graphics systems, and corresponding decreasing size of their semiconductor elements, has made it increasingly difficult to test the video graphics system. Simply observing the screen output of the video graphics system may reveal undesirable operation, but it may not be a sensitive enough test to detect some errors in high resolution video outputs. Further, the simply observing the screen output of the video graphics system may not provide any indication of which semiconductor device may be faulty. External test equipment like logic analyzers, logic probes and/or oscilloscopes may also have limited usefulness as the size of the semiconductor components continues to decrease.


[0007] In recent years, signature analysis using signature registers included in the video graphics system has been developed to provide reliable indications of the correct operation of digital systems. However, trying to isolate faults down to a single component level using signature registers is difficult when there are, for example, 92 semiconductor devices involved in the video graphics system where no signature registers can be put into at least 64 of the semiconductor devices.


[0008] The problems may be exacerbated when video frames may be provided to the video graphics system in multiple formats. Progressive video formats, for example, may represent a single frame of video as a single series of pixels, also known as a field that may be used to draw all the lines on a video output drive, such as a monitor. The field of a progressive video format may extend from the upper left hand corner of the frame to the lower right hand corner of the frame. Interlaced video formats may represent a single frame of video as a pair of fields including one even field and one odd field. The odd field may contain an odd series of pixels that may be used to draw the odd lines on a video monitor and the even field may contain an even series of pixels that may be used to draw the even lines on a video monitor. A stereo monitor format may represent each frame of video as a left field and a right field. The left field may draw an entire image as seen from a user's left eye and the right field may be used to draw the entire image as seen from the user's right eye.



SUMMARY OF THE INVENTION

[0009] In one aspect of the present invention, an apparatus is provided for isolating faulty semiconductor devices in a multiple format graphics system. The apparatus includes a buffer adapted to receive at least one data stream in at least one of a plurality of formats and a convolver comprising at least one signature register, wherein the convolver is adapted to determine the format of the at least one data stream. The apparatus further includes a router adapted to route the data stream from the buffer to the convolver and an analyzer adapted to access the signature register, wherein the analyzer is capable of isolating at least one of a faulty semiconductor device and a faulty interconnect based upon the contents of the signature register and the determined format.


[0010] In another aspect of the instant invention, a method is provided for isolating faulty semiconductor devices in a multiple format graphics system. The method includes providing a test pattern to a buffer via at least one data stream in at least one of a plurality of formats, wherein the buffer is coupled to a router and a convolver. The method further includes determining the format of the data stream, accessing at least one signature register in the convolver, and detecting at least one of a faulty semiconductor device and a faulty interconnect using the contents of the signature register and the determined format.







BRIEF DESCRIPTION OF THE DRAWINGS

[0011] The invention may be understood by reference to the following description taken in conjunction with the accompanying drawings, in which like reference numerals identify like elements, and in which:


[0012]
FIG. 1 shows a block diagram of a system, in accordance with one embodiment of the present invention;


[0013] FIGS. 2A-B show block diagrams illustrating an exemplary configuration of a frame buffer, a router, and a convolver that may be used in the graphics system shown in FIG. 1, in accordance with one embodiment of the present invention;


[0014]
FIG. 3 shows a block diagram of a signature analyzer that may be used in the graphics system depicted in FIGS. 2A-B, in accordance with one embodiment of the present invention;


[0015]
FIG. 4 shows a flow diagram illustrating a method that may be used for detecting faulty semiconductor devices in the graphics system depicted in FIGS. 2A-B; and


[0016]
FIG. 5 shows a flow diagram illustrating a method of analyzing signatures that may be used by the signature analyzer shown in FIG. 3 to detect and isolate faulty semiconductor devices in the graphics system shown in FIG. 1, in accordance with one embodiment of the present invention.


[0017] While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof have been shown by way of example in the drawings and are herein described in detail. It should be understood, however, that the description herein of specific embodiments is not intended to limit the invention to the particular forms disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the scope of the invention as defined by the appended claims.







DETAILED DESCRIPTION OF SPECIFIC EMBODIMENTS

[0018] Illustrative embodiments of the invention are described below. In the interest of clarity, not all features of an actual implementation are described in this specification. It will of course be appreciated that in the development of any such actual embodiment, numerous implementation-specific decisions may be made to achieve the developers' specific goals, such as compliance with system-related and business-related constraints, which will vary from one implementation to another. Moreover, it will be appreciated that such a development effort might be complex and time-consuming, but would nevertheless be a routine undertaking for those of ordinary skill in the art having the benefit of this disclosure.


[0019] Referring now to FIG. 1, a block diagram showing a system 100 in accordance with one embodiment of the present invention is illustrated. The system 100 may include one or more video sources 105 such as a digital video camera, a graphics rendering device, and the like. The video source 105 may, in one embodiment, provide one or more video data streams to a frame buffer 107 in a graphics system 110 such as a Sun Microsystems® video graphic system. The video data streams may comprise a plurality of frames of video (not shown) that may be formed in a variety of video formats including progressive, stereo, interlaced, and the like. Depending on the video formats that may be supported by an embodiment of the present invention, each frame of video may be divided into one or more pixel series known as fields. The one or more fields may be formed of a plurality of bits. In one embodiment, each one of the plurality of frames may be formed of approximately 50 million bits. In alternative embodiments, each frame may be formed of more or fewer bits. In one embodiment, the frame buffer 107 may store the video data from the one or more video streams.


[0020] A convolver 120 may be used by the graphics system 110 to process the data in the video data streams and provide a signal that may be used by one or more video output devices 125 to produce an image. Although not so limited, the video output devices 125 may include such devices as a television, a video projection device, a monitor, and the like. The convolver 120 may, in one embodiment, transmit requests to the frame buffer 107, which may provide data from the one or more video data streams to a router 130 in response to the request. The router 130 may then direct the video data to the convolver 120.


[0021] The frame buffer 107, the convolver 120, the router 130, and other desirable elements of the graphics system 110 may include a plurality of semiconductor devices that may perform various functions. The semiconductor devices may be defective when installed, or they may fail during operation of the graphics system 110. Hereinafter, a semiconductor device that may be defective or may cause the graphics system 110 to operate in an incorrect or undesirable manner will be referred to as a “faulty semiconductor device.” Thus, in accordance with one embodiment of the present invention, the graphics system 110 may comprise a signature analyzer 140 that may be capable of detecting and isolating one or more faulty semiconductor devices in the multiple format graphics system 110.


[0022] The signature analyzer 140 may, in one embodiment, be coupled to the convolver 120. Signature data from a plurality of signature registers in the convolver 120 may be provided to the signature analyzer 140. In one embodiment, the signature data may be provided to the signature analyzer 140 in series using the Joint Test Action Group (JTAG) protocol, also known as the Institute of Electrical and Electronics Engineers (IEEE) Standard 1149.1, entitled “Standard test access port and boundary scan architecture.” As described in more detail below, the signature analyzer 140 may use the signature data from the convolver 120 to detect and isolate one or more faulty semiconductor devices in the multiple format graphics system 110.


[0023] Referring now to FIG. 2A, a block diagram illustrating an exemplary arrangement of the frame buffer 107, the convolver 120, and the router 130 that may be used in the graphics system 110 is shown. The frame buffer 107 may include a plurality of frame buffer elements 220(1-64) and, in one embodiment, the frame buffer elements 220(1-64) may not include signature registers. However, it should be appreciated that, in alternative embodiments, more or fewer frame buffer elements 220(1-64) may be deployed in the frame buffer 107 without deviating from the scope of the present invention. In one embodiment, each of the 64 frame buffer elements 220(1-64) may output 20 bits of video data. Thus, the frame buffer 107 may provide 64×20=1280 bits to the other components of the graphics system 110. It should, however, be appreciated that, in alternative embodiments, more or fewer bits may be output by the frame buffer elements 220(1-64) without deviating from the scope of the present invention.


[0024] The frame buffer elements 220(1-64) may be divided into one or more groups. In one embodiment, the 64 frame buffer elements 220(1-64) may be divided into 8 groups of 8 frame buffer elements 220(1-8), 220(9-16), 220(57-64), as indicated in FIG. 2A. However, it should be appreciated that, in alternative embodiments, the frame buffer elements 220(1-64) may be divided into more or fewer groups having more or fewer frame buffer elements 220(1-64). In one embodiment, each of the video data streams may be provided to separate groups of frame buffer elements 220(1-64). For example, if two video data streams are provided to the graphics system 110, a first video data stream may be provided to four groups including the 32 frame buffer elements 220(1-32) and a second video data stream may be provided to four groups including the 32 frame buffer elements 220(33-64). The two video data streams may be in different video formats and so frames in different video formats may be provided to the separate groups of frame buffer elements 220(1-64).


[0025] The frame buffer 107 may, in one embodiment, provide data to the router 130. The router 130 may, in one embodiment, include 20 router elements 240(1-20). Each of the 20 router elements 240(1-20) may have a plurality of input router signature registers 243(1-64), as shown in FIG. 2B, which may each analyze 1 bit of data. Thus, the router 130 may analyze 20×64×1=1280 bits from the frame buffer 107. However, it should be appreciated that, in alternative embodiments, more or fewer router elements 240(1-20) including more or fewer input router signature registers 243(1-64) capable of analyzing one or more bits may be used without deviating from the scope of the present invention. The input router signature registers 243(1-64) may be formed of 20-bit signature registers, so additional bits may be added to each of the input router signature registers 243(1-64). In one embodiment, the input router signature registers 243(1-64) may be linear hybrid cellular automata (LHCA).


[0026] The bits of video data may be directed to the various input router signature registers 243(1-64) using any of a variety of methods and/or devices well known to those of ordinary skill in the art. In one embodiment, the bits may be divided such that each of the 20 router elements 240(1-20) receives a respective one of the 20 bits from each of the 64 corresponding frame buffer elements 220(1-64). For example, a first bit in the first frame buffer element 220(1) may be routed to the first input router signature register 243(1) and a second bit in the first frame buffer element 220(1) may be routed to the second input router signature register 243(2). For another example, a first bit in the second frame buffer element 220(2) may be routed to the first input router signature register 243(1) and a second bit in the second frame buffer element 220(2) may be routed to the second input router signature register 243(2). Thus, each input router signature register 243(1-64) may be provided with one bit from each of the frame buffer elements 220(1-64). Although not so limited, bits from a single group of frame buffer elements 220(1-64) may be provided to the corresponding input router signature registers 243(1-64). For example, in FIG. 2B, the input router signature registers 243(1-64) in the block labeled 243(1-8) may be provided with the first bit from each of the frame buffer elements 220(1-64) in the first group of 8 frame buffer elements 220(1-8).


[0027] Each of the router elements 240(1-20) may also have a plurality of 8-bit output router signature registers 246(1-8). In one embodiment, the input router signature registers 243(1-64) may provide 8×8×20=1280 bits to the 8-bit output router signature registers 246(1-8) in the 20 router elements 240(1-20). However, it should be appreciated that, in alternative embodiments, more or fewer output router signature registers 246(1-8) capable of analyzing more or fewer than 8 bits may be used without deviating from the scope of the present invention. In one embodiment, the output router signature registers 246(1-8) may be formed from LHCAs. The 8-bit output router signature registers 246(1-8) may, in one embodiment, each be provided with bits from a single group. For example, the input router signature registers 243(1-8) may provide 8 bits to the 8-bit output router signature register 246(1) and the input router signature registers 243(9-16) may provide 8 bits to the 8-bit output router signature register 246(2).


[0028] The router 130 may route the bits of video data to the convolver 120 using a plurality of interconnects 250, which may, in various alternative embodiments, be wires, traces, and the like. The convolver 120 may be capable of post-processing the at least one video data stream provided by the at least one video source 105 and sending the post-processed video data to other portions of the system 100 of which the graphics system 110 may be a part, such as the video output devices 125 shown in FIG. 1. The convolver 120 may, in one embodiment, include a plurality of convolution elements 260(1-8), as shown in FIG. 2B, which may include a plurality of 8-bit input convolution signature registers 265(1-20). Thus, the convolver 120 may be capable of receiving 8×20×8=1280 bits from the router 130. It should, however, be appreciated that, in alternative embodiments, more or fewer convolution elements 260(1-8) including more or fewer input convolution signature registers 265(1-20) capable of analyzing more or fewer than 8 bits may be used without deviating from the scope of the present invention. In various illustrative embodiments, the input convolution signature registers 265(1-20) may be formed from LHCAs.


[0029] In one embodiment, the router 130 may provide the bits from each group of frame buffer elements 220(1-64) to each of the input convolution signature registers 265(1-20). For example, the output router signature register 246(1) on the router element 240(1) may provide the first bits from each of the first group of frame buffer elements 220(1-8) to the input convolution signature register 265(1) on the convolution element 260(1). Similarly, the output router signature register 246(2) on the router element 240(1) may provide the first bits from each of the second group of frame buffer elements 220(9-16) to the convolution element 260(2). For another example, the router element 240(2) may provide the second bits from each of the first group of frame buffer elements 220(1-8) to the input convolution signature register 265(2) on the convolution element 260(1) and the router element 240(20) may provide the twentieth bits from each of the first group of frame buffer elements 220(1-8) to the input convolution signature register 265(20) on the convolution element 260(1). Thus, each convolution element 260(1-8) may, in one embodiment, receive the video data from one group of frame buffer elements 220(1-64) and, consequently, may perform the post-processing on one of the at least one video streams at a time.


[0030] In accordance with one embodiment of the present invention, the convolver 120 may also include a controller 267 that may be coupled to a control register 270 and a timing generator 275, as well as the input convolution signature registers 265(1-20). The control register 270 may provide data that may be used by the controller 267 to control the operation of the convolver 120. For example, the controller 267 may use a start/stop bit in the control register 270 to arm or disarm the input convolution signature registers 265(1-20). The timing generator 275 may provide a signal to the controller 267 indicating when the video source 105 may have begun or ended transmitting a frame. In one embodiment, the controller 267 may also provide a signal to the signature analyzer 140.


[0031]
FIG. 3 shows a block diagram of the signature analyzer 140 that may be used in the graphics system 110. The signature analyzer 140 may, in one embodiment, be coupled to one or more buses 310(1-3). For example, the signature analyzer 140 may be coupled to three buses 310(1-3), which may be coupled to the input router signature registers 243(1-64) on the router elements 240(1-20), the output router signature registers 246(1-8) on the router elements 240(1-20), and the input convolution signature registers 265(1-20) on the convolution elements 260(1-8). However, it should be appreciated that more or fewer buses 310(1-3) may be used in the graphics system 110 without departing from the scope of the present invention.


[0032] In one embodiment, data from the signature registers 243(1-64), 246(1-8), 265(1-20) may be provided to the signature analyzer 140 in series via the buses 310(1-3) using the Joint Test Action Group (JTAG) protocol, also known as the Institute of Electrical and Electronics Engineers (IEEE) Standard 1149.1, entitled “Standard test access port and boundary scan architecture.” The JTAG Standard provides a serial bus standard that may be used to implement a general purpose hardware configuration, initialization, and status bus. However, it should be appreciated that, in alternative embodiments, an Inter-IC (I2C) serial bus, a PCI bus, a parallel bus, or any other standard or proprietary bus well known to those of ordinary skill in the art may be used by the buses 310(1-3) in the graphics system 110.


[0033] The serial buses 310(1-3) may be coupled to an acceptor 320. In one embodiment, the bits in the signature registers 243(1-64), 246(1-8), 265(1-20) may be provided serially to the acceptor 320 via the serial buses 310(1-3), and the acceptor 320 may use the bits to form a plurality of signatures by any of a variety of methods well known to those of ordinary skill in the art. For example, the acceptor 320 may form a calculated signature from the bits in the input convolution signature register 265(1) by performing a binary addition of all the bits. For another example, the acceptor 320 may form a calculated signature from the bits in the input convolution signature register 265(1) by performing an exclusive-OR operation on adjacent bits. Hereinafter, the signatures that may be calculated by the acceptor 320 using the bits in the signature registers 243(1-64), 246(1-8), 265(1-20) are referred to as the “calculated signatures.”


[0034] The signatures that may be formed by the acceptor 320 using signature data from the signature registers 243(1-64), 246(1-8), 265(1-20) may depend upon the video data that may be provided to the frame buffer 107. Consequently, if a predetermined test pattern is provided to the frame buffer 107, the signatures that should be calculated during normal operation of the acceptor 320 may be determined in advance. Although not so limited, the test pattern may include such geometric shapes as triangles, squares, circles, or any other desirable shape or combinations thereof. Hereinafter, the signatures that may be calculated in advance using the predetermined test pattern are referred to as the “predetermined signatures.” In accordance with one embodiment of the present invention, a generator 330 may be provided to determine the predetermined signatures. Although not so limited, in one embodiment, the generator 330 may be one or more processors running one or more software applications.


[0035] The acceptor 320 may be coupled to a comparator 340 and may provide the calculated signatures to the comparator 340. Similarly, the generator 330 may provide the predetermined signatures to the comparator 340, which may compare the calculated signatures to the predetermined signatures. If the frame buffer 107, the router 130, the convolver 120, he interconnects 250, and any other components that it may be desirable to include in the graphics system 110 are operating correctly, the predetermined signatures may be substantially the same as the calculated signatures. However, if the predetermined signatures are not substantially the same as the calculated signatures, it may indicate that one or more components in the graphics system 110 may be faulty. By comparing the calculated and predetermined signatures, the comparator 340 may be capable of detecting and isolating one or more faulty components in the graphics system 110.


[0036] In one embodiment, the one or more video sources 105 may provide video data streams to the graphics system 110. The comparator 340 may then use the calculated signatures of the input router signature registers 243(1-64) in the router elements 240(1-20) to detect and isolate one or more faulty frame buffer elements 220(1-20). For example, if the calculated signature for the input router signature register 243(1) in the router element 240(1) does not substantially match the predetermined signature, the comparator 340 may determine that the frame buffer element 220(1) may be faulty.


[0037] Similarly, the comparator 340 may use the calculated signatures of the output router signature registers 246(1-8) and/or the input convolution signature registers 265(1-20) to determine if one or more of the router elements 240(1-20) or convolution elements 260(1-8) may be faulty. For example, if the calculated signature for the input router signature register 243(1) in the router element 240(1) substantially matches the predetermined signature, but the calculated signature for the output router signature register 246(1) in the router element 240(1) does not substantially match the predetermined signature, the comparator 340 may determine that the router element 240(1) may be faulty.


[0038] Furthermore, the comparator 340 may use the calculated signatures of the output router signature registers 246(1-8) and the input convolution signature registers 265(1-20) to determine if one or more of the interconnections 250 may be faulty. For example, if the calculated signature for the output router signature register 246(1) in the router element 240(1) substantially matches the predetermined signature, but the calculated signature for the input convolution signature register 265(1) in the convolution element 260(1) does not substantially match the predetermined signature, the comparator 340 may determine that one or more of the plurality of interconnections 250 may be faulty.


[0039] However, the one or more video sources 105 may provide video data streams to the graphics system 110 in more than one format, as described above. Thus, in accordance with one embodiment of the present invention, the acceptor 320 may be coupled to the controller 267. The controller 267 may provide a signal to the acceptor 320 that may indicate the format of the video data, when the frame begins and ends, and any other information that it may be desirable to convey to the acceptor 320. In response to the signal from the controller 267, the acceptor 320 may begin gathering signature data from the input convolution signature registers 265(1-20) and may form a plurality of calculated signatures. The acceptor 320 may provide the calculated signatures to the comparator 340 so that the signature analyzer 140 may detect and isolate one or more faulty components in the graphics system 110.


[0040] Referring now to FIG. 4, a flow diagram illustrating a method of detecting and isolating one or more faulty semiconductor devices in the graphics system 110 is shown. A test pattern may be provided (at 400) to the frame buffer 107. Although not so limited, the test pattern may include such geometric shapes as triangles, squares, circles, or any other desirable shape or combinations thereof In one embodiment, the test pattern may be provided (at 400) in a variety of formats, including progressive, stereo, interlaced, and the like.


[0041] In accordance with one embodiment of the present invention, the graphics system 110 may write (at 410) control data to the control register 270 to initiate a signature gathering process. For example, the control data may indicate how many frames it may be desirable to signature analyze, the video format of each frame, a start/stop bit to indicate that the signature gathering process is being initiated, and the like. The controller 267 may access (at 420) the control data in the control register 270 and use the control data to control operation of the input convolution signature registers 265(1-20). For example, if the start-stop bit is set to logic-high, the controller 267 may instruct the signature analyzer 140 to arm the input convolution signature registers 265(1-20). Once armed, the input convolution signature registers 265(1-20) may be ready to gather signature data. The controller 267 may also access (at 420) the contents of the control register 270 to determine the format of the video frame and how many frames may be signature analyzed.


[0042] The controller 267 may determine (at 430) when the video source 105 has begun transmitting at least one frame using a signal provided by the timing generator 275. If the controller 267 determines (at 430) that the video source 105 (see FIG. 1) may not have begun transmitting the desired frame or frames, the controller 267 may wait (at 430) until the timing generator 275 provides a signal indicating that the video source 105 may have begun transmitting the desired frame or frames. In response to receiving the signal from the timing generator 275, the controller 267 may start (at 440) the signature gathering process. In one embodiment, starting (at 440) the signature gathering process may include such steps as providing a signal to the input convolution signature registers 265(1-20) and providing a signal to the signature analyzer 140. As described in more detail below, the input convolution signature registers 265(1-20) and the signature analyzer 140 may then gather (at 440) signatures and analyze the contents of the input convolution signature registers 265(1-20).


[0043] Referring now to FIG. 5, a flow diagram illustrating one embodiment of a more detailed description of the process of gathering signature data and analyzing signatures is shown. The signature analyzer 140 may read out (at 500) the contents of the input convolution signature registers 265(1-20), and any other signature registers that it may be desirable to include in the graphics system 110. Although not so limited, in one embodiment, the signature analyzer 140 may read (at 500) the contents in series using the Joint Test Action Group (JTAG) protocol, also known as the Institute of Electrical and Electronics Engineers (IEEE) Standard 1149.1, entitled “Standard test access port and boundary scan architecture.”


[0044] The acceptor 320 may use the read-out contents to form (at 510) one or more calculated signatures by a variety of means well know to those of ordinary skill in the art. The generator 330 may use the test pattern to form (at 510) one or more predetermined signatures. In one embodiment, one calculated signature and one predetermined signature may be formed for each bit in each input convolution signature register 265(1-20). However, it should be appreciated that, in alternative embodiments, more or fewer calculated and predetermined signatures may be formed without deviating from the scope of the present invention.


[0045] The comparator 340 may then compare (at 520) the calculated signature to the corresponding predetermined signature. If the comparator 340 determines (at 530) that the calculated signatures are substantially equal to the corresponding predetermined signatures, indicating that the semiconductor devices in the graphics system 110 may be operating in a desirable manner, the signature analysis may end (at 535). However, if the comparator determines (at 530) that one or more calculated signatures are not substantially equal to the corresponding predetermined signatures, indicating that one or more semiconductor devices and/or interconnections 250 in the graphics system 110 may be faulty, the signature analyzer 140 may isolate (at 540) the error, as described above, after which the signature analysis may end (at 535).


[0046] Referring back to FIG. 4, the controller 267 may, in one embodiment, monitor the contents of the input convolution signature registers 265(1-20) and the timing generator 275 to determine (at 450) if the frame may have been transmitted to the graphics system 110. If not, the input convolution signature registers 265(1-20) and the signature analyzer 140 may continue to gather (at 440) signature data. If the controller 267 determines (at 450) that the frame may have been transmitted, the controller 267 may increment (at 460) a frame counter (not shown). The controller 267 may then access the contents of the control register 270 and the frame counter to determine (at 470) if all the requested frames have been signature analyzed. If so, the start/stop bit may, in one embodiment, be set (at 475) to logic-low and the signature gathering process may end (at 480). If not, the input convolution signature registers 265(1-20) and the signature analyzer 140 may continue to gather (at 440) signature data.


[0047] The particular embodiments disclosed above are illustrative only, as the invention may be modified and practiced in different but equivalent manners apparent to those skilled in the art having the benefit of the teachings herein. Furthermore, no limitations are intended to the details of construction or design herein shown, other than as described in the claims below. It is therefore evident that the particular embodiments disclosed above may be altered or modified and all such variations are considered within the scope of the invention.


[0048] Accordingly, the protection sought herein is as set forth in the claims below.


Claims
  • 1. An apparatus, comprising: a buffer adapted to receive at least one frame in at least one of a plurality of formats; a convolver comprising at least one signature register, wherein the convolver is adapted to determine the format of the at least one frame; a router adapted to route the frame from the buffer to the convolver; and an analyzer adapted to access the signature register, wherein the analyzer is capable of isolating at least one of a faulty semiconductor device and a faulty interconnect based upon the contents of the signature register and the determined format.
  • 2. The apparatus of claim 1, wherein the faulty semiconductor device is in at least one of the buffer, the convolver, and the router.
  • 3. The apparatus of claim 1, wherein the convolver comprises a control register adapted to receive control data.
  • 4. The apparatus of claim 3, wherein the convolver comprises a controller adapted to determine the format of the at least one frame using the control data in the control register.
  • 5. The apparatus of claim 4, wherein the controller is further adapted to determine the number of frames provided by the video source.
  • 6. The apparatus of claim 1, wherein the convolver comprises a timing generator capable of determining a beginning and an end of the frame.
  • 7. The apparatus of claim 6, wherein the timing generator is adapted to provide a first signal to the controller in response to identifying the beginning of the frame.
  • 8. The apparatus of claim 7, wherein the timing generator is further adapted to provide a second signal to the controller in response to identifying the end of the at least one frame.
  • 9. The apparatus of claim 8, wherein the controller is adapted to instruct the signature register to begin gathering signature data in response to the first signal.
  • 10. The apparatus of claim 9, wherein the controller is adapted to provide a third signal to the analyzer in response to the first signal.
  • 11. The apparatus of claim 10, wherein the analyzer is adapted to access the signature register in response to the third signal.
  • 12. The apparatus of claim 11, wherein the controller is adapted to provide a fourth signal to the analyzer in response to the second signal.
  • 13. The apparatus of claim 12, wherein the analyzer is adapted to stop accessing the signature register in response to the fourth signal.
  • 14. The apparatus of claim 1, wherein the analyzer comprises at least one generator adapted to form at least one predetermined signature using the frame.
  • 15. The apparatus of claim 14, wherein the analyzer comprises at least one acceptor adapted to form at least one calculated signature using the contents of the signature registers.
  • 16. The apparatus of claim 15, wherein the analyzer comprises a comparator adapted to isolate at least one faulty semiconductor device by determining if the calculated signature is substantially equal to the predetermined signature.
  • 17. The apparatus of claim 1, further comprising at least one video source adapted to provide the at least one frame to the buffer.
  • 18. A method comprising: providing at least one frame of a test pattern to a buffer in at least one of a plurality of formats, wherein the buffer is coupled to a router and a convolver; determining the format of the frame; accessing at least one signature register in the convolver; and detecting at least one of a faulty semiconductor device and a faulty interconnect using the contents of the signature register and the determined format.
  • 19. The method of claim 18, wherein detecting the faulty semiconductor device comprises detecting the faulty semiconductor device in at least one of the buffer, the router, and the convolver.
  • 20. The method of claim 18, further comprising detecting the beginning of the at least one frame.
  • 21. The method of claim 20, further comprising determining the number of frames.
  • 22. The method of claim 21, wherein accessing the signature register comprises accessing the signature register in response to detecting the beginning of the frame.
  • 23. The method of claim 22, wherein accessing the signature register comprises detecting the end of the at least one frame based upon the determined number of frames.
  • 24. The method of claim 23, wherein accessing the signature register comprises stopping accessing the signature register in response to detecting the end of the at least one frame.
  • 25. The method of claim 18, wherein accessing the signature register comprises reading out the contents of the signature register.
  • 26. The method of claim 25, wherein detecting the at least one of the faulty semiconductor device and the faulty interconnect comprises forming a calculated signature using the read-out contents of the signature register.
  • 27. The method of claim 26, wherein detecting the at least one of the faulty semiconductor device and the faulty interconnect comprises forming a predetermined signature using the test pattern.
  • 28. The method of claim 27, wherein detecting the at least one of the faulty semiconductor device and the faulty interconnect comprises determining if the calculated signature is substantially equal to the predetermined signature.
  • 29. The method of claim 28, wherein detecting the at least one of the faulty semiconductor device and the faulty interconnect comprises isolating the at least one of the faulty semiconductor device and the faulty interconnect using the calculated and predetermined signatures.
  • 30. A system, comprising: at least one video source adapted to provide a test pattern to a buffer via at least one data stream, wherein the data stream includes at least one frame in at least one format; a convolver adapted to determine the format of the at least one frame, wherein the convolver includes at least one signature register; a router adapted to route the data streams from the buffer to the convolver; a timing generator adapted to determine a beginning and an end of the frame; an acceptor adapted to access the signature registers and form at least one signature using the contents of the signature registers, the determined format, and the determined beginning and end of the frame; a generator adapted to generate at least one predetermined signature using the test pattern; and a comparator adapted to detect at least one of a faulty semiconductor device in at least one of the buffer, the router, and the convolver and a faulty interconnect by determining if the calculated signature is substantially equal to the predetermined signature.
  • 31. The system of claim 30, wherein the signature register is a linear hybrid cellular automata.
  • 32. The system of claim 30, wherein the generator comprises a processor adapted to run software to generate the predetermined signature.
  • 33. The system of claim 30, wherein the video source is a camera.
  • 34. The system of claim 30, wherein the video source is a graphics rendering device.
  • 35. A device, comprising: means for providing at least one data stream to a buffer, wherein the data stream includes at least one frame in at least one of a plurality of formats; means for determining the format of the at least one frame; means for determining when the frame begins and ends; means for accessing at least one signature register on a convolver based upon when the frame begins and ends; and means for detecting at least one of a faulty semiconductor device and a faulty interconnect by forming at least one signature using the contents of the signature registers and the determined format.