190 likes | 403 Views
Functional Design Using Behavioural and Structural Components. Richard Sharp rws26@cl.cam.ac.uk University of Cambridge. aims of this research. SAFL is a Behavioural HDL Supports a functional programming style Designed for source-level program transformation
E N D
Functional Design Using Behavioural and Structural Components Richard Sharp rws26@cl.cam.ac.uk University of Cambridge
aims ofthis research • SAFL is a Behavioural HDL • Supports a functional programming style • Designed for source-level program transformation • Ease of analysis and optimisation • Combine behaviour and structure? • Verilog/VHDL do this to great effect… but as a result are very complex => transformation VERY difficult. Aim: to combine behavioural- and structural-level design elements in a pure-functional framework.
talkoverview • Behavioural HDL: SAFL • Structural HDL: Magma • Integrating SAFL + Magma • Case Study • Conclusions and further work
SAFL:a behavioural HDL • Functional • Call-by-value • First-order statically allocated functional language General properties • Concurrent • Statically Allocated • Resource Aware Hardware-specific properties The FLaSH Silicon Compiler translates SAFL into RTL-Verilog. Other tools (e.g. Leonardo Spectrum, Quartus II, Modelsim) process this RTL-Verilog and map it onto silicon.
fun mult(x, y, acc) = if (x=0 | y=0) then acc else mult(x<<1, y>>1, if y[0] then acc+x else acc) fun cube(x) = mult(x, mult(x, x, 0), 0) fun f(x) = let val y=mult(x,5,0) in y+x end a SAFLexample • Behavioural, … but • … captures system-level structure • One “fun definition” => one hardware resource circuit structure: SAFL Properties cube f mult
magma:a structural HDL • Embedded in pure-functional ML • Similar syntax and semantics (CBV) to SAFL • Supports synthesis/simulation • Uses ML functors to parameterise over different basis functions • Synthesis == Static Expansion • Only describes acyclic, combinatorial hardware • no “observable sharing” problems
a magmaexample (1) functor RippleAdder (B:BASIS):RP_ADD = struct type bit=B.bit fun adder (x,y,c_in) = (B.xorb(c_in, B.xorb(x,y)), B.orb( B.orb( B.andb (x,y), B.andb(x,c_in)), B.andb(y,c_in))) x y Adder c_in c_out s_out
a magmaexample (2) fun carry_chain f _ ([],[]) = [] | carry_chain f c_in (x::xs,y::ys) = let val (res_bit, c_out) = f (x,y,c_in) in res_bit::(carry_chain f c_out (xs,ys)) end val ripple_add = carry_chain adder B.b0 x1 y1 x2 y2 x3 y3 X4 y4 x5 y5 b0 Adder Adder Adder Adder Adder s_out1 s_out2 s_out3 s_out4 s_out5
a magmaexample (3) • Support for simulation and synthesis: - structure SimulateAdder = RippleAdder (SimulationBasis); - SimulateAdder.ripple_add ([b1,b0,b0,b1,b1,b1],[b0,b1,b1,b0,b1,b1]) val it = [b1,b1,b1,b1,b0,b1] : SimulateAdder.bit list - structure SynthesiseAdder = RippleAdder (SynthesisBasis); - SynthesiseAdder.ripple_add (Magma.new_bus 5, Magma.new_bus 5) and(w_1,w_45,w_46); and(w_2,w_1,w_44); ... and(w_149,w_55,w_103); val it = ["w_149","w_150","w_151","w_152","w_153"]
integratingSAFL and magma (1) • Magma fragments treated as SAFL-level functions <% (* Magma code Library Block: ---------------------------------- *) signature RP_ADD = ... functor Magma_Code (B:BASIS):RP_ADD = ... Contains ripple adder spec (as before) %> (* SAFL code: ------------------------------------------------- *) fun mult(x, y, acc) = if (x=0 | y=0) then acc else mult(x<<1, y>>1, if y[0] then <% ripple_add %>(acc,x) else acc)
integratingSAFL and magma (2) Execute Magma under Synthesis Interpretation Process 1: ML Session Magma Verilog Process 2: SAFL Compiler EncounterMagma Fragment [Time] <% m %>(e_1, …, e_k)
integratingSAFL and magma (3) fun f(x) = <% M %>(x) + <% M %>(x) Source-level transformation fun g(x) = <% M %>(x) fun f(x) = g(x) + g(x) High-level synthesis RTL Verilog RTL synthesis FPGA
case study:DES • SAFL Describes DES Algorithm • Magma Describes Wiring Permutations • Current Version Not Pipelined • Making a pipelined version through SAFL/Magma program transformation is topic of future work • Throughput of 15.8 Mb/sec • On Altera APEX 200K FPGA with 33MHz clock • Theoretical max clock speed design > 40MHz • 2 DES blocks + test harness => 17% of FPGA
case study:DES – Dev Boad Status LEDs APEX E20K200E
conclusions • It is possible to combine behavioural + (limited) structural design in a clean way • Fine-grained structure integrates well with SAFL’s notion of resource-awareness • Program transformation remains a powerful technique for exploring tradeoffs • Tested technique on a real-life case study
ongoingresearch • Extending the SAFL Language • ML-style references • Many-many synchronous channels • Pi-calculus style channel passing • Extending the FLaSH tool-chain • Developing / experimenting with new SAFL transformations • Building SAFL compiler which targets asynchronous hardware • Building larger examples