250 likes | 468 Views
DAOmap: A Depth-optimal Area Optimization Mapping Algorithm for FPGA Designs. Deming Chen and Jason Cong Computer Science Department University of California, Los Angeles. This work is partially supported by the California MICRO program and the NSF Grant CCR-0306682. Outline. Introduction
E N D
DAOmap: A Depth-optimal Area Optimization Mapping Algorithm for FPGA Designs Deming Chen and Jason Cong Computer Science Department University of California, Los Angeles This work is partially supported by the California MICRO program and the NSF Grant CCR-0306682
Outline • Introduction • Related Works • Definitions and Problem Formulation • Algorithm Description • Cut Enumeration • Delay and Area Propagation • Cost Function for a Cut • Global and Local Cost Adjustments • Iterative Cut Selection • Experimental Results • Conclusions and Future Work
Introduction • Field Programmable Gate Array (FPGA) has become increasingly popular • Fast to market • No or very low NRE (non-recurring expenses) • The LUT-based FPGA architecture dominates the existing programmable chip industry • FPGA technology mapping converts a given Boolean circuit into a functionally equivalent network comprised only of LUTs • FPGA technology mapping is a crucial optimization step in the FPGA design flow
Related Works on FPGA Mapping • Area Minimization • Chortle-crf, [Francis, et al, DAC’91] • MIS-pga, [Murgai, et al, ICCAD’91] • Praetor, [Cong, et al, FPGA’99] • Anti-fuse FPGA Mapper, [Kang, et al, ASPDAC’04] • Delay Minimization • DAG-Map, [Chen, et al, DTC’92] • FlowMap, [Cong, et al, ICCAD’92] • Edge-map, [Yang, et al, ICCAD’94] • Power Minimization • PowerMinMap, [Li, et al, ASPDAC’03] • Emap, [Lamoureux, et al, ICCAD’03] • DVmap, [Chen, et al, FPGA’04] • Simultaneous Delay and Area Minimization • FlowMap-r, [Cong, et al, TVLSI’94] • CutMap, [Cong, et al, FPGA’95] • BoolMap-D, [Legl, et al, DAC’96]
Fv 3-feasible cone Cv Delay of 2 Definitions • DAG : a Boolean network • Cone Cv : a sub-network rooted on a node v • K-feasible cone : |input(Cv)| K • Fanin ConeFv : the largest Cv • K-feasible cut : • A K-feasible Cv • Occupies a K-LUT • Unit delay model : • One LUT contributes one unit delay • No edge delay PIs a c b d e v
Problem Formulation • Delay-optimal Area Optimization problem • Given: a Boolean network; an integer K • Goal: cover the network with K-feasible cones (K-LUTs), such that • Optimal mapping depth • Area (number of LUTs) is minimized • NP-hard problem on area minimization
Highlights of Our Algorithm • Consider potential node duplications and make mapping-area estimation close to reality • Search solution space considering both global and local optimality information • Carry out an iterative cut selection procedure on top of cost adjustment to further improve solution quality • Each technique used is simple and intuitive • The key is the right combination of them
w z x y c a b Subcut d Subcut Another Subcut New cut Cut Enumeration w z x y c a b d Combine sub-cuts on the inputs of the gate Process each gate in topological order from PIs to POs
Complexity Analysis • Number of cuts on a node for the worst case is O(nK) • Practically, it is a small constant for small K Average over 20 largest MCNC benchmarks
Delay 1, Area 1 Delay 2, Area 2 Delay 1, Area 1 Delay 1, Area 1 Delay 2, Area 3 Delay 2, Area 3 Delay 2, Area 2 Delay 2, Area 2 Delay and Area Propagation w z x y b Delay = 1 Area = 1 Delay = 1 Area = 1 a c Delay = 1 Area = 1 d e g f Delay = 2 Area = 2 Propagation process visits cuts and nodes iteratively The longest best delay on the POs is the optimal mapping delay
As / 2 Area Estimation Ap • AC = [Ai / f(i)] + UC i = input(C) • Ai : estimated area of the fanin cone on signal i • f(i) : fanout number of i • Uc : area of the cut itself • Try to estimate area considering fanout effect • Praetor, [Cong, et al, FPGA’99] • Can under-estimate the area because of node duplications p m n o f(p) = 2 q r Cut C s u t Cut Ct Cut Cu
C3 fanin1 fanin2 Cost (Area) Function of a Cut Some Key parameters • IC: cutsize of C • NC: number of nodes covered by C • f(v): fanout number of the root node v • Pf: duplication cost a C1 c b C2 d e v
Duplication Cost Adjustment • Consider potential node duplications • Check the sub-cuts for multiple fanouts • Propagate adjusted cost globally • Duplication Cost: • NCf : number of nodes the subcut Cf contains • IC : cutsize of C p m n o q r Subcut Cf2 NCf2 = 1 Subcut Cf1 s New cut C IC = 4 Multiple fanouts
Non-critical LUT Critical LUT Cut Selection – Mapping Generation • From POs to PIs • Critical paths optimal delay + best area available • Non-critical paths relaxed delay + better area w z x y b a c d e g f
Techniques for Better Cut Selection • Cut selection equivalent to min-cover problem • Greedy approach will not work well • Use heuristics to guide the selection • Iterative Cut Selection Procedure • Local Cost Adjustment • Input Sharing • Slack Distribution • Cut Probing
Start Mapping Iteration i, i++ i < threshold Profiling data Adjust Cut Cost Exit if i = threshold Iterative Cut Selection (ICS) • Some valuable information on area is unknown until after mapping • mapped LUT root nodes • duplicated nodes • ICS carries out multiple mapping iterations
Duplicated node Become LUT roots Share inputs with existing LUTs Local Cost Adjustment – Input Sharing • Takes advantage of existing resources • Considers roots from previous iterations • The more a cut shares inputs with others, the better for the cut d e g f
Local Cost Adjustment – Slack Distribution • SlackC = Reqv – 1 – MAX (Arri) i input(C) • If SlackC < 0, C is not a timing_feasible cut • The larger the SlackC, the better for C in terms of slack distribution effect w z x y b Largest arrival time among inputs a c C d Reqd : Required time of the root
Local Cost Adjustment – Cut Probing • Probe the amount of area gain locally before making decisions about a cut • Reduce connections between LUTs • Reduce potential node duplications based on previous duplication profiling • Reconvergent paths handling Use Cfinal to guide cut selection
Experimental Results – Settings • DAOmap is implemented using C language within the UCLA RASP system • Compare LUT counts and runtime to CutMap [Cong et al, FPGA’95] • Use a 750 MHz SunBlade-1000 Solaris machine • Test on LUT input numbers from 4 to 6 • Benchmarks • 20 largest MCNC benchmarks • A set of large industrial benchmarks
Experimental Results of DAOmap over CutMap on MCNC Benchmarks After mapping After mapping + packing (daomap + mpack) vs. (“cutmap –x” + mpack)
Detailed Experimental Results on Industrial Benchmarks After mapping into 5-LUTs
Mapping Iteration Analysis 2.5% 2.0% 1.5% Improvement % 1.0% 0.5% 0.0% 1 2 3 4 5 6 Mapping Iterations • For single iteration only (the base case), use manual profiling [Chen et al, FPGA’04] • When the iteration number is more than 3, it is no longer helpful
Conclusions and Future Work • We presented a new mapping algorithm, DAOmap, to minimize FPGA delay and area • We built several cost-adjustment heuristics and used an iterative mapping procedure • DAOmap gained significant amount of area and runtime reduction over a state-of-the-art algorithm CutMap • Future works include adding cut-pruning techniques for mapping with larger K values