Stefano Furiosi e53f03742c More
2016-06-18 15:15:10 -07:00
2016-06-18 14:11:22 -07:00
2016-06-15 21:47:43 -07:00
2016-06-18 15:08:05 -07:00
2016-06-18 14:11:22 -07:00
2016-06-15 21:47:43 -07:00
2016-06-15 21:47:43 -07:00
2016-06-18 15:15:10 -07:00

#Apple 1 REPLICA

Raw but full working implementation of Apple 1 replica, based on real W6502C MPU (modern 6502) and Arduino Due 4KB+4KB RAM.

Arduino Due just listen and write/write the 6502 pins (RW/Address/Data Bus), emulate the PIA (6821) Keyboard & Display + handle the 6502 clock.

The project was originally implemented on an Arduino UNO that is in any case limited in terms of RAM and also less performant. Arduino Due is a perfect fit instead.

The project is build over platform.io but you should be able to compile it in the Arduino standard IDE too, without any change.

  • BAUD RATE: 115200
  • Data Bits: 8
  • Parity: None
  • Stop Bits: 1
  • Flow Control: (everything OFF)
  • Emulation XTerm
  • Send Mode: Immediate
  • Return Key: CR
  • Delete Key: DEL
  • Text Pacing: Normal
  • Uppercase Typed Characters: ON

6502 to Arduino Pin schema:

                    W65C02S <->  Arduino Due

    3.3v      GND                          10uf ---- GND
     |        |       +------\/------+      |
     |        +----  1| VPB     /RES |40 ---+------- +RST BTN- ---- GND
     +--- 3k3 -----  2| RDY    PHI2O |39
     |               3| PHI1O    SOB |38
     +--- 3k3 -----  4| IRQ     PHI2 |37 -------- 52
     |               5| MLB       BE |36---3k3--------3.3v
     +--- 3k3 -----  6| /NMI      NC |35
     |               7| SYNC     R/W |34 -------- 53
     +-------------  8| VDD       D0 |33 -------- 30
       44 ---------  9| A0        D1 |32 -------- 31
       45 --------- 10| A1        D2 |31 -------- 32
        2 --------- 11| A2        D3 |30 -------- 33
        3 --------- 12| A3        D4 |29 -------- 34
        4 --------- 13| A4        D5 |28 -------- 35
        5 --------- 14| A5        D6 |27 -------- 36
        6 --------- 15| A6        D7 |26 -------- 37
        7 --------- 16| A7       A15 |25 -------- 47
        8 --------- 17| A8       A14 |24 -------- 46
        9 --------- 18| A9       A13 |23 -------- 13
       10 --------- 19| A10      A12 |22 -------- 12
       11 --------- 20| A11      VSS |21 ---+
                      +--------------+      |
                                           GND

Note: You may want to put a 100Uf capacitor near the 3.3v & GND lines too.

Auto loaded Program & extended Memory

The Arduino sketch (main.cpp) automatically load the original Apple 1 Basic in the extended RAM at E000 address (was loaded via Tape in the original version).

Same is done with a Program included in AUTLOAD variable (look into programs.h). You can comment & uncomment other programs as needed to get them auto loaded in the related RAM location. First word in the source is the location in RAM when the program should be loaded. This is not part of any original logic, it's just a convenient way to fast load programs without manually inserting them via Woz Monitor.

You can easily comment out this logic or extend it as needed.

MASM version of WAZ MONITOR (Official Apple 1 ROM)

Inside ASM folder you can find the woz_monitor_masm.asm source listing. This is the original ROM listing found in the apple 1 manual converted to be compatible with masm.

If you are under OSX - you can install MASM via homebrew and use it to compile any asm source included the one above.

Apple 1 Address space

      $0000-$0FFF ------------- 4KB RAM
         $0024-$002B ---------- WOZ MONITOR STORE (better to not overwrite)
         $0200-$027F ---------- INPUT BUFFER (as the one above)
      $D010-$D013 ------------- PIA (6821) [KBD & DSP]
      $E000-$EFFF ------------- 4KB extended RAM (Usually for BASIC prog)
      $FF00-$FFFF ------------- 256 Bytes ROM (crazy! with just 2 bytes unused.)

Resources

Description
Apple 1 replica based on real 6502 and Arduino Due
Readme 69 KiB
Languages
C 68.4%
Assembly 22.2%
C++ 9.4%