320 likes | 455 Views
Dynamic Support of Processor Extensions in Cross Development Tools. Vladimir Rubanov Institute for System Programming of RAS SYRCoSE 2007, 31 May 2007. Extensible Embedded System (1). System Components: Processor Core Processor Extensions = Accelerators (new FUs or co-processors)
E N D
Dynamic Support of Processor Extensions in Cross Development Tools Vladimir RubanovInstitute for System Programming of RAS SYRCoSE 2007, 31 May 2007
Extensible Embedded System (1) • System Components: • Processor Core • Processor Extensions = Accelerators (new FUs or co-processors) • Memory Subsystem: • The only program memory. • Core’s data memories. • Shared data memory. • Accelerators' local data memories. • Uniform instruction set for application developer.
System Design Process • Stage 1: Core Design • Stage 2: Accelerators Design • Stage 3: SoC System Design (combining the core and selected extensions)
Cross Development Tools • Cycle-Accurate SW Simulator • Profilers • Macro Assembler • Disassembler • Linker and Librarian • Visual Debugger • Integrated Development Environment (IDE)
Cross Development Tools Role • At the Design Stage: • Design space exploration and prototyping by simulator based profiling. • Early development of optimized software. • HDL verification. • At the Deployment Stage: • Development of various production software.
Formal Accelerator Description • Special language (ISE) for describing: • Accelerator’s Memory Structure • Accelerator’s Resources • Accelerator’s Instruction Set: • assembly syntax; • binary coding; • cycle-accurate behavior andresource usage.
Memory Structure DECLARE_MEMORY(INT(16, 3), 4096) LDM; DECLARE_MEMORY(INT(64, 3), 2048) TM; MEMORY(LDM, "Acc LDM"); MEMORY(TM, "Acc TM"); DECLARE_REGISTERS_FILE(INT(16), 4) grn; REGFILE_BEGIN(grn, "General Registers") REGISTER(0, "GR0"); REGISTER(1, "GR1"); REGISTER(2, "GR2"); REGISTER(3, "GR3"); REGFILE_END()
Accelerator Instruction Set (1) .types grn = [GR0:0] [GR1:1] [GR2:2] [GR3:3] acr = [ACR1:0] [ACR2:1] .operands GRs = {grn : SS} GRt = {grn : TT} ACRa = {acr : A} ACRb = {acr : B}
Accelerator Instruction Set (2) .instructions ALU01 { ADD GRs, GRt // syntax 0110-00SS-0111-T0-T1 // coding constraints { GRs<>GRt : “GRs and GRt must be different” } properties { wgrn:GRs, rgrn:GRs, rgrn:GRt } }
Accelerator Instruction Set (3) ALU01 { … behavior { GRs := GRs + GRt; // GRs ≡ grn[#GRs] } }
Accelerator Instruction Set (4) void ALU01 (OPCODE opcode) { UINT<2> GRs_ind = (opcode >> 8) && 3; UINT<2> GRt_ind = ((opcode >> 3) && 1) || ((opcode >> 1) && 1); grn[GRs_ind] = grn[GRs_ind] + grn[GRt_ind]; FinishCycle(); }
Accelerator Instruction Set (5) MAC01 { MAC ACRa, GRs, GRt … behavior { // the first cycle mulres := GRs * GRt; FinishCycle(); // the second cycle ACRa := ACRa + mulres; } }
Inter-Instruction Conflicts .inter-constraints [@e2_write_acr = read_acr] % error: “Write After Read conflict for accumulator” [@p_write && memory_access] % warning: “1 cycle stall: memory access immediately after pointer update”
Cross Tools Reconfiguration (1) • Accelerator ISE description is created either visually or in plain text. • Accelerator description is compiled into a shared library module (.dll on Windows, .so on Linux). • Such modules are specified in the cross system configuration. • API is used by Core Simulator to execute accelerator instructions as fibers (explicitly controlled threads). • API is used by Assembler, Disassembler, Debugger and IDE to extract necessary meta-information about the accelerators.
Cross Tools Reconfiguration (2) Visual ISE Editor ISE Specification Automatic generation AcceleratorCross Module (.dll or .so) On-the-fly reconfiguration The Cross Tools
Results • Generalized model of extensible embedded systems. • A formalism for specifying particular accelerators in ISE language. • Tools for visual editing, analysis and verification of ISE specifications. • Framework for generating executable accelerator modules with meta-information. • Reconfigurable cross development tool chain dynamically extensible by the accelerator modules plugged-in.
MetaDSP Framework • The results have been used in MetaDSP – a framework for fast construction and modification of cross development tools for embedded systems. • Proved in 5 commercial projects for different extensible processor families: • RISC 32/16 bit DSPs • ARM-like RISC • VLIW DSP • Used in customer’s development teams in Sweden, Taiwan, China, USA
Implemented Accelerators • Fast Fourier Transform (FFT). • Echo cancellation algorithms. • Complex (imaginary) arithmetic operations. • Image processing operations(JPEG accelerator). • Digital voice filtering operations (FIR, IIR). • Voice coding/decoding (AMR). • MP3 music decoding.
Assembler • Parameterized macros support. • Conditional assembly(if, switch, repeat,etc.). • Multi-dimensional arrays. • Constant expression calculation. • Inter-instruction conflicts detection. • Automatic NOP insert. • C debugging info in Dwarf2 format.
Linker • Memory holes optimization (both at variable and module levels). • Visual interface to control memory layout with advanced features (fixed/floating address, alignment).
SW Simulator • Cycle-Accurate. • Fast speed(50 MCPS on Core 2 2000Mhz). • Pipeline simulation with stalls, zero-overhead loops, interrupts and timers. • Dynamically modifiable code support. • Run-time semantics checks. • Breakpoints, sample points, trace points.
Debugger and IDE • MixedC/Asm/Disasm source level debugging • Projects support • Full C expressions in Watch window • Call Stackwith frame switch • Various display formats for register and memory contents • Code helper in editor • Syntax highlighting in editor • Breakpoints / Samplepoints / Tracepoints/ Watchpoints • Source Browser • RTOS debugging support • Various profilers (linear, call graph, instruction tree, RTOS load, RTOS sequence)
Contacts • Vladimir Rubanovvrub@ispras.ru • http://ispras.ru/groups/igroup/igroup.html