एंबेडेड सिस्टम - I / O प्रोग्रामिंग
8051 में, I / O संचालन चार बंदरगाहों और 40 पिनों का उपयोग करके किया जाता है। निम्नलिखित पिन आरेख 40 पिनों का विवरण दिखाता है। I / O ऑपरेशन पोर्ट में 32 पिन होते हैं जहां प्रत्येक पोर्ट में 8 पिन होते हैं। अन्य 8 पिन V cc , GND, XTAL1, XTAL2, RST, EA (बार), ALE / PROG (बार), और PSEN (बार) के रूप में नामित हैं ।
यह एक 40 पिन PDIP (प्लास्टिक दोहरी इनलाइन पैकेज) है
Note- एक डीआईपी पैकेज में, आप आईसी के बीच में कटौती द्वारा पहले पिन और आखिरी पिन को पहचान सकते हैं। पहला पिन इस कट मार्क के बाईं ओर है और आखिरी पिन (यानी इस मामले में 40 वें पिन) कट मार्क के दाईं ओर है।
I / O पोर्ट और उनके कार्य
चार पोर्ट P0, P1, P2 और P3, प्रत्येक 8 पिन का उपयोग करते हैं, जिससे वे 8-बिट पोर्ट बनाते हैं। RESET पर, सभी पोर्ट इनपुट के रूप में कॉन्फ़िगर किए गए हैं, इनपुट पोर्ट के रूप में उपयोग करने के लिए तैयार है। जब पहले 0 को एक पोर्ट पर लिखा जाता है, तो यह आउटपुट बन जाता है। इसे इनपुट के रूप में पुन: कॉन्फ़िगर करने के लिए, 1 पोर्ट पर भेजा जाना चाहिए।
पोर्ट 0 (पिन नंबर 32 - पिन नंबर 39)
इसमें 8 पिन (32 से 39) हैं। इसका उपयोग इनपुट या आउटपुट के लिए किया जा सकता है। P1, P2 और P3 पोर्ट्स के विपरीत, हम आम तौर पर P0 को 10K-ohm पुल-अप रेसिस्टर्स से कनेक्ट करते हैं, इसे एक ओपन ड्रेन होने के नाते इनपुट या आउटपुट पोर्ट के रूप में उपयोग करने के लिए।
इसे AD0-AD7 के रूप में भी नामित किया गया है, यह इसे पते और डेटा दोनों के रूप में उपयोग करने की अनुमति देता है। 8031 (यानी रोम रहित चिप) के मामले में, जब हमें बाहरी ROM तक पहुंचने की आवश्यकता होती है, तब P0 का उपयोग पता और डेटा बस दोनों के लिए किया जाएगा। ALE (पिन नं 31) इंगित करता है कि P0 में पता या डेटा है। जब ALE = 0, यह डेटा D0-D7 प्रदान करता है, लेकिन जब ALE = 1 होता है, तो इसमें A0-A7 का पता होता है। यदि कोई बाहरी मेमोरी कनेक्शन उपलब्ध नहीं है, तो P0 को बाहरी रूप से 10K-ohm पुल-अप प्रतिरोध से जोड़ा जाना चाहिए।
MOV A,#0FFH ;(comments: A=FFH(Hexadecimal i.e. A=1111 1111)
MOV P0,A ;(Port0 have 1's on every pin so that it works as Input)
पोर्ट 1 (पिन 1 8 से होकर)
यह 8-बिट पोर्ट (8 के माध्यम से पिन 1) है और इसे इनपुट या आउटपुट के रूप में उपयोग किया जा सकता है। इसके लिए पुल-अप प्रतिरोधों की आवश्यकता नहीं है क्योंकि वे पहले से ही आंतरिक रूप से जुड़े हुए हैं। रीसेट करने पर, पोर्ट 1 को इनपुट पोर्ट के रूप में कॉन्फ़िगर किया गया है। निम्न कोड का उपयोग पोर्ट 1 में 55H और AAH के वैकल्पिक मूल्यों को भेजने के लिए किया जा सकता है।
;Toggle all bits of continuously
MOV A,#55
BACK:
MOV P2,A
ACALL DELAY
CPL A ;complement(invert) reg. A
SJMP BACK
यदि पोर्ट 1 को आउटपुट पोर्ट के रूप में उपयोग करने के लिए कॉन्फ़िगर किया गया है, तो इसे इनपुट पोर्ट के रूप में फिर से उपयोग करने के लिए, निम्न कोड में उसके सभी बिट्स पर 1 लिखकर इसे प्रोग्राम करें।
;Toggle all bits of continuously
MOV A ,#0FFH ;A = FF hex
MOV P1,A ;Make P1 an input port
MOV A,P1 ;get data from P1
MOV R7,A ;save it in Reg R7
ACALL DELAY ;wait
MOV A,P1 ;get another data from P1
MOV R6,A ;save it in R6
ACALL DELAY ;wait
MOV A,P1 ;get another data from P1
MOV R5,A ;save it in R5
पोर्ट 2 (पिंस 21 28 के माध्यम से)
पोर्ट 2 में कुल 8 पिन हैं (28 के माध्यम से 21 पिन) और इसका उपयोग इनपुट और आउटपुट संचालन दोनों के लिए किया जा सकता है। पी 1 (पोर्ट 1) के रूप में, पी 2 को बाहरी पुल-अप प्रतिरोधों की भी आवश्यकता नहीं है क्योंकि वे पहले से ही आंतरिक रूप से जुड़े हुए हैं। बाहरी मेमोरी के लिए 16-बिट एड्रेस प्रदान करने के लिए P0 के साथ इसका उपयोग किया जाना चाहिए। तो यह भी (A0-A7) के रूप में नामित है, जैसा कि पिन आरेख में दिखाया गया है। जब 8051 बाहरी मेमोरी से जुड़ा होता है, तो यह 16-बिट्स एड्रेस के ऊपरी 8-बिट्स के लिए रास्ता प्रदान करता है, और इसे I / O के रूप में उपयोग नहीं किया जा सकता है। रीसेट होने पर, पोर्ट 2 को इनपुट पोर्ट के रूप में कॉन्फ़िगर किया गया है। निम्नलिखित कोड का उपयोग पोर्ट 2 में 55H और AAH के वैकल्पिक मूल्यों को भेजने के लिए किया जा सकता है।
;Toggle all bits of continuously
MOV A,#55
BACK:
MOV P2,A
ACALL DELAY
CPL A ; complement(invert) reg. A
SJMP BACK
यदि पोर्ट 2 को आउटपुट पोर्ट के रूप में उपयोग करने के लिए कॉन्फ़िगर किया गया है, तो इसे फिर से इनपुट पोर्ट के रूप में उपयोग करने के लिए, निम्न कोड में इसके सभी बिट्स पर 1 लिखकर प्रोग्राम करें।
;Get a byte from P2 and send it to P1
MOV A,#0FFH ;A = FF hex
MOV P2,A ;make P2 an input port
BACK:
MOV A,P2 ;get data from P2
MOV P1,A ;send it to Port 1
SJMP BACK ;keep doing that
पोर्ट 3 (पिंस 10 17 के माध्यम से)
यह 8 बिट्स का भी है और इसे इनपुट / आउटपुट के रूप में इस्तेमाल किया जा सकता है। यह पोर्ट कुछ बेहद महत्वपूर्ण संकेत प्रदान करता है। P3.0 और P3.1 क्रमशः RxD (रिसीवर) और TxD (ट्रांसमीटर) हैं और सामूहिक रूप से सीरियल कम्युनिकेशन के लिए उपयोग किए जाते हैं। बाहरी अवरोधों के लिए P3.2 और P3.3 पिन का उपयोग किया जाता है। P3.4 और P3.5 का उपयोग क्रमशः टाइमर T0 और T1 के लिए किया जाता है। P3.6 और P3.7 राइट (WR) और रीड (RD) पिन हैं। ये सक्रिय कम पिन हैं, इसका मतलब है कि वे सक्रिय होंगे जब 0 उन्हें दिया जाता है और इनका उपयोग 8031 आधारित प्रणालियों में बाहरी रोम को पढ़ने और लिखने के संचालन प्रदान करने के लिए किया जाता है।
P3 बिट | समारोह | पिन |
---|---|---|
P3.0 | RxD | 10 |
P3.1 < | TxD | 1 1 |
P3.2 < | INT0 का कार्यान्वयन | 12 |
P3.3 < | INT1 | 13 |
P3.4 < | T0 | 14 |
P3.5 < | टी 1 | 15 |
P3.6 < | WR | 16 |
P3.7 < | आरडी का पूरक | 17 |
पोर्ट 0 और पोर्ट 2 की दोहरी भूमिका
Dual role of Port 0- पोर्ट 0 को AD0-AD7 के रूप में भी नामित किया गया है, क्योंकि इसका उपयोग डेटा और एड्रेस हैंडलिंग दोनों के लिए किया जा सकता है। 8051 को बाहरी मेमोरी से कनेक्ट करते समय, पोर्ट 0 पता और डेटा दोनों प्रदान कर सकता है। 8051 माइक्रोकंट्रोलर फिर पिन को बचाने के लिए इनपुट को एड्रेस या डेटा के रूप में मल्टीप्लेक्स करता है।
Dual role of Port 2- I / O के रूप में काम करने के अलावा, पोर्ट P2 का उपयोग पोर्ट 0. के साथ बाहरी मेमोरी के लिए 16-बिट एड्रेस बस प्रदान करने के लिए भी किया जाता है। पोर्ट P2 को (A8- A15) के रूप में भी नामित किया गया है, जबकि पोर्ट 0 निम्न 8-बिट्स के माध्यम से प्रदान करता है A0-ए 7। दूसरे शब्दों में, हम कह सकते हैं कि जब 8051 एक बाहरी मेमोरी (ROM) से जुड़ा होता है जो अधिकतम 64KB तक हो सकता है और यह 16 बिट एड्रेस बस द्वारा संभव है क्योंकि हम 216 = 64KB जानते हैं। पोर्ट 2 का उपयोग 16 बिट्स पते के ऊपरी 8-बिट के लिए किया जाता है, और इसका उपयोग I / O के लिए नहीं किया जा सकता है और इस तरह से बाहरी ROM के किसी भी प्रोग्राम कोड को संबोधित किया जाता है।
हार्डवेयर पिन का कनेक्शन
Vcc - पिन 40 चिप को आपूर्ति प्रदान करता है और यह +5 वी है।
Gnd - पिन 20 संदर्भ के लिए जमीन प्रदान करता है।
XTAL1, XTAL2 (Pin no 18 & Pin no 19)- 8051 में ऑन-चिप थरथरानवाला है लेकिन इसे चलाने के लिए बाहरी घड़ी की आवश्यकता होती है। एक क्वार्ट्ज क्रिस्टल चिप के XTAL1 और XTAL2 पिन के बीच जुड़ा हुआ है। वांछित आवृत्ति का संकेत उत्पन्न करने के लिए इस क्रिस्टल को 30pF के दो कैपेसिटर की भी आवश्यकता होती है। प्रत्येक संधारित्र का एक पक्ष जमीन से जुड़ा हुआ है। 8051 आईसी विभिन्न गति में उपलब्ध है और यह सभी इस क्वार्ट्ज क्रिस्टल पर निर्भर करता है, उदाहरण के लिए, 20 मेगाहर्ट्ज माइक्रोकंट्रोलर को एक क्रिस्टल की आवश्यकता होती है जिसमें 20 मेगाहर्ट्ज से अधिक आवृत्ति नहीं होती है।
RST (Pin No. 9)- यह एक इनपुट पिन और सक्रिय हाई पिन है। इस पिन पर एक उच्च पल्स लगाने पर, जो कि 1 है, माइक्रोकंट्रोलर सभी गतिविधियों को रीसेट और समाप्त कर देगा। इस प्रक्रिया के रूप में जाना जाता हैPower-On Reset। पावर-ऑन रीसेट को सक्रिय करने से रजिस्टर में सभी मान खो जाएंगे। यह सभी 0 के लिए एक प्रोग्राम काउंटर सेट करेगा। रीसेट का वैध इनपुट सुनिश्चित करने के लिए, उच्च पल्स कम से कम दो मशीन चक्रों के लिए उच्च होना चाहिए, इससे पहले कि उसे कम जाने दिया जाए, जो कैपेसिटर मूल्य और उस दर पर निर्भर करता है जिस पर वह शुल्क लेता है। (Machine Cycle आवृत्ति की न्यूनतम राशि है जिसे एक निर्देश में निष्पादन की आवश्यकता होती है)।
EA or External Access (Pin No. 31)- यह एक इनपुट पिन है। यह पिन एक सक्रिय कम पिन है; कम नाड़ी लगाने पर, यह सक्रिय हो जाता है। चिप चिप पर माइक्रोकंट्रोलर (8051/52) होने पर, EA (बार) पिन V cc से जुड़ा होता है । लेकिन एक 8031 माइक्रोकंट्रोलर में ऑन-चिप रॉम नहीं है, कोड को एक बाहरी रॉम में संग्रहीत किया जाता है और फिर माइक्रोकंट्रोलर द्वारा लाया जाता है। इस मामले में, हमें यह इंगित करने के लिए कि प्रोग्राम कोड बाहरी रूप से संग्रहीत किया गया है (पिन नं 31) ईए को गोंद से कनेक्ट करना चाहिए।
PSEN or Program store Enable (Pin No 29)- यह भी एक सक्रिय लो पिन है, अर्थात, यह कम पल्स लगाने के बाद सक्रिय हो जाता है। यह एक आउटपुट पिन है और इसका उपयोग 8031 आधारित (यानी ROMLESS) सिस्टम में EA पिन के साथ बाहरी रॉम में प्रोग्राम कोड के भंडारण की अनुमति देने के लिए किया जाता है।
ALE or (Address Latch Enable)- यह एक आउटपुट पिन है और उच्च सक्रिय है। इसे बाहरी मेमोरी से जोड़ने के लिए विशेष रूप से 8031 IC का उपयोग किया जाता है। इसका उपयोग यह तय करते समय किया जा सकता है कि क्या P0 पिन का उपयोग पता बस या डेटा बस के रूप में किया जाएगा। जब ALE = 1 होता है, तब P0 पिन डेटा बस के रूप में काम करता है और जब ALE = 0 होता है, तब P0 पिंस एड्रेस बस के रूप में कार्य करता है।
आई / ओ पोर्ट्स और बिट एड्रेसबिलिटी
यह 8051 के लिए कोड लिखते समय 8051 की सबसे व्यापक रूप से इस्तेमाल की जाने वाली विशेषता है। कभी-कभी हमें पूरे 8-बिट्स के बजाय पोर्ट के केवल 1 या 2 बिट्स तक पहुंचने की आवश्यकता होती है। 8051 बंदरगाहों के व्यक्तिगत बिट्स तक पहुंचने की क्षमता प्रदान करता है।
एक एकल-बिट तरीके से एक बंदरगाह तक पहुँचने के दौरान, हम सिंटैक्स "SETB X. Y" का उपयोग करते हैं, जहां X पोर्ट नंबर (0 से 3) है, और Y डेटा बिट D0-D7 के लिए एक बिट संख्या (0 से 7) है। जहां D0 LSB है और D7 MSB है। उदाहरण के लिए, "SETB P1.5" पोर्ट 1 के उच्च बिट 5 को सेट करता है।
निम्न कोड दिखाता है कि हम बिट P1.2 को लगातार कैसे टॉगल कर सकते हैं।
AGAIN:
SETB P1.2
ACALL DELAY
CLR P1.2
ACALL DELAY
SJMP AGAIN
एकल-बिट निर्देश
अनुदेश | समारोह |
---|---|
SETB बिट | बिट सेट करें (बिट = 1) |
सीएलआर बिट | थोड़ा साफ़ करें (बिट = 0) |
सीपीएल बिट | बिट के पूरक (बिट = बिट नहीं) |
जेबी बिट, लक्ष्य | जंप टू टारगेट बिट = 1 (जंप इफ बिट) |
जेएनबी बिट, लक्ष्य | अगर बिट = 0 पर टारगेट करें (यदि कोई बिट नहीं है तो कूदें) |
जेबीसी बिट, लक्ष्य | जम्प टू बिट = 1, क्लियर बिट (अगर थोड़ा है तो क्लियर करें) |