Тёмный

Why MissingNo Multiplies Items! 

LiveOverflow
Подписаться 880 тыс.
Просмотров 178 тыс.
50% 1

In this part two we investigate how encountering a glitch pokemon will cause the 6th item to multiply. For this we are using Ghidra and SameBoy to debug and reverse engineer the code.
Part 1: • Researching MissingNo ...
Want to understand how to catch Mew? • Exploring the Mew Glitch
Checkout the whole GameBoy hacking playlist with stacksmashing: • Game Boy Hacking
PwnAdventure Game Hacking Series: • Pwn Adventure 3: Pwnie...
GhidraBoy: github.com/Gekkio/GhidraBoy
SameBoy: github.com/LIJI32/SameBoy
=[ 🔴 Stuff I use ]=
→ Microphone:* geni.us/ntg3b
→ Graphics tablet:* geni.us/wacom-intuos
→ Camera#1 for streaming:* geni.us/sony-camera
→ Lens for streaming:* geni.us/sony-lense
→ Connect Camera#1 to PC:* geni.us/cam-link
→ Keyboard:* geni.us/mech-keyboard
→ Old Microphone:* geni.us/mic-at2020usb
US Store Front:* www.amazon.com/shop/liveoverflow
=[ ❤️ Support ]=
→ per Video: / liveoverflow
→ per Month: / @liveoverflow
=[ 🐕 Social ]=
→ Twitter: / liveoverflow
→ Website: liveoverflow.com/
→ Subreddit: / liveoverflow
→ Facebook: / liveoverflow
=[ 📄 P.S. ]=
All links with "*" are affiliate links.
LiveOverflow / Security Flag GmbH is part of the Amazon Affiliate Partner Programm.

Опубликовано:

 

10 май 2020

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 523   
@Hex-DumpsterFire
@Hex-DumpsterFire 4 года назад
The fact, that we're in 2020 and people are still talking about Missingno makes me very happy
@MysticIceFire
@MysticIceFire 4 года назад
Missingno best pokemon,,,
@RedstoneHair
@RedstoneHair 4 года назад
Yeet, I'm playing on lakka pokemon red to get missingno, I got fly and all, I need surf and the island and I will get missingno
@ieanenizedsalt3311
@ieanenizedsalt3311 4 года назад
Quarantine my boi. Quarantine
@wayge
@wayge 3 года назад
Not only are we still talking about it, were still learning things about it
@JesusSaves4real4real
@JesusSaves4real4real 3 года назад
2021
@StanleyDarsh22
@StanleyDarsh22 4 года назад
this is beautiful. not only are you clever for coming to the conclusion you did, but very intelligent for your ability to communicate the behavior of the bug to an audience that knows way less about it than you do.
@TypicalSardine
@TypicalSardine 3 года назад
Literally this looked like magic to me, I hardly understood a thing but I still feel enlightened 😂
@Egan466
@Egan466 3 года назад
that's the reason I love his channel.
@supportic
@supportic 4 года назад
Every video is like watching a detective series.
@kebien6020
@kebien6020 4 года назад
This. I think it's on purpose, and he makes it work sooo well.
@RedstoneHair
@RedstoneHair 4 года назад
Ya
@ReturnRei
@ReturnRei 4 года назад
I like the "how you could've found it yourself" approach as it teaches beginners how to get started in reverse engineering / research! Great Video!
@fouzaialaa7962
@fouzaialaa7962 4 года назад
as my grandpa always said :always check for array out of bound
@aytchemil
@aytchemil 4 года назад
oh gramps
@RussellTeapot
@RussellTeapot 3 года назад
so.. this is basically a buffer overflow?
@fouzaialaa7962
@fouzaialaa7962 3 года назад
@@RussellTeapot yes but the conditions was not catched by anything !!! usually it will be stopped at runtime and caught there but a buffer overflow is wen it doesn't get caught by anything and it roams the memory freely
@fghsgh
@fghsgh 4 года назад
As a fluent Z80 programmer, I could follow along perfectly with the disassembly, but you still gave some insights I could not have gotten, thank you very much. This was definitely worth the 20 minute watch.
@Ice-fl9et
@Ice-fl9et 2 года назад
NERD
@OpenKeith
@OpenKeith 4 года назад
I remember hearing that the reason those right-side tiles spawn land pokemon is because the game only uses the bottom-left 8x8 graphics tile for the "is this water?" check
@Double-Negative
@Double-Negative 4 года назад
This is exactly correct and explains two other things: 1. There are patches of grass in veridian forest which speedrunners use all the time because no pokemon spawn there. This is because certain grass tiles have a different sprite in the bottom left for cosmetic reasons, but it is not read as a grass tile, so no pokemon spawn. 2. In some internationalized versions of the game, both checks are done on the same tile, so the missingno glitch is impossible in those versions.
@ElectTheMusic
@ElectTheMusic 4 года назад
@@Double-Negative you can get missingno in every version of the game, it's just a different process.
@proxy1035
@proxy1035 4 года назад
that is exactly why ru-vid.com/video/%D0%B2%D0%B8%D0%B4%D0%B5%D0%BE-8PILbqZqaS4.html
@some1fromthedark
@some1fromthedark 4 года назад
I believe you were unable to rename variables because even though you disassembled the data, it was set as an undefined function. If you selected the address of the start of the function in ghidra and press f, that will define the function. After that you should be able to rename the function, variables, etc.
@GrandpaGameHacker
@GrandpaGameHacker 4 года назад
this is correct!
@gcm4312
@gcm4312 4 года назад
yes. the grayed out box in the decompiler view means that a function was not defined.
@Modslover
@Modslover 4 года назад
You're a very smart guy and very informative and great personality, i enjoy your videos.
@nikigameplay
@nikigameplay 4 года назад
that's why I really enjoy his vids! :D
@RedstoneHair
@RedstoneHair 4 года назад
Same
@aaggroberlin19
@aaggroberlin19 3 года назад
Why the hell is he smart because he has experience in something? According to you everyone is smart who knows this stuff o.O. And why does he have "great personality" because of his knowledge? Your comment makes 0 sense.
@Modslover
@Modslover 3 года назад
@@aaggroberlin19 wow you went through 11 months of comments to get offended at someone random complementing another random person. I'm sorry that people can't have an interesting and fun way of providing content resulting in a good personality as well as being having the ability to hone his skills and knowledge on technology to be able to describe in detail to everyone that doesn't know how or why something is happening. I am really glad you are here to show us that you are probably the smartest man alive. Knowing everything possible that the world has to offer before even hearing about it because you're so smart. I apologize for hurting your feelings for me supporting another pea brained human like myself. We praise you all mighty watermelon brain. Show us the way, inform us with your superior brain power and knowledge. P.s. get a life and stop trying to take other people down with you, humble yourself and maybe you can provide the world some small amount of hope and further help the world more towards a better future.
@aaggroberlin19
@aaggroberlin19 3 года назад
@@Modslover 🤨
@lostmyplaintext7587
@lostmyplaintext7587 4 года назад
Don't know if you plan on continuing this series but the "beat the game in 3 minutes" glitch is also pretty interesting from a technical standpoint :-)
@Keldor314
@Keldor314 4 года назад
You have to wonder about the speedrun community sometimes when they allow something that's quite literally hacking the game to get to the end to count as a valid run e.e
@SilphBoss
@SilphBoss 4 года назад
@@Keldor314 because it can be done without modification to the physical game... can be done by hand by only playing the game
@Aleuay
@Aleuay 4 года назад
@@Keldor314 overflowing the inventory through ACE or save corruption is within the bounds of the game, which is allowed. It takes a ton of skill and precision (navigating the inventory when it's overflowed requires you press A+B to scroll, it's extremely tight)
@OatmealTheCrazy
@OatmealTheCrazy 3 года назад
@@Keldor314 it almost doesn't really. There's no point trying to beat a time of 00:00, so it's not really run
@DaenaMichelle
@DaenaMichelle 4 года назад
As a pokemon fan and a software developer I must say you are an absolute madman and so admirable for exactly that, thanks for doing this!
@1337GameDev
@1337GameDev 4 года назад
I REALLY like that you show that you're not super knowledgeable about everything, and your process in figuring it out. Very fun to watch/listen.
@over00lordunknown12
@over00lordunknown12 3 года назад
You are the first person I’ve seen actually go into the code to explain the MissingNo glitch. I hadn’t even thought about why it duplicates items, I just knew it did. Keep up the good work!
@Frick-bv6xt
@Frick-bv6xt 4 года назад
I have absolutely no idea whats going on but it makes sense to me idk.
@charalampospapaioannou2371
@charalampospapaioannou2371 4 года назад
Exactly! Cant understand a single thing he just said but I love all of it
@RubyPiec
@RubyPiec 4 года назад
@@charalampospapaioannou2371 I do not understand it either but I still enjoy this. :)
@jpobi9880
@jpobi9880 4 года назад
This Is how I feel watching NileRed (chemistry) as a programmer.
@rndargis0
@rndargis0 4 года назад
The first thing I think of when I see H & L register and then a HL load instruction is that H is the high part of the address register and L is the low part of the register for the jump
@randomnerd4600
@randomnerd4600 3 года назад
Ecountered pokemon are based on pokemons pokedex id. And missingno points to sone crap that mods items... Thats what i think. I mean, i know abt dat from other vids.
@WilliamTresnon
@WilliamTresnon 4 года назад
I love that both of you are doing this together. Collabs like this of this nature around similar subject need to happen more because the amount of content coming out of you two is great.
@vladimir520
@vladimir520 4 года назад
This is such an interesting approach! Although I am not much experienced with assembly (I have simply played with the basics in a CTF), this step-by-step process really helped show me both how to investigate glitches and understand what you were saying! Should the big reveal just have been given to me, I probably couldn't make out much of it! Really fun series, I have thoroughly enjoyed these past videos of yours! Keep doing this amazing stuff, LO!
@AnthonyHarrisTechrat
@AnthonyHarrisTechrat 4 года назад
You and StackSmashing breaking all this down is some of the most enjoyable content I've seen in a long time. Great analysis, thanks for making these!
@d0gkiller87
@d0gkiller87 4 года назад
7:58 The debuggers on Windows work the same way. Set a hardware breakpoint on memory access/write, causes the target be paused AFTER the access/write instruction did something to that memory (no IP register can be traced, so the debugger cannot determine what instruction is gonna do something to what memory without dynamic analysis).
@NorthLaker
@NorthLaker 4 года назад
Hearing you being satisfied with your findings makes me satisfied as well!
@ValseInstrumentalist
@ValseInstrumentalist 4 года назад
Totally agree with your points about seemingly "pointless" research. I first used Cheat Engine by following a tutorial for how to use it with the game Dink Smallwood. That made me feel like a badass programmer, so I continued on to learn all kinds of other tech stuff like Python, Arduino, Raspberry Pi, and more.
@Squolly
@Squolly 2 года назад
Awesome video. Enjoyed this and the corresponding MissingNo Video very much. Your explanation is very detailed and comprehensive and you really cheer one up to try to do similar research on other bugs or just simple game logic in old games. As someone who once wrote a gameboy emulator for learning purposes I can only recommend your videos for everyone who wants to become more emerged with this awesome piece of hardware.
@PicMus
@PicMus 3 года назад
Loved the narrative and editing. Great skills of storytelling =)
@beeperonithe2nd73
@beeperonithe2nd73 2 года назад
I really love videos like these even if I can barely understand them sometimes. But you do the best job at explaining without over-complicating things... Also Gen 1's spaghetti code is amazing to dissect lol.
@Originalimoc
@Originalimoc 4 года назад
There're so many glitches related to the workaround of hardware limitations back then, there's rarely such kind of bug now.
@djbvck
@djbvck 3 года назад
I love how in depth you went into the reasons the glitch effects everything. A lot of people just say "it changes these values when you talk to the old man" and didnt go into the things you can do with for instance the safari zone. I wish I knew about that years ago, would have made getting a Dratini waaaaay easier lol
@revenevan11
@revenevan11 4 года назад
Absolutely fantastic video. So satisfying to be able to follow along with the *why* this historic bug does what it does. You've been slowly kindling my interest in picking apart software to learn about it. I loved picking apart electronics and some mechanical devices to learn how things work or some tricks I could use even if I didn't understand the whole device or what specific or odd components did. Now as my journey into learning to code is continuing, instead of having to pressure myself into committing far enough into a big project or building some arduino gizmo in order to actually get some coding practice in (now that I don't have any coding assignments and am strictly self teaching and using online tutorials), I can now get some practice and learn something by just casually fooling around! Even with games!
@XeZrunner
@XeZrunner 4 года назад
Stunned! You made this so interesting! Thank you for your amazing work! I'm having lots of fun watching these videos!
@AT-zr9tv
@AT-zr9tv 4 года назад
Awesome video!! I'm so happy the time I've been spending these past two months learning about Gameboy assembly has enabled me to understand much of this video. I would have been completely lost otherwise. Really great video, thanks!!
@laurinneff4304
@laurinneff4304 4 года назад
I like how everyone is doing game boy/Pokemon/missingno videos rn, you, stacksmashing and retro game mechanics explained
@Litronom
@Litronom 4 года назад
The conclusion at the end is very satisfying and pleasing! Great video!
@MrJerohm
@MrJerohm 4 года назад
I'm impressed by the details you time and time you must have spent working on this video, thanks a lot for sharing it !
@SergioEduP
@SergioEduP 4 года назад
Loved this (and the previous) videos! Would love to see a similar one explaining the Super Mario Bros credits warp used in speedruns =P
@hasancakir8932
@hasancakir8932 4 года назад
Summary at the end explains the missingno bug well. Great video!
@James2210
@James2210 4 года назад
Just going to post a few more details here, don't mind me: JR LAB_rom3__76a0 is an unconditional relative jump. ADD L doesn't modify L. It adds L to A. The LD L, A does modify L, though. Yes, SRL is a logical shift right.
@123gostly
@123gostly 4 года назад
Used to use this hack all the time as a kid but with this video all of it is so beautiful. If only one thing had not gone wrong it would have never happened. Seems magical.
@Chaos89P
@Chaos89P 4 года назад
Let me paraphrase to you what one Vinesauce guy's dad once said to him: It IS magic.
@over00lordunknown12
@over00lordunknown12 3 года назад
I don’t really know much with assembly (much less disassembling code), but you did a fantastic job explaining it, and the end conclusion makes sense.
@BatteryAcid1103
@BatteryAcid1103 4 года назад
I wish I could thumbs up this video multiple times. That little rant about playful research is really important for people to understand! If you're learning something, it's not a waste of time!
@AT-zr9tv
@AT-zr9tv 4 года назад
Totally agree!
@Ziberac
@Ziberac 4 года назад
This made me think back to the first game I had made in C++ that had this exact problem and made the game do crazy stuff. Very cool to watch.
@GrandpaGameHacker
@GrandpaGameHacker 4 года назад
This is awesome work. Using a scientific approach to game hacking, you figured out exactly why a bug occurs. I didnt know about the memory bank system, thats very cool. Also high five to Ghidra for making hobbyist's lives easier
@Neoplasie1900
@Neoplasie1900 4 года назад
Oh boy. So far, my personal coding was some data organisation with Python and converting a few hundred text files into an Excel sheet. Still you made me (kind of) understand what was going on here. Pretty cool stuff! And pretty fascinating reverse engineering work.
@amirouchedz3896
@amirouchedz3896 4 года назад
As always totally excellent videos ! Keep going !!!
@VampireJester
@VampireJester 4 года назад
I have no knowledge of coding but I feel like I understood everything you said in both videos. I have no idea why but you just made so much sense.
@evanjacoby7805
@evanjacoby7805 4 года назад
I was trying to find a good answer to this the other day! thanks for the upload
@savagetheunicorn4555
@savagetheunicorn4555 4 года назад
Awesome i was waiting for this video when i found the previous yesterday c:
@666mrcrowley666
@666mrcrowley666 4 года назад
same here
@tr1bute411
@tr1bute411 2 года назад
This was great! I know it's a while ago you did this, but I would LOVE more research-perspective game bug investigations. Perhaps you could consider doing something similar with the Ocarina of Time Wrong Warp bug? It's also pretty crazy.
@basedfacistman
@basedfacistman 4 года назад
im genuinely happy when i see live's new video
@prestonduffield5393
@prestonduffield5393 4 года назад
It’s crazy I’m working on a project right now in school where we have to reconstruct a program from assembly. Very relevant and applicable stuff. Good work on finding out this bug and satisfying all of the people who wanted to know the reason behind all this madness’
@cigils1567
@cigils1567 4 года назад
Just finished watching the first one to see this, amazing work man. Keep it up, gained a sub from me
@Demonslay335
@Demonslay335 4 года назад
@3:30 OMG I literally had to pause the video, I was laughing so hard. Can totally relate to that moment on so many levels - both in game and in debugging. 😆
@standarrow9759
@standarrow9759 4 года назад
I just discovered your channel even though i dont understand anything i still enjoy it
@flamemonger2
@flamemonger2 4 года назад
First video I found of yours and insta subbed.
@strattissimo8223
@strattissimo8223 4 года назад
Great video! I have always wondered why it was the 6th item when I found missingNo. Thanks guys!!
@webentwicklungmitrobinspan6935
@webentwicklungmitrobinspan6935 4 года назад
Its so cool that you are able to analyse these old games by looking at their memory allocation.. must have been a cool time as a gamedev back then
@sywei-vn2te
@sywei-vn2te 4 года назад
You can configure your assembly listing window to show Ghidra's IR by clicking on that window's configuration, choosing PCode ops, and "enable field". The breakdown can help you figure out what the labeled mnemonics mean without resorting to a manual. You can also right-click on the mnemonic and jump to the instruction specification in the processor manual included with Ghidra.
@warpster7656
@warpster7656 4 года назад
Epic videos my dude. You have just educated my inner child. Thank you
@carlisleee_
@carlisleee_ 4 года назад
This video makes me really want to learn assembly... Thank you for that
@GodKido
@GodKido 9 месяцев назад
I'm tore between "this is awesome" and "how could you ever let this release unnoticed", but it's still a 25+ years old game so maybe not that odd... thanks for the insight, this was really interesting!
@sagacious03
@sagacious03 4 года назад
Pretty interesting! I wonder if you'll "tackle" some of the less well-known Glitch Pokemon! Nonetheless, thanks for uploading!
@BlackHermit
@BlackHermit 4 года назад
Great video, very well explained. Thank you so much! Greetings from Sweden!
@trustyTankadin
@trustyTankadin 3 года назад
This was a lot of fun! Thank you!
@juliasteam2077
@juliasteam2077 3 года назад
just noticed this video was 20 minutes.. felt like 3. Amazing work.
@Innosos
@Innosos 4 года назад
Some people are gonna eat this up. I'm reminded why I hate assembly. Great video and good job explaining it. It's a bit hard to follow at times because I'm not up to snuff with pointers, memory, addresses and their concepts. Always good to see people with a lots of patience and competence.
@HighPriestFuneral
@HighPriestFuneral 4 года назад
Having done some SNES, N64, and PS2 ASM hacking in the past, this was an absolute joy. I audibly said... "Oh...!!" When you put together the pieces at the end. All of this time it was a simple out of bounds array, with the idea that they never intended to have 32 bytes for all possibilities of Pokemon. This was a fun mystery that you broke down. Hopefully it inspires others to follow your lead.
@gart__
@gart__ 4 года назад
Awesome video! I learned a lot!
@JDSacharok
@JDSacharok 3 года назад
Amazing! Thank you so much for this!
@tartas1995
@tartas1995 4 года назад
Because of this serie, I started looking at the Pokemon disassembly from Pokemon red (pokered on github) and I started to learn assembly for the GB. Gbz80 assembly.
@happinson
@happinson 4 года назад
did he mention that he has never seen this assembly
@Matt23488
@Matt23488 4 года назад
It's such an elegant bug... Thanks for this extremely enjoyable explanation!
@eyede7994
@eyede7994 4 года назад
Really good Video! Keep it up!
@SiIverDragon
@SiIverDragon 3 года назад
I understand the concept of it , but I don't understand all this programming stuff , but still I love that kind of videos Thank you :)
@DoYouKnowWhoKnew
@DoYouKnowWhoKnew 4 года назад
My Brain crapped out at 16:00. But amazing video
@SakiiR
@SakiiR 4 года назад
Hey buddy, nice vid, for the grey decompiler window. This is because de function is not defined, you have to create a function here with the F keybind :) Cya
@joemck85
@joemck85 3 года назад
Clever analysis. I'd just assumed it was decoding the garbage sprite and cry data that resulted in the 6th item quantity being corrupted.
@dervolker
@dervolker 4 года назад
As always great analysis, couldn't agree more with you, that time spent fiddling around with something is worth it, since you learn so many things on your way, that otherwise only seem like abstract ideas. Nothing explains raceconditions better than injecting code into some process and having it crash hard ...sometimes... Keep it up
@nielsbishere
@nielsbishere 4 года назад
So just to add to this; arithmetic functions generally use the accumulation register (a) so that's why that add doesn't have , a there. Also, HL spans two registers; H and L, the gameboy has mainly 8-bit registers but also shares those to make 16-bit registers so it can do stuff with addresses.
@craig47721
@craig47721 4 года назад
Nice I was searching for the answer to this yesterday.
@spiritcore1
@spiritcore1 4 года назад
Another great video! I wonder how the save and restart glitch is working on Gold, Silver and Crystal. Do you mind making a video about it? Thanks!
@morwar_
@morwar_ 4 года назад
You guys are great. Amazing video.
@jambosuss
@jambosuss 3 года назад
You explain this very well, you lost me in parts, but I sort of understand what's going on. I lasted until around 18:00 before I couldn't follow anymore. GG
@asediffaafa2854
@asediffaafa2854 4 года назад
U madman, your videos teach a lot dude
@Ben-ix8yb
@Ben-ix8yb 4 года назад
This was excellent. Thank you.
@qbasic16
@qbasic16 4 года назад
Wonderful rabbit hole! 😎
@woodchucksquirrel
@woodchucksquirrel 4 года назад
Thank you. This video was a great tutorial!
@ScrombIo
@ScrombIo 4 года назад
IIRC the game will place the ending "1" into the item slot, essentially adding 128 items to item stacks that do not have 128+ items in them already. The glitch will not work on any item stack that is greater than 128, and using it on an item with a stack of 127 makes that item into a stack of 255. 255 also has the same properties as the CANCEL button which lead to some of the old Pokemon Blue any% NSC routes before easy ace with maps was discovered.
@shupik
@shupik 4 года назад
Yay! A continuation!
@Levi_OP
@Levi_OP 4 года назад
“The seventy tooth bit”
@ArloMathis
@ArloMathis 4 года назад
You have to admit our system is kinda bad, it should be standardized.
@animowany111
@animowany111 3 года назад
It is, and ordinal 72 is called seventy-second. English is actually one of the simpler languages when it comes to ordinals, and number kinds in general. 1st, 2nd, 3rd, 4-20th, 21st, 22nd, 23rd, 24-30th, ...
@RussellTeapot
@RussellTeapot 3 года назад
@@animowany111 The seventy secondth bit
@m4gmu5hell
@m4gmu5hell 4 года назад
I just started learning 6502 assembly like a week ago and am amazed, on how much I could follow with the code xD
@Chaos89P
@Chaos89P 4 года назад
6502 and z80, especially a modified one to include 8088 instructions, are different chips, but ASM tends to be similar in appearance.
@KidPrarchord95
@KidPrarchord95 4 года назад
I've been fearing and neglecting starting for years and I am also amazed at how well I could follow
@BGroothedde
@BGroothedde 4 года назад
That's a beautiful bug, it's so involved and has so many steps; that's what old school programming was all about!
@Dpx008Music
@Dpx008Music 4 года назад
I think you should check out Zelda Ocarina of Time related glitches, there are a ton of really interesting glitches like inventory manipulation or abusing cutscene pointers to warp to unintended locations. Even a few months ago, they discovered how to execute arbitrary code and functions in the game to basically do anything they like. I think it'd be really amazing if you took a look at this game!
@sundhaug92
@sundhaug92 4 года назад
The Game Boy (and Game Boy Color) uses an instruction-set that is mostly like the 8080 and z80. This family uses 8-bit registers (except PC and SP, which are 16-bit), but for some instructions you can use 16-bit pairs (AF, HL, ...)
@arnevaneycken2878
@arnevaneycken2878 Год назад
This is amazing. Hits right in the childhood
@DHIRAL2908
@DHIRAL2908 4 года назад
15:30 you are a great editor!!!!!
@ariss3304
@ariss3304 4 года назад
Hello. I am currently reverse engineering and annotating minish cap in ghidra. These are some of the methods I use to analyze the program :) Gb and gba use a lot of bitwise functions since space was so tight back then; bitfields are used all the time! It can be frustrating trying to understand all of the shifts ands and ors etc.
@letsrobocraft7282
@letsrobocraft7282 4 года назад
Hey, at 01:16 there's on the screen that 0xff = 256, but 0xff = 255, just wanted to point that out :)
@wildbill268
@wildbill268 Год назад
This is so cool to see in action! If you didn't know, it's actually possible to duplicate TWO sets of items by replacing the already duped item with another item that has yet to have it's bit flipped during battle. When you catch missingno, that same function must be performed in the process of updating it's Pokedex entry, but instead of listing it as "seen", it gets listed as "caught". The game then forgets that you even saw missingno since the data for that would normally be referenced in the Pokedex data, which explains why this can be repeated multiple times through various wild encounters with missingno. That's probably not 100% correct, but that's my educated guess :)
@thatguy147
@thatguy147 4 года назад
A video on your enviornments and go-to toolchains would be great!
@Manawyrm
@Manawyrm 4 года назад
If you also want to read the assembly for the mentioned functions (in a commented and somewhat structured form), here are some links to PokeRed: LoadEnemyMonData: (handles the pokemon encounter, calls the Flag function below) github.com/pret/pokered/blob/606df6a317df7c8d076410e8189f7e0a7782b530/engine/battle/core.asm#L6200 here's the code that handles the IndexToPokedex-conversion and set's the flag: github.com/pret/pokered/blob/606df6a317df7c8d076410e8189f7e0a7782b530/engine/battle/core.asm#L6337 IndexToPokedex: github.com/pret/pokered/blob/606df6a317df7c8d076410e8189f7e0a7782b530/engine/menu/pokedex.asm#L649 Flagging-Function (also takes in a 3rd input value, the B register, which contains clear, set or read) github.com/pret/pokered/blob/606df6a317df7c8d076410e8189f7e0a7782b530/engine/flag_action.asm#L1 predef seems to be the bank-switching function, which is structured as a macro (?) in Pokered: github.com/pret/pokered/blob/6ba3765c5932996f5da6417ae703794ff10bb1cb/home/predef.asm Thanks for these two great videos! I had a lot of fun watching and now reading the assembly.
@cjzx325
@cjzx325 4 года назад
Great explanation. I wonder if they just accidently made Cinnabar 1 tile smaller on the east coast and didn't tell whoever programed the overwrite tiles. Make me wonder if there are any instances of this near other coastlines.
@Letalight
@Letalight 4 года назад
I like that after all of this desassembly you make me feel like a nerd knowing that arrays start at 0.
@seriousskateboarding9938
@seriousskateboarding9938 3 года назад
I personally found a bug along time ago to give your pokemen unlimited hp. It could be used to further this research, if you're interested. And this bug has possibly never been released, until now. As I'm the one whobpersonally discovered this bug by pure accident back in grade 6. Though I'm not sure, this bug is probably already, but here it is; I can't remember exactly how to do it because it was like 2 decades ago, but I think the trick was a Lil sumthin like this. 1. You need to start by doing this same missing no glitch (as most of us know each save file gets its own randomly selected pokemen that can be a lvl that is over 100.) 2. Catch the bugged lvl pokemen. 3. Lvl the bugged pokemen to max lvl. (THIS IS WHERE EVERYONE THOUGHT THE GLITCHES STOPPED) 4. (this next part is the part I accidentally discovered) After steps 1-3 are done: trade the pokemen to a different game via the ol link cable, then trade it back. The pokemon will lose lots of lvls after the trades, but the hp will remain as if it didn't unlvl. 5. Lvl the pokemon back to max lvl then repeat step 4... Everytime you lvl then do the trade and trade back it allows you to infinitly?? Keep increasing the hp everytime steps 4+5 are repeated. I never knew this random bug I found 20 years ago could possibly be useful for awesome research like this my dude..
Далее
Researching MissingNo Glitch in Pokemon
17:56
Просмотров 501 тыс.
Dissecting Pokemon Red Savegame
12:56
Просмотров 235 тыс.
Fixing Glitch Pokémon Sprites
14:17
Просмотров 325 тыс.
Hacking the Game Boy cartridge protection
10:01
Просмотров 551 тыс.
Can You Solve The Martini Glass Puzzle?
10:45
Просмотров 98 тыс.
DLL Injection to Create a Fly Hack - Pwn Adventure 3
11:46
Our Future As Hackers Is At Stake!
4:11
Просмотров 65 тыс.
How Do Linux Kernel Drivers Work? - Learning Resource
17:02
My YouTube Financials - The Future of LiveOverflow
35:00