Computational reflection and its application to platform verification

The complexity of modern hardware design has created the need for higher levels of abstraction, where system modeling is used to integrate modules into complex System-on-Chip (SoCs) platforms. SystemC, and its TLM (Transaction Level Modeling) extensions, have been used for this purpose mainly because of their fast prototyping and simulation features, which allow for early design space exploration. This paper proposes an approach to explore and interact with SystemC models by means of an introspection technique known as Computational Reflection. We use reflection to implement a white-box introspection mechanism called ReflexBox. We show that ReflexBox is a fast, non-intrusive technique that can be used to dynamically gather and inject stimuli into any SystemC module, without the need to use a proprietary SystemC implementation, change the SystemC library, instrument or even inspect the module source code. Our approach can be used to support many different verification tasks like platform debugging, performance evaluation and communication analysis. To show ReflexBox effectiveness we used it in three platforms case studies to address tasks like register inspection, performance analysis and signal replaying for testbench reuse. In all cases we assumed no source code availability and measured the impact on the overall platform performance.

[1]  Ira R. Forman,et al.  Putting metaclasses to work: a new dimension in object-oriented programming , 1999 .

[2]  Jack Donovan,et al.  SystemC: From the Ground Up , 2004 .

[3]  Gabriela Nicolescu,et al.  A new efficient EDA tool design methodology , 2006, TECS.

[4]  Ira R. Forman,et al.  Java Reflection in Action (In Action series) , 2004 .

[5]  Pattie Maes,et al.  Computational reflection , 1987, The Knowledge Engineering Review.

[6]  Erik R. Altman,et al.  Proceedings of the 35th annual ACM/IEEE international symposium on Microarchitecture , 2002, MICRO 2002.

[7]  Guido Araujo,et al.  A computational reflection mechanism to support platform debugging in SystemC , 2007, 2007 5th IEEE/ACM/IFIP International Conference on Hardware/Software Codesign and System Synthesis (CODES+ISSS).

[8]  Jacques Ferber Computational reflection in class based object-oriented languages , 1989, OOPSLA 1989.

[9]  Ira R. Forman,et al.  Java reflection in action , 2005 .

[10]  Luiz Cláudio Villar dos Santos,et al.  A novel verification technique to uncover out-of-order DUV behaviors , 2009, 2009 46th ACM/IEEE Design Automation Conference.

[11]  David Déharbe,et al.  Aspect-oriented design in systemC: implementation and applications , 2006, SBCCI '06.

[12]  Rolf Drechsler,et al.  An Integrated SystemC Debugging Environment , 2007, FDL.

[13]  Luca Fossati,et al.  ReSP: A non-intrusive Transaction-Level Reflective MPSoC Simulation Platform for design space exploration , 2008, 2008 Asia and South Pacific Design Automation Conference.

[14]  Miodrag Potkonjak,et al.  MediaBench: a tool for evaluating and synthesizing multimedia and communications systems , 1997, Proceedings of 30th Annual International Symposium on Microarchitecture.

[15]  Frank Ghenassia Transaction-Level Modeling with SystemC: TLM Concepts and Applications for Embedded Systems , 2010 .

[16]  Heinrich Theodor Vierhaus,et al.  Simulated fault injections and their acceleration in SystemC , 2008, Microprocess. Microsystems.

[17]  El Mostapha Aboulhamid,et al.  Introspection mechanisms for runtime verification in a system-level design environment , 2009, Microelectron. J..

[18]  Ira R. Forman Putting Metaclasses To Work , 1998, Proceedings. Technology of Object-Oriented Languages. TOOLS 26 (Cat. No.98EX176).

[19]  S Roiser,et al.  The SEAL C++ Reflection System , 2005 .

[20]  Sandeep K. Shukla,et al.  Mining metadata for composability of IPs from SystemC IP library , 2006, FDL.

[21]  Jan Haase,et al.  Embedded Systems Specification and Design Languages , 2008 .

[22]  Rodolfo Azevedo,et al.  The ArchC Architecture Description Language and Tools , 2005, International Journal of Parallel Programming.