Knowledge is Power: Module-level Sensing for Runtime Optimisation by Davis, JJ et al.
Knowledge is Power: Module-level 
Sensing for Runtime Optimisation 
James J. Davis, Eddie Hung, Joshua M. Levine, 
Edward A. Stott, Peter Y. K. Cheung, George A. 
Constantinides, Imperial College London 
Contact: {james.davis06, e.hung, josh.levine05, 
ed.stott, p.cheung, g.constantinides}@imperial.ac.uk 
We propose the compile-time instrumentation of coexisting 
modules—IP blocks, accelerators, etc.—implemented in FPGAs. 
The efficient mapping of tasks to execution units can then be 
achieved, for power and/or timing performance, by tracking 
dynamic power consumption and/or timing slack online at 
module-level granularity. Our proposed instrumentation is 
transparent, thereby not affecting circuit functionality. Power 
and timing overheads have proven to be small and tend to be 
outweighed by the exposed runtime benefits. 
Dynamic power consumption can be inferred through the 
measurement of switching activity on indicative, frequently 
toggling nets. Online analysis is able to derive a live power 
breakdown by building and updating a model fed with per-module 
activity counts and system-wide power consumption. Such a 
model can be continuously refined and its use allows the tracking 
of unpredictable phenomena, including degradation. 
Online measurement of slack in critical (and near-critical) paths 
facilitates the safe erosion of static timing analysis-derived 
guardbands. This then enables the co-optimisation of power and 
timing performance under given external operating constraints, 
including those which change over time. Assuming functional 
compatibility, high-priority tasks would suit execution within 
modules with excess slack. This could be reduced via dynamic 
frequency scaling, thereby increasing throughput. 
Keywords: Power measurement; Timing slack measurement; 
Instrumentation; Optimisation; Runtime management; Online 
algorithms; Task mapping 
DOI: http://dx.doi.org/10.1145/2847263.2847316 
