Technologie MOS 6502 - MOS Technology 6502

Technologie MOS 6502
MOS 6502AD 4585 top.jpg
Procesor MOS Technology 6502 v a DIP-40 plastové balení. Čtyřmístný kód data naznačuje, že byl vyroben ve 45. týdnu (listopad) roku 1985.
Obecná informace
Spuštěno1975; Před 45 lety (1975)
Společný výrobce
Výkon
Max. procesor rychlost hodin1 MHz až 3 MHz
Šířka dat8
Šířka adresy16
Architektura a klasifikace
Sada instrukcíMOS 6502
Instrukce56
Fyzické specifikace
Tranzistory
Balení
  • 40kolíkový DIP
Dějiny
Předchůdce
Nástupce

The Technologie MOS 6502 (obvykle „šedesát pět-oh-dva“ nebo „šest-pět-oh-dva“)[3] je 8-bit mikroprocesor který navrhl malý tým pod vedením Chuck prodávat pro Technologie MOS. Designérský tým dříve pracoval v Motorola na Motorola 6800 projekt; 6502 je v podstatě zjednodušená, levnější a rychlejší verze tohoto designu.

Když byl představen v roce 1975, 6502 byl se značnou rezervou nejméně nákladným mikroprocesorem na trhu. Zpočátku prodával za méně než šestinu nákladů na konkurenční designy od větších společností, jako je 6800 nebo Intel 8080. Jeho zavedení způsobilo rychlé snížení cen na celém trhu procesorů. Spolu s Zilog Z80, zažehla řadu projektů, které vyústily v domácí počítač revoluce začátku 80. let.

Oblíbený herní konzole a počítače, například Atari 2600, 8bitová rodina Atari, Apple II, Zábavní systém Nintendo, Commodore 64, Atari Lynx, BBC Micro a další, použijte 6502 nebo varianty základního designu. Brzy po zavedení 6502 byla MOS Technology přímo zakoupena Commodore International, který pokračoval v prodeji mikroprocesoru a licencí dalším výrobcům. Na počátku 6502 to bylo druhý zdroj podle Rockwell a Synertek a později licencován jiným společnostem.

Ve svém CMOS forma, 65C02, který vyvinula Western Design Center (WDC), rodina 6502 je i nadále široce používána v vestavěné systémy, s odhadovaným objemem výroby v řádu stovek milionů.[4]

Historie a použití

Počátky ve společnosti Motorola

Demonstrační deska Motorola 6800 postavená Chuckem Peddleem a Johnem Buchananem v roce 1974

Model 6502 byl navržen mnoha stejnými inženýry, kteří navrhli Motorola 6800 rodina mikroprocesorů.[5] Společnost Motorola zahájila projekt mikroprocesoru 6800 v roce 1971 s hlavním architektem Tomem Bennettem. Uspořádání čipů začalo koncem roku 1972, prvních 6800 čipů bylo vyrobeno v únoru 1974 a celá rodina byla oficiálně vydána v listopadu 1974.[6][7] John Buchanan byl návrhářem čipu 6800[8][9] a Rod Orgill, který později vyrobil 6501, pomáhal Buchananovi s analýzami obvodů a uspořádáním čipů.[10] Bill Mensch nastoupil do společnosti Motorola v červnu 1971 po absolvování University of Arizona (ve věku 26).[11] Jeho prvním úkolem bylo pomoci definovat periferní integrované obvody pro rodinu 6800 a později byl hlavním konstruktérem 6820 Adaptér periferního rozhraní (PIA).[12] Inženýři společnosti Motorola mohli provádět analogové a digitální simulace na počítači IBM 370-165 sálový počítač.[13] Bennett najal Chuck prodávat v roce 1973 provést architektonické podpůrné práce na 6800 již připravovaných produktech rodiny.[14] Podílel se na mnoha oblastech, včetně designu 6850 ACIA (sériové rozhraní).[15]

Cílovými zákazníky společnosti Motorola byly zavedené elektronické společnosti, jako jsou Hewlett Packard, Tektronix, TRW, a Chrysler.[16] V květnu 1972 začali inženýři společnosti Motorola navštěvovat vybrané zákazníky a sdílet podrobnosti o navrhovaném 8bitovém mikroprocesorovém systému s ROM, RAM, paralelním a sériovým rozhraním.[17] Na začátku roku 1974 poskytli technické vzorky čipů, aby zákazníci mohli prototypy svých návrhů. Strategie „celkové produktové rodiny“ společnosti Motorola se nezaměřovala na cenu mikroprocesoru, ale na snížení celkových nákladů na design zákazníka. Nabídli vývojový software na počítači s časovým sdílením, „EXORcis "systém ladění, školení na místě a podpora aplikačního inženýra v terénu.[18][19] Společnost Intel i Motorola původně oznámily cenu 360 $ za jeden mikroprocesor.[20][21] Skutečná cena za výrobní množství byla mnohem nižší. Motorola nabídla designovou sadu obsahující 6800 se šesti podpůrnými čipy za 300 $.[22]

Prodejce, který by doprovázel prodejce při návštěvách zákazníků, zjistil, že zákazníci byli odrazeni vysokými náklady na mikroprocesorové čipy.[23] Zároveň tyto návštěvy vždy vedly k tomu, že inženýři, které představil, vytvořili seznamy požadovaných pokynů, které byly mnohem menší než „všechny tyto fantastické pokyny“, které byly zahrnuty do 6800.[24] Obchodník a další členové týmu začali navrhovat vylepšenou funkci mikroprocesoru se sníženou velikostí. V té době měl nový závod společnosti Motorola na výrobu polovodičů v texaském Austinu potíže s výrobou čipů MOS a v polovině roku 1974 byl začátek celoroční recese v odvětví polovodičů. Také mnoho zaměstnanců v Arizoně v Mese nebylo spokojeno s nadcházejícím přestěhováním do Austinu.[25]

Vedení divize Semiconductor Products společnosti Motorola bylo zahlceno problémy a neprojevilo žádný zájem o levný návrh mikroprocesoru společnosti Peddle. Nakonec Peddle dostal oficiální dopis, ve kterém mu řekl, aby přestal pracovat na systému.[26] Peddle reagoval na objednávku informováním společnosti Motorola, že dopis představuje oficiální prohlášení o „opuštění projektu“ a duševní vlastnictví, které do té doby vyvinul, je nyní jeho.[27] V rozhovoru z listopadu 1975 se předseda společnosti Motorola Robert Galvin nakonec shodl na tom, že koncept společnosti Peddle byl dobrý a že divize promarnila příležitost: „Nevybrali jsme si správné vůdce v divizi Semiconductor Products.“ Divize byla reorganizována a vedení nahrazeno. Nový viceprezident skupiny John Welty řekl: „Organizace prodeje polovodičů ztratila citlivost na potřeby zákazníků a nemohla činit rychlá rozhodnutí.“[28]

Přechod na technologii MOS

Reklama MOS Technology z roku 1973 zdůrazňující jejich vlastní schopnosti integrovaných obvodů
MOS Technology MCS6501, v bílém keramickém obalu, vyrobený na konci srpna 1975

Peddle začal hledat mimo společnost Motorola zdroj financování tohoto nového projektu. Zpočátku se přiblížil MOSTEK Generální ředitel L. J. Sevin, ale Sevin to odmítl a později připustil, že to bylo proto, že se bál, že je Motorola zažaluje.[29]

Když byl Peddle na návštěvě Ford Motor Company na jedné ze svých prodejních cest Bob Johnson, pozdější vedoucí divize automatizace motorů společnosti Ford, uvedl, že jejich bývalý kolega John Paivinen se přestěhoval do Obecný nástroj a naučil se konstrukci polovodičů. Od té doby se přesunul a dělal velmi zajímavou práci na čipových sadách kalkulaček v nové společnosti, ve které založil Valley Forge, Pensylvánie.[30]

Paivinen se zformoval Technologie MOS v roce 1969 se dvěma dalšími manažery z General Instrument, Mortem Jaffem a Donem McLaughlinem. Allen-Bradley, dodavatel elektronických součástek a průmyslových řídicích systémů, získala většinový podíl v roce 1970.[31] Společnost navrhla a vyrobila vlastní integrované obvody pro zákazníky a vyvinula řadu kalkulačních čipů.[32]

Poté, co úsilí MOSTEK propadlo, se Peddle přiblížil k Paivinenovi, který „to okamžitě dostal“.[33] Dne 19. srpna 1974 Chuck Peddle, Bill Mensch, Rod Orgill, Harry Bawcom, Ray Hirt, Terry Holdt a Wil Mathys opustili společnost Motorola, aby se připojili k MOS. Mike Janes se připojil později. Ze sedmnácti návrhářů a návrhářů čipů v týmu 6800 odešlo sedm. Cílem týmu bylo navrhnout a vyrobit nízkonákladový mikroprocesor pro vestavěné aplikace a zaměřit se na co nejširší zákaznickou základnu. To by bylo možné pouze v případě, že mikroprocesor měl nízké náklady a cenový cíl byl stanoven na 5 $ v objemu.[34]

Čipy jsou vyráběny tiskem více kopií designu čipu na povrch a "oplatka", tenký disk z vysoce čistého křemíku. Menší čipy lze tisknout ve větším počtu na stejnou destičku, což snižuje jejich relativní cenu. Oplatky navíc vždy obsahují určitý počet drobných fyzických vad, které jsou rozptýleny po povrchu. Jakýkoli čip vytištěný na tomto místě selže a musí být zlikvidován. Menší čipy znamenají, že u jedné kopie bude méně pravděpodobné, že bude vytištěna na vadu. Z obou těchto důvodů cena konečného produktu silně závisí na velikosti designu čipu.[35]

Původních 6800 čipů mělo být 180 × 180 mil,[A] ale rozvržení bylo dokončeno v 212 × 212 mil (5,4 × 5,4 mm), nebo oblast 29,0 mm2.[36] U nového designu vyžadoval nákladový cíl velikostní cíl 153 × 168 mil (3,9 × 4,3 mm)nebo o ploše 16,6 mm2.[37] K dosažení tohoto cíle by bylo zapotřebí několik nových technik.

Přechod na NMOS

V době, kdy byla navržena 6502, která významně snížila náklady, dorazily na trh dva významné pokroky. První byl přechod z PMOS na NMOS. Obvody PMOS vždy procházely proudem, a to i ve stavu „vypnuto“. Aby byly změny v zapnutém a vypnutém stavu snadno viditelné na signálech, většina systémů PMOS používala dvě kladná napětí, často +12 V a +5 V, jakož i zem a záporné napětí. Příkladem je Intel 8080, který měl +12 V, +5 V, -5 V a zem.[38] Naproti tomu obvody NMOS, také známé jako tranzistory „vyčerpání-zatížení“, spotřeboval asi o polovinu méně energie, a tak mohl být postaven menší, což zmenšilo velikost čipu. Rovněž vyžadovali pouze jedno napájecí napětí, obvykle +5 V, což zjednodušilo zapojení na čipu a dále zmenšilo velikost.[39]

Další praktickou výhodou bylo, že hodinový signál pro procesory PMOS musel být dostatečně silný, aby přežil veškerý rozptyl, když procházel obvody, což téměř vždy vyžadovalo samostatný externí čip, který mohl dodávat dostatečně silný signál. Se sníženými energetickými požadavky NMOS se hodiny mohly přesunout na čip, což zjednodušilo celkový design počítače. Tyto změny výrazně snížily složitost a náklady na implementaci kompletního systému.[39]

Další změnou, která se odehrávala, bylo zavedení bezkontaktních projekčních systémů od společnosti Perkin-Elmer v roce 1973. Dříve byly čipy vzorovány na povrch oplatky umístěním „masky“ na povrch a poté na ni zářily jasným světlem . Masky byly křehké a před opotřebením trvaly jen několik desítek aplikací. The Micralign systém promítal obraz z dálky, takže masky trvaly mnohem déle. To nezmenšilo velikost výsledných návrhů, ale znamenalo to, že výrobní linka mohla být provozována mnohem efektivněji, což snížilo náklady.[40]

Stávající výrobní linky MOS Technology byly založeny na starší technologii PMOS, s příchodem týmu ještě nezačaly pracovat s NMOS. Paivinen slíbil, že bude mít sestavu NMOS spuštěnou včas, aby zahájil výrobu nového CPU. Splnil svůj slib a nová linka byla připravena do června 1975.[41]

Poznámky k návrhu

Chuck Peddle, Rod Orgill a Wil Mathys navrhli počáteční architekturu nových procesorů. Článek ze září 1975 v EDN časopis dává toto shrnutí designu:[42]

Rodina MOS Technology 650X představuje vědomý pokus osmi bývalých zaměstnanců společnosti Motorola, kteří pracovali na vývoji systému 6800, vydat část, která by nahradila a předčila 6800, a přesto jej podprodala. S výhodou zpětného pohledu získaného na projektu 6800 provedl tým technologie MOS v čele s Chuckem Peddle následující architektonické změny v CPU Motorola…

Hlavní změnou, pokud jde o velikost čipu, bylo vyloučení tří stavů z výstupů adresní sběrnice. To bylo zahrnuto do 6800, aby bylo možné pracovat s jinými čipy v přímý přístup do paměti (DMA) a role společného zpracování za cenu významného prostoru matrice. V praxi vyžadovalo použití takového systému, aby ostatní zařízení byla podobně složitá, a designéři místo toho inklinovali ke koordinaci takového přístupu pomocí systémů mimo čip. Model 6502 jednoduše odstranil tuto funkci v souladu se svým designem jako levný řadič používaný pro konkrétní úkoly a komunikaci s jednoduchými zařízeními. Peddle navrhl, že kdokoli, kdo skutečně vyžadoval tento styl přístupu, jej mohl implementovat jediným 74158.[43]

Dalším velkým rozdílem bylo zjednodušení registrů. Za prvé, jeden ze dvou akumulátory byl odstraněn. K univerzálním registrům, jako jsou akumulátory, musí mít přístup mnoho částí dekodéru instrukcí, a proto vyžadují značné množství kabeláže pro přesun dat do az jejich úložiště. Dva akumulátory usnadňují mnoho úloh kódování, ale samotný design čipu stojí za značnou složitost.[42] Další úspory byly dosaženy snížením registr zásobníku od 16 do 8 bitů, což znamená, že zásobník mohl mít délku pouze 256 bajtů, což stačilo na jeho zamýšlenou roli mikrokontroléru.[42]

16bitový IX rejstřík rejstříku byl rozdělen na dvě části a stal se X a Y. Ještě důležitější je, že se změnil styl přístupu; v 6800 měl IX 16bitovou adresu, která byla kompenzována číslem dodaným s instrukcí, dva byly přidány k vytvoření konečné adresy. U 6502 (a většiny dalších návrhů) byla základní adresa uložena v instrukci a byla k ní přidána X nebo Y.[43]

Nakonec byla instrukční sada zjednodušena a uvolnila místo v dekodéru a řídicí logice. Z původních 72 pokynů v 6800 zůstalo 56. Mezi odstraněnými byla jakákoli instrukce, která přesunula data mezi dvěma akumulátory 6800, stejně jako řada instrukcí větví inspirovaných PDP-11 jako schopnost přímo porovnávat dvě číselné hodnoty. Model 6502 používal jednodušší systém, který zpracovával srovnání provedením matematiky na akumulátoru a poté zkoumáním příznaků výsledků.[43]

Konstrukce čipu na vysoké úrovni musela být přeměněna na výkresy tranzistorů a propojení. U technologie MOS byl „layout“ velmi manuální proces prováděný pomocí barevných tužek a pergamenového papíru. Rozložení sestávalo z tisíců mnohoúhelníkových tvarů na šesti různých výkresech; jeden pro každou vrstvu výrobního procesu. Vzhledem k omezení velikosti bylo nutné neustále zvažovat celý design čipu. Mench a Paivinen pracovali na dekodér instrukcí[44] zatímco Mench, Peddle a Orgill pracovali na ALU a registrech. Dalším pokrokem, který byl vyvinut na večírku, byl způsob, jak sdílet některé vnitřní kabely, aby bylo možné zmenšit velikost ALU.[45]

Navzdory jejich nejlepšímu úsilí byl konečný design příliš široký 5 mil.[46] Prvních 6502 čipů bylo 168 × 183 mil (4,3 × 4,7 mm)nebo o ploše 19,8 mm2. Instrukce rotace doprava (ROR) nefungovala v prvním křemíku, takže instrukce byla dočasně vynechána ze zveřejněných dokumentů, ale další iterace designu zmenšila čip a opravila instrukci rotace doprava, která byla poté zahrnuta do revidované dokumentace .[47]

Představujeme modely 6501 a 6502

Úvodní reklama na mikroprocesory MOS Technology MCS6501 a MCS6502

MOS by představil dva mikroprocesory založené na stejném základním designu: 6501 by se zapojil do stejné zásuvky jako Motorola 6800, zatímco 6502 znovu uspořádal vývod tak, aby podporoval hodinový oscilátor na čipu. Oba budou pracovat s dalšími podpůrnými čipy navrženými pro 6800. Nebudou spouštět software 6800, protože mají jinou sadu instrukcí, jiné registry a většinou různé režimy adresování.[48] Rod Orgill byl zodpovědný za design 6501; asistoval Johnu Buchananovi ve společnosti Motorola na 6800. Bill Mensch dělal 6502; byl konstruktérem adaptéru 6820 Peripheral Interface Adapter (PIA) ve společnosti Motorola. Harry Bawcom, Mike Janes a Sydney-Anne Holt pomohli s rozvržením.

Představení mikroprocesoru společnosti MOS Technology se lišilo od tradičního několikaměsíčního uvedení produktu na trh. První běh nového integrovaného obvodu se obvykle používá pro interní testování a sdílí se s vybranými zákazníky jako „technické vzorky“. Tyto čipy mají často menší konstrukční vadu nebo dvě, které budou opraveny před zahájením výroby. Cílem společnosti Chuck Peddle bylo prodat první běh čipů 6501 a 6502 účastníkům veletrhu Wescon v San Francisku od 16. září 1975. Peddle byl velmi efektivní mluvčí a mikroprocesory MOS Technology byly rozsáhle zahrnuty v obchodním tisku. Jedním z prvních byl celostránkový příběh o mikroprocesorech MCS6501 a MCS6502 ve vydání z 24. července 1975 Elektronika časopis.[49] Vběhly také příběhy EE Times (24. srpna 1975),[50] EDN (20. září 1975), Elektronické zprávy (3. listopadu 1975), Byte (Listopad 1975)[51] a Přehled mikropočítačů (Listopad 1975).[52] Reklamy na 6501 se objevily v několika publikacích první srpnový týden 1975. 6501 bude na prodej ve Wesconu po 20 $.[53] V září 1975 zahrnovaly reklamy jak mikroprocesory 6501, tak 6502. Model 6502 by stál jen 25 $ (ekvivalent 119 $ v roce 2019).[54]

Když společnost MOS Technology dorazila na Wescon, zjistili, že vystavovatelům není dovoleno prodávat cokoli na výstavní ploše. Pronajali si MacArthur Suite na Hotel St. Francis a nasměroval tam zákazníky k nákupu procesorů. V sadě byly procesory uloženy ve velkých nádobách, což naznačovalo, že čipy byly ve výrobě a snadno dostupné. Zákazníci nevěděli, že spodní polovina každé sklenice obsahuje nefunkční čipy.[55] Čipy byly 20 $ a 25 $, zatímco dokumentační balíček byl dalších 10 $. Uživatelé byli vyzváni, aby se fotokopie dokumentů, což je pro společnost MOS Technology levný způsob distribuce informací o produktu. Procesory měly mít 56 instrukcí, ale instrukce Rotate Right (ROR) na těchto čipech nefungovala správně, takže předběžné datové listy uváděly pouze 55 instrukcí. Recenze v Byte a EDN zaznamenal nedostatek instrukce ROR. Další revize rozložení tento problém vyřešila a datový list z května 1976 obsahoval 56 pokynů. Peddle chtěl, aby měl každý zainteresovaný technik a fanda přístup k čipům a dokumentaci; jiné polovodičové společnosti chtěly jednat pouze se „vážnými“ zákazníky. Například, Signetics představoval 2650 mikroprocesor a jeho reklamy požádaly čtenáře, aby napsali informace o jejich hlavičkovém papíru společnosti.[56]

MOS Technology MCS6502, v bílém keramickém obalu, vyrobený na konci roku 1975
Pinout rozdíly
Kolík680065016502
2StůjPřipravenPřipraven
3∅1 (v)∅1 (v)∅1 (out)
5Platná adresa pamětiPlatná adresa pamětiN.C.
7Autobus k dispoziciAutobus k dispoziciSYNC
36Povolení datové sběrnicePovolení datové sběrniceN.C.
37∅2 (v)∅2 (v)∅0 (v)
38N.C.N.C.Nastavit příznak přetečení
39Třístavová kontrolaN.C.∅2 (out)

Soudní spor společnosti Motorola

Datový list z května 1976 vynechal mikroprocesor 6501, který byl v Srpna 1975 verze.

Úvod 6501/6502 v tisku a na Wesconu byl obrovský úspěch. Nevýhodou bylo, že pozornost společnosti Motorola získala rozsáhlé zpravodajství. V říjnu 1975 společnost Motorola snížila cenu jediného 6800 mikroprocesoru ze 175 na 69 USD. Sada designu systému 300 $ byla snížena na 150 $ a nyní byla dodávána s deskou tištěných spojů.[57] 3. listopadu 1975 společnost Motorola požádala soudní příkaz, aby zastavil společnost MOS Technology ve výrobě a prodeji mikroprocesorových produktů. Rovněž podali žalobu na porušení patentu a zneužití obchodního tajemství. Společnost Motorola tvrdila, že sedm bývalých zaměstnanců se připojilo k MOS Technology za účelem výroby mikroprocesorových produktů této společnosti.[58]

Motorola byla miliardová společnost s věrohodným případem a právníky. 30. října 1974 podala společnost Motorola řadu patentových přihlášek na rodinu mikroprocesorů a bylo jí uděleno dvacet pět patentů. První byl v červnu 1976 a druhý byl Bill Mensch 6. července 1976, pro uspořádání čipu 6820 PIA. Tyto patenty se týkaly sběrnice 6800 a způsobu, jakým periferní čipy spolupracovaly s mikroprocesorem.[59] Společnost Motorola začala vyrábět tranzistory v roce 1950 a měla portfolio polovodičových patentů. Allen-Bradley se rozhodl nebojovat s tímto případem a prodal svůj zájem o MOS Technology zpět zakladatelům. V obleku byli jmenováni čtyři z bývalých inženýrů společnosti Motorola: Chuck Peddle, Will Mathys, Bill Mensch a Rod Orgill. Všichni byli jmenováni vynálezci v 6800 patentových přihláškách. Během procesu objevování Motorola zjistila, že jeden inženýr, Mike Janes, ignoroval Peddleovy pokyny a přinesl jeho 6800 návrhových dokumentů do MOS Technology.[60] V březnu 1976 se nyní nezávislé MOS Technology došly peníze a případ musel urovnat. Dohodli se, že upustí od procesoru 6501, zaplatí společnosti Motorola 200 000 dolarů a vrátí dokumenty, o nichž Motorola tvrdila, že jsou důvěrné. Obě společnosti souhlasily křížová licence mikroprocesorové patenty.[61] V květnu společnost Motorola snížila cenu jediného 6800 mikroprocesoru na 35 USD. Do listopadu Komodor získal technologii MOS.[62][63]

Počítače a hry

S právními problémy za sebou zůstal MOS problém přimět vývojáře, aby vyzkoušeli svůj procesor, což přimělo Chuck Peddle navrhnout MDT-650 („vývojový terminál mikropočítače“) jednodeskový počítač. Další skupina uvnitř společnosti navrhla KIM-1, který byl prodán jako polokompletní a mohl být přeměněn na použitelný systém s přidáním třetí strany počítačový terminál a kompaktní kazeta řídit. K jejich velkému úžasu se KIM-1 dobře prodával fandům a drotářům i inženýrům, na které byl zaměřen. Související Rockwell CÍL 65 systém řízení / školení / vývoje si vedl také dobře. Software v AIM 65 byl založen na softwaru v MDT. Dalším zhruba podobným produktem byl Synertek SYM-1.

Jedním z prvních „veřejných“ použití designu bylo Apple I. mikropočítač, představený v roce 1976. Model 6502 byl dále použit v Commodore PET a Apple II,[64] oba vydány v roce 1977. Později byl použit v 8bitová rodina Atari a Žalud Atom domácí počítače, BBC Micro,[64] Commodore VIC-20 a další designy pro domácí počítače i firmy, jako např Ohio Scientific a Oric. The 6510, přímý nástupce 6502 s digitálním I / O portem a trojstát adresový autobus, byl procesor využívány v nejprodávanějších[65][66] Commodore 64 domácí počítač. Ve všech Commodore byly použity procesory s variantou 6520 a / nebo 6502 disketa pohony pro všechny jejich 8bitové počítače, od řady PET (z nichž některé měly dva procesory založené na 6502), přes Commodore 128D, včetně Commodore 64, a ve všech diskových jednotkách Atari pro všechny jejich 8bitové počítačové linky , od 400/800 přes XEGS.

Další důležité využití rodiny 6500 bylo ve videohrách. První, kdo využil design procesoru, byl Atari VCS, později přejmenovaný na Atari 2600. VCS použil variantu 6502 nazvanou 6507, který měl méně pinů a ve výsledku dokázal oslovit pouze 8KB paměti. Byly by prodány miliony konzolí Atari, každá s procesorem MOS. Dalším významným využitím bylo Nintendo Entertainment System a Famicom. 6502 použitý v NES byl a druhý zdroj verze od Ricoh, částečný systém na čipu, který postrádal binárně kódované desetinné místo režim, ale přidáno 22 paměťově mapovaných registrů a hardwaru on-die pro generování zvuku, čtení joypadu a skřítek seznam DMA. Volala 2A03 v NTSC konzoly a 2A07 v KAMARÁD konzoly (rozdíl je dělič paměti poměr a vyhledávací tabulka pro vzorkovací frekvence zvuku), tento procesor byl vyroben výhradně pro Nintendo. The Atari Lynx používal 4 MHz verzi čipu 65SC02.

V 80. letech použil populární elektronický časopis Elektor / Elektuur procesor ve své vývojové desce mikroprocesoru Junior počítač.

Technický popis

6502 procesorová matrice. Pravidelná sekce vlevo je instrukce dekódující ROM, zdánlivě náhodná sekce uprostřed je logika řízení a vpravo jsou registry (nahoře) a ALU (dole). Připojení datové sběrnice jsou vpravo nahoře a adresní sběrnice vpravo a vpravo dole.[37]
Konfigurace 6502 Pin (40-Pin DIP )
MOS 6502 registrů
FEDCBA9876543210(bitová pozice, hex)
Hlavní registry
 AAkumulátor
Rejstříkové registry
 XX index
 YY index
00000001SSpřipínáček
Počítadlo programu
PCProgram Counter
Stavový registr
 NPROTI-BDZCP Příznaky procesoru

6502 je a malý Endian 8-bit procesor s a 16-bit adresní sběrnice. Původní verze byly vyrobeny pomocí 8 um[68] čip technologické technologie s reklamou velikost matrice z 153 mil × 168 mil (3,9 mm × 4,3 mm), nebo plochu 16,6 mm2.[37]

Interní logika běží stejnou rychlostí jako rychlost externích hodin, ale navzdory nízkým rychlostem hodin (obvykle v sousedství 1 až 2MHz ), výkon 6502 byl konkurenceschopný s jinými současnými CPU využívajícími výrazně rychlejší hodiny. To je částečně způsobeno jednoduchým stavovým strojem implementovaným pomocí kombinační (bez hodin) logika ve větší míře než v mnoha jiných provedeních; dvoufázové hodiny (dodávající dvě synchronizace na cyklus) tak mohou ovládat celek stroj-cyklujte přímo. Typické pokyny mohou na 6502 trvat o polovinu méně cyklů než na současných designech. Stejně jako většina jednoduchých procesorů té doby, dynamická NMOS Čip 6502 není sekvenován znakem a mikrokód ROM, ale používá a PLA (který zabíral asi 15% plochy čipu) pro dekódování a sekvenování instrukcí. Stejně jako ve většině 8bitových mikroprocesorů i u čipu dochází k omezenému překrývání načítání a provádění.

Nízká taktovací frekvence zmírnila požadavek na rychlost paměti a periferií připojených k CPU, protože pro přístup do paměti bylo k dispozici pouze asi 50% hodinového cyklu (kvůli asynchronnímu designu se tento zlomek mezi verzemi čipů výrazně lišil). To bylo kritické v době, kdy cenově dostupná paměť měla doby přístupu v rozsahu 250–450 ns.

Vzhledem k tomu, že čip přistupoval k paměti pouze během určitých částí hodinového cyklu a tyto cykly byly indikovány pinem PHI2-low clock-out, ostatní čipy v systému mohly přistupovat k paměti během těch časů, kdy byla 6502 mimo sběrnici. Toto bylo někdy známé jako „skrytý přístup“. Tato technika byla široce používána počítačovými systémy; oni by používali paměť schopnou přístupu na 2 MHz, a pak by spustili CPU na 1 MHz. Tím bylo zaručeno, že CPU a video hardware mohou prokládat své přístupy, přičemž celkový výkon odpovídá výkonu paměťového zařízení.[69] Když byly v 80. letech k dispozici rychlejší paměti, mohly novější stroje běžet při vyšších taktovacích rychlostech, jako 2 MHz CPU v BBC Micro a stále používat techniky sdílení sběrnice.

Registry

Stejně jako jeho předchůdce 6800, 6502 má jen velmi málo registry. Registry 6502 obsahují jeden 8bitový akumulátor registr (A), dva 8bitové rejstříky rejstříků (X a Y), 7 bity příznaku stavu procesoru (P), 8bitový ukazatel zásobníku (S) a 16bitové počítadlo programů (PC). To je srovnatelné s typickým designem stejné éry Z80, který má osm univerzálních 8bitových registrů, které lze kombinovat do čtyř 16bitových. Z80 měl také kompletní sadu alternativních registrů, které vytvářely celkem šestnáct univerzálních registrů.

Aby se do jisté míry vyrovnal nedostatek registrů, zahrnoval 6502 a nulová stránka režim adresování, který používá jeden adresní bajt v instrukci namísto dvou potřebných k adresování plných 64 kB paměti. To poskytuje rychlý přístup k prvním 256 bajtům RAM pomocí kratších pokynů. Chuck Peddle v rozhovorech uvedl, že konkrétním záměrem bylo umožnit, aby těchto prvních 256 bajtů RAM bylo použito jako registry.[Citace je zapotřebí ]

Adresní prostor zásobníku je pevně zapojený na stránku paměti $01, tj. rozsah adres $0100$ 01FF (256511). Softwarový přístup do zásobníku se provádí pomocí čtyř implicitních pokynů režimu adresování, jejichž funkcí je tlačit nebo vysouvat (vytahovat) akumulátor nebo stavový registr procesoru. Stejný zásobník se také používá pro volání podprogramu pomocí instrukcí JSR (skok na podprogram) a RTS (návrat z podprogramu) a pro přerušit zacházení.

Adresování

Čip efektivně využívá registry indexů a zásobníků s několika režimy adresování, včetně rychlého režimu „přímé stránky“ nebo „nulové stránky“, podobného režimu, který se nachází na webu PDP-8, který přistupuje k paměťovým místům z adres 0 až 255 s jedinou 8bitovou adresou (uložení cyklu, který je běžně vyžadován k načtení bajtu vyššího řádu adresy) - kód pro 6502 používá nulovou stránku stejně jako kód pro jiné procesory používat registry. Na některých mikropočítačích založených na 6502 s operačním systémem se operační systém používá většinu nulové stránky a uživateli ponechává jen hrstku míst.

Režimy adresování také zahrnují implicitní (1bajtové pokyny); absolutní (3 bajty); indexováno absolutně (3 bajty); indexovaná nulová stránka (2 bajty); relativní (2 bajty); akumulátor (1); nepřímý, x a nepřímý, r (2); a bezprostřední (2). Absolutní režim je režim pro všeobecné účely. Pokyny větve používají 8bitový offset se znaménkem vzhledem k instrukci po větvi; číselný rozsah −128..127 se tedy překládá na 128 bajtů zpět a 127 bajtů vpřed od instrukce následující po větvi (což je 126 bajtů dozadu a 129 bajtů dopředu od začátku instrukce větve). Režim akumulátoru používá akumulátor jako efektivní adresu a žádný nepotřebuje operand data. Okamžitý režim používá 8bitový doslovný operand.

Nepřímé adresování

Nepřímé režimy jsou užitečné pro pole zpracování a další smyčky. V režimu 5/6 „(nepřímý), y“ je 8bitový registr Y přidán k 16bitové základní adrese čtené z nulové stránky, která je umístěna jediným bajtem za opkódem. Registr Y je tedy index zaregistrujte se v tom smyslu, že se používá k uchování skutečného index (na rozdíl od registru X v 6800, kde byla přímo uložena základní adresa a ke kterému lze přidat okamžitý offset). Přírůstek indexového registru k procházení pole po bajtech trvá jen dva další cykly. V méně často používaném režimu „(nepřímý, x)“ je efektivní adresa operace nalezena na adrese nulové stránky vytvořené přidáním druhého bajtu instrukce k obsahu registru X. Při použití indexovaných režimů funguje nulová stránka jako sada až 128 dalších (i když velmi pomalých) registrů adres.

6502 je schopen provádět sčítání a odčítání v binárním nebo binárně kódované desetinné místo. Uvedení CPU do režimu BCD pomocí SED Výsledkem instrukce (příznak D) je dekadická aritmetika, ve které $99 + $01 by mělo za následek $00 a nastaven příznak carry (C). V binárním režimu (CLD, vymazat příznak D), výsledkem by byla stejná operace 9 $ a vynulovaná vlajka. Jiný než Atari BASIC Režim BCD se zřídka používal v aplikacích pro domácí počítače.

Viz Ahoj světe! článek pro jednoduchý, ale charakteristický příklad 6502 montážní jazyk.

Pokyny a operační kódy

6502 instrukce provozní kódy (opcodes) jsou osmibitové a mají obecnou formu AAABBBCC, kde AAA a CC definují operační kód a BBB definuje režim adresování.[70]

Zvažte například ORA instrukce, která provede bitové NEBO na bitech v akumulátoru s jinou hodnotou. Operační kód instrukce má tvar 000bbb01, kde bbb může být 010 pro hodnotu okamžitého režimu (konstanta), 001 pro pevnou adresu nulové stránky, 011 pro absolutní adresu atd.[70]

Tento vzor není absolutní a existuje řada výjimek. Kde to však platí, umožňuje snadno dekonstruovat hodnoty opcode zpět do mnemotechnických pomůcek pro většinu instrukcí a zpracovávat okrajové případy speciálním kódem.[70]

Z 256 možných operačních kódů dostupných pomocí 8bitového vzoru používá původní 6502 151 z nich, uspořádaných do 56 instrukcí s (případně) více režimy adresování. V závislosti na režimu instrukce a adresování může operační kód vyžadovat pro operandy nulu, jeden nebo dva další bajty. Proto se 6502 strojové instrukce liší v délce od jednoho do tří bajtů.[71][72] Operand je uložen obvyklým způsobem u 6502 Little-endian formát.

The 65C816 16bitový CMOS potomek 6502, také podporuje 24-bitové adresování, což má za následek sestavení instrukcí s tříbajtovými operandy, také uspořádanými ve formátu little-endian.

Zbývajících 105 kódů není definováno. V původním návrhu, pokyny, kde 4-bitů nízkého řádu (okusovat) nebyly 3, 7, B nebo F nebyly použity, což poskytlo prostor pro budoucí rozšíření. Stejně tak sloupec $ 2xxx měl pouze jednu položku, LDX #konstantní. Zbývajících 25 prázdných slotů bylo rozdáno. Některé z prázdných slotů byly použity v 65C02 k poskytnutí jak nových instrukcí, tak i variant stávajících s novými režimy adresování. Pokyny $ Fxxx byly zpočátku ponechány volné, aby dodavatelům třetích stran mohli přidávat vlastní pokyny, ale novější verze 65C02 standardizovaly sadu trochu pohrávat pokyny vyvinuté Rockwell Semiconductor.

Montážní jazyk

6502 montážní jazyk příkaz se skládá ze tří znaků mnemotechnická pomůcka, následovaný jakýmkoli operandy. Pokyny, které neberou samostatný operand, ale zacílují na jeden registr na základě režimu adresování, kombinují cílový registr v mnemotechnické instrukci, takže assembler používá INX naproti tomu INC X ke zvýšení registru X.

Instruktážní tabulka

Detailed behavior

The processor's non-maskable interrupt (NMI) input is edge sensitive, which means that the interrupt is triggered by the falling edge of the signal rather than its level. The implication of this feature is that a wired-OR interrupt circuit is not readily supported. However, this also prevents nested NMI interrupts from occurring until the hardware makes the NMI input inactive again, often under control of the NMI obsluha přerušení.

The simultaneous assertion of the NMI and IRQ (maskable) hardware interrupt lines causes IRQ to be ignored. However, if the IRQ line remains asserted after the servicing of the NMI, the processor will immediately respond to IRQ, as IRQ is level sensitive. Thus a sort of built-in interrupt priority was established in the 6502 design.

The "Break" flag of the processor is very different from the other flag bits. It has no flag setting, resetting, or testing instructions of its own, and is not affected by the PHP and PLP instructions. It exists only on the stack, where BRK and PHP always write a 1, while IRQ and NMI always write a 0.

The "SO" input pin, when asserted, will set the processor's overflow status bit (deasserting it does not clear the overflow bit, however). This can be used by a high-speed hlasování device driver, which can poll the hardware once in only three cycles by using a Branch-on-oVerflow-Clear (BVC) instruction that branches to itself. Například Commodore 1541 a další Komodor disketa drives use this technique to detect without delay whether the serializer is ready to accept or provide another byte of disk data. Obviously great care must be used in the device driver and the associated system design, as spurious assertion of the overflow bit could ruin arithmetic processing.

Variations and derivatives

There were numerous variants of the NMOS 6502:

  • The MOS Technology 6503 had reduced memory addressing capability (4 KB) and no RDY input, in a 28-pin DIP package (with the phase 1 (OUT), SYNC, redundant Vss, and SO pins of the 6502 also omitted).[73]
  • The MOS Technology 6504 had reduced memory addressing capability (8 KB), no NMI, and no RDY input, in a 28-pin DIP package (with the phase 1 (OUT), SYNC, redundant Vss, and SO pins of the 6502 also omitted).[73]
  • The MOS Technology 6505 had reduced memory addressing capability (4 KB) and no NMI, in a 28-pin DIP package (with the phase 1 (OUT), SYNC, redundant Vss, and SO pins of the 6502 also omitted).[73]
  • The MOS Technology 6506 had reduced memory addressing capability (4 KB), no NMI, and no RDY input, but all 3 clock pins of the 6502 (i.e. a 2-phase output clock), in a 28-pin DIP package (with the SYNC, redundant Vss, and SO pins of the 6502 also omitted).[73]
  • The Technologie MOS 6507 had reduced memory addressing capability (8 KB) and no interrupts, in a 28-pin DIP package (with the phase 1 (OUT), SYNC, redundant Vss, and SO pins of the 6502 also omitted).[73] This chip was used in the Atari 2600 video game system.
  • The Technologie MOS 6508 has a built-in 8-bit input/output port and 256 bytes of internal static RAM.
  • The Technologie MOS 6509 could address up to 1 MB of RAM as 16 banks of 64 KB and was used in the Commodore CBM-II série.
  • The Technologie MOS 6510 has a built-in 6-bit programmable input/output port and was used in the Commodore 64.
  • The MOS Technology 6512 was a 6502 with a 2-phase clock input for an external clock oscillator, instead of an on-board clock oscillator.[73]
  • The MOS Technology 6513 was a 6503 with a 2-phase clock input like the 6512.[73]
  • The MOS Technology 6514 was a 6504 with a 2-phase clock input like the 6512.[73]
  • The MOS Technology 6515 was a 6505 with a 2-phase clock input like the 6512.[73]
  • The Ricoh 2A03 was a 6502 variant including an audio processing unit and lacking the BCD mode, used in the Zábavní systém Nintendo.
  • The 6502A was a 1.5 MHz chip featured in Asteroids Deluxe.
  • The 6502B was a version of the 6502 capable of running at a maximum speed of 2 MHz instead of 1. The B was used in the Apple III, BBC Micro and, clocked at 1.79 MHz, early Atari 8-bit computers
  • The “official” 6502C was a version of the original 6502 able to run at up to 4 MHz.
  • The Sally, also referred to the 6502C, was a customized 6502 chip used in later Atari 8-bit computers. It has a HALT signal on pin 35 and a second R/W on pin 36 (these pin are not connected (N/C) on a standard 6502s). Pulling HALT low latches the clock, pausing the processor. This was used to sync the CPU with the video circuitry.
  • The MOS Technology 6591 and 6592 are Systém na čipu that utilize a complete Atari 2600 in a 48-pin DIP package.[74][75]
  • The 65C02 je CMOS version of the NMOS 6502 that was designed by Bill Mensch z Western Design Center (WDC), featuring reduced power consumption, support for much higher clock speeds, new instructions, new addressing modes for some existing instructions, and correction of NMOS errata, such as the JMP ($xxFF) bug.
  • The 65SC02 is a variant of the WDC 65C02 without individual bit manipulation operations (RMB, SMB, BBR and BBS).[76] This core, running at 4 MHz, was used in the Atari Lynx 's main system IC.
  • CSG 65CE02 was a CMOS derivative developed by the Commodore Semiconductor Group (CSG), formerly MOS Technology.
  • The Rockwell R6511Q (and R6500/11, R6500/12, R6500/15 "One-Chip Microcomputers") are enhanced versions of the 6502-based processor, also including individual bit manipulation operations (RMB, SMB, BBR and BBS), on-chip 192 byte zero-page RAM, UART, atd.[77][78]
  • The Rockwell R65F11 (introduced in 1983) and the later R65F12 are enhanced versions of the 6502-based processor, also including individual bit manipulation operations (RMB, SMB, BBR and BBS), on-chip zero-page RAM, on-chip Forth kernel ROM, a UART, etc.[79][80][81][82][83]
  • The GTE G65SC102 is software compatible with the 65C02, but has a slightly different pinout and oscillator circuit. The BBC Master Turbo included the 4 MHz version of this CPU on a coprocessor card, which could also be bought separately and added to the Master 128.
  • The Rockwell R65C00, R65C21, and R65C29 featured two enhanced CMOS 6502s in a single chip, and the R65C00 and R65C21 additionally contained 2 kB of mask-programmable ROM.[84][85]
  • The CM630 is a 1 MHz Východní blok clone of the 6502 and was used in the Pravetz 8A and 8C, Bulgarian clones of the Apple // série[86].
  • The Technologie MOS 8502 was designed by MOS Technology and used in the Commodore 128. Based on the MOS 6510 used in the Commodore 64, the 8502 was able run at double clock rate of the 6510.[87] The 8502 family also includes the MOS 7501, 8500 and 8501.
  • The HuC6280 is Japanese video game company Hudson Soft 's improved version of the WDC 65C02 manufactured for them by Seiko Epson a NEC pro SuperGrafx. The most notable product using the HuC6280 is NEC's TurboGrafx-16 video game console.

6512, 6513, 6514, & 6515

The MOS Technology 6512, 6513, 6514, and 6515 each rely on an external clock, instead of using an internal clock generator like the 650x (e.g. 6502). This was used to advantage in some designs where the clocks could be run asymmetrically, increasing overall CPU performance.

The 6512 was used in the BBC Micro B+64.

16-bit derivatives

The Western Design Center designed and currently produces the W65C816S processor, a 16-bit, static-core successor to the 65C02, with greatly enhanced features. The W65C816S is a newer variant of the 65C816, which was the core of the Apple IIGS computer and was the basis of the Ricoh 5A22 processor that powered the popular Super Nintendo Entertainment System. The W65C816S incorporates minor improvements over the 65C816 that make the newer chip not an exact hardware-compatible replacement for the earlier one. Among these improvements was conversion to a static core, which makes it possible to stop the clock in either phase without the registers losing data. Available through electronics distributors, as of March 2020, the W65C816S is officially rated for 14 MHz operation.

The Western Design Center also designed and produced the 65C802, which was a 65C816 core with a 64-kilobyte address space in a 65(C)02 pin-compatible package. The 65C802 could be retrofitted to a 6502 board and would function as a 65C02 on power-up, operating in "emulation mode." As with the 65C816, a two-instruction sequence would switch the 65C802 to "native mode" operation, exposing its 16-bit akumulátor a rejstříky rejstříků, as well as other 65C816 enhanced features. The 65C802 was not widely used; new designs almost always were built around the 65C816, resulting in 65C802 production being discontinued.

Příklad kódu

The following 6502 montážní jazyk zdrojový kód is for a subroutine named TOLOWER, which copies a zakončeno nulou character string from one location to another, converting upper-case letter characters to lower-case letters. The string being copied is the "source", and the string into which the converted source is stored is the "destination".

           0080 0080  00 040082  00 05 0600 0600  A0 00 0602  B1 800604  F0 11 0606  C9 410608  90 06 060A  C9 5B060C  B0 02 060E  09 20 0610  91 820612  C8   0613  D0 ED    0615  38   0616  60 0617  91 820618  18   0619  60 061A
; TOLOWER:;; Convert a null-terminated character string to all lower case.; Maximum string length is 255 characters, plus the null term-; inator.;; Parameters:;; SRC - Source string address; DST - Destination string address;        ORG $0080;SRC     .WORD $0400     ;source string pointer ($40)DST     .WORD $0500     ;destination string pointer ($42);        ORG $0600       ;execution start address;TOLOWER LDY #$00        ;starting index;SMYČKA    LDA (SRC),Y     ;get from source string        BEQ HOTOVO        ;end of string;        CMP #'A'        ;if lower than UC alphabet...        BCC PŘESKOČIT        ;copy unchanged;        CMP #„Z“+1      ;if greater than UC alphabet...        BCS PŘESKOČIT        ;copy unchanged;        ORA #%00100000  ;convert to lower case;PŘESKOČIT    STA (DST),Y     ;store to destination string        INY             ;bump index        BNE SMYČKA        ;next character;; NOTE: If Y wraps the destination string will be left in an undefined; Stát. We set carry to indicate this to the calling function.;        SEK             ;report string too long error &...        RTS             ;return to caller;HOTOVO    STA (DST),Y     ;terminate destination string        CLC             ;report conversion completed &...        RTS             ;return to caller;        .END

Bugs and quirks

The 6502 had several hmyz and quirks, which had to be accounted for when programming it:

  • The earliest revisions of the 6502, such as those shipped with some KIM-1 computers, had a severe bug in the ROR (rotate right memory or accumulator) instruction. The operation of ROR in these chips is effectively an ASL (arithmetic shift left) instruction that does not affect the carry bit in the status register. MOS left the instruction out of chip documentation entirely because of the defect, promising that ROR would appear on 6502 chips starting in 1976.[88] The vast majority of 6502 chips in existence today do not exhibit this bug.
  • The NMOS 6502 family has a variety of undocumented instructions, which vary from one chip manufacturer to another. The 6502 instruction decoding is implemented in a pevně zapojený logic array (similar to a programovatelné logické pole ) that is only defined for 151 of the 256 available opcodes. The remaining 105 trigger strange and occasionally hard-to-predict actions, such as crashing the processor, performing two valid instructions consecutively, performing strange mixtures of two instructions, or simply doing nothing at all. Eastern House Software developed the "Trap65", a device that plugged between the processor and its socket to convert (trap) unimplemented opcodes into BRK (software interrupt) instructions.[Citace je zapotřebí ] Some programmers utilized this feature to extend the 6502 instruction set by providing functionality for the unimplemented opcodes with specially written software intercepted at the BRK instruction's 0xFFFE vector.[89][90] All of the undefined opcodes have been replaced with NOP instructions in the 65C02, an enhanced CMOS version of the 6502, although with varying byte sizes and execution times. V 65C802/65C816, all 256 opcodes perform defined operations.
  • The 6502's memory indirect jump instruction, JMP (
    ), is partly broken. Li <address> je hex xxFF (i.e., any word ending in FF), the processor will not jump to the address stored in xxFF a xxFF+1 as expected, but rather the one defined by xxFF a xx00 (například, JMP ($10FF) would jump to the address stored in 10FF and 1000, instead of the one stored in 10FF and 1100). This defect continued through the entire NMOS line, but was corrected in the CMOS derivatives.
  • The NMOS 6502 indexed addressing across page boundaries will do an extra read of an invalid address. This characteristic may cause random issues by accessing hardware that acts on a read, such as clearing timer or IRQ flags, sending an I/O handshake, etc. This defect continued through the entire NMOS line, but was corrected in the CMOS derivatives, in which the processor does an extra read of the last instruction byte.
  • The 6502 read-modify-write instructions perform one read and two write cycles. First, the unmodified data that was read is written back, and then the modified data is written. This characteristic may cause issues by twice accessing hardware that acts on a write. This anomaly continued through the entire NMOS line, but was fixed in the CMOS derivatives, in which the processor will do two reads and one write cycle. Obranné programování practice will generally avoid this problem by not executing read/modify/write instructions on hardware registers.
  • The N (result negative), V (sign bit overflow) and Z (result zero) status flags are generally meaningless when performing arithmetic operations while the processor is in BCD mode, as these flags reflect the binary, not BCD, result. This limitation was removed in the CMOS derivatives. Therefore, this feature may be used to distinguish a CMOS processor from an NMOS version.[91]
  • If the 6502 happens to be in BCD mode when a hardware interrupt occurs, it will not revert to binary mode. This characteristic could result in obscure bugs in the interrupt service routine if it fails to clear BCD mode before performing any arithmetic operations. Například Commodore 64 je KERNAL did not correctly handle this processor characteristic, requiring that IRQs be disabled or re-vectored during BCD math operations. This issue was addressed in the CMOS derivatives as well.
  • The 6502 instruction set includes BRK (opcode $00), which is technically a software interrupt (similar in spirit to the SWI mnemonic of the Motorola 6800 a PAŽE processors). BRK is most often used to interrupt program execution and start a machine language monitor for testing and debugging during software development. BRK could also be used to route program execution using a simple jump table (analogous to the manner in which the Intel 8086 and derivatives handle software interrupts by number). Unfortunately, if a hardware interrupt occurs when the processor is fetching a BRK instruction, the NMOS version of the processor will fail to execute BRK and instead proceed as if only a hardware interrupt had occurred. This fault was corrected in the CMOS implementation of the processor.
  • When executing JSR (jump to subroutine) and RTS (return from subroutine) instructions, the return address pushed to the stack by JSR is that of the last byte of the JSR operand (that is, the most significant byte of the subroutine address), rather than the address of the following instruction. This is because the actual copy (from počítadlo programů na zásobník and then conversely) takes place before the automatic increment of the program counter that occurs at the end of every instruction.[92] This characteristic would go unnoticed unless the code examined the return address in order to retrieve parameters in the code stream (a 6502 programming idiom documented in the ProDOS 8 Technical Reference Manual). It remains a characteristic of 6502 derivatives to this day.

Viz také

Poznámky

  1. ^ At that time the technical literature would state the length and width of each chip in "mils" (0.001 inch).

Reference

Citace

  1. ^ "The MOS 6502 and the Best Layout Guy in the World". swtch.com. 2011-01-03. Citováno 2014-08-09.
  2. ^ "MOnSter6502". monster6502.com. 2017. Citováno 2017-05-01.
  3. ^ William Mensch, Rob Walker (October 9, 1995). Interview with William Mensch (Webové video). Atherton, California: Silicon Genesis, Stanford University Libraries. Archivovány od originál dne 14. května 2012. Citováno 4. června 2012. William Mensch and the moderator both pronounce the 6502 microprocessor as "sixty-five-oh-two".
  4. ^ "Western Design Center (WDC) Home of 65xx Microprocessor Technology". www.westerndesigncenter.com. Citováno 2019-04-08.
  5. ^ "Motorola Sues MOS Technology" (PDF). Microcomputer Digest. Cupertino CA: Microcomputer Associates. 2 (6): 11. December 1975.
  6. ^ "Motorola joins microprocessor race with 8-bit entry". Elektronika. New York: McGraw-Hill. 47 (5): 29–30. March 7, 1974.
  7. ^ Motorola 6800 Oral History (2008), p. 9
  8. ^ Buchanan, John K., "MOS DC Voltage booster circuit", US Patent 3942047, issued March 2, 1976.
  9. ^ Buchanan, John K., "Chip topography for MOS integrated circuitry microprocessor chip", US Patent 3987418, issued October 19, 1976.
  10. ^ Motorola 6800 Oral History (2008), p. 8
  11. ^ Mensch Oral History (1995) Mensch earned an Associate degree from Temple University in 1966 and then worked at Philco Ford as an electronics technician before attending the University of Arizona.
  12. ^ Mensch, William D., "Chip topography for MOS interface circuit", US Patent 3968478, issued July 6, 1976.
  13. ^ Jenkins, Francis; Lane, E.; Lattin, W.; Richardson, W. (November 1973). "MOS-device modeling for computer implementation". IEEE Transactions on Circuit Theory. IEEE. 20 (6): 649–658. doi:10.1109/tct.1973.1083758. ISSN  0018-9324. All of the authors were with Motorola's Semiconductor Products Division.
  14. ^ Donohue, James F. (October 27, 1988). "The microprocessor first two decades: The way it was". EDN. Cahners Publishing. 33 (22A): 18–32. ISSN  0012-7515. Page 30. Bennett already was at work on what became the 6800. "He hired me," Peddle says of Bennett, "to do the architectural support work for the product he'd already started." … Peddle says. "Motorola tried to kill it several times. Without Bennett, the 6800 would not have happened, and a lot of the industry would not have happened, either."
  15. ^ Hepworth, Edward C., Rodney J. Means, Charles I. Peddle, "Asynchronous Communication Interface Adaptor", Patent 3975712, issued August 17, 1976. Note: Motorola typically listed inventors in alphabetical order.
  16. ^ Motorola (August 5, 1976). "They stay out front with Motorola's M6800 Family". Elektronika. McGraw-Hill. 49 (16): 51. Advertisement showing three embedded applications from TRW, HP and RUSCO.
  17. ^ Motorola 6800 Oral History (2008), p. 89
  18. ^ "It's the total product family". Elektronika. New York: McGraw Hill. 48 (1): 37. January 9, 1975. Motorola advertisement emphasizing their complete set of peripheral chips and development tools. This shorten the customers product design cycle.
  19. ^ Motorola 6800 Oral History (2008) p. 18
  20. ^ "Motorola microprocessor set is 1 MHz n-MOS". Control Engineering. 21 (11): 11. November 1974. MC6800 microprocessor price was $360. The MC6850 asynchronous communications interface adaptor (ACIA) was slated for first quarter 1975 introduction.
  21. ^ Intel Corporation (1984). Kaye, Glynnis Thompson (ed.). A Revolution in Progress - A History to Date of Intel (PDF). Intel Corporation. p. 14. Order number:231295. Archivováno (PDF) z původního dne 23. října 2012. Citováno 30. prosince 2016. "Shima implemented the 8080 in about a year and the new device was introduced in April 1974 for $360."
  22. ^ "Motorola mounts M6800 drive". Elektronika. New York: McGraw-Hill. 48 (8): 25. April 17, 1975. "Distributors are being stocked with the M6800 family, and the division is also offering an introductory kit that includes the family's six initial parts, plus applications and programming manuals, for $300."
  23. ^ Interview 2014, 52:30.
  24. ^ Interview 2014, 54:45.
  25. ^ Bagnall (2010), p. 11. Peddle's new offer came at an opportune time for the 6800 developers. "They didn't want to go to Austin, Texas," explains Mensch.
  26. ^ Interview 2014, 54:40.
  27. ^ Interview 2014, 55:50.
  28. ^ Waller, Larry (November 13, 1975). "Motorola seeks to end skid". Elektronika. New York: McGraw-Hill. 48 (23): 96–98. Summary: Semiconductor Products split into two parts, integrated circuits and discrete components. Semiconductor losses for the last four quarters exceeded $30 million. The sales organization lost its sensitivity to customer needs, "delays in responding to price cuts meant that customers bought elsewhere." Technical problems plagued IC production. The troubles are "not in design, but in chip and die yields." Problems have been solved. The MC6800 microprocessor "arrived in November 1974."
  29. ^ Interview 2014, 56:30.
  30. ^ Interview 2014, 55:00.
  31. ^ Bagnall (2010), p. 13.
  32. ^ MOS Technology (November 14, 1974). "The First Single Chip Scientific Calculator Arrays". Elektronika. McGraw-Hill. 47 (23): 90–91.
  33. ^ Interview 2014, 57:00.
  34. ^ Interview 2014, 58:30.
  35. ^ Ho, Joshua (9 October 2014). "An Introduction to Semiconductor Physics, Technology, and Industry". Anandtech.
  36. ^ Motorola 6800 Oral History (2008), p. 10.
  37. ^ A b C Cushman 1975, str. 40.
  38. ^ "8080A microprocessor - DIP 40 package". Svět CPU.
  39. ^ A b Cushman 1975, str. 38.
  40. ^ "Moore's Law Milestones". IEEE.
  41. ^ Bagnall (2010), p. 19: "Paivinen promised Peddle he would have the n-channel process ready. He was true to his word."
  42. ^ A b C Cushman 1975, str. 36.
  43. ^ A b C Cushman 1975, str. 41.
  44. ^ Interview 2014, 1:01:00.
  45. ^ Interview 2014, 1:02:00.
  46. ^ Interview 2014, 1:02:30.
  47. ^ The August 1975 datasheet had 55 instructions with no ROR, the May 1976 datasheet had the ROR and 56 instructions. File:MCS650x Instruction Set.jpg
  48. ^ Stanford University, Silicon Genesis project: videotaped oral history interview of Willam Mensch
  49. ^ "Microprocessor line offers 4, 8, 16 bits". Elektronika. New York: McGraw-Hill. 48 (15): 118. July 24, 1975. The article covers the 6501 and 6502 plus the 28 pin versions that would only address 4K of memory. It also covered future devices such as "a design that Peddle calls a pseudo 16".
  50. ^ Sugarman, Robert (25 August 1975). "Does the Country Need A Good $20 Microprocessor?" (PDF). EE Times. Manhasset, New York: CMP Publications: 25. Archived from originál (PDF) dne 3. února 2007. Citováno 5. února 2008.
  51. ^ Fylstra, Daniel (Listopad 1975). "Son of Motorola (or the $20 CPU Chip)". Byte. Peterborough, NH: Green Publishing. 1 (3): 56–62. Comparison of the 6502 and the 6800 microprocessors. Author visited MOS Technology in August 1975.
  52. ^ "3rd Generation Microprocessor" (PDF). Microcomputer Digest. Cupertino, CA: Microcomputer Associates. 2 (2): 1–3. Srpna 1975.
  53. ^ "MOS 6501 Microprocessor beats 'em all". Elektronika. New York: McGraw-Hill. 48 (16): 60–61. August 7, 1975.
  54. ^ „MOS 6502 je druhý z rodiny nízkonákladových vysoce výkonných mikroprocesorů“. Počítač. IEEE Computer Society. 8 (9): 38–39. Září 1975. doi:10.1109 / C-M.1975.219074.
  55. ^ Bagnall (2010), pp. 33–35.
  56. ^ Signetics (October 30, 1975). "Easiest-to-use microprocessor". Elektronika. McGraw-Hill. 48 (22): 114–115.
  57. ^ Motorola (October 30, 1975). "All this and unbundled $69 microprocessor". Elektronika. McGraw-Hill. 48 (22): 11. The quantity one price for the MC6800 was reduced from $175 to $69. The previous price for 50 to 99 units was $125.
  58. ^ Waller, Larry (November 13, 1975). "News briefs: Motorola seeks to stop microprocessor foe". Elektronika. New York: McGraw-Hill. 48 (23): 38."Motorola said last week it would seek an immediate injunction to stop MOS Technology Inc., Norristown, Pa., from making and selling microprocessor products, including its MCS6500." (This issue was published on November 7.)
  59. ^ Motorola was awarded the following US Patents on the 6800 microprocessor family: 3962682, 3968478, 3975712, 3979730, 3979732, 3987418, 4003028, 4004281, 4004283, 4006457, 4010448, 4016546, 4020472, 4030079, 4032896, 4037204, 4040035, 4069510, 4071887, 4086627, 4087855, 4090236, 4145751, 4218740, 4263650.
  60. ^ Bagnall (2010), p. 53–54. "He [Mike James] had all his original work from the 6800 and hid it from Motorola…
  61. ^ "Motorola, MOS Technology settle patent suit". Elektronika. New York: McGraw-Hill. 49 (7): 39. April 1, 1975. "MOS Technology Inc. of Norristown, Pa. has agreed to withdraw its MCS6501 microprocessor from the market and to pay Motorola Inc. $200000 ..." "MOS Technology and eight former Motorola employees have given back, under court order documents that Motorola contends are confidential." "…both companies have agreed to a cross license relating to patents in the microprocessor field."
  62. ^ Bagnall (2010), pp. 55-56
  63. ^ "Mergers and Acquisitions". Mini-Micro Systems. Cahners. 9 (11): 19. November 1976." Commodore International … is buying MOS Technology (Norristown, PA). This saves the six-year-old semiconductor house from impending disaster."
  64. ^ A b Goodwins, Rupert (December 4, 2010). "Intel's victims: Eight would-be giant killers". ZDNet. Citováno 7. března 2012.
  65. ^ Reimer, Jeremy. "Personal Computer Market Share: 1975-2004". Archivovány od originál dne 6. června 2012. Citováno 2009-07-17.
  66. ^ "How many Commodore 64 computers were sold?". Archivovány od originál dne 06.03.2016. Citováno 2011-02-01.
  67. ^ "Code Execution on a Tamagotchi". kwartzlab.ca. 7. května 2013. Archivovány od originál on 2018-08-31. Citováno 2018-12-23.
  68. ^ Corder, Mike (Spring 1999). "Big Things in Small Packages". Pioneers' Progress with picoJava Technology. Sun Microelectronics. Archivovány od originál dne 12. 3. 2006. Citováno 23. dubna 2012. The first 6502 was fabricated with 8 micron technology, ran at one megahertz and had a maximum memory of 64k.
  69. ^ "How to implement bus sharing / DMA on a 6502 system".
  70. ^ A b C Parker, Neil. "The 6502/65C02/65C816 Instruction Set Decoded". Neil Parker's Apple II page.
  71. ^ 6502 Instruction Set.
  72. ^ NMOS 6502 Opcodes Archivováno 2016-01-14 at the Wayback Machine.
  73. ^ A b C d E F G h i 1982 MOS Technology Data Catalog (PDF obtained from bitsavers.org)
  74. ^ AtariAge: A2600 clone, 6591 chip pinout
  75. ^ Hackaday: The teensiest Atari 2600 ever
  76. ^ Zaks, Rodnay. Programming the 6502. p. 348.
  77. ^ "Rockwell R6511Q". Citováno 30.dubna 2020.
  78. ^ "Rockwell R6500/11, R6500/12 and R6500/15 One-Chip Microcomputers". 7 Jun 1987. Citováno 30.dubna 2020.
  79. ^ Randy M. Dumse."The R65F11 and F68K Single-Chip Forth Computers".[1][trvalý mrtvý odkaz ][2] Archivováno 2014-12-02 at the Wayback Machine 1984.
  80. ^ Ed Schmauch."A Computerized Corrosion Monitoring System"[trvalý mrtvý odkaz ].1986.
  81. ^ Lawrence P. Forsley."Embedded systems: 1990 Rochester Forth Conference : June 12 - 16th, 1990 University of Rochester".p. 51.
  82. ^ Rockwell."RSC-Forth User's Manual".1983.
  83. ^ "Rockwell R65F11 R65F12 Forth Based Microcomputers" (PDF). Červen 1987. Citováno 28.dubna 2020.
  84. ^ „Archivovaná kopie“ (PDF). Archivovány od originál (PDF) on 2016-05-15. Citováno 2014-10-26.CS1 maint: archivovaná kopie jako titul (odkaz)
  85. ^ "rockwell :: dataBooks :: 1985 Rockwell Data Book" - prostřednictvím internetového archivu.
  86. ^ "East-European Home-Computer: Bulgaria". HCM: Home Computer Museum. Citováno 3. října 2020.
  87. ^ Service Manual C-128/C128D Computer, Commodore Business Machines, PN-314001-08, November 1987
  88. ^ "Measuring the ROR Bug in the Early MOS 6502". Citováno 8. května 2011.
  89. ^ Moser, Carl W. (January 1979). "Add a Trap Vector for Unimplemented 6502 Opcodes" (PDF). Dr. Dobb's Journal of Computer Calisthenics and Orthodontia. No. 31. Menlo Park, California. p. 32. Citováno 2017-01-07.
  90. ^ Harrod, Dennette A. (October 1980). "The 6502 Gets Microprogrammable Instructions". BYTE. Sv. 5 č. 10. Peterborough, New Hampshire. p. 282. Citováno 2017-01-07.
  91. ^ Draco (19 June 1997). "65c02, 6502, 65816 ??? CPU sells but who's buying..." Archivovány od originál dne 2. ledna 2008.
  92. ^ Andrews, Mark (1984). "6". Atari Roots - A Guide To Atari Assembly Language. ISBN  0-88190-171-7.

Bibliografie

Další čtení

Datové listy a manuály
Knihy
  • 6502 Applications Book; 1. vydání; Rodnay Zaks; Sybex; 281 pages; 1979; ISBN  978-0895880154. (archiv)
  • 6502 Assembly Language Programming; 2nd Ed; Lance Leventhal; Osborne/McGraw-Hill; 650 pages; 1986; ISBN  978-0078812163. (archiv)
  • 6502 Assembly Language Subroutines; 1. vydání; Lance Leventhal and Winthrop Saville; Osborne/McGraw-Hill; 550 pages; 1982; ISBN  978-0931988592. (archiv)
  • 6502 Games; 1. vydání; Rodnay Zaks; Sybex; 292 pages; 1980; ISBN  978-0895880222. (archiv)
  • 6502 User's Manual; 1. vydání; Joseph Carr; Reston; 288 pages; 1984; ISBN  978-0835970020. (archiv)
  • Advanced 6502 Programming; 1. vydání; Rodnay Zaks; John Wiley & Sons; 292 pages; 1982; ISBN  978-0895880895. (archiv)
  • Machine Language For Beginners - Personal Computer Machine Language Programming For Atari, VIC, Apple, C64, and PET Computers; 1. vydání; Richard Mansfield; Vypočítat! Publications; 350 stran; 1983; ISBN  978-0942386110. (archiv)
  • Programming the 6502; 4th Ed; Rodnay Zaks; Sybex; 408 pages; 1983; ISBN  978-0895881359. (archiv)
  • Programming the 65816 - including the 6502, 65C02, 65802; 1. vydání; David Eyes and Ron Lichty; Prentice Hall; 636 pages; 1986; ISBN  978-0893037895. (archiv)
Reference cards
  • 6502 Microprocessor Instant Reference Card; James Lewis; Micro Logic; 2 pages; 1980. (archiv)

externí odkazy

Simulátory / emulátory
Desky
FPGA