माइक्रोप्रोसेसर - 8086 कार्यात्मक इकाइयाँ
8086 माइक्रोप्रोसेसर को दो कार्यात्मक इकाइयों में विभाजित किया गया है, अर्थात, EU (निष्पादन इकाई) और BIU (बस इंटरफ़ेस यूनिट)।
EU (निष्पादन इकाई)
निष्पादन इकाई बीआईयू को निर्देश देती है कि डेटा कहां से लाएं और फिर उन निर्देशों को डिकोड और निष्पादित करें। इसका कार्य निर्देश डिकोडर और ALU का उपयोग करके डेटा पर संचालन को नियंत्रित करना है। यूरोपीय संघ का सिस्टम बसों के साथ कोई सीधा संबंध नहीं है जैसा कि उपरोक्त आंकड़े में दिखाया गया है, यह बीआईयू के माध्यम से डेटा पर संचालन करता है।
आइए अब हम 8086 माइक्रोप्रोसेसरों के कार्यात्मक भागों पर चर्चा करते हैं।
आलू
यह सभी अंकगणितीय और तार्किक संक्रियाओं को संभालता है, जैसे +, -, ×, /, OR, AND, NOT संचालन।
ध्वज पंजी
यह एक 16-बिट रजिस्टर है जो फ्लिप-फ्लॉप की तरह व्यवहार करता है, अर्थात यह संचायक में संग्रहीत परिणाम के अनुसार अपनी स्थिति बदलता है। इसके 9 झंडे हैं और इन्हें 2 समूहों में विभाजित किया गया है - सशर्त झंडे और नियंत्रण झंडे।
सशर्त झंडे
यह अंतिम अंकगणित या तार्किक अनुदेश के परिणाम का प्रतिनिधित्व करता है। निम्नलिखित सशर्त झंडे की सूची है -
Carry flag - यह ध्वज अंकगणितीय संचालन के लिए एक अतिप्रवाह स्थिति को इंगित करता है।
Auxiliary flag- जब कोई ऑपरेशन ALU में किया जाता है, तो इसका परिणाम निम्न नीबेल (यानी D0 - D3) से ऊपरी निबल (यानी D4 - D7) तक होता है। वायुसेना ध्वज। प्रोसेसर बीसीडी रूपांतरण के लिए द्विआधारी प्रदर्शन करने के लिए इस ध्वज का उपयोग करता है।
Parity flag- इस ध्वज का उपयोग परिणाम की समता को इंगित करने के लिए किया जाता है, अर्थात जब निचले क्रम के 8-बिट्स में 1 की संख्या भी होती है, तो पैरिटी ध्वज सेट किया जाता है। 1 की विषम संख्या के लिए, पैरिटी फ्लैग को रीसेट किया जाता है।
Zero flag - यह ध्वज 1 पर सेट है जब अंकगणित या तार्किक संचालन का परिणाम शून्य है और इसे 0 पर सेट किया गया है।
Sign flag - यह ध्वज परिणाम का संकेत रखता है, अर्थात जब ऑपरेशन का परिणाम ऋणात्मक होता है, तब संकेत ध्वज को 1 पर सेट करके 0 पर सेट किया जाता है।
Overflow flag - यह ध्वज परिणाम का प्रतिनिधित्व करता है जब सिस्टम की क्षमता पार हो जाती है।
झंडे को नियंत्रित करें
नियंत्रण झंडे निष्पादन इकाई के संचालन को नियंत्रित करते हैं। निम्नलिखित नियंत्रण झंडों की सूची है -
Trap flag- इसका उपयोग सिंगल स्टेप कंट्रोल के लिए किया जाता है और डिबगिंग के लिए उपयोगकर्ता को एक बार में एक निर्देश निष्पादित करने की अनुमति देता है। यदि यह सेट है, तो प्रोग्राम को एकल चरण मोड में चलाया जा सकता है।
Interrupt flag- यह एक इंटरप्ट इनेबल्ड / डिसेबल फ्लैग है, जिसका इस्तेमाल किसी प्रोग्राम के रुकावट को रोकने / अनुमति देने के लिए किया जाता है। यह बाधित सक्षम स्थिति के लिए 1 पर सेट है और बाधित अक्षम स्थिति के लिए 0 पर सेट है।
Direction flag- इसका उपयोग स्ट्रिंग ऑपरेशन में किया जाता है। जैसा कि नाम से पता चलता है कि जब इसे सेट किया जाता है तो स्ट्रिंग बाइट्स को उच्च मेमोरी पते से निचले मेमोरी एड्रेस और इसके विपरीत में एक्सेस किया जाता है।
सामान्य प्रयोजन रजिस्टर
8 सामान्य प्रयोजन रजिस्टर हैं, यानी, एएच, एएल, बीएच, बीएल, सीएच, सीएल, डीएच और डीएल। इन रजिस्टरों को व्यक्तिगत रूप से 8-बिट डेटा स्टोर करने के लिए इस्तेमाल किया जा सकता है और 16 बिट डेटा स्टोर करने के लिए जोड़े में उपयोग किया जा सकता है। वैध रजिस्टर जोड़े एएच और एएल, बीएच और बीएल, सीएच और सीएल, और डीएच और डीएल हैं। इसे क्रमशः AX, BX, CX और DX के लिए संदर्भित किया जाता है।
AX register- इसे संचायक रजिस्टर के रूप में भी जाना जाता है। इसका उपयोग अंकगणित संचालन के लिए ऑपरेंड को संग्रहीत करने के लिए किया जाता है।
BX register- इसका उपयोग आधार पंजी के रूप में किया जाता है। इसका उपयोग डेटा सेगमेंट के भीतर मेमोरी क्षेत्र के शुरुआती आधार पते को संग्रहीत करने के लिए किया जाता है।
CX register- इसे काउंटर के रूप में जाना जाता है। यह लूप काउंटर को स्टोर करने के लिए लूप इंस्ट्रक्शन में उपयोग किया जाता है।
DX register - इस रजिस्टर का उपयोग I / O निर्देश के लिए I / O पोर्ट पता रखने के लिए किया जाता है।
ढेर सूचक रजिस्टर
यह एक 16-बिट रजिस्टर है, जो कि खंड की शुरुआत से स्मृति स्थान तक पता रखता है, जहां एक शब्द हाल ही में स्टैक पर संग्रहीत किया गया था।
BIU (बस इंटरफ़ेस यूनिट)
BIU सभी डेटा का ध्यान रखता है और यूरोपीय संघ के लिए बसों पर पते स्थानांतरित करता है जैसे पते भेजना, मेमोरी से निर्देश प्राप्त करना, पोर्ट से डेटा पढ़ना और मेमोरी के साथ-साथ पोर्ट और मेमोरी पर डेटा लिखना। EU का सिस्टम बसों से कोई संबंध नहीं है इसलिए यह BIU के साथ संभव है। EU और BIU इंटरनल बस के साथ जुड़े हुए हैं।
इसके निम्नलिखित कार्यात्मक भाग हैं -
Instruction queue- बीआईयू में अनुदेश कतार शामिल है। BIU अगले निर्देशों के 6 बाइट्स तक हो जाता है और उन्हें निर्देश कतार में संग्रहीत करता है। जब यूरोपीय संघ निर्देशों को निष्पादित करता है और अपने अगले निर्देश के लिए तैयार होता है, तो वह बस इस निर्देश कतार से निर्देश पढ़ता है जिसके परिणामस्वरूप निष्पादन की गति बढ़ जाती है।
वर्तमान अनुदेश निष्पादित करते समय अगला निर्देश प्राप्त करना कहा जाता है pipelining।
Segment register- BIU में 4 सेगमेंट की बसें हैं, जैसे CS, DS, SS & ES। यह स्मृति में निर्देशों और डेटा के पते रखता है, जो प्रोसेसर द्वारा मेमोरी स्थानों तक पहुंचने के लिए उपयोग किया जाता है। इसमें 1 पॉइंटर रजिस्टर आईपी भी है, जो यूरोपीय संघ द्वारा निष्पादित अगले निर्देश का पता है।
CS- यह कोड सेगमेंट के लिए है। इसका उपयोग मेमोरी के कोड सेगमेंट में मेमोरी स्थान को संबोधित करने के लिए किया जाता है, जहां निष्पादन योग्य प्रोग्राम संग्रहीत होता है।
DS- यह डेटा सेगमेंट के लिए है। यह एक ऑफसेट पते या ऑफसेट रजिस्टर रखने वाले अन्य रजिस्टर की सामग्री द्वारा डेटा सेगमेंट में एक्सेस प्रोग्राम और andis द्वारा उपयोग किए गए डेटा के होते हैं।
SS- यह स्टैक सेगमेंट के लिए है। यह निष्पादन के दौरान डेटा और पतों को संग्रहीत करने के लिए मेमोरी को संभालता है।
ES- यह एक्स्ट्रा सेगमेंट के लिए है। ES अतिरिक्त डेटा खंड है, जो अतिरिक्त गंतव्य डेटा को रखने के लिए स्ट्रिंग द्वारा उपयोग किया जाता है।
Instruction pointer - यह एक 16-बिट रजिस्टर है जिसे निष्पादित किए जाने वाले अगले निर्देश का पता रखने के लिए उपयोग किया जाता है।