2018-10-21 17:02:34 -07:00
|
|
|
# 6502bench #
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-10-01 11:09:04 -07:00
|
|
|
[Features](#key-features) - [Installation](#installation) - [Getting Started](#getting-started) - [About the Code](#about-the-code)
|
2018-09-30 15:10:08 -07:00
|
|
|
|
2018-09-30 21:41:46 -07:00
|
|
|
[6502bench](https://6502bench.com/) is a code development "workbench"
|
|
|
|
for 6502, 65C02, and 65802/65816 code. It currently features one tool,
|
|
|
|
the SourceGen disassembler.
|
2018-09-28 10:05:11 -07:00
|
|
|
|
|
|
|
You can download the source code and build it yourself, or click the
|
2018-10-01 11:09:04 -07:00
|
|
|
[Releases tab](https://github.com/fadden/6502bench/releases) for
|
2018-09-30 15:10:08 -07:00
|
|
|
pre-built downloads.
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-10-08 18:05:07 -07:00
|
|
|
**NEEDED:** ROM/OS symbols for various systems, notably Commodore and Atari
|
2018-10-08 15:30:43 -07:00
|
|
|
home computers.
|
|
|
|
|
2018-09-28 10:05:11 -07:00
|
|
|
|
|
|
|
## SourceGen ##
|
|
|
|
|
|
|
|
SourceGen converts machine-language programs to assembly-language source
|
|
|
|
code. It has most of the features you will find in other 6502 disassemblers,
|
|
|
|
as well as many less-common ones.
|
|
|
|
|
2018-09-30 15:10:08 -07:00
|
|
|
### Key Features ###
|
|
|
|
|
|
|
|
- Fully interactive point-and-click GUI. Define labels, set addresses,
|
|
|
|
add comments, and see the results immediately. Add multi-line comments
|
|
|
|
and have them word-wrapped automatically.
|
|
|
|
- The disassembly engine traces code execution, automatically finding all
|
|
|
|
instructions reachable from a given starting point. Changes to the
|
|
|
|
processor status flags are tracked, allowing identification of branches
|
|
|
|
that are always/never taken, accurate cycle count listings, and correct
|
|
|
|
analysis of 65816 code with variable-width registers.
|
2019-04-19 14:37:46 -07:00
|
|
|
- Easy generation of assembly source code for popular cross-assemblers
|
|
|
|
(currently cc65, 64tass, and Merlin 32). Cross-assemblers can be invoked
|
|
|
|
from the GUI to verify correctness.
|
2018-09-30 15:10:08 -07:00
|
|
|
- Symbols and constants are provided for ROM and operating system entry
|
|
|
|
points on several popular systems.
|
2018-10-09 17:34:21 -07:00
|
|
|
- Project files are designed for sharing and collaboration.</li>
|
2018-09-30 15:10:08 -07:00
|
|
|
|
|
|
|
A demo video is [available on YouTube](https://youtu.be/dalISyBPQq8).
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-09-30 15:10:08 -07:00
|
|
|
#### Additional Features ####
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-09-30 15:10:08 -07:00
|
|
|
Analyzer:
|
|
|
|
- Support for 6502, 65C02, and 65816, including undocumented opcodes.
|
|
|
|
- Hinting mechanism allows manual identification of code, data, and inline
|
|
|
|
data.
|
|
|
|
- Editable labels are generated for every branch destination and data target.
|
2018-09-28 10:05:11 -07:00
|
|
|
- Automatic detection and classification of ASCII strings and runs of
|
|
|
|
identical bytes.
|
2018-09-30 15:10:08 -07:00
|
|
|
- Symbol files for ROM entry points, operating system constants, and other
|
|
|
|
platform-specific data are stored in plain text files.
|
|
|
|
- Extension scripts can be defined that automatically reformat code and
|
|
|
|
identify inline data that follows a JSR/JSL.
|
|
|
|
|
|
|
|
User interface:
|
|
|
|
- "Infinite" undo/redo of all operations.
|
|
|
|
- Cross-reference tables are generated for every branch and data target
|
|
|
|
address, as well as for external platform symbols.
|
|
|
|
- Instruction operand formats (hex, decimal, binary, ASCII, symbol) can be
|
|
|
|
set for individual instructions. References to nearby symbols are offset,
|
|
|
|
allowing simple expressions like "addr + 1".
|
|
|
|
- Data areas can be formatted in various formats, including individual
|
|
|
|
bytes, 16-bit and 24-bit words, addresses, or strings.
|
|
|
|
- Multi-line comments can be "boxed" for an authentic retro feel.
|
|
|
|
- Notes can be added that aren't included in generated output. These also
|
|
|
|
function as color-coded bookmarks. Very useful for marking up a work in
|
|
|
|
progress.
|
|
|
|
- Instruction summaries, including CPU cycles and flags modified, are shown
|
|
|
|
along with a description of the opcode's function.
|
|
|
|
- Various aspects of the code display can be reconfigured, including
|
|
|
|
upper/lower case, pseudo-opcode naming, and expression formats. These
|
|
|
|
choices are not part of the project definition, so everyone can view a
|
|
|
|
project according to their own personal preferences.
|
|
|
|
|
|
|
|
Code generation:
|
|
|
|
- Labels can be coaxed from global to local as allowed by the assembler.
|
|
|
|
- Symbols may be exported from one project and imported into another to
|
|
|
|
facilitate multi-binary disassembly.
|
|
|
|
|
|
|
|
Miscellaneous:
|
2018-09-30 15:21:36 -07:00
|
|
|
- All data files are stored in text formats (primarily JSON).
|
2018-09-30 15:10:08 -07:00
|
|
|
- The project file includes nothing from the data file but a CRC. This may
|
|
|
|
allow the project to be shared without violating copyrights (subject to
|
|
|
|
local laws).
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-09-30 21:41:46 -07:00
|
|
|
Some planned features are not yet implemented. Notable among them are
|
|
|
|
support for multi-bank 65816 files (IIgs OMF, SNES), and alternate
|
|
|
|
character sets (e.g. PETSCII). Visit the wiki section for the
|
|
|
|
[current "TO DO" list](https://github.com/fadden/6502bench/wiki/TO-DO-List).
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-10-06 21:21:18 -07:00
|
|
|
To learn about the past, check the
|
|
|
|
[change log](https://github.com/fadden/6502bench/wiki/Change-Log).
|
|
|
|
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-10-01 11:09:04 -07:00
|
|
|
## Installation ##
|
|
|
|
|
|
|
|
There is currently no installer -- just unzip the archive and run the
|
|
|
|
executable. The data files used by the program are found automatically
|
|
|
|
based on the path to the .EXE file.
|
|
|
|
|
|
|
|
SourceGen relies on the .NET Framework. For Windows, you need to have
|
|
|
|
Microsoft .NET Framework v4.6.2 or later installed. Many people will already
|
|
|
|
have this installed. If SourceGen doesn't seem to want to start, download
|
|
|
|
the latest version (v4.7.2)
|
|
|
|
[directly from Microsoft](https://www.microsoft.com/net/download/dotnet-framework-runtime).
|
|
|
|
The framework requires Win7 SP1, Win8.1, or Win10 updated through at least
|
2018-10-06 21:21:18 -07:00
|
|
|
the Anniversary Update (1607). (One user who had trouble with the 4.7.2
|
|
|
|
installer was able to get the 4.6.2 installer to work.)
|
2018-10-01 11:09:04 -07:00
|
|
|
|
2018-10-12 10:43:28 -07:00
|
|
|
In theory, SourceGen can work with Mono under Linux and Mac OS X. There
|
|
|
|
appear to be many incompatibilities between .NET and Mono, which have to
|
|
|
|
be worked around in SourceGen. Sometimes these are straightforward,
|
|
|
|
sometimes they're [a little weird](https://faddensoft.com/sgbug/). Until
|
|
|
|
these issues are handled, running SourceGen under Mono is not recommended.
|
2018-10-01 11:09:04 -07:00
|
|
|
|
|
|
|
|
2018-09-30 15:10:08 -07:00
|
|
|
## Getting Started ##
|
|
|
|
|
|
|
|
The best way to get started is by working through the tutorial. Launch
|
2018-10-01 11:09:04 -07:00
|
|
|
SourceGen, hit F1 to open the user manual in your web browser, then look
|
|
|
|
for the Tutorial link in the index. Click it and follow the instructions
|
|
|
|
there.
|
2018-09-30 15:10:08 -07:00
|
|
|
|
|
|
|
The tutorial is one of several examples included in the SourceGen
|
|
|
|
distribution. The other directories contain project and data files for
|
|
|
|
completed disassembly projects alongside the original source code, allowing
|
|
|
|
a direct comparison between how the code was written and how SourceGen can
|
|
|
|
display it.
|
|
|
|
|
|
|
|
|
2018-09-28 10:05:11 -07:00
|
|
|
## About the Code ##
|
|
|
|
|
|
|
|
All of the code is written in C# .NET, using the (free to download) Visual
|
|
|
|
Studio Community 2017 IDE as the primary development environment. The user
|
|
|
|
interface uses the WinForms API. Efforts have been made to avoid doing
|
2018-10-01 11:09:04 -07:00
|
|
|
anything Windows-specific, in the hope of running it under Mono.
|
2018-09-28 10:05:11 -07:00
|
|
|
|
2018-10-01 11:09:04 -07:00
|
|
|
The Solution file is called "WorkBench.sln" rather than "6502bench.sln"
|
|
|
|
because some things in Visual Studio got weird when it didn't start with a
|
|
|
|
letter.
|
2018-09-28 10:05:11 -07:00
|
|
|
|
|
|
|
The code style is closer to what Android uses than "standard" C#. Lines
|
|
|
|
are folded to fit 100 columns.
|
|
|
|
|
|
|
|
The source code is licensed under Apache 2.0
|
|
|
|
(http://www.apache.org/licenses/LICENSE-2.0), which makes it free for use in
|
|
|
|
both open-source programs and closed-source commercial software. The license
|
|
|
|
terms are similar to BSD or MIT, but with some additional constraints on
|
|
|
|
patent licensing. (This is the same license Google uses for the Android
|
|
|
|
Open Source Project.)
|
|
|
|
|
|
|
|
Images are licensed under Creative Commons ShareAlike 4.0 International
|
|
|
|
(https://creativecommons.org/licenses/by-sa/4.0/).
|
|
|
|
|