JeremiahK Posted June 2, 2019 Share Posted June 2, 2019 You need to be some sort of masochist to code for the VCS, because the system is so limiting. One of its most well-known limitations is the mere 128 bytes of RAM on board. Programmers have spent ages seeing what is possible using these 1024 bits of information. So, I thought, why not limit myself to the extreme? I challenged myself to make a complete game using absolutely NONE of the on-board RAM. And I did it! It took a lot longer to actually finish than I had anticipated, but I have a fully-functional 2-player pong clone using none of the RAM, namely without addressing anything within $80-$FF or any of its mirrors, neither reading nor writing. This should work perfectly on a system with the RAM disabled or otherwise re-routed. Since I am not using RAM, I am only using the CPU registers for storing information. I can only use X and the stack pointer for storage, though, while A and Y take on more temporary roles. I used T1024T and INTIM to temporarily store data while swapping X with the SP, which is neccessary twice per frame. The SP normally holds the scores (both values from 0-10) encrypted into 7 bits, with the high bit controlling the vertical speed of the ball. The X register normally holds the vertical position of the ball (0-95), with the high bit controlling the vertical direction of the ball. X is also used to trigger "score mode", where a sound is played for about half a second before switching to "serve mode". These are simply special X values that cannot occur during a rally. The Interrupt flag is used to control the horizontal direction of the ball. Since there is no way to test the value of this flag, I am using the stack to push the CPU state to NUSIZ0. GRP0 is used for the score graphics, and since it never moves, I can use a simple collision detection against the playfield to determine what the Interrupt flag is. The ball's horizontal position is not stored, as it is moved with HMOVE. All other game mechanics are done with either checking the bounds of the data, or checking collisions between objects. If you disable different graphics objects, strange things will happen! In attract mode, the screen color cycles, and if you have the BW/COLOR switch set to COLOR, it keeps the color on game reset, otherwise it resets to black and white. This also just happens to fit within 1K of space. I could probably squeeze a few more bytes out to maybe add changeable paddle sizes using the difficulty switches, but I like it as it is. ramless_pong.bin ramless_pong.asm 18 Quote Link to comment Share on other sites More sharing options...
+atari2600land Posted June 2, 2019 Share Posted June 2, 2019 If you want to go really extreme, there's games using only 128 bytes or less. http://www.atari2600land.com/articles/ram.html 2 Quote Link to comment Share on other sites More sharing options...
+Karl G Posted June 2, 2019 Share Posted June 2, 2019 Wow - so this is the exact opposite of RAM Pong. It's an interesting challenge with clever solutions for sure. Well done! 1 Quote Link to comment Share on other sites More sharing options...
JeremiahK Posted June 2, 2019 Author Share Posted June 2, 2019 Thanks guys! I was hoping the game would be under 512 bytes, but it would have to be drastically stripped down. Doing simple things without RAM takes a lot more ROM... I would like to do a 128-byte RAM game someday. Probably as a 256-byte cart that does initialization, pushes the code to RAM, and jumps into it. The inspiration for the gameplay was taken from this video: 1 Quote Link to comment Share on other sites More sharing options...
tschak909 Posted June 2, 2019 Share Posted June 2, 2019 just looked at the code, holy shit! -Thom 1 Quote Link to comment Share on other sites More sharing options...
Thomas Jentzsch Posted June 2, 2019 Share Posted June 2, 2019 Very cool idea! 1 Quote Link to comment Share on other sites More sharing options...
Mr SQL Posted June 5, 2019 Share Posted June 5, 2019 Awesome program Jeremiah! This is really interesting - you are indeed not using any of the 128 bytes, but the registers T1024T and INTIM could count as register RAM; the Fairchild Channel F has 64 bytes of register RAM used like the direct page on the VCS. I think the hardware acceleration makes this code possible since the TIA can transparently access additional RAM; here there is another parallel with the Fairchild Channel F having 2K of video RAM and no way to read it back but with the VCS this is not so; our 20 bits of playfield video RAM and 19 bits of sprites are write only but the bits can be read back by other registers and calculated anywhere within a 40*n scanline matrix for the playfield or a 160*n matrix for the bit sprites. 2 Quote Link to comment Share on other sites More sharing options...
ChildOfCv Posted June 5, 2019 Share Posted June 5, 2019 Just wondering, are there any officially-released games that don't use RAM? Because they would make good troubleshooting tools for the typical black screen issues by ruling out at least one chip. 1 Quote Link to comment Share on other sites More sharing options...
JeremiahK Posted June 5, 2019 Author Share Posted June 5, 2019 (edited) Just wondering, are there any officially-released games that don't use RAM? Because they would make good troubleshooting tools for the typical black screen issues by ruling out at least one chip. Not that I know of, but I had wondered that as well. I know there was a color-test cart made that I thought simply rendered a typical test screen. After looking up the video, though, it looks a bit more complex than that. WARNING: Mute the sound! Edited June 5, 2019 by JeremiahK Quote Link to comment Share on other sites More sharing options...
Omegamatrix Posted June 6, 2019 Share Posted June 6, 2019 Neat! I've too made ramless programs, but never thought about making a game before. Pong is good choice for that. I remember at least one discussion that was had about methods of extra storage. This post captures most of that. 1 Quote Link to comment Share on other sites More sharing options...
azure Posted June 6, 2019 Share Posted June 6, 2019 Neat! I've too made ramless programs, but never thought about making a game before. Pong is good choice for that. I remember at least one discussion that was had about methods of extra storage. This post captures most of that. Has anyone suggested using bankswitching as memory? If you had 8 banks, that would provide 3 bits of state. Each bank would have mostly duplicate code, but coded with an identifier between 0 and 7. Storing the value of 5 would be done by jumping to bank 5. 1 Quote Link to comment Share on other sites More sharing options...
JeremiahK Posted June 6, 2019 Author Share Posted June 6, 2019 Neat! I've too made ramless programs, but never thought about making a game before. Pong is good choice for that. I remember at least one discussion that was had about methods of extra storage. This post captures most of that. I believe that post was the original inspiration for me, then one day in the shower I figured out how to put it all together, haha. Has anyone suggested using bankswitching as memory? If you had 8 banks, that would provide 3 bits of state. Each bank would have mostly duplicate code, but coded with an identifier between 0 and 7. Storing the value of 5 would be done by jumping to bank 5. That would be interesting, although it would require a bit of ROM. Quote Link to comment Share on other sites More sharing options...
christo930 Posted July 27, 2019 Share Posted July 27, 2019 On 6/5/2019 at 5:15 PM, JeremiahK said: Not that I know of, but I had wondered that as well. I know there was a color-test cart made that I thought simply rendered a typical test screen. After looking up the video, though, it looks a bit more complex than that. WARNING: Mute the sound! Do you have a link to this rom? I'm trying to get my TV squared away and I was looking for something like this, but I couldn't find it. Quote Link to comment Share on other sites More sharing options...
Nukey Shay Posted July 27, 2019 Share Posted July 27, 2019 (edited) https://atariage.com/software_page.php?SoftwareID=934 Keep both difficulties on A to mute the test sound. Edited July 27, 2019 by Nukey Shay Quote Link to comment Share on other sites More sharing options...
Hai Nguyen Posted May 29, 2020 Share Posted May 29, 2020 Out of curiousity, anyone know what 128 Bytes in Atari game consist of? I am trying to use RAM to train an agent to play the game so some clues might help. Hai. Quote Link to comment Share on other sites More sharing options...
+Andrew Davie Posted May 31, 2020 Share Posted May 31, 2020 On 5/30/2020 at 7:12 AM, Hai Nguyen said: Out of curiousity, anyone know what 128 Bytes in Atari game consist of? I am trying to use RAM to train an agent to play the game so some clues might help. Hai. I believe this question has been asked before. The 128 bytes "consists of" whatever the programmer decides. It is different for every game. Quote Link to comment Share on other sites More sharing options...
Halycon275 Posted June 2, 2020 Share Posted June 2, 2020 (edited) On 6/1/2019 at 9:53 PM, JeremiahK said: You need to be some sort of masochist to code for the VCS, because the system is so limiting. One of its most well-known limitations is the mere 128 bytes of RAM on board. Programmers have spent ages seeing what is possible using these 1024 bits of information. So, I thought, why not limit myself to the extreme? I challenged myself to make a complete game using absolutely NONE of the on-board RAM. And I did it! It took a lot longer to actually finish than I had anticipated, but I have a fully-functional 2-player pong clone using none of the RAM, namely without addressing anything within $80-$FF or any of its mirrors, neither reading nor writing. This should work perfectly on a system with the RAM disabled or otherwise re-routed. Since I am not using RAM, I am only using the CPU registers for storing information. I can only use X and the stack pointer for storage, though, while A and Y take on more temporary roles. I used T1024T and INTIM to temporarily store data while swapping X with the SP, which is neccessary twice per frame. The SP normally holds the scores (both values from 0-10) encrypted into 7 bits, with the high bit controlling the vertical speed of the ball. The X register normally holds the vertical position of the ball (0-95), with the high bit controlling the vertical direction of the ball. X is also used to trigger "score mode", where a sound is played for about half a second before switching to "serve mode". These are simply special X values that cannot occur during a rally. The Interrupt flag is used to control the horizontal direction of the ball. Since there is no way to test the value of this flag, I am using the stack to push the CPU state to NUSIZ0. GRP0 is used for the score graphics, and since it never moves, I can use a simple collision detection against the playfield to determine what the Interrupt flag is. The ball's horizontal position is not stored, as it is moved with HMOVE. All other game mechanics are done with either checking the bounds of the data, or checking collisions between objects. If you disable different graphics objects, strange things will happen! In attract mode, the screen color cycles, and if you have the BW/COLOR switch set to COLOR, it keeps the color on game reset, otherwise it resets to black and white. This also just happens to fit within 1K of space. I could probably squeeze a few more bytes out to maybe add changeable paddle sizes using the difficulty switches, but I like it as it is. ramless_pong.bin 1 kB · 265 downloads ramless_pong.asm 11.06 kB · 149 downloads Edited June 2, 2020 by Halycon275 1 Quote Link to comment Share on other sites More sharing options...
Halycon275 Posted June 2, 2020 Share Posted June 2, 2020 i quite enjoyed my 3 minutes in mushroom land ? jokes aside, all i'm getting is a flashing red screen Quote Link to comment Share on other sites More sharing options...
JeremiahK Posted June 5, 2020 Author Share Posted June 5, 2020 On 6/1/2020 at 9:19 PM, Halycon275 said: i quite enjoyed my 3 minutes in mushroom land ? jokes aside, all i'm getting is a flashing red screen Are you using paddle controllers? The game only works with paddles. Quote Link to comment Share on other sites More sharing options...
Halycon275 Posted June 6, 2020 Share Posted June 6, 2020 z26 emulator Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.