In this lab, you will write code with arithmetic/math and strings in 6502 assembly language, including text output, graphical output, and keyboard input, in preparation for learning more complex x86_64 and AArch64 assembly language.
For this lab, write a program that meets these criteria:
For example, you could write a simple game:
Or a calculator/converter:
Or anything else that meets the criteria above
You can interact with the user using either display. For example:
Tip: Keep it really simple! Assembly language is hard. Start simple, you can always add features later.
Write the code for your selected program in the 6502 Emulator.
It can be helpful and fun to write this code with one or two other people in a live session. Acknowledge each person's input, and add your own customizations or tweaks.
Remember to save your work periodically, either by pasting the text into a file, or using the Save button. Tip: the Save/Load/Chose File buttons work really well with a directory that is managed by Git.
Acknowledge Other's Code - Feel free to incorporate other people's code into your program with their permission, but you must acknowledge the source of any incorporated code (include a link to the source(s)), identify how you attained permission to use the code (for example, if the code is distributed under an open source license, show which license applies) and clearly identify exactly which parts of the code you wrote (recommendation: colour-code your portion in the blog post).
Important: Failure to fully comply with the terms under which others have shared code with you, failure to fully acknowledge the source and license terms of all code which you incorporate from other sources, or failure to accurately identify exactly which portions of the code were written by you will be considered a violation of Seneca's Academic Integrity Policy.
You must write at least half (50%) of the code in this lab, counted by lines of code. Do not take an existing program and just make minor changes to messages or colours.
Write up your adventures in your blog. Remember to include the source code, some narrative about how it went, perhaps a screenshot of the program running, a reflection on the experience, and some ideas for further enhancement of the program.
Ensure that your program works and is free from major bugs. Document any limitations or remaining minor bugs.
Make sure that others (including your prof!) can run you code by pasting it into the emulator or loading it from a file (e.g., public git repository or downloadable file).
Remember to follow the Blog Guidelines as you write.
For some examples of games and demos, see the Resources section above, and also take a look at the http://txt3.de/ website - which uses an earlier version of the 6502 emulator used in this course. The “Open Project” control on that page provides access to some interesting and inspiring code (check out “Skier”, for example). You can copy-and-paste any of those examples into our SPO600 6502 Emulator. Be sure to check for permission (or licensing terms) before copying any code from that site (or any other source) and incorporating it into your code.