A set of demonstration programs to illustrate the fetch and execution cycles and the operations regarding the ALU, Registers, Memory, and Program Counters.
First developed in 2007
Copyright (C) 2007 - Andrew Kwok-Fai Lui
The Open University of Hong Kong
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, see http://www.gnu.org/licenses/.
The fetch and execution cycle is the foundation of the operation of processors. It involves the collaboration of several essential components including the Arithmetic and Logic Unit (ALU), registers, the program counter (PC), instruction register (IR), and the memory system.
As a teacher of a course about computer architecture, discussion on the fetch and execution cycle is ineffective without visualization of the how and the why of data movement between the components. Therefore this set of demo applications was developed to enable visualization of the fetch and execution cycle in a classroom context. Students with weaker visualization ability can find it useful.
Principally this set is defined as teaching tools. However, with suitable tuition design, it can be part of a exploratory laboratory session. Some of the tools are designed for a course using the Little Man Computer (LMC).
The set of interactive demos include the following.
- IEEE754 Format Demo (
faifai.arch.IEEE754Bit32Demo
) - ALU and Register Operation Demo (
faifai.aludemo.ALUDemo
) - ALU and Two Registers Operation Demo (
faifai.aludemo.ALUTwoRegDemo
) - ALU with Memory System Demo (
faifai.aludemo.ALUMemoryDemo
) - ALU, Program Counter, and Memory System Demo (
faifai.aludemo.ALUPCMemoryDemo
) - The LMC Demo (
faifai.aludemo.LMCDemo
): LMC implemention with the full set of components - LMC Program Execution Demo (
faifai.aludemo.LMCOperationDemo
): The fetch and execution cycle on the LMC illustrated - Program Execution (Faster) Demo (
faifai.aludemo.LMCOperationDemoFast
): The cycle runs a bit faster by combining steps
- Java JDK or JRE 1.8 or above
A launcher application ApplicationLauncher.class is provided for running each of the 8 applications.
- Download the repository to a folder, assuming that it is
/app/ALUDemo
. The Java sources are in thesrc
folder and the classes are found in thebin
folder. - Execute
ApplicationLauncher.class
insider the folder
cd /app/ALUDemo
java -cp "./bin" ApplicationLauncher
Alternatively, each of the 5 applications can be executed from their main classes (as in the above list).
cd /app/ALUDemo
java -cp "./bin" faifai.arch.IEEE754Bit32Demo
Class: faifai.arch.IEEE754Bit32Demo
This demo is actually not part of the fetch and execution cycle demo, but included in this repository because this seems a useful teaching and learning tool.
There are four demos useful for a gradual introduction to the operation of a computer processor and the basics of fetch and execution cycle.
- ALU and Register Operation Demo (
faifai.aludemo.ALUDemo
) - ALU and Two Registers Operation Demo (
faifai.aludemo.ALUTwoRegDemo
) - ALU with Memory System Demo (
faifai.aludemo.ALUMemoryDemo
) - ALU, Program Counter, and Memory System Demo (
faifai.aludemo.ALUPCMemoryDemo
)
- Every component widget offers one or more of the following features. ** Set a new value ** Toggle between decimal and hexadecimal view ** Change the open/closed of the input (read) and the output (write) ports ** The Memory Sytem enables set value of MAR and MDR, and also view, load and save all the data in the memory (size 256) ** The ALU enables selection of 3 instructions: add, subtract, and set
- Pressing the Signal button will simulate a signal activating all the components once.
- Start from the ALU Demo with one register. Emphasis the following (1) the input port and the output port can be in a state of Open (connecting to the bus) or CLosed (not reading nor writing from the bus), (2) the buses connect the output port of one component to the input port of another component. The Closed state means that the component is not prepared to read or write data at the port.
- Emphasis that the components only do work at the signal, which means when the "Send Clock Signal" button is pressed.
- Discuss the ALU operationd (add, subtract, and set) and the data used in these operations. For example, the add function has two operands, one from the register's output and another from the ALU output. Set a value on the ALU and the register, select "add", and press the signal button to show that the updated value is seen in the ALU. I will stop here and hopefully this is enough to give you an idea.
Finally, these three demos have put together all the components of a processor. The last two enables the loading of a LMC program into the memory system and execute the instructions (and the steps in the fetch and execution cycle) one by one.
- The LMC Demo (
faifai.aludemo.LMCDemo
): LMC implemention with the full set of components - LMC Program Execution Demo (
faifai.aludemo.LMCOperationDemo
): The fetch and execution cycle on the LMC illustrated - Program Execution (Faster) Demo (
faifai.aludemo.LMCOperationDemoFast
): The cycle runs a bit faster by combining steps
- A LMC program (Add 2 numbers) should have been pre-loaded into the memory system. Alternatively, load another memory file or enter your own program. Press the View Data button on the Memory System to show that to the students.
- Emphaize the PC is now 000, meaning that the next address to execute is 0.
- Describe the purpose of pressing the "Send Clock Signal" button, which runs a step in the fetch and execution cycle.
- The first step is PC > MAR, which is shown on the left. Press a button once to execute this step. Show that MAR is now 000.
- The next step MEM[MAR] > MDR is shown. Press the signal button to execute, show MDR is changed from 000 to 901.
- The next step is MDR > IR. Press the signal button to execute and show that 901 is loaded into IR. I also stop here now and this should be enough to give you an idea.