C64 Debug MCP
Enables AI-powered control and debugging of Commodore 64 programs via the VICE emulator, supporting memory operations, breakpoints, register access, and program loading.
README
C64 Debug MCP
Debug Commodore 64 programs through conversation - AI-powered control of the VICE emulator for 6502 assembly and BASIC.
Features
- 🎮 Full C64 Control: Pause, resume, step, and reset the emulator
- 🔍 Memory Operations: Read, write, search, and compare memory
- 🐛 Breakpoints: Set execution breakpoints and watchpoints
- 📊 Register Access: Get and set CPU registers (A, X, Y, PC, SP, flags)
- 📸 Display Capture: Capture screen state and text content
- ⌨️ Input Control: Send keyboard and joystick input
- 📝 Program Loading: Load PRG files and manage execution
- 🔢 Flexible Formats: Use C64 notation ($D000, $FF, %11111111) or standard formats (0xD000, 255, 0b11111111)
Address Formats
The MCP server accepts C64 addresses in multiple formats for natural interaction:
- C64 style:
$D000(dollar sign prefix - classic 6502 assembler notation) - C style:
0xD000(0x prefix - standard programming hex notation) - Decimal:
53248(traditional decimal format)
Note: Bare hex without prefix (e.g., D000) is NOT supported to avoid ambiguity with 4-digit decimals.
Range Support
Tools that read memory or set breakpoints support both address+length and start+end formats:
Address + Length format (original):
memory_read(address="$D000", length=256) // Read 256 bytes starting at $D000
breakpoint_set(kind="exec", address="$1000", length=1) // Breakpoint at $1000
Start + End format (more intuitive for ranges):
memory_read(start="$D000", end="$D0FF") // Read from $D000 to $D0FF inclusive
memory_read(start=198, end=199) // Read addresses 198-199 (2 bytes)
breakpoint_set(kind="exec", start="$1000", end="$1000") // Breakpoint at $1000
Both formats work with all address representations (decimal, $, 0x).
Common C64 Addresses:
$D000- SID chip registers (sound)$D020- Border color register$D021- Background color register$0400- Default screen memory$0800- Common program start$C000- BASIC ROM start
Address Ranges
For operations that work with memory ranges (like memory_read and breakpoint_set), you can specify ranges in two ways:
Option 1: Address + Length
memory_read(address="$0400", length=256) // Read 256 bytes from $0400
breakpoint_set(kind="exec", address="$1000", length=16) // Break on $1000-$100F
Option 2: Start + End (inclusive)
memory_read(start="$0400", end="$04FF") // Read from $0400 to $04FF (256 bytes)
breakpoint_set(kind="exec", start="$1000", end="$100F") // Break on $1000-$100F
Both formats work identically and support all address formats (decimal, hex).
Byte Value Formats
The MCP server accepts byte values (0-255) in multiple formats for natural C64-style input:
- C64 hex:
$FF(dollar sign prefix - classic 6502 notation) - C hex:
0xFF(0x prefix - standard programming notation) - C64 binary:
%11111111(percent prefix - classic 6502 bit notation) - C binary:
0b11111111(0b prefix - standard programming notation) - Decimal:
255(traditional decimal format)
Note: Bare hex/binary without prefix (e.g., FF, 11111111) is NOT supported to avoid ambiguity.
Mixed formats in arrays:
[255, "$FF", "0xFF", "%11111111", "0b11111111"]
Common C64 Byte Values:
$00-$0F- Color values (0-15)$20- PETSCII space character$41- PETSCII 'A' character%00011011- VIC-II D011 control register (text mode, 25 rows, screen on)%11111111- All bits set (enable all sprites, etc.)
Use Cases:
// Set border to light blue
memory_write(address="$D020", data=["$0E"])
// Enable all 8 sprites
memory_write(address="$D015", data=["%11111111"])
// Write " AB" to screen (PETSCII)
memory_write(address="$0400", data=["$20", "$41", "$42"])
// Set VIC-II control register with bit pattern
memory_write(address="$D011", data=["%00011011"])
Requirements
- Node.js >= 22.13.0
- VICE Emulator (https://vice-emu.sourceforge.io/)
- MCP-compatible AI assistant (Claude Code, Codex, Windsurf, etc.)
Installation
claude mcp add c64-dev-tools -- npx -y c64-debug-mcp@latest
Or add manually to your MCP client config:
{
"mcpServers": {
"c64-dev-tools": {
"command": "npx",
"args": ["-y", "c64-debug-mcp@latest"]
}
}
}
Quick Start
-
Add MCP server (see Installation above)
-
Ask your AI assistant to interact with C64:
- "What's in memory at $D000?"
- "Set a breakpoint at $1000"
- "Load and run my program.prg"
Important: The MCP server launches and controls VICE automatically. Your AI assistant owns the emulator process and can reset or restart it at any time. Don't use VICE manually or create valuable work in the emulator while debugging - any unsaved state may be lost when it resets the machine.
Example Workflows
Debugging a Program
You: Load examples/hello.prg and set a breakpoint at $1000
AI assistant will:
1. Load the program using program_load
2. Set a breakpoint at $1000 using breakpoint_set
3. Resume execution until breakpoint is hit
4. Show you the register state when stopped
Memory Analysis
You: What's the BASIC program in memory?
AI assistant will:
1. Read memory from $0801 (BASIC start)
2. Parse the BASIC tokens
3. Show you the program listing
Screen Capture
You: Show me what's on the screen
AI assistant will:
1. Capture the display using capture_display
2. Save a PNG image
3. Describe what's visible
License
MIT - see LICENSE file
Made with ❤️ for C64 developers and AI-assisted retro coding
"The C64 never gets old, it just gets smarter" 🎮
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。