विषयसूची:
- आपूर्ति
- चरण 1: अवधारणा
- चरण 2: आवश्यकताएँ
- चरण 3: इसे एक साथ रखना
- चरण 4: सर्किट का परीक्षण
- चरण 5: अगला चरण
- चरण 6: कार्यक्रम
- चरण 7: निष्कर्ष
वीडियो: 6502 न्यूनतम कंप्यूटर (Arduino MEGA के साथ) भाग 1: 7 चरण
2024 लेखक: John Day | [email protected]. अंतिम बार संशोधित: 2024-01-30 09:20
6502 माइक्रोप्रोसेसर पहली बार 1975 में सामने आया था और इसे MOS टेक्नोलॉजी के लिए चक पेडल के नेतृत्व में एक छोटी टीम द्वारा डिजाइन किया गया था। उस समय इसका उपयोग वीडियो कंसोल और घरेलू कंप्यूटरों में किया जाता था जिसमें अटारी, ऐप्पल II, निन्टेंडो एंटरटेनमेंट सिस्टम, बीबीसी माइक्रो, कमोडोर वीआईसी 20 और 64 शामिल थे। उस समय यह बाजार में सबसे सस्ता था। यह वास्तव में कभी दूर नहीं हुआ है और अब इसका उपयोग शौकियों और पेशेवरों द्वारा कई अनुप्रयोगों के लिए किया जाता है।
मैं जिस संस्करण का उपयोग कर रहा हूं वह W65C02S6TPG-14 है जो पश्चिमी डिजाइन केंद्र द्वारा बनाया गया है और मूल से दस गुना कम बिजली का उपयोग करता है। खास बात यह है कि इसमें ओरिजिनल चिप की तरह 1 मेगाहर्ट्ज पर चलने की जरूरत नहीं है। यह बहुत धीमी गति से चल सकता है या एक प्रोग्राम के माध्यम से सिंगल स्टेप के लिए उपयोग किया जा सकता है और यहां तक कि 14 मेगाहर्ट्ज तक रैंप किया जा सकता है। चिप के लिए डेटा शीट इसकी क्षमताओं की व्याख्या करती है। अन्य 6502 चिप्स में यह क्षमता नहीं है और इस तरह से नहीं चलेंगे। चिप्स वर्तमान में eBay के साथ-साथ अन्य स्रोतों पर भी उपलब्ध हैं।
आपूर्ति
उपयोग किए गए सभी भाग वर्तमान में Ebay, AliExpress और अन्य पर उपलब्ध हैं।
चरण 1: अवधारणा
मुझे मेरी प्रेरणा बेन ईटर से मिली जिन्होंने YouTube पर 6502 और कंप्यूटर और सर्किट बनाने के कई अन्य पहलुओं के बारे में वीडियो की एक श्रृंखला तैयार की है। कार्यक्रम मूल रूप से उनके द्वारा लिखा गया था और मैंने इस निर्देश के साथ आने के लिए इसे और उनके कुछ डिजाइनों को संशोधित किया है। एक अन्य व्यक्ति जिसने मुझे प्रेरित किया, वह था एंड्रयू जैकब्स जिसका गिटहब पर एक अनुभाग है जहां वह अपने 6502 को नियंत्रित करने के लिए एक पीआईसी माइक्रो का उपयोग करता है।
बेन की तरह, मैं 6502 की निगरानी के लिए एक Arduino MEGA का उपयोग कर रहा हूं। मैं बेन के विपरीत घड़ी संकेत प्रदान करने के लिए MEGA का भी उपयोग कर रहा हूं। वर्तमान में मैं किसी EEPROM या RAM का उपयोग नहीं कर रहा हूँ।
चरण 2: आवश्यकताएँ
इस "कंप्यूटर" को बनाने के लिए मदों की एक सूची इस प्रकार है:
1 एक्स अरुडिनो मेगा
1 एक्स पश्चिमी डिजाइन केंद्र W65C02S6TPG-14
1 x 74HC00N आईसी (क्वाड 2-इनपुट नंद गेट) या समान
1 x 74HC373N आईसी (ऑक्टल डी-प्रकार पारदर्शी कुंडी) या समान
2 x 830 होल ब्रेड बोर्ड (एक चुटकी में)
विभिन्न ड्यूपॉन्ट पुरुष - पुरुष लीड और लिंक वायर
2 x एल ई डी (मैंने 5 मिमी नीले रंग का उपयोग किया क्योंकि आप बिना किसी प्रतिरोध के दूर हो सकते हैं)
1 x 12 मिमी मोमेंटरी टैक्टाइल पुश बटन स्विच पीसीबी माउंटेड एसपीएसटी या समान
1 एक्स 1 के प्रतिरोधी
2 x 0.1 यूएफ सिरेमिक कैपेसिटर
1 x 8 वे वाटर लाइट मार्की 5 मिमी लाल एलईडी (ऊपर के रूप में) या 8 एलईडी और प्रतिरोधक
नोट: यदि आपको अनसोल्ड किट मिलती है, तो आप एलईडी को गलत तरीके से गोल कर सकते हैं ताकि वे सामान्य कैथोड हों। मैं एक फ्लाई लीड (पिन के बजाय) संलग्न करता हूं ताकि यह आसानी से कहीं और जुड़ सके। वीसीसी अब ग्राउंड बन गया है। आप निश्चित रूप से एल ई डी को (एक इकट्ठे आइटम पर) घुमा सकते हैं और उन्हें फिर से मिलाप कर सकते हैं, लेकिन यह बहुत अधिक है! किट वर्तमान में AliExpress पर उपलब्ध हैं।
चरण 3: इसे एक साथ रखना
मुझे नए ड्यूपॉन्ट तारों का उपयोग करना आसान लगा जो पते और डेटा बसों के लिए उनके रिबन से अलग नहीं किए गए थे।
MEGA के 52 को पिन करने के लिए 6502 के पिन 9 (A0) को कनेक्ट करें, पिन १० (ए१) ६५०२ से ५० आदि को पिन करने के लिए …
जब तक
MEGA के 22 को पिन करने के लिए 6502 के पिन 25 (A15) को कनेक्ट करें।
अब तक 16 कनेक्शन
वैसे ही
MEGA के 39 को पिन करने के लिए 6502 के पिन 26 (D7) को कनेक्ट करें, पिन 27 (D6) 6502 से 41 आदि को पिन करने के लिए …
जब तक
MEGA के 53 को पिन करने के लिए 6502 के पिन 33 (D0) को कनेक्ट करें।
8 और कनेक्शन।
MEGA पर पिन 8 (VDD) को 5v से कनेक्ट करें।
ब्रेड बोर्ड के पिन 8 से Gnd से जुड़ा 0.1uF संधारित्र यहां उपयोगी हो सकता है लेकिन आवश्यक नहीं है।
MEGA पर पिन 21 (VSS) को Gnd से कनेक्ट करें।
पिन 2, 4, 6, 36 और 38 को 5v. से बांधा जा सकता है
MEGA के पिन ३७ (घड़ी) को २ पिन और पिन ७ से कनेक्ट करें।
MEGA के 3 पिन करने के लिए पिन 34 (RWB) कनेक्ट करें।
पिन 40 (रीसेट) को ऊपर आरेख के रूप में कनेक्ट करें।
चरण 4: सर्किट का परीक्षण
इस स्तर पर 6502 काम करेगा और प्रोग्राम1 का उपयोग किया जा सकता है। यदि आप 8 तरह के मार्की (ऊपर के रूप में) का उपयोग कर रहे हैं, तो इसे सीधे ब्रेडबोर्ड में डाला जा सकता है और फ्लाई लीड को जमीन से जोड़ा जा सकता है, या आप 8 एलईडी और प्रतिरोधों का उपयोग कर सकते हैं। LEDS दिखाएगा कि डेटा बस में क्या है।
इस स्तर पर जो हो रहा है उसका पालन करने के लिए लूप() में 500 या उससे अधिक में देरी सेट करना भी होगा।
आपको सीरियल मॉनिटर पर ऊपर की तरह एक समान आउटपुट मिलना चाहिए। जब रीसेट दबाया जाता है, तो प्रोसेसर 7 चक्रों से गुजरता है और फिर यह $FFFC और $FFFD स्थानों में कार्यक्रम की शुरुआत की तलाश करता है। चूंकि 6502 पढ़ने के लिए कोई भौतिक पता नहीं है, इसलिए हमें उन्हें मेगा से आपूर्ति करनी होगी।
उपरोक्त आउटपुट में, 6502 $FFFC और $FFFD पढ़ता है और $00 और $10 (लो बाइट, हाई बाइट) प्राप्त करता है जो $1000 पर प्रोग्राम की शुरुआत है। प्रोसेसर तब प्रोग्राम को $1000 (ऊपर के रूप में) स्थान पर निष्पादित करना शुरू कर देता है। इस मामले में यह $A9 और $55 पढ़ता है, यानी LDA#$55 (संचयक में 85 लोड करें)। फिर से कोई भौतिक स्मृति स्थान नहीं है, मेगा डेटा बस से जो पढ़ा जाता है उसका अनुकरण करता है।
$55 (85) बाइनरी पैटर्न 01010101 देता है और जब घुमाया जाता है तो 1 बिट बाएं $AA (170) 10101010 देता है।
कार्यक्रम से पता चलता है कि प्रोसेसर सही ढंग से काम कर रहा है लेकिन जल्द ही थोड़ा उबाऊ हो जाता है, इसलिए अगले भाग पर।
चरण 5: अगला चरण
ऊपर दिया गया "स्पेगेटी का ढेर" शायद कुछ वैसा ही है जैसा इस चरण के बाद आपके पास होगा।
आगे आपको 74HC373N और 74HC00N IC को ब्रेडबोर्ड में जोड़ना होगा।
दुर्भाग्य से ३७३ के पिन डेटा बस के साथ पंक्तिबद्ध नहीं होते हैं, इसलिए उन्हें तारों से जोड़ने की आवश्यकता होगी।
5v को पिन 20 से कनेक्ट करें।
ग्राउंड को पिन 10 से कनेक्ट करें।
6502 के पिन 33 (D0) को 74HC373N के पिन 3 (D0) से कनेक्ट करें
और इसी तरह पिन D1 से D7 तक।
Q0 से Q7 आउटपुट हैं और इन्हें LED मार्की या अलग-अलग LED और रेसिस्टर्स से कनेक्ट करने की आवश्यकता होगी।
74HC00 के साथ इसके केवल 2 फाटकों की जरूरत है
5v को पिन 14 से कनेक्ट करें।
ग्राउंड को पिन 7 से कनेक्ट करें।
6502 के पिन 17 (A8) को 74HC00. के 1 (1A) को पिन से कनेक्ट करें
6502 के पिन 25 (A15) को 74HC00. के 2 (1B) को पिन से कनेक्ट करें
6502 के पिन 34(R/W) को 74HC00. के 5 (2B) को पिन से कनेक्ट करें
74HC00 के पिन 3 (1Y) को 74HC00 के पिन 4 (2A) से कनेक्ट करें
74HC00 के पिन 6 (2Y) को 74HC373N के 11 (LE) को पिन करने के लिए कनेक्ट करें
74HC373N के पिन 11 (LE) को 74HC373N के पिन 1 (OE) से कनेक्ट करें
आप एक नीली एलईडी को 1Y और जमीन के साथ-साथ 2Y को जमीन से जोड़ सकते हैं, यह इंगित करेगा कि गेट कब सक्रिय है।
अंत में ऑनक्लॉक प्रक्रिया में प्रोग्राम 1 से प्रोग्राम 2 में लाइन बदलें
setDataPins (प्रोग्राम 2 [ऑफ़सेट]);
चरण 6: कार्यक्रम
6502-मॉनिटर कार्यक्रम में ऊपर वर्णित दो 6502 रूटीन शामिल हैं।
कार्यक्रम अभी भी विकास के अधीन है और थोड़ा गन्दा है।
प्रोग्राम 2 चलाते समय, लूप () में देरी 50 या उससे कम हो सकती है और पूरी तरह से हटा भी दी जा सकती है। Serial.print() लाइनों पर टिप्पणी करने से 6502 रन तेज हो जाते हैं। पिन ११ (एलई) से ३७३ के पिन १ (ओई) को डिस्कनेक्ट करने से अलग परिणाम मिलते हैं। NAND गेट से 373 में से पिन 1 और पिन 11 को डिस्कनेक्ट करने से आप यह देख सकते हैं कि प्रत्येक घड़ी चक्र में डेटा बस में क्या है।
आपको OE को जमीन से जोड़ने की आवश्यकता हो सकती है, न कि इसे तैरते हुए छोड़ने के लिए क्योंकि यदि यह पिन अधिक हो जाता है तो 8 आउटपुट लाइनें अक्षम हो जाती हैं। जब LE पिन अधिक होता है, तो आउटपुट पिन इनपुट के समान होते हैं। LE पिन को नीचे ले जाने से आउटपुट लैच हो जाते हैं यानी यदि इनपुट पिन बदलते हैं, तो आउटपुट वही रहता है।
मैंने प्रोग्राम को यथासंभव सरल रखने की कोशिश की है ताकि इसे समझना आसान हो सके।
समय की देरी के साथ प्रयोग करने से आप ठीक वैसा ही अनुसरण कर सकते हैं जैसा कि 6502 कर रहा है।
6502 असेंबलर में नीचे दो प्रोग्राम (दोनों पते पर चलते हैं) हैं:
कार्यक्रम1
एलडीए#$55
एनओपी
रोली
एसटीए$1010
जेएमपी$1000
ROL संचायक की सामग्री को एक बिट बाईं ओर घुमाता है जिसका अर्थ है कि $55 अब $AA हो जाता है।
मशीन कोड (हेक्स) में: A9 55 EA 2A 8D 10 10 4C 00 10
कार्यक्रम २
एलडीए#$01
एसटीए$8100
एडीसी#$03
एसटीए$8100
जेएमपी$1005
मशीन कोड (हेक्स) में: A9 01 8D 00 81 69 03 8D 00 81 4C 05 10
प्रोग्राम 2 में अब एक भौतिक पता $ 8100 है, जो कि पता बस में 74HC373 है।
यानी 6502 का A15 32768 ($8000) है और A8 256 ($0100) = 33024 ($8100) है।
इसलिए जब ६५०२ $८१०० (एसटीए $८१००) को लिखता है तो ६५०२ का आर/डब्ल्यू कम होता है और ३७३ एलई के कम होने पर ६५०२ डेटा बस पर डेटा बंद हो जाता है। 74HC00 NAND गेट के कारण सिग्नल उलट जाते हैं।
उपरोक्त स्क्रीन प्रिंट में दूसरा लेखन 3 (ADC#$03) से बढ़ा है - $7F से $82 हो गया है।
वास्तव में, पता बस की 2 से अधिक पंक्तियों का उपयोग 373 के विशिष्ट स्थान के लिए किया जाएगा। चूंकि यह संभावित 65536 में से एकमात्र भौतिक पता है, यह दर्शाता है कि पता बस कैसे काम करती है। आप अलग-अलग एड्रेस पिन के साथ प्रयोग कर सकते हैं और इसे एक अलग स्थान पर रख सकते हैं। बेशक, आपको एसटीए ऑपरेंड को नए स्थान पर बदलना होगा। जैसे यदि आपने पता पंक्ति A15 और A9 का उपयोग किया है तो पता $8200 (32768 + 512) होगा।
चरण 7: निष्कर्ष
मैंने यह दिखाने की कोशिश की है कि 6502 को ऊपर उठाना और चलाना कितना आसान है।
मैं इस क्षेत्र का विशेषज्ञ नहीं हूं इसलिए मैं किसी भी रचनात्मक टिप्पणी या जानकारी का स्वागत करूंगा।
इसे और विकसित करने के लिए आपका स्वागत है और आपने जो किया है उसमें मेरी दिलचस्पी होगी।
मैं परियोजना में एक EEPROM, SRAM और एक 6522 जोड़ने के साथ-साथ भविष्य में इसे स्ट्रिप बोर्ड पर लगाने का इरादा रखता हूं।
सिफारिश की:
न्यूनतम न्यूनतम - ब्रेडबोर्ड पर Arduino: 5 कदम
बेयर मिनिमम - ब्रेडबोर्ड पर Arduino: Arduino ATMega328p चिप का उपयोग करता है। हम इसे SMD फॉर्मेट (ATMega328p-AU) या ट्रफ होल सोल्डरिंग (ATMega328p-PU) के लिए DIP फॉर्मेट में प्राप्त कर सकते हैं। लेकिन, चिप अपने आप काम नहीं कर सकती। इसे कुछ और घटकों की आवश्यकता है और सभी को एक साथ नंगे कहा जाता है
Arduino Uno के साथ ध्वनिक उत्तोलन चरण-दर-चरण (8-चरण): 8 चरण
Arduino Uno के साथ ध्वनिक उत्तोलन चरण-दर-चरण (8-चरण): अल्ट्रासोनिक ध्वनि ट्रांसड्यूसर L298N डीसी महिला एडाप्टर बिजली की आपूर्ति एक पुरुष डीसी पिन के साथ Arduino UNOBreadboardयह कैसे काम करता है: सबसे पहले, आप Arduino Uno पर कोड अपलोड करते हैं (यह डिजिटल से लैस एक माइक्रोकंट्रोलर है और कोड (C++) कन्वर्ट करने के लिए एनालॉग पोर्ट
6502 न्यूनतम कंप्यूटर (Arduino MEGA के साथ) भाग 3: 7 चरण
६५०२ मिनिमल कंप्यूटर (Arduino MEGA के साथ) भाग ३: और भी आगे बढ़ते हुए, मैंने अब मुख्य बोर्ड में एक ऑक्टल लैच, ८ आयताकार एलईडी और २२० ओम रेसिस्टर ऐरे को जोड़ा है। ऐरे के कॉमन पिन और ग्राउंड के बीच एक जम्पर भी होता है, जिससे एलईडी को बंद किया जा सकता है। ७४एचसी०० नंद गेट एच
6502 और 6522 न्यूनतम कंप्यूटर (Arduino MEGA के साथ) भाग 2: 4 चरण
६५०२ और ६५२२ मिनिमल कंप्यूटर (Arduino MEGA के साथ) भाग २: अपने पिछले निर्देश के बाद, मैंने अब ६५०२ को एक स्ट्रिप बोर्ड पर रखा है और एक ६५२२ बहुमुखी इंटरफ़ेस एडेप्टर (VIA) जोड़ा है। फिर से, मैं ६५२२ के WDC संस्करण का उपयोग कर रहा हूँ, क्योंकि यह उनके ६५०२ के लिए एकदम सही मैच है। इतना ही नहीं ये नए c
कंप्यूटर जॉयस्टिक के रूप में PSP का उपयोग करना और फिर PSP के साथ अपने कंप्यूटर को नियंत्रित करना: 5 चरण (चित्रों के साथ)
कंप्यूटर जॉयस्टिक के रूप में पीएसपी का उपयोग करना और फिर पीएसपी के साथ अपने कंप्यूटर को नियंत्रित करना: आप पीएसपी होमब्रू के साथ कई अच्छी चीजें कर सकते हैं, और इस निर्देशयोग्य में मैं आपको सिखाने जा रहा हूं कि गेम खेलने के लिए जॉयस्टिक के रूप में अपने पीएसपी का उपयोग कैसे करें, लेकिन यह भी है एक प्रोग्राम जो आपको अपने जॉयस्टिक को अपने माउस के रूप में उपयोग करने की अनुमति देता है। यहाँ मेटर हैं