This application is related to: U.S. patent application Ser. No. 10/993,933, titled “HIGH INTEGRITY DATA PROPAGATION IN A BRAIDED RING” (which is also referred to here as the “'933 application” and which is hereby incorporated herein by reference) and U.S. patent application Ser. No. 11/010,249, titled “SELF-CHECKING PAIR ON A BRAIDED RING NETWORK” (which is also referred to here as the “'249 application” and which is hereby incorporated herein by reference) both of which were filed on Nov. 19, 2004. The '933 application claims the benefit of U.S. Provisional Application No. 60/523,892, filed on Nov. 19, 2003, and U.S. Provisional Application No. 60/523,865, filed on Nov. 19, 2003, both of which are also incorporated herein by reference.
This application is also related to: U.S. patent application Ser. No. 11/537,305, titled “SYSTEMS AND METHODS FOR FAULT-TOLERANT HIGH INTEGRITY DATA PROPAGATION USING A HALF-DUPLEX BRAIDED RING NETWORK”, filed on Sep. 29, 2006 (which is also referred to here as the “'305 application” and which is hereby incorporated herein by reference).
Some communication systems are used in applications where a high degree of integrity is desired (also referred to here as “high-integrity applications”). Often, nodes included in such a system include functionality to prevent, detect, and/or correct faults that occur at that node. Examples of such functionality (also referred to here as “covering functions”) include watch-dogs, bus guardians, and protection monitoring systems (for example, to provide over-speed or over-temperature protection). It is typically desirable, given the criticality of such functionality, to periodically test such functionality while such a node is deployed, (for example, in order to detect latent “stuck-at-good” faults). Such testing is also referred to here as “in-field testing” or “fault detection, isolation, and recovery (FDIR) scrubbing.” One type of in-field testing is performed by software executing on a node. Though such in-field testing software is adequate to test functionality that is local to a given node (for example, watch-dogs), such software is typically not sufficient to stimulate functionality that is not local to the node (for example, functionality that is externally influenced, such as bus guardians or communication protocols).
Also, where a node includes “offline” functionality or modes that can be activated while the node is deployed (for example, a test mode or a software or data download mode) and activation of such offline functionality or modes stops or otherwise impairs the normal operation of the node, it is typically desirable to avoid inadvertently activating such offline functionality or modes. This is especially true where such a node is used in a safety-critical application.
In one embodiment, a node comprises an interface to communicatively couple the node to a plurality of independent communication links. The node changes the mode in which the node operates when the node receives an indicator on a plurality of the independent communication links.
In another embodiment, a method is performed at a node. The method comprises determining if the node has received an indicator on a plurality of independent communication links to which the node is communicatively coupled and changing the mode in which the node operates when the node receives the indicator on the plurality of independent communication links.
In another embodiment, a network comprises a plurality of nodes that are communicatively coupled to one another over first and second channels. The first channel communicatively couples each node to: a respective first direct link that is communicatively coupled to a respective first neighbor node of that node in a first direction, a respective first skip link that is communicatively coupled to a respective first neighbor's neighbor node of that node in the first direction; a respective second direct link that is communicatively coupled to a respective second neighbor node of that node in a second direction, and a respective second skip link that is communicatively coupled to a respective second neighbor's neighbor node of that node in the second direction. The second channel communicatively couples each node to: a respective third direct link that is communicatively coupled to the respective first neighbor node of that node in the first direction, a respective third skip link that is communicatively coupled to the respective first neighbor's neighbor node of that node in the first direction, a fourth direct link that is communicatively coupled to the second respective neighbor node of that node in the second direction, and a fourth skip link that is communicatively coupled to the respective second neighbor's neighbor node of that node in the second direction. Each node further comprises: a first pass-through link that communicatively couples the respective first direct link of that node to the respective second skip link of that node and a second pass-through link that communicatively couples the respective third direct link of that node to the respective fourth skip link of that node. For each node, a respective first cable couples that node to the respective first neighbor node of that node and comprises the respective first direct link, the respective first skip link, the respective third direct link, and the respective third skip link and a respective second cable couples that node to the respective second neighbor node of that node and comprises the respective second direct link, the respective second skip link, the respective fourth direct link, and the respective fourth skip link.
The details of various embodiments of the claimed invention are set forth in the accompanying drawings and the description below. Other features and advantages will become apparent from the description, the drawings, and the claims.
Like reference numbers and designations in the various drawings indicate like elements.
In the particular embodiment shown in
Embodiments of network 100 typically support at least two modes of operation. One mode of operation is a “normal” mode of operation in which data is communicated over the network 100 using a particular media access scheme. For example, the embodiment shown in
The other modes of operation can include, for example, “offline” modes of operation in which all of the nodes 102 in the network 100 do not perform the normal-mode processing they would otherwise perform and instead operate in a special mode. Examples of offline modes include an offline test mode (in which one or more test operations are performed) and/or an offline software or data download mode (in which one or more items of software or data is downloaded to one or more nodes 102 of the network 100).
Other, non-normal modes of operation also include “online” modes of operation in which all of the nodes 102 in the network 100 perform special processing in addition to the normal mode processing they otherwise would perform while operating in their respective normal mode of operation. Data related to the special processing is communicated on the network 100 along with any normal-mode data. Examples of how this would be accomplished include storing such special data in the header and/or payload of the normal-mode data (for example, using an embedded management or operations channel, field, register, or flag included in each normal-mode frame or message), and/or by otherwise dedicating a portion of the available communication capacity to such special data using, for example, dedicated time slots, channels, frequencies, portions of the available code space, etc.). One example of such an online special mode is a background debug mode in which a host processor included in the relevant node can be caused to show or set the state of various registers or memory coupled to the processor and/or modify or control the operation of the processor, for example, by setting breakpoints, watchpoints, and catchpoints that halt operation of the processor and/or by permitting the processor to be “single stepped.”
Also, in some embodiments, the nodes 102 in the network 100 are not all operating in the same mode. For example, in one usage scenario, some of the nodes 102 are operating in normal mode while some of the other nodes 102 are operating in a different mode (for example, an online special mode such as a background debug mode or an offline mode in which the offline node relays any data that is not intended for that node). In one example of such a usage scenario, the nodes operating in normal mode communicate using a TDMA scheme in the normal manner while the nodes operating in a different node communicate either during one or more time slots dedicated to those nodes or during other portions of a TDMA round in which data is not normally communicated.
The eight nodes 102 shown in
In addition, as used herein, a “neighbor's neighbor node” (or just “neighbor's neighbor”) for a given node 102 is the neighbor node 102 of the neighbor node 102 of the given node 102. Each node 102 has two neighbor's neighbor nodes 102, one in the clockwise direction (also referred to here as the “clockwise neighbor's neighbor node” or “clockwise neighbor's neighbor”) and one in the counter-clockwise direction (also referred to here as the “counter-clockwise neighbor's neighbor node” or “counter-clockwise neighbor's neighbor”). For example, the two neighbor's neighbor nodes for node A are node G in the clockwise direction and node C in the counter-clockwise direction.
The two communication channels 106 are individually labeled in
As used here, when a link 108 is described as being connected “from” a first node 102 “to” a second node 102, the link 108 provides a communication path for the first node 102 to send data to the second node 102 over the link 108. That is, the direction of that unidirectional link 108 is from the first node 102 to the second node 102.
A link 108 is connected from each node 102 to that node's clockwise neighbor node 102. A link 108 is also connected from each node 102 to that node's clockwise neighbor's neighbor node 102. For example, a link 108 is connected from node A to node H and a link 108 is connected from node A to node G. These clockwise links 108 make up channel 0 and are shown in
A link 108 is connected from each node 102 to that node's counter-clockwise neighbor node 102. A link 108 is also connected from each node 102 to that node's counter-clockwise neighbor's neighbor node 102. For example, a link 108 is connected from node A to node B and a link 108 is connected from node A to node C. These counter-clockwise links 108 make up channel 1 and are shown in
The links 108 that connect a given node 102 to that node's respective clockwise and counter-clockwise neighbor nodes are also referred to here as “direct” links 108. The links 108 that connect a given node 102 to that node's respective clockwise and counter-clockwise neighbor's neighbors are referred to here as “skip” links 108.
In the particular embodiment shown in
Although the embodiment shown in
In the particular embodiment shown in
The '933 application and the '249 application describe various embodiments of processing that can be performed in the embodiment of network 100 shown in
In
The current node 102 comprises application functionality 203 that implements the application-specific functionality supported by the current node 102. In one implementation, the application functionality 203 comprises a programmable processor that executes application software (in addition to appropriate software to interact with the ring functionality 202). The current node 102 comprises a ring interface 201 that serves as the interface between the application functionality 203 and channels 0 and 1 of the network 100 (more specifically, the particular links 108 of those channels). The ring interface 201 comprises ring functionality 202 that performs the normal-mode ring-related processing described in the '933 application and the '249 application.
In the particular embodiment shown in
In such an embodiment, the current node 102 comprises a pass-through link 210 that couples the counter-clockwise direct link 108 of channel 0 to the clockwise skip link 108 of channel 0 and a pass-through link 212 that couples the clockwise direct link 108 of channel 1 to the counter-clockwise skip link 108 of channel 1. In this way, the current node's counter-clockwise neighbor is communicatively coupled to the current node's clockwise neighbor via channel 0 and the current node's clockwise neighbor is communicatively coupled to the current node's counter-clockwise neighbor via channel 1. In such an embodiment, the single-cable connection scheme is used with each such node 102 in the network 100 of
In such an embodiment, the ring interface 201 comprises interface logic 216 that selectively couples the various links 108 of the current node 102 to the ring functionality 202. Such selectively coupling can be implemented in various ways including for example the use of switches, relays, and the like. The logical connections established by the interface logic 216 while the current node 102 is operating in “normal mode” are shown in
When the current node 102 receives a predetermined indicator on a plurality of independent links (checked in block 302), the current node 102 changes the mode in which it operates in the manner associated with the received indicator (block 304). Otherwise, the current node 102 remains in its current operational mode (for example, in a normal mode). In one implementation of such an embodiment, the indicator must be received on each of the plurality of independent links within a given period of time in order for the node 102 to change the mode in which it operates. In such an implementation, if the indicator is received on one of the links but the indicator is not received on one or more of the other links during that time period, the node does not change its operational mode in the manner associated with that indicator. In one example, the period of time is defined as the current time slot. In another example, when the indicator is first received on a first link, the indicator must be received on the other links within a particular “timeout” period that is measured from the receipt of the indicator on the first link.
In some implementations of such an embodiment, the indicator must be received on a specific set of independent links before the node changes its operational mode. For example, in one such implementation that employs the network 100 of
In some implementations of such an embodiment, additional authentication or verification is performed before the mode of operation is changed. For example, in one such implementation, change-mode indicators, to be valid, must be sourced from a “self-checking pair.” As self-checking pair comprises a pair of nodes that are scheduled to act as self-checking pair as is described in the '249 application. In such an embodiment, each such self-checking pair is intended to operate in a replica-deterministic fashion at the application layer such that the output of both members of the self-checking pair is bit-for-bit identical. When a message is sourced from a self-checking pair, if a node 102 receives the same message on both its direct link 108 and skip link 108 of the same channel, the receiving node 102 knows that the message was sourced from the two member nodes of a self-checking pair because of the relay and/or guardian processing described in the '249 application. In the event that a receiving node 102 receives such a message on only one of its direct link 108 and skip link 108 for channel 0 and only one of its direct link 108 and skip link 108 for channel 1, the receiving node 102 cannot assume that the message was sourced from a self-checking pair without performing an additional authentication or verification check.
One example of such an authentication or verification check makes use of a “hop count” field that is included in each message. The hop count field is set to zero by the node 102 that originates each message. Then, each node 102 that receives and relays the message updates the hop count. Each such node 102 increments the hop count field by one if that node 102 received the same message on both a direct and skip link of the relevant channel, resets the hop count field to one if the message is received by that node 102 on only its direct link for the relevant channel, and resets the hop count field to two if the message is received by that node 102 on only its skip link for the relevant channel.
The hop count field is used to determine by a receiving node 102 that receives a message on only one of its direct link 108 and skip link 108 for channel 0 and only one of its direct link 108 and skip link 108 for channel 1. The receive node 102 adds the value contained in the hop count field in both messages together. If this sum is not equal to N−1 (where N equals the number of nodes in the braided-ring network), the message was not transmitted by a self-checking pair and the receiving node 102 does not change its operational mode based on the received message if it contains an appropriate change-mode indicator. If the sum is equal to N−1, the receiving node 102 considers the messages to be valid and the receiving node 102 does changes its operational mode based on the received message if it contains an appropriate change-mode indicator.
In other embodiments, other techniques are used to determine if a given message is sourced from a single node or a self-checking pair (for example, “identifier stamping” each such message with an identifier associated with the source of the message).
In one implementation of the embodiment shown in
In one implementation of the embodiment shown in
The embodiment of method 300 shown in
In one embodiment, the indicator comprises one or more predefined, special-purpose units of data (for example, one or more “enter mode” messages or flags) that indicate to the current node 102 that it should change its operational mode. In another embodiment, the indicator is a pattern or other data-related condition.
In the particular embodiment shown in
In one exemplary implementation of the embodiment shown in
There are many ways in which test commands and test stimulus can be applied to a node under test and test responses can be transmitted by the node under test. In the following description, several exemplary approaches are described. However, it is to be understood that other approaches are used in other embodiments and the following description should not be construed in a limiting sense.
One testing scenario is illustrated in
In this testing scenario, the nodes 102 of the network 100 initially operate in a normal operational mode. As illustrated in
Then, in this testing scenario (as illustrated in
Then, in this testing scenario (as illustrated in
Such processing can proceed around the rest of the ring in order to test nodes F, E, D, C, and B in the same manner as described above in connection with
While the interface logic 216 of the current node 102 is in the bypass configuration, any data received on the counter-clockwise direct link 108 of channel 0 is communicated on both the clockwise direct link 108 of channel 0 to the current node's clockwise neighbor and the clockwise skip link 108 of channel 0 to the current node's clockwise neighbor's neighbor and any data received on the clockwise direct link 108 of channel 1 is communicated on both the counter-clockwise direct link 108 of channel 1 to the current node's counter-clockwise neighbor and the counter-clockwise skip link 108 of channel 1 to the current node's counter-clockwise neighbor's neighbor. For example, as shown in
In the particular embodiment shown in
The test controller 250 serves as bridge between the JTAG TAP of the JTAG functionality 252 and 254 and the rings over which test command, stimulus, and response data are communicated. In one simple exemplary implementation of such an embodiment, the test commands and stimulus (collectively “test input data”) are communicated to the current node 102 in 4-bit packets of data on channel 0. The most significant bit of each packet indicates whether the particular bit is a simple JTAG packet or a high-level command packet. If the most significant bit indicates that a particular packet is a simple JTAG packet, then the three least significant bits comprise the TDI, TMS, and TCK bits for a given point in time and the test controller 250 applies these bits to the lines of the JTAG TAP for the JTAG functionality 252 or 254. If the most significant bit indicates that a particular packet is a high-level command packet, then the three least significant bits represent a particular high-level command. Examples of such commands include commands that cause the interface logic 216 of the current node 102 to be configured in the bypass configuration, that select whether to test the JTAG functionality 252 of the ring functionality 202 or the JTAG functionality 254 of the application functionality 203, that cause the current node 102 to enter a “background debug” mode or to carry out one or more debug commands. The test controller 250 also transmits the TDO output line of the JTAG TAP for the JTAG functionality 252 or 254 on channel 1.
In one implementation of such an embodiment, the JTAG functionality 252 or 254 is selected for testing by interacting with a special test control register included in the JTAG functionality 252 of the ring functionality 202. In such an implementation, the selection of which JTAG functionality 252 or 254 is selected as a part of the JTAG boundary scan. In another implementation, the JTAG functionality 252 or 254 is selected for testing using a high-level command of the type described above that is communicated to the test controller 250. In other implementations, such selection is carried out in different ways.
In such an implementation, when simple JTAG packets are received at the current node 102 from test equipment 400 (not shown in
In one implementation of such an embodiment, the behavior of each of the nodes 102 in the network 100 is characterized using a standard boundary-scan description (for example, using a boundary-scan description language (BSDL), hierarchical scan-description language (HSDL), or serial vector format (SVF)).
In one implementation, other JTAG features are used in test mode. Examples of such other JTAG features include running high-level test commands such as BIST and using the JTAG interface as a loading mechanism to load data and/or software onto the node 102 (for example, loading communication table data used by the ring functionality 202 or loading application software, boot-strap software, or test software used by the application functionality 203). In one testing scenario, such a loading mechanism is used to load software that performs one or more functional tests, which provides a way to perform software functional tests in addition to (or instead of) JTAG structural boundary-scan tests.
In the embodiment shown in
The other way in which debug commands and results are communicated to and from the processor 256 makes use of a debug port (for example, a NEXUS or background debug mode (BDM) port). The application functionality 203 comprises a debug master 258 for communicating with the processor 256 over the debug port. In one implementation of such an embodiment that makes of a NEXUS interface and a NEXUS master, NEXUS test input data is supplied to the current node 102 from test equipment 400 on channel 0 in a serial form in which successive frames of data containing a bit to be applied to each of the input lines of the NEXUS interface. The test controller 250 serves as a bridge between channel 0 and the debug master 258. When the current node 102 is operating in test mode (and is the interface logic 216 is not in the bypass configuration) and such NEXUS test-input data is received at the current node 102 from channel 0, the test controller 250 recognizes the received test input data as NEXUS test input data and extracts each of the bits associated with each of the input lines of the NEXUS interface and applies each such bit to a respective input line of the debug port of the debug master 258. In such an implementation, the test controller 250 periodically reads the output lines of the debug port and formats successive frames of data containing a bit for each of the output lines of the NEXUS debug port and communicates the frames on channel 1 back to the test equipment 400.
The debug functionality of the processor 256 can be tested using, for example, at least two approaches (though other approaches are possible). In one approach, the debug functionality of the processor 256 is used while the current node 102 is in an offline test mode in which only test-related messages are communicated on the network 100. Such messages are communicated as described above.
In another approach, the debug functionality of the processor 256 is used while the current node 102 is in an “online” test mode in which the current node 102 operates as if it where in “normal” mode except that the current node 102 performs various test-related actions while it otherwise is operating in normal mode and test-related messages are communicated over the network 100 among or as “normal” communication traffic. In such an embodiment, debug commands are sent to the current node 102 as or among normal messages. The test controller 250 identifies those messages containing debug commands and extracts the debug commands from the messages and forwards the debug commands to the processor 256 for performing the debug command (or the test controller 250 other causes the processor 256 to perform a debug operation associated with the extracted debug command). Any debug-related output data that the processor 256 produces is forwarded to the test controller 250 for communicating on the network 100 among or as normal messages. In one implementation of such an approach, the test controller 250 maintains debug-message buffer memory into which debug commands and debug output are passed between the test controller 250 and the debug master 258 (which serves as the interface to the processor 256). In one implementation of such an approach that is implemented in a network 100 that makes use of a TDMA access scheme, debug-related messages are communicated during one or more predetermined time slots that have been selected for communicating such messages. In another implementation of such an approach, the network 100 supports an asynchronous messaging capability in which a priority is assigned a priori to each node 102 in the network 100 and in which collisions are resolved using the priority assigned to each node.
Such an online debugging approach can also be used to debug multiple processors in the network 100. For example, such an approach can be used to set breakpoints on multiple processors within the network 100. Such an approach can also be used to observe detailed processor behavior (for example, to assist with WCET profiling of the entire network 100).
Also, such test and debugging functionality can be employed to remove dedicated processor boot load functionality from the nodes 102. Where this is the case, the ring functionality 202 (that is, the ring communication engine) starts autonomously since the ring functionality 202 is used to boot-strap the processor 256. That is, the processor 256 does not turn on the ring functionality 202; instead, the ring functionality 202 will immediately power itself up upon powering on the current node 102 and/or will respond to wake-up messages received from the network 100. Once powered on, the ring functionality 202 interacts with an external device that supplies the software load using the test/debug functionality of the current node 102 in order to boot-strap the processor 256.
The ring test adapter 606 further comprises conversion functionality 612 that “packetizes” the TDI, TMS, and TCK lines from the JTAG TAP that output by the JTAG test device 602. That is, the conversion functionality assembles simple JTAG packets of the type described above in connection with
In other embodiments, test equipment is communicatively coupled to the network 100 in other ways.
Although in the embodiments described above in connection with
The systems, devices, methods, and techniques described here may be implemented in networks having network topologies other than the particular braided-ring topology illustrated in
The methods and techniques described here may be implemented in digital electronic circuitry, or with a programmable processor (for example, a special-purpose processor or a general-purpose processor such as a computer) firmware, software, or in combinations of them. Apparatus embodying these techniques may include appropriate input and output devices, a programmable processor, and a storage medium tangibly embodying program instructions for execution by the programmable processor. A process embodying these techniques may be performed by a programmable processor executing a program of instructions to perform desired functions by operating on input data and generating appropriate output. The techniques may advantageously be implemented in one or more programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Generally, a processor will receive instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and DVD disks. Any of the foregoing may be supplemented by, or incorporated in, specially-designed application-specific integrated circuits (ASICs).
A number of embodiments of the invention defined by the following claims have been described. Nevertheless, it will be understood that various modifications to the described embodiments may be made without departing from the spirit and scope of the claimed invention. Accordingly, other embodiments are within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
4417334 | Gunderson et al. | Nov 1983 | A |
4428046 | Chari et al. | Jan 1984 | A |
4630254 | Tseng | Dec 1986 | A |
4631718 | Miyao | Dec 1986 | A |
4663748 | Karbowiak et al. | May 1987 | A |
4726018 | Bux et al. | Feb 1988 | A |
4733391 | Godbold et al. | Mar 1988 | A |
4740958 | Duxbury et al. | Apr 1988 | A |
4856023 | Singh | Aug 1989 | A |
4866606 | Kopetz | Sep 1989 | A |
4905230 | Madge et al. | Feb 1990 | A |
5132962 | Hobgood et al. | Jul 1992 | A |
5161153 | Westmore | Nov 1992 | A |
5235595 | O'Dowd | Aug 1993 | A |
5235599 | Nishimura et al. | Aug 1993 | A |
5257266 | Maki | Oct 1993 | A |
5307409 | Driscoll | Apr 1994 | A |
5341232 | Popp | Aug 1994 | A |
5383191 | Hobgood et al. | Jan 1995 | A |
5386424 | Driscoll et al. | Jan 1995 | A |
5394401 | Patrick et al. | Feb 1995 | A |
5463634 | Smith et al. | Oct 1995 | A |
5557778 | Vaillancourt | Sep 1996 | A |
5687356 | Basso et al. | Nov 1997 | A |
5715391 | Jackson et al. | Feb 1998 | A |
5742646 | Woolley et al. | Apr 1998 | A |
5896508 | Lee | Apr 1999 | A |
5903565 | Neuhaus et al. | May 1999 | A |
5920267 | Tattersall et al. | Jul 1999 | A |
5937414 | Souder et al. | Aug 1999 | A |
5940367 | Antonov | Aug 1999 | A |
6028837 | Miller | Feb 2000 | A |
6052753 | Doerenberg et al. | Apr 2000 | A |
6088141 | Merli et al. | Jul 2000 | A |
6172984 | Beyda et al. | Jan 2001 | B1 |
6175553 | Luk et al. | Jan 2001 | B1 |
6219528 | Wright et al. | Apr 2001 | B1 |
6226676 | Crump et al. | May 2001 | B1 |
6240140 | Lindbergh et al. | May 2001 | B1 |
6374078 | Williams et al. | Apr 2002 | B1 |
6381714 | Tomita et al. | Apr 2002 | B1 |
6414953 | Lamarche et al. | Jul 2002 | B1 |
6513092 | Gorshe | Jan 2003 | B1 |
6590863 | Nakajima et al. | Jul 2003 | B1 |
6594802 | Ricchetti et al. | Jul 2003 | B1 |
6618359 | Chen et al. | Sep 2003 | B1 |
6707913 | Harrison et al. | Mar 2004 | B1 |
6741559 | Smeulderse et al. | May 2004 | B1 |
6760768 | Holden et al. | Jul 2004 | B2 |
6765924 | Wu et al. | Jul 2004 | B1 |
6842617 | Williams et al. | Jan 2005 | B2 |
6925497 | Vetrivelkumaran et al. | Aug 2005 | B1 |
6956461 | Yoon et al. | Oct 2005 | B2 |
7035539 | Gumaste | Apr 2006 | B2 |
7050395 | Chow et al. | May 2006 | B1 |
7085560 | Petermann | Aug 2006 | B2 |
7088921 | Wood | Aug 2006 | B1 |
7269177 | Baker | Sep 2007 | B2 |
7304957 | Ngo et al. | Dec 2007 | B2 |
7349414 | Sandstrom | Mar 2008 | B2 |
7372859 | Hall et al. | May 2008 | B2 |
7457303 | Blumrich et al. | Nov 2008 | B2 |
7502334 | Hall et al. | Mar 2009 | B2 |
20020024535 | Ueno et al. | Feb 2002 | A1 |
20020027877 | Son et al. | Mar 2002 | A1 |
20020087763 | Wendorff | Jul 2002 | A1 |
20020118636 | Phelps et al. | Aug 2002 | A1 |
20030002435 | Miller | Jan 2003 | A1 |
20030035530 | Mansfield et al. | Feb 2003 | A1 |
20030067867 | Weis | Apr 2003 | A1 |
20030128984 | Oberg et al. | Jul 2003 | A1 |
20040073698 | Harter et al. | Apr 2004 | A1 |
20040128673 | Fuchs et al. | Jul 2004 | A1 |
20040223515 | Rygielski et al. | Nov 2004 | A1 |
20040258097 | Arnold et al. | Dec 2004 | A1 |
20050002332 | Oh | Jan 2005 | A1 |
20050129037 | Zumsteg et al. | Jun 2005 | A1 |
20050129038 | Hall et al. | Jun 2005 | A1 |
20050132105 | Hall et al. | Jun 2005 | A1 |
20050135277 | Hall et al. | Jun 2005 | A1 |
20050135278 | Hall et al. | Jun 2005 | A1 |
20050152377 | Hall et al. | Jul 2005 | A1 |
20050152379 | Hall et al. | Jul 2005 | A1 |
20050169296 | Katar et al. | Aug 2005 | A1 |
20050198280 | Hall et al. | Sep 2005 | A1 |
20060039301 | Tsuji et al. | Feb 2006 | A1 |
20060077981 | Rogers | Apr 2006 | A1 |
20060203851 | Eidson | Sep 2006 | A1 |
20070253327 | Saha et al. | Nov 2007 | A1 |
20080010705 | Quaid et al. | Jan 2008 | A1 |
20080080551 | Driscoll et al. | Apr 2008 | A1 |
20080144526 | Hall et al. | Jun 2008 | A1 |
20080144668 | Hall et al. | Jun 2008 | A1 |
20100003979 | Iwamura et al. | Jan 2010 | A1 |
Number | Date | Country |
---|---|---|
407582 | Apr 2001 | AT |
3238692 | Apr 1984 | DE |
19633744 | Feb 1998 | DE |
20220280 | Nov 2003 | DE |
0405706 | Feb 1990 | EP |
1280024 | Jan 2003 | EP |
1280312 | Jan 2003 | EP |
1365543 | Nov 2003 | EP |
1398710 | Mar 2004 | EP |
1469627 | Oct 2004 | EP |
2028062 | Feb 1980 | GB |
1581803 | Dec 1980 | GB |
2175775 | Dec 1986 | GB |
0064122 | Oct 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20090086653 A1 | Apr 2009 | US |