Welcome back to this series on building a Chip-8 emulator. Last time we looked at an outline for how the Chip-8 emulator works, and gave it the ability to run programs. But so far, it doesn’t know how to do anything inside that program.
Last time we saw that each operation is represented by two bytes, and we can combine those to get a 16 bit value that tells us which instruction to run.
Looking at the table on the Chip-8 wikipedia page, you’ll see a table with opcodes and an explanation for what it means. You’ll notice that the values expressed in the opcode column aren’t simply numbers, but patterns. Take for example:
Hex numbers only include 0-9, A-F. So the ‘6’ represents a hex value, but the ‘X’ and ‘NN’ are saying that those are variables. To implement this opcode, we’ll need to extract the X and NN fields, assuming that first digit is a ‘6’. We’ll need to use a few bitwise operations to extract these values.
If you are already familiar with bitwise operations, feel free to skip this section. While computers commonly operate on large numbers, they’re also great at performing parallel operations across each bit in a number. You are likely already familiar with and, which results in true only when both inputs are true.