The Nintendo 64 has always been a difficult machine to emulate correctly. But in 2025 - we should be well and truly past all of it right? Not exactly. Issues with Plugins, performance, graphical glitches, stutters. Unless you have a very powerful machine, these are common things many of us will run into when emulating the Nintendo 64. But why? And Is there any hope for fast, accurate N64 emulation in 2025 and beyond?

  • glitchdx@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    2 days ago

    I had no issue emulating n64 games on my piece of shit machine almost 20 years ago. What even is this?

    • deltapi@lemmy.world
      link
      fedilink
      English
      arrow-up
      0
      ·
      edit-2
      2 days ago

      The first time I played ocarina of time, it was on a k6-2/450 with a voodo3-3000. It ran well enough that I considered it on par with a real N64. Edit: this would have been 2002/2003.

      • glitchdx@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        1 day ago

        i just didn’t want to say 25 years ago and have someone ‘um akshuly’ me about when emulation started getting viable.

        • deltapi@lemmy.world
          link
          fedilink
          English
          arrow-up
          0
          ·
          1 day ago

          To be fair, I was using ultrahle, which was a very high level emulator targeting mario64 and specifically needing a GLIDE-supporting card. It did well enough on ocarina as (my understanding is that) it used the same graphics engine as Mario64 and therefore the same function calls… but there were many other games that wouldn’t run at all.

  • LibertyLizard@slrpnk.net
    link
    fedilink
    English
    arrow-up
    0
    ·
    3 days ago

    Not sure if this is related but I’ve been using project 64 lately and the control stick seems way more difficult to use than the original hardware. Anyone know why this is? It makes it really tough to aim.

      • LibertyLizard@slrpnk.net
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 days ago

        Yeah that’s part of it but also it’s just really tough to do fine adjustments and it seems to jump all over the place. That’s the bigger issue though the lag is a compounding factor.

          • LibertyLizard@slrpnk.net
            link
            fedilink
            English
            arrow-up
            0
            ·
            2 days ago

            Tried that. The issue is that the it’s still too sensitive at the point the motion kicks in. Surprised p64 doesn’t have a sensitivity setting. Maybe another emulator would?

              • deltapi@lemmy.world
                link
                fedilink
                English
                arrow-up
                0
                ·
                1 day ago

                Last time I used project 64, I used a retrobrawler (the really plugs into a N64 one) and a raphnet adapter. It was great, and the stick control did feel better than an xb360 controller.

  • Bobby Turkalino@lemmy.yachts
    link
    fedilink
    English
    arrow-up
    0
    ·
    3 days ago

    I respect MVG a lot but this is honestly clickbait. All you have to do is:

    1. Download RetroArch
    2. Install Mupen64Plus-Next core
    3. Enable ParaLLEl RDP and RSP plugins in core settings

    and you can play every game without issues. Not a broken mess by any means.

    If you have resources leftover, you can even go into the core settings and turn internal resolution to 4x for better 3D graphics

    • A_Random_Idiot@lemmy.world
      link
      fedilink
      English
      arrow-up
      0
      ·
      2 days ago

      You didnt watch the video, did you?

      Cause the whole needing plugins and hacks to run games was exactly the point he was making, on why emulation of n64 is still in a poor shape, despite consoles before and after being emulated just fine without issue.

      • kadup@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 days ago

        The only reason we still have this plugin paradigm is because that’s how N64 emulator cultured evolved over time. That’s deliberate though, there’s no “mess” here.

        I can easily download a cycle-accurate N64 emulator that depends on zero plugins. However, being the N64, it obviously takes a lot of power to emulate in such an accurate way.

      • frezik@midwest.social
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        2 days ago

        Right, and on different platforms, too. Yes, your gaming PC can do it fine, but a PS Vita should have the horsepower to do it, too, and that’s not where things are at.

        And then there’s homebrew stuff. Works fine on real hardware, but emulators often fail.

    • rhombus@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      FPGA mimics hardware 1:1 without overhead, which is why it works well. This is talking about software emulation, which has to use lots of shortcuts to make it fast enough (for most machines). The N64 has a weird architecture though that makes it difficult to find shortcuts that work well.

      • frezik@midwest.social
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 days ago

        People tend to overstate FPGAs. They are designed as software in a funny programming language and then “burned in” to hardware. They can and do have inaccuracies and bugs.

        In the long run, real hardware is going to disappear through the attrition of time, so we do need this stuff for the sake of preservation. But people tend to put it on a pedestal without really understanding it.

        • rhombus@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 days ago

          I did some FPGA programming in school, so I totally get it. The hardware is really amazing, but the janky proprietary development toolchains not so much. Plus, Verilog is kind of a pain in the ass.

        • kadup@lemmy.world
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 days ago

          Even hypervisors can have software bugs - running GBA games on the ARM9 core in the DSi is possible and even closer to “actual hardware” than a FPGA, but there are still weird side cases and glitches that only happen on this setup rather than actual GBA hardware.

          FPGAs aren’t some magical hardware clone that bypasses software issues.

          • deltapi@lemmy.world
            link
            fedilink
            English
            arrow-up
            0
            ·
            1 day ago

            That depends on the accuracy of the core on the FPGA.

            Your comparison of GBA on dsi is kinda like saying “my dos games didn’t work well on my windows 2000 computer” same cpu sure, but OS and hardware ‘locations’ aren’t necessarily the same.

            • kadup@lemmy.world
              link
              fedilink
              English
              arrow-up
              0
              ·
              1 day ago

              on the accuracy of the core on the FPGA.

              Or in other words, FPGAs aren’t miracle hardware clones and depend on the quality of their programming. Exactly as I said, got it.

              Your comparison of GBA on dsi is kinda like saying “my dos games didn’t work well on my windows 2000 computer” same cpu sure, but OS and hardware ‘locations’ aren’t necessarily the same.

              Which is why I mentioned it’s an hypervisor, not running as if it were natively supported. It’s more analogous to original hardware than a FPGA, though. Your analogy to DOS and Windows 2000 however shows you really do not understand how GBA2Runner or FPGAs work in general.

              Your comment is got any point or it’s just these two incoherent sentences?

              • deltapi@lemmy.world
                link
                fedilink
                English
                arrow-up
                0
                ·
                edit-2
                1 day ago

                Wow you’re unnecessarily aggressive and oppositional. Who hurt you today?

                FPGAs can absolutely be used to provide cycle accurate hardware replacements. The fact that they guarantee realtime execution of instructions also makes it easier to achieve cycle-accurate execution than can be achieved with emulation.

                I’m not claiming FPGAs are a magic bullet, but when it comes to offering a retro gaming experience they offer a number of advantages for accuracy that is incredibly difficult to achieve with emulation, and with input latency far closer to the original experience than an emulator can offer.

                Edit: Oh, and since you crapped on my parable, educate yourself with a Google search for “ntvdm”

                • kadup@lemmy.world
                  link
                  fedilink
                  English
                  arrow-up
                  0
                  ·
                  1 day ago

                  FPGAs can absolutely be used to provide cycle accurate hardware replacements.

                  And the sky is bright blue. Who said otherwise?

                  easier to achieve cycle-accurate execution than can be achieved with emulation.

                  Good thing my comment never claimed software emulation is easier then. Do if you are trying to “correct” somebody, I can do the same: FPGAs are still emulation.

                  I’m not claiming FPGAs are a magic bullet

                  Then your comment isn’t relevant, because the only thing my comment ever said is to be careful with the marketing and comments claiming FPGAs are instantly accurate and perfect hardware clones.

                  but when it comes to offering a retro gaming experience they offer a number of advantages

                  Thanks ChatGPT

                  accuracy that is incredibly difficult to achieve with emulation

                  FPGAs are emulation. Also, given an arbitrarily powerful CPU, there’s always a way to perfectly recreate the same result in software. It just obviously isn’t practical for complex systems.

  • Endymion_Mallorn@kbin.melroy.org
    link
    fedilink
    arrow-up
    0
    ·
    3 days ago

    An interesting video, but I don’t really feel it got to answer the question posed. He also didn’t, for me, answer why he wants to focus on LLE instead of HLE as it’s been obvious that LLE is very resource intensive.

  • pixxelkick@lemmy.world
    link
    fedilink
    English
    arrow-up
    0
    ·
    3 days ago

    The core if it boils down to, when emulating older machines, is the consoles processor speaks language A, and our computers all speak language B

    The emulator has to translate back and forth between A<->B faster than the speed the original processors would’ve just spoken A

    So translating A<->B is a way tougher task than just reciting A. So you need a tremendously better CPU than what the console had to emulate it.

    It’s kinda like, Dropping a rock in a pile of sand is easy. Simulating dropping that rock into the pile of sand in real time accurately is really challenging.

    • CileTheSane@lemmy.ca
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      Emulators exist for the Switch. So it’s not just the fact that the emulator needs to translate, there is something specific about the N64’s ‘language’ that makes translating more difficult and time consuming.

      • Ledivin@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        2 days ago

        The easiest way I could describe it, is that the languages are much, much more similar. Translating for the switch is like going from Spanish to Latin, while the N64 is more like going from Chinese to Latin - much less 1-to-1 and objective.

      • Fondots@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        The “language” that the n64 used was basically in a totally different language family than what PCs and later Nintendo consoles use.

        Think of it as if the N64 spoke Japanese, while PCs speak Spanish. There’s a lot of things that don’t translate cleanly from one language to the other, you can’t just feed it into google translate and expect what comes out the other end to make sense, you’re going to need someone who understands both languages to go over it, rewrite some of it to make sure all of the nuance is coming through, add some asterisks and translation notes to explain some concepts that don’t really have a direct equivalent in the other language, etc.

        Later Nintendo consoles spoke something more like Portuguese or maybe even Mexican Spanish instead of PC’s Castilian Spanish. They’re much more similar languages that translate more directly and some things may not even really need translation as long as both parties slow down, speak clearly, and maybe throw in some hand gestures here and there, and google translate will get you like 99% of the way there, without the translator needing to add as many explanatory notes.

        All those translation notes are what the emulator is doing, and the N64 to PC emulator has to do a lot more interpreting than the Switch to PC emulator.

      • rhombus@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        There isn’t actually a ton of translating going on with the Switch, as it’s basically just a computer (an ARM computer, but still). The N64 had a very different architecture that doesn’t work like modern computers do. On top of that, games on it relied on low level graphics code that makes it very difficult to cheat like other emulators do.

      • otp@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        3 days ago

        EDIT: Sorry, I mixed up my comment chains.

        Is Switch emulation HLE? Because if so, the Switch isn’t relevant to what the other commenter is explaining.

        HLE just means the emulator needs to have the same output as the Switch.

        LLE means the Emulator is kind of running an entire Switch.

        There’s a difference.

        EDIT: I think it’s more that the Switch’s “language” is much closer to a computer’s “language” today. Older consoles were complex beasts built completely differently from contemporary computers, let alone modern ones.

    • Feyd@programming.dev
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      It’s even more complicated than that, because for full accuracy, it must also emulate the clock speed at which the emulated processor ran, as well as the various memory busses etc

    • magic_lobster_party@fedia.io
      link
      fedilink
      arrow-up
      0
      ·
      3 days ago

      Not only that. Emulators must often ”cheat” to achieve high speeds. This means emulators doesn’t try to achieve a 1:1 replication of what’s happening inside the hardware, but something that’s gives close enough results and better tailored for modern hardware.

      The reason why N64 is particularly difficult is because each game must be optimized individually (due to the heavy reliance on microcode). The emulator must replicate the hardware at a much lower level for an accurate emulation of all games. Emulator developers can apply optimizations on each individual game, but it’s incredibly time consuming to do so for every game in the N64 library.

      • umbrella@lemmy.ml
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        3 days ago

        why is its reliance on microcode making it so difficult? i tought this was the case across the board?

        • yetAnotherUser@discuss.tchncs.de
          link
          fedilink
          English
          arrow-up
          0
          ·
          3 days ago

          According to: https://emulation.gametechwiki.com/index.php/Nintendo_64_emulators

          One of the biggest hurdles to emulating the Nintendo 64 was the Reality Display Processor (RDP), which used a custom design that had to be fine-tuned to get higher performance out of the system using microcode. To emulate the RDP accurately, one would have to execute said microcode the way the RDP did, which differed from the PC graphics cards of the day. To complicate matters further, API standards available on PCs two decades ago were nowhere near as flexible as they’re today. If you wanted to make an accurate GPU-accelerated RDP plugin in 2003, you simply couldn’t with the APIs of the time (OpenGL 1.x and Direct3D 9).

          Accurate low-level emulation would only come to the GPU in 2020 when a new version of the Mupen64Plus-based ParaLLEl libretro core was released containing a rewritten RDP plugin using compute shaders in Vulkan.

      • TachyonTele@lemm.ee
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        And that’s the reason MVG is telling other devs: stop using those cheats, if the sceen is going progress they have start using low level standards.

  • Rentlar@lemmy.ca
    link
    fedilink
    English
    arrow-up
    0
    ·
    3 days ago

    Back in 2015 I used the emulator “1964” to play some MarioKart64 and it ran well on a very weak computer, fwiw.

    • magic_lobster_party@fedia.io
      link
      fedilink
      arrow-up
      0
      ·
      3 days ago

      The video says that emulation has always worked better on popular games. But if you try to emulate a less popular game, you will run into major issues. This is because the emulation must be tweaked for each game specifically due to how N64 hardware works.

      • 🔍🦘🛎@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        I’ve never been able to play though Goemon’s Great Adventure on emulation. It always hits a game-breaking crash :/

        • DarkFuture@lemmy.world
          link
          fedilink
          English
          arrow-up
          0
          ·
          2 days ago

          Oddly enough this is the game I was trying to get to work a handful of years ago when I last gave N64 emulation a shot so I could play it with a friend. Ended up realizing the N64 emulation scene just wasn’t there yet. Guess it’s time to give it another go.

        • samus12345@lemm.ee
          link
          fedilink
          English
          arrow-up
          0
          ·
          3 days ago

          Where is the crash? I have it playing via the official N64 app on my modded Switch, but haven’t gotten very far. Wondering if the issue still exists there.

          • 🔍🦘🛎@lemmy.world
            link
            fedilink
            English
            arrow-up
            0
            ·
            2 days ago

            Turtle Island, it’s like world 4 or so. Hopefully it’s been updated, I haven’t tried again for probably 8 years

      • Altima NEO@lemmy.zip
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        Especially Nintendo’s own games. Mario 64, Mario kart, etc, were usually the first to be emulated correctly.

    • Altima NEO@lemmy.zip
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      Kaze just works on Mario 64. He’s torn that game up and rebuilt it for his needs. He’s even mentioned that emulators won’t even work with some of the hardware tricks that he utilizes.

    • KRAW@linux.community
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      Just Mario 64. However there is a very good implementation of the N64 in the Mister FPGA project. The downside is there aren’t many emulation features that you’d expect out of a software emulator (e.g. save states)

  • TachyonTele@lemm.ee
    link
    fedilink
    English
    arrow-up
    0
    ·
    3 days ago

    I didn’t have time to watch the video at the moment. What’s wrong with Dolphin?

      • OR3X@lemm.ee
        link
        fedilink
        English
        arrow-up
        0
        ·
        edit-2
        3 days ago

        Yes, you are correct Dolphin will not play N64 ROMs directly. It will however play SOME Wii virtual console games which includes around 22 N64 games. Soooo, sorta?? 🤷‍♂️

            • lime!@feddit.nu
              link
              fedilink
              English
              arrow-up
              0
              ·
              edit-2
              3 days ago

              no but, how do you make it handle n64 games? i’m interested in setting this up. like i have this old rom of airboarder 64, which to my knowledge was not on the gamecube, and it emulates terribly. how do i set it up to run with dolphin?

              • TachyonTele@lemm.ee
                link
                fedilink
                English
                arrow-up
                0
                ·
                edit-2
                3 days ago

                I just use the wiiware games. It covers pretty much all the N64 games I care about.

                It’s funny, I can picture the Airboarder cover in my head. Kinda crazy how those things can get burned into your memory.

        • Sabin10@lemmy.world
          link
          fedilink
          English
          arrow-up
          0
          ·
          edit-2
          3 days ago

          Then you are playing virtual console roms/injections, which typically have more issues than current proper n64 emulators.

          If it’s good enough for you, that’s fine but it’s far from perfect.

            • Sabin10@lemmy.world
              link
              fedilink
              English
              arrow-up
              0
              ·
              3 days ago

              If you are only playing officially released virtual console games then they only have minior issues, Nintendo did a really good job with n64 on the Wii. With injected roms you will run in to a lot more issues. Like I said, if it’s good enough for you then that’s fine but a proper n64 emulator will be more responsive and give you more options.

        • Zarxrax@lemmy.world
          link
          fedilink
          English
          arrow-up
          0
          ·
          3 days ago

          Ah, an emulator within an emulator. Yes, I’m sure the results must be just like the original hardware!

          • TachyonTele@lemm.ee
            link
            fedilink
            English
            arrow-up
            0
            ·
            edit-2
            3 days ago

            The games work just fine. I played them when they were new, and get just as much enjoyment out of them now.

            I’m not sorry i don’t care about milliseconds or whatever technical details the programmers care about. I am thankful for their hard work though.

            • Mojave@lemmy.world
              link
              fedilink
              English
              arrow-up
              0
              ·
              3 days ago

              How are you using dolphin to emulate N64?

              Dolphin has no native N64 emulation support. Are you using N64 ports from the Wii? Those are running using Nintendo’s Wii-based emulator (which also has known issues) on top of the Wii emulation. That introduced a whole second layer of technical issues.

              Not that the N64 roms aren’t playable, but the problem is more technical on why it’s so difficult to emulate the specific N64 hardware perfectly using just modern software

              • TachyonTele@lemm.ee
                link
                fedilink
                English
                arrow-up
                0
                ·
                3 days ago

                Thanks. Like i said i haven’t been able to check the video out yet.

                I am enjoying everyone jumping down my throat about being able to play n64 games with no issues though. It’s giving me a good laugh with my coffee.

                • BlueSquid0741@lemmy.sdf.org
                  link
                  fedilink
                  English
                  arrow-up
                  0
                  ·
                  3 days ago

                  People are jumping down your throat because you’re talking about N64 emulation being just fine on a GameCube emulator which plays a total of 21 of the 388 N64 games.

                  That’s fine that you only like those games, but it’s irrelevant to a discussion about N64 emulators and it’s only a tiny subset of games for the system.

                  You can see this right? Surely you understand that?

    • Kichae@lemmy.ca
      link
      fedilink
      English
      arrow-up
      0
      ·
      3 days ago

      “If you aren’t a programmer, don’t speak” is about what I expect from programmers, yes. That kind of elitism is why most programmer-only projects are utter shit.

      • hedgehog@ttrpg.network
        link
        fedilink
        English
        arrow-up
        0
        ·
        3 days ago

        This is even worse tbh, because, as someone else pointed out, the YouTuber is a programmer. This is saying “only write code, don’t discuss what kinds of changes are needed.”

        That + the “commit a pull request” nonsense (you submit a pull request, which comprises commits; the PR only gets committed when it’s been reviewed and merged by a maintainer) makes me doubt that the commenter you replied to has ever collaborated productively on a software project.