Mesen is a cross-platform (Windows & Linux) NES/Famicom emulator built in C++
Go to file
2017-12-27 13:36:09 -05:00
Core Movies: Fixed issue with disable PPU reset option 2017-12-27 13:36:09 -05:00
Dependencies Build: Statically link the C++ runtime for all build configs 2017-05-15 20:33:38 -04:00
DependencyPacker Version Update: 0.7.1 2017-02-18 15:46:01 -05:00
GUI.NET UI: Fixed crash when checking for updates 2017-12-27 13:20:20 -05:00
InteropDLL Debugger: Added highlight modes based on CDL flags to memory viewer 2017-12-26 17:33:46 -05:00
Linux Linux: Fixed compilation warnings 2017-11-29 23:37:23 -05:00
Lua Debugger: LUA scripting 2017-08-30 18:31:27 -04:00
PGOHelper Code refactoring (patch/archive handling) + allow HD packs to be loaded from archives 2017-07-30 09:46:07 -04:00
SevenZip Build: Statically link the C++ runtime for all build configs 2017-05-15 20:33:38 -04:00
TestHelper Code refactoring (patch/archive handling) + allow HD packs to be loaded from archives 2017-07-30 09:46:07 -04:00
UpdateHelper Version Update: 0.7.1 2017-02-18 15:46:01 -05:00
Utilities Input: Added UI for family basic tape recorder 2017-11-24 21:38:12 -05:00
Windows Input: Make left and right shift behave the same way (as they were meant to) 2017-12-20 19:03:31 -05:00
.gitattributes Initial commit 2014-06-10 16:58:37 -04:00
.gitignore Input: Added support for ~20 new peripherals (Incomplete, more fixes/changes to come) 2017-11-19 23:08:23 -05:00
build.sh Linux: Enabled LTO for clang (+25-30% performance) 2017-12-07 22:52:18 -05:00
makefile Linux: Enabled LTO for clang (+25-30% performance) 2017-12-07 22:52:18 -05:00
Mesen.sln Debugger: LUA scripting 2017-08-30 18:31:27 -04:00
README.md Linux: Enabled LTO for clang (+25-30% performance) 2017-12-07 22:52:18 -05:00

Mesen is a cross-platform NES/Famicom emulator for Windows & Linux built in C++ and C#.

If you want to support this project, please consider making a donation:
Donate to this project using Paypal

Website (https://www.mesen.ca)
Documentation (https://www.mesen.ca/docs)

Releases

Windows

The latest version is available on the website. Older releases are available from the releases tab on GitHub.

Ubuntu

The official releases (same downloads as the Windows builds above) also contain the Linux version of Mesen, built under Ubuntu 16 - you should be able to use that in most cases if you are using Ubuntu.

The Linux version is a standard .NET executable file and requires Mono to run - you may need to configure your environment to allow it to automatically run .exe files through Mono, or manually run Mesen by using mono (e.g: "mono Mesen.exe").

The following packages need to be installed to run Mesen:

  • mono-complete
  • libsdl2-2.0
  • gnome-themes-standard

Arch Linux

Packages are available here: https://aur.archlinux.org/packages/mesen

Roadmap

Things that may or may not be added in the future, in no particular order:

-Support for more UNIF boards and more NES/Famicom input devices
-Debugger improvements (APU state display, etc.)
-Shaders
-Libretro support
-TAS editor

Compiling

Windows

  1. Open the solution in VS2015/2017
  2. Compile as Release/x64 or Release/x86
  3. Run

Linux

To compile and run Mesen under Linux, you will need:

  • A recent version of clang/gcc
  • Mono 4.2.1+ (package: mono-devel)
  • SDL2 (package: libsdl2-dev)

The makefile contains some more information at the top. Running "make" will build the x64 version by default, and then "make run" should start the emulator.
LTO is supported under clang, which gives a large performance boost (25-30%+), so turning it on is highly recommended (see makefile for details).

LICENSE

Mesen is available under the GPL V3 license. Full text here: http://www.gnu.org/licenses/gpl-3.0.en.html

Copyright (C) 2017 M. Bibaud

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.