BRISC-V Emulator: A Standalone, Installation-Free, Browser-Based
  Teaching Tool by Isakov, Mihailo & Kinsy, Michel A.
ar
X
iv
:1
81
2.
04
07
7v
1 
 [c
s.P
L]
  7
 D
ec
 20
18
BRISC-V Emulator: A Standalone, Installation-Free,
Browser-Based Teaching Tool
Mihailo Isakov and Michel A. Kinsy
Adaptive and Secure Computing Systems (ASCS) Laboratory
Department of Electrical and Computer Engineering
Boston University
{mihailo,mkinsy}@bu.edu
ABSTRACT
Many computer organization and computer architecture classes
have recently started adopting the RISC-V architecture as an alter-
native to proprietary RISC ISAs and architectures. Emulators are a
common teaching tool used to introduce students to writing assem-
bly. We present the BRISC-V (Boston University RISC-V) Emulator
and teaching tool, a RISC-V emulator inspired by existing RISC and
CISC emulators. The emulator is a web-based, pure javascript im-
plementation meant to simplify deployment, as it does not require
maintaining support for different operating systems or any instal-
lation. Here we present the workings, usage, and extensibility of
the BRISC-V emulator.
KEYWORDS
RISC-V, ISA, assembly, simulation, emulation, web-based, teaching,
tool.
1 INTRODUCTION
The x86 architecture assembly language is typically considered too
large and complex to be taught in a college entry-level class on as-
sembly or computer organization. Instead, RISC architectures are a
common choice due to their relatively small instruction set. A stu-
dent learn to write assembly by hand using RISC emulators either
through the command line, or wrapped in a graphical user inter-
face (GUI). The student uses the emulator by first loading an assem-
bly program written in an external editor, which is then wrapped
in a small kernel. The kernel is tasked with initializing the registers
and providing a small number of system calls. The user then either
runs or steps through the program line-by-line. The emulator of-
fers the student a view of the code with the instruction pointer
clearly visible, as well as tables showing the state of the registers
and memory when the program is paused or has finished.
RISC-V is an open-source RISC architecture widely seen as an
alternative to proprietary RISC and CISC architectures. It has seen
broad adoption in the recent years, with a number of extension pro-
posals, public implementations, growing software support, several
fabricated designs, and software emulators. It is increasingly being
used in college-level classes as amoremodernRISC alternative, but
the teaching tools have yet to catch up.
In this paper, we present our browser-based RISC-V emulator
we call BRISC-V Emulator (Boston University RISC-V Emulator).
It is inspired by existing RISC-based emulators, and has been de-
veloped for the purpose of teaching computer organization and
computer architecture classes.
Due to common issues with (1) installing software on locked-
down machines and (2) students wanting to use their own ma-
chines with different operating systems (OSs), the authors wanted
a javascript-based, OS-oblivious RISC-V emulator that does not re-
quire installation by the user, and provides a consistent GUI inde-
pendent of the platform. Having a browser-based implementation
reduces the need to maintain multiple versions of the codebase,
and removes the perceived ‘bloat’ from installing new software.
BRISC-V emulator was built with simplicity and extensibility in
mind.
2 BRISC-V EMULATOR
The whole emulator is written in javascript, and runs on the user’s
computer. The emulator can be ran in three ways: (1) the student
can download it and run it, i.e. by unzipping a directory and click-
ing on a index.html file which opens in the browser, (2) hosted by
a teaching assistant which would give out students a link to access
the emulator, or (3) from our website, located at
http://ascslab.org/research/briscv/emulator/emulator.html.
After the page is loaded, all further processing is done on the
students computer. This is beneficial when hosting the emulator
for a large class, as the server can cache the website, and performs
no other processing once the site is loaded.
The emulator is roughly split into three parts: the parser, the em-
ulator, and the GUI, as seen in Figure 1. The user writes RISC-V as-
sembly code in an external text editor, and loads the code through
the website. The parser first wraps the code with the kernel code,
which consists of the front-end code setting register states as well
as the stack pointer, and backend code which contains an infinite
loop used in place of an exit system call. The parser then parses
the code and produces a list of instruction objects and a label map.
Each element in the instruction list is an object containing a list of
symbols, the instruction type (instruction, label, pseudo-instruction,
directive, or error), the line number in the original file, and a in-
struction address. The label map maps labels to appropriate in-
struction addresses.
The emulator accepts the instruction list and label map, and ini-
tializes an array of registers and a memory map. The registers are
small enough and frequently used enough that we create a simple
array to store them. We use a map for the memory as most pro-
grams will not allocate large amounts of memory. When a certain
address is accessed, if not already present, it is created in the map,
where the key is the address and the value is provided by the pro-
gram. The emulator provides several functions tied to GUI buttons:
(1) stepping through one instruction, (2) running the code until
the backend infinite loop or a breakpoint is hit, and (3) initializing
the emulator. The single_step function takes the instruction at
the current instruction pointer (IP) and depending on the type of
instruction, updates the registers, memory, and IP. How each in-
struction is handled (ADD, JALR, AUIPC, etc.) is hardcoded in the
emulator. The run instruction repeatedly calls the single_step
instruction until it detects that the PC has hit the backend kernel
infinite loop or breakpoint. The setup_emulator is used to initial-
ize or reset the emulator. It calls the appropriate parser functions,
stores parsers outputs, and initializes the registers and memory.
Parser Emulator
GUI
Registers Memory
Kernel 
code 
Parsing errorsÊ
Emulator state & user commands
User
code 
User
Figure 1: The emulator pipeline.
3 USING THE BRISC-V EMULATOR
Figure 2 shows a screenshot of the current version of the emula-
tor web-page. The page is split into three columns. In the middle
column, we have buttons for loading assembly, running the loaded
code, stepping through one instruction, and restarting the emu-
lator 1 . Below the buttons is a code editor 2 (though currently
read-only). The editor shows both the kernel lines 3 (with a grey
background), as well as user’s code 4 (with a white background).
The current instruction is highlighted blue 5 . Each instruction has
an instruction pointer before it 6 (shown here in decimal). Right-
clicking on an instruction opens a context menu where the user
can set or remove a breakpoint at the selected instruction. When
running the code (not stepping through it), the run will stop when
hitting a breakpoint. This allows the user to skip large parts of as-
sembly and quickly debug regions of interest. The editor allows
code-folding, where the user can hover left of any label and a +
symbol appears. Clicking the symbol folds/unfolds the instructions
between the specified and the next label.
On the left-hand column, the user can monitor registers 7 and
view the instruction at the current IP in binary 8 . The register file
displays the values of all 32 registers in decimal, hexadecimal or bi-
nary representations. As the IP progresses through the code, some
registers will change values, and this change will be highlighted
by changing the background of the appropriate register to red. At
the same time, each new (non-pseudo) instruction will be broken
down to its 32bit instruction format, shown on the bottom-left side
of Figure 2 8 . The elements in the top row of this table signify the
bitrange of the column. The middle row specifies which part of the
instruction is shown in the column, and changes with instruction
type, i.e., R-type instructions will have columns funct7, rs2, rs1,
funct3, rd, opcode, while I-type instructions will have one less
column, as funct7 and rs2 are replaced with imm.
On the right column is the memory visualization 9 table. It is
a descending list with 5 foldable regions: the stack segment, free
space, heap segment, data segment, and text segment. Each line
represents one word (32 bits). The address is shown on the left
in hexadecimal format (light blue), and the value is shown on the
right. Lines belonging to the text segment also contain a comment
specifying which instruction is stored at that location. Same as
with labels in the code (middle) column, each of the segments can
be folded. Figure 3 depicts the memory management layout.
Stack Segment
Free Space
Heap Segment
Data Segment
Text Segment
Free Space
Variable 
Size 
Fixed 
Size LowerÊ 
Addresses 
HigherÊ 
Addresses 
Stack  
Bottom 
Stack  
Top 
Figure 3: Emulator program memory management.
4 EXTENSIBILITY
While there exist more mature RISC-V emulators like the RISC-V
Angel [1], we choose to write our own for multiple reasons: (1)
RISC-V Angel seems focused more on performance (booting Busy-
Box in seconds) than on showing the state of the processor at every
instruction, (2) RISC-V Angel is harder for students to modify. We
aim to provide students with a simple, ‘hackable’ tool which they
can use in computer organization classes to get familiar with as-
sembly, in computer architecture classes to test out existing ISA
extensions (i.e. floating point or vector instructions) and confirm
their compiled code behaves as expected, and in hardware security
classes to quickly test out new security ISA extensions.
As an example, to implement the multiplication operations MUL,
MULH, MULHU, MULHSU proposed in the RISC-V specification [2], one
needs to:
(1) Add the MUL, MULH, MULHU, MULHSU to the instructions.js
file containing instruction names.
(2) Edit the parser.js file so that these instructions are parsed
with the two source registers and a destination register. This
requiresminimal coding as the registers are already extracted
by the parser.
(3) Add a new case condition in the emulator.js that on a MUL*
instruction (1) updates the IP by 4, and (2) puts the correct
multiplication result in the correct register. The emulator
already has the registers as local variables, so the user just
needs to refer to the appropriate ones.
2
Figure 2: A screenshot of the BRISC-V emulator user interface.
5 CONCLUSION
We introduced in this brief the BRISC-V emulator that targets the
RISC-V architecture. The emulator is meant to be used as a teach-
ing tool, as currently many computer organization and computer
architecture classes are migrating to RISC-V. The emulator is writ-
ten in vanilla javascript, and the user only needs to open an HTML
page to use it. It does not require any installation, simplifying class
setup as no admin access is needed on student machines. The em-
ulatorwill bemade available at the following address uponpublica-
tion: http://ascslab.org/research/briscv/emulator/emulator.html.
REFERENCES
[1] RISC-V Foundation. 2018. RISC-V Angel Emulator. (2018).
https://riscv.org/software-tools/riscv-angel/
[2] "RISC-V Foundation". 2018. RISC-V Specification. (2018).
https://content.riscv.org/wp-content/uploads/2017/05/riscv-spec-v2.2.pdf
3
