एंबेडेड सिस्टम - रजिस्टर बैंक / स्टैक
8051 माइक्रोकंट्रोलर में कुल 128 बाइट्स की रैम होती है। हम रैम के इन 128 बाइट्स के आवंटन के बारे में चर्चा करेंगे और स्टैक और रजिस्टर के रूप में उनके उपयोग की जांच करेंगे।
8051 में RAM मेमोरी स्पेस आवंटन
8051 के अंदर रैम के 128 बाइट्स को पता 00 से 7FH सौंपा गया है। उन्हें सीधे मेमोरी स्थानों के रूप में एक्सेस किया जा सकता है और उन्हें तीन अलग-अलग समूहों में विभाजित किया जाता है -
00H से 1FH स्थानों के 32 बाइट्स रजिस्टर बैंकों और स्टैक के लिए अलग रखे गए हैं।
20H से 2FH स्थानों पर 16 बाइट्स को बिट-एड्रेसेबल रीड / राइट मेमोरी के लिए अलग रखा गया है।
30H से 7FH स्थानों पर 80 बाइट्स का उपयोग पढ़ने और लिखने के भंडारण के लिए किया जाता है; इसे कहा जाता हैscratch pad। 8051 प्रोग्रामर द्वारा डेटा और मापदंडों को संग्रहीत करने के उद्देश्य से इन 80 स्थानों रैम का व्यापक रूप से उपयोग किया जाता है।
8051 में बैंकों को पंजीकृत करें
कुल 32 बाइट्स की रैम रजिस्टर बैंकों और स्टैक के लिए अलग रखी गई हैं। इन 32 बाइट्स को चार रजिस्टर बैंकों में विभाजित किया गया है, जिसमें प्रत्येक बैंक में 8 रजिस्टर, R0-R7 हैं। 0 से 7 तक के रैम स्थानों को R0-R7 के बैंक 0 के लिए अलग रखा गया है जहाँ R0 में RAM का स्थान 0 है, R1 का रैम स्थान 1 है, R2 का स्थान 2 है, और इसी तरह, स्मृति स्थान 7 तक, जो बैंक के R7 से संबंधित है 0।
R0-R7 का दूसरा बैंक रैम लोकेशन 08 से शुरू होता है और OFH के स्थानों तक जाता है। R0-R7 का तीसरा बैंक मेमोरी लोकेशन 10H से शुरू होता है और 17H पर जाता है। अंत में, रैम स्थानों 18H से 1FH को R0-R7 के चौथे बैंक के लिए अलग रखा गया है।
डिफ़ॉल्ट रजिस्टर बैंक
यदि रैम रजिस्टर ००-१ एफ को चार रजिस्टरों वाले बैंकों के लिए अलग रखा जाता है, जो 00० -११ के of०१ तक संचालित होने पर R0-R7 के बैंक को रजिस्टर करते हैं? जवाब है रजिस्टर बैंक 0; यह है कि, 0 से 7 तक के रैम स्थानों को 8051 की प्रोग्रामिंग करते समय R0 से R7 नाम के साथ एक्सेस किया जाता है। क्योंकि इन रैम स्थानों को R0 से R7 जैसे नामों से संदर्भित करना ज्यादा आसान है, बजाय कि उनके मेमोरी लोकेशन के।
रजिस्टर बैंकों को कैसे स्विच करें
8051 को संचालित करने पर रजिस्टर बैंक 0 डिफ़ॉल्ट है। हम PSW रजिस्टर का उपयोग करके अन्य बैंकों में जा सकते हैं। पीएसडब्ल्यू के डी 4 और डी 3 बिट्स का उपयोग वांछित रजिस्टर बैंक का चयन करने के लिए किया जाता है, क्योंकि उन्हें बिट एड्रेसेबल निर्देशों एसईटीबी और सीएलआर द्वारा एक्सेस किया जा सकता है। उदाहरण के लिए, "SETB PSW.3" PSW.3 = 1 सेट करेगा और बैंक रजिस्टर 1 का चयन करेगा।
RS1 | RS2 | बैंक चयनित |
---|---|---|
0 | 0 | Bank0 |
0 | 1 | Bank1 |
1 | 0 | Bank2 |
1 | 1 | Bank3 |
ढेर और उसके संचालन
8051 में ढेर
स्टैक एक RAM का एक भाग है जिसका उपयोग CPU द्वारा अस्थाई आधार पर डेटा या मेमोरी एड्रेस जैसी जानकारी को स्टोर करने के लिए किया जाता है। सीपीयू को सीमित संख्या को देखते हुए इस भंडारण क्षेत्र की आवश्यकता है।
कैसे ढेर पहुँचा जाता है
जैसा कि स्टैक रैम का एक खंड है, इसे इंगित करने के लिए सीपीयू के अंदर रजिस्टर होते हैं। स्टैक तक पहुंचने के लिए उपयोग किए जाने वाले रजिस्टर को स्टैक पॉइंटर रजिस्टर के रूप में जाना जाता है। 8051 में स्टैक पॉइंटर 8-बिट चौड़ा है, और यह 00 से FFH का मान ले सकता है। जब 8051 को प्रारंभ किया जाता है, तो SP रजिस्टर में 07H का मान होता है। इसका मतलब है कि रैम स्थान 08 स्टैक के लिए उपयोग किया जाने वाला पहला स्थान है। स्टैक में सीपीयू रजिस्टर के संचालन को एक के रूप में जाना जाता हैPUSH, और एक सीपीयू रजिस्टर में स्टैक से सामग्री प्राप्त करना एक कहा जाता है POP।
ढेर में धकेलना
8051 में, स्टैक पॉइंटर (SP) स्टैक के अंतिम उपयोग किए गए स्थान को इंगित करता है। जब डेटा को स्टैक पर धकेल दिया जाता है, तो स्टैक पॉइंटर (SP) 1 से बढ़ जाता है। जब PUSH निष्पादित होता है, तो रजिस्टर की सामग्री को स्टैक पर सहेजा जाता है और SP को 1 से बढ़ा दिया जाता है। स्टैक पर रजिस्टरों को पुश करने के लिए, हम उनके RAM पते का उपयोग करना चाहिए। उदाहरण के लिए, निर्देश "पुश 1" स्टैक पर रजिस्टर आर 1 को धक्का देता है।
स्टैक से रोकना
स्टैक की सामग्री को किसी दिए गए रजिस्टर में वापस लाना धक्का देने की प्रक्रिया के विपरीत है। प्रत्येक पॉप ऑपरेशन के साथ, स्टैक के शीर्ष बाइट को निर्देश द्वारा निर्दिष्ट रजिस्टर में कॉपी किया जाता है और स्टैक पॉइंटर को एक बार डिक्रिप्ट किया जाता है।