Kazalo:
2025 Avtor: John Day | [email protected]. Nazadnje spremenjeno: 2025-01-13 06:58
Mikroprocesor 6502 se je prvič pojavil leta 1975 in ga je oblikovala majhna ekipa pod vodstvom Chucka Peddlea za tehnologijo MOS. Takrat so ga uporabljali v video konzolah in domačih računalnikih, vključno z Atari, Apple II, Nintendo Entertainment System, BBC Micro, Commodore VIC20 in 64. Takrat je bil eden najcenejših na trgu. Nikoli ni zares izginil, zdaj pa ga ljubitelji in strokovnjaki uporabljajo za številne aplikacije.
Različica, ki jo uporabljam, je W65C02S6TPG-14, ki jo izdeluje Western Design Center in porabi desetkrat manj energije kot izvirnik. Poseben je po tem, da mu ni treba delovati na 1 MHz kot prvotni čip. Lahko deluje veliko počasneje ali pa se uporablja za posamezen korak skozi program in celo poveča do 14 MHz. Podatkovni list za čip pojasnjuje njegove zmogljivosti. Drugi čipi 6502 nimajo te zmogljivosti in ne bodo delovali na ta način. Žetoni so trenutno na voljo na Ebayu in v drugih virih.
Zaloge
Vsi uporabljeni deli so trenutno na voljo na Ebayu, AliExpressu in drugih.
1. korak: Koncept
Navdih sem dobil pri Ben Eaterju, ki je na YouTubu izdelal vrsto videoposnetkov o 6502 in številnih drugih vidikih gradnje računalnikov in vezij. Program je napisal on prvotno in to in nekatere njegove zasnove sem spremenil, da sem prišel do tega Instructable. Še ena oseba, ki me je navdihnila, je Andrew Jacobs, ki ima razdelek na GitHubu, kjer uporablja mikrofon PIC za nadzor svojega 6502.
Tako kot Ben uporabljam Arduino MEGA za spremljanje 6502. Za razliko od Bena uporabljam tudi MEGA za zagotavljanje signala ure. Trenutno ne uporabljam niti EEPROM -ov niti RAM -a.
2. korak: Zahteve
Za izdelavo tega "računalnika" je seznam elementov naslednji:
1 x Arduino MEGA
1 x Western Design Center W65C02S6TPG-14
1 x 74HC00N IC (Quad 2-input NAND gate) ali podobno
1 x 74HC373N IC (oktalni prozorni zapah tipa D) ali podobno
2 x 830 luknjic za kruh (1 na ščepec)
Različni Dupont moški - moški kabli in žice za povezavo
2 x LED (uporabil sem 5 mm modro, saj se lahko izognete brez uporov)
1 x 12 -milimetrsko stikalno stikalo s pritiskom na gumb, SPST ali podobno
1 x 1K upor
2 x 0,1 uF keramični kondenzatorji
1 x 8 -milimetrska rdeča LED lučka (kot zgoraj) ali 8 LED in uporov
OPOMBA: Če dobite spajkani komplet, lahko LED napačno vstavite tako, da so skupne katode. Pritrdim muhovod (namesto zatiča), tako da se lahko enostavno poveže drugam. VCC zdaj postane Ground. LED diode lahko seveda obrnete (na sestavljenem predmetu) in jih ponovno spajkate, vendar je to veliko napake! Kompleti so trenutno na voljo na AliExpressu.
3. korak: Sestavite skupaj
Lažje sem uporabil nove žice DuPont, ki niso bile ločene od traku, za naslovna in podatkovna vodila.
Priključite pin 9 (A0) 6502 na pin 52 MEGA, nožica 10 (A1) 6502 na pin 50 itd …
dokler
Priključite pin 25 (A15) 6502 na pin 22 MEGA.
16 povezav do sedaj.
Prav tako
Priključite pin 26 (D7) 6502 na pin 39 MEGA, pin 27 (D6) of 6502 to pin 41 etc…
dokler
Priključite pin 33 (D0) 6502 na pin 53 MEGA.
Še 8 povezav.
Priključite pin 8 (VDD) na 5v na MEGA.
0,1uF kondenzator, povezan z zatičem 8 na Gnd plošče za kruh, je tukaj lahko uporaben, ni pa nujen.
Priključite pin 21 (VSS) na Gnd na MEGA.
Zatiči 2, 4, 6, 36 in 38 so lahko vezani na 5v
Priključite pin 37 (Ura) na pin 2 in pin 7 na MEGA.
Priključite pin 34 (RWB) na pin 3 MEGA.
Priključite pin 40 (ponastavitev), kot je prikazano zgoraj.
4. korak: Preizkusite vezje
Na tej stopnji bo 6502 deloval in lahko uporabljate program1. Če uporabljate 8 -smerno oznako (kot zgoraj), jo lahko vstavite naravnost v ploščo in muho povežete s tlemi ali pa uporabite 8 LED in uporov. LED diode bodo pokazale, kaj je na podatkovnem vodilu.
Na tej stopnji bi bilo prav tako nastaviti zamude v zanki () na 500 ali več, da bi spremljali dogajanje.
Na serijskem monitorju bi morali dobiti podoben izhod kot zgornji. Ko pritisnete Ponastavi, procesor opravi 7 ciklov in nato poišče zagon programa na lokacijah $ FFFC in $ FFFD. Ker za 6502 ni fizičnih naslovov za branje, jih moramo dostaviti iz MEGA.
V zgornjem izhodu 6502 bere $ FFFC in $ FFFD in dobi $ 00 in 10 (Low byte, High byte), kar je začetek programa pri 1000 $. Procesor nato začne izvajati program na lokaciji 1000 USD (kot zgoraj). V tem primeru se glasi A9 USD in 55 USD, to je LDA#55 USD (Naložite 85 v akumulator). Tudi če ni fizičnega pomnilnika, MEGA simulira prebrano iz podatkovnega vodila.
55 USD (85) daje binarni vzorec 01010101 in ko zavrtite 1 bit v levo, daje AA AA (170) 10101010.
Program pokaže, da procesor deluje pravilno, a kmalu postane malce dolgočasen, zato pojdimo na naslednji del.
5. korak: Naslednji korak
Zgornji "kup špagetov" je verjetno nekaj takega, kar boste imeli po tej stopnji.
Nato morate na vezje dodati integrirani vmesnik 74HC373N in 74HC00N.
Na žalost se zatiči 373 ne ujemajo s podatkovnim vodilom, zato jih bo treba priključiti na žice.
Priključite 5V na pin 20.
Ozemljitev priključite na pin 10.
Priključite pin 33 (D0) 6502 na pin 3 (D0) 74HC373N
in prav tako z zatiči D1 do D7.
Q0 do Q7 so izhodi, ki jih je treba priključiti na LED okvir ali posamezne LED in upore.
Pri 74HC00 sta potrebni le 2 vrata
Priključite 5V na pin 14.
Ozemljitev priključite na pin 7.
Priključite pin 17 (A8) 6502 na pin 1 (1A) 74HC00
Priključite pin 25 (A15) 6502 na pin 2 (1B) 74HC00
Priključite pin 34 (R/W) 6502 na pin 5 (2B) 74HC00
Priključite pin 3 (1Y) 74HC00 na pin 4 (2A) 74HC00
Priključite pin 6 (2Y) 74HC00 na pin 11 (LE) 74HC373N
Priključite pin 11 (LE) 74HC373N na pin 1 (OE) 74HC373N
Na 1Y in ozemljitev ter 2Y na maso lahko priključite modro LED, kar bo pokazalo, kdaj so vrata aktivna.
Končno spremenite vrstico v postopku onClock iz programa1 v program2
setDataPins (program2 [odmik]);
6. korak: Program
Program 6502-Monitor vsebuje dve zgoraj opisani rutini 6502.
Program se še razvija in je nekoliko neurejen.
Pri izvajanju programa2 so lahko zamude v zanki () 50 ali manj in se celo odstranijo. Komentiranje vrstic Serial.print () tudi pospeši delovanje 6502. Če ločite pin 1 (OE) 373 iz pin 11 (LE), dobite različne rezultate. Če odklopite zatič 1 in 11 za 373 iz vrat NAND, lahko vidite, kaj je na podatkovnem vodilu pri vsakem ciklu.
Morda boste morali OE priklopiti na tla, namesto da bi ga pustili plavajočega, saj je 8 izhodnih linij onemogočeno, če gre ta pin visoko. Ko je pin LE visok, so izhodni zatiči enaki kot vhodi. Če levi pin pripeljete nizko, se izhodi zaklenejo, torej če se vhodni zatiči spremenijo, izhodi ostanejo enaki.
Poskušal sem narediti program čim bolj preprost, da ga lažje razumem.
Eksperimentiranje s časovnimi zamiki vam omogoča, da natančno spremljate, kaj počne 6502.
Spodaj sta dva programa (oba tečeta na naslovu 1000 USD) v 6502 Assembler:
program1
LDA#55 USD
NOP
ROL
STA 1010 USD
1000 JMP
ROL vrti vsebino akumulatorja za en bit levo, kar pomeni, da 55 USD zdaj postane AA AA.
V strojni kodi (šestnajstiška): A9 55 EA 2A 8D 10 10 4C 00 10
program2
LDA#01 USD
STA 8100 USD
ADC#03 USD
STA 8100 USD
1005 JMP
V strojni kodi (šestnajstiška): A9 01 8D 00 81 69 03 8D 00 81 4C 05 10
V programu2 je zdaj fizični naslov 8100 USD, kjer je 74HC373 na naslovnem vodilu.
A15 iz 6502 je 32768 (8000 USD), A8 pa 256 (0100 USD) = 33024 (8100 USD).
Torej, ko 6502 zapiše 8100 USD (STA 8100 USD), je R/W 6502 nizka, podatki na podatkovnem vodilu 6502 pa zaklenjeni, ko 373 LE pade. Zaradi vrat 74HC00 NAND so signali obrnjeni.
V zgornjem sitotisku se je drugo pisanje povečalo za 3 (ADC#$ 03) - s 7F na 82 USD.
V resnici bi bili za določeno lokacijo 373. uporabljeni več kot 2 vrstici naslovnega vodila. Ker je to edini fizični naslov od možnih 65536, dokazuje, kako deluje naslovno vodilo. Lahko poskusite z različnimi zatiči naslova in jih postavite na drugo mesto. Seveda boste morali operande STA spremeniti na novo lokacijo. npr. Če bi uporabili naslovni vrstici A15 in A9, bi bil naslov 8200 USD (32768 + 512).
7. korak: Zaključek
Poskušal sem pokazati, kako enostavno je 6502 zagnati in zagnati.
Nisem strokovnjak na tem področju, zato bi bil dobrodošel kakršne koli konstruktivne pripombe ali informacije.
Vabljeni, da to še naprej razvijate in zanimalo bi me, kaj ste storili.
Projektu nameravam dodati EEPROM, SRAM in 6522 ter ga v prihodnje postaviti na trak.