Bugs & Glitches of High-Level NES Tetris

Поделиться
HTML-код
  • Опубликовано: 26 ноя 2024

Комментарии • 604

  • @gentlesoul221
    @gentlesoul221 8 месяцев назад +1446

    "And viewers like you, thank you." That brought me back to watching PBS Kids every saturday

  • @raggedystar8255
    @raggedystar8255 8 месяцев назад +526

    The fact that half a 'byte' is called a 'nybble' is a fact that I often forget and always feel joy upon remembering.

    • @halfsourlizard9319
      @halfsourlizard9319 8 месяцев назад +14

      nibble*

    • @raggedystar8255
      @raggedystar8255 8 месяцев назад +114

      @@halfsourlizard9319 The subtitles/transcript uses 'nybble', so I went with that spelling - though, according to Wikipedia, 'nibble', 'nyble' and 'nybl' are also used, with the 'y' usually added in place of the 'i' because it matches the spelling of 'byte'

    • @NocturnalTyphlosion
      @NocturnalTyphlosion 8 месяцев назад +79

      ​@@halfsourlizard9319 i love when pedants are wrong

    • @usernametaken017
      @usernametaken017 8 месяцев назад +41

      2 Bytes should be a Chomp

    • @Monody512
      @Monody512 8 месяцев назад +13

      I've always seen it spelled "nibl".

  • @radomiami
    @radomiami 8 месяцев назад +536

    I have no idea why, but I got unreasonably excited when the captions moved to the bottom right corner to make better use of the white space at 24:14.

    • @TheDMan2003
      @TheDMan2003 8 месяцев назад +42

      24:20 And then they desync for a moment there… (at least it actually gets fixed immediately).

    • @RGMechEx
      @RGMechEx  8 месяцев назад +253

      I use an external program to create the captions which allows for color and positional changes. However RUclips's support isn't entirely perfect so sometimes the text snaps back to the center when it shouldn't. It's better than the alternative of all the text being in the default position at least.

    • @thezipcreator
      @thezipcreator 8 месяцев назад +23

      @@RGMechEx what program is it?

    • @d-man4485
      @d-man4485 8 месяцев назад +19

      @@thezipcreatorYeah, it’d be nice to know how fancy captions can be created for videos!

    • @forgettablePyromaniac
      @forgettablePyromaniac 8 месяцев назад +15

      ​@@thezipcreatori would also like to know. Seems very useful! Assuming it can also do colour and things like that, and next thing you know, we have Tom Scott subs.

  • @voratheexplorer6442
    @voratheexplorer6442 8 месяцев назад +677

    Ah, my good friend "Important table indexed out of bounds resulting in important functions being fed garbage data"

    • @brinleyhamer729
      @brinleyhamer729 8 месяцев назад +97

      im pretty sure "table indexed out of bounds resulting in functions being fed garbage data" is the cause of most glitchiness in older games

    • @animowany111
      @animowany111 8 месяцев назад

      @@brinleyhamer729It's also the cause of 70% of computer bugs in general, if you trust google and microsoft (although that's a more general 'memory safety bugs' category, which includes out-of-bounds accesses and buffer overflows)

    • @markb5249
      @markb5249 8 месяцев назад +119

      If not code, why is code-shaped?

    • @absurt11
      @absurt11 8 месяцев назад +31

      If you want things to fall apart with style, you gotta use pointers!

    • @Operational117
      @Operational117 7 месяцев назад

      @@brinleyhamer729
      Absolutely. That's essentially what MissingNo. is: a Pokémon entry that references garbage data that is located outside of the table of valid Pokémon-species.
      Without safeguards to ensure the index pointer *never* exceeds the valid boundary of a table, things like wrong palette colors and MissingNo. happen. Even if you try to develop safeguards against that, you may still experience edge cases where these safeguards fail.

  • @aGameScout
    @aGameScout 8 месяцев назад +221

    Thanks for covering NES Tetris! I'm blown away with not only how clear your explanations are, but how clean your editing and presentation style is, while showing a lot of very intricate stuff.

  • @hydrantdude3642
    @hydrantdude3642 8 месяцев назад +166

    Wonderfully explained! This channel was a source of inspiration for my own videos on mechanics, so it coming back around and contributing to one of the videos is an incredibly cool feeling. Even though I already know how everything described worked, I still got some great value out of the visuals in this video. Writing out all the code in the frame at 37:00 is beautiful. Most of all though, I want to give Frieze credit for seemingly deriving lots of the info on his own-- our community has already disassembled the game fully, but when he reached out to me with the script, he'd disassembled the code himself with different labels! I barely had anything to correct him on, which was refreshing compared to a lot of other journalism following the publicity of Blue Scuti crashing the game.
    Thanks for the excellent work!

  • @AB-Prince
    @AB-Prince 8 месяцев назад +203

    it would take ungodly amounts of foresight to have thought of this fix back when this game was made, but some of the crashes could have been avoided by checking if the score was already "999999" before running the score update routine. or once it's done the check at the end of the routine, then set a flag in memory to say to not bother running the routine again.

    • @arlasoft
      @arlasoft 8 месяцев назад +44

      Another way would be to restrict the number of times the score loop can run in one frame, it's no big deal if it's spread over a few frames, it would even give an unintentional counting up effect to the score display.

    • @davidmcgill1000
      @davidmcgill1000 8 месяцев назад +52

      Considering they would have definitely known that the level number was 8 bits yet didn't bother to limit that going past that, I'd imagine they just never expected anybody to play that long. Missing 128 being signed would be an easy oversight however.

    • @ClassicTVMan1981X
      @ClassicTVMan1981X 8 месяцев назад +18

      A similar extended routine is used in Super Mario All-Stars to fix the lives counter display problem in both Super Mario Bros. and Super Mario Bros.: The Lost Levels: first for the tens digits and the second for the hundreds digits; in the respective NES and FDS originals, the lives display counter used a crown for the tens digit, but the ones digit went through the entire character set from 10 lives onward.

    • @remskolney4040
      @remskolney4040 8 месяцев назад +8

      You could also compare to a level where a score less than 999999 is impossible, alternatively you could limit the score counter input to only two numbers so it just rolls back to 00 at level 100.

    • @3rdalbum
      @3rdalbum 8 месяцев назад +20

      ​@@davidmcgill1000 They never expected play beyond level 29 or 30. At that falling pace, it's impossible to tap the d-pad quickly enough to get pieces to the side walls, so you can't complete any more lines - at least, it's impossible with normal controller posture.
      The only reason human players can get higher is because they developed special techniques for holding the controller differently in order to achieve the required number of taps per second.

  • @aceae4210
    @aceae4210 8 месяцев назад +78

    the subtitiles/closed captions are very good here, thank you.
    (like at 27:25, they go to the right where there is space so you can see the cpu and stack info but when that ui is not there, it just goes to the center, very good job)

  • @diribigal
    @diribigal 8 месяцев назад +427

    Don't interrupt me when I'm in my lonely spinning loop.

    • @LiliumOrientalis
      @LiliumOrientalis 8 месяцев назад +85

      *ONLY* interrupt me when I'm in my lonely spinning loop.

    • @charlotteshenkenberger345
      @charlotteshenkenberger345 8 месяцев назад +10

      Apologies, but I must interrupt you now.

    • @thenoteverythingchannel
      @thenoteverythingchannel 8 месяцев назад +4

      Someone watched the video!

    • @notnullnotvoid
      @notnullnotvoid 8 месяцев назад +17

      I'm just out here, waiting for someone to come interrupt my lonely spinning loop

    • @argil7192
      @argil7192 7 месяцев назад +6

      You're lonely rolling star
      Don't stand in one place, ok?
      You're lonely rolling star
      So, face forward and let's go!

  • @betamaxuser1282
    @betamaxuser1282 8 месяцев назад +95

    33:17 - It should be noted that a real 6502 CPU has a built-in decimal arithmetic mode allowing it to add and subtract BCD numbers easily. The CPU in the NES is not a true 6502, but a Ricoh 2A03 (or 2A07 in PAL/SECAM machines) made by Ricoh for Nintendo.
    The 6502's BCD logic was patented and required royalty payments to MOS Technology, the inventor of the 6502.
    To avoid this, the 2A03/2A07 simply omits the decimal mode, requiring BCD calculations to be done manually, as shown in your example. If the decimal mode had been available, the code to add points to the score would have been much simpler and shorter.

    • @vuurniacsquarewave5091
      @vuurniacsquarewave5091 8 месяцев назад +13

      It makes sense this was omitted because an NES game didn't require BCD for much else other than data displayed to the user like time or score, while office applications on a C64 for example or Apple might have benefited more from it.

    • @Toonrick12
      @Toonrick12 7 месяцев назад +15

      Now you might ask "Why didn't they want to pay royalties to MOS Technology?" The answer is simple. MOS was owned by Commodore at this time. Thus Nintendo didn't want to help the competition. It might sound odd since in America, the NES and the C64 were in completely different markets. In Europe however, they most definitely were market rivals.
      (Though in an alternative universe, if Nintendo did pay out the royalties, there's a chance the Commodore and MOS could of stayed in business thanks to Nintendo's payments.)

    • @nonagonguy6121
      @nonagonguy6121 22 дня назад +1

      Wow, patent law really does ruin everything, huh?

  • @GamingGardevoir
    @GamingGardevoir 8 месяцев назад +57

    The smile that came across my face when you said “…and viewers like you! Thank You!” is immeasurable. That was a heavy nostalgia bomb for me!!! 😊

  • @TuxraGamer
    @TuxraGamer 8 месяцев назад +452

    Bro really worked out how to smoothly blend a 69/420 joke in an otherwise 100% serious video. Absolutely epic.
    Edit: go to 22:13 for the sauce

    • @michaelcalvin42
      @michaelcalvin42 8 месяцев назад +15

      Wait, really? I missed it (probably because I, too, was in 100% serious mode.) You got a timestamp?

    • @eljefecom
      @eljefecom 8 месяцев назад +21

      Starts at 22:13

    • @macstevins
      @macstevins 8 месяцев назад +13

      i hate that i saw this before the scene, and i *still* didnt notice it

    • @DrPeeper
      @DrPeeper 8 месяцев назад +18

      LMFAO IT'S SO SEAMLESS

    • @michaelcalvin42
      @michaelcalvin42 8 месяцев назад +7

      @@eljefecom Haha, nice. I completely missed it the first time, but there it is, plain as day.

  • @breadcodes
    @breadcodes 8 месяцев назад +35

    This is literally the first channel I name when someone asks what I watch. Thanks for the hard work!

  • @zeta0134
    @zeta0134 8 месяцев назад +22

    When we talk about the vblank interrupt on the NES pausing the CPU no matter what it's doing, that's more true than you might think. The PPU signals vblank using NMI, which stands for "non-maskable interrupt", and it's a special signal the CPU is hard-coded to always take. Other interrupts (IRQs) can be ignored by the software during sensitive work. If you're reading the NESDev Wiki or doing research, you'll often hear people talk about their "NMI routine." It's the same thing, that's just the work that starts at the top of vblank. Naming things is hard. :D

    • @vuurniacsquarewave5091
      @vuurniacsquarewave5091 8 месяцев назад +3

      That's why it blows my mind that the PC Engine was designed with completely ignoring the NMI. It is simply not connected to anything, you have to use any sync to video through the IRQ vector, and you need to set it up on the display's side whether you want it triggered by VBlank or the scanline counter.

  • @jakint0sh
    @jakint0sh 8 месяцев назад +17

    I absolutely LOVE the “viewers like you, thank you!” in the intro. Reminds me of when I used to watch PBS Kids in the late 2000s, such a throwback. Great video as always, keep ‘em coming!

  • @Kaishidow
    @Kaishidow 8 месяцев назад +47

    Blessing us with a nearly 1h video

  • @CambriaBold
    @CambriaBold 8 месяцев назад +450

    Babe wake up, new Retro Game Mechanics Explained dropped

    • @TactileTherapy
      @TactileTherapy 8 месяцев назад +15

      waifus dont sleep

    • @jmkqfnvyl87
      @jmkqfnvyl87 8 месяцев назад

      She didn’t want to wake up. Or watch . . Kept saying Tetris was a product of Russian collusion. . . 😅

    • @jaredjoe133
      @jaredjoe133 8 месяцев назад +3

      @@fuggler2465 my guy you are insulting

    • @olivercharles2930
      @olivercharles2930 8 месяцев назад +1

      @@fuggler2465 ???

  • @dakotaboy80
    @dakotaboy80 8 месяцев назад +11

    As soon as Blue Scuti broke the game, I knew RGM would have to do an episode like this. Well done, sir.

  • @JJW410
    @JJW410 8 месяцев назад +10

    Found this channel last night and I'm endlessly impressed. Fantastic communicative visuals, great voice over, no distracting music -- 10/10, love it.

  • @Zettymaster
    @Zettymaster 7 месяцев назад +5

    i love how this is essentially explaining bugs (mostly use after free, aliasing and out of bounds indexing) in context. still technical, but with enough game elements and diagrams to explain everything.

  • @MM4646
    @MM4646 8 месяцев назад +24

    Always fun to see the details of why a game breaks, ty for all the good content

  • @creepercraftytT99
    @creepercraftytT99 8 месяцев назад +36

    Finally RGMEx made a video about a Tetris Game!!
    Wait, what about the 810-line long level?

    • @tookiecar1
      @tookiecar1 8 месяцев назад +1

      B L U E

    • @h3nry_s71ckm1n
      @h3nry_s71ckm1n 8 месяцев назад +4

      The 810-line long level happens for the same reason that it takes 130 lines for you to level up from level 18 to level 19 on a 18 start.

    • @creepercraftytT99
      @creepercraftytT99 8 месяцев назад +1

      ​@@h3nry_s71ckm1n yeah but i meant why wasn't it featured on the video

  • @ExaltedUriel
    @ExaltedUriel 8 месяцев назад +16

    This is exactly the calming content I needed right now, been super stressed out. Time to pop this on and let this super neat info I won't retain wash it away...

    • @ExaltedUriel
      @ExaltedUriel 8 месяцев назад +5

      ​​@@ToTheGAMESWow thanks for the extremely specific and actionable advice, you obviously know exactly what I'm going through Mr. Comments Section Therapist. Nice job liking your own comment btw.

    • @celsiuspsi6770
      @celsiuspsi6770 8 месяцев назад +3

      i'm sure you're doing great, even just by getting through the day and doing your best; i sincerely hope you feel better soon, the stress won't last forever ❤

  • @sirembrum49thegreatmoth2
    @sirembrum49thegreatmoth2 8 месяцев назад +189

    7:44 This isnt palette glitches. THIS IS PATRICK

    • @patientallison
      @patientallison 8 месяцев назад +20

      Since some glitched palette levels have names (dusk, charcoal) I like to call this one watermelon.

    • @sirembrum49thegreatmoth2
      @sirembrum49thegreatmoth2 8 месяцев назад +11

      @@patientallison that's pretty good right there! :D I gotta look at more of these glitched palettes and see what funs to cook up :) like color table 244: (61) it's mostly very dark blue's and they're barely different from one another. So I call this Deep Sea or Twilight Zone

    • @JetFalcon710
      @JetFalcon710 8 месяцев назад +10

      ​@@sirembrum49thegreatmoth2 There's one that I fondly refer to as "Nuclear Christmas"

    • @sirembrum49thegreatmoth2
      @sirembrum49thegreatmoth2 8 месяцев назад +4

      @@JetFalcon710 oooo which one is that ? :D

    • @JetFalcon710
      @JetFalcon710 8 месяцев назад

      @@sirembrum49thegreatmoth2 125 (32), it's at the very top of the second column

  • @aprilgwynn
    @aprilgwynn 8 месяцев назад +44

    This video reignites the spark of wonder I get from low-level programming. Things are what we make of them. The numbers aren't "signed integers" unless we treat them like one. It's all just ones and zeroes. Excellent explanation as always ❤

  • @EntergeticalakaBot
    @EntergeticalakaBot 8 месяцев назад +49

    The waiting spinning loop feels like a Sisyphus moment, just doing the same thing over and over until its out of its misery

    • @thisisachannelwhy42069
      @thisisachannelwhy42069 7 месяцев назад +14

      One must imagine the CPU happy

    • @NocturnalTyphlosion
      @NocturnalTyphlosion 6 месяцев назад +3

      i look at it more like those dogs who wait for their owners at train stations

  • @egg.mpeg4
    @egg.mpeg4 8 месяцев назад +14

    i can not describe my excitement when a new video uploads
    YESSS

  • @RhythmJigoku
    @RhythmJigoku 8 месяцев назад +5

    Welp, time to clear my schedule for an hour!
    It's always amazing how approachable these videos are, even to people who aren't this type of tech-inclined.

  • @glarynth
    @glarynth 8 месяцев назад +9

    Really enjoyed this one! I think Dr Mario has a similar problem getting bogged down in binary-coded decimal scorekeeping when there's an extremely large combo.

  • @biggallcaps
    @biggallcaps 8 месяцев назад +5

    Thanks for covering this! With the Tetris records being broken, now I can finally have an idea as to why it does what it does

  • @bmenrigh
    @bmenrigh 8 месяцев назад +7

    I'm very glad you decided to tackle this. I was not satisfied with the technical depth (or lack of, as is the case) with the other explanation video(s).

    • @sugardude
      @sugardude 6 месяцев назад

      Exactly. However, to be fair, I thought it is reasonable to not provide technical explanation after watching this, because it is just that hard. You basically have to do a course for CPU architecture and assembly code; a notoriously difficult subject.

  • @PubstarHero
    @PubstarHero 8 месяцев назад +27

    Why did you upload this? I have chores I wanted to handle, but now I have to watch an hour long video about the tetris kill screen and glitches.

  • @YaroKasear
    @YaroKasear 8 месяцев назад +29

    Fun fact, the 6502 ISA actually has a BCD mode, but the Ricoh chip has that physically severed and disabled in the NES.

    • @jacoblister
      @jacoblister 8 месяцев назад +7

      the Gamboy Z80ish CPU does have BCD adjust instructions - don't know if they are used by the game though. I wrote emuboy on github recently - just remembered the BCD codes were a pain to implement

    • @vuurniacsquarewave5091
      @vuurniacsquarewave5091 8 месяцев назад +4

      @@jacoblister Now that's an interesting thing, since the Gameboy's version is sort of cut down and a tad closer to an Intel 8080, especially since the Z80's IX and IY registers were removed. In general this gen of CPU's had some smart 16-bit like operations on an 8-bit CPU, while the 6502 took a cheap but still decent approach instead. It's a bit like modern Intel vs. AMD honestly.

  • @opalpersonal
    @opalpersonal 8 месяцев назад +1

    your infographics and special animations while explaining processes really help me understand what’s going on way more than just an explanation on its own. thank you so much for taking the time to make them (especially making them so sleek and nice), it really helps me get the concepts much better!!

  • @Dr_Cosmobyte
    @Dr_Cosmobyte 8 месяцев назад +117

    Do i know programming? No.
    Is this important to my career? No.
    Do i understand what's going on? No.
    Will i make a Tetris-based game? Not that i know now.
    Do i like this? YES.

    • @brian8152
      @brian8152 8 месяцев назад +2

      Same lol

    • @lmnk
      @lmnk 8 месяцев назад +8

      The fun thing is, we had Assembly on 1st uni course, and just watching RGME out of fun when I was in high school made me feel much more familiar with it (despite like 2/3 of the instructions being different), even though I never programmed in it (I only programmed in Python and JS) before uni. So, who knows? =)

  • @forgor-uhh
    @forgor-uhh 8 месяцев назад +5

    I was wondering how this happened after watching a StackRabbit video yesterday. Today, I see this. RUclips recommendations are absolute gold, thank you for making this!

  • @20LeeBrian1
    @20LeeBrian1 7 месяцев назад +1

    “And viewers like you, thank you.” I really like that quote since it brought me PBS and PBS kids nostagia!

  • @LovroPlaninšek
    @LovroPlaninšek 8 месяцев назад +1

    THANK YOU SO MUCH for the detailed explanation of the line clear crashes, I was confused as to what was happening back in 2019 when I made my mullti-255-level-loop TAS (I made it to around level 700 or so before giving up)
    After a bit I read somewhere that "the score calculation would take too long", but I wanted to know more details. I've known about this channel even back then, but unfortunately I'm not very savvy when it comes to understanding assembly, so basically I've been waiting for your visualisations in this specific video since early 2020 haha

  • @rosi_com
    @rosi_com 8 месяцев назад +7

    Your videos are always excellent and a joy to watch and be intrigued by! Got so excited when I saw a new upload! ^^

  • @dietpebsi
    @dietpebsi 8 месяцев назад +2

    Love this!! Your voice is so calming and I love how you describe these things in detail so we know exactly what's going on behind the scenes instead of a sanitized explanation. For some reason youtube unsubscribed me to you and I think it did this for other ppl too so don't think your vids aren't interesting, youtube is just weird!! This video is awesome and even though I'm def not an expert on NES coding and honestly hex in general (I'm more of a bash and python fella myself) you explained it in a way that I could still mostly understand with limited knowledge!! Awesome vids as always!!

    • @dietpebsi
      @dietpebsi 8 месяцев назад

      Also garbage data truly seems to cause so many problems in these types of games lol

  • @zeemee9631
    @zeemee9631 2 месяца назад +1

    this is my favorite channel on youtube. i had to become a member to support you in the best way i can

  • @brianalmon
    @brianalmon 8 месяцев назад +6

    Going beyond the expected address space is like going off the edge of a medieval map - here there be dragons.

  • @WingedAsarath
    @WingedAsarath 8 месяцев назад +22

    I see those choices of the numbers 69 and 420 in your example at 22:39 🧐

  • @atc_wro
    @atc_wro 7 месяцев назад +3

    I thought the youtuber TheZZAZZGlitch had some insane machine code analysis, this is just next level, you're showing specific instructions and explaining them one by one and It is way easier to follow, I love the visual component to those videos, since it better utilizes the medium than just having text on screen to pause and read.

  • @johneygd
    @johneygd 8 месяцев назад +6

    Eventrough it’s all very complicated to understand,but it is well explained,also i absolutely like how you explain stuff,no annoying generic stuff,no overhumorism,no sarcasm,no jokes and that’s how i like it,just focussing on the subject rather then interrupting it with jokes or so,
    And that’s how it always should be😁

  • @evidence2839
    @evidence2839 8 месяцев назад +9

    I was busy but not anymore, RGME video!!

    • @raafmaat
      @raafmaat 8 месяцев назад

      i was gonna sleep but i guess that'll have to wait an hour! :)

    • @evidence2839
      @evidence2839 8 месяцев назад

      @@raafmaat ooooh noooo... /s

  • @Grey-mo5py
    @Grey-mo5py 8 месяцев назад +1

    I always love when you post a new video, especially these super long ones. it's so intriguing to learn about how all these older games and systems worked with their limited capabilities.
    amazing video as always, time to rewatch over and over until I memorize it :)

  • @terrafimeira
    @terrafimeira 8 месяцев назад +5

    I could listen to these all day. Interesting to learn the workings and quirks of deeper hardware/software through the context of gaming.

  • @HmmmmmLemmeThinkNo
    @HmmmmmLemmeThinkNo 7 месяцев назад

    Someone in the comments mentioned the captions and i'm going to cry, there's real captions!! Thank you _so_ much for having them. I can actually understand so much more easily now

  • @MadamLava094
    @MadamLava094 2 месяца назад

    I absolutely love your visualization of all the lines of code that run in a frame! Really puts into perspective how limited a processor that runs at a few KHz is, and how a function improperly looping too many times can consume so much of the limited time.

  • @HBMmaster
    @HBMmaster 8 месяцев назад +15

    I'm never going to unhear "x position" as "exposition"

    • @RGMechEx
      @RGMechEx  8 месяцев назад +13

      Neither can my captioning software!

    • @janajusimi269
      @janajusimi269 8 месяцев назад

      I did not expect to see you here hi

  • @RoysGamingGarret
    @RoysGamingGarret 8 месяцев назад +9

    There is one thing that is missed. One of the levels between 210 and 220 is around 800+ lines before it proceeds to level up.

  • @Chubby_Bub
    @Chubby_Bub 8 месяцев назад

    Even though I know how assembly language works in general, it always seems so daunting when it appears on screen, but you do such a good job of explaining it. Explanations of low-level language like this, especially with the dependence on frames, serve as a reminder of just how much computers are doing each instant, and games like this are the perfect way to demonstrate it. :)

  • @sierranicholes6712
    @sierranicholes6712 8 месяцев назад

    i always really appreciate how these videos build up the topics on each other as the video progresses! feels really clear and easy to understand.

  • @DanielsG
    @DanielsG 7 месяцев назад +1

    Hi RGME, first of all, amazing video as always! I've been watching your content for a while and thought you would be the perfect guy for diving deep in to the Playstation's personified fear and fearful harmony errors, I've always wondered how they've worked down to specifics and your content style seems perfect for them!

  • @wamp9175
    @wamp9175 8 месяцев назад +1

    As an old C64 coder, every time I see 6502 code I just have to stop and watch. Dude, you have a good handle on it. Kudos...

    • @D0Samp
      @D0Samp 8 месяцев назад +1

      Also this is extra painful since the 2A03 does not have BCD mode. If it did, the level and score counter would just be SED + a bunch of ADCs + CLD.

  • @skjell3439
    @skjell3439 3 месяца назад

    Your videos are actually some of the best explanations of assembly code I've ever seen, this is so fascinating

  • @plindquist84
    @plindquist84 8 месяцев назад +1

    Thank you so much!!! It is so much fun learning about what's going on behind the digital-curtain!!!

  • @Sonicgott
    @Sonicgott 8 месяцев назад

    I love how beautifully and carefully you explain the detail in these videos. It’s like a mini tutorial on computer science. ❤

  • @asterpw
    @asterpw 8 месяцев назад +1

    36:53 Totally amazing to see the code of a single cycle. What a cool visualization! I wish debuggers could show things like this.

  • @AlecInstant
    @AlecInstant 8 месяцев назад

    Videos like these are the only way I can understand more complicated topics. And insanely entertaining. Thank you

  • @wiirambo7437
    @wiirambo7437 8 месяцев назад

    Great video!
    Some minor corrections:
    There are actually two lookuptables for the level display the other one goes up to level 49.
    When the score loop takes so long and is interrupted by the NMI, the counter get overwritten by the BCD represention of the lower 2 digits of the (old *) line counter.
    That means after returning from the interrupt the score loop runs BCD represention of the lower 2 digits of the line counter - 1 times before exiting. This is a value beetween 0 and 152. Running it 152 time will finish before the NMI trigges again so no further corruption can happen. If the line counter ends in 00 it will run 255 times which is so long it will overrun the next frame too and will cause another lag frame. But it is so long that NMI will never happen to corrupt anything. So it is sort of lucky that can never trigger any corruption.
    The PAL version has some different effect when reaching high levels.
    * past some point the displayed numbers of the line counter no longer matches that used in working RAM

  • @Dragonmaster022783
    @Dragonmaster022783 8 месяцев назад +1

    Great vid and thanks for the explaination of the code. I guess one "bug" that was left out of the video on the code would be the one level that goes on for 800+ lines.

  • @Lefty7788tinkatolli
    @Lefty7788tinkatolli 8 месяцев назад +9

    In the 200s a "super level" occurs too, due to an issue with the level-up code.

    • @jangamecuber
      @jangamecuber 8 месяцев назад +3

      and the fact that at least 1 level up and at least 1 line will not visually update the level/score count

    • @EebstertheGreat
      @EebstertheGreat 8 месяцев назад +3

      That is related to the bug that causes games starting on level 10 or higher to transition at the incorrect number of lines. Unlike the bugs mentioned in this video, that bug is actually super relevant to normal play. For instance, if you start at 18, you will transition to 19 after just 130 lines instead of the expected 190. This is just a mistake in the code; it's supposed to convert a binary value to packed BCD using the lookup table, but it just doesn't. Meatfighter has a good description of it at nintendotetrisai.
      Incidentally, this is one way in which wrapping around from level 255 to 0 doesn't really "reset" the game. Since the bugged level is based on line count, it will occur at a different level the second time around.

  • @Marksman560
    @Marksman560 8 месяцев назад +1

    This video is such a masterpiece, one every dev and gamefreak should watch.

  • @Controllerhead
    @Controllerhead 8 месяцев назад

    Incredible video! Excellent explanations and visualizations of raw 6502 into game concepts. Your label names are very well chosen. I did a romhack a while back of this game (Tetris Excel on RHDN) and it's great to see these routines all laid out like this so clearly: Perhaps releasing your label file (.MLB?) could help future romhackers, i would have LOVED to have a resource like that.
    It's also very silly to see that most of these crashes could have been avoided lol, though, humans weren't really supposed to get past level 29. Honestly, it was a fair thing to assume, no one in 1988 could have predicted the controller tapping methods perfected by the Classic Tetris community in the 2020s. I'm excited to see the race to 255, and if humans will ever get there...

  • @jamesdoesthings1096
    @jamesdoesthings1096 7 месяцев назад

    I've been blessed to find such a channel that makes incredibly informative and clear explanations on things I am so interested in.

  • @Pigeins
    @Pigeins 4 месяца назад

    I dont understand 90% of this stuff, but i cant stop watching these videos on here. Its always nice background noise as well while i play video games 😅 Very fascinating stuffs

  • @eduardorickrot4763
    @eduardorickrot4763 8 месяцев назад +2

    Amazing how it’s very interesting but also this video is great at making me fall asleep. Thank you, one day I’ll finish watching!

  • @NickNackGus
    @NickNackGus 8 месяцев назад

    Excellent video as always :) Speaking of code waiting for an interrupt to occur - more modern processor designs allow you to effectively turn off the CPU until an external interrupt occurs instead of spinning in a loop, which is useful for reducing energy usage in battery powered devices like phones. Modern operating systems do something similar to this to allow a program to stop running until it's got something it needs, like keyboard/mouse inputs or network messages.

  • @willarasmith4893
    @willarasmith4893 8 месяцев назад

    Watched the whole thing. Had no idea what you said for any of it. Enjoyed it immensely.

  • @erok0809
    @erok0809 6 месяцев назад +2

    Summoning Salt just put out a new video on NES Tetris, and I already knew some of the stuff he was going to mention like the glitch colors because of this video

  • @BrunoValads
    @BrunoValads 8 месяцев назад +1

    Amaaaaaaazing video! I would love a part 2 where you propose fixes for these various coding mistakes, to make it failproof

  • @DEADEYESTUDIO
    @DEADEYESTUDIO Месяц назад

    i love watching these, its fun to hear how these are coded. i used to hate coding, and only enjoy making art of the game but once i started to learn its actually very enjoyable, like a lil puzzle to figure out.

  • @the0007lord
    @the0007lord 6 месяцев назад +1

    With Summoningsalt's new video, I got reminded of this and am rewatching to see just what causes the legendary crashes.

  • @whamer100
    @whamer100 8 месяцев назад +1

    this is such a nice video, absolutely well worth the wait

  • @AubrianneAnderson
    @AubrianneAnderson 8 месяцев назад

    Thank you for all your videos. I've watched them all and learned a lot, then subsequently rewatched them many times for their calming effect. In fact, I've watched them enough that I'm actually starting to retain some of the information through osmosis, despite not having much of a technical background (or brain).
    Also, I doubt you think about this, but I was glad to see another of your videos with a black background for improved night mode learning!

  • @quintopia
    @quintopia 8 месяцев назад +1

    i love how much detail you go into. hydrantdude's videos were good enough to get the basic idea across, but you really made everything clear.

  • @csehszlovakze
    @csehszlovakze 8 месяцев назад +3

    I assumed it would be something like this, but thank you for going in extra detail!

    • @turnkey_hole
      @turnkey_hole 8 месяцев назад

      Why is the Palestine flag in your picture so weird

    • @csehszlovakze
      @csehszlovakze 8 месяцев назад +1

      @@turnkey_hole what? 🤣 the background is the Hungarian flag, and what Gollum's holding is Possessed's _Seven Churches_ LP.

    • @turnkey_hole
      @turnkey_hole 8 месяцев назад +1

      @@csehszlovakze oh... Well, respect. Free Hungarian, too

  • @RobinLeGaming
    @RobinLeGaming 8 месяцев назад

    I've been waiting for a Tetris video from RGMechEx for a while now, and I'm not disappointed ☺️

  • @RipVanFish09
    @RipVanFish09 8 месяцев назад +6

    Party time, RGME upload! :D

  • @mattlau04
    @mattlau04 8 месяцев назад

    These videos give me a better understanding of computers than my computer architecture classes, pretty amazing

  • @Allen_isnt_available
    @Allen_isnt_available 8 месяцев назад

    I absolutely love how you explain the code line by line!!!!

  • @nathang5518
    @nathang5518 8 месяцев назад +1

    I don't know why I like these videos so much but I really do 😂

  • @walugusgrudenburg3068
    @walugusgrudenburg3068 8 месяцев назад +1

    The amount of ways, often basic safety measures, that the crash could have been avoided is crazy. It's a bizarre set of coincidences that it happens at all.

  • @Leadbraw
    @Leadbraw 8 месяцев назад +2

    Gotta be my favorite channel

  • @Aethelia
    @Aethelia 8 месяцев назад +1

    It was kinda weird how people somehow just recently discovered the NES Tetris limits for some reason. It is not really news, it has been known for awhile now to people like us. I did not go as far as you because I am just an amateur compared to what you do, but I came up with some game genie codes years ago to prevent the check for losing, and to add 10 lines to the counter after every block drop, so I could quickly see all the colors it goes through. Makes it really easy to hit the game ending glitch, but it is just as easy to get around that too and see the various effects of seemingly clearing thousands of lines. Also found a way to get only long blocks, if anyone is interested in that.

  • @alandecowski5945
    @alandecowski5945 8 месяцев назад

    We have been blessed with nearly an hour of Retro Games Mechanics!

  • @RNorthex
    @RNorthex 6 месяцев назад +1

    Clear, concise, and very well edited without it feeling dry. In a sea of sensationalist essays and reviews, this is a breath of fresh air. I love the way you do videos even if about half of it I don't understand, you make it very engaging.

  • @arlasoft
    @arlasoft 8 месяцев назад +5

    Some bizarre design decisions, it would have been far easier to make the palette lookup table have 8 or 16 entries and then just mask the level number to always get a valid entry. Or just use two extra bytes of RAM to permanently hold the level number in BCD as well as hex rather than having to use an inadequate lookup table each time - did they really think no-one would ever reach level 30? I can sort of understand why they thought people wouldn't reach levels high enough for the score routine to take so long. If I have an issue with something like that I'll usually restrict each frame to only processing X iterations and carry on with the rest on the next one, even if it takes 4-5 frames the player isn't going to notice.

    • @EebstertheGreat
      @EebstertheGreat 8 месяцев назад +4

      They weren't even sure if players could make it to 29. Making it to 30 is nearly impossible with DAS, and making it to 29 is a serious struggle and likely far beyond the abilities of anyone designing the game. They probably played up to level 10 and then made some basic checks for higher levels, but I doubt they could actually play them.

  • @harrisonmoore3841
    @harrisonmoore3841 8 месяцев назад

    I still love how a kid was the first human being to do it. Like, bro gets to feel awesome for much longer, that must be amazing

    • @gobblegobble2071
      @gobblegobble2071 7 месяцев назад

      And his determination got us to learn more about how tetris works!
      Screw the British reporter, this kid deserves high respect!

  • @MegaMonkeVr
    @MegaMonkeVr 5 месяцев назад

    I was expecting something like aGameScout’s videos but this helps understand how the glitches happen I love the video

  • @D0Samp
    @D0Samp 8 месяцев назад +2

    Since both the level counter update and the palette update deal with remainders modulo 10, they could both be fixed if they occur in that order, so the latter only needs to look at the ones digit. Also an obvious improvement to the score update is to loop over the lines cleared rather than the current level, which leads to at most 4 BCD additions.

    • @D0Samp
      @D0Samp 8 месяцев назад +1

      On second thought that's also not ideal, but better. The base score for singles through tetris are 40/100/300/1200 points, you could calculate 20*level (the game probably would have a lookup table up to level 29 for this) and then add that 2, 5, 15 or 60 times to the score. Still constant time well within the frame budget and wouldn't run any code when no lines are cleared, but a "score cap reached" flag is nevertheless a good idea.

  • @stilelits
    @stilelits 8 месяцев назад +2

    how crazy is it that they could have avoided ALL of those score-calculation crashes, if they had just hardcoded the score increment routine to exit immediately whenever the player is already at the maximum score?

  • @eddievhfan1984
    @eddievhfan1984 8 месяцев назад +2

    If Sky News drags this video too, there is no hope for humanity. Another banger.

  • @damiencouturee6240
    @damiencouturee6240 8 месяцев назад

    I just realized I havent been subscriibed, I thought I was cause you were always in my feed. Fixed that now lol, thanks for all the great videos!

  • @i_want_pizza7576
    @i_want_pizza7576 8 месяцев назад

    i got one for you: sound tunnels in doom.
    when i was a kid and i sometimes saw mysterious little holes in the wall, i figured they were used for something that had to do with the game but not what. much later i learned that's for the "sound" of the player to travel through to other rooms and wake up enemies.

  • @Periwinkleaccount
    @Periwinkleaccount 8 месяцев назад +4

    Great to see one on Tetris.

  • @chaathon2
    @chaathon2 8 месяцев назад

    I'm so glad NES Tetris had that much visibility, this game and its top players are incredible

  • @OPP03
    @OPP03 8 месяцев назад +1

    There is one more fall speed that was not covered in this video that I want to address.
    In levels 39 and beyond, another set of code was implemented for tournament use to set the drop speed past the level 29 drop speed, which is twice that of the previous drop speed. This fastest fall speed was originally never used in the original game, then implemented in a fanmade patch that is used in global Tetris tournaments, including the Tetris Masters and Tetris Mega Masters tournaments respectively. This sets the drop speed to 2 rows per frame, too fast for any normal player to master. This is dubbed the "Super Killscreen" or the "Run Killer", as it is simply too hard to consistently drop pieces in to get lines and avoid a topout.