-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathREADME
194 lines (154 loc) · 7.41 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
This is a reconstruction of an 1980s-era Apple ][+ implemented in VHDL for
FPGAs.
Stephen A. Edwards, [email protected]
http://www1.cs.columbia.edu/~sedwards
------------------------------
The current implementation uses the Altera DE1/DE2 board and takes
advantage of its off-chip SRAM, VGA DAC, SD card, audio CODEC, and
PS/2 keyboard interface.
It was designed to be fairly easy to port: the apple2.vhd file should
be implementation-agnostic: it only assumes the external availability
of 48K of RAM and a keyboard.
It contains a simple read-only Disk II emulator that expects
"nibblized" disk images written raw onto an SD or MMC card (i.e., it
does not use a FAT or any other type of filesystem).
The VGA controller (not part of an original Apple) doubles each line
and interprets the Apple's NTSC-compatible color signals to produce a color
640 X 480 VGA display with non-standard dot timing.
------------------------------
To compile under Altera's Quartus software, open the
apple2fpga_DE1.qpf or apple2fpga_DE2.qpf project file and compile.
------------------------------
VHDL files, in order of elaboration:
timing_generator.vhd Timing signal generation, video counters
character_rom.vhd The beautiful 5 X 8 uppercase-only text font
video_generator.vhd Text, lores, and hires mode shift registers
main_roms.vhd D000-FFFF ROMs: Applesoft and the Monitor
cpu6502.vhd The 6502 CPU core
apple2.vhd Top-level of the Apple: mostly address decode
disk_ii_rom.vhd C600-C6FF ROM: Disk II bootstrap ROM
disk_ii.vhd Read-only Disk II emulator
vga_controller.vhd NTSC-to-VGA color interpolation, line doubler
PS2_Ctrl.vhd Low-level PS/2 keyboard interface
keyboard.vhd PS/2 keyboard-to-Apple interface
spi_controller.vhd SD/MMC card controller: reads raw tracks
i2c_controller.vhd Simple I2C bus driver; initializes the codec
wm8731_audio.vhd Controller for the Wolfson WM8731 audio codec
DE1_TOP.vhd Top-level entity for the Altera DE1 board
DE2_TOP.vhd Top-level entity for the Altera DE2 board
CLK28MPLL.vhd Altera-specific configuration for 28 MHz PLL
Other files:
dsk2nib.c Converts a 140K .dsk image file to the raw 228K
.nib format used by the Disk II emulator
dsknib.sln Visual C++ Express 2008 solution file for
generating dsknib.exe under Windows
dsknib.vcproj Visual C++ Express 2008 project file for
generating dsknib.exe under Windows
makenibs A shell (e.g., bash) script that assembles
collections of .dsk files into a file suitable
for directly writing onto an SD card
rom2vhdl Script to convert raw ROM files into
synthesizable VHDL code. Used to produce main_roms.vhd
apple2fpga_DE1.qpf DE1 board project file for Altera's Quartus
apple2fpga_DE2.qpf DE2 board project file for Altera's Quartus
DE1_TOP.qsf Mostly pin assignments for Altera's Quartus
DE1_TOP.sof A compiled bitstream for the DE1 board: the
result of compiling all the VHDL files in
Quartus; suitable for programming if you have a
DE1 board.
DE2_TOP.qsf Mostly pin assignments for Altera's Quartus
DE2_TOP.sof A compiled bitstream for the DE2 board: the
result of compiling all the VHDL files in
Quartus; suitable for programming if you have a
DE2 board.
dos33master.nib Bootable disk image: Apple DOS 3.3 system master
bios.a65 6502 assembly source for a "fake" BIOS
bios.rom Binary data for the "fake" BIOS
Makefile Rules for creating the .zip, .vhd files, etc.
------------------------------
Disk images
The system expects a sequence of "nibblized" (227K) disk images on the
SD card starting at block 0. Switches on the DE1/DE2 board selects
which image appears to be in the drive; the image number is displayed
in hex on two of the seven-segment displays.
Most Apple II disk images are in 140K .dsk files, which stores only
the disk's logical data, i.e., is not encoded. dsk2nib.c is a small C
program that expands .dsk files to .nib files.
I used the "makenibs" script to find all the .dsk files in a tree of
directories, assemble them into an image suitable for downloading to
the SD card, and print an image number/file name cross-listing.
To write .nib images to an SD/MMC card under Linux, I use
dd if=dos33master.nib of=/dev/sdd
Of course, your card may appear as something other than /dev/sdd.
Under Windows, you can use dd.exe (http://www.chrysocome.net/dd):
dd.exe if=dos33master.nib of=\\?\Device\Harddiskx\Partition0
where the correct "Harddiskx" can be determined using the dd.exe
"--list" option:
dd.exe --list
------------------------------
ROMs
This archive does NOT include a copy of the Apple ][+'s ROMs, which
are copyright Apple Computer. Instead, it includes a very trivial
BIOS that beeps, displays a text screen, then cycles through some
lores and hires graphics patterns when keys are pressed. This should
be enough to verify the graphics, sound, and keyboard are working (but
not the disk emulator). Source for this BIOS is in the bios.a65 file,
which I assembled using the xa65 cross-assembler.
The system requires two ROM images: a 12K image of the system roms
(memory from 0xD000 - 0xFFFF) and a 256-byte image of the Disk II
controller bootstrap ROM (memory from 0xc600 - 0xc6ff if the card is
in the usual slot 6).
Once you obtain them, run the "rom2vhdl" script to convert the binary
files into .vhd files that hold the data. The Makefile contains rules
for doing this.
------------------------------
Operation
For the DE1 board:
KEY[3] Reset
KEY[2..0] Game Port
SW[9] B&W/Color Display
SW[8..0] Disk Image # (0 to 511)
HEX[2..3] Disk Image # (0 to 255 => 00 to FF hex)
HEX[1..0] Track # (0 to 35 => 00 to 23 hex)
LEDR[9..0] PC[15..6] (CPU Program Counter in 64-byte page unit)
LEDG[3] Unused
LEDG[2] Disk Drive #2 Activity
LEDG[1] Disk Drive #1 Activity
LEDG[0] Speaker Activity
For the DE2 board:
KEY[3] Reset
KEY[2..0] Game Port
SW[17] B&W/Color Display
SW[16..10] Unused
SW[9..0] Disk Image # (0 to 1023)
HEX[7..6] Disk Image # (0 to 255 => 00 to FF hex)
HEX[5..4] Track # (0 to 35 => 00 to 23 hex)
HEX[3..0] PC[15..0] (CPU Program Counter, 0000 to FFFF hex)
LEDR[17..16] Unused
LEDR[15..0] PC[15..12] (CPU Program Counter in 4Kbyte page unit decoded)
LEDG[8] Disk Drive #1 Activity
LEDG[7..4] Analog Joystick Activity
LEDG[3..1] Unused
LEDG[0] Speaker Activity
------------------------------
Credits:
Peter Wendrich supplied the 6502 core:
-- cpu65xx_fast.vhdl, part of FPGA-64, is made available strictly for personal
-- educational purposes. Distributed with apple2fgpa with permission.
--
-- Copyright 2005-2008 by Peter Wendrich ([email protected]).
-- All rights reserved.
-- http://www.syntiac.com/fpga64.html
The low-level PS/2 keyboard controller is from ALSE:
-- PS2_Ctrl.vhd
-- ------------------------------------------------
-- Simplified PS/2 Controller (kbd, mouse...)
-- ------------------------------------------------
-- Only the Receive function is implemented !
-- (c) ALSE. http://www.alse-fr.com
Michel Stempin ([email protected]):
- ported apple2fpga to the Altera DE1 board
- added SD/SDHC to MMC Flash disk comptatibility
- added i18n + French keymap
I adapted the Apple ][ keyboard emulation from Alex Freed's FPGApple:
http://mirrow.com/FPGApple/