Multimedia Teaching Tool SimArch V1.0 Faculty of Electronic Engineering University of Nis Serbia
SimArch is a teaching tool that supports lectures of computer architectures. SimArch can be adapted to meet requirements of any computer architecture course. SimArch - visualization tool that leads to higher quality lectures. Enables better lecture understanding - the students are driven through data flows step-by-step. Application area
Software requirements FUNCTIONAL REQUIREMENTS Visualization of custom processor architecture. Hardware descriptions have to be stored in separated files. Capabilities of viewing hardware component details. Visualization of instruction flow through processor components. Detailed information of hardware components status need to be derived from hardware simulation. Adaptation capabilities that enables involving of new lectures. User-friendly interface. Easy software upgrading.
Software requirements NON-FUNCTIONAL REQUIREMENTS Graphical elements optimized for presentation using video-beam. Basic package distribution contains files with RISC architectures that are involved in computer architecture courses on Faculty of Electronic Engineering, University of Nis. Supported platforms: Microsoft Win9x, Win2000, WinXP.
Development environment CASE tools that have been used for software development are: Rational Rose 2000e. Microsoft Visual Studio 6.0 (Visual C++), Software model has been developed using the CASE tool named Rose 2000e, made by Rational , while the Microsoft product named Visual Studio 6.0 has been used for coding process. Used programming language is C++.
Used techniques Complexness of involved requirements engages usage of Design Patterns as well as some of the task-separation techniques. Used Design Patterns are: Singleton classes Manager classes Interface classes
Software model SimArch contains a few sub-systems. All sub-system models were derived from using UML modeling tool - Rational Rose 2000e. Sub-systems are Components Engine Window Manager Draw Manager Shared Components
UML model Fig 1. UML model of subsystem Components
Script language A specialized, custom script language has been developed to meet requirements of hardware description. Architectures are described by script language that consists of three parts: First part of script is involved into hardware description. Second is used for lecture scenario description. Third part of script language consist of a list of assembler instruction (assembler program without declarations) to be simulated.
Script example PC(0,1;2) %38 ?28,302,29,60,1 OR#3(7,93;1) %1 ?30,100,26,26,1 CONSTANT#1(;3) %4 ?80,238,0,0,1 ADD#1(2,3;4) ?110,185,35,80,1 INSTRUCTION_MEMORY(2;5) %.\Code\Code.mps ?85,302,69,125,1 IF_ID(5,4,6,7;8,9) ?175,217,22,330,1 BUS_SPLITER#1(8;57) %31,26 ?0,0,0,0,0 … #INSTRUCTION=ADD PC INSTRUCTION_MEMORY ADD#1 CONSTANT#1 MUX2X1#17 MUX2X1# stop 30: sw $25, 50($7) 34: j 16 38: lw $10, 0($1) 3c: add $8, $10, $8 40: sub $11, $2, $3 44: lw $16, -12($7) 48: and $12, $1, $7 4c: or $13, $1, $7 50: add $1, $2, $1 54: slt $12, $15, $6 58: beq $3, $9, -11 5c: slt $3, $0, $1 60: or $2, $3, $5 64: sub $1, $2, $25.\1_Singleclock implementation\Single.shm.\2_Multiclock implementation\Multi.shm.\3_Pipeline without Forwarding\Main.shm.\3_Pipeline without Forwarding\Main_HDU.sh m.\4_Pipeline with Forwarding\Main.shm.\4_Pipeline with Forwarding\Main_FU_HD U.shm
How to use SimArch? Lectures are being prepared by the following steps: Step 1: Architecture selection Step 2: Planning the lecture flow Step 3: Scripts writing.
How to use SimArch? As well as lecture preparation, presentation conduction consists of two steps, too. These steps are: Step 1: Selection and loading of created script Step 2: Script leaded step-by-step presentation.
Vision of Future Releases NEW VISUAL EFECTS Future releases will involve new visualization methods, such as: Animated data flows through processor Involving additional windows that will have a capability to display a waveform of signals that flows through architecture buses and components.
Vision of Future Releases Client – Server presentation Plan for future SimArch releases contains involving of network capabilities. One of those capabilities is client-server presentation. Aim of the client-server presentation will be to enable presenting without using video-beam. Presentation tools will be monitors of the client computers. That kind of approach enables implementation of interactive learning tool.
Vision of Future Releases Web version Web version of package is one of the future releases that represents SimArch's web application. Web release should be an application, hosted on web server, able to provide identical user interface using web techniques. Students should be able to practice their own test examples on architectures prepared by teacher.
Vision of Future Releases Extension of available component sets Components libraries CISC processor components Components needed by most of DSP architectures Script libraries
All Suggestions and Comments are welcome... The END