Skip to content

experimental remote debugger for the Commander X16 emulator.

License

Notifications You must be signed in to change notification settings

deckfln/x16-web-debugger

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Release License: BSD-Clause

This is an experimental remote debugger for the Commander X16 emulator. It is tailored for CA65 assembler code and needs a patched version of the emulator available here

Design

          http://*:9009            http://localhost:8000           http://*:8000
+---------+----------+                +---------+                  +-----------+
|         |MicroHTTP | <------------> | Browser | <--------------> | server.py |
|         |----------+                |         |                  +-----------+
|         | Remote   |                +---------+                    |       |
|         | Debugger |                                     Project <-+       +-> Debugger 
| mainloop-----------+                                     Folder               Folder
|         |
|         |
+---------+
  x16-emulator

Features

  • Debug 65c02 instructions
  • Debug CA65 source code
  • Memory & VRAM dump
  • Code breakpoints
  • Memory & VRAM breakpoints
  • Display memory as structure (format extracted from source code)

Memory & VRAM dump

  • Dump 256 bytes of memory from the address provided in hexadecimal
  • Highlights bytes changed
  • Add memory breakpoints on individual bytes
  • Monitored memory bytes are highlight
  • Change size of monitored bytes on the fly (byte, word, long)
  • display tiles per layer (first 16x of the tile list)

Source code

  • Syntax highlighting

Code breakpoints

  • Set breakpoints on instructions on the source code

Memory & VRAM breakpoints

  • Trigger a breakpoint as soon as the content of the memory changes (byte, word, long)

Memory watches

  • Display memory as a structure defined in the source code (.STRUCTURE / .ENDSTRUCTURE)
  • indirect access register base (r0),y
  • memory indirect access ($0002),y
  • highlights attributes changed

Todo

  • Display memory as byte, word, long
  • Conditional code breakpoint
  • Trigger a breakpoint when the memory content reaches a predefined value

Configuration

Update config.json to point to the source code folder and the debug files

{
    "root":"d:/dev/x16/x16-uncharted",      // home folder of the project
    "sources":"/src",                       // sub folder with sources
    "remote":"http://localhost:9009",       // address of the emulator
    "debuginfo":"/bin/test.dbg",            // local path of the debug info file
    "symbols":"",                           // local path of the symbol files (if there is no debuginfo)
    "binary":"bin/test.prg"                // local path for the binary
}

Usage

  • Compile the source code with debug options

    • ca65 --debug-info -t cx16 main.asm -o main.o
    • cl65 -t cx16 -o ../bin/test.prg main.o -Wl --dbgfile,../bin/test.dbg
  • Start the debugger server

    • cd x16-web-debugger
    • python server.py
  • Start the emulator in remote debug mode

    • x16-emulator.exe -rom rom.bin -remote-debugger -prg test.prg
  • point your web browser to the remote debugger

  • Detect bug

  • Fix the bug in your editor

  • Compile

  • The debugger will detect the new version and propose to load source (on the debugger) and PRG (on the emulator)

A word about security

There is none ! Communications are in clear text over HTTP, there is no credentials to log in.

External libraries

Mandatory screenshot

IDE screenshot