130 likes | 142 Views
Learn the advantages of virtual platform design including productivity, observability, and gradual refinement to RTL. Discover the teaching concept involving virtual platform design, system on chip, application-specific instruction set processors, and more. Engage in tutorials on SystemC, basic programming skills, and system verification. Participate in a detailed laboratory on electronic-system-level design using Platform Architect from Synopsys. Develop practical skills through hands-on sessions in platform design, software mapping, JPEG acceleration, and system debugging. Gain diverse knowledge applicable to industrial needs and expand your expertise in system development.
E N D
Teaching The Principles Of System Design, Platform Development and Hardware Acceleration Tim Kranich 11.05.2010
Outline • Good reasons for platform design • Our teaching concept • Laboratory structure “Platform Design” • Conclusion
Advantages of Virtual Platform Design • A Virtual Platform is an abstract hardware model that is simulated by software VPs can easily be duplicatedand packaged allowing multiple developers to work in parallel. Software development can start before hardware prototypes are available. Productivity Availability Accessibility Consistency Unlike physical hardware VPs provide observability and controllability for the entiresystem. VPs can be co-simulated/emulated. Gradual refinement from high abstraction to RTL eases verification.
Teaching Concept • Partitioning the knowledge transfer into three different teaching forms Virtual platform design with industrial tools based on SystemC Basic programming skills in SystemC and TLM General ideas and concepts of system and platform design
Lecture In Detail • Teaching general concepts of system and platform design • System on Chip (SoC) • Multi Processors SoC (MPSoC) • Application Specific Instruction Set Processors (ASIP) • Reconfigurable ASIP (RASIP) • Bus Communication • Network on Chip (NoC) • Low Power System Design • System Test, Verification and Debugging • Providing up-to-date literature and praxis oriented examples
Tutorials in Detail • SystemC Crash-Course • 3 hour presentation • Concepts and techniques • Basic language elements • Computer-based programming tasks • HDL equivalent designs (counter, adder, …) • Testbench and stimuli generator • TLM modeling (SystemC channels like FIFO and simple BUS)
Laboratory in Detail • Electronic-system-level (ESL) design with an industrial tool called Platform Architect from Synopsys • Pool of basic platform elements allows rapid design exploration • Point of origin: Simplified JPEG compression written in generic C code • Target platform: ARM processor with hardware accelerator for DCT calculation
Platform Architect from Synopsys • For architectural analysis, Platform Architect provides views to: • Analyze cycle-accurate performance • Study throughput and bottlenecks • Look at bus switching and cache usage • For the case of functional analysis, Platform Architect provides views to: • Look at system response and task scheduling • Analyze processor loading • Profile software Cross-correlate different views to extract powerful information
Laboratory: Tool Handling • First design • Assemble a sample system (timer + reset generator + testbench) • Instantiate an OCP bus • SystemC Explorer • Build-in hardware debugging tool • SystemC Shell • Command line tool for platform simulation • Component Wizard • Introduction to the component library approach • Creation of custom-designed components • Duration: 4 Sessions
Laboratory: Platform Design • Designing a platform based on ARM9 core • Understanding the design constraints • Composing the initial acceleration platform • Duration: 1 Session
Laboratory: Software Mapping • Core Programming • Writing test application for virtual ARM core • In-system debugging with GDB • Algorithm Adoption • Introduction to JPEG compression • Source code modification • Duration: 3 Sessions
Laboratory: JPEG Acceleration • Modification of Hardware and Software • Encapsulating the DCT • Extending virtual platform by a hardware accelerator • Implement software call routines • Hardware Refinement • Integration of a given HDL component for DCT calculation into the virtual platform • Duration: 5 Sessions
Conclusion • Providing wide, state of the art knowledge for system design during lecture sessions • Tutorials are chosen to teach fundamental modeling skills with SystemC • The laboratory combines various aspect taught during lectures with an industrial leading tool framework (Platform Architect form Synopsys) for ESV • Challenging programming professional development environment motivates students • Taught knowledge about systems and platforms meets industrial needs