Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dragonbytes/Apple2CoCo

A simple Apple II emulator written for the Tandy Color Computer 3
https://github.com/dragonbytes/Apple2CoCo

Last synced: about 1 month ago
JSON representation

A simple Apple II emulator written for the Tandy Color Computer 3

Awesome Lists containing this project

README

        

# Apple2CoCo v1.0
A simple Apple II emulator written for the Tandy Color Computer 3

Written by Todd Wallace


YouTube: https://www.youtube.com/@tekdragon
Website: https://tektodd.com



Screenshot 2023-02-16 131143

It's alive! AppleSoft BASIC in action!





lo_res_gfx_screenshot

New Lo-Res Graphics Video Mode Support!!




**Version 1.0 Update**

I think i've finally gotten this emulator into a state that I feel comfortable calling it a version 1.0! In no particular order, here are some of the major changes/updates:
- Simplified loader reads in the needed ROM file directly off of the CoCo disk's filesystem. No weird custom disk images needed anymore.
- Rudimentary Apple II+ Lo-Res Graphics mode support
- Optional build flag to include a basic 6502 debugger that uses CoCo3 Hi-Res Text screen to display a trace of 6502 instructions as the emulator runs them
- Simple BASH build script to create the executable and CoCo DSK image

This emulator is mostly a proof-of-concept project and is by no means a complete emulation of the Apple II+. While the 6502 CPU emulation is pretty complete, apple-specific hardware support is limited to keyboard input and two video output modes. The emulator supports the Lo-Res "stock" 40 column text-only video mode as well as the Lo-Res Graphics mode. The video stuff isn't cycle-accurate and probably could have been implemented in a more effective manner, but hey it works for now! I do hope to expand the functionality of this emulator in the future, the video graphics modes and floppy support in particular.

**The Apple II+ ROM Image**

A 20KB ROM image from an Apple II+ is required for the emulator to work. For obvious reasons I cannot bundle this with my emulator, but it shouldn't be too difficult to obtain one. The filename of the ROM you need for my emulator is called APPLE2.ROM. Copy this file onto the same CoCo-formatted disk that the emulator is located on. That's all you have to do!

**Running The Emulator**

Once you have copied your APPLE2.ROM file onto the disk alongside the emulator, type:

LOADM"APPLEEMU.BIN"

Run the program with the EXEC command. The loader will automatically search the disk for the required APPLE2.ROM file and load it into the CoCo 3's RAM. As soon as it finishes, the Apple II+ emulation will boot and you should soon see the familiar "Apple II" text at the top of the screen. By default, a real Apple II+ tries to boot off the floppy drive when you power it on. Unfortuantely, floppy drives are not yet supported by my emulator so all you can really do is jump into AppleSoft BASIC. To do this on real hardware, you would press the APPLE + RESET keys together. I have mapped this function to the CoCo 3's CLEAR key. After pressing this key, you should find yourself at the AppleSoft BASIC prompt! The rest is up to you! Have fun tinkering!

**Building Instructions**

If you want to build the emulator from source yourself, I wrote a simple BASH script to help. In your terminal of choice, navigate to the directory that you downloaded the files to and run the script with:

./build_apple.sh

The script should be mostly self-explanatory, but here is what it does. First, it checks to make sure that you have the required assembler LWASM in your system PATH. Next it will assemble the emulator core into a raw binary payload file that my loader needs. Finally, it will assemble the loader itself (which automatically includes the payload) into a normal CoCo BIN file. After the project is built, the script will attempt to use Toolshed's DECB tool to create (or update) the DSK image file apple2coco.dsk and copy the BIN file over to it. If you don't have the Toolshed tools in your PATH, then you must manually copy the executable to your own CoCo-foramtted disk using whichever tool you want.