एंबेडेड सिस्टम - रजिस्टर
सीपीयू में अस्थायी रूप से जानकारी को संग्रहीत करने के लिए सीपीयू का उपयोग किया जाता है जो संसाधित होने के लिए डेटा हो सकता है, या उस पते की ओर संकेत किया जा सकता है जिसे प्राप्त करना है। 8051 में, MSB (सबसे महत्वपूर्ण बिट) D7 से LSB (कम से कम महत्वपूर्ण बिट) D0 तक 8-बिट्स का एक डेटा प्रकार होता है। 8-बिट डेटा प्रकार के साथ, 8-बिट्स से बड़ा कोई भी डेटा प्रकार संसाधित होने से पहले 8-बिट विखंडू में तोड़ा जाना चाहिए।
8051 के सबसे व्यापक रूप से उपयोग किए जाने वाले रजिस्टर ए (संचायक), बी, आर0-आर 7, डीपीटीआर (डेटा पॉइंटर), और पीसी (प्रोग्राम काउंटर) हैं। DPTR और PC को छोड़कर, ये सभी रजिस्टर 8-बिट्स के हैं।
8051 में स्टोरेज रजिस्टर
हम यहां निम्नलिखित प्रकार के भंडारण रजिस्टर पर चर्चा करेंगे -
- Accumulator
- आर रजिस्टर
- B रजिस्टर
- डेटा सूचक (DPTR)
- कार्यक्रम काउंटर (पीसी)
- स्टैक पॉइंटर (SP)
बिजली संचयक यंत्र
संचायक, रजिस्टर ए, का उपयोग सभी अंकगणित और तर्क संचालन के लिए किया जाता है। यदि संचायक मौजूद नहीं है, तो प्रत्येक गणना के प्रत्येक परिणाम (इसके अलावा, गुणन, पारी, आदि) को मुख्य मेमोरी में संग्रहीत किया जाना है। संचयकर्ता की तरह एक रजिस्टर तक पहुंच की तुलना में मुख्य मेमोरी तक पहुंच धीमी है क्योंकि बड़ी मेन मेमोरी के लिए इस्तेमाल की जाने वाली तकनीक धीमी है (लेकिन सस्ती) जो रजिस्टर के लिए उपयोग की जाती है।
"आर" रजिस्टर
"R" रजिस्टर आठ रजिस्टरों का एक सेट है, जिसका नाम है, R0, R1 से R7। ये रजिस्टर कई ऑपरेशन में सहायक या अस्थायी भंडारण रजिस्टर के रूप में कार्य करते हैं। 10 और 20 के योग का एक उदाहरण पर विचार करें। एक संचयकर्ता में एक चर 10 को स्टोर करें और दूसरे चर 20 में, कहते हैं, R4 को पंजीकृत करें। अतिरिक्त संचालन को संसाधित करने के लिए, निम्नलिखित कमांड निष्पादित करें -
ADD A,R4
इस निर्देश को निष्पादित करने के बाद, संचायक में मूल्य 30 होगा। इस प्रकार "आर" रजिस्टर बहुत महत्वपूर्ण सहायक हैं या helper registers। अकेले Accumulator बहुत उपयोगी नहीं होगा अगर यह इन "R" रजिस्टरों के लिए नहीं था। "आर" रजिस्टर अस्थायी रूप से मूल्यों के भंडारण के लिए हैं।
एक और उदाहरण लेते हैं। हम R1 और R2 में मूल्यों को एक साथ जोड़ देंगे और फिर परिणाम से R3 और R4 के मूल्यों को घटा देंगे।
MOV A,R3 ;Move the value of R3 into the accumulator
ADD A,R4 ;Add the value of R4
MOV R5,A ;Store the resulting value temporarily in R5
MOV A,R1 ;Move the value of R1 into the accumulator
ADD A,R2 ;Add the value of R2
SUBB A,R5 ;Subtract the value of R5 (which now contains R3 + R4)
जैसा कि आप देख सकते हैं, हमने R3 का उपयोग अस्थायी रूप से R3 और R4 के योग को रखने के लिए किया। बेशक, यह (R1 + R2) - (R3 + R4) की गणना करने का सबसे कुशल तरीका नहीं है, लेकिन यह अस्थायी रूप से मूल्यों को संग्रहीत करने के तरीके के रूप में "R" रजिस्टरों के उपयोग को चित्रित करता है।
"बी" रजिस्टर
"बी" रजिस्टर इस अर्थ में Accumulator के समान है कि यह एक 8-बिट (1-बाइट) मान रख सकता है। "बी" रजिस्टर का उपयोग केवल दो 8051 निर्देशों द्वारा किया जाता है:MUL AB तथा DIV AB। किसी अन्य संख्या से A को जल्दी और आसानी से गुणा या विभाजित करने के लिए, आप दूसरे नंबर को "B" में संग्रहीत कर सकते हैं और इन दोनों निर्देशों का उपयोग कर सकते हैं। MUL और DIV निर्देशों का उपयोग करने के अलावा, "B" रजिस्टर का उपयोग अक्सर एक और अस्थायी भंडारण रजिस्टर के रूप में किया जाता है, बहुत कुछ नौवें R रजिस्टर की तरह।
डेटा सूचक
डेटा पॉइंटर (DPTR) 8051 का एकमात्र उपयोगकर्ता-सुलभ 16-बिट (2-बाइट) रजिस्टर है। Accumulator, R0-R7 रजिस्टर और B रजिस्टर 1-बाइट मान रजिस्टर हैं। DPTR डेटा की ओर इशारा करने के लिए है। इसका उपयोग DP51 द्वारा इंगित पते का उपयोग करके बाहरी मेमोरी तक पहुंचने के लिए 8051 तक किया जाता है। DPTR केवल 16-बिट रजिस्टर उपलब्ध है और अक्सर इसका उपयोग 2-बाइट मानों को संग्रहीत करने के लिए किया जाता है।
कार्यक्रम काउंटर
प्रोग्राम काउंटर (पीसी) एक 2-बाइट पता है जो 8051 को बताता है जहां निष्पादित करने का अगला निर्देश मेमोरी में पाया जा सकता है। पीसी की शुरुआत 0000h से होती है जब 8051 शुरू होता है और एक निर्देश के निष्पादित होने के बाद हर बार बढ़ाया जाता है। पीसी हमेशा 1 से बढ़ा हुआ नहीं होता है। कुछ निर्देशों में 2 या 3 बाइट्स की आवश्यकता हो सकती है; ऐसे मामलों में, पीसी 2 या 3 से बढ़ जाएगा।
Branch, jump, तथा interruptसंचालन प्रोग्राम काउंटर को अगले अनुक्रमिक स्थान के अलावा अन्य पते से लोड करता है। पावर-ऑन रीसेट को सक्रिय करने से रजिस्टर में सभी मान खो जाएंगे। इसका मतलब है कि पीसी का मान रीसेट पर 0 है, CPU को ROM स्थान 0000 से पहला ओपकोड लाने के लिए मजबूर करता है। इसका मतलब है कि हमें ROM स्थान 0000 में upcode का पहला बाइट रखना होगा क्योंकि सीपीयू को खोजने की उम्मीद है पहला निर्देश।
स्टैक पॉइंटर (SP)
स्टैक पॉइंटर, डीपीटीआर और पीसी को छोड़कर सभी रजिस्टरों की तरह, 8-बिट (1-बाइट) मान रख सकता है। स्टैक पॉइंटर उस स्थान को बताता है जहां से अगले मूल्य को स्टैक से हटाया जाना है। जब किसी मूल्य को स्टैक पर धकेला जाता है, तो SP का मान बढ़ जाता है और फिर परिणामी मेमोरी लोकेशन पर मान जमा हो जाता है। जब स्टैक से कोई मान पॉप किया जाता है, तो मान SP द्वारा इंगित मेमोरी स्थान से वापस आ जाता है, और उसके बाद SP का मान घटाया जाता है।
ऑपरेशन का यह क्रम महत्वपूर्ण है। एसपी को 07h से शुरू किया जाएगा जब 8051 को आरंभीकृत किया जाएगा। यदि एक ही समय में एक स्टैक पर मान धकेल दिया जाता है, तो मान आंतरिक RAM पते 08h में संग्रहीत किया जाएगा क्योंकि 8051 पहले SP का मान बढ़ाएगा (07h से 08h तक) और फिर उस मेमोरी में पुश किए गए मान को संग्रहीत करेगा पता (08 ह)। एसपी को 8051 तक सीधे छह निर्देशों द्वारा संशोधित किया गया है: पुश, पीओपी, एसीएएलएल, एलसीएएल, आरईटी, और आरईटीआई।
8051 में ROM स्पेस
8051 के कुछ परिवार के सदस्यों में ऑन-चिप ROM (उदाहरण के लिए 8751, AT8951) के केवल 4K बाइट्स हैं; कुछ में AT89C52 की तरह 8K ROM है, और कुछ परिवार के सदस्यों के साथ 32K बाइट्स और 64K बाइट्स ऑन-चिप ROM जैसे डलास सेमीकंडक्टर हैं। यह याद रखने की बात यह है कि 8051 परिवार का कोई भी सदस्य 64K बाइट्स के ओपकोड तक नहीं पहुंच सकता है क्योंकि 8051 में प्रोग्राम काउंटर 16-बिट रजिस्टर (0000 से FFFF एड्रेस) है।
8051 के अंदर प्रोग्राम रोम के पहले स्थान पर 0000H का पता है, जबकि चिप पर रोम के आकार के आधार पर अंतिम स्थान भिन्न हो सकता है। 8051 परिवार के सदस्यों में, AT8951 में $ k बाइट्स ऑन-चिप ROM है, जिसका मेमोरी पता 0000 (पहला स्थान) से 0FFFH (अंतिम स्थान) है।
8051 फ्लैग बिट्स और PSW रजिस्टर
कार्यक्रम की स्थिति शब्द (PSW) रजिस्टर एक 8-बिट रजिस्टर है, जिसे के रूप में भी जाना जाता है flag register। यह 8-बिट वाइड का है लेकिन इसका केवल 6-बिट ही उपयोग किया जाता है। दो अप्रयुक्त बिट हैंuser-defined flags। झंडे के चार कहा जाता हैconditional flags, जिसका अर्थ है कि वे एक शर्त को इंगित करते हैं जिसके परिणामस्वरूप एक निर्देश निष्पादित होता है। ये चार हैंCY (कैरी), AC (सहायक कैरी), P (समानता), और OV(अतिप्रवाह)। बिट्स RS0 और RS1 का उपयोग बैंक रजिस्टरों को बदलने के लिए किया जाता है। निम्नलिखित आंकड़ा कार्यक्रम की स्थिति शब्द रजिस्टर दिखाता है।
PSW रजिस्टर में वह स्थिति बिट्स होती हैं जो CPU की वर्तमान स्थिति को दर्शाती हैं।
सीवाई | सीए | F0 | RS1 | RS0 | OV | - | पी |
---|
सीवाई | PSW.7 | ध्वज ले जाना |
एसी | PSW.6 | सहायक कैरी फ्लैग |
F0 | PSW.5 | ध्वज 0 सामान्य प्रयोजन के लिए उपयोगकर्ता के लिए उपलब्ध है। |
RS1 | PSW.4 | रजिस्टर बैंक चयनकर्ता बिट 1 |
RS0 | PSW.3 | रजिस्टर बैंक चयनकर्ता बिट 0 |
OV | PSW.2 | ओवरफ्लो झंडा |
- | PSW.1 | उपयोगकर्ता निश्चित फ्लैग |
पी | PSW.0 | पैरिटी FLAG। संचायक में 1 बिट के सम / विषम संख्या को इंगित करने के लिए अनुदेश चक्र के दौरान हार्डवेयर द्वारा सेट / क्लियर किया गया। |
हम RS0 और RS1 बिट्स का उपयोग करके संबंधित रजिस्टर बैंक बिट का चयन कर सकते हैं।
RS1 | RS2 | बैंक रजिस्टर करें | पता |
---|---|---|---|
0 | 0 | 0 | 00H-07h |
0 | 1 | 1 | 08H-0FH |
1 | 0 | 2 | 10H-17h |
1 | 1 | 3 | 18h-1FH |
CY, the carry flag- यह कैरी फ्लैग सेट है (1) जब भी डी 7 बिट से कोई कैरी आउट होता है। यह 8-बिट जोड़ या घटाव ऑपरेशन के बाद प्रभावित होता है। इसे "SETB C" और "CLR C" जैसे निर्देशों के द्वारा सीधे 1 या 0 पर रीसेट किया जा सकता है, जहाँ "SETB" सेट बिट कैरी के लिए है और "CLR" स्पष्ट कैरी के लिए है।
AC, auxiliary carry flag- अगर ADD या SUB ऑपरेशन के दौरान D3 और D4 से कैरी होता है, तो AC बिट सेट हो जाता है; अन्यथा, यह साफ हो गया है। इसका उपयोग द्विआधारी कोडित दशमलव अंकगणित करने के निर्देश के लिए किया जाता है।
P, the parity flag- समता ध्वज केवल संचायक रजिस्टर में 1 की संख्या का प्रतिनिधित्व करता है। यदि A रजिस्टर में विषम संख्या 1 है, तो P = 1; और 1 की संख्या के लिए, पी = 0।
OV, the overflow flag- यह झंडा तब सेट किया जाता है जब हस्ताक्षरित ऑपरेशन का परिणाम बहुत बड़ा होता है, जो उच्च-क्रम बिट को साइन बिट में ओवरफ्लो करने का कारण बनता है। इसका उपयोग केवल हस्ताक्षरित अंकगणितीय कार्यों में त्रुटियों का पता लगाने के लिए किया जाता है।
उदाहरण
निम्नलिखित निर्देश में 9CH और 64H के जोड़ के बाद CY, AC, और P फ्लैग की स्थिति दिखाएं।
MOV ए, # 9CH
एडीडी ए, # 64 एच
Solution: 9C 10011100
+64 01100100
100 00000000
CY = 1 since there is a carry beyond D7 bit
AC = 0 since there is a carry from D3 to D4
P = 0 because the accumulator has even number of 1's