माइक्रोप्रोसेसर - त्वरित गाइड

माइक्रोप्रोसेसर एक माइक्रो-कंप्यूटर की एक नियंत्रित इकाई है, जो ALU (अरिथमेटिक लॉजिकल यूनिट) के संचालन में सक्षम एक छोटी चिप पर निर्मित है और इससे जुड़े अन्य उपकरणों के साथ संचार करता है।

माइक्रोप्रोसेसर में ALU, रजिस्टर ऐरे और एक कंट्रोल यूनिट होते हैं। ALU मेमोरी या एक इनपुट डिवाइस से प्राप्त डेटा पर अंकगणितीय और तार्किक संचालन करता है। रजिस्टर ऐरे में बी, सी, डी, ई, एच, एल और संचायक जैसे अक्षरों से पहचाने जाने वाले रजिस्टर होते हैं। नियंत्रण इकाई कंप्यूटर के भीतर डेटा और निर्देशों के प्रवाह को नियंत्रित करती है।

एक बुनियादी माइक्रो कंप्यूटर के ब्लॉक आरेख

कैसे एक माइक्रोप्रोसेसर काम करता है?

माइक्रोप्रोसेसर एक अनुक्रम का अनुसरण करता है: फ़ेच, डिकोड, और फिर निष्पादित करें।

प्रारंभ में, निर्देश एक क्रमबद्ध क्रम में मेमोरी में संग्रहीत होते हैं। माइक्रोप्रोसेसर स्मृति से उन निर्देशों को प्राप्त करता है, फिर उसे डिकोड करता है और उन निर्देशों को तब तक निष्पादित करता है जब तक STOP निर्देश नहीं पहुंच जाता। बाद में, यह बाइनरी को आउटपुट पोर्ट पर भेजता है। इन प्रक्रियाओं के बीच, रजिस्टर अस्थायी रूप से डेटा संग्रहीत करता है और ALU कंप्यूटिंग फ़ंक्शन करता है।

माइक्रोप्रोसेसर में प्रयुक्त शब्दों की सूची

यहाँ एक माइक्रोप्रोसेसर में अक्सर इस्तेमाल किए जाने वाले कुछ शब्दों की सूची दी गई है -

  • Instruction Set - यह निर्देशों का सेट है जिसे माइक्रोप्रोसेसर समझ सकता है।

  • Bandwidth - यह एकल निर्देश में संसाधित बिट्स की संख्या है।

  • Clock Speed- यह निर्धारित करता है कि प्रोसेसर प्रति सेकंड कितने ऑपरेशन कर सकता है। इसे मेगाहर्ट्ज़ (मेगाहर्ट्ज) या गीगाहर्ट्ज़ (गीगाहर्ट्ज) में व्यक्त किया जाता है। इसे क्लॉक रेट के रूप में भी जाना जाता है।

  • Word Length- यह आंतरिक डेटा बस, रजिस्टरों, ALU, आदि की चौड़ाई पर निर्भर करता है। एक 8-बिट माइक्रोप्रोसेसर एक बार में 8-बिट डेटा को संसाधित कर सकता है। माइक्रो कंप्यूटर के प्रकार के आधार पर शब्द की लंबाई 4 बिट से लेकर 64 बिट तक होती है।

  • Data Types - माइक्रोप्रोसेसर में बाइनरी, बीसीडी, एएससीआईआई, हस्ताक्षरित और अहस्ताक्षरित संख्याओं जैसे कई डेटा प्रकार प्रारूप हैं।

एक माइक्रोप्रोसेसर की विशेषताएं

यहाँ किसी भी माइक्रोप्रोसेसर की सबसे प्रमुख विशेषताओं में से कुछ की एक सूची है -

  • Cost-effective - माइक्रोप्रोसेसर चिप्स कम कीमत पर उपलब्ध हैं और इसकी कम लागत का परिणाम है।

  • Size - माइक्रोप्रोसेसर छोटे आकार की चिप का होता है, इसलिए यह पोर्टेबल होता है।

  • Low Power Consumption - माइक्रोप्रोसेसर मेटलोक्साइड सेमीकंडक्टर तकनीक का उपयोग करके निर्मित होते हैं, जिसमें कम बिजली की खपत होती है।

  • Versatility - माइक्रोप्रोसेसर बहुमुखी हैं क्योंकि हम सॉफ्टवेयर प्रोग्राम को कॉन्फ़िगर करके एक ही चिप का उपयोग कई अनुप्रयोगों में कर सकते हैं।

  • Reliability - माइक्रोप्रोसेसरों में एक आईसी की विफलता दर बहुत कम है, इसलिए यह विश्वसनीय है।

एक माइक्रोप्रोसेसर को तीन श्रेणियों में वर्गीकृत किया जा सकता है -

RISC प्रोसेसर

RISC का मतलब है Reduced Instruction Set Computer। यह कंप्यूटर के इंस्ट्रक्शन सेट को सरल करके निष्पादन समय को कम करने के लिए डिज़ाइन किया गया है। RISC प्रोसेसर का उपयोग करते हुए, प्रत्येक निर्देश को समान निष्पादन समय में परिणाम निष्पादित करने के लिए केवल एक घड़ी चक्र की आवश्यकता होती है। यह दक्षता कम कर देता है क्योंकि कोड की अधिक लाइनें हैं, इसलिए निर्देशों को संग्रहीत करने के लिए अधिक रैम की आवश्यकता होती है। संकलक को उच्च-स्तरीय भाषा निर्देशों को मशीन कोड में बदलने के लिए अधिक काम करना पड़ता है।

RISC प्रोसेसर में से कुछ हैं -

  • पावर पीसी: 601, 604, 615, 620
  • DEC अल्फा: 210642, 211066, 21068, 21164
  • MIPS: TS (R10000) RISC प्रोसेसर
  • PA-RISC: HP 7100LC

RISC का आर्किटेक्चर

RISC माइक्रोप्रोसेसर आर्किटेक्चर निर्देशों के अत्यधिक-अनुकूलित सेट का उपयोग करता है। इसकी क्षमता के कारण इसका उपयोग Apple iPod जैसे पोर्टेबल उपकरणों में किया जाता है।

आरआईएससी के लक्षण

RISC प्रोसेसर की प्रमुख विशेषताएं इस प्रकार हैं -

  • इसमें सरल निर्देश शामिल हैं।

  • यह विभिन्न डेटा-प्रकार प्रारूपों का समर्थन करता है।

  • यह सरल संबोधित मोड और पाइपलाइनिंग के लिए निश्चित लंबाई निर्देशों का उपयोग करता है।

  • यह किसी भी संदर्भ में उपयोग करने के लिए रजिस्टर का समर्थन करता है।

  • एक चक्र निष्पादन समय।

  • "लोड" और "स्टोर" निर्देशों का उपयोग मेमोरी स्थान तक पहुंचने के लिए किया जाता है।

  • इसमें बड़ी संख्या में रजिस्टर होते हैं।

  • इसमें ट्रांजिस्टर की संख्या कम होती है।

CISC प्रोसेसर

CISC का मतलब है Complex Instruction Set Computer। इसे प्रति प्रोग्राम साइकिल की संख्या को अनदेखा करते हुए, प्रति प्रोग्राम निर्देशों की संख्या को कम करने के लिए डिज़ाइन किया गया है। जोर सीधे हार्डवेयर में जटिल निर्देशों के निर्माण पर है।

कंपाइलर को उच्च स्तरीय भाषा को असेंबली लेवल लैंग्वेज / मशीन कोड में ट्रांसलेट करने के लिए बहुत कम काम करना पड़ता है क्योंकि कोड की लंबाई अपेक्षाकृत कम होती है, इसलिए निर्देशों को स्टोर करने के लिए बहुत कम रैम की आवश्यकता होती है।

CISC प्रोसेसर्स में से कुछ हैं -

  • आईबीएम 370/168
  • वैक्स 11/780
  • इंटेल 80486

CISC का आर्किटेक्चर

इसकी वास्तुकला को स्मृति लागत को कम करने के लिए डिज़ाइन किया गया है क्योंकि बड़े कार्यक्रमों में अधिक भंडारण की आवश्यकता होती है जिसके परिणामस्वरूप उच्च स्मृति लागत होती है। इसे हल करने के लिए, प्रति प्रोग्राम निर्देशों की संख्या को एकल निर्देश में परिचालनों की संख्या को एम्बेड करके कम किया जा सकता है।

CISC के लक्षण

  • संबोधित करने के तरीकों की विविधता।
  • निर्देशों की बड़ी संख्या।
  • अनुदेश प्रारूपों की परिवर्तनीय लंबाई।
  • एक निर्देश को निष्पादित करने के लिए कई चक्रों की आवश्यकता हो सकती है।
  • निर्देश-डिकोडिंग तर्क जटिल है।
  • कई एड्रेसिंग मोड्स को सपोर्ट करने के लिए एक निर्देश की आवश्यकता होती है।

विशेष प्रोसेसर

ये प्रोसेसर हैं जो कुछ विशेष उद्देश्यों के लिए डिज़ाइन किए गए हैं। कुछ विशेष प्रोसेसर के बारे में संक्षेप में चर्चा की गई है -

सह प्रोसेसर

एक कॉपरप्रोसेसर एक विशेष रूप से डिज़ाइन किया गया माइक्रोप्रोसेसर है, जो साधारण माइक्रोप्रोसेसर की तुलना में कई गुना तेजी से अपने विशेष कार्य को संभाल सकता है।

For example - मैथ कॉपप्रोसेसर।

कुछ इंटेल गणित-कोप्रोसेसर हैं -

  • 8087- 8086 के साथ इस्तेमाल किया
  • 80287-80286 के साथ इस्तेमाल किया
  • 80387-80386 के साथ इस्तेमाल किया

इनपुट / आउटपुट प्रोसेसर

यह एक विशेष रूप से डिज़ाइन किया गया माइक्रोप्रोसेसर है जिसकी स्वयं की एक स्थानीय मेमोरी है, जिसका उपयोग न्यूनतम सीपीयू भागीदारी के साथ I / O उपकरणों को नियंत्रित करने के लिए किया जाता है।

For example -

  • डीएमए (डायरेक्ट मेमोरी एक्सेस) कंट्रोलर
  • कीबोर्ड / माउस नियंत्रक
  • ग्राफिक प्रदर्शन नियंत्रक
  • SCSI पोर्ट नियंत्रक

ट्रांसप्यूटर (ट्रांजिस्टर कंप्यूटर)

एक ट्रांसप्यूटर एक विशेष रूप से डिज़ाइन किया गया माइक्रोप्रोसेसर है जिसकी अपनी स्थानीय मेमोरी है और इंटर-प्रोसेसर संचार के लिए एक ट्रांसप्यूटर को दूसरे ट्रांसप्यूटर से जोड़ने के लिए लिंक है। इसे पहली बार 1980 में इनमोस द्वारा डिज़ाइन किया गया था और इसे वीएलएसआई तकनीक के उपयोग के लिए लक्षित किया गया है।

एक ट्रांसप्यूटर को एकल प्रोसेसर सिस्टम के रूप में इस्तेमाल किया जा सकता है या बाहरी लिंक से जोड़ा जा सकता है, जो निर्माण लागत को कम करता है और प्रदर्शन को बढ़ाता है।

For example - 16-बिट T212, 32-बिट T425, फ्लोटिंग पॉइंट (T800, T805 & T9000) प्रोसेसर।

डीएसपी (डिजिटल सिग्नल प्रोसेसर)

इस प्रोसेसर को विशेष रूप से एनालॉग सिग्नल को डिजिटल रूप में संसाधित करने के लिए डिज़ाइन किया गया है। यह नियमित समय अंतराल पर वोल्टेज के स्तर का नमूना लेने और उस तत्काल में वोल्टेज को डिजिटल रूप में परिवर्तित करने के द्वारा किया जाता है। यह प्रक्रिया सर्किट द्वारा डिजिटल कनवर्टर, ए से डी कनवर्टर या एडीसी नामक एनालॉग द्वारा की जाती है।

एक डीएसपी में निम्नलिखित घटक होते हैं -

  • Program Memory - यह उन प्रोग्रामों को संग्रहीत करता है जो डीएसपी डेटा प्रोसेस करने के लिए उपयोग करेंगे।

  • Data Memory - यह संसाधित होने वाली जानकारी संग्रहीत करता है।

  • Compute Engine - यह गणितीय प्रोसेसिंग करता है, प्रोग्राम मेमोरी से प्रोग्राम को एक्सेस करता है और डेटा मेमोरी से डेटा।

  • Input/Output - यह बाहरी दुनिया से जुड़ता है।

इसके अनुप्रयोग हैं -

  • ध्वनि और संगीत संश्लेषण
  • ऑडियो और वीडियो संपीड़न
  • वीडियो सिग्नल प्रोसेसिंग
  • 2 डी और 3 डी ग्राफिक्स त्वरण।

For example - टेक्सास इंस्ट्रूमेंट की टीएमएस 320 श्रृंखला, उदाहरण के लिए, टीएमएस 320 सी 40, टीएमएस 320 सी 50।

8085 को "अस्सी-पचहत्तर" माइक्रोप्रोसेसर के रूप में उच्चारण किया जाता है। यह 1977 में इंटेल द्वारा NMOS तकनीक का उपयोग कर बनाया गया 8-बिट माइक्रोप्रोसेसर है।

इसके निम्नलिखित विन्यास हैं -

  • 8-बिट डेटा बस
  • 16-बिट पता बस, जो 64KB तक संबोधित कर सकता है
  • 16-बिट प्रोग्राम काउंटर
  • 16-बिट स्टैक पॉइंटर
  • छह 8-बिट रजिस्टर जोड़े में व्यवस्थित होते हैं: बीसी, डीई, एचएल
  • 3.2 MHZ एकल चरण घड़ी में संचालित करने के लिए + 5V आपूर्ति की आवश्यकता होती है

इसका उपयोग वॉशिंग मशीन, माइक्रोवेव ओवन, मोबाइल फोन आदि में किया जाता है।

8085 माइक्रोप्रोसेसर - कार्यात्मक इकाइयाँ

8085 में निम्नलिखित कार्यात्मक इकाइयाँ शामिल हैं -

बिजली संचयक यंत्र

यह एक 8-बिट रजिस्टर है जिसका उपयोग अंकगणितीय, तार्किक, I / O & LOAD / STORE संचालन करने के लिए किया जाता है। यह आंतरिक डेटा बस और ALU से जुड़ा है।

अंकगणितीय और तार्किक इकाई

जैसा कि नाम से पता चलता है, यह 8-बिट डेटा पर जोड़, घटाव, और, या, आदि अंकगणित और तार्किक संचालन करता है।

सामान्य प्रयोजन रजिस्टर

8085 प्रोसेसर में 6 सामान्य उद्देश्य रजिस्टर हैं, यानी बी, सी, डी, ई, एच एंड एल। प्रत्येक रजिस्टर में 8-बिट डेटा रखा जा सकता है।

ये रजिस्टर 16-बिट डेटा रखने के लिए जोड़ी में काम कर सकते हैं और उनका युग्म संयोजन बीसी, डीई और एचएल की तरह है।

कार्यक्रम गणक

यह एक 16-बिट रजिस्टर है जिसे निष्पादित किए जाने वाले अगले निर्देश की मेमोरी एड्रेस लोकेशन को स्टोर करने के लिए उपयोग किया जाता है। जब भी कोई निर्देश निष्पादित किया जा रहा है, माइक्रोप्रोसेसर कार्यक्रम को बढ़ाता है, ताकि प्रोग्राम काउंटर अगले निर्देश की मेमोरी पते को इंगित करता है जिसे निष्पादित किया जा रहा है।

स्टेक सूचक

यह स्टैक की तरह 16-बिट रजिस्टर का काम भी करता है, जिसे हमेशा पुश और पॉप ऑपरेशन के दौरान 2 से बढ़ा / घटा दिया जाता है।

अस्थायी रजिस्टर

यह एक 8-बिट रजिस्टर है, जो अंकगणित और तार्किक संचालन का अस्थायी डेटा रखता है।

ध्वज पंजी

यह एक 8-बिट रजिस्टर है जिसमें पांच 1-बिट फ्लिप-फ्लॉप हैं, जो संचायक में संग्रहीत परिणाम के आधार पर या तो 0 या 1 रखता है।

ये हैं 5 फ्लिप-फ्लॉप का सेट -

  • साइन (एस)
  • शून्य (Z)
  • सहायक कैरी (AC)
  • समानता (पी)
  • कैरी (C)

इसकी बिट स्थिति निम्न तालिका में दिखाई गई है -

D7 D6 D5 D4 डी 3 डी 2 डी 1 D0
रों जेड एसी पी सीवाई

निर्देश रजिस्टर और डिकोडर

यह 8-बिट रजिस्टर है। जब कोई निर्देश मेमोरी से लिया जाता है तो उसे इंस्ट्रक्शन रजिस्टर में संग्रहित किया जाता है। निर्देश डिकोडर निर्देश रजिस्टर में मौजूद जानकारी को डिकोड करता है।

समय और नियंत्रण इकाई

यह संचालन करने के लिए माइक्रोप्रोसेसर को समय और नियंत्रण संकेत प्रदान करता है। निम्नलिखित समय और नियंत्रण संकेत हैं, जो बाहरी और आंतरिक सर्किट को नियंत्रित करते हैं -

  • नियंत्रण संकेत: READY, RD ', WR', ALE
  • स्थिति संकेत: S0, S1, IO / M '
  • डीएमए सिग्नल: होल्ड, एचएलडीए
  • RESET सिग्नल: RESET IN, RESET OUT

बाधा पर नियंत्रण

जैसा कि नाम से पता चलता है कि यह एक प्रक्रिया के दौरान व्यवधान को नियंत्रित करता है। जब एक माइक्रोप्रोसेसर मुख्य कार्यक्रम को निष्पादित कर रहा होता है और जब भी कोई व्यवधान उत्पन्न होता है, तो माइक्रोप्रोसेसर आने वाले अनुरोध को संसाधित करने के लिए मुख्य कार्यक्रम से नियंत्रण को स्थानांतरित कर देता है। अनुरोध पूरा होने के बाद, नियंत्रण मुख्य कार्यक्रम पर वापस चला जाता है।

8085 माइक्रोप्रोसेसर में 5 अवरोध संकेत हैं: INTR, RST 7.5, RST 6.5, RST 5.5, TRAP।

सीरियल इनपुट / आउटपुट कंट्रोल

यह इन दो निर्देशों का उपयोग करके धारावाहिक डेटा संचार को नियंत्रित करता है: SID (सीरियल इनपुट डेटा) और SOD (सीरियल आउटपुट डेटा)।

पता बफ़र और पता-डेटा बफ़र

स्टैक पॉइंटर और प्रोग्राम काउंटर में संग्रहीत सामग्री को सीपीयू के साथ संवाद करने के लिए एड्रेस बफर और एड्रेस-डेटा बफर में लोड किया जाता है। मेमोरी और आई / ओ चिप्स इन बसों से जुड़े हैं; सीपीयू मेमोरी और आई / ओ चिप्स के साथ वांछित डेटा का आदान-प्रदान कर सकता है।

पता बस और डेटा बस

डेटा बस डेटा संग्रहीत किया जाता है। यह द्विदिश है, जबकि पता बस उस स्थान को ले जाता है जहां इसे संग्रहीत किया जाना चाहिए और यह यूनिडायरेक्शनल है। इसका उपयोग डेटा और पता I / O उपकरणों को स्थानांतरित करने के लिए किया जाता है।

8085 वास्तुकला

हमने इस चित्र के साथ 8085 की वास्तुकला को चित्रित करने की कोशिश की है -

निम्न चित्र में 8085 माइक्रोप्रोसेसर के पिन आरेख को दर्शाया गया है -

8085 माइक्रोप्रोसेसर के पिन को सात समूहों में वर्गीकृत किया जा सकता है -

पता बस

A15-A8, यह मेमोरी / IO पते की सबसे महत्वपूर्ण 8-बिट्स को वहन करता है।

डेटा बस

AD7-AD0, यह कम से कम महत्वपूर्ण 8-बिट पता और डेटा बस वहन करती है।

नियंत्रण और स्थिति संकेत

इन संकेतों का उपयोग ऑपरेशन की प्रकृति की पहचान करने के लिए किया जाता है। 3 नियंत्रण संकेत और 3 स्थिति संकेत हैं।

तीन नियंत्रण संकेत आरडी, डब्ल्यूआर और एएलई हैं।

  • RD - यह संकेत इंगित करता है कि चयनित IO या मेमोरी डिवाइस को पढ़ना है और डेटा बस पर उपलब्ध डेटा को स्वीकार करने के लिए तैयार है।

  • WR - यह संकेत बताता है कि डेटा बस पर डेटा एक चयनित मेमोरी या IO स्थान में लिखा जाना है।

  • ALE- यह एक पॉजिटिव गोइंग पल्स है, जब माइक्रोप्रोसेसर द्वारा एक नया ऑपरेशन शुरू किया जाता है। जब नाड़ी उच्च जाती है, तो यह पते को इंगित करता है। जब नाड़ी नीचे जाती है तो यह डेटा को इंगित करता है।

तीन स्थिति संकेत IO / M, S0 & S1 हैं।

आईओ / एम

इस सिग्नल का उपयोग IO और मेमोरी ऑपरेशन के बीच अंतर करने के लिए किया जाता है, अर्थात जब यह उच्च होता है तो IO ऑपरेशन इंगित करता है और जब यह कम होता है तो यह संकेत देता है कि यह ऑपरेशन है।

S1 और S0

इन संकेतों का उपयोग वर्तमान ऑपरेशन के प्रकार की पहचान करने के लिए किया जाता है।

बिजली की आपूर्ति

2 बिजली आपूर्ति संकेत हैं - वीसीसी और वीएसएस। वीसीसी इंगित करता है + 5 v बिजली की आपूर्ति और वीएसएस जमीनी संकेत दर्शाता है।

घड़ी के संकेत

3 घड़ी सिग्नल हैं, अर्थात X1, X2, CLK OUT।

  • X1, X2- एक क्रिस्टल (RC, LC N / W) इन दो पिनों से जुड़ा होता है और इसका उपयोग आंतरिक घड़ी जनरेटर की आवृत्ति सेट करने के लिए किया जाता है। इस आवृत्ति को आंतरिक रूप से 2 से विभाजित किया गया है।

  • CLK OUT - इस सिग्नल का उपयोग माइक्रोप्रोसेसर से जुड़े उपकरणों के लिए सिस्टम क्लॉक के रूप में किया जाता है।

व्यवधान और बाहरी रूप से शुरू किए गए संकेत

रुकावट बाहरी उपकरणों द्वारा उत्पन्न सिग्नल हैं जो माइक्रोप्रोसेसर को किसी कार्य को करने के लिए अनुरोध करते हैं। टीआरएपी, आरएसटी 7.5, आरएसटी 6.5, आरएसटी 5.5 और आईएनटीआर, 5 इंटरप्ट सिग्नल हैं। हम इंटरप्ट सेक्शन में विस्तार से चर्चा करेंगे।

  • INTA - यह एक रुकावट पावती संकेत है।

  • RESET IN - इस सिग्नल का उपयोग प्रोग्राम काउंटर को शून्य पर माइक्रोप्रोसेसर को रीसेट करने के लिए किया जाता है।

  • RESET OUT - इस सिग्नल का उपयोग माइक्रोप्रोसेसर के रीसेट होने पर सभी कनेक्टेड डिवाइस को रीसेट करने के लिए किया जाता है।

  • READY- यह संकेत इंगित करता है कि डिवाइस डेटा भेजने या प्राप्त करने के लिए तैयार है। यदि READY कम है, तो CPU को उच्च जाने के लिए READY का इंतजार करना होगा।

  • HOLD - यह संकेत बताता है कि एक अन्य मास्टर पते और डेटा बसों के उपयोग का अनुरोध कर रहा है।

  • HLDA (HOLD Acknowledge)- यह इंगित करता है कि सीपीयू ने होल्ड अनुरोध प्राप्त किया है और यह अगले घड़ी चक्र में बस को फिर से जारी करेगा। होल्ड सिग्नल हटाए जाने के बाद HLDA कम पर सेट होता है।

सीरियल I / O सिग्नल

2 सीरियल सिग्नल हैं, अर्थात SID और SOD और इन संकेतों का उपयोग धारावाहिक संचार के लिए किया जाता है।

  • SOD (सीरियल आउटपुट डेटा लाइन) - सिम निर्देश द्वारा निर्दिष्ट आउटपुट SOD सेट / रीसेट है।

  • SID (सीरियल इनपुट डेटा लाइन) - जब भी रिम निर्देश निष्पादित किया जाता है, तो इस लाइन पर डेटा संचायक में लोड होता है।

अब हम 8085 माइक्रोप्रोसेसर में एड्रेसिंग मोड्स पर चर्चा करते हैं।

8085 में मोड्स को संबोधित करना

ये निर्देश हैं जो डेटा को एक रजिस्टर से दूसरे रजिस्टर में, मेमोरी से रजिस्टर में रजिस्टर करने के लिए, और रजिस्टर से मेमोरी में कंटेंट में किसी भी बदलाव के बिना ट्रांसफर करने के लिए उपयोग किए जाते हैं। 8085 में संबोधित मोड 5 समूहों में वर्गीकृत किया गया है -

तत्काल पता मोड

इस मोड में, 8/16-बिट डेटा को निर्देश में ही निर्दिष्ट किया जाता है। For example: MVI K, 20F: मतलब 20F को रजिस्टर K में कॉपी किया जाता है।

पंजीकरण पता मोड

इस मोड में, डेटा को एक रजिस्टर से दूसरे रजिस्टर में कॉपी किया जाता है। For example: MOV K, B: का अर्थ है रजिस्टर B में डेटा को K रजिस्टर करने के लिए कॉपी किया गया है।

डायरेक्ट एड्रेसिंग मोड

इस मोड में, डेटा सीधे दिए गए पते से रजिस्टर में कॉपी किया जाता है। For example: LDB 5000K: इसका मतलब है कि पता 5000K पर डेटा को बी रजिस्टर करने के लिए कॉपी किया गया है।

अप्रत्यक्ष पता मोड

इस मोड में, डेटा को रजिस्टर द्वारा इंगित पते का उपयोग करके एक रजिस्टर से दूसरे रजिस्टर में स्थानांतरित किया जाता है। For example: एमओवी के, बी: का मतलब है कि डेटा को रजिस्टर द्वारा रजिस्टर किए गए मेमोरी पते से स्थानांतरित किया जाता है।

लागू पता मोड

इस मोड में किसी भी ऑपरेंड की आवश्यकता नहीं है; डेटा स्वयं opcode द्वारा निर्दिष्ट किया गया है।For example: सीएमपी।

8085 में रुकावट

रुकावट बाहरी उपकरणों द्वारा उत्पन्न सिग्नल हैं जो माइक्रोप्रोसेसर को किसी कार्य को करने के लिए अनुरोध करते हैं। टीआरएपी, आरएसटी 7.5, आरएसटी 6.5, आरएसटी 5.5 और आईएनटीआर, 5 इंटरप्ट सिग्नल हैं।

रुकावट को उनके पैरामीटर के आधार पर निम्नलिखित समूहों में वर्गीकृत किया जाता है -

  • Vector interrupt - इस प्रकार के व्यवधान में, बाधित पता प्रोसेसर को ज्ञात होता है। For example: RST7.5, RST6.5, RST5.5, TRAP।

  • Non-Vector interrupt - इस प्रकार के व्यवधान में, बाधित पता प्रोसेसर को ज्ञात नहीं होता है, इसलिए व्यवधान को बाधित करने के लिए उपकरण द्वारा बाहरी पते को बाहरी रूप से भेजने की आवश्यकता होती है। For example: INTR।

  • Maskable interrupt - इस प्रकार के व्यवधान में, हम प्रोग्राम में कुछ निर्देश लिखकर व्यवधान को निष्क्रिय कर सकते हैं। For example: RST7.5, RST6.5, RST5.5।

  • Non-Maskable interrupt - इस प्रकार के व्यवधान में, हम कार्यक्रम में कुछ निर्देश लिखकर इस बाधा को निष्क्रिय नहीं कर सकते। For example: जाल।

  • Software interrupt- इस प्रकार की रुकावट में, प्रोग्रामर को इंटरप्ट को निष्पादित करने के लिए प्रोग्राम में निर्देश जोड़ना पड़ता है। 8085 में 8 सॉफ्टवेयर इंटरप्ट हैं, यानी RST0, RST1, RST2, RST3, RST4, RST5, RST6 और RST7।

  • Hardware interrupt - 8085 में 5 इंटरप्ट पिन होते हैं जिनका उपयोग हार्डवेयर इंटरप्ट, यानी TRAP, RST7.5, RST6.5, RST5.5, INTA के रूप में किया जाता है।

Note- एनटीए एक रुकावट नहीं है, इसका उपयोग माइक्रोप्रोसेसर द्वारा पावती भेजने के लिए किया जाता है। TRAP की सर्वोच्च प्राथमिकता है, तो RST7.5 और इतने पर।

बाधित सेवा दिनचर्या (ISR)

एक छोटा कार्यक्रम या एक रूटीन जिसे निष्पादित करते समय, संबंधित व्यवधान स्रोत को ISR कहा जाता है।

जाल

यह एक गैर-मुखौटा योग्य व्यवधान है, जिसमें सभी व्यवधानों में सर्वोच्च प्राथमिकता है। बायडफॉल्ट, इसे तब तक सक्षम किया जाता है जब तक इसे स्वीकार नहीं किया जाता है। विफलता के मामले में, यह ISR के रूप में निष्पादित होता है और डेटा को बैकअप मेमोरी में भेजता है। यह अवरोध नियंत्रण को 0024H स्थान पर स्थानांतरित करता है।

RST7.5

यह एक नकाबपोश व्यवधान है, जिसमें सभी व्यवधानों के बीच दूसरी सर्वोच्च प्राथमिकता है। जब इस अवरोध को निष्पादित किया जाता है, तो प्रोसेसर पीसी रजिस्टर की सामग्री को स्टैक में सहेजता है और शाखाओं को 003CH पते पर भेजता है।

आरएसटी 6.5

यह एक नकाबपोश व्यवधान है, जिसमें सभी व्यवधानों के बीच तीसरी सर्वोच्च प्राथमिकता है। जब इस रुकावट को निष्पादित किया जाता है, तो प्रोसेसर पीसी रजिस्टर की सामग्री को ढेर में सहेजता है और शाखाओं को 0034H पते पर भेजता है।

आरएसटी 5.5

यह एक नकाबपोश व्यवधान है। जब इस रुकावट को निष्पादित किया जाता है, तो प्रोसेसर पीसी रजिस्टर की सामग्री को स्टैक में सहेजता है और 002CH पते पर शाखाएं देता है।

विस्मयबोधक

यह एक नकाबपोश रुकावट है, सभी अवरोधों में सबसे कम प्राथमिकता है। इसे माइक्रोप्रोसेसर को रीसेट करके अक्षम किया जा सकता है।

कब INTR signal goes highनिम्नलिखित घटनाएं घटित हो सकती हैं -

  • माइक्रोप्रोसेसर प्रत्येक निर्देश के निष्पादन के दौरान INTR सिग्नल की स्थिति की जाँच करता है।

  • जब INTR सिग्नल अधिक होता है, तब माइक्रोप्रोसेसर अपना वर्तमान निर्देश पूरा करता है और सक्रिय कम इंटरप्ट सिग्नल को भेजता है।

  • जब निर्देश प्राप्त होते हैं, तो माइक्रोप्रोसेसर स्टैक पर अगले निर्देश का पता बचाता है और प्राप्त निर्देश को निष्पादित करता है।

आइए हम 8085 माइक्रोप्रोसेसर की प्रोग्रामिंग पर एक नज़र डालें।

निर्देश सेट कुछ कार्य करने के लिए निर्देश कोड हैं। इसे पाँच श्रेणियों में वर्गीकृत किया गया है।

क्र.सं. निर्देश और विवरण
1 नियंत्रण निर्देश

निम्नलिखित तालिका उनके निर्देशों के साथ नियंत्रण निर्देशों की सूची दिखा रही है।

2 तार्किक निर्देश

निम्नलिखित तालिका उनके अर्थ के साथ तार्किक निर्देशों की सूची दिखा रही है।

3 शाखा निर्देश

निम्नलिखित तालिका उनके निर्देशों के साथ शाखाओं के निर्देशों की सूची दिखा रही है।

4 अंकगणितीय निर्देश

निम्नलिखित तालिका उनके अर्थ के साथ अंकगणितीय निर्देशों की सूची दिखा रही है।

5 डेटा ट्रांसफर निर्देश

निम्नलिखित तालिका उनके आंकड़ों के साथ डेटा-स्थानांतरण निर्देशों की सूची दिखा रही है।

8085 - डेमो प्रोग्राम

अब, उपरोक्त निर्देशों का उपयोग करते हुए कुछ कार्यक्रम प्रदर्शनों पर एक नज़र डालते हैं -

दो 8-बिट नंबर जोड़ना

3005H और 3006H मेमोरी लोकेशन पर डेटा जोड़ने और 3007H मेमोरी लोकेशन पर रिजल्ट स्टोर करने के लिए एक प्रोग्राम लिखें।

Problem demo -

(3005H) = 14H 
   (3006H) = 89H

Result -

14H + 89H = 9DH

प्रोग्राम कोड को इस तरह लिखा जा सकता है -

LXI H 3005H   : "HL points 3005H" 
MOV A, M      : "Getting first operand" 
INX H         : "HL points 3006H" 
ADD M         : "Add second operand" 
INX H         : "HL points 3007H" 
MOV M, A      : "Store result at 3007H" 
HLT           : "Exit program"

स्मृति स्थानों का आदान-प्रदान

5000M और 6000M मेमोरी स्थान पर डेटा का आदान-प्रदान करने के लिए एक कार्यक्रम लिखें।

LDA 5000M   : "Getting the contents at5000M location into accumulator" 
MOV B, A    : "Save the contents into B register" 
LDA 6000M   : "Getting the contents at 6000M location into accumulator" 
STA 5000M   : "Store the contents of accumulator at address 5000M" 
MOV A, B    : "Get the saved contents back into A register" 
STA 6000M   : "Store the contents of accumulator at address 6000M"

बढ़ते क्रम में संख्याओं को व्यवस्थित करें

आरोही क्रम में मेमोरी एड्रेस 3000H से पहले 10 नंबरों को व्यवस्थित करने के लिए एक प्रोग्राम लिखें।

MVI B, 09         :"Initialize counter"      
START             :"LXI H, 3000H: Initialize memory pointer" 
MVI C, 09H        :"Initialize counter 2" 
BACK: MOV A, M    :"Get the number" 
INX H             :"Increment memory pointer" 
CMP M             :"Compare number with next number" 
JC SKIP           :"If less, don’t interchange" 
JZ SKIP           :"If equal, don’t interchange" 
MOV D, M 
MOV M, A 
DCX H 
MOV M, D 
INX H             :"Interchange two numbers" 
SKIP:DCR C        :"Decrement counter 2" 
JNZ BACK          :"If not zero, repeat" 
DCR B             :"Decrement counter 1" 
JNZ START 
HLT               :"Terminate program execution"

8086 माइक्रोप्रोसेसर 8085Microprocessor का एक उन्नत संस्करण है जो 1976 में Intel द्वारा डिजाइन किया गया था। यह 16-बिट माइक्रोप्रोसेसर है जिसमें 20 पता लाइनें और 16 डेटा लाइनें हैं जो 1MB संग्रहण प्रदान करती हैं। इसमें शक्तिशाली निर्देश सेट होते हैं, जो आसानी से गुणा और विभाजन जैसे संचालन प्रदान करते हैं।

यह ऑपरेशन के दो मोडों का समर्थन करता है, यानी अधिकतम मोड और न्यूनतम मोड। एक से अधिक प्रोसेसर वाले सिस्टम के लिए अधिकतम मोड उपयुक्त है और सिंगल प्रोसेसर वाले सिस्टम के लिए न्यूनतम मोड उपयुक्त है।

8086 की विशेषताएं

8086 माइक्रोप्रोसेसर की सबसे प्रमुख विशेषताएं इस प्रकार हैं -

  • इसमें एक निर्देश कतार है, जो मेमोरी से छह अनुदेश बाइट को संग्रहीत करने में सक्षम है, जिसके परिणामस्वरूप तेजी से प्रसंस्करण होता है।

  • यह पहला 16-बिट प्रोसेसर था जिसमें 16-बिट ALU, 16-बिट रजिस्टर, आंतरिक डेटा बस और 16-बिट बाहरी डेटा बस थी, जिसके परिणामस्वरूप तेजी से प्रसंस्करण हुआ।

  • यह ऑपरेशन की आवृत्ति के आधार पर 3 संस्करणों में उपलब्ध है -

    • 8086 → 5 मेगाहर्ट्ज

    • 8086-2 → 8 मेगाहर्ट्ज

    • (c) 8086-1 → 10 मेगाहर्ट्ज

  • यह पाइपलाइनिंग के दो चरणों का उपयोग करता है, अर्थात् फ़ेच स्टेज और निष्पादन चरण, जो प्रदर्शन को बेहतर बनाता है।

  • फ़ेच चरण निर्देशों के 6 बाइट्स तक प्रीफ़ैच कर सकता है और उन्हें कतार में संग्रहीत कर सकता है।

  • निष्पादित चरण इन निर्देशों को निष्पादित करता है।

  • इसमें 256 वीच इंटरप्ट हैं।

  • इसमें 29,000 ट्रांजिस्टर शामिल हैं।

8085 और 8086 माइक्रोप्रोसेसर के बीच तुलना

  • Size - 8085 8-बिट माइक्रोप्रोसेसर है, जबकि 8086 16-बिट माइक्रोप्रोसेसर है।

  • Address Bus - 8085 में 16-बिट एड्रेस बस है जबकि 8086 में 20-बिट एड्रेस बस है।

  • Memory - 8085 64Kb तक पहुंच सकता है, जबकि 8086 1 एमबी तक मेमोरी तक पहुंच सकता है।

  • Instruction - 8085 में एक निर्देश कतार नहीं है, जबकि 8086 में एक अनुदेश कतार है।

  • Pipelining - 8085 पाइपलाइड आर्किटेक्चर का समर्थन नहीं करता है जबकि 8086 पाइपलाइड आर्किटेक्चर का समर्थन करता है।

  • I/O - 8085 2 ^ 8 = 256 I / O का पता कर सकता है, जबकि 8086 2 ^ 16 = 65,536 I / O तक पहुंच सकता है।

  • Cost - 8085 की लागत कम है जबकि 8086 की है।

8086 की वास्तुकला

निम्नलिखित चित्र में 8086 माइक्रोप्रोसेसर की वास्तुकला को दर्शाया गया है -

8086 माइक्रोप्रोसेसर को दो कार्यात्मक इकाइयों में विभाजित किया गया है, अर्थात, EU (निष्पादन इकाई) और BIU (बस इंटरफ़ेस यूनिट)।

EU (निष्पादन इकाई)

निष्पादन इकाई बीआईयू को निर्देश देती है कि डेटा कहां से लाएं और फिर उन निर्देशों को डिकोड और निष्पादित करें। इसका कार्य निर्देश डिकोडर और ALU का उपयोग करके डेटा पर संचालन को नियंत्रित करना है। यूरोपीय संघ का सिस्टम बसों के साथ कोई सीधा संबंध नहीं है जैसा कि उपरोक्त आंकड़े में दिखाया गया है, यह BIU के माध्यम से डेटा पर परिचालन करता है।

आइए अब हम 8086 माइक्रोप्रोसेसरों के कार्यात्मक भागों पर चर्चा करते हैं।

आलू

यह सभी अंकगणित और तार्किक संचालन को संभालता है, जैसे +, -, ×, /, या, और, नॉट ऑपरेशंस।

ध्वज पंजी

यह एक 16-बिट रजिस्टर है जो फ्लिप-फ्लॉप की तरह व्यवहार करता है, अर्थात यह संचायक में संग्रहीत परिणाम के अनुसार अपनी स्थिति बदलता है। इसके 9 झंडे हैं और इन्हें 2 समूहों में बांटा गया है - सशर्त झंडे और नियंत्रण झंडे।

सशर्त झंडे

यह अंतिम अंकगणित या निष्पादित तार्किक अनुदेश के परिणाम का प्रतिनिधित्व करता है। निम्नलिखित सशर्त झंडे की सूची है -

  • Carry flag - यह ध्वज अंकगणितीय संचालन के लिए एक अतिप्रवाह स्थिति को इंगित करता है।

  • Auxiliary flag- जब ALU में कोई ऑपरेशन किया जाता है, तो इसका परिणाम निचले नीबेल (यानी D0 - D3) से ऊपरी निबल (यानी D4 - D7) तक कैरी / बैरो होता है, तब यह ध्वज सेट होता है, अर्थात D3 बिट द्वारा D4 को दिया जाता है। वायुसेना ध्वज। प्रोसेसर बीसीडी रूपांतरण के लिए द्विआधारी प्रदर्शन करने के लिए इस ध्वज का उपयोग करता है।

  • 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-बिट रजिस्टर है जिसे निष्पादित करने के लिए अगले निर्देश का पता रखने के लिए उपयोग किया जाता है।

8086 पहला 16-बिट माइक्रोप्रोसेसर था जो 40-पिन डीआईपी (डुअल इनलाइन पैकेज) चिप में उपलब्ध था। आइए अब विस्तार से चर्चा करते हैं 8086 माइक्रोप्रोसेसर के पिन विन्यास के बारे में।

8086 पिन आरेख

यहाँ 8086 माइक्रोप्रोसेसर का पिन आरेख है -

आइए अब विस्तार से संकेतों पर चर्चा करते हैं -

Power supply and frequency signals

यह वी सीसी पिन 40 पर 5 वी डीसी आपूर्ति का उपयोग करता है, और इसके संचालन के लिए वी एसएस पिन 1 और 20 पर जमीन का उपयोग करता है ।

Clock signal

पिन -19 के माध्यम से घड़ी संकेत दिया जाता है। यह संचालन के लिए प्रोसेसर को समय प्रदान करता है। इसकी आवृत्ति अलग-अलग संस्करणों के लिए भिन्न होती है, अर्थात 5MHz, 8MHz और 10MHz।

Address/data bus

AD0-AD15। ये 16 पते / डेटा बस हैं। AD0-AD7 कम ऑर्डर बाइट डेटा और AD8AD15 उच्च आदेश बाइट डेटा वहन करती है। पहले घड़ी चक्र के दौरान, यह 16-बिट पते को ले जाता है और इसके बाद यह 16-बिट डेटा को ले जाता है।

Address/status bus

A16-A19 / S3-S6। ये 4 पता / स्टेटस बसें हैं। पहले घड़ी चक्र के दौरान, यह 4-बिट पते को ले जाता है और बाद में यह स्थिति संकेतों को वहन करता है।

S7/BHE

BHE का मतलब बस हाई इनेबल है। यह पिन 34 पर उपलब्ध है और डेटा बस डी 8-डी 15 का उपयोग करके डेटा के हस्तांतरण का संकेत देता है। यह संकेत पहले घड़ी चक्र के दौरान कम है, इसके बाद यह सक्रिय है।

Read($\overline{RD}$)

यह पिन 32 पर उपलब्ध है और रीड ऑपरेशन के लिए सिग्नल पढ़ने के लिए उपयोग किया जाता है।

Ready

यह पिन 22 पर उपलब्ध है। यह I / O उपकरणों से एक पावती संकेत है जो डेटा स्थानांतरित किया जाता है। यह एक सक्रिय उच्च संकेत है। जब यह उच्च होता है, तो यह इंगित करता है कि डिवाइस डेटा स्थानांतरित करने के लिए तैयार है। जब यह कम होता है, तो यह प्रतीक्षा स्थिति को इंगित करता है।

RESET

यह पिन 21 पर उपलब्ध है और निष्पादन को पुनः आरंभ करने के लिए उपयोग किया जाता है। यह प्रोसेसर को उसकी वर्तमान गतिविधि को तुरंत समाप्त करने का कारण बनता है। यह संकेत माइक्रोप्रोसेसर को रीसेट करने के लिए पहले 4 घड़ी चक्रों के लिए सक्रिय है।

INTR

यह पिन 18 पर उपलब्ध है। यह एक बाधा अनुरोध संकेत है, जिसे यह निर्धारित करने के लिए प्रत्येक निर्देश के अंतिम घड़ी चक्र के दौरान नमूना किया जाता है कि प्रोसेसर ने इसे एक बाधा माना या नहीं।

NMI

यह गैर-नकाबपोश रुकावट के लिए खड़ा है और पिन 17 पर उपलब्ध है। यह एक बढ़त ट्रिगर इनपुट है, जो माइक्रोप्रोसेसर के लिए एक बाधा अनुरोध का कारण बनता है।

$\overline{TEST}$

यह सिग्नल प्रतीक्षा स्थिति की तरह है और यह पिन 23 पर उपलब्ध है। जब यह संकेत अधिक होता है, तो प्रोसेसर को IDLE स्थिति की प्रतीक्षा करनी होती है, अन्यथा निष्पादन जारी रहता है।

MN/$\overline{MX}$

यह न्यूनतम / अधिकतम के लिए खड़ा है और पिन 33 पर उपलब्ध है। यह इंगित करता है कि प्रोसेसर किस मोड में काम करना है; जब यह उच्च होता है, तो यह न्यूनतम मोड और इसके विपरीत में काम करता है।

INTA

यह एक पावती पावती संकेत है और पिन 24 पर उपलब्ध है। जब माइक्रोप्रोसेसर को यह संकेत मिलता है, तो यह रुकावट को स्वीकार करता है।

ALE

यह पता सक्षम करने के लिए खड़ा है और 25 पिन पर उपलब्ध है। एक सकारात्मक पल्स उत्पन्न होने पर हर बार प्रोसेसर किसी भी ऑपरेशन को शुरू करता है। यह संकेत पता / डेटा लाइनों पर एक वैध पते की उपलब्धता को इंगित करता है।

DEN

यह डेटा सक्षम करने के लिए खड़ा है और पिन 26 पर उपलब्ध है। इसका उपयोग ट्रांसरेसीवर 8286 को सक्षम करने के लिए किया जाता है। ट्रांसीवर एक ऐसा उपकरण है जिसका उपयोग पता / डेटा बस से डेटा को अलग करने के लिए किया जाता है।

DT/R

यह डेटा ट्रांसमिट / रिसीव सिग्नल के लिए खड़ा है और पिन 27 पर उपलब्ध है। यह ट्रांसीवर के माध्यम से डेटा प्रवाह की दिशा तय करता है। जब यह उच्च होता है, तो डेटा को प्रेषित किया जाता है और इसके विपरीत।

M/IO

इस सिग्नल का उपयोग मेमोरी और I / O संचालन के बीच अंतर करने के लिए किया जाता है। जब यह उच्च होता है, तो यह I / O ऑपरेशन को इंगित करता है और जब यह कम होता है तो मेमोरी ऑपरेशन को दर्शाता है। यह पिन 28 पर उपलब्ध है।

WR

यह लिखने के संकेत के लिए खड़ा है और पिन 29 पर उपलब्ध है। इसका उपयोग एम / आईओ सिग्नल की स्थिति के आधार पर डेटा को मेमोरी या आउटपुट डिवाइस में लिखने के लिए किया जाता है।

HLDA

यह होल्ड एग्लिबिलेशन सिग्नल के लिए है और यह पिन 30 पर उपलब्ध है। यह सिग्नल होल्ड सिग्नल को स्वीकार करता है।

HOLD

यह संकेत प्रोसेसर को इंगित करता है कि बाहरी डिवाइस पते / डेटा बसों तक पहुंचने का अनुरोध कर रहे हैं। यह पिन 31 पर उपलब्ध है।

QS1 and QS0

ये कतार स्थिति संकेत हैं और पिन 24 और 25 पर उपलब्ध हैं। ये संकेत अनुदेश कतार की स्थिति प्रदान करते हैं। उनकी शर्तों को निम्न तालिका में दिखाया गया है -

QS 0 क्यूएस स्थिति
0 0 कोई ऑपरेशन नहीं
0 1 कतार से opcode का पहला बाइट
1 0 कतार खाली करो
1 1 कतार से बाद में बाइट

S0, S1, S2

ये स्थिति संकेत हैं जो ऑपरेशन की स्थिति प्रदान करते हैं, जिसका उपयोग बस नियंत्रक 8288 द्वारा मेमोरी और I / O नियंत्रण संकेतों को उत्पन्न करने के लिए किया जाता है। ये पिन 26, 27 और 28 पर उपलब्ध हैं। निम्नलिखित तालिका उनकी स्थिति दर्शा रही है -

एस 2 एस 1 S 0 स्थिति
0 0 0 बाधा पावती
0 0 1 मैं / ओ पढ़ें
0 1 0 मैं / हे लिख
0 1 1 पड़ाव
1 0 0 ओपकोड लाना
1 0 1 स्मृति पढ़ी
1 1 0 मेमोरी लिखिए
1 1 1 निष्क्रिय

LOCK

जब यह संकेत सक्रिय होता है, तो यह अन्य प्रोसेसर को इंगित करता है कि सीपीयू को सिस्टम बस को छोड़ने के लिए न कहें। यह किसी भी निर्देश पर LOCK उपसर्ग का उपयोग करके सक्रिय है और पिन 29 पर उपलब्ध है।

RQ/GT1 and RQ/GT0

ये अन्य प्रोसेसर द्वारा उपयोग किए जाने वाले अनुरोध / अनुदान संकेत हैं जो सिस्टम बस को जारी करने के लिए सीपीयू का अनुरोध करते हैं। जब सिग्नल सीपीयू द्वारा प्राप्त किया जाता है, तो यह पावती भेजता है। RQ / GT 0 में RQ / GT 1 की तुलना में अधिक प्राथमिकता है ।

8086 माइक्रोप्रोसेसर 8 प्रकार के निर्देशों का समर्थन करता है -

  • डेटा ट्रांसफर निर्देश
  • अंकगणितीय निर्देश
  • बिट मैनिपुलेशन निर्देश
  • स्ट्रिंग निर्देश
  • कार्यक्रम निष्पादन स्थानांतरण निर्देश (शाखा और लूप निर्देश)
  • प्रोसेसर नियंत्रण निर्देश
  • Iteration नियंत्रण निर्देश
  • बाधा निर्देश

आइए अब इन अनुदेश सेटों पर विस्तार से चर्चा करते हैं।

डेटा ट्रांसफर निर्देश

इन निर्देशों का उपयोग स्रोत ऑपरेंड से गंतव्य ऑपरेंड तक डेटा स्थानांतरित करने के लिए किया जाता है। इस समूह के अंतर्गत निर्देशों की सूची निम्नलिखित है -

किसी शब्द को स्थानांतरित करने का निर्देश

  • MOV - उपलब्ध स्रोत से बाइट या शब्द की प्रतिलिपि उपलब्ध कराए गए गंतव्य के लिए उपयोग की जाती है।

  • PPUSH - स्टैक के शीर्ष पर एक शब्द लगाने के लिए उपयोग किया जाता है।

  • POP - स्टैक के ऊपर से दिए गए स्थान पर एक शब्द प्राप्त करने के लिए उपयोग किया जाता है।

  • PUSHA - सभी रजिस्टर को स्टैक में डालने के लिए उपयोग किया जाता है।

  • POPA - स्टैक से सभी रजिस्टरों के लिए शब्द मिलते थे।

  • XCHG - दो स्थानों से डेटा का आदान-प्रदान करने के लिए उपयोग किया जाता है।

  • XLAT - मेमोरी में टेबल का उपयोग करके AL में एक बाइट का अनुवाद करने के लिए उपयोग किया जाता है।

इनपुट और आउटपुट पोर्ट ट्रांसफर के निर्देश

  • IN - उपलब्ध बंदरगाह से संचयकर्ता को एक बाइट या शब्द पढ़ने के लिए उपयोग किया जाता है।

  • OUT - संचयकर्ता से प्रदान किए गए पोर्ट पर एक बाइट या शब्द भेजने के लिए उपयोग किया जाता है।

पते को स्थानांतरित करने के निर्देश

  • LEA - प्रदान किए गए रजिस्टर में ऑपरेंड के पते को लोड करने के लिए उपयोग किया जाता है।

  • LDS - मेमोरी से डीएस रजिस्टर और अन्य प्रदान किए गए रजिस्टर को लोड करने के लिए उपयोग किया जाता है

  • LES - मेमोरी से ES रजिस्टर और अन्य प्रदान किए गए रजिस्टर को लोड करने के लिए उपयोग किया जाता है।

ध्वज पंजी को हस्तांतरित करने के निर्देश

  • LAHF - ध्वज रजिस्टर के कम बाइट के साथ एएच को लोड करने के लिए उपयोग किया जाता है।

  • SAHF - AH रजिस्टर को फ्लैग रजिस्टर के लो बाइट में स्टोर किया जाता है।

  • PUSHF - स्टैक के शीर्ष पर ध्वज रजिस्टर की प्रतिलिपि बनाने के लिए उपयोग किया जाता है।

  • POPF - स्टैक के शीर्ष पर एक शब्द को ध्वज रजिस्टर में कॉपी करने के लिए उपयोग किया जाता है।

अंकगणितीय निर्देश

इन निर्देशों का उपयोग अंकगणित संचालन जैसे कि जोड़, घटाव, गुणा, भाग, आदि करने के लिए किया जाता है।

इस समूह के तहत निर्देशों की सूची निम्नलिखित है -

इसके अलावा प्रदर्शन करने के निर्देश दिए

  • ADD - उपलब्ध बाइट को बाइट / शब्द से शब्द में जोड़ने के लिए उपयोग किया जाता है।

  • ADC - कैरी के साथ जोड़ते थे।

  • INC - उपलब्ध बाइट / शब्द को 1 से बढ़ाना।

  • AAA - इसके अलावा ASCII को समायोजित करने के लिए उपयोग किया जाता है।

  • DAA - जोड़ / घटाव ऑपरेशन के बाद दशमलव को समायोजित करने के लिए उपयोग किया जाता है।

घटाव प्रदर्शन करने के निर्देश

  • SUB - शब्द से बाइट / शब्द से बाइट को घटाना।

  • SBB - उधार के साथ घटाव प्रदर्शन करने के लिए इस्तेमाल किया।

  • DEC - दिए गए बाइट / शब्द को 1 से घटाना।

  • NPG - उपलब्ध बाइट / शब्द के प्रत्येक बिट को नकारने और 1/2 के पूरक को जोड़ने के लिए उपयोग किया जाता है।

  • CMP - 2 प्रदान बाइट / शब्द की तुलना करने के लिए इस्तेमाल किया।

  • AAS - घटाव के बाद ASCII कोड समायोजित करने के लिए उपयोग किया जाता है।

  • DAS - घटाव के बाद दशमलव को समायोजित करने के लिए उपयोग किया जाता है।

गुणा करने का निर्देश

  • MUL - शब्द द्वारा बाइट / शब्द से अनसॉल्टेड बाइट को गुणा करने के लिए उपयोग किया जाता है।

  • IMUL - शब्द द्वारा बाइट / शब्द से बाइट पर हस्ताक्षर करने के लिए उपयोग किया जाता है।

  • AAM - गुणा के बाद ASCII कोड समायोजित करने के लिए उपयोग किया जाता है।

विभाजन करने के निर्देश

  • DIV − Used to divide the unsigned word by byte or unsigned double word by word.

  • IDIV − Used to divide the signed word by byte or signed double word by word.

  • AAD − Used to adjust ASCII codes after division.

  • CBW − Used to fill the upper byte of the word with the copies of sign bit of the lower byte.

  • CWD − Used to fill the upper word of the double word with the sign bit of the lower word.

Bit Manipulation Instructions

These instructions are used to perform operations where data bits are involved, i.e. operations like logical, shift, etc.

Following is the list of instructions under this group −

Instructions to perform logical operation

  • NOT − Used to invert each bit of a byte or word.

  • AND − Used for adding each bit in a byte/word with the corresponding bit in another byte/word.

  • OR − Used to multiply each bit in a byte/word with the corresponding bit in another byte/word.

  • XOR − Used to perform Exclusive-OR operation over each bit in a byte/word with the corresponding bit in another byte/word.

  • TEST − Used to add operands to update flags, without affecting operands.

Instructions to perform shift operations

  • SHL/SAL − Used to shift bits of a byte/word towards left and put zero(S) in LSBs.

  • SHR − Used to shift bits of a byte/word towards the right and put zero(S) in MSBs.

  • SAR − Used to shift bits of a byte/word towards the right and copy the old MSB into the new MSB.

Instructions to perform rotate operations

  • ROL − Used to rotate bits of byte/word towards the left, i.e. MSB to LSB and to Carry Flag [CF].

  • ROR − Used to rotate bits of byte/word towards the right, i.e. LSB to MSB and to Carry Flag [CF].

  • RCR − Used to rotate bits of byte/word towards the right, i.e. LSB to CF and CF to MSB.

  • RCL − Used to rotate bits of byte/word towards the left, i.e. MSB to CF and CF to LSB.

String Instructions

String is a group of bytes/words and their memory is always allocated in a sequential order.

Following is the list of instructions under this group −

  • REP − Used to repeat the given instruction till CX ≠ 0.

  • REPE/REPZ − Used to repeat the given instruction until CX = 0 or zero flag ZF = 1.

  • REPNE/REPNZ − Used to repeat the given instruction until CX = 0 or zero flag ZF = 1.

  • MOVS/MOVSB/MOVSW − Used to move the byte/word from one string to another.

  • COMS/COMPSB/COMPSW − Used to compare two string bytes/words.

  • INS/INSB/INSW − Used as an input string/byte/word from the I/O port to the provided memory location.

  • OUTS/OUTSB/OUTSW − Used as an output string/byte/word from the provided memory location to the I/O port.

  • SCAS/SCASB/SCASW − Used to scan a string and compare its byte with a byte in AL or string word with a word in AX.

  • LODS/LODSB/LODSW − Used to store the string byte into AL or string word into AX.

कार्यक्रम निष्पादन स्थानांतरण निर्देश (शाखा और लूप निर्देश)

इन निर्देशों का उपयोग निष्पादन के दौरान निर्देशों को स्थानांतरित / शाखा करने के लिए किया जाता है। इसमें निम्नलिखित निर्देश शामिल हैं -

बिना किसी शर्त के निष्पादन के दौरान निर्देश हस्तांतरित करने के निर्देश -

  • CALL - एक प्रक्रिया को कॉल करने और स्टैक पर उनके रिटर्न पते को बचाने के लिए उपयोग किया जाता है।

  • RET - प्रक्रिया से मुख्य कार्यक्रम में लौटने के लिए उपयोग किया जाता है।

  • JMP - अगले निर्देश पर आगे बढ़ने के लिए दिए गए पते पर जाएं।

कुछ शर्तों के साथ निष्पादन के दौरान निर्देश स्थानांतरित करने के निर्देश -

  • JA/JNBE - ऊपर / नीचे निर्देश के बराबर / संतोषजनक होने पर कूदने के लिए उपयोग किया जाता है।

  • JAE/JNB - यदि निर्देश से ऊपर / नीचे नहीं तो संतोष प्राप्त करने के लिए कूदते थे।

  • JBE/JNA - यदि नीचे / बराबर / ऊपर की ओर कूदने के लिए उपयोग किया जाता है तो अनुदेश संतुष्ट नहीं होता है।

  • JC - झंडा ले जाने के लिए उपयोग किया जाता है तो झंडा CF = 1

  • JE/JZ - बराबर / शून्य ध्वज ZF = 1 होने पर कूदने के लिए उपयोग किया जाता है

  • JG/JNLE - अधिक से अधिक / बराबर अनुदेश से कम / संतुष्ट नहीं होने पर कूदने के लिए उपयोग किया जाता है।

  • JGE/JNL - यदि निर्देश / संतुष्टि से कम / अधिक / बराबर नहीं तो कूदने के लिए उपयोग किया जाता है।

  • JL/JNGE - से कम / अधिक से अधिक / बराबर निर्देश संतोषजनक होने पर कूदने के लिए उपयोग किया जाता है।

  • JLE/JNG - कम से कम / बराबर / यदि निर्देश से अधिक नहीं है तो कूदने के लिए उपयोग किया जाता है।

  • JNC - अगर कोई कैरी फ्लैग नहीं कूदता है (CF = 0)

  • JNE/JNZ - बराबर / शून्य ध्वज ZF = 0 नहीं तो कूदने के लिए उपयोग किया जाता है

  • JNO - जंप करने के लिए उपयोग किया जाता है अगर कोई अतिप्रवाह का ध्वज = 0 नहीं है

  • JNP/JPO - समता / समता विषम पीएफ = 0 नहीं तो कूदने के लिए उपयोग किया जाता है

  • JNS - SF = 0 पर हस्ताक्षर नहीं करने पर कूदने के लिए प्रयुक्त

  • JO - का प्रयोग किया जाता है कूद अगर overflow झंडा = 1

  • JP/JPE - समता / समता यहां तक ​​कि पीएफ = 1 होने पर कूदते थे

  • JS - साइन फ्लैग SF = 1 होने पर कूदने के लिए उपयोग किया जाता है

प्रोसेसर नियंत्रण निर्देश

इन निर्देशों का उपयोग ध्वज मानों को सेट / रीसेट करके प्रोसेसर कार्रवाई को नियंत्रित करने के लिए किया जाता है।

इस समूह के तहत निर्देश निम्नलिखित हैं -

  • STC - कैरी फ्लैग CF को 1 पर सेट करने के लिए उपयोग किया जाता है

  • CLC - क्लीयर / रीसेट कैरी फ्लैग CF को 0 पर उपयोग किया जाता है

  • CMC - कैरी फ्लैग सीएफ के राज्य में पूरक लगाने के लिए उपयोग किया जाता है।

  • STD - दिशा ध्वजा DF को 1 पर सेट करने के लिए उपयोग किया जाता है

  • CLD - दिशा ध्वज DF को 0 पर साफ़ / रीसेट करने के लिए उपयोग किया जाता है

  • STI - बाधा सक्षम ध्वज को 1 पर सेट करने के लिए उपयोग किया जाता है, अर्थात, INTR इनपुट को सक्षम करें।

  • CLI - इंटरप्ट फ्लैग को 0 में सक्षम करने के लिए उपयोग किया जाता है, अर्थात, INTR इनपुट को अक्षम करें।

Iteration नियंत्रण निर्देश

इन निर्देशों का उपयोग कई बार दिए गए निर्देशों को निष्पादित करने के लिए किया जाता है। इस समूह के तहत निर्देशों की सूची निम्नलिखित है -

  • LOOP - जब तक कि स्थिति संतुष्ट न हो जाए, तब तक निर्देशों का एक समूह लूप करें, अर्थात सीएक्स = 0

  • LOOPE/LOOPZ - जब तक यह ZF = 1 और CX = 0 को संतुष्ट नहीं करता तब तक निर्देशों के एक समूह का उपयोग करें

  • LOOPNE/LOOPNZ - जब तक यह ZF = 0 और CX = 0 को संतुष्ट नहीं करता है तब तक निर्देशों के एक समूह का उपयोग करें

  • JCXZ - दिए गए पते पर कूदने के लिए उपयोग किया जाता है अगर CX = 0

बाधा निर्देश

इन निर्देशों का उपयोग प्रोग्राम निष्पादन के दौरान व्यवधान को कॉल करने के लिए किया जाता है।

  • INT - निर्दिष्ट निष्पादन और कॉलिंग सेवा के दौरान कार्यक्रम को बाधित करने के लिए उपयोग किया जाता है।

  • INTO - यदि 1 = यदि निष्पादन के दौरान कार्यक्रम को बाधित किया जाता है

  • IRET - मुख्य कार्यक्रम के लिए इंटरप्ट सेवा से लौटने के लिए उपयोग किया जाता है

Interruptकार्यक्रम के निष्पादन के दौरान एक अस्थायी पड़ाव बनाने की विधि है और परिधीय उपकरणों को माइक्रोप्रोसेसर तक पहुंचने की अनुमति देता है। माइक्रोप्रोसेसर एक के साथ उस रुकावट का जवाब देता हैISR (इंटरप्ट सर्विस रूटीन), जो रुकावट को संभालने के तरीके पर माइक्रोप्रोसेसर को निर्देश देने के लिए एक छोटा कार्यक्रम है।

निम्नलिखित छवि 8086 माइक्रोप्रोसेसर में हमारे द्वारा बाधित किए गए प्रकारों को दिखाती है -

हार्डवेयर में बाधा

हार्डवेयर अवरोध किसी भी परिधीय उपकरण द्वारा माइक्रोप्रोसेसर को एक निर्दिष्ट पिन के माध्यम से सिग्नल भेजने के कारण होता है।

8086 में दो हार्डवेयर इंटरप्ट पिन यानी NMI और INTR हैं। एनएमआई एक गैर-मुखौटा योग्य व्यवधान है और INTR कम प्राथमिकता वाले एक मुखौटा योग्य बाधा है। एक और इंटरप्ट पिन जुड़ा है जिसे INTA कहा जाता है जिसे इंटरप्ट एक्सेलेबल कहा जाता है

एनएमआई

यह एक एकल गैर-नकाबपोश इंटरप्ट पिन (NMI) है जो नकाबपोश रुकावट अनुरोध पिन (INTR) की तुलना में अधिक प्राथमिकता रखता है और यह टाइप 2 रुकावट का है।

जब यह व्यवधान सक्रिय होता है, तो ये क्रियाएं होती हैं -

  • उस वर्तमान निर्देश को पूरा करता है जो प्रगति पर है।

  • स्टैक पर ध्वज रजिस्टर मूल्यों को धक्का देता है।

  • CS (कोड सेगमेंट) मान और IP (इंस्ट्रक्शन पॉइंटर) मान को स्टैक पर दिए गए पते पर दबाता है।

  • IP शब्द 00008H स्थान की सामग्री से लोड किया गया है।

  • CS को अगले शब्द स्थान 0000AH की सामग्री से लोड किया गया है।

  • इंटरप्ट फ्लैग और ट्रैप फ्लैग को 0 पर रीसेट किया जाता है।

विस्मयबोधक

INTR एक नकाबपोश रुकावट है क्योंकि माइक्रोप्रोसेसर केवल तभी बाधित होगा जब इंटरप्ट को सेट इंटरप्ट फ़्लैग इंस्ट्रक्शन का उपयोग करके सक्षम किया जाता है। इसे स्पष्ट व्यवधान ध्वज निर्देश का उपयोग करके सक्षम नहीं किया जाना चाहिए।

INTR अवरोध I / O पोर्ट द्वारा सक्रिय होता है। यदि अवरोध सक्षम है और NMI अक्षम है, तो माइक्रोप्रोसेसर पहले वर्तमान निष्पादन को पूरा करता है और दो बार INTA पिन पर '0' भेजता है। पहले '0' का मतलब है कि INTA तैयार होने के लिए बाहरी डिवाइस को सूचित करता है और दूसरे '0' के दौरान माइक्रोप्रोसेसर को प्रोग्रामेबल इंटरप्ट कंट्रोलर से 8 बिट, एक्स कहते हैं।

ये क्रियाएं माइक्रोप्रोसेसर द्वारा की जाती हैं -

  • पहले वर्तमान निर्देश को पूरा करता है।

  • X का कहना है कि INTA आउटपुट को सक्रिय करता है और इंटरप्ट प्रकार प्राप्त करता है।

  • फ्लैग रजिस्टर मूल्य, रिटर्न एड्रेस का सीएस मूल्य और रिटर्न एड्रेस का आईपी मूल्य स्टैक पर धकेल दिया जाता है।

  • IP मान शब्द स्थान X × 4 की सामग्री से लोड किया गया है

  • CS को अगले शब्द स्थान की सामग्री से लोड किया गया है।

  • इंटरप्ट फ्लैग और ट्रैप फ्लैग को 0 पर रीसेट किया जाता है

सॉफ्टवेयर में बाधा

कुछ निर्देश इंटरप्ट बनाने के लिए कार्यक्रम में वांछित स्थिति में डाले जाते हैं। इन रुकावट निर्देशों का उपयोग विभिन्न रुकावट संचालकों के काम का परीक्षण करने के लिए किया जा सकता है। इसमें शामिल हैं -

INT- टाइप संख्या के साथ बाधित निर्देश

यह 2-बाइट अनुदेश है। पहला बाइट ऑप-कोड प्रदान करता है और दूसरा बाइट इंटरप्ट प्रकार संख्या प्रदान करता है। इस समूह के अंतर्गत 256 बाधा प्रकार हैं।

इसके निष्पादन में निम्नलिखित चरण शामिल हैं -

  • फ्लैग रजिस्टर मूल्य स्टैक पर धकेल दिया जाता है।

  • रिटर्न एड्रेस का CS मान और रिटर्न एड्रेस का IP मान स्टैक पर धकेल दिया जाता है।

  • IP शब्द 'लोकेशन नंबर टाइप' × 4 के कंटेंट से भरा गया है

  • CS को अगले शब्द स्थान की सामग्री से लोड किया गया है।

  • इंटरप्ट फ्लैग और ट्रैप फ्लैग को 0 पर रीसेट किया जाता है

Type0 इंटरप्ट के लिए शुरुआती पता 000000H है, टाइप 1 इंटरप्ट के लिए 00004H है इसी तरह टाइप 2 के लिए 00008H है और …… इत्यादि। पहले पाँच पॉइंट्स इंटरप्ट पॉइंटर्स समर्पित हैं। अर्थात -

  • TYPE 0 व्यवधान शून्य स्थिति से विभाजन का प्रतिनिधित्व करता है।

  • TYPE 1 किसी प्रोग्राम की डीबगिंग के दौरान व्यवधान एकल-चरण निष्पादन का प्रतिनिधित्व करता है।

  • TYPE 2 व्यवधान गैर-मुखौटा योग्य NMI अवरोध का प्रतिनिधित्व करता है।

  • TYPE 3 व्यवधान ब्रेक-पॉइंट इंटरप्ट का प्रतिनिधित्व करता है।

  • TYPE 4 व्यवधान अतिप्रवाह अवरोध का प्रतिनिधित्व करता है।

टाइप 5 से टाइप 31 के बीच की रुकावट अन्य उन्नत माइक्रोप्रोसेसरों के लिए आरक्षित हैं, और 32 से टाइप 255 के बीच के अंतर हार्डवेयर और सॉफ्टवेयर इंटरप्ट के लिए उपलब्ध हैं।

INT 3-ब्रेक प्वाइंट इंटरप्ट निर्देश

यह एक 1-बाइट अनुदेश है जिसमें ऑप-कोड CCH है। इन निर्देशों को प्रोग्राम में डाला जाता है ताकि जब प्रोसेसर वहां पहुंचे, तो यह प्रोग्राम के सामान्य निष्पादन को रोक देता है और ब्रेक-पॉइंट प्रक्रिया का पालन करता है।

इसके निष्पादन में निम्नलिखित चरण शामिल हैं -

  • फ्लैग रजिस्टर मूल्य स्टैक पर धकेल दिया जाता है।

  • रिटर्न एड्रेस का CS मान और रिटर्न एड्रेस का IP मान स्टैक पर धकेल दिया जाता है।

  • IP शब्द 3 × 4 = 0000CH स्थान की सामग्री से भरा हुआ है

  • CS को अगले शब्द स्थान की सामग्री से लोड किया गया है।

  • इंटरप्ट फ्लैग और ट्रैप फ्लैग को 0 पर रीसेट किया जाता है

INTO - ओवरफ्लो निर्देश पर रुकावट

यह एक 1-बाइट अनुदेश है और उनके mnemonic है INTO। इस निर्देश के लिए op- कोड CEH है। जैसा कि नाम से पता चलता है कि यह एक सशर्त अवरोध अनुदेश है, अर्थात यह तभी सक्रिय होता है जब ओवरफ्लो ध्वज 1 पर सेट हो जाता है और शाखाएँ उस बाधा हैंडलर के पास आती हैं, जिसका व्यवधान प्रकार संख्या 4 है। यदि ओवरफ़्लो ध्वज को रीसेट किया जाता है, तो निष्पादन जारी रहता है। अगला निर्देश।

इसके निष्पादन में निम्नलिखित चरण शामिल हैं -

  • फ्लैग रजिस्टर मूल्यों को स्टैक पर धकेल दिया जाता है।

  • रिटर्न एड्रेस का CS मान और रिटर्न एड्रेस का IP मान स्टैक पर धकेल दिया जाता है।

  • IP शब्द स्थान 4 × 4 = 00010H की सामग्री से लोड किया गया है

  • CS को अगले शब्द स्थान की सामग्री से लोड किया गया है।

  • इंटरप्ट फ्लैग और ट्रैप फ्लैग को 0 पर रीसेट किया जाता है

एक निर्देश में एक स्रोत ऑपरेंड को निरूपित करने के विभिन्न तरीकों को कहा जाता है addressing modes। 8086 प्रोग्रामिंग में 8 अलग-अलग एड्रेसिंग मोड हैं -

तत्काल पता मोड

एड्रेसिंग मोड जिसमें डेटा ऑपरेंड निर्देश का एक हिस्सा होता है, उसे तत्काल एड्रेसिंग मोड के रूप में जाना जाता है।

उदाहरण

MOV CX, 4929 H, ADD AX, 2387 H,  MOV AL, FFH

पंजीकरण पता मोड

इसका मतलब है कि रजिस्टर एक निर्देश के लिए एक ऑपरेंड का स्रोत है।

उदाहरण

MOV CX, AX   ; copies the contents of the 16-bit AX register into  
             ; the 16-bit CX register),  
ADD BX, AX

डायरेक्ट एड्रेसिंग मोड

एड्रेसिंग मोड जिसमें मेमोरी लोकेशन का प्रभावी पता सीधे निर्देश में लिखा होता है।

उदाहरण

MOV AX, [1592H], MOV AL, [0300H]

रजिस्टर अप्रत्यक्ष पता मोड

यह एड्रेसिंग मोड डेटा को किसी भी मेमोरी लोकेशन पर निम्न रजिस्टरों में आयोजित ऑफसेट पते के माध्यम से संबोधित करने की अनुमति देता है: बीपी, बीएक्स, डीआई और एसआई।

उदाहरण

MOV AX, [BX]  ; Suppose the register BX contains 4895H, then the contents  
              ; 4895H are moved to AX 
ADD CX, {BX}

आधारित पता मोड

इस एड्रेसिंग मोड में, BX / BP रजिस्टर और 8-बिट / 16-बिट विस्थापन की सामग्री के योग से ऑपरेंड का ऑफसेट पता दिया जाता है।

उदाहरण

MOV DX, [BX+04], ADD CL, [BX+08]

अनुक्रमित पता मोड

इस एड्रेसिंग मोड में, ऑपरेंड ऑफ़सेट पता SI या DI रजिस्टर और 8-बिट / 16-बिट विस्थापन की सामग्री को जोड़कर पाया जाता है।

उदाहरण

MOV BX, [SI+16], ADD AL, [DI+16]

आधारित-सूचकांक पता मोड

इस एड्रेसिंग मोड में, ऑपरेंड के ऑफसेट पते की गणना एक बेस रजिस्टर को एक इंडेक्स रजिस्टर की सामग्री से जोड़कर की जाती है।

उदाहरण

ADD CX, [AX+SI], MOV AX, [AX+DI]

विस्थापन मोड के साथ अनुक्रमित आधारित

इस एड्रेसिंग मोड में, ऑपरेंड ऑफसेट की गणना आधार रजिस्टर सामग्री को जोड़कर की जाती है। एक सूचकांक सामग्री और 8 या 16-बिट विस्थापन को पंजीकृत करता है।

उदाहरण

MOV AX, [BX+DI+08], ADD CX, [BX+SI+16]

मल्टीप्रोसेसर का मतलब प्रोसेसर का एक से अधिक सेट है जो एक साथ निर्देशों को निष्पादित करता है। तीन बुनियादी मल्टीप्रोसेसर कॉन्फ़िगरेशन हैं।

  • Coprocessor कॉन्फ़िगरेशन
  • बारीकी से युग्मित विन्यास
  • ढीला युग्मित विन्यास

Coprocessor कॉन्फ़िगरेशन

कॉपरप्रोसेसर माइक्रोप्रोसेसर चिप पर एक विशेष रूप से डिज़ाइन किया गया सर्किट है, जो एक ही कार्य को बहुत तेज़ी से कर सकता है, जिसे माइक्रोप्रोसेसर करता है। यह मुख्य प्रोसेसर के कार्य भार को कम करता है। कोप्रोसेसर उसी मेमोरी, IO सिस्टम, बस, कंट्रोल लॉजिक और क्लॉक जनरेटर को साझा करता है। कोपरोसेसर गणितीय गणना, स्क्रीन पर चित्रमय प्रदर्शन आदि जैसे विशेष कार्यों को संभालता है।

8086 और 8088 अधिकांश ऑपरेशन कर सकते हैं लेकिन उनका निर्देश सेट जटिल गणितीय संचालन करने में सक्षम नहीं है, इसलिए इन मामलों में माइक्रोप्रोसेसर को इंटेल 8087 गणित कोप्रोसेसर जैसे गणित कोप्रोसेसर की आवश्यकता होती है, जो आसानी से बहुत तेजी से अपने ऑपरेशन कर सकते हैं।

कोप्रोसेसर कॉन्फ़िगरेशन के ब्लॉक आरेख

कप्रोसेसर और प्रोसेसर कैसे जुड़ा है?

  • कोप्रोसेसर और प्रोसेसर TEST, RQ- / GT- और QS 0 & QS 1 सिग्नल के माध्यम से जुड़ा हुआ है।

  • TEST सिग्नल कोप्रोसेसर के BUSY पिन से जुड़ा होता है और शेष 3 पिन कोप्रोसेसर के समान नाम के 3 पिन से जुड़े होते हैं।

  • टेस्ट सिग्नल कोप्रोसेसर की गतिविधि का ध्यान रखता है, अर्थात कोप्रोसेसर व्यस्त या निष्क्रिय है।

  • आरटी- / जीटी-का उपयोग बस मध्यस्थता के लिए किया जाता है।

  • कोप्रोसेसर होस्ट प्रोसेसर की कतार की स्थिति को ट्रैक करने के लिए QS 0 & QS 1 का उपयोग करता है ।

बारीकी से युग्मित विन्यास

क्लोजली कपल्ड कॉन्फ़िगरेशन कोप्रोसेसर कॉन्फ़िगरेशन के समान है, अर्थात दोनों समान मेमोरी, I / O सिस्टम बस, कंट्रोल लॉजिक और होस्ट प्रोसेसर के साथ कंट्रोल जनरेटर को साझा करते हैं। हालाँकि, कोप्रोसेसर और होस्ट प्रोसेसर अपने स्वयं के निर्देशों को प्राप्त और निष्पादित करता है। सिस्टम बस कोप्रोसेसर और होस्ट प्रोसेसर द्वारा स्वतंत्र रूप से नियंत्रित किया जाता है।

क्लोजली कपल कॉन्फ़िगरेशन के ब्लॉक आरेख

प्रोसेसर और स्वतंत्र प्रोसेसर कैसे जुड़ा है?

  • मेजबान और स्वतंत्र प्रोसेसर के बीच संचार मेमोरी स्पेस के माध्यम से किया जाता है।

  • कोई भी निर्देश संचार के लिए उपयोग नहीं किया जाता है, जैसे कि WAIT, ESC, आदि।

  • होस्ट प्रोसेसर मेमोरी का प्रबंधन करता है और इसके एक पोर्ट पर कमांड भेजकर स्वतंत्र प्रोसेसर को जगाता है।

  • फिर स्वतंत्र प्रोसेसर कार्य को निष्पादित करने के लिए मेमोरी तक पहुंचता है।

  • कार्य पूरा होने के बाद, यह स्थिति संकेत या एक बाधा अनुरोध का उपयोग करके मेजबान प्रोसेसर को एक पावती भेजता है।

ढीला युग्मित विन्यास

ढीले युग्मित विन्यास में माइक्रोप्रोसेसर आधारित प्रणालियों के मॉड्यूल की संख्या होती है, जो एक सामान्य सिस्टम बस के माध्यम से जुड़े होते हैं। प्रत्येक मॉड्यूल में अपने स्वयं के घड़ी जनरेटर, मेमोरी, I / O डिवाइस होते हैं और एक स्थानीय बस के माध्यम से जुड़े होते हैं।

ढीले युग्मित विन्यास के ब्लॉक आरेख

लाभ

  • एक से अधिक प्रोसेसर होने से दक्षता में वृद्धि होती है।

  • प्रत्येक प्रोसेसर के पास स्थानीय मेमोरी / I / O उपकरणों तक पहुंचने के लिए अपनी स्थानीय बस है। इससे समानांतर प्रसंस्करण को प्राप्त करना आसान हो जाता है।

  • सिस्टम संरचना लचीली है, अर्थात एक मॉड्यूल की विफलता पूरे सिस्टम की विफलता को प्रभावित नहीं करती है; दोषपूर्ण मॉड्यूल को बाद में बदला जा सकता है।

8087 संख्यात्मक डेटा प्रोसेसर के रूप में भी जाना जाता है Math co-processor, Numeric processor extension तथा Floating point unit। यह इंटेल द्वारा 8086/8088 के साथ जोड़ी बनाने वाला पहला गणित कोप्रोसेसर था, जिसके परिणामस्वरूप आसान और तेज गणना हुई।

एक बार जब निर्देश 8086/8088 प्रोसेसर द्वारा पहचाने जाते हैं, तो इसे आगे निष्पादन के लिए 8087 सह-प्रोसेसर को आवंटित किया जाता है।

8087 द्वारा समर्थित डेटा प्रकार हैं -

  • बाइनरी इंटेगर
  • पैक किए गए दशमलव संख्या
  • वास्तविक संख्याये
  • अस्थायी वास्तविक प्रारूप

8087 संख्यात्मक डेटा प्रोसेसर की सबसे प्रमुख विशेषताएं इस प्रकार हैं -

  • यह 2-10 बाइट्स से लेकर पूर्णांक, फ्लोट और वास्तविक प्रकार के डेटा का समर्थन करता है।

  • प्रसंस्करण की गति इतनी अधिक है कि यह ~ 64 in में दो 64-बिट वास्तविक संख्याओं के गुणन की गणना कर सकता है और ~ 35 high वर्ग में वर्गमूल की गणना भी कर सकता है।

  • यह IEEE फ़्लोटिंग पॉइंट मानकों का अनुसरण करता है।

8087 वास्तुकला

8087 वास्तुकला दो समूहों में विभाजित है, अर्थात, Control Unit (सीयू) और Numeric Extension Unit (Neu)।

  • control unit प्रोसेसर और मेमोरी के बीच सभी संचार को संभालता है जैसे कि यह प्राप्त करता है और निर्देश को डिकोड करता है, मेमोरी ऑपरेंड को पढ़ता और लिखता है, समानांतर कतार बनाए रखता है, आदि सभी कोप्रोसेसर निर्देश ईएससी निर्देश हैं, अर्थात, वे केवल 'एफ' से शुरू करते हैं, कोप्रोसेसर केवल। ESC निर्देशों को निष्पादित करता है जबकि अन्य निर्देशों को माइक्रोप्रोसेसर द्वारा निष्पादित किया जाता है।

  • numeric extension unitअंकगणित, तार्किक, ट्रान्सेंडैंटल और डेटा ट्रांसफर निर्देश जैसे सभी संख्यात्मक प्रोसेसर निर्देश को संभालता है। इसमें 8 रजिस्टर स्टैक है, जो निर्देशों और उनके परिणामों के लिए ऑपरेंड रखता है।

8087 कोप्रोसेसर की वास्तुकला इस प्रकार है -

8087 पिन विवरण

आइए पहले हम 8087 के पिन आरेख पर एक नज़र डालें -

निम्नलिखित सूची 8087 का पिन विवरण प्रदान करती है -

  • AD0 – AD15 - ये समय बहुविकल्पीय पता / डेटा लाइनें हैं, जो पहले घड़ी चक्र के दौरान पते और दूसरी घड़ी चक्र से डेटा ले जाती हैं।

  • A19 / S6 – A16/S- ये पंक्तियाँ टाइम मल्टीप्लेक्स एड्रेस / स्टेटस लाइन्स हैं। यह 8086 के संबंधित पिंस के समान तरीके से कार्य करता है। एस 6 , एस 4 और एस 3 स्थायी रूप से उच्च हैं, जबकि एस 5 स्थायी रूप से कम है।

  • $\overline{BHE}$/S7 - पहले घड़ी चक्र के दौरान, $\overline{BHE}$/ S 7 का उपयोग 8086 डेटा बस के उच्च बाइट पर डेटा को सक्षम करने के लिए किया जाता है और उसके बाद स्टेटस लाइन S 7 के रूप में काम करता है ।

  • QS1, QS0 - ये कतार स्थिति इनपुट संकेत हैं जो अनुदेश कतार की स्थिति प्रदान करते हैं, उनकी शर्तें निम्न तालिका में दर्शाई गई हैं -

QS 0 क्यूएस स्थिति
0 0 कोई ऑपरेशन नहीं
0 1 कतार से opcode का पहला बाइट
1 0 कतार खाली करो
1 1 कतार से बाद में बाइट
  • INT - यह एक रुकावट संकेत है, जो निष्पादन के दौरान बिना किसी अपवाद के प्राप्त होने पर उच्च में बदल जाता है।

  • BUSY - यह एक आउटपुट सिग्नल है, जब यह अधिक होता है तो यह सीपीयू में एक व्यस्त स्थिति को इंगित करता है।

  • READY - यह एक इनपुट सिग्नल है जिसका उपयोग कॉपोरोसेसर को सूचित करने के लिए किया जाता है कि बस डेटा प्राप्त करने के लिए तैयार है या नहीं।

  • RESET - यह एक इनपुट सिग्नल होता है जिसका उपयोग कोप्रोसेसर की आंतरिक गतिविधियों को अस्वीकार करने और सीपीयू द्वारा आवश्यकता पड़ने पर आगे के निष्पादन के लिए तैयार करने में किया जाता है।

  • CLK - सीएलके इनपुट प्रोसेसर संचालन के लिए मूल समय प्रदान करता है।

  • VCC - यह एक बिजली आपूर्ति संकेत है, जिसे सर्किट के संचालन के लिए + 5V आपूर्ति की आवश्यकता होती है।

  • S0, S1, S2- ये स्थिति संकेत हैं जो ऑपरेशन की स्थिति प्रदान करते हैं जो मेमोरी और I / O नियंत्रण संकेतों को उत्पन्न करने के लिए बस कंट्रोलर 8087 द्वारा उपयोग किया जाता है। ये संकेत चौथे घड़ी चक्र के दौरान सक्रिय हैं।

एस 2 एस 1 S 0 कतार की स्थिति
0 एक्स एक्स अप्रयुक्त
1 0 0 अप्रयुक्त
1 0 1 स्मृति पढ़ी
1 1 0 मेमोरी लिखिए
1 1 1 निष्क्रिय
  • RQ/GT1 & RQ/GT0 - ये हैं Request/Grant 8087 प्रोसेसर द्वारा उपयोग किए जाने वाले सिग्नल, ऑपरेंड ट्रांसफर के लिए होस्ट प्रोसेसर 8086/8088 से बस पर नियंत्रण पाने के लिए।

इस अध्याय में, हम 8085 के साथ मेमोरी इंटरफेसिंग और आईओ इंटरफेसिंग पर चर्चा करेंगे।

Interfaceदो घटकों के बीच संचार का मार्ग है। इंटरफेसिंग दो प्रकार की होती है, मेमोरी इंटरफेसिंग और आई / ओ इंटरफेसिंग।

मेमोरी इंटरफेसिंग

जब हम किसी निर्देश को निष्पादित कर रहे होते हैं, तो हमें माइक्रोप्रोसेसर को निर्देश कोड पढ़ने और मेमोरी में संग्रहीत डेटा को एक्सेस करने की आवश्यकता होती है। इसके लिए, मेमोरी और माइक्रोप्रोसेसर दोनों को रजिस्टरों से पढ़ने और लिखने के लिए कुछ संकेतों की आवश्यकता होती है।

इंटरफेसिंग प्रक्रिया में मेमोरी आवश्यकताओं और माइक्रोप्रोसेसर संकेतों के साथ मिलान करने के लिए कुछ प्रमुख कारक शामिल हैं। इसलिए इंटरफेसिंग सर्किट को इस तरह से डिज़ाइन किया जाना चाहिए कि यह माइक्रोप्रोसेसर के संकेतों के साथ मेमोरी सिग्नल की आवश्यकताओं से मेल खाता हो।

आईओ इंटरफेसिंग

कीबोर्ड, माउस, प्रिंटर आदि जैसे विभिन्न संचार उपकरण हैं, इसलिए हमें कुंडी और बफर का उपयोग करके माइक्रोप्रोसेसर के साथ कीबोर्ड और अन्य उपकरणों को इंटरफ़ेस करने की आवश्यकता है। इस प्रकार के इंटरफेसिंग को I / O इंटरफेसिंग के रूप में जाना जाता है।

मेमोरी और I / O इंटरफेसिंग के ब्लॉक आरेख

8085 पिंसिंग इंटरफेसिंग पिन

अन्य उपकरणों के साथ इंटरफेसिंग के लिए 8085 पिनों की सूची निम्नलिखित है -

  • एक 15 - एक 8 (उच्च पता बस)
  • AD 7 - AD 0 (निचला पता / डेटा बस)
  • ALE
  • RD
  • WR
  • READY

संचार के तरीके - बाहरी दुनिया के साथ माइक्रोप्रोसेसर?

संचार के दो तरीके हैं जिनमें माइक्रोप्रोसेसर बाहरी दुनिया से जुड़ सकता है।

  • सीरियल कम्युनिकेशन इंटरफ़ेस
  • समानांतर संचार इंटरफ़ेस

Serial Communication Interface - इस प्रकार के संचार में, इंटरफ़ेस माइक्रोप्रोसेसर से डेटा का एक सिंगल बाइट प्राप्त करता है और इसे बिट द्वारा दूसरे सिस्टम को क्रमिक रूप से और इसके विपरीत भेजता है।

Parallel Communication Interface - इस प्रकार के संचार में, इंटरफ़ेस माइक्रोप्रोसेसर से डेटा का एक बाइट प्राप्त करता है और इसे बिट सिस्टम द्वारा एक साथ अन्य (या) समानांतर फैशन और इसके विपरीत में भेजता है।

8279 प्रोग्रामेबल कीबोर्ड / डिस्प्ले कंट्रोलर इंटेल द्वारा डिज़ाइन किया गया है जो सीपीयू के साथ एक कीबोर्ड को इंटरफेस करता है। कीबोर्ड पहले कीबोर्ड को स्कैन करता है और पहचानता है कि क्या कोई कुंजी दबाया गया है। यह तब सीपीयू के लिए दबाए गए कुंजी की अपनी सापेक्ष प्रतिक्रिया भेजता है और इसके विपरीत।

सीपीयू के साथ कीबोर्ड कितने तरीकों से इंटरफेज किया जाता है?

कीबोर्ड को इंटरप्ट या पोलेड मोड में या तो इंटर किया जा सकता है। मेंInterrupt modeप्रोसेसर से अनुरोध किया जाता है कि कोई भी कुंजी दबाए जाने पर ही सेवा दी जाए, अन्यथा सीपीयू अपने मुख्य कार्य के साथ जारी रहेगा।

में Polled mode, सीपीयू समय-समय पर 8279 के आंतरिक झंडे को जांचता है कि कोई कुंजी दबाया गया है या नहीं।

8279 कीबोर्ड कैसे काम करता है?

कीबोर्ड में अधिकतम 64 कुंजी होती हैं, जो कि की-कोड का उपयोग करके सीपीयू के साथ इंटरफेयर होती हैं। ये की-कोड डी-बाउंस होते हैं और 8-बाइट फ़िफ़ोरम में संग्रहीत होते हैं, जिसे सीपीयू द्वारा एक्सेस किया जा सकता है। यदि FIFO में 8 से अधिक अक्षर दर्ज किए जाते हैं, तो इसका मतलब है कि एक बार में आठ से अधिक कुंजी दबाए जाते हैं। यह तब होता है जब ओवररन स्थिति सेट की जाती है।

यदि किसी FIFO में एक मान्य कुंजी प्रविष्टि है, तो CPU को एक व्यवधान मोड में बाधित किया जाता है अन्यथा CPU प्रविष्टि को पढ़ने के लिए मतदान में स्थिति की जांच करता है। एक बार जब CPU एक कुंजी प्रविष्टि पढ़ता है, तो FIFO को अपडेट किया जाता है, और नई प्रविष्टि के लिए स्थान उत्पन्न करने के लिए कुंजी प्रविष्टि को FIFO से बाहर धकेल दिया जाता है।

वास्तुकला और विवरण

I / O नियंत्रण और डेटा बफर

यह इकाई माइक्रोप्रोसेसर के माध्यम से डेटा के प्रवाह को नियंत्रित करती है। यह केवल तभी सक्षम होता है जब D कम होता है। इसका डेटा बफर माइक्रोप्रोसेसर की आंतरिक बस के साथ सिस्टम की बाहरी बस को रोकता है। पिन A0, RD और WR का उपयोग कमांड, स्थिति या डेटा पढ़ने / लिखने के संचालन के लिए किया जाता है।

नियंत्रण और समय रजिस्टर और समय नियंत्रण

इस यूनिट में सीपीयू द्वारा प्रोग्राम किए गए कीबोर्ड, डिस्प्ले मोड और अन्य ऑपरेशन को स्टोर करने के लिए रजिस्टर हैं। समय और नियंत्रण इकाई सर्किट के संचालन के लिए समय को संभालती है।

स्कैन काउंटर

इसके दो मोड हैं Encoded modeऔर डिकोड्ड मोड। एन्कोडेड मोड में, काउंटर बाइनरी काउंट प्रदान करता है जो कि कीबोर्ड और डिस्प्ले के लिए स्कैन लाइनें प्रदान करने के लिए बाहरी रूप से डिकोड किया जाना है।

में decoded scan modeकाउंटर आंतरिक रूप से कम से कम 2 महत्वपूर्ण बिट्स को डीकोड करता है और SL 0 -SL 3 पर 4 में से 1 स्कैन को डीकोड करता है ।

रिटर्न बफ़र्स, कीबोर्ड डेब्यू और कंट्रोल

यह इकाई सबसे पहले कुंजी क्लोजर पंक्ति-वार को स्कैन करती है, यदि ऐसा पाया जाता है तो कीबोर्ड डीबेज यूनिट कुंजी प्रविष्टि की आलोचना करता है। यदि उसी कुंजी का पता लगाया जाता है, तो उस कुंजी का कोड सीधे SHIFT & CONTROL कुंजी की स्थिति के साथ सेंसर रैम में स्थानांतरित हो जाता है।

FIFO / सेंसर रैम और स्टेटस लॉजिक

यह इकाई 8-बाइट फर्स्ट-इन-फ़र्स्ट-आउट (FIFO) रैम के रूप में कार्य करती है जहाँ प्रत्येक अनुक्रमित कुंजी का कोड उनके अनुक्रम के अनुसार RAM में दर्ज किया जाता है। FIFO के खाली होने तक प्रत्येक FIFO रीड ऑपरेशन के बाद स्थिति तर्क एक बाधा अनुरोध उत्पन्न करता है।

स्कैन किए गए सेंसर मैट्रिक्स मोड में, यह इकाई सेंसर रैम के रूप में कार्य करती है जहां इसकी प्रत्येक पंक्ति मैट्रिक्स में उनके संबंधित सेंसर की स्थिति के साथ भरी हुई है। जब सेंसर अपनी स्थिति बदलता है, तो IRQ लाइन सीपीयू को उच्च और बाधित करती है।

पता रजिस्टर और डिस्प्ले रैम प्रदर्शित करें

इस यूनिट में डिस्प्ले एड्रेस रजिस्टर होते हैं, जो वर्तमान में सीपीयू द्वारा डिस्प्ले रैम से / के लिए लिखे गए शब्दों के पते रखते हैं।

8279 - पिन विवरण

निम्नलिखित आंकड़ा 8279 का पिन आरेख दिखाता है -

डेटा बस लाइन्स, DB 0 - DB 7

ये 8 द्विदिश डेटा बस लाइनें हैं जिनका उपयोग सीपीयू से / से डेटा स्थानांतरित करने के लिए किया जाता है।

CLK

घड़ी इनपुट का उपयोग माइक्रोप्रोसेसर द्वारा आवश्यक आंतरिक समय उत्पन्न करने के लिए किया जाता है।

रीसेट

जैसा कि नाम से पता चलता है कि इस पिन का उपयोग माइक्रोप्रोसेसर को रीसेट करने के लिए किया जाता है।

सीएस चिप का चयन करें

जब यह पिन कम पर सेट होता है, तो यह पढ़ने / लिखने के संचालन की अनुमति देता है, अन्यथा इस पिन को उच्च पर सेट किया जाना चाहिए।

यह पिन कमांड / स्थिति की जानकारी के हस्तांतरण को इंगित करता है। जब यह कम होता है, तो यह डेटा के हस्तांतरण का संकेत देता है।

आरडी, डब्ल्यूआर

यह पढ़ें / लिखें पिन डेटा बफर को डेटा बस पर डेटा भेजने / प्राप्त करने में सक्षम बनाता है।

आईआरक्यू

FIFO सेंसर रैम में डेटा होने पर यह इंटरप्ट आउटपुट लाइन हाई हो जाती है। प्रत्येक FIFO RAM रीड ऑपरेशन के साथ इंटरप्ट लाइन कम होती जाती है। हालाँकि, यदि FIFO RAM में CPU द्वारा पढ़ने के लिए कोई भी कुंजी-कोड प्रविष्टि शामिल है, तो यह पिन फिर से CPU के लिए एक बाधा उत्पन्न करने के लिए उच्च जाता है।

वी एस एस , वी सीसी

ये माइक्रोप्रोसेसर की जमीन और बिजली की आपूर्ति लाइनें हैं।

SL 0 - SL 3

ये कीबोर्ड मैट्रिक्स को स्कैन करने और अंकों को प्रदर्शित करने के लिए उपयोग की जाने वाली स्कैन लाइनें हैं। मोड नियंत्रण रजिस्टर का उपयोग करके इन लाइनों को एन्कोडेड या डीकोड किया जा सकता है।

आरएल 0 - आरएल 7

ये रिटर्न लाइनें हैं जो कुंजियों के एक टर्मिनल से जुड़ी हैं, जबकि चाबियों का दूसरा टर्मिनल डिकोडेड स्कैन लाइनों से जुड़ा है। किसी भी कुंजी को दबाने पर ये रेखाएँ 0 पर सेट हो जाती हैं।

खिसक जाना

Shift इनपुट लाइन स्थिति स्कैन किए गए कीबोर्ड मोड में FIFO में प्रत्येक कुंजी कोड के साथ संग्रहीत होती है। जब तक इसे एक कुंजी बंद करने के साथ कम खींच लिया जाता है, तब तक इसे उच्च रखने के लिए आंतरिक रूप से खींच लिया जाता है

CNTL / STB - I / P मोड को नियंत्रित / नियंत्रित करें

कीबोर्ड मोड में, इस लाइन का उपयोग एक कंट्रोल इनपुट के रूप में किया जाता है और एक कुंजी बंद होने पर फीफो में संग्रहीत किया जाता है। लाइन एक स्ट्रोब लाइन है जो डेटा को FIFO RAM में, स्ट्रेटेड इनपुट मोड में प्रवेश करती है। यह एक आंतरिक पुल अप है। एक कुंजी बंद होने के साथ लाइन नीचे खींची जाती है।

BD

यह खाली प्रदर्शन के लिए खड़ा है। डिजिट स्विचिंग के दौरान डिस्प्ले को खाली करने के लिए इसका उपयोग किया जाता है।

OUTA 0 - OUTA 3 और OUTB 0 - OUTB 3

ये दो 16x4 या एक 16x8 आंतरिक डिस्प्ले रिफ्रेश रजिस्टरों के लिए आउटपुट पोर्ट हैं। इन लाइनों का डेटा डिस्प्ले और कीबोर्ड को स्कैन करने के लिए स्कैन लाइनों के साथ सिंक्रनाइज़ किया जाता है।

8279 के ऑपरेशनल मोड

8279 पर ऑपरेशन के दो तरीके हैं - Input Mode तथा Output Mode

इनपुट मोड

यह मोड कीबोर्ड द्वारा दिए गए इनपुट से संबंधित है और इस मोड को आगे 3 मोड में वर्गीकृत किया गया है।

  • Scanned Keyboard Mode- इस मोड में, कुंजी मैट्रिक्स को एन्कोडेड या डीकोड किए गए स्कैन का उपयोग करके हस्तक्षेप किया जा सकता है। एन्कोडेड स्कैन में, एक 8 × 8 कीबोर्ड या डिकोड किए गए स्कैन में, 4 × 8 कीबोर्ड को इंटर किया जा सकता है। SHIFT और नियंत्रण स्थिति के साथ दबाए गए कुंजी का कोड FIFO RAM में संग्रहीत होता है।

  • Scanned Sensor Matrix- इस मोड में, एन्कोडर या डिकोडर स्कैन का उपयोग करके प्रोसेसर के साथ एक सेंसर ऐरे को इंटर किया जा सकता है। एनकोडर स्कैन में, 8 × 8 सेंसर मैट्रिक्स या डिकोडर स्कैन 4 × 8 सेंसर मैट्रिक्स के साथ हस्तक्षेप किया जा सकता है।

  • Strobed Input - इस मोड में, जब नियंत्रण रेखा 0 पर सेट की जाती है, तो रिटर्न लाइनों पर डेटा FIFO बाइट में बाइट द्वारा संग्रहीत होता है।

आउटपुट मोड

यह मोड प्रदर्शन से संबंधित कार्यों से संबंधित है। इस मोड को आगे दो आउटपुट मोड में वर्गीकृत किया गया है।

  • Display Scan - यह मोड 8/16 कैरेक्टर के मल्टीप्लेक्स वाले डिस्प्ले को डुअल 4-बिट / सिंगल 8-बिट डिस्प्ले यूनिट के रूप में व्यवस्थित करने की अनुमति देता है।

  • Display Entry - यह मोड डेटा को राइट साइड / लेफ्ट साइड से डिस्प्ले के लिए एंटर करने की अनुमति देता है।

DMA का मतलब डायरेक्ट मेमोरी एक्सेस है। यह इंटेल द्वारा सबसे तेज दर पर डेटा स्थानांतरित करने के लिए डिज़ाइन किया गया है। यह डिवाइस को सीपीयू के किसी भी हस्तक्षेप के बिना डिवाइस को सीधे / से मेमोरी में स्थानांतरित करने की अनुमति देता है।

डीएमए नियंत्रक का उपयोग करते हुए, डिवाइस सीपीयू से अपने डेटा, पते और नियंत्रण बस को रखने का अनुरोध करता है, इसलिए डिवाइस सीधे मेमोरी से / से डेटा स्थानांतरित करने के लिए स्वतंत्र है। सीपीए से HLDA सिग्नल प्राप्त करने के बाद ही DMA डेटा ट्रांसफर शुरू किया जाता है।

डीएमए संचालन कैसे किया जाता है?

निम्नलिखित एक डीएमए द्वारा निष्पादित संचालन का क्रम है -

  • प्रारंभ में, जब किसी भी डिवाइस को डिवाइस और मेमोरी के बीच डेटा भेजना होता है, तो डिवाइस को डीएमए नियंत्रक को डीएमए अनुरोध (डीआरक्यू) भेजना पड़ता है।

  • डीएमए कंट्रोलर सीपीयू को होल्ड रिक्वेस्ट (एचआरक्यू) भेजता है और सीपीयू के लिए एचएलडीए का दावा करने का इंतजार करता है।

  • फिर माइक्रोप्रोसेसर सभी डेटा बस, एड्रेस बस और कंट्रोल बस को त्रि-राज्यों में भेजता है। CPU बस पर नियंत्रण छोड़ देता है और HLDA सिग्नल के माध्यम से होल्ड अनुरोध स्वीकार करता है।

  • अब CPU होल्ड स्थिति में है और DMA कंट्रोलर को CPU, मेमोरी और I / O डिवाइसेस के बीच बसों के संचालन का प्रबंधन करना है।

8257 की विशेषताएं

यहाँ 8257 की कुछ प्रमुख विशेषताओं की सूची दी गई है -

  • इसके चार चैनल हैं जिनका उपयोग चार I / O उपकरणों पर किया जा सकता है।

  • प्रत्येक चैनल में 16-बिट पता और 14-बिट काउंटर है।

  • प्रत्येक चैनल 64kb तक का डेटा ट्रांसफर कर सकता है।

  • प्रत्येक चैनल को स्वतंत्र रूप से प्रोग्राम किया जा सकता है।

  • प्रत्येक चैनल रीड ट्रांसफर कर सकता है, ट्रांसफर लिख सकता है और ट्रांसफर ऑपरेशन को सत्यापित कर सकता है।

  • यह परिधीय उपकरण के लिए MARK सिग्नल उत्पन्न करता है कि 128 बाइट्स को स्थानांतरित कर दिया गया है।

  • इसके लिए सिंगल फेज की घड़ी चाहिए।

  • इसकी आवृत्ति 250Hz से 3MHz तक होती है।

  • यह 2 मोड में संचालित होता है, अर्थात Master mode तथा Slave mode

8257 वास्तुकला

निम्नलिखित छवि 8257 की वास्तुकला को दर्शाती है -

8257 पिन विवरण

निम्नलिखित छवि 8257 डीएमए नियंत्रक के पिन आरेख को दिखाती है -

DRQ 0 −DRQ3

ये चार व्यक्तिगत चैनल डीएमए अनुरोध इनपुट हैं, जो डीएमए सेवाओं का उपयोग करने के लिए परिधीय उपकरणों द्वारा उपयोग किया जाता है। जब निश्चित प्राथमिकता मोड का चयन किया जाता है, तो DRQ 0 की सर्वोच्च प्राथमिकता होती है और DRQ 3 की उनके बीच सबसे कम प्राथमिकता होती है।

DACK o - DACK 3

ये सक्रिय-कम डीएमए लाइनों को स्वीकार करते हैं, जो सीपीयू द्वारा उनके अनुरोध की स्थिति के बारे में अनुरोध परिधीय अद्यतन करता है। ये लाइनें अनुरोध करने वाले उपकरणों के लिए स्ट्रोब लाइनों के रूप में भी कार्य कर सकती हैं।

डी - डी 7

ये द्विदिश, डेटा लाइनें हैं जो डीएमए नियंत्रक के आंतरिक डेटा बस के साथ सिस्टम बस को इंटरफ़ेस करने के लिए उपयोग की जाती हैं। स्लेव मोड में, यह 8257 से कमांड शब्द और 8257 से स्टेटस शब्द ले जाता है। मास्टर मोड में, इन पंक्तियों का उपयोग लैच को उत्पन्न पते के उच्च बाइट को भेजने के लिए किया जाता है। यह पता ADSTB सिग्नल का उपयोग करके आगे लगाया गया है।

आईओआर

यह एक सक्रिय-कम द्विदिशीय त्रि-राज्य इनपुट लाइन है, जिसका उपयोग सीपीयू द्वारा स्लेव मोड में 8257 के आंतरिक रजिस्टरों को पढ़ने के लिए किया जाता है। मास्टर मोड में, इसका उपयोग मेमोरी राइट साइकल के दौरान परिधीय उपकरणों के डेटा को पढ़ने के लिए किया जाता है।

IOW

यह एक सक्रिय निम्न द्वि-दिशा त्रिकोणीय राज्य रेखा है, जिसका उपयोग डेटा बस की सामग्री को 8-बिट मोड रजिस्टर या 16-बिट डीएमए एड्रेस रजिस्टर या टर्मिनल काउंट रजिस्टर के ऊपरी / निचले बाइट को लोड करने के लिए किया जाता है। मास्टर मोड में, इसका उपयोग डीएमए मेमोरी रीड साइकल के दौरान परिधीय उपकरणों को डेटा लोड करने के लिए किया जाता है।

CLK

यह एक घड़ी आवृत्ति संकेत है जो 8257 के आंतरिक संचालन के लिए आवश्यक है।

रीसेट

यह संकेत सभी डीएमए चैनलों को अक्षम करके डीएमए नियंत्रक को रीसेट करने के लिए उपयोग किया जाता है।

- ए

ये चार महत्वपूर्ण पता रेखाएँ हैं। गुलाम मोड में, वे एक इनपुट के रूप में कार्य करते हैं, जो पढ़ने या लिखे जाने के लिए रजिस्टरों में से एक का चयन करता है। मास्टर मोड में, वे 8257 द्वारा निर्मित चार सबसे महत्वपूर्ण मेमोरी एड्रेस आउटपुट लाइनें हैं।

सीएस

यह एक एक्टिव-लो चिप सेलेक्ट लाइन है। स्लेव मोड में, यह 8257 / से / से पढ़ने / लिखने के संचालन को सक्षम करता है। मास्टर मोड में, यह 8257 से / से पढ़ने / लिखने के संचालन को अक्षम करता है।

4 - ए 7

ये मास्टर मोड में डीएमए द्वारा उत्पन्न निचले बाइट पते के उच्च नीच हैं।

तैयार

यह एक सक्रिय-उच्च एसिंक्रोनस इनपुट सिग्नल है, जो प्रतीक्षा राज्यों को सम्मिलित करके डीएमए तैयार करता है।

HRQ

इस सिग्नल का उपयोग आउटपुट डिवाइस से होल्ड रिक्वेस्ट सिग्नल प्राप्त करने के लिए किया जाता है। दास मोड में, यह DRQ इनपुट लाइन 8257 के साथ जुड़ा हुआ है। मास्टर मोड में, यह सीपीयू के होल्ड इनपुट के साथ जुड़ा हुआ है।

HLDA

यह होल्ड पावती सिग्नल है जो डीएमए नियंत्रक को इंगित करता है कि बस को सीपीयू द्वारा परिधीय अनुरोध करने के लिए दिया गया है जब यह 1 पर सेट होता है।

MEMR

यह कम मेमोरी रीड सिग्नल है, जो डीएमए रीड साइकिल के दौरान संबोधित मेमोरी स्थानों से डेटा को पढ़ने के लिए उपयोग किया जाता है।

MEMW

यह सक्रिय-लो थ्री स्टेट सिग्नल है जिसका उपयोग डीएमए लिखने के ऑपरेशन के दौरान एड्रेस किए गए मेमोरी लोकेशन पर डेटा लिखने के लिए किया जाता है।

ADST

इस सिग्नल का उपयोग DMA कंट्रोलर द्वारा उत्पन्न मेमोरी एड्रेस के उच्च बाइट को कुंडी में बदलने के लिए किया जाता है।

AEN

इस सिग्नल का उपयोग एड्रेस बस / डेटा बस को निष्क्रिय करने के लिए किया जाता है।

टीसी

यह 'टर्मिनल काउंट' के लिए है, जो वर्तमान डीएमए चक्र को वर्तमान परिधीय उपकरणों को इंगित करता है।

निशान

निशान को प्रत्येक 128 चक्र या इसके बाद के इंटीग्रल मल्टीपल के बाद सक्रिय किया जाएगा। यह इंगित करता है कि मौजूदा डीएमए चक्र पिछले परिधीय डिवाइस के चयनित परिधीय उपकरण के बाद से 128 वां चक्र है।

वी सीसी

यह पावर सिग्नल है जो सर्किट के संचालन के लिए आवश्यक है।

microcontroller एक छोटा और कम लागत वाला माइक्रो कंप्यूटर है, जो एम्बेडेड सिस्टम के विशिष्ट कार्यों को करने के लिए डिज़ाइन किया गया है जैसे कि माइक्रोवेव की जानकारी प्रदर्शित करना, विशेष सिग्नल प्राप्त करना, आदि।

सामान्य माइक्रोकंट्रोलर में प्रोसेसर, मेमोरी (RAM, ROM, EPROM), सीरियल पोर्ट, पेरिफेरल (टाइमर, काउंटर) आदि होते हैं।

माइक्रोप्रोसेसर और माइक्रोकंट्रोलर के बीच अंतर

निम्न तालिका एक माइक्रोप्रोसेसर और एक माइक्रोकंट्रोलर के बीच के अंतर को उजागर करती है -

microcontroller माइक्रोप्रोसेसर
माइक्रोकंट्रोलर्स का उपयोग किसी एप्लिकेशन के भीतर किसी एक कार्य को करने के लिए किया जाता है। माइक्रोप्रोसेसरों का उपयोग बड़े अनुप्रयोगों के लिए किया जाता है।
इसकी डिजाइनिंग और हार्डवेयर की कीमत कम है। इसकी डिजाइनिंग और हार्डवेयर की कीमत अधिक है।
बदलने में आसान। बदलने के लिए इतना आसान नहीं है।
इसे CMOS तकनीक से बनाया गया है, जिसे संचालित करने के लिए कम शक्ति की आवश्यकता होती है। इसकी बिजली की खपत अधिक है क्योंकि इसे पूरी प्रणाली को नियंत्रित करना है।
इसमें CPU, RAM, ROM, I / O पोर्ट शामिल हैं। इसमें RAM, ROM, I / O पोर्ट शामिल नहीं हैं। यह अपने पिन का उपयोग परिधीय उपकरणों के इंटरफेस के लिए करता है।

माइक्रोकंट्रोलर्स के प्रकार

माइक्रोकंट्रोलर्स को मेमोरी, आर्किटेक्चर, बिट्स और इंस्ट्रक्शन सेट के आधार पर विभिन्न श्रेणियों में बांटा गया है। निम्नलिखित उनके प्रकारों की सूची है -

बिट

बिट कॉन्फ़िगरेशन के आधार पर, माइक्रोकंट्रोलर को आगे तीन श्रेणियों में विभाजित किया गया है।

  • 8-bit microcontroller - इस प्रकार के माइक्रोकंट्रोलर का उपयोग अंकगणित और तार्किक संचालन जैसे कि जोड़, घटाव, गुणा भाग आदि को निष्पादित करने के लिए किया जाता है। उदाहरण के लिए, इंटेल 8031 ​​और 8051 8 बिट्स माइक्रोकंट्रोलर हैं।

  • 16-bit microcontroller- इस प्रकार के माइक्रोकंट्रोलर का उपयोग अंकगणित और तार्किक संचालन करने के लिए किया जाता है जहां उच्च सटीकता और प्रदर्शन की आवश्यकता होती है। उदाहरण के लिए, इंटेल 8096 एक 16-बिट माइक्रोकंट्रोलर है।

  • 32-bit microcontroller - इस प्रकार के माइक्रोकंट्रोलर का उपयोग आमतौर पर स्वचालित रूप से नियंत्रित उपकरणों जैसे स्वचालित परिचालन मशीनों, चिकित्सा उपकरणों आदि में किया जाता है।

याद

मेमोरी कॉन्फ़िगरेशन के आधार पर, माइक्रोकंट्रोलर को आगे दो श्रेणियों में विभाजित किया गया है।

  • External memory microcontroller- इस प्रकार के माइक्रोकंट्रोलर को इस तरह से डिज़ाइन किया गया है कि उनके पास चिप पर प्रोग्राम मेमोरी नहीं है। इसलिए, इसे बाहरी मेमोरी माइक्रोकंट्रोलर के रूप में नामित किया गया है। उदाहरण के लिए: इंटेल 8031 ​​माइक्रोकंट्रोलर।

  • Embedded memory microcontroller- इस प्रकार के माइक्रोकंट्रोलर को इस तरह से डिज़ाइन किया गया है कि माइक्रोकंट्रोलर के पास सभी प्रोग्राम और डेटा मेमोरी, काउंटर और टाइमर, इंटरप्ट, I / O पोर्ट चिप पर एम्बेडेड हैं। उदाहरण के लिए: इंटेल 8051 माइक्रोकंट्रोलर।

निर्देश समुच्चय

निर्देश सेट कॉन्फ़िगरेशन के आधार पर, माइक्रोकंट्रोलर को आगे दो श्रेणियों में विभाजित किया गया है।

  • CISC- CISC का मतलब जटिल इंस्ट्रक्शन सेट कंप्यूटर है। यह उपयोगकर्ता को कई सरल निर्देशों के विकल्प के रूप में एकल निर्देश सम्मिलित करने की अनुमति देता है।

  • RISC- RISC का मतलब कम इंस्ट्रक्शन सेट कंप्यूटर्स है। यह प्रति निर्देश घड़ी चक्र को छोटा करके परिचालन समय को कम करता है।

माइक्रोकंट्रोलर्स के अनुप्रयोग

माइक्रोकंट्रोलर्स को विभिन्न विभिन्न उपकरणों में व्यापक रूप से उपयोग किया जाता है जैसे -

  • लाइट सेंसिंग और कंट्रोलिंग डिवाइस जैसे एलईडी।

  • माइक्रोवेव ओवन, चिमनी जैसे तापमान संवेदन और नियंत्रण उपकरण।

  • फायर डिटेक्शन और सेफ्टी डिवाइस जैसे फायर अलार्म।

  • मापक उपकरण जैसे वोल्ट मीटर।

8051 माइक्रोकंट्रोलर को 1981 में इंटेल द्वारा डिजाइन किया गया था। यह 8-बिट माइक्रोकंट्रोलर है। इसे 40 पिन DIP (डुअल इनलाइन पैकेज), 4kb रॉम स्टोरेज और 128 बाइट्स रैम स्टोरेज, 2 16-बिट टाइमर के साथ बनाया गया है। इसमें चार समानांतर 8-बिट पोर्ट होते हैं, जो प्रोग्राम योग्य होते हैं और साथ ही आवश्यकता के अनुसार पता योग्य होते हैं। एक चिप चिप थरथरानवाला 12 MHz की क्रिस्टल आवृत्ति वाले माइक्रोकंट्रोलर में एकीकृत होता है।

आइए अब हम 8051 माइक्रोकंट्रोलर की वास्तुकला पर चर्चा करते हैं।

निम्नलिखित आरेख में, सिस्टम बस सभी समर्थन उपकरणों को सीपीयू से जोड़ता है। सिस्टम बस में 8-बिट डेटा बस, 16-बिट एड्रेस बस और बस कंट्रोल सिग्नल शामिल होते हैं। अन्य सभी डिवाइस जैसे प्रोग्राम मेमोरी, पोर्ट, डेटा मेमोरी, सीरियल इंटरफेस, इंटरप्ट कंट्रोल, टाइमर, और सीपीयू सभी को सिस्टम बस के माध्यम से एक साथ रखा जाता है।

8051 माइक्रोकंट्रोलर का पिन आरेख इस प्रकार है -

  • Pins 1 to 8- इन पिनों को पोर्ट 1 के रूप में जाना जाता है। यह पोर्ट किसी भी अन्य कार्य को पूरा नहीं करता है। इसे आंतरिक रूप से ऊपर खींचा जाता है, द्वि-दिशात्मक I / O पोर्ट।

  • Pin 9 - यह एक RESET पिन है, जिसका उपयोग माइक्रोकंट्रोलर को उसके प्रारंभिक मानों को रीसेट करने के लिए किया जाता है।

  • Pins 10 to 17 - इन पिनों को पोर्ट 3 के रूप में जाना जाता है। यह पोर्ट कुछ कार्यों जैसे इंटरप्ट, टाइमर इनपुट, कंट्रोल सिग्नल, सीरियल कम्युनिकेशन सिग्नल RxD और TxD इत्यादि का कार्य करता है।

  • Pins 18 & 19 - इन पिनों का उपयोग सिस्टम घड़ी प्राप्त करने के लिए एक बाहरी क्रिस्टल को रखने के लिए किया जाता है।

  • Pin 20 - यह पिन सर्किट को बिजली की आपूर्ति प्रदान करता है।

  • Pins 21 to 28- इन पिनों को पोर्ट 2 के रूप में जाना जाता है। यह I / O पोर्ट के रूप में कार्य करता है। इस पोर्ट का उपयोग करते हुए उच्च क्रम का पता बस सिग्नल भी बहुसंकेतन हैं।

  • Pin 29- यह PSEN पिन है जो प्रोग्राम स्टोर इनेबल के लिए है। इसका उपयोग बाहरी प्रोग्राम मेमोरी से सिग्नल पढ़ने के लिए किया जाता है।

  • Pin 30- यह ईए पिन है जो बाहरी एक्सेस इनपुट के लिए है। इसका उपयोग बाह्य मेमोरी इंटरफेस को सक्षम / अक्षम करने के लिए किया जाता है।

  • Pin 31- यह ALE पिन है जो एड्रेस लैच इनेबल के लिए है। इसका उपयोग पोर्ट के एड्रेस-डेटा सिग्नल को डी-मेल करने के लिए किया जाता है।

  • Pins 32 to 39- इन पिनों को पोर्ट 0. के रूप में जाना जाता है। यह I / O पोर्ट के रूप में कार्य करता है। इस पोर्ट का उपयोग करते हुए लोअर ऑर्डर एड्रेस और डेटा बस सिग्नल को मल्टीप्लेक्स किया जाता है।

  • Pin 40 - इस पिन का उपयोग सर्किट को बिजली की आपूर्ति प्रदान करने के लिए किया जाता है।

8051 माइक्रोकंट्रोलर्स में 8-बिट में से प्रत्येक में 4 I / O पोर्ट होते हैं, जिन्हें इनपुट या आउटपुट के रूप में कॉन्फ़िगर किया जा सकता है। इसलिए, कुल 32 इनपुट / आउटपुट पिन माइक्रोकंट्रोलर को परिधीय उपकरणों के साथ जोड़ने की अनुमति देते हैं।

  • Pin configuration, यानी पिन को तर्क के अनुसार आउटपुट के लिए 1 और आउटपुट के लिए 0 के रूप में कॉन्फ़िगर किया जा सकता है।

    • Input/Output (I/O) pin - माइक्रोकंट्रोलर के भीतर सभी सर्किट P0 पोर्ट को छोड़कर इसके किसी एक पिन से जुड़े होने चाहिए क्योंकि इसमें पुल-अप रेसिस्टर्स बिल्ट-इन नहीं होते हैं।

    • Input pin- तर्क 1 को P रजिस्टर में थोड़ा सा लागू किया जाता है। आउटपुट FE ट्रांजिस्टर को बंद कर दिया जाता है और दूसरा पिन उच्च प्रतिरोध के पुल-अप प्रतिरोध पर बिजली की आपूर्ति वोल्टेज से जुड़ा रहता है।

  • Port 0 - P0 (शून्य) पोर्ट दो कार्यों की विशेषता है -

    • जब बाहरी मेमोरी का उपयोग किया जाता है तो उस पर निचला पता बाइट (पते A0A7) लगाया जाता है, अन्यथा इस पोर्ट के सभी बिट्स इनपुट / आउटपुट के रूप में कॉन्फ़िगर किए जाते हैं।

    • जब P0 पोर्ट को आउटपुट के रूप में कॉन्फ़िगर किया जाता है, तो अन्य पोर्ट्स जिसमें अंतर्निर्मित पुल-अप अवरोधक होते हैं, जो इसके 5V पावर सप्लाई के अंत से जुड़े होते हैं, इस पोर्ट के पिनों में यह रेसिस्टर बाहर रहता है।

इनपुट कॉन्फ़िगरेशन

यदि इस पोर्ट के किसी भी पिन को इनपुट के रूप में कॉन्फ़िगर किया गया है, तो यह कार्य करता है जैसे कि यह "फ्लोट" करता है, अर्थात इनपुट में असीमित इनपुट प्रतिरोध और निर्धारित क्षमता है।

आउटपुट कॉन्फ़िगरेशन

जब पिन आउटपुट के रूप में कॉन्फ़िगर किया जाता है, तो यह "ओपन ड्रेन" के रूप में कार्य करता है। तर्क 0 को पोर्ट बिट पर लागू करने से, उपयुक्त पिन जमीन (0V) से जुड़ा होगा, और तर्क 1 को लागू करने पर, बाहरी आउटपुट "फ्लोटिंग" रहेगा।

इस आउटपुट पिन पर तर्क 1 (5V) लागू करने के लिए, बाहरी पुलअप अवरोधक का निर्माण करना आवश्यक है।

पोर्ट 1

P1 एक सच्चा I / O पोर्ट है क्योंकि इसमें P0 जैसा कोई वैकल्पिक कार्य नहीं है, लेकिन इस पोर्ट को सामान्य I / O के रूप में कॉन्फ़िगर किया जा सकता है। इसमें एक अंतर्निहित पुल-अप रोकनेवाला है और पूरी तरह से टीटीएल सर्किट के साथ संगत है।

पोर्ट 2

P2, P0 के समान है जब बाहरी मेमोरी का उपयोग किया जाता है। इस पोर्ट के पिन बाहरी मेमोरी चिप के लिए निर्धारित पतों पर कब्जा कर लेते हैं। इस पोर्ट का उपयोग A8-A15 के पते के साथ उच्च पता बाइट के लिए किया जा सकता है। जब कोई मेमोरी नहीं जोड़ी जाती है तो इस पोर्ट को पोर्ट 1 के समान सामान्य इनपुट / आउटपुट पोर्ट के रूप में उपयोग किया जा सकता है।

पोर्ट 3

इस पोर्ट में, फ़ंक्शन अन्य पोर्ट के समान हैं सिवाय इसके कि तर्क 1 को P3 रजिस्टर के उपयुक्त बिट पर लागू किया जाना चाहिए।

पिंस वर्तमान सीमाएँ

  • जब पिंस को आउटपुट (अर्थात लॉजिक 0) के रूप में कॉन्फ़िगर किया जाता है, तब सिंगल पोर्ट पिन को 10mA का करंट प्राप्त हो सकता है।

  • जब इन पिनों को इनपुट (यानी तर्क 1) के रूप में कॉन्फ़िगर किया जाता है, तो अंतर्निहित पुल-अप प्रतिरोध बहुत कमजोर वर्तमान प्रदान करते हैं, लेकिन एलएस श्रृंखला के 4 टीटीएल इनपुट तक सक्रिय कर सकते हैं।

  • यदि किसी बंदरगाह के सभी 8 बिट सक्रिय हैं, तो कुल वर्तमान 15mA (पोर्ट P0: 26mA) तक सीमित होना चाहिए।

  • यदि सभी पोर्ट (32 बिट) सक्रिय हैं, तो कुल अधिकतम वर्तमान 71mA तक सीमित होना चाहिए।

रुकावटें ऐसी घटनाएं हैं जो मुख्य कार्यक्रम को अस्थायी रूप से निलंबित करती हैं, बाहरी स्रोतों पर नियंत्रण पारित करती हैं और अपने कार्य को निष्पादित करती हैं। यह तब मुख्य कार्यक्रम पर नियंत्रण को पारित करता है जहां इसे छोड़ दिया गया था।

8051 में 5 इंटरप्ट सिग्नल हैं, यानी INT0, TFO, INT1, TF1, RI / TI। IE रजिस्टर के बिट्स सेट करके प्रत्येक रुकावट को सक्षम या अक्षम किया जा सकता है और एक ही रजिस्टर के EA बिट को क्लियर करके पूरे इंटरप्ट सिस्टम को निष्क्रिय किया जा सकता है।

IE (इंटरप्ट इनेबल) रजिस्टर

यह रजिस्टर व्यवधान को सक्षम और अक्षम करने के लिए जिम्मेदार है। ईए रजिस्टर इंटरप्ट को सक्षम करने के लिए एक पर सेट है और इंटरप्ट को अक्षम करने के लिए 0 पर सेट है। इसका बिट क्रम और उनके अर्थ निम्न आकृति में दिखाए गए हैं।

ईए IE.7 यह सभी व्यवधानों को निष्क्रिय करता है। जब ईए = 0 कोई अवरोध स्वीकार नहीं किया जाएगा और ईए = 1 व्यक्तिगत रूप से रुकावट को सक्षम करता है।
- IE.6 भविष्य उपयोग के लिए आरक्षित।
- IE.5 भविष्य उपयोग के लिए आरक्षित।
तों IE.4 सीरियल पोर्ट में बाधा / निष्क्रिय करता है।
ET1 IE.3 टाइमर 1 को ओवरफ्लो बाधित करने में सक्षम / अक्षम करता है।
EX1 IE.2 बाहरी अवरोध 1 को निष्क्रिय / निष्क्रिय करता है।
ET0 IE.1 टाइमर 0 को ओवरफ़्लो बाधित करने में सक्षम / अक्षम करता है।
EX0 IE.0 बाहरी अवरोध को सक्षम / अक्षम करता है।

आईपी ​​(बाधित प्राथमिकता) रजिस्टर

हम इंटरप्रिट प्रायोरिटी (IP) रजिस्टर में संबंधित बिट को बदलकर इंटरप्ट के प्राथमिकता स्तर को बदल सकते हैं जैसा कि निम्नलिखित आकृति में दिखाया गया है।

  • एक कम प्राथमिकता वाले व्यवधान को केवल उच्च प्राथमिकता वाले व्यवधान से बाधित किया जा सकता है, लेकिन एक अन्य कम प्राथमिकता वाले व्यवधान से बाधित नहीं किया जा सकता है।

  • यदि अलग-अलग प्राथमिकता स्तरों के दो व्यवधान एक साथ प्राप्त होते हैं, तो उच्च प्राथमिकता स्तर का अनुरोध परोसा जाता है।

  • यदि समान प्राथमिकता स्तरों के अनुरोध एक साथ प्राप्त होते हैं, तो आंतरिक मतदान अनुक्रम निर्धारित करता है कि किस सेवा को सेवित किया जाना है।

- IP.6 भविष्य उपयोग के लिए आरक्षित।
- IP.5 भविष्य उपयोग के लिए आरक्षित।
पी.एस. IP.4 यह सीरियल पोर्ट इंटरप्ट प्राथमिकता स्तर को परिभाषित करता है।
PT1 IP.3 यह 1 प्राथमिकता के टाइमर रुकावट को परिभाषित करता है।
PX1 IP.2 यह बाहरी रुकावट प्राथमिकता स्तर को परिभाषित करता है।
PT0 IP.1 यह टाइमर 0 बाधा प्राथमिकता स्तर को परिभाषित करता है।
PX0 IP.0 यह 0 प्राथमिकता स्तर के बाहरी व्यवधान को परिभाषित करता है।

TCON रजिस्टर

TCON रजिस्टर माइक्रोकंट्रोलर के बाहरी अवरोधन के प्रकार को निर्दिष्ट करता है।

8255A एक सामान्य उद्देश्य प्रोग्रामेबल I / O डिवाइस है जिसे I / O से डेटा को ट्रांसफर करने के लिए डिज़ाइन किया गया है ताकि कुछ शर्तों के तहत I / O को बाधित किया जा सके। इसका उपयोग लगभग किसी भी माइक्रोप्रोसेसर के साथ किया जा सकता है।

इसमें तीन 8-बिट द्विदिश I / O पोर्ट (24I / O लाइन्स) होते हैं जिन्हें आवश्यकता के अनुसार कॉन्फ़िगर किया जा सकता है।

8255 ए के पोर्ट

8255A के तीन पोर्ट हैं, जैसे, PORT A, PORT B ​​और PORT C।

  • Port A इसमें एक 8-बिट आउटपुट लैच / बफर और एक 8-बिट इनपुट बफर होता है।

  • Port B PORT A के समान है।

  • Port C दो भागों में विभाजित किया जा सकता है, यानी PORT C लोअर (PC0-PC3) और PORT C अपर (PC7-PC4) कंट्रोल शब्द से।

इन तीन बंदरगाहों को आगे दो समूहों में विभाजित किया गया है, यानी ग्रुप ए में पोर्ट ए और ऊपरी पोर्ट सी। ग्रुप बी में पोर्ट बी और निचले पोर्ट सी शामिल हैं। इन दो समूहों को तीन अलग-अलग मोड में प्रोग्राम किया जा सकता है, अर्थात पहले मोड को मोड के रूप में नामित किया गया है। 0, दूसरे मोड को मोड 1 और तीसरे मोड को मोड 2 नाम दिया गया है।

वर्तमान विधियां

8255A के तीन अलग-अलग ऑपरेटिंग मोड हैं -

  • Mode 0- इस मोड में, पोर्ट ए और बी को दो 8-बिट पोर्ट के रूप में और पोर्ट सी को दो 4-बिट पोर्ट के रूप में उपयोग किया जाता है। प्रत्येक पोर्ट को इनपुट मोड या आउटपुट मोड में प्रोग्राम किया जा सकता है, जहां आउटपुट लैच होते हैं और इनपुट लैच नहीं होते हैं। पोर्ट्स में इंटरप्ट क्षमता नहीं है।

  • Mode 1- इस मोड में, पोर्ट ए और बी का उपयोग 8-बिट I / O पोर्ट के रूप में किया जाता है। उन्हें इनपुट या आउटपुट पोर्ट के रूप में कॉन्फ़िगर किया जा सकता है। प्रत्येक पोर्ट हैंडशेक सिग्नल के रूप में पोर्ट सी से तीन लाइनों का उपयोग करता है। इनपुट्स और आउटपुट लैच किए गए हैं।

  • Mode 2- इस मोड में, पोर्ट ए को द्विदिश पोर्ट के रूप में और पोर्ट बी को मोड 0 या मोड 1 में कॉन्फ़िगर किया जा सकता है। पोर्ट ए डेटा ट्रांसफर के लिए हैंडशेक सिग्नल के रूप में पोर्ट सी से पांच सिग्नल का उपयोग करता है। पोर्ट सी से शेष तीन संकेतों को सरल I / O के रूप में या पोर्ट बी के लिए हैंडशेक के रूप में इस्तेमाल किया जा सकता है।

8255A की विशेषताएं

8255A की प्रमुख विशेषताएं इस प्रकार हैं -

  • इसमें 3 8-बिट IO पोर्ट यानी PA, PB और PC शामिल हैं।

  • पता / डेटा बस बाहरी रूप से डिमएक्सलाइड होना चाहिए।

  • यह टीटीएल संगत है।

  • इसने डीसी ड्राइविंग क्षमता में सुधार किया है।

8255 वास्तुकला

निम्नलिखित आंकड़ा 8255A की वास्तुकला को दर्शाता है -

आइए पहले इंटेल 8255A के पिन आरेख पर एक नज़र डालें -

अब हम A२५५ ए में पिंस के कार्यात्मक विवरण पर चर्चा करते हैं।

डेटा बस बफर

यह एक त्रिकोणीय 8-बिट बफर है, जिसका उपयोग माइक्रोप्रोसेसर को सिस्टम डेटा बस में इंटरफेस करने के लिए किया जाता है। सीपीयू द्वारा निर्देशों के अनुसार बफर द्वारा डेटा प्रेषित या प्राप्त किया जाता है। इस बस का उपयोग करके नियंत्रण शब्द और स्थिति की जानकारी भी स्थानांतरित की जाती है।

पढ़ें / नियंत्रण तर्क लिखें

यह ब्लॉक डेटा / नियंत्रण / स्थिति शब्द के आंतरिक / बाहरी हस्तांतरण को नियंत्रित करने के लिए जिम्मेदार है। यह CPU पते और नियंत्रण बसों से इनपुट को स्वीकार करता है, और बदले में दोनों नियंत्रण समूहों को आदेश जारी करता है।

सीएस

यह चिप सेलेक्ट के लिए है। इस इनपुट पर एक LOW चिप का चयन करता है और 8255A और CPU के बीच संचार को सक्षम करता है। यह डिकोड किए गए पते से जुड़ा है, और A 0 & A 1 माइक्रोप्रोसेसर पता लाइनों से जुड़ा है।

उनका परिणाम निम्न स्थितियों पर निर्भर करता है -

सीएस परिणाम
0 0 0 पोर्ट ए
0 0 1 पोर्ट बी
0 1 0 पोर्ट सी
0 1 1 नियंत्रण रजिस्टर
1 एक्स एक्स कोई चयन नहीं

WR

यह लिखने के लिए खड़ा है। यह नियंत्रण संकेत लिखने के संचालन को सक्षम करता है। जब यह संकेत कम होता है, तो माइक्रोप्रोसेसर किसी चयनित I / O पोर्ट या कंट्रोल रजिस्टर में लिखता है।

रीसेट

यह एक सक्रिय उच्च संकेत है। यह नियंत्रण रजिस्टर को साफ करता है और इनपुट मोड में सभी पोर्ट सेट करता है।

तृतीय

यह पढ़ने के लिए खड़ा है। यह नियंत्रण संकेत रीड ऑपरेशन को सक्षम करता है। जब सिग्नल कम होता है, तो माइक्रोप्रोसेसर 8255 के चयनित I / O पोर्ट से डेटा पढ़ता है।

और ए

ये इनपुट सिग्नल RD, WR और कंट्रोल सिग्नल में से एक के साथ काम करते हैं। निम्नलिखित तालिका उनके परिणाम के साथ उनके विभिन्न संकेतों को दिखा रही है।

तृतीय WR सीएस परिणाम
0 0 0 1 0

Input Operation

पोर्ट ए → डेटा बस
0 1 0 1 0 पोर्ट बी → डेटा बस
1 0 0 1 0 पोर्ट सी → डेटा बस
0 0 1 0 0

Output Operation

डेटा बस → PORT A
0 1 1 0 0 डेटा बस → PORT A
1 0 1 0 0 डेटा बस → पोर्ट बी
1 1 1 0 0 डेटा बस → पोर्ट डी

इंटेल 8253 और 8254 प्रोग्रामेबल इंटरवल टाइमर (PTI) हैं जो माइक्रोप्रोसेसरों के लिए तीन 16-बिट रजिस्टरों का उपयोग करके समय और गिनती कार्यों को करने के लिए डिज़ाइन किए गए हैं। प्रत्येक काउंटर में 2 इनपुट पिन, क्लॉक और गेट, और "आउट" आउटपुट के लिए 1 पिन है। एक काउंटर को संचालित करने के लिए, 16-बिट काउंट को उसके रजिस्टर में लोड किया जाता है। आदेश पर, यह 0 तक पहुंचने तक गिनती को कम करना शुरू कर देता है, फिर यह एक पल्स उत्पन्न करता है जिसका उपयोग सीपीयू को बाधित करने के लिए किया जा सकता है।

8253 और 8254 के बीच अंतर

निम्न तालिका 8253 और 8254 की विशेषताओं को अलग करती है -

8253 8254
इसकी ऑपरेटिंग आवृत्ति 0 - 2.6 मेगाहर्ट्ज है इसकी ऑपरेटिंग आवृत्ति 0 - 10 मेगाहर्ट्ज है
यह एन-एमओएस तकनीक का उपयोग करता है इसमें H-MOS तकनीक का इस्तेमाल होता है
रीड-बैक कमांड उपलब्ध नहीं है रीड-बैक कमांड उपलब्ध है
एक ही काउंटर को पढ़ता है और लिखता नहीं है। एक ही काउंटर के रीड एंड राइट्स को इंटरलीव किया जा सकता है।

8253/54 की विशेषताएं

8253/54 की सबसे प्रमुख विशेषताएं इस प्रकार हैं -

  • इसमें तीन स्वतंत्र 16-बिट डाउन काउंटर हैं।

  • यह डीसी से 10 मेगाहर्ट्ज तक इनपुट संभाल सकता है।

  • इन तीन काउंटरों को बाइनरी या बीसीडी काउंट के लिए प्रोग्राम किया जा सकता है।

  • यह लगभग सभी माइक्रोप्रोसेसरों के साथ संगत है।

  • 8254 में READ BACK कमांड नामक एक शक्तिशाली कमांड है, जो उपयोगकर्ता को काउंट वैल्यू, प्रोग्राम किए गए मोड, वर्तमान मोड और काउंटर की वर्तमान स्थिति की जांच करने की अनुमति देता है।

8254 वास्तुकला

8254 की वास्तुकला इस प्रकार है -

8254 पिन विवरण

यहाँ 8254 का पिन आरेख है -

उपरोक्त आंकड़ों में, तीन काउंटर हैं, एक डेटा बस बफर, नियंत्रण तर्क पढ़ें / और एक नियंत्रण रजिस्टर। प्रत्येक काउंटर में दो इनपुट सिग्नल होते हैं - CLOCK & GATE, और एक आउटपुट सिग्नल - OUT।

डेटा बस बफर

यह एक त्रि-राज्य, द्वि-दिशात्मक, 8-बिट बफर है, जिसका उपयोग सिस्टम डेटा बस में 8253/54 को इंटरफ़ेस करने के लिए किया जाता है। इसके तीन बुनियादी कार्य हैं -

  • 8253/54 के मोड प्रोग्रामिंग।
  • गिनती रजिस्टर लोड हो रहा है।
  • गिनती मूल्यों को पढ़ना।

लॉजिक लिखें / लिखें

इसमें 5 सिग्नल, यानी RD, WR, CS और एड्रेस लाइन्स A 0 & A 1 शामिल हैं । परिधीय I / O मोड में, RD और WR सिग्नल क्रमशः IOR और IOW से जुड़े होते हैं। मेमोरीमैप्ड I / O मोड में, ये MEMR और MEMW से जुड़े हैं।

सीपीयू की पता लाइनें A 0 & A 1 8253/54 की लाइनों A 0 और A 1 से जुड़ी हैं, और CS एक डिकोड किए गए पते से बंधा हुआ है। नियंत्रण शब्द रजिस्टर और काउंटरों को लाइनों ए 0 और ए 1 पर संकेतों के अनुसार चुना जाता है ।

परिणाम
0 0 काउंटर 0
0 1 काउंटर 1
1 0 Counter 2
1 1 Control Word Register
X X No Selection

Control Word Register

This register is accessed when lines A0 & A1 are at logic 1. It is used to write a command word, which specifies the counter to be used, its mode, and either a read or write operation. Following table shows the result for various control inputs.

A1 A0 RD WR CS Result
0 0 1 0 0 Write Counter 0
0 1 1 0 0 Write Counter 1
1 0 1 0 0 Write Counter 2
1 1 1 0 0 Write Control Word
0 0 0 1 0 Read Counter 0
0 1 0 1 0 Read Counter 1
1 0 0 1 0 Read Counter 2
1 1 0 1 0 No operation
X X 1 1 0 No operation
X X X X 1 No operation

Counters

Each counter consists of a single, 16 bit-down counter, which can be operated in either binary or BCD. Its input and output is configured by the selection of modes stored in the control word register. The programmer can read the contents of any of the three counters without disturbing the actual count in process.

8253/54 can be operated in 6 different modes. In this chapter, we will discuss these operational modes.

Mode 0 ─ Interrupt on Terminal Count

  • It is used to generate an interrupt to the microprocessor after a certain interval.

  • Initially the output is low after the mode is set. The output remains LOW after the count value is loaded into the counter.

  • The process of decrementing the counter continues till the terminal count is reached, i.e., the count become zero and the output goes HIGH and will remain high until it reloads a new count.

  • The GATE signal is high for normal counting. When GATE goes low, counting is terminated and the current count is latched till the GATE goes high again.

Mode 1 – Programmable One Shot

  • It can be used as a mono stable multi-vibrator.

  • The gate input is used as a trigger input in this mode.

  • The output remains high until the count is loaded and a trigger is applied.

Mode 2 – Rate Generator

  • The output is normally high after initialization.

  • Whenever the count becomes zero, another low pulse is generated at the output and the counter will be reloaded.

Mode 3 – Square Wave Generator

  • This mode is similar to Mode 2 except the output remains low for half of the timer period and high for the other half of the period.

Mode 4 − Software Triggered Mode

  • In this mode, the output will remain high until the timer has counted to zero, at which point the output will pulse low and then go high again.

  • The count is latched when the GATE signal goes LOW.

  • On the terminal count, the output goes low for one clock cycle then goes HIGH. This low pulse can be used as a strobe.

Mode 5 – Hardware Triggered Mode

  • This mode generates a strobe in response to an externally generated signal.

  • This mode is similar to mode 4 except that the counting is initiated by a signal at the gate input, which means it is hardware triggered instead of software triggered.

  • After it is initialized, the output goes high.

  • When the terminal count is reached, the output goes low for one clock cycle.