Quick start¶
Five minutes from brew install to single-stepping your first ROM.
1. Install¶
brew tap nkane/tap
brew install chippy
curl -LO https://github.com/nkane/chippy/releases/latest/download/chippy_<VERSION>_linux_amd64.deb
sudo dpkg -i chippy_*.deb
yay -S chippy-bin
go install github.com/nkane/chippy/cmd/chippy@latest
Verify:
chippy --help
2. Try a canned ROM¶
The repo ships small ca65 demos under example/. Clone, build with
cc65, run:
git clone git@github.com:nkane/chippy.git
cd chippy/example
make
chippy -rom count_to_ten.bin
You should see the TUI: register pane, disassembly, stack, memory, text-output, status bar. The CPU starts paused at the reset vector.
3. Step + observe¶
| key | action |
|---|---|
s |
single step (one instruction) |
n |
step over JSR (run to RTS) |
r |
run / pause |
< |
reverse step |
b |
toggle breakpoint at PC |
: |
command line (see help modal) |
? / h |
help modal |
q |
quit |
Try:
- Press
sa few times — watchXincrement from$00to$01,$02, …, then stop at$0A. - Press
<once to reverse-step. - Press
rto free-run; pressragain to pause.
4. Load your own program¶
ca65/cc65 emit .bin (raw image), .prg (with leading load address),
.hex (Intel HEX), or .o (objects ld65 must link). chippy auto-detects
by extension:
chippy -rom myprog.bin -addr 0x8000 # raw bin
chippy -rom myprog.prg # .prg
chippy -rom myprog.o -cfg myprog.cfg # .o + linker config
A sibling .dbg symbol file (the --dbgfile output from ld65 -g)
gets picked up automatically — disassembly shows real symbol names,
breakpoints can target :bp main or :bp src.s:42.
5. Editor integration (DAP)¶
For a step-debugger experience in VS Code / nvim / JetBrains, see DAP server reference. The short version:
- VS Code: install the chippy extension
and use
examples/dap/launch.jsonas a template. - nvim-dap: copy
examples/dap/nvim-dap.luainto your config.
Other editors that speak DAP work too — see the editor matrix.
Next steps¶
- Browse the example programs organised by category (math, I/O, interrupts, CMOS-only).
- Read the DAP reference for the full editor-side feature set (reverse-step, conditional breakpoints, function breakpoints, exception breakpoints, evaluate expressions).
- Try the browser playground — same emulator, no install.