Method for generating redundant configuration in FPGAs
11106849 · 2021-08-31
Assignee
Inventors
Cpc classification
G01R31/31816
PHYSICS
International classification
Abstract
A method for generating redundant configuration in FPGA devices includes: analysing the configuration pertaining to a given design to be configured, or already configured, in the FPGA device, in order to identify programmed and empty configuration memory portions, configuring the FPGA device for implementing said design, measuring the power consumption of the configured FPGA device, copying the configuration from at least some subsets of the programmed portion to subsets of the empty portion, (a) verifying the configuration read back from said subsets of the empty portion with the configuration data read from said subsets of the programmed portion, (b) verifying whether the functionality of the design after the copy is still correct, (c) measuring the power consumption of the FPGA device, and verifying whether the power consumption of the FPGA device after the copy is acceptable according to pre-defined criteria, if the verification steps (a), (b) and (c) are all successful the redundant configuration is correctly generated, and if the verification steps (a), (b) and (c) are not all successful the method restarts from the beginning choosing other subsets of the empty portion of the FPGA device for hosting the configuration data from said subsets of the programmed portion.
Claims
1. A method for generating a redundant configuration in an FPGA device, the FPGA device being connected to a power supply that provides required supply voltages for proper operation of the FPGA device, the FPGA device comprising a design and a Configuration Access Port (CAP), the method being operated by a replication controller, the method comprising the steps of: identifying sets of programmed and empty configuration memory frames of the FPGA device pertaining to the design, configuring the FPGA device with configuration data for implementing a functionality of the design, measuring a first power consumption of the configured FPGA device, writing a copy of the configuration data from at least some subsets of the set of programmed frames into at least some subsets of the set of empty frames, (a) verifying whether the copy is correct by comparing the configuration data read back from the at least some subsets of the set of empty frames against the configuration data read from the at least some subsets of the set of programmed frames, (b) running a functional test on the design in order to verify if the functionality of the FPGA device is still correct after the step of writing the copy, (c) measuring a second power consumption of the FPGA device after the step of writing the copy, and verifying whether a variation between the first power consumption and the second power consumption of the FPGA device complies with predefined criteria, and restarting the method from the beginning choosing other subsets of the set of empty frames of the configuration memory of the FPGA device for hosting the configuration data from the at least some subsets of the set of programmed frames if any of the following conditions is met: the copy, verified at step a), is not correct; or, the functionality of the design, verified at step b), is not correct; or, the variation of the power consumption, verified at step c), does not comply with the predefined criteria.
2. The method according to claim 1, further comprising analyzing the configuration data pertaining to the design to identify each sequence of frames at least in a subset of the set of programed frames, wherein for each frame of each identified sequence of the set of programmed frames, the replication controller, by means of signals, accesses the Configuration Access Port (CAP) to copy the configuration data from a source frame address (SRC) to a destination frame address (DST).
3. The method according to claim 2, wherein the step of identifying comprises identifying each sequence of frames at least in a subset of the set of programmed frames, wherein for each frame of each identified sequence of the set of programmed frames, the replication controller, by means of signals, accesses the Configuration Access Port (CAP) to copy a subset of the frame configuration data from a source frame address (SRC) to a destination frame address (DST).
4. The method according to claim 2, wherein the step of identifying comprises identifying each sequence of frames at least in a subset of the set of programmed frames, wherein for each identified sequence of the set of programmed frames, the replication controller, by means of signals accesses the Configuration Access Port (CAP) to copy a part of the sequence consisting of a plurality of frames starting at a source frame address (SRC) to a homologous plurality of frames starting at a destination frame address (DST).
5. The method according to claim 2, comprising the steps of: after the step of writing the copy, reading back by means of the replication controller the configuration data from the Configuration Access Port (CAP), and comparing the configuration data with the configuration data read back by the replication controller, and verifying if the configuration data matches with the configuration data read back by the replication controller, in positive case the verification step (a) is successful, otherwise the verification step (a) is not successful.
6. The method according to claim 2, wherein the verification step (b) is performed by comparing the actual output signals of the design with the expected ones, and verifying that the redundancy generation process has not corrupted the functionality of the design.
7. The method according to claim 2, wherein the verification step (b) is performed by means of a built-in self-test, a mechanism that permits to the design to check its own functionality and output a passed/failed signal to the replication controller.
8. The method according to claim 1, comprising the steps of: measuring the currents drawn by the FPGA device on its power domains, before the step of writing the copy (Ii(SRC)), and after the step of writing the copy (I′i(SRC)), where i=1, . . . ,N and N is the number of power domains of the FPGA device, evaluating the drawn current differences |Ii(SRC)-I′i(SRC)|, and comparing the drawn current differences to pre-defined threshold values (ΔIthi(SRC)) wherein, the verification step (c) is successful if
|Ii(SRC)-I′i(SRC)|<ΔIthi(SRC) (1) for i=1, . . . ,N.
9. The method according to claim 8, wherein said pre-defined threshold values (ΔIthi(SRC)) are computed for each frame at least in a subset of the set of programmed frames to be copied in the step of writing the copy as a function of a pertaining source frame address (SRC).
10. The method according to claim 9, comprising: taking into account time evolution of the currents at the power domains after the step of writing the copy as a function of the source frame address (Ii(f)) and the time evolution of the currents during the initial configuration as a function of the frame address (I0i(f)) of the design where f=0, . . . ,SRC varies over all the copied frame source addresses, considering the time evolution of the currents as vectors of a 12 sequence space, wherein, the verification step (c) is successful if
∥O(Ii(f),I0i(f))∥2<Ki (2) for i=1, . . . , N, where N is the number of power domains comprised in the considered FPGA, Ki are N real numbers, O is an operator of the 12.Math.12 space, the symbol .Math. denotes the tensor product, ∥O(Ii(f), I0i(f))∥ is the norm of the vector O(Ii(f), I0i(f)) in the 12.Math.12 space.
11. The method according to claim 1, wherein the method further comprises the steps of: setting a source frame address (SRC) equal to an address of a programmed frame to be copied and a destination frame address (DST) equal to the address of an empty frame, measuring an absorbed current on FPGA power domains before a next step of writing the copy of the configuration data Ii(SRC), where i=1, . . . , N, and N indicates the number of power domains comprised in the considered FPGA device, creating a backup copy of the configuration data at the destination address (DST) and then writing a copy of configuration data from the source address (SRC) to the destination address (DST), reading back the configuration data written in the previous step at the destination address (DST), comparing the configuration data read back at the previous step with the configuration data written at the step of writing the copy to verify whether the copy is correct, if the copy is correct, the absorbed currents at the FPGA power domains, are measured, otherwise the destination address (DST) is changed to another empty frame address, verifying whether the verification steps (b) and (c) are successful: in negative case the frame at the destination address (DST) is restored to its configuration backed up before the step of writing the copy, the destination address (DST) is changed to another empty frame address and the method returns to the measuring step, in positive case it is verified whether all the frames of the sequence have been processed, and in positive case the method goes to the next frame sequence, and in negative case the method goes back to processing the next frame in the sequence of frames.
12. The method according to claim 1, wherein a generation of redundant configuration data can be performed during an operation of the design in order to dynamically change a number of redundant copies of each identified sequence of the subsets of the set of programmed frames.
13. A system comprising: an FPGA device connected to a power supply that provides required supply voltages for proper operation of the FPGA device, wherein the FPGA device comprises: a replication controller, a design, a Configuration Access Port (CAP), and a sub-system for measuring a current for each FPGA power domain, wherein the replication controller is configured for executing the method according to claim 1.
Description
BRIEF DESCRIPTION OF DRAWING
(1) The characteristics and other advantages of the present invention will become apparent from the description of an embodiment illustrated in the appended drawings, provided purely by way of no limiting example, in which:
(2)
(3)
(4)
(5)
(6)
(7)
(8)
DETAILED DESCRIPTION OF THE INVENTIONS
(9) In this description, any reference to “an embodiment” will indicate that a particular configuration, structure or feature described in regard to the implementation of the invention is comprised in at least one embodiment. Therefore, the phrase “in an embodiment” and other similar phrases, which may be present in different parts of this description, will not necessarily be all related to the same embodiment. Furthermore, any particular configuration, structure or feature may be combined in one or more embodiments in any way deemed appropriate.
(10) The references below are therefore used only for the sake of simplicity, and do not limit the protection scope or extension of the various embodiments.
(11) All user-programmable features of FPGA devices are controlled by memory cells, which must be configured according to the design to be implemented.
(12) These memory cells are collectively known as configuration memory, as disclosed in “7-Series FPGAs Configuration User Guide”, Xilinx Inc., San Jose, Calif. 2016 https://www.xilinx.com/support/documentation/user_guides/ug470_7Series_Config.pdf.
(13) The configuration memory cells define, for example, logic equations for CLBs, signal routing for PIPs, input/output voltage standards for IOBs, and all other aspects of the design. The device configuration memory is logically partitioned in the so-called “frames”, which are arranged vertically. The frame is the smallest accessible configuration fragment and in recent devices can include a few thousands of bits as shown in Table 1.
(14) TABLE-US-00001 TABLE 1 Frame sizes in recent Xilinx ® FPGA families. Family Virtex-5 Virtex-6 7-Series Ultra-scale Ultra-scale+ Size (bits) 1312 2592 3232 3936 2976
(15) From a configuration perspective, the FPGA structure can be divided into rows and columns (see
(16)
(17) In particular, reference number 1 refers to a IOB column, reference number 2 refers to a IO Interconnect column, reference numbers 3 to 8 refer to CLB columns, reference number 9 refers to BRAM column and reference number 10 refers to BRAM Interconnect column.
(18) Each column requires one or more frames to be configured. Unused columns correspond to configuration frames set to a default, predictable value.
(19) It is important to note that the configuration memory is pretty different from standard memories, which are used only to store information. In fact, since each configuration bit controls a physical resource, any change may have an impact on the device behaviour, both logically and electrically. An important consequence of this peculiarity is that it is not possible to store any data in any frame, as it might lead to an incorrect operation of the device.
(20) A typical design flow for FPGAs ends with the generation of a configuration file, the bitstream, to be loaded onto the device in order to implement the design functionality. In order to analyse the configuration content of the design, it is possible to dump the frame content for each frame address from the bitstream file or, after programming the FPGA device, by reading back the configuration from it.
(21) This can be performed by means of a custom software program, referred to as the “analysis script”. The same analysis script can also group frames into sequences of empty frames, i.e., frames which are going to be loaded with their default data, and programmed frames, i.e., frames which are going to be loaded with data different from the default.
(22) For a given design, the script determines which frames are programmed and which are not, and it produces a list of programmed and empty sequences. In the following, it is described an example of a list of frame sequences generated by a configuration analysis script.
(23) # List of Programmed Frame Sequences
(24) # e.g. the following line describes a sequence of programmed frames
(25) # starting at address 0x0000001D ending at address 0x0000009D and
(26) # consisting of 43 frames (frame addresses do not grow linearly)
(27) PROGRAMMED 0x0000001D 0x0000009D 00000043
(28) # e.g. the following line describes a sequence of default value
(29) # frames starting at address 0x00000100 ending at address 0x00000C9A
(30) # and consisting of 817 frames
(31) # (frame addresses do not grow linearly)
(32) EMPTY 0x00000100 0x00000C9A 00000817
(33) PROGRAMMED 0x00000C9B 0x00000D23 00000039
(34) EMPTY 0x00000D80 0x00000C9A 00000344
(35) PROGRAMMED 0x00001280 0x0000129F 00000032
(36) EMPTY 0x00020000 0x00C201FE 00006126
(37) Modern FPGAs enable read and write access to configuration frames by means of the so-called Configuration Access Ports referred to as CAPs. In fact, it is possible to write software or hardware controllers, which permit to access individual frames via the CAP of the FPGA.
(38) It is possible to configure the FPGA with the bitstream pertaining to the design and then use the above-mentioned controller to readback the configuration from the device and/or to generate redundant copies of programmed frames into empty frames.
(39) However, care must be taken in this operation as the content of the configuration memory has a physical impact on the device and not any frame is compatible to host the content from any other frame.
(40) Moreover, the type of each frame is normally unknown to the designer since FPGA vendors do not disclose such implementation details. In any case, copying configuration from a frame, or set of frames, to another frame, or set of frames, may lead to misbehaviours of the circuit or to an unintended increase of the power consumption related to driver contentions on the programmable interconnect.
(41) The solution described in this document consists of a method for the generation of redundant configuration which is completely independent of such details of the underlying hardware. The solution is based on a dedicated controller connected to an FPGA and a number of ammeters, one per each FPGA power domain (let N be the number of power domains) and a power supply.
(42)
(43) Each ammeter is a device for measuring the electric current through a wire or a circuit element, and it measures the correspondent currents I.sub.1, I.sub.2, I.sub.3, I.sub.4 associated to each power domain.
(44) The power supply 40 is a device providing the required supply voltages for proper operation of the FPGA, V.sub.1, V.sub.2, V.sub.3, V.sub.4. The number of power domains and the required supply voltage at each domain depend on the specific FPGA device and they are normally specified in its datasheet.
(45) The replication controller 20 exchanges functional input/output signals 50 with the design 32 configured in the FPGA and configuration input/output signals 52 with the Configuration Access Port (CAP) 34 of the device.
(46) All the current measurements I.sub.1, I.sub.2, I.sub.3, I.sub.4 are fed back to the dedicated controller 20 by means of signals 54.
(47) For each frame of each sequence of frames identified by the analysis script, the controller 20, by means of the signals 52 accesses the CAP 34 to copy the configuration from a source frame address SRC to a destination frame address DST.
(48) Moreover, after the copy, the controller 20 reads back the configuration data from the CAP 34 by means of the signals 52 and compares them with the data it attempted to write.
(49) If there is a match the copy is successful, otherwise the copy is failed. It might fail, for instance, if the destination frames configure different resources with respect to the source frames.
(50)
(51)
(52) For instance, attempting to copy the configuration from a CLB column frame to a IO Interconnect column frame might be unsuccessful, as the configuration cells are connected to different hardware resources and their state might be different when read back.
(53) For example, a certain bit could be read only at the ‘1’ state, attempting to write a ‘0’ in it might be ineffective. When read back, the bit would still result as a ‘1’.
(54) When the copy is successful, the controller 20 performs a power consumption test by measuring the current values I.sub.1, I.sub.2, I.sub.3, I.sub.4 drawn by the FPGA on its power domains, measured before (I.sub.i(SRC), with i=1, . . . , 4) and after the copy (I′.sub.i(SRC), with i=1, . . . , 4).
(55) A simple method is to evaluate the drawn current differences and compare them to pre-defined threshold values (ΔI.sup.th.sub.i, for i=1, . . . , 4), which can be computed as a function of SRC, i.e., ΔI.sup.th.sub.i=ΔI.sup.th.sub.i(SRC).
If |I.sub.i−I′.sub.i|<ΔI.sup.th.sub.i(SRC) for i=1, . . . ,4, (1) the power consumption variation is considered normal, otherwise an internal fault, such as a short circuit, is assumed.
(56) The threshold values can be determined by analysing the power consumption of the device during the initial configuration of the source frame sequence to be copied.
(57) The threshold values are in general a function of the time evolution of the current versus the frame address, I.sup.0.sub.i=I.sup.0.sub.i(f) for i=1, . . . , n, where f varies over the frame addresses of the configured sequence (f=0, . . . , SRC).
(58) For example, it is possible to choose the threshold values as:
ΔI.sub.i.sup.th(SRC)=α|I.sub.i.sup.0(SRC+1)−I.sup.0.sub.i(SRC)|,
(59) where α is a coefficient suitably chosen by the designer.
(60)
(61) Other more complex methods can be envisaged in order to evaluate whether the power consumption is correct.
(62) For instance, by taking into account the time evolution of the currents as a function of the source frame address at the power domains during the redundancy generation process I.sub.i(f) and the time evolution of the currents I.sup.0.sub.i(f) as a function of the frame address during the initial configuration, and considering them as vectors of the sequence space, it is possible to state that the power consumption test is successful if
∥O(I.sub.i(f),I.sub.i.sup.0(f)∥.sup.2<K.sub.i (2)
(63) for i=1, . . . , N,
(64) where N is the number of power domains, K.sub.i are N real numbers, O is an operator of the .Math.
space, where the symbol .Math. denotes the tensor product, ∥O(I.sub.i(f), I.sup.0.sub.i(f))∥ is the norm of the vector O(I.sub.i(f), I.sup.0.sub.i(f)) in the
.Math.
space.
(65) The controller 20 also runs a functional test on the design 32 in order to verify if its behaviour is still correct after the copy.
(66) The functional test is performed by comparing the actual output signals 50 of the design 32 with the expected ones, i.e., the correct ones. In other words, the functional test verifies that the redundancy generation process has not corrupted the functionality of 32. This may happen if the new configuration written into the redundant frames interacts with the functionality of the design.
(67)
(68)
(69)
(70)
(71)
(72) In some embodiments, the controller 20 may implement the same functionality of the design 32 and it may provide the correct outputs to be compared against the FPGA outputs 50.
(73) In some other embodiments, the functional test might also be a built-in self-test, i.e., a mechanism that permits the design 32 to check its own functionality and output a passed/failed signal, among signals 50, to the controller 20.
(74) If the copy fails, if the power consumption is not correct with respect to the predefined criteria, or if the functional test is unsuccessful, the controller 20 restarts by restoring the previous configuration of the destination frame, the controller 20 updates DST to a different value and the controller 20 retries the copy operation.
(75)
(76) At step 100, the procedure begins.
(77) At step 104, the source frame address SRC is set to the address of the frame to be copied and the destination frame address DST is set to the address of an empty frame.
(78) In the subsequent step 106, the procedure measures the absorbed current on the FPGA power domains before the copy of the configuration frame I.sub.i(SRC), i=1, . . . , N, wherein N indicates the number of power domains comprised in the considered FPGA.
(79) At step 108, the procedure creates a backup copy of the configuration data at the DST address and then copies the configuration data from the SRC address to the DST address.
(80) In the subsequent step 110, the procedure reads back the configuration data written at the DST address in the previous step.
(81) Then at step 112, the configuration data read back at step 110 is compared with the configuration data written at step 108 to verify whether the copy is correct.
(82) The implementation of this comparison depends on how the controller 20 is implemented.
(83) In the case the controller is implemented as a digital circuit, the comparison is probably implemented as a binary bit-to-bit comparator.
(84) In the case the controller 20 is implemented as a software program running on a microprocessor, the comparison is implemented as a function comparing two input variables containing the configuration data of the frames.
(85) It has to be considered that there is a huge number of possible implementations for this operation, and here two examples have been provided.
(86) In
(87) At step 114, the absorbed currents at the FPGA power domains, i.e., the values I′.sub.i(SRC), i=1, . . . , N, are measured.
(88) Then, at step 116 it is verified whether the “power consumption” test and the “functional” test are passed
(89) In positive case the procedure jumps to step 120 and in negative case the procedure goes to step 118.
(90) At step 118, the frame at address DST is restored to its configuration before the copy, the DST address is changed to another empty frame address, for instance to the next frame in the empty frame sequence, and the procedure returns to step 106.
(91) It is possible to choose the new DST address in different ways according to the design requirements. For instance, it is possible to choose the new address as the first which allows to find a contiguous number of empty frames for storing the remaining part of the frame sequence. Moreover, it is possible to avoid selected frame intervals in order to leave free frames for additional logic to be configured in the FPGA after the redundancy generation.
(92) At point 120, it is verified whether all the frames of the sequence have been processed, i.e., whether the last frame of the sequence has been reached.
(93) In the positive case the procedure goes to step 122, to process the next frame sequence, and in the negative case the procedure goes back to step 104.
(94) For each frame sequence, depending on whether or not it is critical for the design operation, a different number of redundant copies can be added, from a minimum of 0 (no redundancy) to a maximum value depending on the free resources in the device and on the required reliability level.
(95) Normally, the total number of replicas, including the original configuration, is an odd value to make it possible to majority vote the bits of the copied frames.
(96) It is important to highlight that copied configuration in general does not generate operating circuits.
(97) Only the original configuration pertains to an actual operating circuit, which receives the necessary inputs (e.g., data, clock, resets) and actually drives the outputs.
(98) In this case, the configuration redundancy generation does not increase the dynamic power consumption of the original design.
(99) It can however increase the quiescent power consumption due to the activation of additional resources in the device.
(100) At the end of the configuration redundancy generation, a list of redundant frame sequences and of frame sequences pertaining to empty FPGA configuration portions is produced by the analysis script.
(101) This information can be used by dedicated scrubbers in order to detect and correct configuration upsets by means of majority voting or comparison to the default value.
(102) It is important to remark that in other embodiments of this invention, the proposed flow diagram can be modified for copying subsets of each frame, for instance the bits in specific ranges (e.g., bits from 0 to 31, bits from 45 to 62, bit 66, bits from 1000 to 1005 and so forth). In this case, the frame read back at step 108 before the copy is used. The bits in the specified subsets are set at the value they have at the SRC address and the other bits are left unchanged. The so-modified frame is then written to the DST address. In this case, it is possible to use both empty and programmed frames as destination frames for storing the redundant configuration, provided that at least the bits to be overwritten are unused by the design 32.
(103) It is important to remark that in other embodiments of this invention, the same flow diagram of
(104) It is important to remark that in other embodiments of the invention, the controller 20 can be implemented in the same FPGA device, by properly configuring part of its programmable resources.
(105) Other embodiments might use the internal CAP offered by most of the modern devices.
(106) Further other embodiments, might exploit analog-to-digital converters (ADCs) embedded in the FPGA for monitoring external voltages (see for example
(107) When coupled to the external shunt resistors R.sub.1, R.sub.2, R.sub.3, R.sub.4, an internal ADC module can be profitably exploited to monitor the voltage drop on the resistors (ΔV.sub.1, ΔV.sub.2, ΔV.sub.3, ΔV.sub.4) through signals 58.
(108) Since the resistances of R.sub.1, R.sub.2, R.sub.3, R.sub.4 are known, the controller 20 can determine the currents drawn by the FPGA power domains I.sub.1, I.sub.2, I.sub.3, I.sub.4 by means of Ohm's law.
(109) It is important to remark that, in the disclosed solution, logic and configuration redundancies are completely decoupled.
(110) Techniques such as Triple Modular Redundancy (TMR) can be adopted for enhancing logic reliability in parallel to this approach, but they are not necessary for performing configuration scrubbing.
(111) Scrubbing techniques built upon TMR-based Frame-Level Redundancy (TFLR), such as the scientific publication J. Tonfat, F. L. Kastensmidt, P. Rech, R. Reis, and H. M. Quinn, “Analyzing the Effectiveness of a Frame-Level Redundancy Scrubbing Technique for SRAM-based FPGAs”, IEEE Trans. Nucl. Sci., vol. 62, no. 6, pp. 3080-3087, December 2015, offer benefits related to logic redundancy, but this TFLR solution requires to find three identical subsets of the FPGA device for hosting the same layout three times. Such a requirement might not be met by designs occupying a higher percentage of the device resources.
(112) Moreover, this TFLR solution introduce an additional power consumption due to the operation of the replicas.
(113) It has to be highlighted that the total current I.sub.t drawn by a configured FPGA can be split in two contributions:
(114) 1. the quiescent current related to the device itself and referred as I.sub.q, which does not depend on the used resources; and
(115) 2. the current related to the used logic resources referred as I.sub.r such that I.sub.t=I.sub.q+I.sub.r.
(116) Table 2 shows the average current drawn at the core power domain (power supply at 1.0V) by a Xilinx® 7K70T FPGA when configured with a benchmark design.
(117) The measured current at power up is I.sub.q, after configuration with the initial bitstream of the benchmark design is I.sub.c, and after replication of the frames, performed by means of the method disclosed in this description, is I.sub.f.
(118) The currents related to the resources configured by the initial bitstream and to the replicated design, are therefore I.sub.r(c,f)=I.sub.(c,f)−I.sub.q.
(119) The relative increment in power consumption for triplicating the design frames is
(120)
(121) TABLE-US-00002 TABLE 2 Average current drawn by a Xilinx ® 7K70T FPGA at the core power domain. I.sub.q (mA) I.sub.c (mA) I.sub.f (mA) I.sub.rc (mA) I.sub.rf (mA) 57 80 94 23 37
(122) For a TFLR approach, neglecting the voting logic and assuming each of the replicas exhibits the same power consumption of the others, the power would grow by
(123)
(124) Since the proposed technique does not require the redundant frames to be associated to operating logic, the power consumption penalty is significantly lower.
(125) The solution proposed in this document advances the prior art in multiple ways.
(126) It describes a novel redundancy generation technique aimed for scrubbing the configuration of FPGAs.
(127) It leads to a negligible additional power consumption with respect to the prior art. In fact, for selected benchmark designs the power consumption penalty related to the generation of redundant frames can be as low as 60%, while it can reach 200% for TFLR techniques.
(128) The described technique does not require to generate redundant layouts and therefore does not require to find identical subsets of the FPGA device for hosting them. The technique is therefore applicable to a greater deal of designs, with respect to the TFLR of the prior art.
(129) The proposed solution allows the designer to avoid the usage of third-party layout tools and to simplify the design flow, which is not possible with TFLR of the prior art.
(130) In the proposed approach configuration redundancy and modular redundancy are completely decoupled, therefore the power consumption associated to redundant modules is avoided.
(131) The proposed solution is applicable to multiple FPGA devices and families, including latest generation devices, provided they offer an interface for accessing the configuration.
(132) When coupled to dedicated scrubbers, this solution permits to correct single and multiple bit upsets and makes it possible to reduce the increment in power consumption related to the accumulation of configuration upsets.
(133) Moreover, this method is compatible by design with n-modular redundancy (also with n different from 3) and it could be extended for changing the number of redundant copies and the pertaining voting logic at run-time, if needed.
(134) The redundant configuration can be scrubbed during operation by voting the configuration frames as described in R. Giordano et al., “Redundant-Configuration Scrubbing of SRAM-based FPGAs”, IEEE Trans. Nucl. Sci. vol. 64, no. 9, September 2017. doi: 10.1109/TNS.2017.2730960.
(135) In fact, the cited document shows how to exploit configuration redundancy to correct single and multiple bit upsets and it makes it possible to reduce the increase in power consumption related to the accumulation of configuration upsets.
(136) The present description has tackled some of the possible variants, but it will be apparent to the man skilled in the art that other embodiments may also be implemented, wherein some elements may be replaced with other technically equivalent elements. The present invention is not therefore limited to the explanatory examples described herein, but may be subject to many modifications, improvements or replacements of equivalent parts and elements without departing from the basic inventive idea, as set out in the following claims.