Skip to content

Optimization for Nintendo 64

Hardware and hardware setup.

Nintendo 64 emulation requires at a bare minimum a Raspberry Pi 2 and a Raspberry Pi 3 is highly suggested due to its increased performance.

Suggested overclock for Raspi 3 for optimal N64 emulation (This to be paired with proper power, cooling, please see this article for further information.)

please note that these are just suggested settings, the manufacture of Pi's silicon can differ from unit to unit so while some have reported success with clock speeds above 1300 and v3d_freq up to 525 you may not be able to hit that stably. Some trial and error is suggested.

Raspberry Pi 3 Model B

#Overclock Settings

Raspberry Pi 3 Model B+ (Highly Experimental) moderate overclock

#Overclock Settings

Raspberry Pi 3 Model B+
Heavy Overclock settings only recommended for those who do not mind blowing warranty and have proper cooling.

#Overclock Settings

Of most important note of categories that most correctly benefit the Nintendo 64 is v3d_freq this is not a setting that when increased fails warranty or even really has a huge impact on heat but it has a great effect on higher performing emulators such as N64 and Dreamcast.

Run Command (rom compatibility lists are all in need of retesting with new hardware sets and updates to software) To learn the community tested optimal settings please view either of the 2 rom compatibility lists located here or here. Current Default Emulator is mupen64plus-auto and default render should be 640x480 This can be scaled up for some games that perform really well like Mario kart and Super Mario 64 at your own discretion.


The CPU governor can be throttled to max performance mode in one of two ways.

echo "performance" |sudo tee /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor

Or you can enable it from Runcommand Go to Retropie-Setup - Setup and Configuration to be used post install - Configure the runcommand launch script - cpu configuration force performance then cancel exit and reboot

Enabling Frame Skip

modify your mupen64plus.cfg file to enable frame skipping

sudo nano -w /opt/retropie/configs/n64/mupen64plus.cfg

Edit the variable below from false to True


Test your game with it by ensuring that when the game launches you press any button and select the emulator for the rom to gles-rice

Essentially this forces the game to skip every other frame while it hurts perfect emulation it can be a big help to unplayable games to almost playable. In example modifying this variable doubles the framerate in Crusin USA from 10 to 20 and the game goes from abysmal to slightly playable.

Notes on Audio


Use HDMI as composite requires more CPU usage.

High Resolution Texture Packs

From Current version forward Hi Resolution Texture options are automatically configured to True in the configuration files. You should not need to modify them as you did with previous versions.

If it is critical to check that everything is enabled simply run this command in one line

cat /opt/retropie/configs/n64/mupen64plus.cfg | grep Textures && cat /opt/retropie/configs/n64/mupen64plus.cfg | grep txHiresEnable

and you should get a result looking like

LoadHiResTextures = True DumpTexturesToFiles = False txHiresEnable = True txHiresEnable = True

Which will confirm that Hi Rez is turned on for both Glide and Rice Plugins

Make sure you have launched a rom with both Rice and Glide before checking the file or the variables will not be there to confirm.

Glide Line

# Use high-resolution texture packs if available.
txHiresEnable = False

Rice Line

# Enable hi-resolution texture file loading
LoadHiResTextures = False

You would then place high res texture packs in the directory /home/pi/.local/share/mupen64plus/hires_texture

Download the texture packs to that directory and then unzip them:

mkdir /home/pi/.local/share/mupen64plus/hires_texture
cd /home/pi/.local/share/mupen64plus/hires_texture

wget http://websitewithtexturepack/
sudo unzip

Texture packs are available for download here

The folder name in that directory must match the core name in the rom header. Most cases the default directory name is ok but you may need to check if you find if your rom is not correctly launching the texture pack.

To find that you can use the command to display the core name just use the command below in terminal then exit and scroll up I do it from a ssh session cause I can scroll up and read it. But in the first few lines it will show the core name

cd /home/pi/RetroPie/roms/n64
/opt/retropie/emulators/mupen64plus/bin/ mupen64plus-video-rice rom name

You can use the same command to launch the rom correctly loading the texture pack.

To get the texture pack to load from emulation station you must do the following. Launch Retropie Setup Update Retropie Setup Script Go to Manage Packages update the mupen64plus package (I Suggest installing from source)

Go to launch one of the N64 games you have uploaded a high resolution texture pack for. Launch that game Press x or any key when it launches change the video mode to one of the following options mupen64plus-gles2rice-highres or mupen64plus-GLideN64-highres

Then hit launch

Please also feel free to reference the Rice 64 github page for the source documentation

Quality of Roms There is a definite difference in some roms. There are multiple versions of the SOTE rom some of which have noticeable stuttering and seizure screens but there are clean versions which play without the buggy effects. I believe some of this could be due to the core name in the rom header not correctly matching what is in the .ini files for different plugins which apply different effects per game or could be as simple as bad rips which were never noticed on more powerful hardware.

Optimizations to mupen64plus.cfg

These are all experimental settings I am playing with


# Size of texture cache in megabytes. Good value is VRAM*3/4
CacheSize = 900

# Enable N64 depth compare instead of OpenGL standard one. Experimental.
EnableN64DepthCompare = True

# Allow to use alpha channel of high-res texture fully.
txHiresFullAlphaChannel = True

# Save texture cache to hard disk.
txSaveCache = True
# This is currently set to True Investigating if setting to false will overload ram or not If texture cache is 500 by default is there enough overhead on ram to go with this setting.