Difference between revisions of "6502 Assembly Language Math Lab"
Chris Tyler (talk | contribs) |
Chris Tyler (talk | contribs) |
||
(5 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
− | [[Category:SPO600 Labs]]{{Admon/lab|Purpose of this Lab|In this lab, you will write code with arithmetic/math in [[6502]] assembly language, in preparation for learning more complex x86_64 and AArch64 assembly language.}} | + | [[Category:SPO600 Labs - Retired]] |
+ | {{Admon/important|This lab is not used in the current semester.|Please refer to the other labs in the [[:Category:SPO600 Labs|SPO600 Labs]] category.}} | ||
+ | |||
+ | {{Admon/lab|Purpose of this Lab|In this lab, you will write code with arithmetic/math in [[6502]] assembly language, in preparation for learning more complex x86_64 and AArch64 assembly language.}} | ||
== Resources == | == Resources == | ||
Line 45: | Line 48: | ||
3. Select and complete one of these options for this lab: | 3. Select and complete one of these options for this lab: | ||
− | ==== Option | + | ==== Option 1: Bouncing Graphic ==== |
# Create a simple graphic in a square that is 5x5 or 7x7 pixels in size. Use the colours available in the emulator's bitmapped display. The graphic could be a ball, a happy face, a logo, an emoji, or anything else (appropriate!) that you want to use. | # Create a simple graphic in a square that is 5x5 or 7x7 pixels in size. Use the colours available in the emulator's bitmapped display. The graphic could be a ball, a happy face, a logo, an emoji, or anything else (appropriate!) that you want to use. | ||
# Encode that graphic in bytes using DCB (declare constant byte) instructions. | # Encode that graphic in bytes using DCB (declare constant byte) instructions. | ||
# Write code to make the graphic bounce around the screen, reflecting off the edges when it hits. Note: for simplicity, it is OK if the object always bounces at 45-degree angles. | # Write code to make the graphic bounce around the screen, reflecting off the edges when it hits. Note: for simplicity, it is OK if the object always bounces at 45-degree angles. | ||
− | # Make the speed keyboard-adjustable (faster/slower) and perturb the object's path once in a while. | + | # Make the speed keyboard-adjustable (faster/slower) and perturb the object's path once in a while (add a glitch - adjust the angle or nudge the obect by a pixel at random intervals). |
Challenge: randomize the starting position, and make the object bounce at angles other than 45 degrees. | Challenge: randomize the starting position, and make the object bounce at angles other than 45 degrees. | ||
==== Option 2: Numeric Display ==== | ==== Option 2: Numeric Display ==== | ||
− | # | + | # Obtain bitmapped font patterns for the digits 0-9 on an 8x8 pixel matrix: |
− | # Encode the font patterns for these characters using DCB (declare constant byte) | + | #* Use [[8x8 Bitmap Patterns for Digits|pre-defined bitmap patterns]], or |
+ | #* Find alternate patterns on the web, or | ||
+ | #* Design your own font patterns | ||
+ | # Encode the font patterns for these characters using DCB (declare constant byte) directives. | ||
# Write code to display a 2-digit unsigned decimal number (0-99). The + and - keys should increment and decrement this number. | # Write code to display a 2-digit unsigned decimal number (0-99). The + and - keys should increment and decrement this number. | ||
Challenge: extend the code to suppress leading zeros and display a signed number (-99 to +99). | Challenge: extend the code to suppress leading zeros and display a signed number (-99 to +99). |
Latest revision as of 11:32, 28 January 2022
Contents
Resources
- 6502
- 6502 Emulator
- 6502 Emulator Example Code - Specifically:
- Place a Graphic on the Screen - for an example of defining a graphic using DCB, and copying a graphic to the screen
- Etch-a-Sketch Style Drawing - for an example of converting (ROW,COL) co-ordinates to a screen address, and reading the keyboard
- Opcode/Instruction References
Techniques
- Bouncing Object
- To bounce an object around the screen:
- Use two variables for deltaX and deltaY values -- the amount that the object will move in each direction for each update. Add these values to the X,Y position of the object on the screen each time you update the position.
- These values can simply be -1 or +1 if the object is going to bounce at 45-degree angles.
- These values will need to include a fractional component for angles other than 45 degrees. This can be handled by using two bytes for each element of the X,Y position and for the deltaX and deltaY values, where one byte represents the integer portion and one byte represents the fractional portion (fixed-point representation).
- Use two variables for deltaX and deltaY values -- the amount that the object will move in each direction for each update. Add these values to the X,Y position of the object on the screen each time you update the position.
- Detect when the object has collided with the edge of the screen or other objects, and reverse the sign of the deltaX or deltaY value (or both). For example, when bouncing off the top of the display, set
deltaX = -deltaX
- To bounce an object around the screen:
- Keyboard
- The last key pressed is stored in memory location $FF. Clear this location (to 0) after reading it. Printable characters, ENTER, and Backspace are represented by their ASCII codes; the arrow keys are represented by the codes $80-$83 (up/right/down/left).
- Random number generator
- A random byte is available at memory location $FE.
- Drawing a Line
- To draw a line between two arbitrary points (X1,Y1)(X2,Y2) where X2-X1 > Y2-Y1 and all coordinates are positive, calculate the rise/run, then set Y=Y1 and iterate for X=X1:X2 incrementing Y by the rise/run each step.
- Do something similar with run/rise where X2-X1 < Y2-Y1
- Suggestion: Use fixed-point math for the rise/run (aka deltaY) value.
Lab 3
Setup
1. Join the assigned Breakout Room.
2. Select one person to be the "Driver", who will type/operate the computer for the group. That person will share their screen and open the 6502 Emulator at [1] as well as this Lab page. It's a good idea to ensure that the Speed slider on the emulator is at its lowest setting (left) and that the Text Screen is turned off (unchecked).
Pick an Option
3. Select and complete one of these options for this lab:
Option 1: Bouncing Graphic
- Create a simple graphic in a square that is 5x5 or 7x7 pixels in size. Use the colours available in the emulator's bitmapped display. The graphic could be a ball, a happy face, a logo, an emoji, or anything else (appropriate!) that you want to use.
- Encode that graphic in bytes using DCB (declare constant byte) instructions.
- Write code to make the graphic bounce around the screen, reflecting off the edges when it hits. Note: for simplicity, it is OK if the object always bounces at 45-degree angles.
- Make the speed keyboard-adjustable (faster/slower) and perturb the object's path once in a while (add a glitch - adjust the angle or nudge the obect by a pixel at random intervals).
Challenge: randomize the starting position, and make the object bounce at angles other than 45 degrees.
Option 2: Numeric Display
- Obtain bitmapped font patterns for the digits 0-9 on an 8x8 pixel matrix:
- Use pre-defined bitmap patterns, or
- Find alternate patterns on the web, or
- Design your own font patterns
- Encode the font patterns for these characters using DCB (declare constant byte) directives.
- Write code to display a 2-digit unsigned decimal number (0-99). The + and - keys should increment and decrement this number.
Challenge: extend the code to suppress leading zeros and display a signed number (-99 to +99).
Option 3: Pong
- Create a single-user version of the classic Pong game: one paddle, controlled by the keyboard, and one single-pixel ball that bounces off the paddle plus the three sides of the screen not guarded by the paddle. The game is over if the ball hits the fourth side of the screen. (The screen may optionally have lines drawn on the three sides on which the ball bounces).
Challenge: extend the code to play a game similar to Breakout; or, add a display of the score as a digit, with the game ending when five balls have been missed
Option 4: Kaleidoscope
- Create code that permits the user to draw pixels on one-quarter of the screen in any of several different colours (for example, the user might position a cursor with the arrow keys and colour a pixel with the a digit from 0-9 which would select the colour for that pixel).
- Mirror the pixel to the other three quadrants of the screen like a kaleidoscope. For example, a pixel drawn at (0,0) should be mirrored to (31,31), (0,31), and (31,0); if a pixel is drawn at (2,10) is should be mirrored to (29,10), (2,21), and (29,21)
Challenge: replay the drawing of the image, i.e., when a key is pressed, the screen is cleared and the pixels are redrawn to the screen in the order in which they were originally added by the user, with the kaleidoscope effect, as an animation.
Write-Up
Post an entry on your blog describing your experiments in this lab. Include:
- An introduction, so that someone who happens across your blog will understand the context of what you're writing about.
- The results from the lab, including the code, a description of how the code works, and the results produced. Credit other sources appropriately (i.e., font/graphics data, code snippets) and ensure that you are in compliance with the licenses of any code snippets used.
- Your experiences with this lab -- your impressions of the Assembly Language, what you learned, and your reflections of the process.
Remember to follow the Blog Guidelines as you write.