This application is related to commonly assigned and co-pending U.S. patent application Ser. No. 11/348,277, filed on Feb. 6, 2006 and entitled “FAULT TOLERANCE IN A DISTRIBUTED PROCESSING NETWORK” (the '277 Application) and U.S. patent application Ser. No. 11/348,290, filed on Feb. 6, 2006 and entitled “FAULT TOLERANT COMPUTING SYSTEM” (the '290 Application). The '277 and '290 Applications are incorporated herein by reference.
Present and future high-reliability (that is, space) missions require significant increases in on-board signal processing. Presently, generated data is not transmitted via downlink channels in a reasonable time. As users of the generated data demand faster access, increasingly more data reduction or feature extraction processing is performed directly on the high-reliability vehicle (for example, spacecraft) involved. Increasing processing power on the high-reliability vehicle provides an opportunity to narrow the bandwidth for the generated data and/or increase the number of independent user channels.
In signal processing applications, traditional instruction-based processor approaches are unable to compete with million-gate, field-programmable gate array (FPGA)-based processing architectures. Systems with multiple FPGA-based processors are required to meet computing needs for Space Based Radar (SBR), next-generation adaptive beam forming, and adaptive modulation space-based communication programs. As the name implies, an FPGA-based system is easily reconfigured to meet new requirements. FPGA-based reconfigurable processing architectures are also re-useable and able to support multiple space-based communication programs with relatively simple changes to their unique data interfaces.
Existing commercial-off-the-shelf (COTS), synchronous read-only memory (SRAM)-based processing elements are sensitive to radiation-induced upsets. Consequently, traditional COTS-based reconfigurable systems are unreliable in high-radiation environments. Furthermore, existing diagnostic approaches for detecting and mitigating susceptibilities to one or more single event upsets (SEUs), single event functional interrupts (SEFIs) and single event transients (SETs) have several disadvantages, particularly with respect to partial reconfiguration. Partial reconfiguration involves replacing (restoring) dynamic memory register contents with new (existing) processing configurations while leaving static memory register contents intact. Current methods of partial reconfiguration remove radiation effects in dynamic memory portions of the processing system while (potentially) leaving static memory portions with accumulated radiation over a significant time period.
The following specification addresses an alternating fault tolerant reconfigurable computing architecture for electronic systems. Particularly, in one embodiment, a method for reducing radiation effects in an electronic circuit is provided. The method involves periodically transferring operation of the electronic circuit to at least one alternate processing element of a plurality of processing elements. With the at least one alternate processing element in control, the method reconfigures one or more processing elements of the plurality of processing elements. Once the one or more processing elements are reconfigured, the method synchronizes the one or more processing elements with the at least one alternate processing element.
These and other features, aspects, and advantages will be better understood with regard to the following description, appended claims, and accompanying drawings where:
In operation, a plurality of reconfigurable processing elements in each of the signal processing nodes 1141 to 114N periodically alternate between reconfiguration and signal processing to maintain operational time continuity of the signal processing unit 102. The periodic alternating reconfiguration substantially eliminates radiation effects on the signal processing unit 102, as discussed in further detail below with respect to
The signal processing nodes 1141 to 114N comprise symmetrical reconfigurable processing elements (that is, reconfigurable processing elements with comparable capabilities and features) that enhance mitigation efforts in the reduction of radiation effects on the signal processing unit 102. The signal processing nodes 1141 to 114N reconfigure each of the symmetrical reconfigurable processing elements (described in further detail below with respect to
The signal processing node 200 further comprises local memories 2051 to 205M coupled to the processing element 204, and local memories 2071 to 207M coupled to the processing element 206. In the example embodiment of
The sensor interface processor 202 processes sensor payload data from the one or more sensors 108 of
The signal processing node 200 further comprises alternate data buffers 210 and 212, each of the alternate data buffers 210 and 212 responsive to a data path control block 216. During reconfiguration of the processing element B, the alternate data buffer 210 (shown as alternate data buffer PEB) stores a current processing element state of the processing element B. Similarly, during reconfiguration of the processing element A, the alternate data buffer 212 (shown as alternate data buffer PEA) stores a current processing element state of the processing element A. The data path control block 216 transfers the current processing element state from the local memory devices 2051 to 205M (2071 to 207M) to the alternate data buffer 212 (210). The alternate data buffers 210 and 212 comprise, without limitation, at least one of QDR SRAM devices and DDR SDRAM devices. In the example embodiment of
In operation, the sensor interface processor 202 periodically alternates processing between the processing elements A and B. For example, the configuration manager 214 reconfigures processing element A while processing element B continues to function. The memory controller 218 reconfigures one or more sets of processing logic from the configuration memory 208 between the processing elements A and B based on a programmable reconfiguration rate determined by the programmable timer 215. The data path control block 216 synchronizes operation of the processing elements A and B between alternating processing operations to substantially reduce radiation susceptibilities in the signal processing system of
In the example embodiment of
At block 302, the configuration manager 214 evaluates the programmable reconfiguration rate in the programmable timer 215. If block 304 determines that the programmable reconfiguration rate has not been modified (alternatively, the reconfiguration rate is a fixed rate), the reconfiguration rate timer is started at block 306. If the programmable reconfiguration rate has been modified, the configuration manager 214 is updated at block 305. Once the reconfiguration rate timer expires (based on the programmable reconfiguration rate in the programmable timer 215) at block 308, the configuration manager 214 determines which of the processing elements of the signal processing node 200 to reconfigure at block 310. For example, if the processing element 204 was last reconfigured, the processing element 206 will be reconfigured. The data path control block 216 stores the current state of the processing element 206 in the alternate data buffer 210 at block 312. At block 314, the configuration manager 214 transfers operation of the signal processing node 200 to the processing element 204. At block 316, the configuration manager 214 reconfigures the processing element 206 with the latest program logic as indicated by the memory controller 218. The memory controller 218 transfers the latest program logic as one or more program logic files from the configuration memory 208. Before reconfiguration of the processing element 206 is complete, block 318 determines if the processing element 206 is being reconfigured with identical program logic as a previous reconfiguration of the processing element 206. If the current program logic is not identical, the memory controller 218 prepares the next set of the latest program logic files in the configuration sequence of the signal processing node 200 at block 320. At block 322, the configuration manager 214 restores operation of the processing element 206 by returning the current state information of the processing element 206 from the alternate data buffer 210.
While the methods and techniques described here have been described in the context of a fully functioning fault tolerant signal processing unit (for example, the signal processing unit 102 of
This description has been presented for purposes of illustration, and is not intended to be exhaustive or limited to the form (or forms) disclosed. Variations and modifications may occur, which fall within the scope of the embodiments described above, as set forth in the following claims.
Number | Name | Date | Kind |
---|---|---|---|
4413327 | Sabo et al. | Nov 1983 | A |
4644498 | Bedard et al. | Feb 1987 | A |
5361373 | Gilson | Nov 1994 | A |
5502812 | Leyre et al. | Mar 1996 | A |
5655069 | Ogawara et al. | Aug 1997 | A |
6104211 | Alfke | Aug 2000 | A |
6178522 | Zhou et al. | Jan 2001 | B1 |
6219785 | Smith | Apr 2001 | B1 |
6856600 | Russell et al. | Feb 2005 | B1 |
6973608 | Abramovici et al. | Dec 2005 | B1 |
6996443 | Marshall et al. | Feb 2006 | B2 |
7036059 | Carmichael et al. | Apr 2006 | B1 |
7340596 | Crosland et al. | Mar 2008 | B1 |
7467326 | Hillman et al. | Dec 2008 | B2 |
7539914 | Sundararajan et al. | May 2009 | B1 |
20020016942 | MacLaren et al. | Feb 2002 | A1 |
20020116683 | Mitra et al. | Aug 2002 | A1 |
20030041290 | Peleska | Feb 2003 | A1 |
20030167307 | Filepp et al. | Sep 2003 | A1 |
20040078508 | Rivard | Apr 2004 | A1 |
20050027409 | Marshall et al. | Feb 2005 | A1 |
20050268061 | Vogt | Dec 2005 | A1 |
20050278567 | Wolfe et al. | Dec 2005 | A1 |
20060020852 | Bernick et al. | Jan 2006 | A1 |
20060020774 | Ramos et al. | Jun 2006 | A1 |
20060117164 | Coxe et al. | Jun 2006 | A1 |
Number | Date | Country |
---|---|---|
2006052397 | May 2006 | WO |
Number | Date | Country | |
---|---|---|---|
20080120500 A1 | May 2008 | US |