The Digital Systems Design course, at Missouri University of Science and Technology (Missouri S&T), aims to introduce Electrical and Computer Engineering majors to embedded systems design using microcontrollers. The internal conceptual working of the chosen microcontroller family is explained, using the instruction set, over the course of a semester. In order to introduce students to typical computer organization and architecture design techniques, the Weekend Instructional Microprocessor (WIMP51), which is rudimentary in design and has a small instruction set, is also covered. The original WIMP51 was created using synthesizable VHDL. Students taking the prerequisite Introduction to Computer Engineering course are not required to learn, and are rarely introduced to, VHDL at that level depending on the instructor's choice. In order to provide a platform for students to better visualize, understand and learn the internal organization and architecture of the WIMP51 processor, a student oriented experiential learning based project was implemented to redesign WIMP51, using the original inspiration (a similar but different implementation) in Quartus II design software using schematic capture of digital circuits via Block Diagram Files (BDF). This paper discusses, in depth, the recreation of the WIMP51 processor and describes the designed features to help students obtain a deeper understanding of the internal working of the processor.
Introduction
As an Electrical Engineering (EE) major, the opportunities to learn about computer organization and architecture are limited, unless their emphasis area is Computer Engineering (CpE). The Introduction to CpE course, which is required for EE and CpE majors, introduces the basics of computer hardware, and precedes courses that focus on computer organization and architecture development and design. These subsequent courses are electives for EE majors, and could be the only exposure they have to this material. One of these courses, Digital Systems Design, focuses on the 8051 family of microcontrollers to teach embedded system design of microcontroller based applications. The 8051 platform is different from the Gnome 1-2 and Gumnut 3 microprocessor platforms, the earlier has been previously taught at Missouri S&T. As the 8051's internal organization can be difficult to grasp, at an introductory level, the internal conceptual workings of this family of microcontrollers are explained over a semester using the instruction set. This normally involves implementing projects using programming to create applications, but leaves students with limited knowledge of the internal architecture of a microcontroller. Other courses teach microprocessor design using Hardware Descriptive Languages (HDL), such as VHDL and Verilog [4] [5] [6] .
In order to provide exposure to a simple internal architecture, the Weekend Instructional Microprocessor (WIMP51), a simpler version of the 8051 with a smaller instruction set, was formerly designed 7 . The original WIMP51 was created using VHDL 4 , a hardware descriptive language, which is not normally introduced to students in the Introduction to CpE course. Instead students are required to create digital circuits using Block Diagram Files (BDF), as a graphic representation of a digital circuit, in Altera's Quartus II design software. After simulation, these circuits can be downloaded and tested on Altera's DE II FPGA board. With this knowledge, it seems fitting that a subsequent course in CpE, which concentrates on microcontroller based embedded system design, would use the BDF platform in order to teach basics of microprocessor design, which allows students to easily learn the concepts in a familiar environment.
A group of junior and senior level EE students were given the task of using the basic organizational diagram and instruction set as the reference, and the knowledge learnt in the Introduction to CpE course, to recreate the WIMP51 processor, using the BDF platform, via an experiential learning project. Note that the group did not have any prior knowledge on microprocessor design techniques. They also had not yet taken the Digital Systems Design course.
Design Methodology
The WIMP51 design was based on the available block diagram and instruction set 7 , shown below in Figures 1 and 2 . Some additional state machine information, including the three main states, in an instruction cycle, was also available 7 . In order to complete the design, in the allotted time, minor changes in the internal organization (missing 'PSEN' as seen in Figure 1 ) and the instruction set ( Figure 3 ) had to be made. Each Upper-level block was broken down, into sub-systems, to determine the required internal structure to correctly process information using the machine code mentioned in the instruction set ( Figure 3 ). The instructions were grouped according to their similarities in machine code. Using this resemblance information, the required control logic was designed for each of the major blocks seen in Figure 2 Throughout the construction process, the placement of different top-level entity blocks, in the BDF, was kept similar to their location as seen in the block diagram ( Figure 1 ). This process aided circuit troubleshooting as required. The WIMP51 was created using a bottom up approach.
First, common basic datapath components were designed with basic digital logic gates. Figure 4 shows an example of basic element of self-loop (a 2:1 MUX), which allows either a new input to enter or the output of the memory element to be routed back into the memory element. Several other basic elements were created, which included multiplexers, decoders, priority encoders, and 8-bit binary adder unit. These elements were turned into their own individual block symbols and used to create larger blocks of the microprocessor. Some of these larger elements include the Zero Flag (ZF), Register File (RF), Arithmetic Logic Unit (ALU), and Program Counter (PC)-ALU. Figure 5 shows how the self-loop block was used to create the ZF, an element that detects if the content of the Accumulator (ACC) is zero. Self-loop is not only used in the ZF block. It is also used in each register, including the Instruction Register (IR), Auxiliary Register (AUX), the ACC, the PC, and the registers that make up the RF. Figure 6 shows the ZF in its place in the top-level WIMP51 structure connected to the ACC. These elements were created so students could replicate them easily, gain an understanding of their functions, and reuse them in their own designs if needed. In order to maximize access and simplify the design process, the required control signals were generated externally to each upper-level entity. This ensured that similar components, such as the registers used for the AUX and the eight registers in the RF, were consistent in design.
Students could easily access control signal blocks without having to look at the controlled block. This facility also allowed for easy troubleshooting of the system. In order to aide lecture delivery, and perhaps initial learning during teaching the WIMP51, an interactive diagram was created 8 , which allows students/instructor to quickly view any component, at any level, of the WIMP51 easily without inadvertently making a change. Users can double click on any block to view the lower level entity. This interactive diagram can serve as quick reference and as an application show-and-tell in the Introduction to CpE course without the hassle of going through the large number of BDF involved, in the Quartus environment.
Design Features
Through the design and construction process, several facilities were provided that would maximize student understanding of the internal working of the processor. Since there are a number of registers in the WIMP51 architecture, it would be prudent to observe their contents during an instruction cycle. One limitation discovered, during implementation, was the limited number (only eight) of Seven-Segment-Displays (SSD) available on the Altera board. With two displays required to show eight bits of data in HEX form, only four register values could be viewed at a time unless multiple data-sources are multiplexed. After careful consideration, a standard output viewing package was setup, which included access to important registers, control and status signals. The project implementation also included the construction of two programs; the first for entering the machine code into the on-board RAM module, and the second for running the stored program using the WIMP51.
The program for entering the machine code allows the user to enter an 8-bit binary instruction or address on the Altera FPGA RAM using switches, and view the HEX equivalent using two SSD each. Once both the instruction and address have been entered correctly, a push button is used to save the instruction to a RAM location before entering another. Figure 7 shows the components, on the Altera FPGA board, which were used for user input and system output, while Table 1 provides a description of the components used. A demonstration video can be found on the project webpage 10 . Figure 7 : Locations of features used to enter an 8-bit instruction and memory address to the Altera FPGA on-board RAM. This organization allows the user to associate the 8-bit binary instruction with its HEX equivalent. Table 1 : Description of features, as seen in Figure 7 , used to enter the machine code into the on-board RAM. Location on Altera DE2 Board Description A 8-bit instruction/data (in HEX) on SSD 4 and 5. This instruction is entered using switches (C) B 8-bit memory location in on-board RAM displayed on SSD 0 and 1. This address is entered using switches (D) C Switches used to enter 8-bit instruction. Switch 15 (left) is the MSB and switch 8 (right) is the LSB. D Switches used to enter 8-bit memory address. Switch 7 (left) is the MSB and switch 0 (right) is the LSB E Push button 0 used to write the instruction, once the instruction and address have been setup using switches.
The program used for running the stored machine code was more complex than the one used for entering it. Access to standard register and control signals values was provided as shown in Figure 8 and described in Table 2 . Following is a description of the features included in WIMP51 program and displayed on the Altera FPGA board:
• Access to six register values was setup as part of the standard viewing package. Since only four sets of seven segment displays are available on the board, some of the register data had to be multiplexed, which are controlled by switches (Table 2 ). To achieve deeper understanding and learning, it was considered prudent to provide some facility which could be used to access additional internal register and/or control signal values. Unassigned output pins and seven segment decoders were setup for such additional registers and control signals as seen in Figure 9 . Even though reassigning pins will decrease accessibility to standard registers, a user or a designer can observe and verify the internal working of a module for planned system improvement or expansion. • The LEDs on the Altera board are used to display various control signals including the write enables and the machine states of fetch, decode and execute cycles. Depending on the instruction stored in the Instruction Register (IR), during the fetch cycle, different control signals are activated to perform the desired operation. In order to facilitate learning, access to the activation and deactivation of different control signals during each state of an instruction cycle was provided, as seen in Table 2 and Figure 8 . The standard viewing package included access to different write enables, flags, and internal ALU decode signals. Note that some of the LEDs, as seen in Figure 8 , are not assigned to any signal. Capacity exists so that a user can view additional control signals as desired. Table 2 : Description of Features, seen in Figure 8 , available during WIMP51 run cycle. Speed up Clock-push button 2 can be used to speed through a familiar part of the program P Reset: When switch (K) is low, press push button 1 to start the program execution from the beginning
Location on Altera
• An internal clock (50 MHz), available on the DE II board, was intentionally slowed down significantly, which became the system clock, to allow time for viewing and understanding how the different registers and control signals update during each state of an instruction cycle. As users become more familiar with the WIMP51, they will no longer need as much time during certain instructions. An option to use a push button (Table 2 and Figure 8 ), to speed up the clock, was provided as part of the standard user control package.
• After viewing the program, the user may wish to go back and review the program again.
In order to run the program again, a reset facility was incorporated as mentioned in Table  2 and Figure 8 .
It is anticipated that the provided standard viewing package, along with a running test program and access to the internal circuit diagram will allow the user to understand the working of the WIMP51. Additional details can be found on the project webpage 10 . Figure 9 : Access to additional register data and control signals, which is provided in terms of unassigned output pins and seven-segment decoders, in addition to the standard provided access.
Platform for Class Project Implementation
The WIMP51 was primarily recreated to serve as a teaching tool and project platform in the regularly taught Digital Systems Design course, which is typically divided into three phases. The WIMP51 instruction and the corresponding major class project form the first phase of the course. Students are taught the WIMP51 and its internal design. They learn how to use its instruction set to write program, and, synchronously, are given access to the WIMP51 and its associated programming circuit. They hardware test the WIMP51, using test programs. Concurrently, the first major design project is assigned, in which they are required to improve the WIMP51 by adding, 8051 compatible instructions, to the current instruction set 9 . This project was implemented in the spring semester of 2014 at the Missouri S&T and Missouri State University (MSU) Cooperative Engineering program. All enrolled students were EE majors. The successful completion of the project required the fruitful demonstration of their version of the WIMP51 using test programs that included their additions to the current instruction set.
Though students found the project relatively difficult to implement, as compared to the other course projects, the project experience allowed them to gain knowledge into basic processor design, construction and testing. Additional information, on the implemented course projects, along with demonstration videos, can be found on the course webpage 9 .
Conclusion and Future Work
The reimplementation of the WIMP51 learning and project development platform proved to be a successful learning experience for undergraduate EE students who did not have any prior knowledge on processor design techniques. Even though WIMP51 is rudimentary in design, the implementation allowed undergraduate EE students working on the project to gain experience in computer organization and architecture design principles via an experiential learning project. Such exercises are an essential confidence and skill building platforms, which expose students to project-based learning is areas, which are closely related to their field of study, and should be encouraged at all levels of undergraduate study. In addition, the developed learning tool proved to be a successful stage to implement a major class project, which can easily be implemented in a familiar design environment for a the academic level of the course.
Future work will concentrate on the design optimization of the recreated WIMP51. An important goal was to get the logic to work. Since the clock is significantly slowed down, effort was not made to enhance the design. Also, owing to time restrictions, a simulation testbench was not created. Adding simulation profiles may augment current teaching methodology of the WIMP51. Furthermore, this project can branch out into additional similar projects, which involve creating different versions of the WIMP51 that incorporate hardware peripherals typically found in the 8051 family of microcontrollers. It is anticipated that such projects would be lengthy and time consuming, and, therefore, will become part of experiential learning projects implemented outside the traditional lecture course environment.
Bibliography

