Automatic BRAM Testing for Robust Dynamic Voltage Scaling for FPGAs

Ibrahim Ahmed,Shuze Zhao,James Meijers,Olivier Trescases,Vaughn Betz
DOI: https://doi.org/10.1109/fpl.2018.00020
2018-08-01
Abstract:Recently FPGA researchers have proposed different approaches to enable dynamic voltage scaling (DVS) for FPGAs. While the proposed approaches have shown that DVS is able to significantly reduce FPGA power consumption, most of these solutions were developed only for the soft fabric of the FPGA and hence cannot be deployed for applications that use the FPGA hard blocks such as block RAMs (BRAMs). In this work, we extend a previously proposed offline calibration-based DVS approach to enable DVS for FPGAs with BRAMs; we build testing circuitry to ensure that all used BRAM cells operate safely while scaling $V_{dd}$, and we develop testing procedures that are able to measure the delay of timing paths that start or end at BRAMs. We extend the CAD tool FRoC to automatically generate calibration designs with BRAM testers along with soft fabric testers to measure the actual $F_{max}$ of each application on any chip under different operating conditions; this information is stored in a calibration table that is then used when the application is running to scale $V_{dd}$ to the minimum value that guarantees safe operation at the desired speed. Using our proposed solution, we show that we can run a discrete Fourier transform core with 32% and 46% power reduction compared to the conventional fixed-voltage operation at the reported $F_{max}$ and at a lower clock frequency, respectively.
What problem does this paper attempt to address?