SPIM A MIPS32 Simulator

James Larus

spim@larusstone.org Microsoft Research

Formerly: Professor, Computer Sciences Department, University of Wisconsin-Madison

spim has moved to SourceForge.org. New versions of spim are at that site. This site only contains old versions of the simulator.

Why move? SourceForge offers a number of services, such as a source code repository and collaborative tools, that make it easier to share code with other developers. Now that spim has an open source license, the time has come to move off a 20-year old web site and join the 21st century.

What's New? QtSpim is a new user interface for spim built on the Qt UI framework. Qt is cross-platform, so the same user iterface and same code will run on Windows, Linux, and Mac OS X (yeah!). Moreover, the interface is clean and up-to-date (unlike the archaic X windows interface). Spim has moved to SourceForge! The source code for all version of spim are in an SVN repository and compiled version are available for download. There is also a bug tracker and discussion forum.

spim is a self-contained simulator that runs MIPS32 programs. It reads and executes assembly language programs written for this processor. spim also provides a simple debugger and minimal set of operating system services. spim does not execute binary (compiled) programs.

spim implements almost the entire MIPS32 assembler-extended instruction set. (It omits most floating point comparisons and rounding modes and the memory system page tables.) The MIPS architecture has several variants that differ in various ways (e.g., the MIPS64 architecture supports 64-bit integers and addresses), which means that spim will not run programs compiled for all MIPS processors. MIPS compilers also generate a number of assembler directives that spim cannot process. These directives usually can be safely ignored.

Earlier versions of spim (before 7.0) implemented the MIPS-I instruction set used on the MIPS R2000/R3000 computers. This architecture is obsolete (though, never surpassed for its simplicity and elegance). spim now supports the more modern MIPS32 architecture, which is the MIPS-I instruction set augmented with a large number of occasionally useful instructions. MIPS code from earlier versions of SPIM should run without changes, except code that handles exceptions and interrupts. This part of the architecture changed over time (and was poorly implemented in earlier versions of spim). This type of code will need to be updated. Examples of new exception handling are in the files: exceptions.s and Tests/tt.io.s.

spim comes with complete source code and documentation. It also include a torture test to verify a port to a new machine.

spim implements both a terminal and a window interface. On Microsoft Windows, Linux, and Mac OS X, the spim program provides the simple terminal interface and the QtSpim program provides the windowing interface.

spim turned 20 years old January 2010. I wrote the original version of spim as the target machine for my first compiler class at University of Wisconsin, Madison in the spring semester 1990. spim is likely older than most of the students currently using it!

As a birthday present, the 8.0 version of spim has a simpler, less restrictive license, namely the standard BSD license.

The newest version of spim is called QtSpim, and unlike all of the other version, it runs on Microsoft Windows, Mac OS X, and Linux—the same source code and the same user interface on all three platforms! QtSpim is the version of spim that currently being actively maintaned. The other versions are still available, but please stop using them and move to QtSpim. It has a modern user interface, extensive help, and is consistent across all three platforms. QtSpim makes my life far easier, and will likely improve yours and your students' experience as well.

A compiled, immediately installable version of QtSpim is available for Microsoft Windows, Mac OS X, and Linux can be downloaded from: https://sourceforge.net/projects/spimsimulator/files/. Full source code is also available (to compile QtSpim, you need Nokia's Qt framework, a very nice cross-platform UI framework that can be downloaded from here).

Older Versions of SPIM The information in this shaded box describes the older versions of SPIM. Please use QtSpim instead.

Most Recent Versions of SPIM Platform Program Form File Unix or Linux system

Mac OS X spim

xspim Source code http://spimsimulator.svn.sourceforge.net/viewvc/spimsimulator/ Microsoft Windows (spim 7.0 and later versions no longer run on Windows 95/98. Use version 6.5 or earlier.) PCSpim Executable http://sourceforge.net/projects/spimsimulator/files/PCSpim_9.0.zip/download Source code http://spimsimulator.svn.sourceforge.net/viewvc/spimsimulator/ To run spim or xspim on a Unix, Linux, or Mac OS X system, get the source code from the SourceForge repository and compile it for your system.

To run PCspim under Microsoft Windows, download the file http://sourceforge.net/projects/spimsimulator/files/PCSpim_9.0.zip/download , unzip it, and click on setup.exe .

Source for the Microsoft Windows version ( PCspim ) is available SourceForge repository.

There is no native Macintosh version of spim (but there is a QtSpim version). However, xspim compiles and runs on Mac OS X, if you can find a way to install the Xaw library. Installing Older Versions of SPIM Microsoft Windows To run PCspim under Microsoft Windows, download the file http://sourceforge.net/projects/spimsimulator/files/PCSpim_9.0.zip/download. Unzip the file. Click on the setup.exe program. Unix, Linux, or Mac OS X (Note: the directions changed slightly for version 7.2, to reflect a new directory structure. Please read carefully.) Installation is a bit more complex for a Unix or Linux system, as you need to compile the program for your particular computer and operating system. Download the files from the SourceForge repository. You don't need the Boneyard directory, which contains old versions, but the other directories are useful.

The simple terminal interface is contained in the spim-8.0/spim directory and the X-windows interfaces is in the spim-8.0/xspim directory. The other directories are described in the README file.

Next, you must set the directories in which spim will be installed by editing the Makefile (the file that contains instructions on building spim). In general, if you are installing spim and want the windowing version (xspim), edit the file xspim/Imakefile . If you don't want xspim or are running on a system without X-windows installed, you use the file spim/Makefile.



The programs are installed in standard locations, but you can change the pathnames to other locations: EXCEPTION_DIR -- The full pathname of the directory in which to install the spim exception handler (exceptions.s). BIN_DIR -- The full pathname of the directory in which spim and xspim should be installed. MAN_DIR -- The full pathname of the directory in which the manual pages for spim and xspim should be installed.



In general, the remaining parameters in a Makefile need not be changed.

Then, if you are building xspim, change to the spim-8.0/xspim directory and type:



% xmkmf

% make

If you do not have a copy of xmkmf, you can use the Makefile in the xspim directory, but beware that it may not work on your system because the paths to the X windows libraries could be different.

If you do not have X-windows, change to thespim-8.0/spim directory, edit Makefile, and type:



% make

To run spim or xspim, the exception handler must be installed in the directory specified by the variable EXCEPTION_DIR in the Makefile. If the file exception.s is not installed, spim and xspim fail before they start running. You can either install this file by hand or by typing:



% make install



which also installs spim or xspim, and the manual pages in the directories that you set (above). You may need root permission to install these files, in which case type:



% sudo make install



To test that spim is correctly built, change to the spim-8.0/spim directory and type:



% make test



and examine the output of the test. (Note: the exception handler must be installed before running the test.)

The current version of spim is 9.0 (January 2011), which is a major release that introduces QtSpim and fixes some bugs in all versions:

Add Debian package and Linux desktop metadata.

Moved SVN repository to SourceForge.

Fit and finish bugs in PCSpim and error parsing quoted command line arguments.

QtSpim!!!

Single stepping hung at breakpoint.

Did not display first 4K of the stack.

Ported PCSpim to VisualStudio 2010.

Fixed type errors so code compiles under Linux and on x64 systems.

Moved version information into CPU/version.h and eliminated old, ad-hoc Configure file for spim and xpsim.

The current version of spim is 8.0 (January 2010), which is a minor release that cleans up bugs in 7.5 and moves to a BSD license:

Changed install path from /usr to /usr/local and removed -D option to install command (which doesn't exists on Mac OS X).

Change license to a BSD license, update copyright notices, and eliminated references to my old email address.

Simplify alignment of data on stack to ensure enough room is left for environment and args at top of stack.

Initialize stack with arguments when running program from run dialog.

read_input filled buffer with last character of file not terminated by newline.

Links to MIPS documentation were broken.

Did not return value from exit syscall.

The current version of spim is 7.5 (August 2009), which is a minor release that cleans up bugs in 7.4:

Correct problem with installer script that did not install appropriate versions of msvcrt and mfc dlls for Visual Studio 9.0.

Fix install scripts to put exceptions.s at /usr/lib/spim on Linux.

Fixed major memory leak caused by overwritten instructions not being freed.

Force redisplay of data segment in situations when register values (such as $sp) have changed.

Properly initialize PC at first invocation of step operation on PCSPim.

Fixed bug in Xxpim that caused the step commend to reinitialize the stack.

The current version of spim is 7.4 (January 2009), which is a minor release that cleans up bugs in 7.3:

1/14/09: Released new version of pcspim.zip to correct problem with installer script that did not install appropriate versions of msvcrt and mfc dlls.

1/21/09: Released new version of spim.tar.Z and spim.tar.gz to correct problem with install command for spim program (but not xspim).

Fixed install directories for Linux systems.

Retained command line arguments in second and subsequent runs.

Bug in overflow from low-order word in MADD, MSUB.

Bug in decoding SPECIAL2 instructions (e.g. madd).

The previous version of spim is 7.3 (August 2006), which is a minor release that cleans up a number of bugs in 7.2:

Fix for flex 2.5.33 (internal change broke spim's scanner).

Exception handler can be a semicolon-separated list of files that will be loaded in order. On Unix, SPIM_EXCEPTION_HANDLER environment variable is consulted before command line arguments.

Memory corruption caused spim to crash when label was defined twice in succession.

PCSpim updates register and memory display after a parse error while reading a file.

Eliminated unnecessary null char between strings in list of strings produced by .asciiz.

Makefiles (in spim/ and xspim/) now contain clearly defined paths for installing executables, exception handler, and man pages. The man pages are no longer installed by the "make install" command.

Change psfig to epsfig in spim.tex (does anyone still use this obsolete documentation?).

The previous version of spim is 7.2.1 (August 2005), which is a minor release that cleans up a number of bugs in 7.1:

Fixed multiple problems in memory mapped IO in xspim and spim. (Note: to make programming uniform across all three platforms, memory mapped IO now follows"Unix" handling of carriage return (CR) and new line (NL) characters . On input, a CR is translated to a NL, and on output, a CR is printed after a NL. This was previously true for PCSpim and xspim, but not spim.)

Fixed bug in indexed address computation in LW and SW instructions.

Eliminated non-POSIX flags IUCLC and IXANY to facilitate port to Mac OS X.

Use termios(3) library calls instead of IOCTLs to fix bug introduced in port from termio to termios struct.

Test default case for jalr, without default $rd (=31).

Trap handler in test extracted wrong bits from ExcCode field of Cause register.

Pervasive restructuring of files to put 3 UIs (spim, xspim, PCSpim) in separate directories and cleanup organization and Makefiles.

Use correct help file in install process.

Added work-around for bug in flex 2.5.31 that left yytext_ptr undefined.

Epilogue code restored $at register, then used a pseduo instructions that smashed it.

Cleared filename when reinitializing PCSpim, which broke next reload command.

The previous version of spim is 7.1 (January 2005), which is a minor release that cleans up a number of bugs in 7.0:

Minor cleanup.

Switched Windows installer to Microsoft .msi installer, from InstallShield.

exceptions.s used wrong mask for exception cause field.

Clearing the transmitter or receiver interrupt enable bits also clear interrupt pending bits in Cause register.

Code to poll for a console input character in X windows blocked and prevented any output until input occured.

Type of "mul" instruction was wrong, which lead to it being printed without destination register.

Print underlying instruction, not breakpoint.

Unparing error that unparsed beq as beql.

Eliminated dependence on obsolete termio.h in favor of POSIX termios.h since Mac OS X doesn't have termio.h any more.

Fix null pointer problem if no entries in registry.

Turn off EXL bit after break instruction, since break is handled by spim, not MIPS, code and the bit was never cleared.

Set default path for exceptions.s to C:\Program Files\PCSpim, the default installation directory.

Test for SQRT.S used double constant, which failed on SPARC (but not x86).

The previous version of spim is 7.0 (August 2004), which is a major release that contains a significant number of changes from version 6.5:

Upgraded simulator to MIPS32, Version 1 architecture (except details of FPU and memory).

Exceptions and interrupts reimplemented, to make them closer to the actual hardware.

Memory mapped IO console reimplemented to make it work properly.

Implemented timer in CPU.

Renamed "trap" to "exception" to correspond to MIPS terminology.

Introduced short forms of command line arguments and dropped need for "-file" argument.

Major internal cleanup and reorganization of code to eliminate unused code and simplify implementation.

PCSpim prompts about reinitialization when file reloaded.

PCSpim lets user set font.

Word align all segment boundaries and ensure sbrk returns word-aligned addresses.

Added new syscall (EXIT2_SYSCALL) that returns value from SPIM.

Improved implementation of delayed load instructions.

Refactored the test cases, so that endian-independent code is in tt.core.s

Many small bug fixes.

Outstanding bugs in 7.0:

The trap handler (exceptions.s) fails when the trapping instruction is in the delay slot of a branch or jump. The trap handler returns by simplemindedly adding 4 to the EPC (which is the branch's address in this case), so it does not return to the instruction executed after the trapping instruction.

Handling of newlines and carriage returns is inconsistent between platforms. When a program prints a newline, PCSpim also prints a carriage return, spim and xspim don't. Or, is this consistent with the underlying platform?

The previous version of spim is 6.5 (January 2003), which contains the following changes from version 6.4:

If started program is started with only one argument, assume it is a file name.

Added Alt-F4 shortcut to PCSpim.

Fixed trap.handler to return to instruction at EPC on interrupt.

Fixed (real!) hardware exception on integer overflow in division.

-trap_file did not properly parse argument in xspim.

Fixed printing of error on last line without a carriage return.

Print proper registers when printing hex FP numbers.

Properly zero newly allocated memory.

Added nops (addu $0, $0, 0) to trap handler, so that it works properly in bare mode!

PCSPIM.HLP file was corrupted.

The previous version of spim is 6.4 (January 2002), which contains the following changes from version 6.3:

PCSpim no longer shifts the focus of the register and data segments when values change.

Fixed bug in the expansion of USH pseudo-op.

Add system calls for open, close, read, and write.

Fixed the Configure file to work with Mac OSX.

Made the REM pseudo-op require 3 arguments.

Fixed PCSpim dumping code to dump contents of console window.

Treat LUI's immediate value as unsigned, as it is not sign extended.

More error checking for malformed programs.

Make symbol "main" as global.

Avoid clearing last few bytes of data segments when they expand.

Check that high-order 4 bits in jump instruction's PC match bits in target PC.

The previous version of spim is 6.3 (January 2001), which contains the following changes from version 6.2:

PCSpim interface simplified to 4 fixed panes, similar to xspim, which permit cut and paste.

PCSpim console stays on the screen after assembly program terminates.

Comments in assembly source displayed in text segment.

NOP is standardized to sll $0 $0 0 (= 0x00000000)

Fixed several bugs and missed optimization in computing immediate values in lw/sw instruction sequences.

High 2 bits in negative branch offsets were incorrect.

Display floating point registers with up to 18 digits of precision.

New spim command (print_all_regs) prints all registers.

Minor changes to compile spim under cygwin for Windows.

Validate the range of immediate values in MIPS (but not pseudo) instructions.

Fixed display of stack with non-word aligned $sp.

New flags: -delayed-branches Simulate MIPS delayed control transfers for branches, jumps, and calls -delayed-loads Simulate MIPS non-interlocked loads.



spim is copyrighted by James Larus and distributed under a BSD license.

Copyright (c) 1990-2010, James R. Larus. All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

Neither the name of the James R. Larus nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

The DOS and Windows ports were done by David A. Carley and are copyrighted y Morgan Kaufmann Publishers.

SPIMSAL Note

spimsal is an old version of spim that ran on PCs running Windows 3.1 and Macintoshes. spimsal implements an extended version of the MIPS instruction set and is based on an old version of spim. It also does NOT run under Windows 95 or Windows NT.