Specy / asm-editor

A modern webapp to write, run and learn M68K assembly code

Home Page:https://asm-editor.specy.app

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Asm editor

A webapp made with sveltekit and rust webassembly to learn, write and run m68k assembly code. Uses monaco-editor for the editor, and my WASM M68K interpreter to run the code.

Mainly made to help people approaching assembly by providing the tools necessary to write and debug code more easily. localImage

Features recap

  • Simple code completition and full syntax highlighting
  • Run the program or step through it
  • Code breakpoints, settings, input/output interrupts, undo, formatter and more
  • Inspect the value of each register and memory address to see which was changed with each instruction
  • Create new projects and manage them all in the webapp
  • Integrated IDE with semantic checks and useful errors to help you learn assembly
  • Integrated documentation and intellisense with addressing modes, descriptions and examples
  • Customisable settings and shortcuts, including theme customization

Code completion and syntax highlighting

The editor suggests you with the available instructions and the valid addressing modes for each operand, while also giving a simple description and example.

Step and undo

The code can be run completely or step by step, the changes to the state of the interpreter is kept in memory so that it can be undone. Breakpoints can be set to stop the execution at a specific line while running, to then proceed with stepping.

Documentation

The webapp comes with a built-in documentation, both available inside the editor and as a separate page. It explains brefly how each instruction works and the addressing modes, further documentation is coming in the future.

Settings and shortcuts

Settings to choose from to customise the editor and the interpreter, like how to view the registers, how many steps to keep in history, themes, etc. There are also some shortcuts to ease the use of the editor, which can be changed in the settings.

Projects

Projects are stored locally on your browser, and with the app also working offline, you can create and manage them all in the webapp. Export and import to come in the future.

Tools

Once running the program there are many tools to help you understand what instructions did and debug the code.

  • Values which changed between each instructions are highlighted and the old value is also visible. registers and memory have tooltips to show the decimal/hexadecimal value.
  • Follow the stack pointer with the dedicated tab, it's split in rows of 4 bytes to make it easier to see the changes
  • Whenever a jsr / bsr / rts instruction is executed, the callstack is saved so that it can be seen
  • A view of the changes to the state of the interpreter is visible to see what each instruction did, like register / memory writes and changes to the ccr, it is alsoo possible to jump back to a previous state
  • Full memory viewer to inspect a memory region, with also string conversion.

Assembler features

The assembler has a few directives and features to simplify writing code.

  • equ directive to define constants
  • dc, ds, dcb directives to define data regions
  • org directive to set the origin of the code
  • expressions (like $FF*10) and many immediate representations.

Benchmarks

The interpreter runs at round 30mhz on the browser and 50mhz natively (on my machine). You can benchmark your own machine by running a loop, the time it took to run is shown in the bottom right of the console in the editor, the total time of each execution is shown. example code:

limit equ 10000000
move.l #limit, d0
move.l #0, d1
for:
    add.l #1, d1
    sub.l #1, d0
    bne for

This runs 30 million instructions, make sure you set the Maximum instructions iteration, Maximum history size and Maximum visible history size to 0, as well as not having any breakpoints, this will turn off the debugging tools and run the code as fast as possible.

About

A modern webapp to write, run and learn M68K assembly code

https://asm-editor.specy.app

License:MIT License


Languages

Language:Svelte 56.8%Language:TypeScript 41.1%Language:JavaScript 0.8%Language:HTML 0.7%Language:CSS 0.6%Language:SCSS 0.1%