Session F4E Uvi51: A Simulation Tool For Teaching/Learning The 8051 Microcontroller
Session F4E Uvi51: A Simulation Tool For Teaching/Learning The 8051 Microcontroller
Session F4E Uvi51: A Simulation Tool For Teaching/Learning The 8051 Microcontroller
Abstract Teaching/learning microcontrollers in the This paper presents a software tool, called UVI51,
laboratory has been traditionally carried out using general specifically designed for teaching and learning the 8051
purpose simulators and/or evaluation boards. In-circuit microcontroller. The current version (5.0) is the result of
emulators are not widely used because their high cost. This succesive enhancements carried out on early versions [5]. It
paper presents UVI51, a software tool developed for allows to simulate systems consisting of up to 4
teaching/learning the 8051 microcontroller in the laboratory microcontrollers operating concurrently, plus a set of
and/or the classroom. UVI51 includes an assembler, a interconnected external peripherals.
multimicro simulator, a logic analyzer, and an assistant. The UVI51 consists of an assembler, a multimicro simulator
tool allows to simulate systems consisting of up to 4 (the core of the tool), a logic analyzer, and an assistant that
microcontrollers plus a set of external peripherals. Both the guides the user through the development process. UVI51
CPU core and the embedded peripherals of each provides its own assembler, but standard assemblers as [6]
microcontroller are simulated. Everything in UVI51 has can also be used. The C language is also supported, but in
been designed with the educational perspective in mind. A this case a standard compiler, as [7], must be used.
set of windows depict the configuration and behaviour of The structure of the paper derives from our aim of
every embedded peripheral. UVI51 is currently being used highlighting the educational worth of UVI51. Therefore, the
in several courses on microcontrolllers at University of Vigo main components of the tool (assistant, assembler, simulator
(Spain) and also at the college level. The tool is suitable for and logic analyzer) are described in the following sections.
learning nearly everything about the 8051, ranging from the Furthermore, a section is devoted to an application example.
CPU and instruction set basics to complex use of timers, Finally, the conclusions of the work are presented.
interrupts and the serial port. This paper shows the benefits
of using UVI51 as an alternative to traditional instruction THE ASSISTANT
tools.
The assistant guides the user through the development
process which basically consists of the following steps: i)
Index Terms Education, MCS51, microcontrollers,
simulation. System definition; ii) Source code writing; iii) Code
assembly; iv) Simulation.
INTRODUCTION The system to be simulated is first specified by editing a
system configuration file. This is an ASCII file where the
8-bit microcontrollers are widely used for introductory user defines every microcontroller indicating their respective
courses on this topic mainly because they are simpler and source file names, clock frequencies, and memory sizes.
easier to describe than 16-bit or 32-bit microcontrollers, and Furthermore, the user can include external peripherals from
also due to their low cost. Among them, Motorola 68HC11, a predefined set. Finally, the user indicates the
Microchip PIC family, and the industry standard 8051 are interconnections between the microcontrollers and the
prevalent [1]. external peripherals. An example of a system and its
Even though many simulators are available for the 8051 corresponding configuration file is shown in Figure 1.
family [2][3][4], most of them do not support multimicro The present version of UVI51 supports the following
operation, nor simulate all the embedded peripherals, and types of external peripherals: i) Pushbuttons; ii) Switches
only a few can simulate external peripherals. In our opinion (either manually-operated or node-controlled); iii) Light-
none of them is a CAI-oriented simulator, since they do not Emitting Diodes (LEDs); iv) 7 segment displays; v) LCD
include features as 8051-specific graphical help windows. screens (either serial or standard types as Trident MDLS
Furthermore, the most complete one [4] is too expensive for 16265). Complex peripherals can usually be simulated using
many educational environments. These limitations an additional microcontroller with a suitable program.
recommended the development of a new simulator within Both assembler and C language are supported as source
the universitary scene, providing a free tool to the education code, but a standard compiler is needed for the latter.
community.
1
Alfredo del Río, University of Vigo, Dpto. Tecnología Electrónica, Vigo, Spain, ario@uvigo.es
2
Juan José Rodríguez Andina, University of Vigo, Dpto. Tecnología Electrónica, Spain, juanjo@dte.uvigo.es
0-7803-6424-4/00/$10.00 © 2000 IEEE October 18 - 21, 2000 Kansas City, MO
30 th ASEE/IEEE Frontiers in Education Conference
F4E-11
Session F4E
THE SIMULATOR
The simulator is the core of UVI51. Its main features are: i)
Umyprog.src 12 256 1024 Multimicro capability; ii) Embedded and external
P10=2 peripherals simulation; iii) Trace into, step over and
P11=3 continuous simulation; iv) Unlimited breakpoints; v)
Kstart 2 0 1 Additional breakpoint by value; vi) Chronograms
Lflash 1 3 2 generation; vii) Graphic user interface; viii) Help windows
for every embedded peripheral; ix) External peripherals
FIGURE. 1 window.
SYSTEM BLOCK DIAGRAM AND I TS CORRESPONDING CONFIGURATION The simulator main window is shown in Figure 2. The
FILE . upper part, called the system window, includes a bar of
pusbuttons used to control system operation. For example,
THE ASSEMBLER the RESET button is used to reset all the microcontrollers in
UVI51 includes an assembler that eliminates the need for a the system. The external peripherals are also shown in this
third-party assembler. The assembler generates executable area, each type with its own picture. Their connections are
code directly, in Intel-Hex format; therefore no relocatable depicted using node numbers or labels.
FIGURE. 2
SIMULATOR MAIN W INDOW .
FIGURE. 3
T IMERS/COUNTERS GRAPHIC W INDOW .
“Design a system consisting of two 8051 terminal P1 port. The LCD screen is connected using a 4-bit
microcontrollers interconnected via an asynchronous serial data bus and the 3 standard control signals RS, RW and E.
link, intended to generate pulse bursts. The first The terminal TxD and RxD pins are connected to the
microcontroller, called terminal must be connected to a 12 pulse generator RxD and TxD pins. In a real application
key matrix keyboard and to a standard 2 lines by 16 these connections could be made through RS232C buffers,
characters LCD screen. When terminal starts from reset, it an ASK radio link or any other suitable channel. In order to
has to show in the LCD screen the message “Pulses?” and to test system response to an eventual link fail, the simulation
wait for the user to introduce from the keyboard a number must provide a way to open the link between the terminal
between 1 and 127. Then, terminal has to show the message TxD pin and the pulse generator RxD pin. This is the reason
“Period?” so that the user can introduce pulse duration in why the BRK switch is included.
tenths of miliseconds in the range 1 to 127. When both The students begin their work writing the suitable
parameters have been introduced, terminal has to send their configuration file.
values to the second microcontroller, called pulse generator. The system configuration file asigns a program called
Pulse generator must generate a pulse burst in response terminal.src to the first microcontroller. The second one is
to each message received via the serial link. The numb er of assigned a program called pulsegen.src. All the external
pulses and their duration must agree with the received peripherals are defined: Twelve pushbuttons (keyboard), one
parameters. The idle level of the output pulses must be high. LCD screen, three LEDs, and a switch. The external
The time between consecutive pulses of a same burst must peripherals are shown by the simulator as depicted in Figure
be equal to pulse duration. Moreover, pulse generator must 7.
answer either with an acknowledge (ACK) or not The next step is to write the source code file for each
acknowledge (NAK) message to terminal before the burst microcontroller. The best option is to start writing the code
starts. The NAK message indicates a bad format or a number for terminal, and debug it until the right signals are obtained
out of range. in its TxD pin. The students can verify all the signals using
Both microcontrollers must operate at 12 MHz. The the logic analyzer, as shown in Figure 8. These include
serial link must operate at 10417 bits per second with an 8- keyboard scan signals and the LCD screen interface.
bit data format and without a parity bit. Messages are to be Once terminal is operating properly, the students write
sent as ascii codes.” the source code file called pulsegen.src. This program can be
The block diagram in Figure 6 shows the system easily debugged using the keyboard conected to terminal to
hardware structure. The matrix keyboard is connected to the send the convenient requests.
Micro 0 Micro 1
terminal pulsegen
KEYBOARD P3.4
RS
RW
LCD SCREEN Vdd
1 2 3 P1.0
P3.5
1
E P1.0
4 5 6 P1.1 P3.6 PULSE
7 8 9 P1.2 P2.7
DB7
Vdd
<- 0 Ent P1.3 P2.6 DB6
DB5
P1.6 P2.5 BRK
P1.5 P2.4 DB4
TX0 RX1 P3.0
P1.4 P3.1
RX0
P3.0 P3.1
Vdd
1
TX0 Vdd
1
RX1
FIGURE. 6
BLOCK DIAGRAM FOR THE P ROPOSED EXAMPLE .
FIGURE. 7
SIMULATOR P ERIPHERALS W INDOW FOR THE P ROPOSED EXAMPLE .
Finally, the switch placed between terminal’s TxD and used in the classroom when describing the microcontroller
pulse generator’s RxD can be left open before a request is architecture, the instruction set or the embedded peripherals
sent by terminal. Since pulse generator does not receive any operation, and also in the laboratory to write and test
request, it does not generate any pulse and does not answer application programs. A copy of UVI51 can be delivered to
to terminal. Terminal must detect this situation as a time-out the students, so they can make some home-work before they
and show a suitable message in the LCD screen. enter the laboratory.
Once the whole system is operative, students can UVI51 is being used in introductory courses on
introduce new specifications or refinements in order to learn microcontrollers. Students instruction is complemented with
more about keyborad scanning, LCD screen control, serial the use of a low-cost in-circuit emulator, based on the
links, use of timers, serial ports, interrupts, etc. downloadable flash versions of the 8051 family [8]. The user
can request the download process from the UVI51 assistant.
CONCLUSION The results of the application of our approach to education
have been excellent both in terms of student motivation and
A software tool for teaching/learning the 8051 scores.
microcontroller, called UVI51, has been presented. It can be
FIGURE. 8
LOGIC ANALYZER CHRONOGRAMS.
The simulator operates at instruction level, but our work [2] Avocet Systems, AVS High-Level Simulator/Debugger,
http://www.avocetsystems.com/.
is being oriented to develope a new version operating at
machine-cycle or clock-cycle level. This will aid in two [3] Keil Software, dScope Simulator/Debugger, http://www.keil.com/.
aditional improvements, at the expense of decreasing [4] Virtual Micro Design, Universal Microprocessor Program Simulator
performance: i) Timer 2 and new serial port modes (UMPS), http://www.vmdesign.com/.
simulation for the 8052 microcontroller; ii) External bus [5] Rodriguez Andina, J.J., del Río, A., "Aplicación de un simulador al
detailed simulation. Other possible improvements include
desarrollo de prácticas con microcontroladores," Proc. of the 2nd
undo and save/load state capabilities. Conference on Tecnologías Aplicadas a la Enseñanza de la
The current version of UVI51 runs under MSDOS and Electrónica, Vol. III, Sept. 1996, pp. 42-46 (in Spanish).
is available, free, in the web site http://www.dte.uvigo.es. In [6] Intel Corp., MCS-51 Macro Assembler Manual (V2.2). 1986.
the near future, versions running under Microsoft Windows
and LINUX will be developed. [7] IAR Systems, Micro Series 8051 C-Compiler Manual (V4.10A/DOS).
1991.
REFERENCES [8] Atmel Corporation, 8051 Flash Microcontroller Data Book, Dec.
1997. http://www.atmel.com/atmel/products/prod20.htm.
[1] Nunnally, C.E. , "Teaching Microcontrollers," Proc. of the 26th
Frontiers in Education Annual Conference, Vol 1, Nov. 1996, pp.
434-436.