Did Nintendo really forget to Optimize Super Mario 64 ? | MVG

Поділитися
Вставка
  • Опубліковано 31 гру 2024

КОМЕНТАРІ • 2,1 тис.

  • @dsproductions19
    @dsproductions19 4 роки тому +845

    There was a reply on the original video about the -02 thing by Kaze Emanuar, who is a very knowledgeable Mario 64 hacker and modder. According to him, most of the slowdown in Dire Dire Dock is from the submarine's collision being dynamic, instead of static like most every other object in the game, and he even fixes it in his SM64 Multiplayer mod.

    • @ABVW92
      @ABVW92 3 роки тому +47

      I wonder if the submarine collision was just an oversight by the dev team, or if they actually had a reason for it being dynamic.
      Perhaps time constraints and cut content?

    • @Kaleidio
      @Kaleidio 3 роки тому +104

      @@ABVW92 They probably thought it needed to be dynamic since the submarine eventually disappears.

    • @ABVW92
      @ABVW92 3 роки тому +8

      @@Kaleidio I genuinely hadn't even thought about that.
      Interesting :p

    • @scottmjohnson1980
      @scottmjohnson1980 2 роки тому +1

      YOU'RE dynamic

    • @nottoofast
      @nottoofast 2 роки тому +8

      @@scottmjohnson1980 What a hilarious and witty comment. Thank you, Scott Johnson, the artist famous for his promotional art made for Marvel comics, specifically his drawings of Spider-Man that could be found on all sorts of merchandise throughout the 2000s and early 2010s.

  • @boris3320
    @boris3320 4 роки тому +123

    The real question is why was - O2 enabled on the pal version

    • @torst3in
      @torst3in 3 роки тому +54

      Released 5 months later in EU.

    • @LonelySpaceDetective
      @LonelySpaceDetective 3 роки тому +43

      I think the better question is why they never put out an revision built with -O2 for USA. I mean, they had to print new cartridges at some point; why not toss in an optimized ROM now that you know it doesn't break anything?
      Perhaps I'm just unfamiliar with the logistics of cartridge manufacturing.

    • @williamdrum9899
      @williamdrum9899 3 роки тому +18

      @@LonelySpaceDetective Sometimes when you fix one bug you end up creating more

    • @thewhitefalcon8539
      @thewhitefalcon8539 3 роки тому +6

      Maybe something to do with PAL versions only getting 25 FPS instead of 30 to begin with.
      It's pretty strange to get variable framerates on a console actually. Usually at the end of a frame a console game waits for the next frame, so if it takes longer than one frame to process one frame, when it waits for the frame to end it's actually waiting for the next one, and it ends up taking whole 2 frames total, therefore (assuming it started at 30 FPS) getting 20 FPS (3 frames per frame) or 15 (4 frames per frame) instead of 30 (2). IDK how you can get 27 FPS that way.

    • @RyoLeo
      @RyoLeo 3 роки тому

      @@thewhitefalcon8539 would the drop in frame rate be because it didn’t process the information soon enough? And by information I mean both gameplay variables and graphics rendering.
      My biggest question is how does it ensure that the tv still drawls “perfect” images with variable frame rates. My best guess is that it will hold a frame until the next screen reset. But I have yet heard anyone mention that before. Also there the issue, which I think you were trying to get at, of frame buffering stacking. But eh

  • @the_kovic
    @the_kovic 4 роки тому +579

    So the answer is, they didn't "forget" out of some negligence or incompetence, it was a safety decision. But there is no denial the game runs better with -O2, and not insignificantly! 1 or 2 frame difference is a lot when you are in a

    • @johneymute
      @johneymute 3 роки тому +29

      So true so this video turned almost to be just a (f) waste of time,almost.

    • @ABVW92
      @ABVW92 3 роки тому +62

      @@johneymute I wouldn't say it was a waste of time at all, it finally puts to bed any question of Nintendo not optimising sm64

    • @Poever
      @Poever 3 роки тому +4

      Safety from what?

    • @ABVW92
      @ABVW92 3 роки тому +37

      @@Poever
      It was safety against an unplayable mess of a game.
      Whilst the game may run better with further optimisation, it may cause unintended stress on the hardware over time, or have other unknown effects on the game itself, that preliminary testing didn't find.
      So for safety, they used a less Intrusive optimisation, trading a few frames for a more stable experience.

    • @RJARRRPCGP
      @RJARRRPCGP 2 роки тому

      @@ABVW92 Well, it may just need more cooling, likened to using AVX on recent PC processors. Like when Intel reportedly has a lower frequency, when AVX instructions are being used. Still not noticeably slow like Goldeneye is in spots on a real Nintendo 64.

  • @Mobius14
    @Mobius14 4 роки тому +1715

    You're glossing over a lot of facts and several incorrect statements were made in this video.
    1. We did not use Ghidra. We only sometimes used our own custom decompiler (mips_to_c) but most of the work was completely handwritten from static analysis. We were able to do this since the unoptimized code basically read literally out directly to C mannerisms with few exceptions.
    2. It's not actually certain O2 "caused" issues. We are only certain of the compiler for US/JP: IDO 5.3 (IRIS Development Option) with -g for the main game code. Why Nintendo either left it in or deliberately used it is unknown but we do have a few hypothesizes, some of them match the accidental side and some of them are the on purpose side. What we do know also is that since the collision routine slowed down by -g causes the major DDD sub lab being an indicator of the flag also means the Spaceworld 1995 build is unoptimized. If that ever leaks out, decompiling that would be easy pickings for us. (Please get out!)
    3. Compiling US/JP builds with O2 (as-is, no AVOID_UB) they can complete 0 star and 120 star TASes respectively. Since inputs arent accepted on lag frames, they can pass these since it appears the functionality is identical. Hell, I even tried modern gcc, and they *still pass,* but only if we define AVOID_UB. gcc actually makes a ROM that crashes the n64 if we don't. IDO doesn't seem to care.
    4. The mulmul bug was patched way before the N64's release, and I believe before SW95's showcasing. This was patched at the assembler level by SGI which that patch is IDO 5.3 only, made default in 7.1 (released in November 1996 after sm64's release) and gcc got its own version of the fix with gcc 2.8.x (2.7.x builds that had it were available by Cygnus and the N64 SDK.)
    It is possible though earlier builds with O2 spooked them into not using it, but it either had to have been before or after sw95 [Spaceworld 1995] (which would mean it was originally -g but they tried O2 to see if they could). There's a bug in the Disk Drive version that crashes Wiggler's room which is caused by an out of bounds read for a float value. This crashes real N64 hardware because that value just so happens to be a denorm on the O2 build (but we arent sure if O2 shifted it into place) but not the original US/JP releases which just so happen to read a valid float and dont crash.
    This was miles better than the other video, but I do wish it dived deeper into how we actually figured out it was IDO 5.3.

    • @PablosCorner
      @PablosCorner 4 роки тому +71

      MVG gotta see this comment.

    • @Skazzy3YT
      @Skazzy3YT 4 роки тому +8

      Hey thanks Revo.
      Also hi Pablo c:

    • @denisskenderovic3707
      @denisskenderovic3707 4 роки тому +174

      I stumbled upon this video and comment by accident and ngl it's like I am reading some ancient alien language.

    • @jak3w
      @jak3w 4 роки тому +163

      First off I appreciate your hard work and it is truly fascinating, however this comment sort of makes you come off as a dick. Just as you took the information given and interpreted it he did the same thing. Instead of accusing him of not diving deep.enough or comparing him to that other asshat help him understand and get the correct info out.

    • @amnottabs
      @amnottabs 4 роки тому +40

      so in the end mistakes were made...

  • @SetnaroX
    @SetnaroX 4 роки тому +632

    >"mistakes werent made"
    >"werent" missing an apostrophe
    A mistake was made!

    • @Skul1ManEXE
      @Skul1ManEXE 4 роки тому +13

      Mistakes were indeed made after all.

    • @ninja_raven256
      @ninja_raven256 4 роки тому +8

      the irony...

    • @sissel02
      @sissel02 4 роки тому +3

      This phrase has no mistaeks

    • @palanthis
      @palanthis 4 роки тому +1

      Thank you. I am glad I didn't have to be the one to point out both the error and the irony.

    • @oaktree2406
      @oaktree2406 4 роки тому

      Profound!

  • @MarcoGPUtuber
    @MarcoGPUtuber 4 роки тому +1902

    Mistakes WEREN'T made?
    My world is shattered. The cake is a lie.

    • @joesshows6793
      @joesshows6793 4 роки тому +18

      Marco your response is much better than what I had in mind 👍

    • @MarcoGPUtuber
      @MarcoGPUtuber 4 роки тому +7

      @@joesshows6793 I appreciate it. Thank you!
      But feel free to make your comment anyways! All comments help MVG.

    • @davkdavk
      @davkdavk 4 роки тому +3

      Is it to do with the 60hz/50hz region differences?

    • @MarcoGPUtuber
      @MarcoGPUtuber 4 роки тому +3

      @@davkdavk No. Thumbnail.

    • @joesshows6793
      @joesshows6793 4 роки тому +1

      davkdavk thats what I was thinking but then why would it work in one region and not another?

  • @Orbitthemaster
    @Orbitthemaster 4 роки тому +799

    This topic makes me wonder about other games like Donkey Kong 64 that crashes randomly on the console and requires a expansion pak to work.

    • @ExceedSC2
      @ExceedSC2 4 роки тому +481

      From what I remember, it has a memory leak and will eventually crash due to running out of RAM, they made the expansion pak required to increase the amount of time before the crash to 8 hours by basically just give it more RAM to leak to, it didn’t actually need that memory for anything else

    • @KuroAno
      @KuroAno 4 роки тому +249

      The problem with DK64 is a memory leak and it was "fixed" with the expansion pak because more memory meant the leak took more time to crash the console.

    • @ShaunDreclin
      @ShaunDreclin 4 роки тому +265

      I was livid when I found out about that. I was so convinced that the expansion pak was some magical thing that made the n64 more powerful. Damn marketing 😂

    • @Orbitthemaster
      @Orbitthemaster 4 роки тому +113

      @@KuroAno I know that but this was never really well documented on any channel on UA-cam whatsoever, the memory leak problem has never been explained properly here, just the "it's a memory leak lol".

    • @DarktheEagle
      @DarktheEagle 4 роки тому +113

      @@ShaunDreclin I mean, technically it did, but not by much. It doubled the RAM from 4mb to 8mb. It just wasn't something that would affect games not designed around it.

  • @HenrikoMagnifico
    @HenrikoMagnifico 4 роки тому +154

    I think they didn't want to risk releasing the game with potential critical bugs caused by -02 optimization since it was a launch title and it was crucial that it was polished to show off the N64

    • @Anon.G
      @Anon.G 4 роки тому +2

      But if they did it with eu then that's not right

    • @CounterFlow64
      @CounterFlow64 4 роки тому +44

      @@Anon.G I think it released maybe a bit later in EU, so they tested more and started to feel comfortable with it.

    • @yanm8633
      @yanm8633 2 роки тому +24

      @@CounterFlow64 Quite a bit later indeed! US, in September 1996 and in Europe, March 1997. So yeah.

    • @awii.neocities
      @awii.neocities 2 роки тому +6

      @@Anon.G The EU release came out 6 months later.

    • @PaperBanjo64
      @PaperBanjo64 11 місяців тому

      Is the shindou version-02 optimized?

  • @Abyssoft
    @Abyssoft 2 роки тому +4

    Have you seen Kaze Emanuar's recent video where he optimized the game to 60fps?

  • @LongPeter
    @LongPeter 4 роки тому +180

    For real frame rate slowdowns, see Goldeneye 64 or Perfect Dark multiplayer with grenade launchers. We really, REALLY didn't mind as much back then.

    • @lancepate
      @lancepate 2 роки тому +8

      Even more recently with games like Dark Souls. I don't remember seeing a lot of hate for the console framerates until PTDE came out.

    • @Alucard54s
      @Alucard54s Рік тому +16

      I think anything involving explosions can be excused for dropping frames as long as the damage done is appropriately powerful. It gives the grenade launcher a feeling of "ah crap, that is a lot of hurt, give the machine a moment"

    • @intron9
      @intron9 Рік тому +1

      You can feel when there's not enough frames, it feels worse.
      The multiplayer modes of those games weren't intended to be the most common mode, so it's better to just have it than remove it. Same thing happens in for example, Mario kart Wii, on 3 and 4 player mode, it locks to 30fps instead of 60.

    • @LongPeter
      @LongPeter Рік тому +13

      @@intron9 I'm not talking about 30 fps. I'm talking about 1fps. Those explosions just ate the whole system if they filled the screen.

    • @ACX-z1p
      @ACX-z1p 5 місяців тому

      True. Isn't as easy to notice on a CRT as well.

  • @vriskaserketontheps5
    @vriskaserketontheps5 4 роки тому +282

    "the game was criticized for its camera"
    aren't they all though?

    • @hotpotatodude3473
      @hotpotatodude3473 4 роки тому +11

      Not really I really like Sunshine's and oddiseys camera

    • @kilowatt8401
      @kilowatt8401 4 роки тому +28

      joão prudencio I think he’s talking about 3D games of the mid to late 90s.

    • @rac1equalsbestgame853
      @rac1equalsbestgame853 4 роки тому +23

      DanROW All 3d games in that era had some type of camera annoyance

    • @r-ea
      @r-ea 4 роки тому +8

      I quite like the Mario 64 camera

    • @luisjogos821
      @luisjogos821 4 роки тому +11

      @@r-ea hahaha just play Tick Tock Clock and you will """love""" the camera even more

  • @metroid031993
    @metroid031993 4 роки тому +7

    One thing to add: the sm64 project was started before ghidra was released, and it wasn't the method used, at the very least for most of the development. The reason they got such accuracy that they could produce a byte-for-byte identical ROM was the compiler test-casing that was done. The exact IDO compiler version that was used was found based on testing a set of specific code until the correct patterns were found, until enough version-specific behavior was found to be sure of the exact compiler used. Once that was known, different ways of representing effectively the same algorithm with slightly different tweaks was used in order to figure out the way the original code was likely written, based on the compiler output. Eventually you can do something like making your own pattern matcher which can output likely C-code that was started with originally. Pretty cool details, imo. In any case, nice video, glad someone covered this topic with the proper measured approach :)

  • @deanmoncaster
    @deanmoncaster 4 роки тому +446

    If ghidra wasn't open source, I'd use ghidra to decompile it and release the source.

    • @agnel47
      @agnel47 4 роки тому +93

      Hacking 100

    • @y00d
      @y00d 4 роки тому +44

      h a c k e r m a n

    • @skrubbed
      @skrubbed 4 роки тому +56

      there wouldnt be any reason to not make it open source. if it wasnt open source, ofc people would decompile it with itself.

    • @deanmoncaster
      @deanmoncaster 4 роки тому +37

      @@skrubbed that's what I said

    • @skrubbed
      @skrubbed 4 роки тому +5

      @@deanmoncaster no i was just saying how there would be no point in it not being open source

  • @justsomeperson5110
    @justsomeperson5110 4 роки тому +198

    It's actually kind of funny to see Nintendo intentionally disabled optimizations, as around the same time I was writing completely different software and our team found a compiler bug that forced us to release unoptimized code for a while until Microsoft fixed their bug. I guess it was just a thing to do that year. LOL

    • @Azlehria
      @Azlehria 4 роки тому +16

      My assumption was similar: a codegen issue that only occurred with optimization enabled so they hand-optimized during development, and then not wanting to risk "breaking the build" even after the issue was fixed.

  • @B10KPlaysGames
    @B10KPlaysGames 4 роки тому +646

    23 years later:
    *_Did Nintendo really forget to Optimize Zelda Link's Awakening for Nintendo Switch?_*

    • @litjellyfish
      @litjellyfish 4 роки тому +27

      B10K PlaysGames 23 years later:
      is people that never worked on an released a AAA title themselves still arrogant to use their spare time to draw quick assumptions without thinking before claiming “I could have done it better”

    • @akj7
      @akj7 4 роки тому +17

      Haha nice one. Remembering that swamp area in the game.

    • @tbtb66
      @tbtb66 4 роки тому +59

      Actually yes, the homebrew community has already figured that
      It seems to be a problem with the engine Grezzo made for loading stuff in, rerouting the game to load files off the SD card significantly speeds up the game

    • @NathanChisholm041
      @NathanChisholm041 4 роки тому +2

      @@akj7 Yeah the swamp had bad frame rate drops!

    • @howmanyshrimps
      @howmanyshrimps 4 роки тому +16

      Minecraft was made in Java and thus was horribly optimized.

  • @Xilefian
    @Xilefian 4 роки тому +240

    5:01 "As someone who is a C program" Holy shit I knew it.

    • @bigstar66
      @bigstar66 4 роки тому +23

      I've never understood why black people and the British hate the letter R so much

    • @nxxxxzn
      @nxxxxzn 4 роки тому +3

      @@bigstar66 [’prəugræmə] r is ə, no hate at all

    • @oelschlegel
      @oelschlegel 4 роки тому

      except he uses pico

    • @shiningwhiffle
      @shiningwhiffle 4 роки тому +6

      ​@@bigstar66 Nothing to do with hate, just normal language change. Consonants tend to weaken over time, especially at the end of words. What you're noticing are just dialects where the "R" sound has weakened or disappeared more than usual.

    • @bigstar66
      @bigstar66 4 роки тому

      James Jensen yes, but they don’t usually this much this quickly. I think the British and African American spurned the letter r for the same reasons - they didn’t want to sound like white Americans.

  • @kris-wj3wj
    @kris-wj3wj 4 роки тому +25

    That lag while swimming will always be a part of the game for me lol.

  • @DaveVoyles
    @DaveVoyles 4 роки тому +15

    I love that you dive into great detail, while at the same time can explain complex subjects in a manner which is easy to understand.

  • @DeenHoward
    @DeenHoward 4 роки тому +87

    Decompilation of Panzer Dragoon Saga for the Sega Saturn would be interesting, considering that the original source code is lost.

    • @TheXev
      @TheXev 4 роки тому +22

      This actually amazes me, as Sega generally keeps very good track of it's source code.

    • @PaperBanjo64
      @PaperBanjo64 11 місяців тому +3

      ​@@TheXevNights into Dreams was also lost.

    • @mostverticalproductions4808
      @mostverticalproductions4808 6 місяців тому +3

      ​@@PaperBanjo64 most of their Saturn era stuff is gone. But I think Futatsugi has PDS' source code secretly.

  • @ErraticPT
    @ErraticPT 4 роки тому +316

    I remember seeing SM64 for the first time and it was jaw dropping even for me who is no Nintendo fan.

    • @ValensBellator
      @ValensBellator 4 роки тому +19

      Yup I remember playing it either in a Best Buy or a blockbuster or something and fighting King Bobomb. I’d only seen it in a commercial to that point and just never wanted to leave the store 😂

    • @marcowulliampopirers2216
      @marcowulliampopirers2216 4 роки тому +1

      @Franky Padilla what??? the nintendo 64 was released in 1996

    • @xanderdoesnt
      @xanderdoesnt 4 роки тому +4

      @Sadist Fake Bootleg Tiki Nice bait wee man, try a bit harder next time though:)

    • @AliceC993
      @AliceC993 4 роки тому +3

      @Sadist Fake Bootleg Tiki so how's middle school going?

    • @susu5331
      @susu5331 3 роки тому +2

      Same thing when I first played Zelda BOTW a few years ago, I became a fan boy after that and brought 3DS WiiU Switch Switch Lite to enrich my collection over the years.

  • @siphillis
    @siphillis 4 роки тому +191

    Sort of reminds me of FF7's development: basically they toyed with the release candidate for a while until it finally ran from beginning to end, then they were too afraid to make adjustments.

    • @TheSwillMan
      @TheSwillMan 4 роки тому +23

      if it ain't broke...

    • @ooo-oq3bn
      @ooo-oq3bn 4 роки тому +10

      @@TheSwillMan fix it (dont)

    • @no_nameyouknow
      @no_nameyouknow 4 роки тому +5

      Hi from the future FF7 remake is out and it is GLORIOUS

    • @PowerPandaMods
      @PowerPandaMods 4 роки тому +32

      FF7 is held together with duct tape and prayers. :D I am in the FF6 modding scene, and even that game had 180+ separate bugs when the first battle system disassembly was made. Like the fact that evasion is never checked, or that the Genji Glove doesn't reduce your attack stat to 80% like it should. Ah, the things we didn't notice as kids....

    • @kuraiwolf4047
      @kuraiwolf4047 3 роки тому +5

      Like a jenga tower where you are too afraid to pull that one block because it may fall apart.

  • @bubby-fi9mc
    @bubby-fi9mc 4 роки тому +41

    Usually in almost all game development cases, accusing companies of not doing something out of "laziness" is almost never correct. There's almost ALWAYS more to the story, and laziness should always be the last resort for deciding why something happened the way it did. Good work!

    • @ConanVictor
      @ConanVictor Рік тому +8

      lazy comment
      0/10

    • @keiyakins
      @keiyakins 8 місяців тому +1

      And when there isn't a "good" reason, there's usually a "shit we only have three days left it works get on to the next task!" reason.

  • @ValensBellator
    @ValensBellator 4 роки тому +60

    I actually remember liking slowdown in many games... it often coincided with explosions and action and felt epic and was occasionally helpful lol; heck, I’d try to make it happen as much as possible in Goldeneye

    • @ant777live
      @ant777live 2 роки тому +1

      It happens in "real" life also, during important events time can slow down

    • @Arigal3
      @Arigal3 2 роки тому +4

      yeah, i actually thought that the slowdowns were intended, like a bullet time mechanic to give you a little wiggle room to operate in case of overwhelming odds

    • @ant777live
      @ant777live 2 роки тому

      @@Arigal3 It's evidence that we live in a simulation ; )

    • @mulletsquirrel
      @mulletsquirrel 2 роки тому

      I immediately thought of Goldeneye too, when explosions were happening, it could slow down to like 1 FPS lol! I had no idea what was happening as a kid.

  • @lukehero
    @lukehero 4 роки тому +83

    4 player Perfect Dark with all bots enabled. The ultimate lagfest.

    • @LonelySpaceDetective
      @LonelySpaceDetective 4 роки тому +22

      Turn hi-res mode on and put it in 16:9 too for """""""""best""""""""" effect.

    • @justiny.1773
      @justiny.1773 4 роки тому +3

      Luke Hero can’t believe I use to love playing that

    • @dbadgones
      @dbadgones 4 роки тому

      Hahahahah

  • @omgitsbees
    @omgitsbees 4 роки тому +2

    As always, thank you so much on your work on these videos! You provide a very unique perspective and recorded history of vintage games that can't be seen anywhere else. This was a really interesting video and was well done.

  • @paddyblack-exe
    @paddyblack-exe 3 роки тому +8

    What an amazing gem. Still have my N64 and a copy of SM64. I think I remember having access to a family PC back then, and early 3D games. Many 3D games were really quite poor in execution compared to SM64.

  • @ME3WarrantyVoider
    @ME3WarrantyVoider 4 роки тому +65

    Hey there, thanks for showing my N64 plugin at 1:48 :D

  • @ophello
    @ophello 4 роки тому +22

    “Piqued my interest” is the proper phrase.

    • @PantsYT
      @PantsYT 3 роки тому +2

      it's not "peaked"? my life is a lie

  • @EvilRSA
    @EvilRSA 4 роки тому +2

    Loved that you used the File Menu music at the end. I used to just leave that playing as background music in my room when I was a kid.

  • @justmoritz
    @justmoritz 4 роки тому +1

    I love that your channel is both comprehensible to just listen to because you break it down so easily, but also provides screenshots and references to c code if you want to know more.

  • @AbdAbdAbdAbd
    @AbdAbdAbdAbd 4 роки тому +194

    It's so nice of you to credit MattKC instead of stealing the idea.

    • @ModernVintageGamer
      @ModernVintageGamer  4 роки тому +67

      of course. his video is excellent

    • @joshsadowski8869
      @joshsadowski8869 4 роки тому +4

      MattKC has been making great videos. He has just recently getting into vintage videogames but worth a view.... Just don't go back to far or there is a bunch of cringy eye liner videos lol.

    • @USSMariner
      @USSMariner 4 роки тому +11

      @@joshsadowski8869 everyone starts somewhere
      Besides, one poorly-researched video (which was more a failure of his knowledge of consoles, and knowing where to look in order to verify the actual tools used for development) isn't going to wipe away his work on preserving Lego Island for modern systems.
      Figuring out how the game handles audio *by himself* and releasing a free tool to update the game with the uncovered full-quality audio tapes is still commendable.

    • @Marsunpentu
      @Marsunpentu 4 роки тому

      @@VirtuousLiberty me 2

    • @MybeautifulandamazingPrincess
      @MybeautifulandamazingPrincess 4 роки тому

      Stealing his idea?
      What's next I'm stealing other people who came before me for being alive?

  • @MrMario2011
    @MrMario2011 4 роки тому +85

    I'm a bit surprised this flag wasn't added and recompiled in a later release of the game, such as for the Player's Choice version. It looks like it would have been worth revisiting with the newer tools available!

  • @dannowell269
    @dannowell269 4 роки тому +3

    One area I think MVG really puts effort in , but is subtle is the audio, the audio and sfx are really well mixed in every vid

  • @ctrlaltrees
    @ctrlaltrees 4 роки тому +1

    As a fellow developer and retro gamer yours has to be one of my favourite channels on UA-cam. Really thorough explanation of the situation as always. Keep up the good work!

  • @DrFearCo
    @DrFearCo 4 роки тому +16

    Man I love modern strongly typed languages! However, a few years ago when we had a client crazy enough to want us to use Swift Beta 1 for their project, we would frequently run into issues where compiler optimization would optimize away entire classes that were being used. So in the early days we had to turn it off.

    • @ChristopherGray00
      @ChristopherGray00 2 роки тому

      What time was this? Around the early 90s?

    • @an2thea514
      @an2thea514 Рік тому

      @@ChristopherGray00 I doubt that Swift, a language released 2014 was worked on 20 years prior.

  • @MinisterSandman
    @MinisterSandman 4 роки тому +275

    the short answer is basically, "no, they did not" - it was a different time.
    the long answer is everything else in the video. haha

    • @MarcoGPUtuber
      @MarcoGPUtuber 4 роки тому +5

      I'm amused that, on my account, your comment is beside mine.

    • @MinisterSandman
      @MinisterSandman 4 роки тому +1

      @@MarcoGPUtuber sweet irony. we just need one more commenter to make this a "beetlejuice" xD

    • @MarcoGPUtuber
      @MarcoGPUtuber 4 роки тому +1

      @@MinisterSandman lmao. Are there any more Marcos in the 300000 or so MVG subscribers? May the real Marcos please stand up!

    • @MinisterSandman
      @MinisterSandman 4 роки тому +1

      @@MarcoGPUtuber i second this statement. Lol!!!

    • @ABaumstumpf
      @ABaumstumpf 4 роки тому +2

      The correct answer is:
      "They did not forget but have actually written code so sloppily that it relied on undefined behaviour left and right and the compiler - rightfully - would screw that up"

  • @summer_xo
    @summer_xo 4 роки тому +194

    mvg is such a brilliant channel:
    interesting and relevant topics,
    technical but well explained,
    aussie accent

    • @phr33z10
      @phr33z10 4 роки тому +18

      Shane holy shit I’ve never considered the fact that he sounds more Australian than Australians
      I am Australian
      He has the perfect “radio” or “TV” voice

    • @mrniceguy7168
      @mrniceguy7168 4 роки тому +5

      Emphasis on Aussie accent

    • @squishmastah4682
      @squishmastah4682 4 роки тому

      @@phr33z10 Bye for now

    • @phr33z10
      @phr33z10 4 роки тому

      Squish Mastah ?

    • @Unregistered007
      @Unregistered007 4 роки тому

      He fucking copied the material off others... bald bitch...

  • @duxnihilo
    @duxnihilo 4 роки тому +29

    5:00 I've just now noticed that canvas with the health/oxygen indicator is supposed to be Mario's profile. It's 2020 and I played this at launch.

    • @dougr.8653
      @dougr.8653 4 роки тому +5

      I still have my copy bought in November 1996 together with the console. All with their boxes.

    • @RageUnchained
      @RageUnchained 4 роки тому +4

      Isn't it fascinating how we can see a film, or play a game and miss a detail until revisiting years later?

    • @andersgale9544
      @andersgale9544 4 роки тому +2

      Lol u must be blind

    • @PokeDude1995
      @PokeDude1995 4 роки тому +4

      Better late than never I guess

    • @renakunisaki
      @renakunisaki 4 роки тому +1

      I noticed it while hacking the game and thought I'd accidentally enabled an Easter egg.

  • @skywolfbat
    @skywolfbat 4 роки тому +2

    This is indeed an interesting little bit of gaming history. Granted, it doesn't change my view of one of my favorite childhood games, it does bring to light some little things I'm slowly learning as I start entering more and more into the programming world. Thanks for taking the time to do this, MVG.

  • @ZachAttackIsBack
    @ZachAttackIsBack 4 роки тому +4

    2:59 The dragon logo for Ghidra is freaking awesome.

  • @WellBadPanda
    @WellBadPanda 4 роки тому +46

    The tortured soul of Lara Croft appears to be trapped inside the Silver Play Button on your wall

    • @Ronan34753
      @Ronan34753 4 роки тому +1

      Fitting, considering the first Tomb Raider came out around the same time as Mario 64.

  • @SkyCharger001
    @SkyCharger001 4 роки тому +21

    There may be another reason: I've seen some games written to work reasonably well on NTSC and then put through optimization to run at comparable speed on PAL.

    • @DenniWintyr
      @DenniWintyr 4 роки тому +3

      & then you get the opposite, like Rare on Goldeneye & Perfect Dark. Both written & optimised for PAL, & duly running far worse in the NTSC versions

    • @ragnevi
      @ragnevi 4 роки тому

      I was thinking the same thing.

  • @Yngdady
    @Yngdady 4 роки тому +11

    MattKC is such an underrated content creator. Glad you mentioned him for others to be made aware of what he does
    Edit: just realized y'all both Aussie

  • @PicksterTG
    @PicksterTG 4 роки тому +2

    My initial thought when I saw that video was that it was probably because Mario 64 was made using early sdk and there were probably very good reasons Nintendo didn't use the 02 optimization.
    Thank you for digging into this further.

  • @RetroHQ
    @RetroHQ 4 роки тому +10

    I’m pretty sure I remember the release version of Croc: Legend of the Gobbos was without C compiler optimisation. I don’t think there was anything intentional about this, but as mentioned, a lot of code back then was hand optimised in assembler, so the gains to be had with C optimisation is less drastic. And I certainly remember bugs being introduced by optimisation back at that time period. Tools are much more stable now... :)

    • @MattGodbolt
      @MattGodbolt 4 роки тому +2

      Not the PC version, for sure (I worked on that); and I'd be very surprised on the PS version too

    • @RetroHQ
      @RetroHQ 4 роки тому +2

      @@MattGodbolt This was PS. I have memory of Tony discovering this while getting stuck into Croc2. It may be a false memory, of course, it was a while ago... ;)

    • @MattGodbolt
      @MattGodbolt 4 роки тому +2

      @@RetroHQ hahaha cool! It's entirely feasible it was fixed up pre PC! By the time we got it (ahem) when porting I'm pretty sure the nmake file had O2 hardcoded

  • @NicJohnson
    @NicJohnson 4 роки тому +16

    This was really interesting. This is definitely the type of content I'd expect from this channel. Great work.

  • @PaulMeranda
    @PaulMeranda 4 роки тому +147

    *"Mistakes Weren't Made"* hahaha, i love that

    • @PaulMeranda
      @PaulMeranda 4 роки тому +1

      aah, quite a different meaning once you've been through the video. great upload 💙 i always learn so much here

    • @Gfreak250
      @Gfreak250 4 роки тому +1

      @@PaulMeranda *werent, they left out the apostrophe which was a really clever joke.

  • @LuigiVN
    @LuigiVN 4 роки тому +12

    Props for getting Dylan Cuthberg on the show! Man started my most favorite Nintendo franchise (Star Fox)

  • @ryancoke777
    @ryancoke777 4 роки тому +10

    I'd like to see how various retail games would run with all the optimizations changed to O3

    • @JethroRose
      @JethroRose 4 роки тому +7

      those that don’t already use it would break. otherwise they would have used it.

  • @alesta2212
    @alesta2212 3 роки тому +3

    When MVG's thumbnail says Mistakes _weren't_ made:
    **Confused Screaming**

  • @jlucasp25
    @jlucasp25 4 роки тому +50

    Having MVG talk about O2 and Makefiles sure is amazing.. Hope we get more videos like that..
    Quick Question: Why not compile it with O3?

    • @ModernVintageGamer
      @ModernVintageGamer  4 роки тому +74

      I compiled with O3. The game crashes at random

    • @surrodox
      @surrodox 4 роки тому +19

      gcc -O3 is pretty unreliable as mattkc says

    • @user-ro1cc8tz6d
      @user-ro1cc8tz6d 4 роки тому +9

      @@surrodox it doesn't really. if you're using latest gcc and on x86 it will work fine %90 of time. Its suprised me that -03 made it crash.
      Also it do make sense that nintendo didn't push optimisation to everything since compiler are came a long way too. in early 2000's maybe the compiler wasn't as good as of today.

    • @jlucasp25
      @jlucasp25 4 роки тому +15

      @@user-ro1cc8tz6dHe needs to compile using Nintendo's compiler that is really old, he's not using gcc

    • @AngDavies
      @AngDavies 4 роки тому +7

      @@user-ro1cc8tz6ddon't the -03 optimisations all have some kind of space/speed tradeoff and thus tend to increase memory usage/size of the resulting binary? If you're already running at redline for memory at points I could see it pushing you over and crashing the system due to running out of memory.
      I doubt the developers were leaving much memory on the table for a dedicated device like a games console not designed for multitasking, and rather to run one application at a time.
      Today, on a modern multitasking operating system memory is by necessity comparatively more available and that's less of an issue

  • @duuqnd
    @duuqnd 4 роки тому +42

    As far as I know, Ghidra wasn't used for the decomp project at all. It was mostly done by hand.

    • @Rainchus
      @Rainchus 4 роки тому +19

      This is true, the project started way before ghidra was released to the public

    • @leonidas6682
      @leonidas6682 4 роки тому +11

      Amazing.. these guys are wizards wasting their talent on meaningless things like this. Like saints of the programming world utilising their talents so youtubers can make bank with clickbait videos for a week

    • @RoadrunnerWMC
      @RoadrunnerWMC 4 роки тому +29

      Yes, this was my main reaction upon seeing this video. Claiming that Ghidra did most of the work is really selling the decompilation team short -- tools like that are nice in general, but are close to useless if you're aiming for perfect byte-for-byte accuracy. This project was mostly done manually, which no doubt took _tons_ of time and effort.

    • @pian-0g445
      @pian-0g445 4 роки тому +6

      Victoria Meets World those people did it for fun because they love video games. It’s their passion for their community and also most UA-camr like these guys make very little bucks unlike those who cash in millions, also, how is this clickbait. These you tubers are like those guys who did it, they love gaming and want to help it.

    • @leonidas6682
      @leonidas6682 4 роки тому +1

      @@pian-0g445 it's click Bait because of U watch the video he rushed or our and didn't do he research and on turn disrespected the talents and the assumptions of those who put in the hard work. He was in a rush to make money while the topic was hot and he substitute d his opinion as facts rather then just going over and looking at the project and ppl that worked on it

  • @shankthebat8654
    @shankthebat8654 4 роки тому +16

    In the initial makefile, there's a conditional that specifies 02 optimization if a version condition is met. I assume this is part of the reverse engineering and not something from Nintendo's original code?

    • @OpenKeith
      @OpenKeith 4 роки тому +14

      The EU version wasn't released at the same time as the US and JP ones, so somewhere in between the releases, Nintendo enabled O2. The condition in the Makefile is the reverse engineering team's way of replicating that.

  • @arcadeslum5882
    @arcadeslum5882 2 роки тому +2

    MVG have you seen Kaze's m64 code rewrite project? Some massive progress made on native n64 hardware.

  • @awesomedata8973
    @awesomedata8973 4 роки тому +1

    Loved me some Pilotwings... The terrible blood-curdling screams of Robin when she crashes and burns still gives me chills... but... infinite rockets, the birdman suit, and the amazing soundtrack kinda made up for that in the end. Go Pilotwings!!

  • @Laykun9000
    @Laykun9000 4 роки тому +10

    Golden Eye would be worth a look, although I get the feeling it's probably just a problem with the game code rather than the compiler settings.

    • @LonelySpaceDetective
      @LonelySpaceDetective 4 роки тому +2

      Wasn't GoldenEye a first project for a lot of its dev staff? Or just their first project at Rare.

    • @Jombo23MC
      @Jombo23MC 4 роки тому +1

      GoldenEye uses older drawing methods. no depth buffer, etc. all triangles had to be z sorted which has a good bit of overhead and more or less totally screws optimized display lists, where triangles can share vertices, flat surfaces could be quads, etc. the 64 is really kinda based around being given optimized display lists (they have a limited vertex cache, between 32 and 128 depending on the microcode) since the rsp only has a 4k data cache (think ram) for any 3d data to be passed through, any time it has to stop and change out its data it's gotta throw an exception/interrupt and have the cpu send it another chunk of data.
      all in all it also saves ram as there's no depth buffer, so another 320x240(or whatever the game runs at)*2 bytes freed up. the pixel fill rate is also increased substantially because it's not having to constantly check the depth buffer when it's drawing.
      tldr GoldenEye used old styles of rendering that would have fit the psx but don't work out so well on the 64.

    • @blahblahbleeeblahh7053
      @blahblahbleeeblahh7053 4 роки тому

      Goldeneye has been optimized by minimizing the explosions among other things you can also just play it on PC to have a faster game on PC normal speed is turbo mode and turbo mode is even faster.

    • @Jombo23MC
      @Jombo23MC 4 роки тому

      @@blahblahbleeeblahh7053 totally irrelevant. getting rid of features is not "optimizing"

    • @blahblahbleeeblahh7053
      @blahblahbleeeblahh7053 4 роки тому

      @@Jombo23MC it doesn't remove the explosions entirely only minimizes them because too many explosions lag it hard just check out Goldeneye NGPA edition you will see what I mean it feels nice.

  • @hypnovertigo7200
    @hypnovertigo7200 4 роки тому +51

    This is the shit that makes my monday worth waking up for

    • @frostbite1991
      @frostbite1991 4 роки тому

      just got off a 12 hr shift on 3.5 hr's of sleep and it was still worth it lol

    • @Iliek
      @Iliek 4 роки тому +4

      Wow. Truly dire times we live in.

  • @Jordio
    @Jordio 4 роки тому +6

    This was well written and thoroughly researched. Thank you!

  • @dang3114
    @dang3114 4 роки тому +1

    Please keep mashing more games and code/development topics!! This video was fantastic!

  • @rebow2568
    @rebow2568 4 роки тому +2

    Celebrating 25 years of Nintendo 64 and Super Mario 64 in this year!
    👏🏼👏🏼👏🏼👏🏼👏🏼 🥳🎉🎊🍾 🎮

  • @no_nameyouknow
    @no_nameyouknow 4 роки тому +8

    "Redefine the platforming genre." As a clip shows mario falling from a platform while trying to simply walk across a short bridge.
    I'm joking of course, it was just a funny juxtaposition.

  • @BrianJChagnon
    @BrianJChagnon 4 роки тому +13

    This video made me realize I optimized my first child, and then figured the second one would be just fine so I didn’t bother.

    • @RyoLeo
      @RyoLeo 3 роки тому

      Normally its the other way around spending years trying to debug the first child while the second tends to be programed better.

  • @joeykeilholz925
    @joeykeilholz925 4 роки тому +107

    I was shocked when I heard there was an "easy fix" improving performance..

    • @FrankHarwald
      @FrankHarwald 4 роки тому +6

      Up to a certain level - the speed differences often aren't that groundbreaking & limited to a couple of percent points. Beyond that thinking about using different algorithms & data structures as well as different game logic is more fruitful.

    • @litjellyfish
      @litjellyfish 4 роки тому +2

      Well usually the “easy” fix is not that easy in a real world scenario.

    • @vyor8837
      @vyor8837 4 роки тому +1

      @@litjellyfish as stated by the reverse engineering team... No, it really is that easy.

    • @litjellyfish
      @litjellyfish 4 роки тому +2

      Vyor and again yout forgot to read “real world scenario” so sorry no it’s not that easy.
      Technically it’s that easy. Nintendo is not that stupid. Risk wise it’s not that easy all. So Nintendo took the right decision and not go for the optimizations. Nintendo are not stupid.
      Nintendo have of course more skill, experience and resources than this reverse engineering team. Also what indeed IS easy is to conclude this about the optimization now many years later with emulators time and more.

    • @vyor8837
      @vyor8837 4 роки тому +2

      @@litjellyfish Nintendo is stuffed to the brim with shit coders, worse leadership, and a terrible track record of technically competent design.
      Just look at smash ultimate: broken and buggy. BOTW: laggy as shit. Sword and Shield: incomplete rush job. Mario 64: too many bugs to count and horrid optimization.

  • @Robosan4000
    @Robosan4000 4 роки тому

    Some of the best content on youtube. Always looking forward to your next video!

  • @FurEngel
    @FurEngel 4 роки тому +1

    I commented on the original video to point out the main flaw / mistake in its thesis. Mario 64 was developed in '94-'96 on the SGI Onyx (circa 1993). Its ASM/C/C++ compiler with MIPS R3000 support did not support the level of -O2 that a modern day GCC install has. Many of the compiling optimizations performed now take advantage of techniques that have been developed and progressed over 20 years. So Nintendo did not "forget" to optimize the game, it was the best compiled binary at the time with the given tools. Edit: finished the video and I think MVG hit nearly every point. Great job.

  • @leumasme
    @leumasme 4 роки тому +53

    5:03 did he just say that he is a c program?

    • @Iliek
      @Iliek 4 роки тому +21

      It's that Aussie accent. He's a "C programma"

    • @TorutheRedFox
      @TorutheRedFox 4 роки тому +12

      no he legit said "C program"

    • @EpicureMammon
      @EpicureMammon 4 роки тому +8

      It's a liaison between the /a/ sound in "programma" and "and." It's probably not something easily picked up by a non-native speaker.

    • @TorutheRedFox
      @TorutheRedFox 4 роки тому +3

      there's a clear pause between the word "program(mer)" and "and"
      maybe he just ran out of breath and just rolled with it?

    • @jckf
      @jckf 4 роки тому +4

      His voice is quite slurred at times, but it was easy to understand from context

  • @genomainteractivo2872
    @genomainteractivo2872 4 роки тому +3

    One of the most interesting videos never seen. Thank you!

  • @jamesmumby-croft3861
    @jamesmumby-croft3861 3 роки тому +3

    I might be mistaken, I remember hearing back in the day that NTSC games used to run slightly faster than PAL due to the screen refresh difference. Could that account for the optimization difference between the versions, to produce a more consistent final product?

  • @Cruznick06
    @Cruznick06 4 роки тому +1

    Yay someone else who remembers Pilotwings! Very interesting video. As someone who is not a programmer it is fascinating to learn about the oddities of different languages and compilers.

  • @mantonioisc
    @mantonioisc 4 роки тому +1

    Please do more videos about these subjects, also very interesting your videos about how emulators work, there is no other channel that provides content like this. Huge fan of your videos.

  • @mattiviljanen8109
    @mattiviljanen8109 4 роки тому +54

    Can we all just stop and appreciate MVG for a moment for the high quality content, knowledge, professional approach, all his contributions to all the various projects he has taken part in, and - last but not least - extremely quick response time combined with ability to give credit where credit is due. I'm speechless.

    • @ModernVintageGamer
      @ModernVintageGamer  4 роки тому +12

      Appreciate the kind words.

    • @immoloism
      @immoloism 4 роки тому +3

      I don't think I could have worded that any better than you did if I tried. I don't think anyone on UA-cam can make quailty and interesting content like MVG about these niche subjects.

  • @handleneeds3charactersormore
    @handleneeds3charactersormore 2 роки тому +4

    Kaze Emanar would like to have a word on this

  • @bborkzilla
    @bborkzilla 4 роки тому +6

    Compiler bugs - I ran into a bunch of those more times in my career than I'd care to enumerate. Usually they were with proprietary compilers!

    • @steefant
      @steefant 4 роки тому +1

      I would never hire a guy telling me that in such a context (there exist compiler bugs - of course, even more so in proprietary compilers - but programmers declaring to have run into numerous of them - relative to themselves writing code with UB - is usually a big red warning sign indicating incompetence and dunning-kruger. I am not implying this here - that would be ridiculous from a one-line comment on youtube). However, it is rather clear that the compiler was not really to blame in the case of SM64 but its input was crap.

    • @JethroRose
      @JethroRose 4 роки тому +1

      steefant GCC was notorious for bugs in optimisation in the 90s when mario 64 game out. so much so that you could only compile linux kernel with specific gcc versions that had the “right combination of known bugs” the source code had taken into account. it was ages before anything newer than GCC 2.7.x was supported

  • @BaalFridge
    @BaalFridge 4 роки тому +1

    Incredible! I don't know a single thing about programming nor did I understand a single of the technical terms you used, but you put everything is such good context and laid it out so that people like me (whose knowledge of ''programming'' is limited to WoW macros) can understand everything! Amazing !

  • @bleachie
    @bleachie 4 роки тому +1

    I saw the other UA-cam video a few days ago, I really appreciate your follow up. Thanks for the extra details on the SDK, it’s a lot more believable that Nintendo choose not to enable optimizations given the cost/ benefits.

  • @fredspofford
    @fredspofford 4 роки тому +3

    What's with all these young UA-camrs always saying how Super Mario 64 was criticised for it's camera back in the day? No it wasn't. Mario 64 seemed like a gift from the creator Himself and was flawless in every way back then. I think these guys are trying to think of things that a naysayer would have said back then but although it's hard to imagine, if you were actually a kid growing up with the N64, you'd remember there wasn't a single game anywhere near the level of 3D perfection as Mario 64. The camera wasn't "bad" because it was the only 3D camera we'd ever experienced.

  • @DukenukemX
    @DukenukemX 4 роки тому +61

    I'm more interested in this allowing someone to make a native port of Mario 64 to PC.

    • @andrewrusso3871
      @andrewrusso3871 4 роки тому +12

      Demetrius Lolos unfortunately, I imagine a great deal of the code is hardware dependent

    • @Kira-zf7te
      @Kira-zf7te 4 роки тому

      @@andrewrusso3871 couldn't you just remove those bits of code?

    • @airysquared
      @airysquared 4 роки тому +34

      @@Kira-zf7te Rewriting code to run natively on a completely different architecture is not as easy as that.

    • @erick_ac
      @erick_ac 4 роки тому +12

      The thing is that all the code is tailored to that hardware, and if you wanted to simulate it it could be the same as using an emulator.

    • @CoTeCiOtm
      @CoTeCiOtm 4 роки тому +7

      I saw someone on Reddit post that they were working on a PC port of the game. It had quite a bit of emulation layers going on, but I'm pretty sure that's normal procedure when porting software from one platform to another, you start emulating most of the output and you implement changes to use actual hardware in the end. Man, I'd love to see a port of the game made to run on vintage hardware, like a 3Dfx Voodoo on Windows 95, like how it would have been if Nintendo decided to port their game to the PC back in 1996.

  • @hateWinVista
    @hateWinVista 4 роки тому +66

    Instant click. Very interesting topic for sure.

  • @karehaqt
    @karehaqt 4 роки тому +1

    This is why I love your videos, in depth research followed by a very interesting presentation.

  • @TheHighlian
    @TheHighlian 2 роки тому +1

    Can I say its really cute to put sleepytime music over the big brain lesson moment.

  • @Henderburn
    @Henderburn 4 роки тому +57

    When I saw the original video, my main thought was “this is cool but I need MVG to confirm.”

    • @Iliek
      @Iliek 4 роки тому +5

      MVG is like your pastor.

    • @litjellyfish
      @litjellyfish 4 роки тому

      When I saw the original video I came to the same same normal conclusion as this video...

  • @Abyss-Will
    @Abyss-Will 3 роки тому +5

    One of the best things about Super Mario 64 is that unlike most games from the era it doesn't feel old, dated or boxy thanks to it's super dynamic gameplay and cartooney graphics

    • @Scolio
      @Scolio 3 роки тому +1

      That’s always it. When a game goes for realism, it dates itself instantly. The next gen makes it look bad. That doesn’t happen as much on cartoony graphics. I can play modern mario games and then go back to a gamecube one or DS one and barely see a difference (resolution and such aside). Its different with sm64 because its marios first 3D game and the design just wasnt... *there* yet.

    • @blazethegame
      @blazethegame 2 роки тому

      Personally I don't agree. It looks and feels *OLDER* than it is. I'm all for cartoony graphics over realistic ones, and I can more or less get over the graphics. But the camera makes the game literally fucking unplayable. I want to enjoy the game so much but it's just unfathomably clunky and claustrophobic for most modern gamers. I understand rating it on the time it came out, but rank it by modern standards and the gameplay becomes bottom of the barrel.

    • @ThatPianoNoob
      @ThatPianoNoob 2 роки тому

      I very much disagree.. then again not really because of the graphics just the camera is fucking ass. The first "realistic" 3d titles are now all but unplayable unfortunately :D

    • @blazethegame
      @blazethegame 2 роки тому

      @@ThatPianoNoob absolutely

    • @Abyss-Will
      @Abyss-Will 2 роки тому

      @@ThatPianoNoob I'm gonna install Mario 64 again to see what's up cause I don't remember any trouble with the camera.
      Maybe you guys are not moving the camera?? And just expect it to point to where you want automatically?? Or you expect it to move it using the mouse?

  • @leadingauctions8440
    @leadingauctions8440 4 роки тому +16

    This does not answer the question at all.
    Then why was it 02 in Europe?

    • @ChickenFingers42
      @ChickenFingers42 4 роки тому +11

      I think, because the game was released later in Europe and the compiler issues were fixed by then.

    • @SuppleAloe64
      @SuppleAloe64 4 роки тому +1

      Chicken Fingers yeah, that’s the kind of thing that happened with Metroid Prime on GameCube, too

    • @Krullerized
      @Krullerized 4 роки тому

      How do you decompile a Makefile? 🤔

    • @SuppleAloe64
      @SuppleAloe64 4 роки тому +4

      Krullerized You don’t, you build the makefile from scratch and trial and error (or use clues in how the code was compiled) to figure out the options that make the output binary match

  • @JayEm1325
    @JayEm1325 10 місяців тому +2

    Theres another video of a guy that makes mario 64 run at 60 fps on nintendo 64, by just coding it better. Absolute legend.

  • @Omn1Slash
    @Omn1Slash 4 роки тому

    Another awesome video MVG. Thanks for breaking it all down!

  • @Heavenira
    @Heavenira 4 роки тому +29

    You do realize that if you were to make a coding tutorial for the basics, people would absolutely eat that up. You speak with such conviction its incredible.

  • @ChannelSho
    @ChannelSho 4 роки тому +36

    I like it when someone who actually has experience and even referenced the actual documentation digs in, rather than go with the armchair developer cry of "lazy programmers can't even optimize"
    Programming is hard.

  • @TheNiteNinja19
    @TheNiteNinja19 4 роки тому +7

    I love the Nintendo DS version of this game, polished it up so much and added so much, without taking away from the game itself.

  • @CapnSlipp
    @CapnSlipp 4 роки тому

    Well done. I was pretty upset about the misinformation in other YTer's video about Mario 64 and O2, and you've straightened out most of it. The only thing I'd add is that I believe Nintendo was using Codewarrior, not GCC, and that the makefile was created by the decompilation team (it's impossible to decompile a makefile from assembly- it's literally jusy instructions for the compiler, not the runtime/device).

  • @seancondon5572
    @seancondon5572 4 роки тому +1

    Wow. As a Gentoo Linux user this is like... SUPER triggering. -O2 is like... THE MOST BASIC optimization option. This isn't -funroll-loops we're talking about here.

  • @ZeldaTheSwordsman
    @ZeldaTheSwordsman 4 роки тому +3

    It's noteworthy that whatever Nintendo did and didn't do, the ROM is only 8MB.
    Looking at the comment of Nobody, who was apparently involved in the project, this vid probably merits a do-over. Especially since the useless bozos who run UA-cam took away annotations.

  • @M1XART
    @M1XART 4 роки тому +10

    Nintendo has always aimed to go for stable frame rate. This is also the reason, why small rooms on Zelda:OOT run at the same frame rate as Hyrule field. Even though the N64 would be able run smaller arear easily 60fps. Nintendo just wants balance. Perhaps if they found that Mario 64 would have some slowdown, while still running 60fps most of the time, they would reject the idea. I have European PAL and USA & Japan NTSC - -versions of Mario 64. European version has worst framerate (still stable, though) and it does not have rumble pack support even on players choice version. USA/JAP versions run equally stable when compared each other, and faster than PAL.

    • @Unit_00
      @Unit_00 2 роки тому

      I may be wrong on this but weren't most N64 games 480i resolution? That would mean 30fps is the limit

    • @M1XART
      @M1XART 2 роки тому

      @@Unit_00 Most N64 games were 240 progressive scan. Very few games (without Expansion Pack) were above. But it's worth to mention that N64 could change resolution during gameplay. Those games have problems with current flatcreen TV's that have poor response time (gray to gray).

  • @andljoy
    @andljoy 4 роки тому +17

    would be interesting to see what a modern GCC could do optimising that code.

    • @RobertDunn310
      @RobertDunn310 2 роки тому +3

      You can try compiling the source code yourself. You will just need to provide an original ROM since the source code does not include the game's assets due to copyright reasons.

    • @D0Samp
      @D0Samp 2 роки тому +3

      Surprisingly not much, since the MIPS-specific parts of code generation have changed little due to lack of interest and focus was mostly on stability for use in routers etc. before they switched to ARM. There's no magic gains to be made from auto-vectorization either since the only powerful vector unit is in the GPU, unlike the Playstation you have to go through microcode to make use of it.

  • @MGlBlaze
    @MGlBlaze 4 роки тому +1

    So basically, only PARTS of the game were left with reduced optimization; but they actually did that intentionally because their tools and compilers at the time were prone to errors that could potentially break the game, and they didn't want to risk it with it bring one of exactly two launch titles - but other more generalised parts that were also used throughout the game were indeed optimised. And the people saying "They didn't optimise the game!" are cherry-picking.
    "They ran out of time" is a pretty common story in game development, especially back then when you couldn't just patch a game for everyone post-launch.

  • @cholarrytheone
    @cholarrytheone 3 роки тому +3

    This channel is actually one of those hidden gems of youtube. Keep it up!

  • @CinnamonOwO
    @CinnamonOwO 4 роки тому +9

    2:58 This is misinformation, The Super Mario 64 Decompilation Project was done by hand and sometimes used Mips to C Decompiler, No Ghidra, Ghidra does a bad job at decompiling SM64, No Ghidra, it's not a good tool for this job, *No Ghidra*

    • @zzco
      @zzco 4 роки тому

      He got the information from somewhere, though.

    • @fders938
      @fders938 4 роки тому +1

      No Ghidra

  • @captainnintendo
    @captainnintendo 4 роки тому +16

    Was there any additional optimizations or changes to the code done to the Super Mario 64 Shindou Edition?

    • @joshm264
      @joshm264 4 роки тому +1

      The only big one is patching out BLJ, and in Japanese SM64, when you got a key, it would turn into a star

    • @joshuashoup4261
      @joshuashoup4261 4 роки тому +4

      Shindou is not supported yet by the decompilation, but afaik the optimizations were just change to the second level of optimizations.
      Regarding changes, those are a bit more complicated. They updated their audio and main libultra files and added rumble support. They also did patch BLJ's, but there are likely other unknown fixes to the base. For example, we only recently discovered they patched a bug that allowed bullies to clip OOB if hit in lava while burning. In a few months, we will likely have a full answer to this question.

  • @Semmelein
    @Semmelein 4 роки тому +1

    As a programmer I was also sceptical of the initial claims but it was very interesting nonetheless. This video is even more amazing with all the background info. Thx dude!

    • @toooes
      @toooes Рік тому

      Little known fact: the green pipes are actually very septical

  • @FyberOptic
    @FyberOptic 4 роки тому

    I'm glad you addressed this, because I had kind of assumed the same based on my experience. It doesn't make the other video any less interesting, but it puts it into better context.

  • @Vienna3080
    @Vienna3080 4 роки тому +5

    Can’t believe the N64 came out more then 20 years ago...