कंट्रोल यूनिट: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Component of a computer's CPU}} {{About|the component of a computer's CPU}} कंट्रोल यूनिट (CU) कंप्यूटर की ...")
 
 
(27 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{Short description|Component of a computer's CPU}}
{{About|the component of a computer's CPU}}


कंट्रोल यूनिट (CU) कंप्यूटर की [[सेंट्रल प्रोसेसिंग यूनिट]] (CPU) का एक घटक है जो प्रोसेसर के संचालन को निर्देशित करता है। एक सीयू आमतौर पर कोडित निर्देशों को समय और नियंत्रण संकेतों में परिवर्तित करने के लिए एक [[बाइनरी डिकोडर]] का उपयोग करता है जो अन्य इकाइयों (मेमोरी, [[अंकगणितीय तर्क इकाई]] और इनपुट और आउटपुट डिवाइस इत्यादि) के संचालन को निर्देशित करता है।


अधिकांश कंप्यूटर संसाधन सीयू द्वारा प्रबंधित किए जाते हैं। यह CPU और अन्य उपकरणों के बीच डेटा के प्रवाह को निर्देशित करता है। [[जॉन वॉन न्यूमैन]] ने [[वॉन न्यूमैन वास्तुकला]] के भाग के रूप में नियंत्रण इकाई को शामिल किया।<ref>{{Citation|last1=von Neumann |first1=John |title=First Draft of a Report on the EDVAC |year=1945 |publisher=Moore School of Electrical Engineering, University of Pennsylvania |url=http://qss.stanford.edu/~godfrey/vonNeumann/vnedvac.pdf |url-status=dead |archive-url=https://web.archive.org/web/20130314123032/http://qss.stanford.edu/~godfrey/vonNeumann/vnedvac.pdf |archive-date=March 14, 2013 }}</ref> आधुनिक कंप्यूटर डिजाइनों में, नियंत्रण इकाई आमतौर पर सेंट्रल प्रोसेसिंग यूनिट का एक आंतरिक हिस्सा होती है<!-- or other device that directs its operation--> इसकी शुरूआत के बाद से इसकी समग्र भूमिका और संचालन में कोई बदलाव नहीं हुआ है।<ref>{{cite web|url=https://www.geeksforgeeks.org/computer-organization-control-unit-and-design/|title=कंप्यूटर संगठन - नियंत्रण इकाई और डिजाइन|website=GeeksforGeeks|author=Astha Singh|date=24 September 2018 |access-date=25 May 2019}}</ref>
'''कंट्रोल यूनिट''' (CU) कंप्यूटर की [[सेंट्रल प्रोसेसिंग  यूनिट]] (सीपीयू) का घटक है जो प्रोसेसर के ऑपरेशन को निर्देशित करता है। सीयू सामान्यतः कोडित निर्देशों को समय और कंट्रोल संकेतों में परिवर्तित करने के लिए [[बाइनरी डिकोडर]] का उपयोग करता है जो अन्य यूनिट्स (मेमोरी, [[अंकगणितीय तर्क इकाई|अर्थमेटिक लॉजिक यूनिट]] और इनपुट और आउटपुट डिवाइस इत्यादि) के ऑपरेशन को निर्देशित करता है।


अधिकांश कंप्यूटर संसाधन सीयू द्वारा प्रबंधित किए जाते हैं। यह सीपीयू और अन्य उपकरणों के मध्य डेटा के प्रवाह को निर्देशित करता है। [[जॉन वॉन न्यूमैन]] ने [[वॉन न्यूमैन वास्तुकला]] के भाग के रूप में कंट्रोल यूनिट को सम्मिलित किया।<ref>{{Citation|last1=von Neumann |first1=John |title=First Draft of a Report on the EDVAC |year=1945 |publisher=Moore School of Electrical Engineering, University of Pennsylvania |url=http://qss.stanford.edu/~godfrey/vonNeumann/vnedvac.pdf |url-status=dead |archive-url=https://web.archive.org/web/20130314123032/http://qss.stanford.edu/~godfrey/vonNeumann/vnedvac.pdf |archive-date=March 14, 2013 }}</ref> आधुनिक कंप्यूटर डिजाइनों में, कंट्रोल यूनिट सामान्यतः सेंट्रल प्रोसेसिंग  यूनिट का आंतरिक भाग होता है इसके प्रारम्भ के पश्चात से इसकी समग्र भूमिका और ऑपरेशन में कोई परिवर्तन नहीं हुआ है।<ref>{{cite web|url=https://www.geeksforgeeks.org/computer-organization-control-unit-and-design/|title=कंप्यूटर संगठन - नियंत्रण इकाई और डिजाइन|website=GeeksforGeeks|author=Astha Singh|date=24 September 2018 |access-date=25 May 2019}}</ref>
== मल्टीसाइकिल कंट्रोल  यूनिट ==


== मल्टीसाइकिल कंट्रोल यूनिट ==
सरलतम कंप्यूटर सूक्ष्म वास्तुकला मल्टीसाइकिल सूक्ष्म वास्तुकला का उपयोग करते हैं। ये सबसे प्रारंभिक डिजाइन थी। वे अभी भी सबसे अल्प कंप्यूटरों में लोकप्रिय हैं, जैसे अंतः स्थापित प्रणालियाँ जो मशीनरी संचालित करते हैं।


सरलतम कंप्यूटर एक माइक्रोआर्किटेक्चर#मल्टीसाइकल माइक्रोआर्किटेक्चर का उपयोग करते हैं। ये सबसे शुरुआती डिजाइन थे। वे अभी भी सबसे छोटे कंप्यूटरों में लोकप्रिय हैं, जैसे एम्बेडेड सिस्टम जो मशीनरी संचालित करते हैं।
कंप्यूटर में, कंट्रोल यूनिट प्रायः [[निर्देश चक्र]] के माध्यम से क्रमिक रूप से कदम उठाती है। इसमें निर्देश प्राप्त करना, ऑपरेंड प्राप्त करना, निर्देश को डिकोड करना, निर्देश को क्रियान्वित करना और तत्पश्चात परिणाम को मैमोरी में वापस लिखना सम्मिलित है। जब आगामी निर्देश कंट्रोल यूनिट में रखा जाता है, तो यह निर्देश को उचित रूप से पूर्ण करने के लिए कंट्रोल यूनिट के व्यवहार को परिवर्तित कर देता है। तो, निर्देश के बिट्स सीधे कंट्रोल  यूनिट को नियंत्रित करते हैं, जो परिवर्तन में कंप्यूटर को नियंत्रित करता है।


एक कंप्यूटर में, नियंत्रण इकाई अक्सर [[निर्देश चक्र]] के माध्यम से क्रमिक रूप से कदम उठाती है। इसमें निर्देश प्राप्त करना, ऑपरेंड प्राप्त करना, निर्देश को डिकोड करना, निर्देश को क्रियान्वित करना और फिर परिणाम को स्मृति में वापस लिखना शामिल है। जब अगला निर्देश नियंत्रण इकाई में रखा जाता है, तो यह निर्देश को सही ढंग से पूरा करने के लिए नियंत्रण इकाई के व्यवहार को बदल देता है। तो, निर्देश के बिट्स सीधे कंट्रोल यूनिट को नियंत्रित करते हैं, जो बदले में कंप्यूटर को नियंत्रित करता है।
कंट्रोल यूनिट में कंट्रोल यूनिट के नियम को बताने के लिए बाइनरी काउंटर सम्मिलित हो सकता है कि उसे क्या कदम उठाना चाहिए।


नियंत्रण इकाई में नियंत्रण इकाई के तर्क को बताने के लिए एक बाइनरी काउंटर शामिल हो सकता है कि उसे क्या कदम उठाना चाहिए।
मल्टीसाइकिल कंट्रोल यूनिट्स सामान्यतः अपने स्क्वायर-वेव टाइमिंग क्लॉक के बढ़ते और गिरते दोनों सीमाओं का उपयोग करती हैं। वे टाइमिंग क्लॉक की प्रत्येक सीमा पर अपने ऑपरेशन का चरण संचालित करते हैं, जिससे चार-चरण का ऑपरेशन दो घड़ी चक्रों में पूर्ण हो। समान लॉजिक समुदाय  को देखते हुए यह कंप्यूटर की गति को दोगुना कर देता है।


मल्टीसाइकिल नियंत्रण इकाइयां आमतौर पर अपने स्क्वायर-वेव टाइमिंग क्लॉक के बढ़ते और गिरते दोनों किनारों का उपयोग करती हैं। वे टाइमिंग क्लॉक के प्रत्येक किनारे पर अपने ऑपरेशन का एक चरण संचालित करते हैं, ताकि चार-चरण का ऑपरेशन दो घड़ी चक्रों में पूरा हो। समान लॉजिक परिवार को देखते हुए यह कंप्यूटर की गति को दोगुना कर देता है।
कई कंप्यूटरों में दो भिन्न-भिन्न प्रकार की अनपेक्षित घटनाएं होती हैं। व्यवधान उत्पन्न होता है क्योंकि किसी प्रकार के इनपुट या आउटपुट को उचित रूप से संचालित करने के लिए सॉफ़्टवेयर ध्यान देने की आवश्यकता होती है। कंप्यूटर के ऑपरेशन के कारण  अपवाद हैंडलिंग होती है। महत्वपूर्ण अंतर यह है कि रुकावट के समय की भविष्यवाणी नहीं की जा सकती। दूसरा यह है कि कुछ अपवाद (जैसे मेमोरी-नॉट-उपलब्ध अपवाद) निर्देश के कारण हो सकते हैं जिन्हें पुनःप्रारम्भ करने की आवश्यकता होती है।


कई कंप्यूटरों में दो अलग-अलग प्रकार की अनपेक्षित घटनाएं होती हैं। व्यवधान उत्पन्न होता है क्योंकि किसी प्रकार के इनपुट या आउटपुट को सही ढंग से संचालित करने के लिए सॉफ़्टवेयर ध्यान देने की आवश्यकता होती है। कंप्यूटर के संचालन के कारण एक अपवाद हैंडलिंग होती है। एक महत्वपूर्ण अंतर यह है कि रुकावट के समय की भविष्यवाणी नहीं की जा सकती। दूसरा यह है कि कुछ अपवाद (जैसे मेमोरी-नॉट-उपलब्ध अपवाद) एक निर्देश के कारण हो सकते हैं जिन्हें पुनरारंभ करने की आवश्यकता होती है।
कंट्रोल यूनिट्स को दो विशिष्ट प्रविधियो में व्यवधान को संभालने के लिए डिज़ाइन किया जा सकता है। यदि त्वरित प्रतिक्रिया सबसे महत्वपूर्ण है, तो कंट्रोल यूनिट को रुकावट को संभालने के लिए कार्य त्यागने के लिए डिज़ाइन किया गया है। इस विषय में, अंतिम पूर्ण निर्देश के पश्चात प्रक्रिया में कार्य तत्पश्चात से प्रारम्भ हो जाएगा। यदि कंप्यूटर को अधिक सस्ता, अधिक सरल, अधिक विश्वसनीय होना है, या अधिक कार्य करना है, तो कंट्रोल यूनिट व्यवधान को संभालने से पूर्व प्रक्रिया में कार्य पूर्ण कर लेगी। कार्य समाप्त करना सस्ता है, क्योंकि अंतिम प्रस्तुत निर्देश को रिकॉर्ड करने के लिए किसी रजिस्टर की जरूरत नहीं है। यह सरल और विश्वसनीय है क्योंकि इसमें सबसे कम अवस्थाएँ हैं।


नियंत्रण इकाइयों को दो विशिष्ट तरीकों में से एक में व्यवधान को संभालने के लिए डिज़ाइन किया जा सकता है। यदि एक त्वरित प्रतिक्रिया सबसे महत्वपूर्ण है, तो एक नियंत्रण इकाई को रुकावट को संभालने के लिए काम छोड़ने के लिए डिज़ाइन किया गया है। इस मामले में, अंतिम पूर्ण निर्देश के बाद प्रक्रिया में काम फिर से शुरू हो जाएगा। यदि कंप्यूटर को बहुत सस्ता, बहुत सरल, बहुत विश्वसनीय होना है, या अधिक काम करना है, तो नियंत्रण इकाई व्यवधान को संभालने से पहले प्रक्रिया में काम पूरा कर लेगी। काम खत्म करना सस्ता है, क्योंकि अंतिम तैयार निर्देश को रिकॉर्ड करने के लिए किसी रजिस्टर की जरूरत नहीं है। यह सरल और विश्वसनीय है क्योंकि इसमें सबसे कम अवस्थाएँ हैं। यह कम से कम काम की बर्बादी भी करता है।
अधिक सरल कंप्यूटरों में [[ बाधा डालना | व्यवधान्स]] के जैसे कार्य करने के लिए अपवाद बनाए जा सकते हैं। यदि [[ आभासी मेमोरी |आभासी मेमोरी]] की आवश्यकता है, तो मेमोरी-नॉट-उपलब्ध अपवाद को असफल निर्देश का पुनः प्रयास करना चाहिए।


बहुत ही सरल कंप्यूटरों में [[ बाधा डालना ]]्स की तरह काम करने के लिए अपवाद बनाए जा सकते हैं। यदि [[ आभासी मेमोरी ]] की आवश्यकता है, तो मेमोरी-नॉट-उपलब्ध अपवाद को असफल निर्देश का पुनः प्रयास करना चाहिए।
मल्टीसाइकिल कंप्यूटर के लिए अधिक साइकिल का उपयोग करना सरल कथन है। कभी-कभी नियमनुसार छलांग लगाने में अधिक समय लगता है, क्योंकि प्रोग्राम काउंटर को तत्पश्चात भार करना पड़ता है। कभी-कभी वे प्रक्रिया द्वारा गुणन या भाग निर्देश करते हैं, जैसे बाइनरी लंबा गुणन और विभाजन अधिक अल्प कंप्यूटर अंकगणित कर सकते हैं, समय में कुछ बिट, कुछ कंप्यूटरों में अधिक जटिल निर्देश होते हैं जो कई कदम उठाते हैं।


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


== पाइपलाइन नियंत्रण इकाइयां ==
कई मध्यम-जटिलता वाले कंप्यूटर सूक्ष्म वास्तुकला निर्देश पाइपलाइनिंग यह डिज़ाइन स्वयं की गति के कारण लोकप्रिय है।


कई मध्यम-जटिलता वाले कंप्यूटर माइक्रोआर्किटेक्चर#निर्देश पाइपलाइनिंग। यह डिज़ाइन अपनी किफायत और गति के कारण लोकप्रिय है।
पाइपलाइन कंप्यूटर में, कंप्यूटर के माध्यम से निर्देश प्रवाहित होते हैं। इस डिज़ाइन के कई चरण हैं। उदाहरण के लिए, इसमें वॉन न्यूमैन चक्र के प्रत्येक चरण के लिए चरण हो सकता है। पाइपलाइन कंप्यूटर में सामान्यतः प्रत्येक चरण के पश्चात पाइपलाइन रजिस्टर होते हैं। ये अवस्था द्वारा परिकलित बिट्स को एकत्र करते हैं जिससे आगामी चरण के [[लॉजिक गेट]] आगामी चरण को करने के लिए बिट्स का उपयोग कर सकें।


एक पाइपलाइन कंप्यूटर में, कंप्यूटर के माध्यम से निर्देश प्रवाहित होते हैं। इस डिज़ाइन के कई चरण हैं। उदाहरण के लिए, इसमें वॉन न्यूमैन चक्र के प्रत्येक चरण के लिए एक चरण हो सकता है। एक पाइपलाइन कंप्यूटर में आमतौर पर प्रत्येक चरण के बाद पाइपलाइन रजिस्टर होते हैं। ये एक स्टेज द्वारा परिकलित बिट्स को स्टोर करते हैं ताकि अगले चरण के [[लॉजिक गेट]] अगले चरण को करने के लिए बिट्स का उपयोग कर सकें।
स्क्वायर-वेव क्लॉक के किनारे पर सम संख्या वाले चरणों के लिए यह सामान्य है, जबकि विषम संख्या वाले चरण दूसरे किनारे पर कार्य करते हैं। यह एकल बढ़त डिज़ाइन की तुलना में कंप्यूटर को दो गुना गति देता है।


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


एक पाइपलाइन कंप्यूटर में, नियंत्रण इकाई प्रोग्राम कमांड के रूप में प्रवाह को शुरू करने, जारी रखने और बंद करने की व्यवस्था करती है। निर्देश डेटा आमतौर पर पाइपलाइन रजिस्टरों में एक चरण से अगले चरण तक पारित किया जाता है, प्रत्येक चरण के लिए नियंत्रण तर्क के कुछ अलग टुकड़े के साथ। नियंत्रण इकाई यह भी आश्वासन देती है कि प्रत्येक चरण में निर्देश अन्य चरणों में निर्देशों के संचालन को नुकसान नहीं पहुँचाता है। उदाहरण के लिए, यदि दो चरणों में डेटा के एक ही टुकड़े का उपयोग करना चाहिए, तो नियंत्रण तर्क यह आश्वासन देता है कि उपयोग सही क्रम में किया जाता है।
कुशलतापूर्वक ऑपरेशन करते समय, पाइपलाइन कंप्यूटर में प्रत्येक चरण में निर्देश होगा। यह समय में उन सभी निर्देशों पर कार्य कर रहा है। यह अपनी घड़ी के प्रत्येक चक्र के लिए लगभग निर्देश पूर्ण कर सकता है। जब कोई प्रोग्राम निर्णय लेता है, और निर्देशों के भिन्न अनुक्रम पर परिवर्तित करता है, तो पाइपलाइन को कभी-कभी प्रक्रिया में डेटा को त्याग देना चाहिए और पुनरारंभ करना चाहिए। इसे स्टॉल कहा जाता है। जब दो निर्देश हस्तक्षेप कर सकते हैं, तो कभी-कभी कंट्रोल यूनिट को पश्चात के निर्देश को तब तक संसाधित करना संवृत कर देना चाहिए जब तक कि पूर्व वाला निर्देश पूर्ण न हो जाए। इसे पाइपलाइन बबल कहा जाता है क्योंकि पाइपलाइन का भाग निर्देशों को प्रोसेस नहीं कर रहा है। पाइपलाइन बुलबुले तब हो सकते हैं जब दो निर्देश साथ में रजिस्टर पर कार्य करते हैं।


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


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


रफ़्तार? इलेक्ट्रॉनिक लॉजिक की समान गति के लिए, यह एक मल्टीसाइकिल कंप्यूटर की तुलना में प्रति सेकंड अधिक निर्देश कर सकता है। इसके अलावा, भले ही इलेक्ट्रॉनिक लॉजिक की एक निश्चित अधिकतम गति हो, पाइपलाइन में चरणों की संख्या को बदलकर एक पाइपलाइन कंप्यूटर को तेज या धीमा बनाया जा सकता है। अधिक चरणों के साथ, प्रत्येक चरण कम कार्य करता है, और इसलिए चरण में लॉजिक गेट्स से कम विलंब होता है।
अर्थव्यवस्था? कंप्यूटर के पाइपलाइन मॉडल में प्रायः प्रति निर्देश प्रति सेकंड कम से कम लॉजिक गेट्स होते हैं, जो मल्टीसाइकिल या आउट-ऑफ-ऑर्डर कंप्यूटर से कम होते हैं। क्यों? मल्टीसाइकिल कंप्यूटर की तुलना में औसत चरण कम जटिल है। आउट-ऑफ़-ऑर्डर कंप्यूटर में सामान्यतः किसी भी क्षण में बड़ी मात्रा में निष्क्रिय लॉजिक होते हैं। इसी प्रकार की गणना सामान्यतः दिखाती है कि पाइपलाइन कंप्यूटर प्रति निर्देश कम ऊर्जा का उपयोग करता है।


अर्थव्यवस्था? कंप्यूटर के एक पाइपलाइन मॉडल में अक्सर प्रति निर्देश प्रति सेकंड कम से कम लॉजिक गेट्स होते हैं, जो या तो एक मल्टीसाइकिल या आउट-ऑफ-ऑर्डर कंप्यूटर से कम होते हैं। क्यों? मल्टीसाइकिल कंप्यूटर की तुलना में औसत चरण कम जटिल है। एक आउट-ऑफ-ऑर्डर कंप्यूटर में आमतौर पर किसी भी पल में बड़ी मात्रा में निष्क्रिय तर्क होते हैं। इसी तरह की गणना आमतौर पर दिखाती है कि एक पाइपलाइन कंप्यूटर प्रति निर्देश कम ऊर्जा का उपयोग करता है।
चूंकि, पाइपलाइन कंप्यूटर सामान्यतः तुलनात्मक मल्टीसाइकिल कंप्यूटर की तुलना में अधिक जटिल और अधिक मूल्यवान होता है। इसमें सामान्यतः अधिक लॉजिक गेट, रजिस्टर और अधिक जटिल कंट्रोल यूनिट होती है। इसी प्रकार, यह प्रति निर्देश कम ऊर्जा का उपयोग करते हुए अधिक कुल ऊर्जा का उपयोग कर सकता है। आउट-ऑफ़-ऑर्डर सीपीयू सामान्यतः प्रति सेकंड अधिक निर्देश कर सकते हैं क्योंकि वे साथ  में कई निर्देश कर सकते हैं।


हालांकि, एक पाइपलाइन कंप्यूटर आमतौर पर तुलनात्मक मल्टीसाइकिल कंप्यूटर की तुलना में अधिक जटिल और अधिक महंगा होता है। इसमें आमतौर पर अधिक लॉजिक गेट, रजिस्टर और एक अधिक जटिल नियंत्रण इकाई होती है। इसी तरह, यह प्रति निर्देश कम ऊर्जा का उपयोग करते हुए अधिक कुल ऊर्जा का उपयोग कर सकता है। आउट-ऑफ़-ऑर्डर CPU आमतौर पर प्रति सेकंड अधिक निर्देश कर सकते हैं क्योंकि वे एक साथ कई निर्देश कर सकते हैं।
== प्रेवेंटिंग स्टालों ==


== स्टालों को रोकना ==
पाइपलाइन को पूर्ण रखने और स्टालों से बचने के लिए कंट्रोल यूनिट्स कई प्रविधियो का उपयोग करती हैं। उदाहरण के लिए, यहां तक ​​कि सरल कंट्रोल यूनिट्स भी मान सकती हैं कि पूर्व शाखा, कम संख्या वाले, पूर्व के निर्देश के लिए, लूप है, और दोहराया जाएगा<ref name=riscv>{{cite book |last1=Asanovic |first1=Krste |title=आरआईएससी वी निर्देश सेट मैनुअल|date=2017 |publisher=RISC-V Foundation |location=Berkeley |edition=2.2 |url=https://content.riscv.org/wp-content/uploads/2017/05/riscv-spec-v2.2.pdf}}</ref> तो, इस डिजाइन के साथ कंट्रोल यूनिट सदैव पाइपलाइन को पीछे की ओर शाखा पथ से भर देगी। यदि कंपाइलर किसी शाखा की सबसे अधिक बार-बार ली जाने वाली दिशा की जानकारी ज्ञात कर सकता है, तो कंपाइलर केवल निर्देश दे सकता है जिससे सबसे अधिक बार ली जाने वाली शाखा की रुचिकर दिशा हो। इसी प्रकार, कंट्रोल यूनिट को [[संकलक]] से संकेत मिल सकते हैं, कुछ कंप्यूटरों में ऐसे निर्देश होते हैं जो शाखा की दिशा के विषय में संकलक से संकेतों को सांकेतिक शब्दों में परिवर्तित कर सकते हैं।<ref>{{cite book |title=पावर आईएसए (टीएम)|date=2017 |publisher=IBM |location=Austin |edition=3.0B |url=https://ibm.ent.box.com/s/1hzcwkwf8rbju5h9iyf44wm94amnlcrv |access-date=26 December 2019}}</ref> कुछ कंट्रोल यूनिट्स [[शाखा भविष्यवक्ता]] करती हैं, कंट्रोल यूनिट शीघ्र की शाखाओं कीइलेक्ट्रिसिटीसूची रखती है, जो शाखा निर्देश के एड्रेस से एन्कोडेड होती है।<ref name=riscv />इस सूची में प्रत्येक शाखा के लिए उस दिशा को याद रखने के लिए कुछ अंश हैं जो शीघ्र ही में लिए गए थे।


पाइपलाइन को पूर्ण रखने और स्टालों से बचने के लिए नियंत्रण इकाइयां कई तरीकों का उपयोग करती हैं। उदाहरण के लिए, यहां तक ​​कि सरल नियंत्रण इकाइयां भी मान सकती हैं कि एक पिछली शाखा, कम संख्या वाले, पहले के निर्देश के लिए, एक लूप है, और दोहराया जाएगा।<ref name=riscv>{{cite book |last1=Asanovic |first1=Krste |title=आरआईएससी वी निर्देश सेट मैनुअल|date=2017 |publisher=RISC-V Foundation |location=Berkeley |edition=2.2 |url=https://content.riscv.org/wp-content/uploads/2017/05/riscv-spec-v2.2.pdf}}</ref> तो, इस डिजाइन के साथ एक नियंत्रण इकाई हमेशा पाइपलाइन को पीछे की ओर शाखा पथ से भर देगी। यदि एक कंपाइलर किसी शाखा की सबसे अधिक बार-बार ली जाने वाली दिशा का पता लगा सकता है, तो कंपाइलर केवल निर्देश दे सकता है ताकि सबसे अधिक बार ली जाने वाली शाखा शाखा की पसंदीदा दिशा हो। इसी तरह, एक नियंत्रण इकाई को [[संकलक]] से संकेत मिल सकते हैं: कुछ कंप्यूटरों में ऐसे निर्देश होते हैं जो शाखा की दिशा के बारे में संकलक से संकेतों को सांकेतिक शब्दों में बदल सकते हैं।<ref>{{cite book |title=पावर आईएसए (टीएम)|date=2017 |publisher=IBM |location=Austin |edition=3.0B |url=https://ibm.ent.box.com/s/1hzcwkwf8rbju5h9iyf44wm94amnlcrv |access-date=26 December 2019}}</ref>
कुछ कंट्रोल यूनिट्स [[सट्टा निष्पादन|अस्तित्व निष्पादन]] कर सकती हैं, जिसमें कंप्यूटर में दो या दो से अधिक पाइपलाइन हो सकती हैं, शाखा की दोनों दिशाओं की गणना कर सकती हैं, और तत्पश्चात अप्रयुक्त दिशा की गणनाओं को त्याग सकती हैं।
कुछ नियंत्रण इकाइयाँ [[शाखा भविष्यवक्ता]] करती हैं: एक नियंत्रण इकाई हाल की शाखाओं की एक इलेक्ट्रॉनिक सूची रखती है, जो शाखा निर्देश के पते से एन्कोडेड होती है।<ref name=riscv />इस सूची में प्रत्येक शाखा के लिए उस दिशा को याद रखने के लिए कुछ अंश हैं जो हाल ही में लिए गए थे।


कुछ नियंत्रण इकाइयां [[सट्टा निष्पादन]] कर सकती हैं, जिसमें एक कंप्यूटर में दो या दो से अधिक पाइपलाइन हो सकती हैं, शाखा की दोनों दिशाओं की गणना कर सकती हैं, और फिर अप्रयुक्त दिशा की गणनाओं को त्याग सकती हैं।
मेमोरी से परिणाम अप्रत्याशित समय पर उपलब्ध हो सकते हैं क्योंकि अधिक तीव्र कंप्यूटर मेमोरी को कैश करते हैं। यही है, वे सीमित मात्रा में मेमोरी डेटा को अधिक तीव्र मेमोरी में कॉपी करते हैं। सीपीयू को [[कैश मैमोरी]] की अधिक तीव्र गति से प्रोसेस करने के लिए डिज़ाइन किया जाना चाहिए। इसलिए, सीपीयू तब रुक हो सकता है जब उसे सीधे मुख्य मेमोरी तक पहुंचना चाहिए। आधुनिक पीसी में, मुख्य मेमोरी कैश की तुलना में तीन सौ गुना मंद होती है।


मेमोरी से परिणाम अप्रत्याशित समय पर उपलब्ध हो सकते हैं क्योंकि बहुत तेज़ कंप्यूटर मेमोरी को कैश करते हैं। यही है, वे सीमित मात्रा में मेमोरी डेटा को बहुत तेज़ मेमोरी में कॉपी करते हैं। सीपीयू को [[कैश मैमोरी]] की बहुत तेज गति से प्रोसेस करने के लिए डिज़ाइन किया जाना चाहिए। इसलिए, सीपीयू तब ठप हो सकता है जब उसे सीधे मुख्य मेमोरी तक पहुंचना चाहिए। आधुनिक पीसी में, मुख्य मेमोरी कैश की तुलना में तीन सौ गुना धीमी होती है।
इसकी सहायता के लिए, डेटा उपलब्ध होते ही उसे प्रोसेस करने के लिए आउट-ऑफ-ऑर्डर सीपीयू और कंट्रोल  यूनिट विकसित किए गए।


इसकी मदद के लिए, डेटा उपलब्ध होते ही उसे प्रोसेस करने के लिए आउट-ऑफ-ऑर्डर सीपीयू और कंट्रोल यूनिट विकसित किए गए। (अगला भाग देखें)
किन्तु क्या होगा यदि सभी गणना पूर्ण हो गई है, किन्तु सीपीयू अभी भी संवृत है, मुख्य मेमोरी की प्रतीक्षा कर रहा है? तत्पश्चात, कंट्रोल यूनिट [[एक साथ मल्टीथ्रेडिंग|साथ बहु सूत्रण]] पर परिवर्तित कर सकती है जिसका डेटा सूत्र के निष्क्रिय होने पर प्राप्त किया गया है। सूत्र का अपना प्रोग्राम काउंटर, निर्देशों की धारा और रजिस्टरों का भिन्न समुच्चय होता है। डिजाइनर वर्तमान मेमोरी प्रविधियों और कंप्यूटर के प्रकार के आधार पर थ्रेड्स की संख्या बदलते हैं। पीसी और स्मार्ट फोन जैसे विशिष्ट कंप्यूटरों में सामान्यतः कुछ थ्रेड्स के साथ कंट्रोल यूनिट्स होती हैं, जो कि कम मूल्य मेमोरी प्रणाली के साथ व्यस्त रखने के लिए पर्याप्त होती हैं। डेटाबेस कंप्यूटरों में प्रायः उनकी अधिक बड़ी यादों को व्यस्त रखने के लिए लगभग दोगुने धागे होते हैं। ग्राफिक प्रोसेसिंग यूनिट (जीपीयू) में सामान्यतः सैकड़ों या हजारों धागे होते हैं, क्योंकि उनके निकट सैकड़ों या हजारों निष्पादन यूनिट्स होती हैं जो दोहराए जाने वाले ग्राफिक गणना करते हैं।


लेकिन क्या होगा अगर सभी गणना पूरी हो गई है, लेकिन सीपीयू अभी भी ठप है, मुख्य मेमोरी की प्रतीक्षा कर रहा है? फिर, एक नियंत्रण इकाई [[एक साथ मल्टीथ्रेडिंग]] पर स्विच कर सकती है जिसका डेटा थ्रेड के निष्क्रिय होने पर प्राप्त किया गया है। एक थ्रेड का अपना प्रोग्राम काउंटर, निर्देशों की एक धारा और रजिस्टरों का एक अलग सेट होता है। डिजाइनर वर्तमान मेमोरी तकनीकों और कंप्यूटर के प्रकार के आधार पर थ्रेड्स की संख्या बदलते हैं। पीसी और स्मार्ट फोन जैसे विशिष्ट कंप्यूटरों में आमतौर पर कुछ थ्रेड्स के साथ नियंत्रण इकाइयां होती हैं, जो कि सस्ती मेमोरी सिस्टम के साथ व्यस्त रखने के लिए पर्याप्त होती हैं। डेटाबेस कंप्यूटरों में अक्सर उनकी बहुत बड़ी यादों को व्यस्त रखने के लिए लगभग दोगुने धागे होते हैं। ग्राफिक प्रोसेसिंग यूनिट (जीपीयू) में आमतौर पर सैकड़ों या हजारों धागे होते हैं, क्योंकि उनके पास सैकड़ों या हजारों निष्पादन इकाइयां होती हैं जो दोहराए जाने वाले ग्राफिक गणना करते हैं।
जब कंट्रोल यूनिट [[थ्रेड (कंप्यूटिंग)]] की अनुमति देती है, तो सॉफ़्टवेयर को भी उन्हें कंट्रोल करने के लिए डिज़ाइन किया जाना चाहिए। पीसी और स्मार्टफोन जैसे सामान्य-उद्देश्य वाले सीपीयू में, थ्रेड्स को सामान्यतः सामान्य समय प्रक्रियाओं की प्रकार दिखने के लिए बनाया जाता है। अधिक से अधिक, ऑपरेशन प्रणाली को उनके विषय में कुछ जागरूकता की आवश्यकता हो सकती है। जीपीयू में, थ्रेड शेड्यूलिंग को सामान्यतः आवेदन सॉफ़्टवेयर से छुपाया नहीं जा सकता है, और इसे प्रायः विशेष सबरूटीन लाइब्रेरी के साथ नियंत्रित किया जाता है।


जब एक नियंत्रण इकाई [[थ्रेड (कंप्यूटिंग)]] की अनुमति देती है, तो सॉफ़्टवेयर को भी उन्हें संभालने के लिए डिज़ाइन किया जाना चाहिए। पीसी और स्मार्टफोन जैसे सामान्य-उद्देश्य वाले सीपीयू में, थ्रेड्स को आमतौर पर सामान्य टाइम-स्लाइस्ड प्रक्रियाओं की तरह दिखने के लिए बनाया जाता है। अधिक से अधिक, ऑपरेटिंग सिस्टम को उनके बारे में कुछ जागरूकता की आवश्यकता हो सकती है। जीपीयू में, थ्रेड शेड्यूलिंग को आमतौर पर एप्लिकेशन सॉफ़्टवेयर से छुपाया नहीं जा सकता है, और इसे अक्सर एक विशेष सबरूटीन लाइब्रेरी के साथ नियंत्रित किया जाता है।
== आउट ऑफ ऑर्डर कंट्रोल  यूनिट ==


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


एक नियंत्रण इकाई को माइक्रोआर्किटेक्चर#आउट-ऑफ़-ऑर्डर निष्पादन के लिए डिज़ाइन किया जा सकता है। यदि एक ही समय में कई निर्देश पूरे किए जा सकते हैं, तो नियंत्रण इकाई इसकी व्यवस्था करेगी। इसलिए, सबसे तेज़ कंप्यूटर एक क्रम में निर्देशों को संसाधित कर सकते हैं जो कुछ हद तक भिन्न हो सकते हैं, यह इस बात पर निर्भर करता है कि ऑपरेंड या निर्देश गंतव्य कब उपलब्ध होते हैं। अधिकांश सुपरकंप्यूटर और कई पीसी सीपीयू इस पद्धति का उपयोग करते हैं। इस प्रकार की नियंत्रण इकाई का सटीक संगठन कंप्यूटर के सबसे धीमे भाग पर निर्भर करता है।
जब गणनाओं का निष्पादन सबसे मंद होता है, तो निर्देश मेमोरी सेइलेक्ट्रिसिटीके भागो में प्रवाहित होते हैं जिन्हें इश्यू  यूनिट कहा जाता है। निर्गम यूनिट तब तक निर्देश रखती है जब तक कि उसके ऑपरेशन और निष्पादन यूनिट दोनों उपलब्ध न हों। तत्पश्चात, निर्देश और उसके ऑपरेशन निष्पादन यूनिट को निरंतर किए जाते हैं। निष्पादन यूनिट निर्देश करती है। तत्पश्चात परिणामी डेटा को मेमोरी या रजिस्टरों में वापस लिखे जाने के लिए डेटा की रेखा में ले जाया जाता है। यदि कंप्यूटर में कई निष्पादन यूनिट्स हैं, तो यह सामान्यतः प्रति घड़ी चक्र में कई निर्देश कर सकता है।


जब गणनाओं का निष्पादन सबसे धीमा होता है, तो निर्देश मेमोरी से इलेक्ट्रॉनिक्स के टुकड़ों में प्रवाहित होते हैं जिन्हें इश्यू यूनिट कहा जाता है। एक निर्गम इकाई तब तक एक निर्देश रखती है जब तक कि उसके संचालन और निष्पादन इकाई दोनों उपलब्ध न हों। फिर, निर्देश और उसके संचालन एक निष्पादन इकाई को जारी किए जाते हैं। निष्पादन इकाई निर्देश करती है। फिर परिणामी डेटा को मेमोरी या रजिस्टरों में वापस लिखे जाने के लिए डेटा की कतार में ले जाया जाता है। यदि कंप्यूटर में कई निष्पादन इकाइयाँ हैं, तो यह आमतौर पर प्रति घड़ी चक्र में कई निर्देश कर सकता है।
विशिष्ट निष्पादन यूनिट्स का होना साधारण कथन है। उदाहरण के लिए, साधारण मूल्य वाले कंप्यूटर में केवल फ़्लोटिंग-पॉइंट निष्पादन यूनिट हो सकती है, क्योंकि फ़्लोटिंग पॉइंट यूनिट्स मूल्यवान होती हैं। कंप्यूटर में कई पूर्णांक यूनिट्स हो सकती हैं, क्योंकि ये अपेक्षाकृत महत्वहीन होती हैं, और बड़ी मात्रा में निर्देश दे सकती हैं।
 
विशिष्ट निष्पादन इकाइयों का होना आम बात है। उदाहरण के लिए, मामूली कीमत वाले कंप्यूटर में केवल एक फ़्लोटिंग-पॉइंट निष्पादन इकाई हो सकती है, क्योंकि फ़्लोटिंग पॉइंट इकाइयाँ महंगी होती हैं। एक ही कंप्यूटर में कई पूर्णांक इकाइयाँ हो सकती हैं, क्योंकि ये अपेक्षाकृत सस्ती होती हैं, और बड़ी मात्रा में निर्देश दे सकती हैं।
   
   
जारी करने के लिए एक प्रकार की नियंत्रण इकाई इलेक्ट्रॉनिक तर्क, एक स्कोरबोर्ड की एक सरणी का उपयोग करती है<ref>{{cite book |last1=Thornton |first1=J.E. |title=Design of a Computer: The CDC 6600 |url=https://archive.org/details/designcomputerco6600thor |url-access=limited |date=1970 |publisher=Scott, Foreman and Co. |location=Atlanta |page=[https://archive.org/details/designcomputerco6600thor/page/n134 125]|isbn=9780673059536 }}</ref>यह पता लगाता है कि निर्देश कब जारी किया जा सकता है। सरणी की ऊंचाई निष्पादन इकाइयों की संख्या है, और लंबाई और चौड़ाई प्रत्येक ऑपरेंड के स्रोतों की संख्या है। जब सभी आइटम एक साथ आते हैं, तो ऑपरेंड और एक्जीक्यूशन यूनिट के सिग्नल क्रॉस हो जाएंगे। इस चौराहे पर तर्क यह पता लगाता है कि निर्देश काम कर सकता है, इसलिए नि: शुल्क निष्पादन इकाई को निर्देश जारी किया जाता है। नियंत्रण इकाई जारी करने की एक वैकल्पिक शैली [[टोमासुलो एल्गोरिथम]] को लागू करती है, जो निर्देशों की एक हार्डवेयर कतार को फिर से व्यवस्थित करती है। कुछ अर्थों में, दोनों शैलियाँ कतार का उपयोग करती हैं। स्कोरबोर्ड निर्देशों की कतार को एन्कोड और पुन: व्यवस्थित करने का एक वैकल्पिक तरीका है, और कुछ डिज़ाइनर इसे कतार तालिका कहते हैं।<ref name="leighton">{{cite web |last1=Leighton |first1=Luke |title=लिबर आरआईएससी-वी एम-क्लास|url=https://www.crowdsupply.com/libre-risc-v/m-class/updates/modernising-1960s-computer-technology-learning-from-the-cdc-6600 |website=Crowd Supply |access-date=16 January 2020}}</ref><ref name="rv5via6600">{{cite web |last1=Alsup |first1=Mitch |last2=Leighton |first2=Luke |last3=Zaruba |first3=Florian |last4=Thornton |first4=James |last5=Kimmitt |first5=Jonathon |last6=Petrisko |first6=Dan |last7=Takano |first7=S. |last8=Falvo |first8=Samuel |title=RISC-V HW Dev, 6600-style out-of-order scoreboard |url=https://groups.google.com/a/groups.riscv.org/forum/#!msg/hw-dev/b4pPvlzBzu0/7hDfxArEAgAJ |website=Google Groups |publisher=RISC-V Foundation |access-date=16 January 2020}}</ref>
निरंतर करने के लिए कंट्रोल यूनिटइलेक्ट्रिसिटीलॉजिक, स्कोरबोर्ड की सरणी का उपयोग करती है<ref>{{cite book |last1=Thornton |first1=J.E. |title=Design of a Computer: The CDC 6600 |url=https://archive.org/details/designcomputerco6600thor |url-access=limited |date=1970 |publisher=Scott, Foreman and Co. |location=Atlanta |page=[https://archive.org/details/designcomputerco6600thor/page/n134 125]|isbn=9780673059536 }}</ref>यह ज्ञात करता है कि निर्देश कब निरंतर किया जा सकता है। सरणी की ऊंचाई निष्पादन यूनिट्स की संख्या है, और लंबाई और चौड़ाई प्रत्येक ऑपरेंड के स्रोतों की संख्या है। जब सभी आइटम साथ आते हैं, तो ऑपरेंड और निष्पादन यूनिट के सिग्नल क्रॉस हो जाएंगे। इस चौराहे पर लॉजिक यह ज्ञात करता है कि निर्देश कार्य कर सकता है, इसलिए नि: शुल्क निष्पादन यूनिट को निर्देश निरंतर किया जाता है। कंट्रोल यूनिट निरंतर करने की वैकल्पिक शैली [[टोमासुलो एल्गोरिथम]] को प्रारम्भ करती है, जो निर्देशों की हार्डवेयर रेखा को तत्पश्चात से व्यवस्थित करती है। कुछ अर्थों में, दोनों शैलियाँ रेखा का उपयोग करती हैं। स्कोरबोर्ड निर्देशों की रेखा को एन्कोड और पुन: व्यवस्थित करने की वैकल्पिक प्रविधि है, और कुछ डिज़ाइनर इसे रेखा टेबल कहते हैं।<ref name="leighton">{{cite web |last1=Leighton |first1=Luke |title=लिबर आरआईएससी-वी एम-क्लास|url=https://www.crowdsupply.com/libre-risc-v/m-class/updates/modernising-1960s-computer-technology-learning-from-the-cdc-6600 |website=Crowd Supply |access-date=16 January 2020}}</ref><ref name="rv5via6600">{{cite web |last1=Alsup |first1=Mitch |last2=Leighton |first2=Luke |last3=Zaruba |first3=Florian |last4=Thornton |first4=James |last5=Kimmitt |first5=Jonathon |last6=Petrisko |first6=Dan |last7=Takano |first7=S. |last8=Falvo |first8=Samuel |title=RISC-V HW Dev, 6600-style out-of-order scoreboard |url=https://groups.google.com/a/groups.riscv.org/forum/#!msg/hw-dev/b4pPvlzBzu0/7hDfxArEAgAJ |website=Google Groups |publisher=RISC-V Foundation |access-date=16 January 2020}}</ref> कुछ अतिरिक्त तर्कों के साथ, स्कोरबोर्ड निष्पादन पुन: क्रमांकन, नाम परिवर्तन करने और स्थिर अपवादों और व्यवधानों को पंजीकृत कर सकता है। इसके अतिरिक्त यह टोमासुलो एल्गोरिथम द्वारा उपयोग की जाने वाली शक्ति-भूख, जटिल सामग्री-एड्रेस योग्य मैमोरी के बिना ऐसा कर सकता है।<ref name="leighton" /><ref name="rv5via6600" />
कुछ अतिरिक्त तर्कों के साथ, एक स्कोरबोर्ड निष्पादन पुन: क्रमांकन, नाम बदलने और सटीक अपवादों और व्यवधानों को पंजीकृत कर सकता है। इसके अलावा यह Tomasulo एल्गोरिथम द्वारा उपयोग की जाने वाली शक्ति-भूख, जटिल सामग्री-पता योग्य स्मृति के बिना ऐसा कर सकता है।<ref name="leighton" /><ref name="rv5via6600" />
 
यदि परिणाम लिखने की तुलना में निष्पादन धीमा है, तो मेमोरी राइट-बैक कतार में हमेशा निःशुल्क प्रविष्टियाँ होती हैं। लेकिन क्या होगा अगर स्मृति धीरे-धीरे लिखती है? या क्या होगा यदि गंतव्य रजिस्टर का उपयोग पहले के निर्देश द्वारा किया जाएगा जो अभी तक जारी नहीं किया गया है? फिर निर्देश के राइट-बैक चरण को शेड्यूल करने की आवश्यकता हो सकती है। इसे कभी-कभी एक निर्देश को सेवानिवृत्त करना कहा जाता है। इस मामले में, निष्पादन इकाइयों के पीछे के अंत में शेड्यूलिंग तर्क होना चाहिए। यह उन रजिस्टरों या मेमोरी तक पहुंच को शेड्यूल करता है जो परिणाम प्राप्त करेंगे।<ref name="leighton" /><ref name="rv5via6600" />
 
जारी करने वाले लॉजिक में मेमोरी या रजिस्टर एक्सेस को शामिल करके रिटायरिंग लॉजिक को जारी करने वाले स्कोरबोर्ड या टोमासुलो कतार में भी डिज़ाइन किया जा सकता है।<ref name="leighton" /><ref name="rv5via6600" />


आउट ऑफ ऑर्डर कंट्रोलर्स को इंटरप्ट्स को संभालने के लिए विशेष डिज़ाइन सुविधाओं की आवश्यकता होती है। जब कई निर्देश प्रगति पर होते हैं, तो यह स्पष्ट नहीं होता है कि निर्देश प्रवाह में कहाँ व्यवधान उत्पन्न होता है। इनपुट और आउटपुट में व्यवधान के लिए, लगभग कोई भी समाधान काम करता है। हालाँकि, जब कंप्यूटर में वर्चुअल मेमोरी होती है, तो यह इंगित करने के लिए एक रुकावट उत्पन्न होती है कि मेमोरी एक्सेस विफल हो गई है। यह मेमोरी एक्सेस एक सटीक निर्देश और एक सटीक प्रोसेसर स्थिति से जुड़ा होना चाहिए, ताकि प्रोसेसर की स्थिति को इंटरप्ट द्वारा सहेजा और पुनर्स्थापित किया जा सके। मेमोरी एक्सेस पूर्ण होने तक एक सामान्य समाधान रजिस्टरों की प्रतियों को सुरक्षित रखता है।<ref name="leighton" /><ref name="rv5via6600" />
यदि परिणाम लिखने की तुलना में निष्पादन मंद है, तो मेमोरी राइट-बैक रेखा में सदैव निःशुल्क प्रविष्टियाँ होती हैं। किन्तु क्या होगा यदि मैमोरी मंद-मंद लिखती है? या क्या होगा यदि गंतव्य रजिस्टर का उपयोग पूर्व के निर्देश द्वारा किया जाएगा जो अभी तक निरंतर नहीं किया गया है? तत्पश्चात निर्देश के राइट-बैक चरण को अनुसूची करने की आवश्यकता हो सकती है। इसे कभी-कभी निर्देश को सेवानिवृत्त करना कहा जाता है। इस विषय में, निष्पादन यूनिट्स के पीछे के अंत में अनुसूची लॉजिक होना चाहिए। यह उन रजिस्टरों या मेमोरी तक पहुंच को अनुसूची करता है जो परिणाम प्राप्त करेंगे।<ref name="leighton" /><ref name="rv5via6600" />


इसके अलावा, क्रम से बाहर सीपीयू को ब्रांचिंग से स्टॉल के साथ और भी अधिक समस्याएँ होती हैं, क्योंकि वे प्रति घड़ी चक्र में कई निर्देश पूरे कर सकते हैं, और आमतौर पर प्रगति के विभिन्न चरणों में कई निर्देश होते हैं। इसलिए, ये नियंत्रण इकाइयां पाइपलाइन किए गए प्रोसेसरों द्वारा उपयोग किए जाने वाले सभी समाधानों का उपयोग कर सकती हैं।<ref name="rv5boomreuse">{{cite web |last1=Celio |first1=Chris |title=बूम डॉक्स, रॉकेटशिप एसओसी जेनरेटर|url=https://docs.boom-core.org/en/latest/sections/intro-overview/rocket-chip.html |access-date=16 January 2020}}</ref>
निरंतर करने वाले लॉजिक में मेमोरी या रजिस्टर एक्सेस को सम्मिलित करके रिटायरिंग लॉजिक को निरंतर करने वाले स्कोरबोर्ड या टोमासुलो रेखा में भी डिज़ाइन किया जा सकता है।<ref name="leighton" /><ref name="rv5via6600" />


आउट ऑफ ऑर्डर नियंत्रकों को व्यवधान को कंट्रोल के लिए विशेष डिज़ाइन सुविधाओं की आवश्यकता होती है। जब कई निर्देश प्रगति पर होते हैं, तो यह स्पष्ट नहीं होता है कि निर्देश प्रवाह में कहाँ व्यवधान उत्पन्न होता है। इनपुट और आउटपुट में व्यवधान के लिए, लगभग कोई भी समाधान कार्य करता है। चूंकि, जब कंप्यूटर में वर्चुअल मेमोरी होती है, तो यह इंगित करने के लिए रुकावट उत्पन्न होती है कि मेमोरी एक्सेस विफल हो गई है। यह मेमोरी एक्सेस स्थिर निर्देश और स्थिर प्रोसेसर स्थिति से जुड़ा होना चाहिए, जिससे प्रोसेसर की स्थिति को व्यवधान द्वारा सहेजा और पुनर्स्थापित किया जा सके। मेमोरी एक्सेस पूर्ण होने तक सामान्य समाधान रजिस्टरों की प्रतियों को सुरक्षित रखता है।<ref name="leighton" /><ref name="rv5via6600" />


== नियंत्रण इकाइयों का अनुवाद ==
इसके अतिरिक्त, क्रम से बाहर सीपीयू को ब्रांचिंग से स्टॉल के साथ और भी अधिक समस्याएँ होती हैं, क्योंकि वे प्रति घड़ी चक्र में कई निर्देश पूर्ण कर सकते हैं, और सामान्यतः प्रगति के विभिन्न चरणों में कई निर्देश होते हैं। इसलिए, ये कंट्रोल यूनिट्स पाइपलाइन किए गए प्रोसेसरों द्वारा उपयोग किए जाने वाले सभी समाधानों का उपयोग कर सकती हैं।<ref name="rv5boomreuse">{{cite web |last1=Celio |first1=Chris |title=बूम डॉक्स, रॉकेटशिप एसओसी जेनरेटर|url=https://docs.boom-core.org/en/latest/sections/intro-overview/rocket-chip.html |access-date=16 January 2020}}</ref>
== कंट्रोल यूनिट्स का अनुवाद ==


कुछ कंप्यूटर प्रत्येक एकल निर्देश को सरल निर्देशों के अनुक्रम में अनुवादित करते हैं। इसका लाभ यह है कि जटिल मल्टी-स्टेप निर्देशों को संभालते हुए, एक खराब कंप्यूटर अपने तर्क के बड़े हिस्से में सरल हो सकता है। [[पेंटियम प्रो]] के बाद से x[[86]] इंटेल सीपीयू जटिल CISC x86 निर्देशों को अधिक RISC-जैसे आंतरिक माइक्रो-ऑपरेशंस में अनुवादित करता है।
कुछ कंप्यूटर प्रत्येक एकल निर्देश को सरल निर्देशों के अनुक्रम में अनुवादित करते हैं। इसका लाभ यह है कि जटिल बहु-चरण निर्देशों को नियंत्रित करते हुए, निकृष्ट कंप्यूटर अपने लॉजिक के बड़े भाग में सरल हो सकता है। [[पेंटियम प्रो]] के पश्चात से x[[86]] इंटेल सीपीयू जटिल CISC x86 निर्देशों को अधिक RISC-जैसे आंतरिक सूक्ष्म ऑपरेशन में अनुवादित करता है।


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


== कम शक्ति वाले कंप्यूटरों के लिए नियंत्रण इकाइयाँ ==
== लो पावरड कंप्यूटरों के लिए कंट्रोल यूनिट्स ==


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


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


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


अधिकांश कंप्यूटरों में हॉल्ट इंस्ट्रक्शन भी होता है। इसका आविष्कार नॉन-इंटरप्ट कोड को रोकने के लिए किया गया था ताकि इंटरप्ट कोड की विश्वसनीय टाइमिंग हो। हालांकि, डिजाइनरों ने जल्द ही देखा कि सीपीयू की घड़ी को पूरी तरह से बंद करने के लिए एक पड़ाव निर्देश भी एक अच्छा समय था, जिससे सीपीयू की सक्रिय शक्ति शून्य हो गई। बाधा नियंत्रक को घड़ी की आवश्यकता जारी रह सकती है, लेकिन वह आमतौर पर सीपीयू की तुलना में बहुत कम बिजली का उपयोग करती है।
अधिकांश कंप्यूटरों में "रोकें" निर्देश भी होता है। इसका आविष्कार गैर-व्यवधान कोड को रोकने के लिए किया गया था जिससे व्यवधान कोड की विश्वसनीय टाइमिंग हो। चूंकि, डिजाइनरों ने शीघ्र देखा कि सीपीयू की घड़ी को पूर्ण रूप से संवृत करने के लिए पड़ाव निर्देश भी उत्तम समय था, जिससे सीपीयू की सक्रिय शक्ति शून्य हो गई। बाधा कंट्रोलर को घड़ी की आवश्यकता निरंतर रह सकती है, किन्तु वह सामान्यतः सीपीयू की तुलना में अधिक कमइलेक्ट्रिसिटीका उपयोग करती है।


इन तरीकों को डिजाइन करना अपेक्षाकृत आसान है, और इतना सामान्य हो गया है कि वाणिज्यिक लाभ के लिए दूसरों का आविष्कार किया गया। कई आधुनिक कम-शक्ति वाले [[सीएमओएस]] सीपीयू आवश्यक निर्देश के आधार पर विशेष निष्पादन इकाइयों और बस इंटरफेस को रोकते हैं और शुरू करते हैं। कुछ कंप्यूटर<ref>{{cite book |title=MAXQ आर्किटेक्चर का परिचय|publisher=Maxim Integrated Inc. |location=Dallas |url=https://www.maximintegrated.com/en/design/technical-documents/app-notes/3/3222.html |access-date=26 December 2019}}</ref> ट्रांसफर-ट्रिगर मल्टीप्लेक्सर्स का उपयोग करने के लिए सीपीयू के माइक्रोआर्किटेक्चर को भी व्यवस्थित करें ताकि प्रत्येक निर्देश केवल आवश्यक तर्क के सटीक टुकड़ों का उपयोग करे।
इन प्रविधियो को डिजाइन करना अपेक्षाकृत सरल है, और इतना सामान्य हो गया है कि वाणिज्यिक लाभ के लिए दूसरों का आविष्कार किया गया। कई आधुनिक कम-शक्ति वाले [[सीएमओएस]] सीपीयू आवश्यक निर्देश के आधार पर विशेष निष्पादन यूनिट्स और बस अंतरापृष्ठ को रोकते हैं और प्रारम्भ करते हैं। कुछ कंप्यूटर<ref>{{cite book |title=MAXQ आर्किटेक्चर का परिचय|publisher=Maxim Integrated Inc. |location=Dallas |url=https://www.maximintegrated.com/en/design/technical-documents/app-notes/3/3222.html |access-date=26 December 2019}}</ref> स्थानांतरण-उत्प्रेरित मल्टीप्लेक्सर्स का उपयोग करने के लिए सीपीयू के सूक्ष्म वास्तुकला को भी व्यवस्थित करें जिससे प्रत्येक निर्देश केवल आवश्यक लॉजिक के स्थिर भागो का उपयोग करे।


एक सामान्य तरीका यह है कि लोड को कई सीपीयू में फैला दिया जाए, और लोड कम होने पर अप्रयुक्त सीपीयू को बंद कर दिया जाए। ऑपरेटिंग सिस्टम का टास्क स्विचिंग लॉजिक सीपीयू के डेटा को मेमोरी में सेव करता है। कुछ मामलों में,<ref>{{cite book |title=एआरएम तकनीकी संदर्भ, कॉर्टेक्स|publisher=ARM Ltd |edition=v8}}</ref> सीपीयू में से एक सरल और छोटा हो सकता है, शाब्दिक रूप से कम लॉजिक गेट्स के साथ। तो, इसमें कम रिसाव होता है, और यह सबसे आखिरी में बंद होता है, और सबसे पहले चालू होता है। इसके अलावा यह एकमात्र सीपीयू है जिसके लिए विशेष कम-शक्ति सुविधाओं की आवश्यकता होती है। अधिकांश पीसी में इसी तरह की विधि का उपयोग किया जाता है, जिसमें आमतौर पर एक सहायक एम्बेडेड सीपीयू होता है जो पावर सिस्टम का प्रबंधन करता है। हालाँकि, पीसी में, सॉफ्टवेयर आमतौर पर BIOS में होता है, ऑपरेटिंग सिस्टम में नहीं।
सामान्य प्रविधि यह है कि भार को कई सीपीयू में विस्तृत किया जाए, और भार कम होने पर अप्रयुक्त सीपीयू को संवृत कर दिया जाए। ऑपरेशन प्रणाली का कार्य परिवर्तित करना लॉजिक सीपीयू के डेटा को मेमोरी में सेव करता है। कुछ विषयो में,<ref>{{cite book |title=एआरएम तकनीकी संदर्भ, कॉर्टेक्स|publisher=ARM Ltd |edition=v8}}</ref> सीपीयू में सरल और अल्प हो सकता है, शाब्दिक रूप से कम लॉजिक गेट्स के साथ, तो इसमें कम रिसाव होता है, और यह सबसे अंत में संवृत होता है, और सबसे पूर्व प्रारम्भ होता है। इसके अतिरिक्त यह एकमात्र सीपीयू है जिसके लिए विशेष कम-शक्ति सुविधाओं की आवश्यकता होती है। अधिकांश पीसी में इसी प्रकार की विधि का उपयोग किया जाता है, जिसमें सामान्यतः सहायक अंतर्निहित सीपीयू होता है जो पावर प्रणाली का प्रबंधन करता है। चूंकि, पीसी में, सॉफ्टवेयर सामान्यतः BIOS में होता है, ऑपरेटिंग प्रणाली में नहीं होता है।


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


कुछ डिज़ाइन बहुत कम रिसाव वाले ट्रांजिस्टर का उपयोग कर सकते हैं, लेकिन ये आमतौर पर लागत जोड़ते हैं। ट्रांजिस्टर के अवक्षय अवरोधों को कम रिसाव के लिए बड़ा बनाया जा सकता है, लेकिन इससे ट्रांजिस्टर बड़ा हो जाता है और इस प्रकार धीमा और अधिक महंगा दोनों हो जाता है। कुछ विक्रेता बड़े ट्रांजिस्टर से कम रिसाव तर्क का निर्माण करके आईसी के चयनित भागों में इस तकनीक का उपयोग करते हैं जो कुछ प्रक्रियाएं एनालॉग सर्किट के लिए प्रदान करती हैं। कुछ प्रक्रियाएं ट्रांजिस्टर को सिलिकॉन की सतह के ऊपर, फिन फेट्स में रखती हैं, लेकिन इन प्रक्रियाओं में अधिक चरण होते हैं, इसलिए अधिक महंगे होते हैं। विशेष ट्रांजिस्टर डोपिंग सामग्री (जैसे हेफ़नियम) भी रिसाव को कम कर सकती है, लेकिन यह प्रसंस्करण में कदम जोड़ती है, जिससे यह अधिक महंगा हो जाता है। कुछ अर्धचालकों में सिलिकॉन की तुलना में बड़ा बैंड-गैप होता है। हालाँकि, ये सामग्री और प्रक्रियाएँ वर्तमान में (2020) सिलिकॉन की तुलना में अधिक महंगी हैं।
कुछ डिज़ाइन अधिक कम रिसाव वाले ट्रांजिस्टर का उपयोग कर सकते हैं, किन्तु ये सामान्यतः व्यय जोड़ते हैं। ट्रांजिस्टर के अवक्षय अवरोधों को कम रिसाव के लिए बड़ा बनाया जा सकता है, किन्तु इससे ट्रांजिस्टर बड़ा हो जाता है और इस प्रकार मंद और अधिक मूल्यवान दोनों हो जाता है। कुछ विक्रेता बड़े ट्रांजिस्टर से कम रिसाव लॉजिक का निर्माण करके आईसी के चयनित भागों में इस प्रविधि का उपयोग करते हैं जो कुछ प्रक्रियाएं एनालॉग परिपथ के लिए प्रदान करती हैं। कुछ प्रक्रियाएं ट्रांजिस्टर को सिलिकॉन की सतह के ऊपर, फिन फेट्स में रखती हैं, किन्तु इन प्रक्रियाओं में अधिक चरण होते हैं, इसलिए अधिक मूल्यवान होते हैं। विशेष ट्रांजिस्टर डोपिंग सामग्री (जैसे हेफ़नियम) भी रिसाव को कम कर सकती है, किन्तु यह प्रसंस्करण में कदम जोड़ती है, जिससे यह अधिक मूल्यवान हो जाता है। कुछ अर्धचालकों में सिलिकॉन की तुलना में बड़ा बैंड-अंतर होता है। चूंकि, ये सामग्री और प्रक्रियाएँ वर्तमान में (2020) सिलिकॉन की तुलना में अधिक मूल्यवान हैं।


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


कुछ सीपीयू<ref name="armv6">{{cite book |title=एआरएम (टीएम) तकनीकी संदर्भ मैनुअल|publisher=ARM Ltd. |location=Cambridge |edition=v6, r0}}</ref> एक विशेष प्रकार के फ्लिप-फ्लॉप (थोड़ा स्टोर करने के लिए) का उपयोग करें जो एक धीमी, बड़ी (महंगी) कम-रिसाव वाली सेल के लिए एक तेज, उच्च-रिसाव भंडारण सेल को जोड़ता है। इन दो कोशिकाओं ने बिजली की आपूर्ति को अलग कर दिया है। जब CPU पावर सेविंग मोड में प्रवेश करता है (उदाहरण के लिए एक रुकावट के कारण जो रुकावट की प्रतीक्षा करता है), डेटा को कम-रिसाव कोशिकाओं में स्थानांतरित कर दिया जाता है, और अन्य बंद कर दिए जाते हैं। जब सीपीयू कम-रिसाव मोड छोड़ता है (उदाहरण के लिए एक बाधा के कारण), तो प्रक्रिया उलट जाती है।
कुछ सीपीयू<ref name="armv6">{{cite book |title=एआरएम (टीएम) तकनीकी संदर्भ मैनुअल|publisher=ARM Ltd. |location=Cambridge |edition=v6, r0}}</ref> विशेष प्रकार के फ्लिप-फ्लॉप का उपयोग करें जो मंद, बड़ी (मूल्यवान) कम-रिसाव वाली सेल के लिए एक तीव्र, उच्च-रिसाव भंडारण विक्रय को जोड़ता है। इन दो कोशिकाओं नेइलेक्ट्रिसिटीकी आपूर्ति को भिन्न कर दिया है। जब सीपीयू पावर सेविंग मोड में प्रवेश करता है (उदाहरण के लिए रुकावट के कारण जो रुकावट की प्रतीक्षा करता है), डेटा को कम-रिसाव कोशिकाओं में स्थानांतरित कर दिया जाता है, और अन्य संवृत कर दिए जाते हैं। जब सीपीयू कम-रिसाव मोड त्यागता है (उदाहरण के लिए बाधा के कारण), तो प्रक्रिया विपरीत हो जाती है।


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


== कंप्यूटर के साथ एकीकरण ==
== इंटीग्रेटिंग विद कंप्यूटर ==


सभी आधुनिक सीपीयू में सीपीयू को बाकी कंप्यूटर से जोड़ने के लिए कंट्रोल लॉजिक होता है। आधुनिक कंप्यूटरों में, यह आमतौर पर एक बस नियंत्रक होता है। जब कोई निर्देश स्मृति को पढ़ता या लिखता है, तो नियंत्रण इकाई या तो सीधे बस को नियंत्रित करती है या बस नियंत्रक को नियंत्रित करती है। कई आधुनिक कंप्यूटर मेमोरी, इनपुट और आउटपुट के लिए एक ही बस इंटरफ़ेस का उपयोग करते हैं। इसे मेमोरी-मैप्ड I/O कहा जाता है। एक प्रोग्रामर के लिए, I/O उपकरणों के रजिस्टर विशिष्ट मेमोरी पतों पर संख्या के रूप में दिखाई देते हैं। x86 पीसी एक पुरानी पद्धति का उपयोग करते हैं, I/O निर्देशों द्वारा एक्सेस की गई एक अलग I/O बस।
सभी आधुनिक सीपीयू में सीपीयू को अन्य कंप्यूटर से जोड़ने के लिए कंट्रोल लॉजिक होता है। आधुनिक कंप्यूटरों में, यह सामान्यतः बस कंट्रोलर होता है। जब कोई निर्देश मैमोरी को पढ़ता या लिखता है, तो कंट्रोल यूनिट या तो सीधे बस को नियंत्रित करती है या बस कंट्रोलर को नियंत्रित करती है। कई आधुनिक कंप्यूटर मेमोरी, इनपुट और आउटपुट के लिए बस अंतरापृष्ठ का उपयोग करते हैं। इसे मेमोरी-मैप्ड आई/कहा जाता है। प्रोग्रामर के लिए, आई/उपकरणों के रजिस्टर विशिष्ट मेमोरी एड्रेस पर संख्या के रूप में दिखाई देते हैं। x86 पीसी पूर्व पद्धति का उपयोग करते हैं, आई/निर्देशों द्वारा एक्सेस की गई भिन्न आई/ओ बस हैं।


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


मेमोरी को कैश करने के लिए अक्सर कैश कंट्रोलर होता है। कैश कंट्रोलर और संबद्ध कैश मेमोरी अक्सर आधुनिक, उच्च-प्रदर्शन CPU का सबसे बड़ा भौतिक हिस्सा होता है। जब मेमोरी, बस या कैश को अन्य सीपीयू के साथ साझा किया जाता है, तो नियंत्रण तर्क को उनके साथ यह सुनिश्चित करने के लिए संचार करना चाहिए कि कोई भी कंप्यूटर कभी भी पुराना डेटा प्राप्त नहीं करता है।
मेमोरी को कैश करने के लिए प्रायः कैश कंट्रोल होता है। कैश कंट्रोल और संबद्ध कैश मेमोरी प्रायः आधुनिक, उच्च-प्रदर्शन सीपीयू का सबसे बड़ा भौतिक भाग होता है। जब मेमोरी, बस या कैश को अन्य सीपीयू के साथ विचार किया जाता है, तो कंट्रोल लॉजिक को उनके साथ यह सुनिश्चित करने के लिए संचार करना चाहिए कि कोई भी कंप्यूटर कभी भी पूर्व डेटा प्राप्त नहीं करता है।


कई ऐतिहासिक कंप्यूटर कुछ प्रकार के इनपुट और आउटपुट को सीधे कंट्रोल यूनिट में निर्मित करते हैं। उदाहरण के लिए, कई ऐतिहासिक कंप्यूटरों में नियंत्रण इकाई द्वारा सीधे नियंत्रित स्विच और रोशनी के साथ एक फ्रंट पैनल होता था। ये एक प्रोग्रामर को सीधे एक प्रोग्राम में प्रवेश करने देते हैं और उसे डिबग करते हैं। बाद के उत्पादन कंप्यूटरों में, फ्रंट पैनल का सबसे आम उपयोग डिस्क से ऑपरेटिंग सिस्टम को पढ़ने के लिए एक छोटे बूटस्ट्रैप प्रोग्राम में प्रवेश करना था। यह कष्टप्रद था। तो, फ्रंट पैनल को रीड-ओनली मेमोरी में [[BIOS]] द्वारा बदल दिया गया था।
कई ऐतिहासिक कंप्यूटर कुछ प्रकार के इनपुट और आउटपुट को सीधे कंट्रोल यूनिट में निर्मित करते हैं। उदाहरण के लिए, कई ऐतिहासिक कंप्यूटरों में कंट्रोल यूनिट द्वारा सीधे नियंत्रित स्विच और रोशनी के साथ सामने का भाग होता था। ये प्रोग्रामर को सीधे प्रोग्राम में प्रवेश करने देते हैं और उसे डिबग करते हैं। पश्चात के उत्पादन कंप्यूटरों में, फ्रंट पैनल का सबसे आम उपयोग डिस्क से ऑपरेटिंग प्रणाली को पढ़ने के लिए एक अल्प बूटस्ट्रैप प्रोग्राम में प्रवेश करना था। यह कष्टप्रद था। तो, फ्रंट पैनल को रीड-ओनली मेमोरी में [[BIOS]] द्वारा परिवर्तित किया गया था।


अधिकांश [[PDP-8]] मॉडल में एक डेटा बस थी जिसे I/O उपकरणों को नियंत्रण इकाई की मेमोरी पढ़ने और तर्क लिखने के लिए उधार लेने के लिए डिज़ाइन किया गया था।<ref>{{cite book |title=PDP-8L Maintenance Manual |date=1970 |publisher=Digital Equipment Corp. |location=Maynard Mass. |url=http://bitsavers.trailing-edge.com/pdf/dec/pdp8/pdp8l/DEC-8L-HR1B-D_8LmaintVol1.pdf |archive-url=https://web.archive.org/web/20150422211242/http://bitsavers.trailing-edge.com/pdf/dec/pdp8/pdp8l/DEC-8L-HR1B-D_8LmaintVol1.pdf |archive-date=2015-04-22 |url-status=live |access-date=26 December 2019}}</ref> इसने उच्च गति I/O नियंत्रकों की जटिलता और खर्च को कम किया, उदा। डिस्क के लिए।
अधिकांश [[PDP-8]] मॉडल में डेटा बस थी जिसे आई/उपकरणों को कंट्रोल यूनिट की मेमोरी पढ़ने और लॉजिक लिखने के लिए उधार लेने के लिए डिज़ाइन किया गया था।<ref>{{cite book |title=PDP-8L Maintenance Manual |date=1970 |publisher=Digital Equipment Corp. |location=Maynard Mass. |url=http://bitsavers.trailing-edge.com/pdf/dec/pdp8/pdp8l/DEC-8L-HR1B-D_8LmaintVol1.pdf |archive-url=https://web.archive.org/web/20150422211242/http://bitsavers.trailing-edge.com/pdf/dec/pdp8/pdp8l/DEC-8L-HR1B-D_8LmaintVol1.pdf |archive-date=2015-04-22 |url-status=live |access-date=26 December 2019}}</ref> इसने उच्च गति आई/नियंत्रकों की जटिलता और व्यय को कम किया,  


[[ज़ेरॉक्स ऑल्टो]] में एक मल्टीटास्किंग माइक्रोप्रोग्रामेबल कंट्रोल यूनिट थी जो लगभग सभी I / O का प्रदर्शन करती थी।<ref>{{cite book |title=ऑल्टो हार्डवेयर मैनुअल|date=1976 |publisher=Xerox |url=http://bitsavers.informatik.uni-stuttgart.de/pdf/xerox/alto/Alto_Hardware_Manual_Aug76.pdf |archive-url=https://web.archive.org/web/20101207201936/http://bitsavers.informatik.uni-stuttgart.de/pdf/xerox/alto/Alto_Hardware_Manual_Aug76.pdf |archive-date=2010-12-07 |url-status=live}}</ref> इस डिज़ाइन ने इलेक्ट्रॉनिक लॉजिक के केवल एक छोटे से अंश के साथ एक आधुनिक पीसी की अधिकांश सुविधाएँ प्रदान कीं। डुअल-थ्रेड कंप्यूटर दो निम्नतम-प्राथमिकता वाले माइक्रोथ्रेड्स द्वारा चलाया गया था। जब भी I/O की आवश्यकता नहीं थी, ये गणना करते थे। वीडियो, नेटवर्क, डिस्क, आवधिक टाइमर, माउस और कीबोर्ड प्रदान किए गए (घटती प्राथमिकता में) उच्च प्राथमिकता वाले माइक्रोथ्रेड। माइक्रोप्रोग्राम ने I/O डिवाइस के जटिल लॉजिक के साथ-साथ कंप्यूटर के साथ डिवाइस को एकीकृत करने के लिए लॉजिक किया। वास्तविक हार्डवेयर I/O के लिए, माइक्रोप्रोग्राम अधिकांश I/O के लिए शिफ्ट रजिस्टर पढ़ता और लिखता है, कभी-कभी प्रतिरोधक नेटवर्क और ट्रांजिस्टर के साथ आउटपुट वोल्टेज स्तर (जैसे वीडियो के लिए) को स्थानांतरित करने के लिए। बाहरी घटनाओं को संभालने के लिए, माइक्रोकंट्रोलर के पास थ्रेड के चक्र के अंत में थ्रेड्स को स्विच करने के लिए माइक्रोइंटरप्ट्स थे, उदा। एक निर्देश के अंत में, या एक शिफ्ट-रजिस्टर तक पहुँचने के बाद। माइक्रोप्रोग्राम को फिर से लिखा और पुनः स्थापित किया जा सकता था, जो एक शोध कंप्यूटर के लिए बहुत उपयोगी था।
उदाहरण डिस्क के लिए हैं।


== नियंत्रण इकाई के कार्य ==
[[ज़ेरॉक्स ऑल्टो]] में बहु कार्यण सूक्ष्म प्रोग्राम करने योग्य कंट्रोल  यूनिट थी जो लगभग सभी आई/ओ का प्रदर्शन करती थी।<ref>{{cite book |title=ऑल्टो हार्डवेयर मैनुअल|date=1976 |publisher=Xerox |url=http://bitsavers.informatik.uni-stuttgart.de/pdf/xerox/alto/Alto_Hardware_Manual_Aug76.pdf |archive-url=https://web.archive.org/web/20101207201936/http://bitsavers.informatik.uni-stuttgart.de/pdf/xerox/alto/Alto_Hardware_Manual_Aug76.pdf |archive-date=2010-12-07 |url-status=live}}</ref> इस डिज़ाइन ने विद्युत  लॉजिक के केवल अल्प से अंश के साथ आधुनिक पीसी की अधिकांश सुविधाएँ प्रदान कीं। डुअल-थ्रेड कंप्यूटर दो निम्नतम-प्राथमिकता वाले माइक्रोथ्रेड्स द्वारा चलाया गया था। जब भी आई/ओ की आवश्यकता नहीं थी, ये गणना करते थे। वीडियो, नेटवर्क, डिस्क, आवधिक टाइमर, माउस और कीबोर्ड प्रदान किए गए (घटती प्राथमिकता में) उच्च प्राथमिकता वाले माइक्रोथ्रेड, माइक्रोप्रोग्राम ने आई/ओ डिवाइस के जटिल लॉजिक के साथ-साथ कंप्यूटर के साथ डिवाइस को एकीकृत करने के लिए लॉजिक किया। वास्तविक हार्डवेयर आई/ओ के लिए, माइक्रोप्रोग्राम अधिकांश आई/ओ के लिए शिफ्ट रजिस्टर पढ़ता और लिखता है, कभी-कभी प्रतिरोधक नेटवर्क और ट्रांजिस्टर के साथ आउटपुट वोल्टेज स्तर (जैसे वीडियो के लिए) को स्थानांतरित करने के लिए बाहरी घटनाओं को कंट्रोल करने के लिए, माइक्रो कंट्रोल के निकट धागे के चक्र के अंत में धागे को स्विच करने के लिए सूक्ष्म व्यवधान थे, उदा, निर्देश के अंत में, या शिफ्ट-रजिस्टर तक पहुँचने के पश्चात माइक्रोप्रोग्राम को तत्पश्चात से लिखा और पुनः स्थापित किया जा सकता था, जो शोध कंप्यूटर के लिए अधिक उपयोगी था।


इस प्रकार मेमोरी में निर्देशों का एक कार्यक्रम सीयू को सीपीयू के डेटा प्रवाह को निर्देशों के बीच डेटा को सही ढंग से हेरफेर करने के लिए कॉन्फ़िगर करने का कारण बनेगा। इसका परिणाम एक कंप्यूटर के रूप में होता है जो एक पूर्ण प्रोग्राम चला सकता है और निर्देशों के बीच हार्डवेयर परिवर्तन करने के लिए किसी मानवीय हस्तक्षेप की आवश्यकता नहीं होती है (जैसा कि केवल प्लगबोर्ड का उपयोग करते समय किया जाता था # सीयू के साथ प्रोग्राम किए गए कंप्यूटरों का आविष्कार करने से पहले संगणना के लिए यूनिट रिकॉर्ड उपकरण)।
== कंट्रोल यूनिट के कार्य ==


== हार्डवेयर्ड कंट्रोल यूनिट ==<!-- Front end processor redirects here -->
इस प्रकार मेमोरी में निर्देशों का कार्यक्रम सीयू को सीपीयू के डेटा प्रवाह को निर्देशों के मध्य डेटा को उचित रूप से आदान-प्रदान करने के लिए कॉन्फ़िगर करने का कारण बनेगा। इसका परिणाम कंप्यूटर के रूप में होता है जो पूर्ण प्रोग्राम चला सकता है और निर्देशों के मध्य हार्डवेयर परिवर्तन करने के लिए किसी मानवीय हस्तक्षेप की आवश्यकता नहीं होती है (जैसा कि केवल प्लगबोर्ड का उपयोग करते समय किया जाता था। सीयू के साथ प्रोग्राम किए गए कंप्यूटरों का आविष्कार करने से पूर्व संगणना के लिए यूनिट रिकॉर्ड उपकरण)।
[[File:Animation of an LDA instruction performed by the control matrix of a simple hardwired control unit.gif|thumb|एक एलडीए-अनुदेश निष्पादित करने वाली एक साधारण हार्डवेयर्ड नियंत्रण इकाई के नियंत्रण मैट्रिक्स का एनिमेशन]]हार्डवार्ड नियंत्रण इकाइयों को [[संयोजन तर्क]] इकाइयों के उपयोग के माध्यम से कार्यान्वित किया जाता है, जिसमें गेट्स की एक सीमित संख्या होती है जो उन प्रतिक्रियाओं के आधार पर विशिष्ट परिणाम उत्पन्न कर सकते हैं जो उन प्रतिक्रियाओं को लागू करने के लिए उपयोग किए गए थे। हार्डवार्ड नियंत्रण इकाइयां आमतौर पर माइक्रोप्रोग्राम्ड डिज़ाइनों की तुलना में तेज़ होती हैं।<ref>{{Cite web|url=http://www.cs.binghamton.edu/~reckert/hardwire3new.html|title=MICRO-PROGRAMMED VERSUS HARDWIRED CONTROL UNITS;|website=www.cs.binghamton.edu|access-date=2017-02-17|url-status=live|archive-url=https://web.archive.org/web/20170430162916/http://www.cs.binghamton.edu/~reckert/hardwire3new.html|archive-date=2017-04-30}}</ref>
यह डिज़ाइन एक निश्चित आर्किटेक्चर का उपयोग करता है - यदि निर्देश सेट को संशोधित या बदला जाता है तो इसमें वायरिंग में बदलाव की आवश्यकता होती है। यह सरल, तेज़ कंप्यूटर के लिए सुविधाजनक हो सकता है।


एक नियंत्रक जो इस दृष्टिकोण का उपयोग करता है वह उच्च गति पर काम कर सकता है; हालाँकि, इसमें थोड़ा लचीलापन है। एक जटिल निर्देश सेट एक डिजाइनर को अभिभूत कर सकता है जो तदर्थ तर्क डिजाइन का उपयोग करता है।
== हार्डवेयर्ड कंट्रोल  यूनिट ==
[[File:Animation of an LDA instruction performed by the control matrix of a simple hardwired control unit.gif|thumb|एलडीए-अनुदेश निष्पादित करने वाली साधारण हार्डवेयर्ड कंट्रोल यूनिट के कंट्रोल मैट्रिक्स का एनिमेशन]]हार्डवार्ड कंट्रोल यूनिट्स को [[संयोजन तर्क|संयोजन लॉजिक]] यूनिट्स के उपयोग के माध्यम से कार्यान्वित किया जाता है, जिसमें गेट्स की सीमित संख्या होती है जो उन प्रतिक्रियाओं के आधार पर विशिष्ट परिणाम उत्पन्न कर सकते हैं जो उन प्रतिक्रियाओं को प्रारम्भ करने के लिए उपयोग किए गए थे। हार्डवार्ड कंट्रोल यूनिट्स सामान्यतः माइक्रोप्रोग्राम्ड डिज़ाइनों की तुलना में तीव्रता होती हैं।<ref>{{Cite web|url=http://www.cs.binghamton.edu/~reckert/hardwire3new.html|title=MICRO-PROGRAMMED VERSUS HARDWIRED CONTROL UNITS;|website=www.cs.binghamton.edu|access-date=2017-02-17|url-status=live|archive-url=https://web.archive.org/web/20170430162916/http://www.cs.binghamton.edu/~reckert/hardwire3new.html|archive-date=2017-04-30}}</ref>
यह डिज़ाइन निश्चित वास्तुकला का उपयोग करता है, यदि निर्देश समुच्चय को संशोधित या परिवर्तित किया जाता है तो इसमें वायरिंग में परिवर्तन की आवश्यकता होती है। यह सरल, तीव्रता कंप्यूटर के लिए सुविधाजनक हो सकता है।


जैसे-जैसे कंप्यूटर विकसित हुए हैं, वैसे-वैसे हार्डवार्ड दृष्टिकोण कम लोकप्रिय होता गया है। पहले, सीपीयू के लिए नियंत्रण इकाइयां तदर्थ तर्क का उपयोग करती थीं, और उन्हें डिजाइन करना कठिन था।<ref>{{Cite journal |last1=Williams |first1=R. D. |last2=Klenke |first2=R. H. |last3=Aylor |first3=J. H. |date=May 2003 |title=वर्चुअल प्रोटोटाइपिंग का उपयोग करके कंप्यूटर डिजाइन सिखाना|journal=IEEE Transactions on Education |volume=46 |issue=2 |pages=296–301 |doi=10.1109/te.2002.808278 |issn=0018-9359 }}</ref>
कंट्रोलर जो इस दृष्टिकोण का उपयोग करता है वह उच्च गति पर कार्य कर सकता है, चूंकि, इसमें लचीलापन है। जटिल निर्देश समुच्चय डिजाइनर को अभिभूत कर सकता है जो तदर्थ लॉजिक डिजाइन का उपयोग करता है।


जैसे-जैसे कंप्यूटर विकसित हुए हैं, वैसे-वैसे हार्डवार्ड दृष्टिकोण कम लोकप्रिय होता गया है। पूर्व, सीपीयू के लिए कंट्रोल यूनिट्स तदर्थ लॉजिक का उपयोग करती थीं, और उन्हें डिजाइन करना कठिन था।<ref>{{Cite journal |last1=Williams |first1=R. D. |last2=Klenke |first2=R. H. |last3=Aylor |first3=J. H. |date=May 2003 |title=वर्चुअल प्रोटोटाइपिंग का उपयोग करके कंप्यूटर डिजाइन सिखाना|journal=IEEE Transactions on Education |volume=46 |issue=2 |pages=296–301 |doi=10.1109/te.2002.808278 |issn=0018-9359 }}</ref>


== माइक्रोप्रोग्राम कंट्रोल यूनिट ==
== माइक्रोप्रोग्राम कंट्रोल यूनिट ==
{{main|Microcode}}
{{main|
माइक्रोकोड}}


माइक्रोप्रोग्रामिंग का विचार [[मौरिस विल्क्स]] द्वारा 1951 में [[कंप्यूटर प्रोग्राम]] निर्देशों को निष्पादित करने के लिए एक मध्यवर्ती स्तर के रूप में पेश किया गया था। माइक्रोप्रोग्राम को सूक्ष्म निर्देशों के अनुक्रम के रूप में व्यवस्थित किया गया था और विशेष नियंत्रण स्मृति में संग्रहीत किया गया था। माइक्रोप्रोग्राम कंट्रोल यूनिट के लिए एल्गोरिथ्म, हार्डवेयर्ड कंट्रोल यूनिट के विपरीत, आमतौर पर [[प्रवाह संचित्र]] विवरण द्वारा निर्दिष्ट किया जाता है।<ref>{{Cite book  | last1 = Barkalov | first1 = Alexander | title = Logic synthesis for FSM based control units / Alexander Barkalov and Larysa Titarenko | year = 2009 | publisher = Springer | location = Berlin | isbn = 978-3-642-04308-6 }}</ref> माइक्रोप्रोग्राम्ड कंट्रोल यूनिट का मुख्य लाभ इसकी संरचना की सादगी है। नियंत्रक से आउटपुट सूक्ष्म निर्देशों द्वारा होते हैं। माइक्रोप्रोग्राम को डिबग किया जा सकता है और सॉफ्टवेयर की तरह बदला जा सकता है।<ref>{{Cite book  | last1 = Wiśniewski | first1 = Remigiusz | title = प्रोग्राम करने योग्य उपकरणों के लिए रचनात्मक माइक्रोप्रोग्राम नियंत्रण इकाइयों का संश्लेषण| year = 2009 | publisher = University of Zielona Góra | location = Zielona Góra | isbn = 978-83-7481-293-1 | pages = 153}}</ref>
माइक्रोप्रोग्रामिंग का विचार [[मौरिस विल्क्स]] द्वारा 1951 में [[कंप्यूटर प्रोग्राम]] निर्देशों को निष्पादित करने के लिए मध्यवर्ती स्तर के रूप में प्रस्तुत किया गया था। माइक्रोप्रोग्राम को सूक्ष्म निर्देशों के अनुक्रम के रूप में व्यवस्थित किया गया था और विशेष कंट्रोल मैमोरी में संग्रहीत किया गया था। माइक्रोप्रोग्राम कंट्रोल यूनिट के लिए एल्गोरिथ्म, हार्डवेयर्ड कंट्रोल यूनिट के विपरीत, सामान्यतः [[प्रवाह संचित्र]] विवरण द्वारा निर्दिष्ट किया जाता है।<ref>{{Cite book  | last1 = Barkalov | first1 = Alexander | title = Logic synthesis for FSM based control units / Alexander Barkalov and Larysa Titarenko | year = 2009 | publisher = Springer | location = Berlin | isbn = 978-3-642-04308-6 }}</ref> माइक्रोप्रोग्राम्ड कंट्रोल यूनिट का मुख्य लाभ इसकी संरचना की सरलता है। कंट्रोलर से आउटपुट सूक्ष्म निर्देशों द्वारा होते हैं। माइक्रोप्रोग्राम को डिबग किया जा सकता है और सॉफ्टवेयर के जैसे परिवर्तन किया जा सकता है।<ref>{{Cite book  | last1 = Wiśniewski | first1 = Remigiusz | title = प्रोग्राम करने योग्य उपकरणों के लिए रचनात्मक माइक्रोप्रोग्राम नियंत्रण इकाइयों का संश्लेषण| year = 2009 | publisher = University of Zielona Góra | location = Zielona Góra | isbn = 978-83-7481-293-1 | pages = 153}}</ref>




== डिजाइन के संयोजन तरीके ==
== कॉम्बिनेशन मेथड्स ऑफ़ डिजाइन ==


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


== यह भी देखें ==
== यह भी देखें ==
* [[प्रोसेसर डिजाइन]]
* [[प्रोसेसर डिजाइन]]
*[[कंप्यूटर आर्किटेक्चर]]
*[[कंप्यूटर आर्किटेक्चर|कंप्यूटर आर्टिटेक्टर]]
* रिचर्ड्स नियंत्रक
* रिचर्ड्स कंट्रोलर
*[[नियंत्रक (कंप्यूटिंग) (बहुविकल्पी)]]|नियंत्रक (कंप्यूटिंग)
*[[नियंत्रक (कंप्यूटिंग) (बहुविकल्पी)|कंट्रोलर (कंप्यूटिंग)]]


== संदर्भ ==
== संदर्भ ==
{{reflist}}
{{reflist}}


{{CPU technologies}}
[[Category:Articles with hatnote templates targeting a nonexistent page|Control Unit]]
 
[[Category:Collapse templates|Control Unit]]
{{DEFAULTSORT:Control Unit}}[[Category: सेंट्रल प्रोसेसिंग यूनिट]] [[Category: डिजिटल इलेक्ट्रॉनिक्स]]  
[[Category:Created On 31/05/2023|Control Unit]]
 
[[Category:Lua-based templates|Control Unit]]
 
[[Category:Machine Translated Page|Control Unit]]
 
[[Category:Navigational boxes| ]]
[[Category: Machine Translated Page]]
[[Category:Navigational boxes without horizontal lists|Control Unit]]
[[Category:Created On 31/05/2023]]
[[Category:Pages with script errors|Control Unit]]
[[Category:Short description with empty Wikidata description|Control Unit]]
[[Category:Sidebars with styles needing conversion|Control Unit]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Control Unit]]
[[Category:Templates generating microformats|Control Unit]]
[[Category:Templates that add a tracking category|Control Unit]]
[[Category:Templates that are not mobile friendly|Control Unit]]
[[Category:Templates that generate short descriptions|Control Unit]]
[[Category:Templates using TemplateData|Control Unit]]
[[Category:Wikipedia metatemplates|Control Unit]]
[[Category:डिजिटल इलेक्ट्रॉनिक्स|Control Unit]]
[[Category:सेंट्रल प्रोसेसिंग यूनिट|Control Unit]]

Latest revision as of 13:07, 31 October 2023


कंट्रोल यूनिट (CU) कंप्यूटर की सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) का घटक है जो प्रोसेसर के ऑपरेशन को निर्देशित करता है। सीयू सामान्यतः कोडित निर्देशों को समय और कंट्रोल संकेतों में परिवर्तित करने के लिए बाइनरी डिकोडर का उपयोग करता है जो अन्य यूनिट्स (मेमोरी, अर्थमेटिक लॉजिक यूनिट और इनपुट और आउटपुट डिवाइस इत्यादि) के ऑपरेशन को निर्देशित करता है।

अधिकांश कंप्यूटर संसाधन सीयू द्वारा प्रबंधित किए जाते हैं। यह सीपीयू और अन्य उपकरणों के मध्य डेटा के प्रवाह को निर्देशित करता है। जॉन वॉन न्यूमैन ने वॉन न्यूमैन वास्तुकला के भाग के रूप में कंट्रोल यूनिट को सम्मिलित किया।[1] आधुनिक कंप्यूटर डिजाइनों में, कंट्रोल यूनिट सामान्यतः सेंट्रल प्रोसेसिंग यूनिट का आंतरिक भाग होता है इसके प्रारम्भ के पश्चात से इसकी समग्र भूमिका और ऑपरेशन में कोई परिवर्तन नहीं हुआ है।[2]

मल्टीसाइकिल कंट्रोल यूनिट

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

कंप्यूटर में, कंट्रोल यूनिट प्रायः निर्देश चक्र के माध्यम से क्रमिक रूप से कदम उठाती है। इसमें निर्देश प्राप्त करना, ऑपरेंड प्राप्त करना, निर्देश को डिकोड करना, निर्देश को क्रियान्वित करना और तत्पश्चात परिणाम को मैमोरी में वापस लिखना सम्मिलित है। जब आगामी निर्देश कंट्रोल यूनिट में रखा जाता है, तो यह निर्देश को उचित रूप से पूर्ण करने के लिए कंट्रोल यूनिट के व्यवहार को परिवर्तित कर देता है। तो, निर्देश के बिट्स सीधे कंट्रोल यूनिट को नियंत्रित करते हैं, जो परिवर्तन में कंप्यूटर को नियंत्रित करता है।

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

मल्टीसाइकिल कंट्रोल यूनिट्स सामान्यतः अपने स्क्वायर-वेव टाइमिंग क्लॉक के बढ़ते और गिरते दोनों सीमाओं का उपयोग करती हैं। वे टाइमिंग क्लॉक की प्रत्येक सीमा पर अपने ऑपरेशन का चरण संचालित करते हैं, जिससे चार-चरण का ऑपरेशन दो घड़ी चक्रों में पूर्ण हो। समान लॉजिक समुदाय को देखते हुए यह कंप्यूटर की गति को दोगुना कर देता है।

कई कंप्यूटरों में दो भिन्न-भिन्न प्रकार की अनपेक्षित घटनाएं होती हैं। व्यवधान उत्पन्न होता है क्योंकि किसी प्रकार के इनपुट या आउटपुट को उचित रूप से संचालित करने के लिए सॉफ़्टवेयर ध्यान देने की आवश्यकता होती है। कंप्यूटर के ऑपरेशन के कारण अपवाद हैंडलिंग होती है। महत्वपूर्ण अंतर यह है कि रुकावट के समय की भविष्यवाणी नहीं की जा सकती। दूसरा यह है कि कुछ अपवाद (जैसे मेमोरी-नॉट-उपलब्ध अपवाद) निर्देश के कारण हो सकते हैं जिन्हें पुनःप्रारम्भ करने की आवश्यकता होती है।

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

अधिक सरल कंप्यूटरों में व्यवधान्स के जैसे कार्य करने के लिए अपवाद बनाए जा सकते हैं। यदि आभासी मेमोरी की आवश्यकता है, तो मेमोरी-नॉट-उपलब्ध अपवाद को असफल निर्देश का पुनः प्रयास करना चाहिए।

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

पाइपलाइन कंट्रोल यूनिट्स

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

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

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

पाइपलाइन कंप्यूटर में, कंट्रोल यूनिट प्रोग्राम कमांड के रूप में प्रवाह को प्रारम्भ करने, निरंतर रखने और संवृत करने की व्यवस्था करती है। निर्देश डेटा सामान्यतः पाइपलाइन रजिस्टरों में चरण से आगामी चरण तक पारित किया जाता है, प्रत्येक चरण के लिए कंट्रोल लॉजिक के कुछ भिन्न भागो के साथ कंट्रोल यूनिट यह भी आश्वासन देती है कि प्रत्येक चरण में निर्देश अन्य चरणों में निर्देशों के ऑपरेशन को हानि नहीं पहुँचाता है। उदाहरण के लिए, यदि दो चरणों में डेटा के भाग का उपयोग करना चाहिए, तो कंट्रोल लॉजिक यह आश्वासन देता है कि उपयोग सही क्रम में किया जाता है।

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

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

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

अर्थव्यवस्था? कंप्यूटर के पाइपलाइन मॉडल में प्रायः प्रति निर्देश प्रति सेकंड कम से कम लॉजिक गेट्स होते हैं, जो मल्टीसाइकिल या आउट-ऑफ-ऑर्डर कंप्यूटर से कम होते हैं। क्यों? मल्टीसाइकिल कंप्यूटर की तुलना में औसत चरण कम जटिल है। आउट-ऑफ़-ऑर्डर कंप्यूटर में सामान्यतः किसी भी क्षण में बड़ी मात्रा में निष्क्रिय लॉजिक होते हैं। इसी प्रकार की गणना सामान्यतः दिखाती है कि पाइपलाइन कंप्यूटर प्रति निर्देश कम ऊर्जा का उपयोग करता है।

चूंकि, पाइपलाइन कंप्यूटर सामान्यतः तुलनात्मक मल्टीसाइकिल कंप्यूटर की तुलना में अधिक जटिल और अधिक मूल्यवान होता है। इसमें सामान्यतः अधिक लॉजिक गेट, रजिस्टर और अधिक जटिल कंट्रोल यूनिट होती है। इसी प्रकार, यह प्रति निर्देश कम ऊर्जा का उपयोग करते हुए अधिक कुल ऊर्जा का उपयोग कर सकता है। आउट-ऑफ़-ऑर्डर सीपीयू सामान्यतः प्रति सेकंड अधिक निर्देश कर सकते हैं क्योंकि वे साथ में कई निर्देश कर सकते हैं।

प्रेवेंटिंग स्टालों

पाइपलाइन को पूर्ण रखने और स्टालों से बचने के लिए कंट्रोल यूनिट्स कई प्रविधियो का उपयोग करती हैं। उदाहरण के लिए, यहां तक ​​कि सरल कंट्रोल यूनिट्स भी मान सकती हैं कि पूर्व शाखा, कम संख्या वाले, पूर्व के निर्देश के लिए, लूप है, और दोहराया जाएगा[3] तो, इस डिजाइन के साथ कंट्रोल यूनिट सदैव पाइपलाइन को पीछे की ओर शाखा पथ से भर देगी। यदि कंपाइलर किसी शाखा की सबसे अधिक बार-बार ली जाने वाली दिशा की जानकारी ज्ञात कर सकता है, तो कंपाइलर केवल निर्देश दे सकता है जिससे सबसे अधिक बार ली जाने वाली शाखा की रुचिकर दिशा हो। इसी प्रकार, कंट्रोल यूनिट को संकलक से संकेत मिल सकते हैं, कुछ कंप्यूटरों में ऐसे निर्देश होते हैं जो शाखा की दिशा के विषय में संकलक से संकेतों को सांकेतिक शब्दों में परिवर्तित कर सकते हैं।[4] कुछ कंट्रोल यूनिट्स शाखा भविष्यवक्ता करती हैं, कंट्रोल यूनिट शीघ्र की शाखाओं कीइलेक्ट्रिसिटीसूची रखती है, जो शाखा निर्देश के एड्रेस से एन्कोडेड होती है।[3]इस सूची में प्रत्येक शाखा के लिए उस दिशा को याद रखने के लिए कुछ अंश हैं जो शीघ्र ही में लिए गए थे।

कुछ कंट्रोल यूनिट्स अस्तित्व निष्पादन कर सकती हैं, जिसमें कंप्यूटर में दो या दो से अधिक पाइपलाइन हो सकती हैं, शाखा की दोनों दिशाओं की गणना कर सकती हैं, और तत्पश्चात अप्रयुक्त दिशा की गणनाओं को त्याग सकती हैं।

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

इसकी सहायता के लिए, डेटा उपलब्ध होते ही उसे प्रोसेस करने के लिए आउट-ऑफ-ऑर्डर सीपीयू और कंट्रोल यूनिट विकसित किए गए।

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

जब कंट्रोल यूनिट थ्रेड (कंप्यूटिंग) की अनुमति देती है, तो सॉफ़्टवेयर को भी उन्हें कंट्रोल करने के लिए डिज़ाइन किया जाना चाहिए। पीसी और स्मार्टफोन जैसे सामान्य-उद्देश्य वाले सीपीयू में, थ्रेड्स को सामान्यतः सामान्य समय प्रक्रियाओं की प्रकार दिखने के लिए बनाया जाता है। अधिक से अधिक, ऑपरेशन प्रणाली को उनके विषय में कुछ जागरूकता की आवश्यकता हो सकती है। जीपीयू में, थ्रेड शेड्यूलिंग को सामान्यतः आवेदन सॉफ़्टवेयर से छुपाया नहीं जा सकता है, और इसे प्रायः विशेष सबरूटीन लाइब्रेरी के साथ नियंत्रित किया जाता है।

आउट ऑफ ऑर्डर कंट्रोल यूनिट

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

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

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

निरंतर करने के लिए कंट्रोल यूनिटइलेक्ट्रिसिटीलॉजिक, स्कोरबोर्ड की सरणी का उपयोग करती है[5]यह ज्ञात करता है कि निर्देश कब निरंतर किया जा सकता है। सरणी की ऊंचाई निष्पादन यूनिट्स की संख्या है, और लंबाई और चौड़ाई प्रत्येक ऑपरेंड के स्रोतों की संख्या है। जब सभी आइटम साथ आते हैं, तो ऑपरेंड और निष्पादन यूनिट के सिग्नल क्रॉस हो जाएंगे। इस चौराहे पर लॉजिक यह ज्ञात करता है कि निर्देश कार्य कर सकता है, इसलिए नि: शुल्क निष्पादन यूनिट को निर्देश निरंतर किया जाता है। कंट्रोल यूनिट निरंतर करने की वैकल्पिक शैली टोमासुलो एल्गोरिथम को प्रारम्भ करती है, जो निर्देशों की हार्डवेयर रेखा को तत्पश्चात से व्यवस्थित करती है। कुछ अर्थों में, दोनों शैलियाँ रेखा का उपयोग करती हैं। स्कोरबोर्ड निर्देशों की रेखा को एन्कोड और पुन: व्यवस्थित करने की वैकल्पिक प्रविधि है, और कुछ डिज़ाइनर इसे रेखा टेबल कहते हैं।[6][7] कुछ अतिरिक्त तर्कों के साथ, स्कोरबोर्ड निष्पादन पुन: क्रमांकन, नाम परिवर्तन करने और स्थिर अपवादों और व्यवधानों को पंजीकृत कर सकता है। इसके अतिरिक्त यह टोमासुलो एल्गोरिथम द्वारा उपयोग की जाने वाली शक्ति-भूख, जटिल सामग्री-एड्रेस योग्य मैमोरी के बिना ऐसा कर सकता है।[6][7]

यदि परिणाम लिखने की तुलना में निष्पादन मंद है, तो मेमोरी राइट-बैक रेखा में सदैव निःशुल्क प्रविष्टियाँ होती हैं। किन्तु क्या होगा यदि मैमोरी मंद-मंद लिखती है? या क्या होगा यदि गंतव्य रजिस्टर का उपयोग पूर्व के निर्देश द्वारा किया जाएगा जो अभी तक निरंतर नहीं किया गया है? तत्पश्चात निर्देश के राइट-बैक चरण को अनुसूची करने की आवश्यकता हो सकती है। इसे कभी-कभी निर्देश को सेवानिवृत्त करना कहा जाता है। इस विषय में, निष्पादन यूनिट्स के पीछे के अंत में अनुसूची लॉजिक होना चाहिए। यह उन रजिस्टरों या मेमोरी तक पहुंच को अनुसूची करता है जो परिणाम प्राप्त करेंगे।[6][7]

निरंतर करने वाले लॉजिक में मेमोरी या रजिस्टर एक्सेस को सम्मिलित करके रिटायरिंग लॉजिक को निरंतर करने वाले स्कोरबोर्ड या टोमासुलो रेखा में भी डिज़ाइन किया जा सकता है।[6][7]

आउट ऑफ ऑर्डर नियंत्रकों को व्यवधान को कंट्रोल के लिए विशेष डिज़ाइन सुविधाओं की आवश्यकता होती है। जब कई निर्देश प्रगति पर होते हैं, तो यह स्पष्ट नहीं होता है कि निर्देश प्रवाह में कहाँ व्यवधान उत्पन्न होता है। इनपुट और आउटपुट में व्यवधान के लिए, लगभग कोई भी समाधान कार्य करता है। चूंकि, जब कंप्यूटर में वर्चुअल मेमोरी होती है, तो यह इंगित करने के लिए रुकावट उत्पन्न होती है कि मेमोरी एक्सेस विफल हो गई है। यह मेमोरी एक्सेस स्थिर निर्देश और स्थिर प्रोसेसर स्थिति से जुड़ा होना चाहिए, जिससे प्रोसेसर की स्थिति को व्यवधान द्वारा सहेजा और पुनर्स्थापित किया जा सके। मेमोरी एक्सेस पूर्ण होने तक सामान्य समाधान रजिस्टरों की प्रतियों को सुरक्षित रखता है।[6][7]

इसके अतिरिक्त, क्रम से बाहर सीपीयू को ब्रांचिंग से स्टॉल के साथ और भी अधिक समस्याएँ होती हैं, क्योंकि वे प्रति घड़ी चक्र में कई निर्देश पूर्ण कर सकते हैं, और सामान्यतः प्रगति के विभिन्न चरणों में कई निर्देश होते हैं। इसलिए, ये कंट्रोल यूनिट्स पाइपलाइन किए गए प्रोसेसरों द्वारा उपयोग किए जाने वाले सभी समाधानों का उपयोग कर सकती हैं।[8]

कंट्रोल यूनिट्स का अनुवाद

कुछ कंप्यूटर प्रत्येक एकल निर्देश को सरल निर्देशों के अनुक्रम में अनुवादित करते हैं। इसका लाभ यह है कि जटिल बहु-चरण निर्देशों को नियंत्रित करते हुए, निकृष्ट कंप्यूटर अपने लॉजिक के बड़े भाग में सरल हो सकता है। पेंटियम प्रो के पश्चात से x86 इंटेल सीपीयू जटिल CISC x86 निर्देशों को अधिक RISC-जैसे आंतरिक सूक्ष्म ऑपरेशन में अनुवादित करता है।

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

लो पावरड कंप्यूटरों के लिए कंट्रोल यूनिट्स

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

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

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

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

इन प्रविधियो को डिजाइन करना अपेक्षाकृत सरल है, और इतना सामान्य हो गया है कि वाणिज्यिक लाभ के लिए दूसरों का आविष्कार किया गया। कई आधुनिक कम-शक्ति वाले सीएमओएस सीपीयू आवश्यक निर्देश के आधार पर विशेष निष्पादन यूनिट्स और बस अंतरापृष्ठ को रोकते हैं और प्रारम्भ करते हैं। कुछ कंप्यूटर[9] स्थानांतरण-उत्प्रेरित मल्टीप्लेक्सर्स का उपयोग करने के लिए सीपीयू के सूक्ष्म वास्तुकला को भी व्यवस्थित करें जिससे प्रत्येक निर्देश केवल आवश्यक लॉजिक के स्थिर भागो का उपयोग करे।

सामान्य प्रविधि यह है कि भार को कई सीपीयू में विस्तृत किया जाए, और भार कम होने पर अप्रयुक्त सीपीयू को संवृत कर दिया जाए। ऑपरेशन प्रणाली का कार्य परिवर्तित करना लॉजिक सीपीयू के डेटा को मेमोरी में सेव करता है। कुछ विषयो में,[10] सीपीयू में सरल और अल्प हो सकता है, शाब्दिक रूप से कम लॉजिक गेट्स के साथ, तो इसमें कम रिसाव होता है, और यह सबसे अंत में संवृत होता है, और सबसे पूर्व प्रारम्भ होता है। इसके अतिरिक्त यह एकमात्र सीपीयू है जिसके लिए विशेष कम-शक्ति सुविधाओं की आवश्यकता होती है। अधिकांश पीसी में इसी प्रकार की विधि का उपयोग किया जाता है, जिसमें सामान्यतः सहायक अंतर्निहित सीपीयू होता है जो पावर प्रणाली का प्रबंधन करता है। चूंकि, पीसी में, सॉफ्टवेयर सामान्यतः BIOS में होता है, ऑपरेटिंग प्रणाली में नहीं होता है।

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

कुछ डिज़ाइन अधिक कम रिसाव वाले ट्रांजिस्टर का उपयोग कर सकते हैं, किन्तु ये सामान्यतः व्यय जोड़ते हैं। ट्रांजिस्टर के अवक्षय अवरोधों को कम रिसाव के लिए बड़ा बनाया जा सकता है, किन्तु इससे ट्रांजिस्टर बड़ा हो जाता है और इस प्रकार मंद और अधिक मूल्यवान दोनों हो जाता है। कुछ विक्रेता बड़े ट्रांजिस्टर से कम रिसाव लॉजिक का निर्माण करके आईसी के चयनित भागों में इस प्रविधि का उपयोग करते हैं जो कुछ प्रक्रियाएं एनालॉग परिपथ के लिए प्रदान करती हैं। कुछ प्रक्रियाएं ट्रांजिस्टर को सिलिकॉन की सतह के ऊपर, फिन फेट्स में रखती हैं, किन्तु इन प्रक्रियाओं में अधिक चरण होते हैं, इसलिए अधिक मूल्यवान होते हैं। विशेष ट्रांजिस्टर डोपिंग सामग्री (जैसे हेफ़नियम) भी रिसाव को कम कर सकती है, किन्तु यह प्रसंस्करण में कदम जोड़ती है, जिससे यह अधिक मूल्यवान हो जाता है। कुछ अर्धचालकों में सिलिकॉन की तुलना में बड़ा बैंड-अंतर होता है। चूंकि, ये सामग्री और प्रक्रियाएँ वर्तमान में (2020) सिलिकॉन की तुलना में अधिक मूल्यवान हैं।

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

कुछ सीपीयू[11] विशेष प्रकार के फ्लिप-फ्लॉप का उपयोग करें जो मंद, बड़ी (मूल्यवान) कम-रिसाव वाली सेल के लिए एक तीव्र, उच्च-रिसाव भंडारण विक्रय को जोड़ता है। इन दो कोशिकाओं नेइलेक्ट्रिसिटीकी आपूर्ति को भिन्न कर दिया है। जब सीपीयू पावर सेविंग मोड में प्रवेश करता है (उदाहरण के लिए रुकावट के कारण जो रुकावट की प्रतीक्षा करता है), डेटा को कम-रिसाव कोशिकाओं में स्थानांतरित कर दिया जाता है, और अन्य संवृत कर दिए जाते हैं। जब सीपीयू कम-रिसाव मोड त्यागता है (उदाहरण के लिए बाधा के कारण), तो प्रक्रिया विपरीत हो जाती है।

पूर्व डिज़ाइन सीपीयू स्थिति को मेमोरी, या डिस्क में कॉपी कर देते थे, कभी-कभी विशेष सॉफ़्टवेयर के साथ ही अधिक सरल अंतर्निहित प्रणाली कभी-कभी पुनः आरंभ करते हैं।

इंटीग्रेटिंग विद कंप्यूटर

सभी आधुनिक सीपीयू में सीपीयू को अन्य कंप्यूटर से जोड़ने के लिए कंट्रोल लॉजिक होता है। आधुनिक कंप्यूटरों में, यह सामान्यतः बस कंट्रोलर होता है। जब कोई निर्देश मैमोरी को पढ़ता या लिखता है, तो कंट्रोल यूनिट या तो सीधे बस को नियंत्रित करती है या बस कंट्रोलर को नियंत्रित करती है। कई आधुनिक कंप्यूटर मेमोरी, इनपुट और आउटपुट के लिए बस अंतरापृष्ठ का उपयोग करते हैं। इसे मेमोरी-मैप्ड आई/ओ कहा जाता है। प्रोग्रामर के लिए, आई/ओ उपकरणों के रजिस्टर विशिष्ट मेमोरी एड्रेस पर संख्या के रूप में दिखाई देते हैं। x86 पीसी पूर्व पद्धति का उपयोग करते हैं, आई/ओ निर्देशों द्वारा एक्सेस की गई भिन्न आई/ओ बस हैं।

आधुनिक सीपीयू में व्यवधान कंट्रोल भी सम्मिलित होता है। यह प्रणाली बस से व्यवधान संकेत को कंट्रोल करता है। कंट्रोल यूनिट कंप्यूटर का वह भाग है जो व्यवधान का उत्तर देता है।

मेमोरी को कैश करने के लिए प्रायः कैश कंट्रोल होता है। कैश कंट्रोल और संबद्ध कैश मेमोरी प्रायः आधुनिक, उच्च-प्रदर्शन सीपीयू का सबसे बड़ा भौतिक भाग होता है। जब मेमोरी, बस या कैश को अन्य सीपीयू के साथ विचार किया जाता है, तो कंट्रोल लॉजिक को उनके साथ यह सुनिश्चित करने के लिए संचार करना चाहिए कि कोई भी कंप्यूटर कभी भी पूर्व डेटा प्राप्त नहीं करता है।

कई ऐतिहासिक कंप्यूटर कुछ प्रकार के इनपुट और आउटपुट को सीधे कंट्रोल यूनिट में निर्मित करते हैं। उदाहरण के लिए, कई ऐतिहासिक कंप्यूटरों में कंट्रोल यूनिट द्वारा सीधे नियंत्रित स्विच और रोशनी के साथ सामने का भाग होता था। ये प्रोग्रामर को सीधे प्रोग्राम में प्रवेश करने देते हैं और उसे डिबग करते हैं। पश्चात के उत्पादन कंप्यूटरों में, फ्रंट पैनल का सबसे आम उपयोग डिस्क से ऑपरेटिंग प्रणाली को पढ़ने के लिए एक अल्प बूटस्ट्रैप प्रोग्राम में प्रवेश करना था। यह कष्टप्रद था। तो, फ्रंट पैनल को रीड-ओनली मेमोरी में BIOS द्वारा परिवर्तित किया गया था।

अधिकांश PDP-8 मॉडल में डेटा बस थी जिसे आई/ओ उपकरणों को कंट्रोल यूनिट की मेमोरी पढ़ने और लॉजिक लिखने के लिए उधार लेने के लिए डिज़ाइन किया गया था।[12] इसने उच्च गति आई/ओ नियंत्रकों की जटिलता और व्यय को कम किया,

उदाहरण डिस्क के लिए हैं।

ज़ेरॉक्स ऑल्टो में बहु कार्यण सूक्ष्म प्रोग्राम करने योग्य कंट्रोल यूनिट थी जो लगभग सभी आई/ओ का प्रदर्शन करती थी।[13] इस डिज़ाइन ने विद्युत लॉजिक के केवल अल्प से अंश के साथ आधुनिक पीसी की अधिकांश सुविधाएँ प्रदान कीं। डुअल-थ्रेड कंप्यूटर दो निम्नतम-प्राथमिकता वाले माइक्रोथ्रेड्स द्वारा चलाया गया था। जब भी आई/ओ की आवश्यकता नहीं थी, ये गणना करते थे। वीडियो, नेटवर्क, डिस्क, आवधिक टाइमर, माउस और कीबोर्ड प्रदान किए गए (घटती प्राथमिकता में) उच्च प्राथमिकता वाले माइक्रोथ्रेड, माइक्रोप्रोग्राम ने आई/ओ डिवाइस के जटिल लॉजिक के साथ-साथ कंप्यूटर के साथ डिवाइस को एकीकृत करने के लिए लॉजिक किया। वास्तविक हार्डवेयर आई/ओ के लिए, माइक्रोप्रोग्राम अधिकांश आई/ओ के लिए शिफ्ट रजिस्टर पढ़ता और लिखता है, कभी-कभी प्रतिरोधक नेटवर्क और ट्रांजिस्टर के साथ आउटपुट वोल्टेज स्तर (जैसे वीडियो के लिए) को स्थानांतरित करने के लिए बाहरी घटनाओं को कंट्रोल करने के लिए, माइक्रो कंट्रोल के निकट धागे के चक्र के अंत में धागे को स्विच करने के लिए सूक्ष्म व्यवधान थे, उदा, निर्देश के अंत में, या शिफ्ट-रजिस्टर तक पहुँचने के पश्चात माइक्रोप्रोग्राम को तत्पश्चात से लिखा और पुनः स्थापित किया जा सकता था, जो शोध कंप्यूटर के लिए अधिक उपयोगी था।

कंट्रोल यूनिट के कार्य

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

हार्डवेयर्ड कंट्रोल यूनिट

एलडीए-अनुदेश निष्पादित करने वाली साधारण हार्डवेयर्ड कंट्रोल यूनिट के कंट्रोल मैट्रिक्स का एनिमेशन

हार्डवार्ड कंट्रोल यूनिट्स को संयोजन लॉजिक यूनिट्स के उपयोग के माध्यम से कार्यान्वित किया जाता है, जिसमें गेट्स की सीमित संख्या होती है जो उन प्रतिक्रियाओं के आधार पर विशिष्ट परिणाम उत्पन्न कर सकते हैं जो उन प्रतिक्रियाओं को प्रारम्भ करने के लिए उपयोग किए गए थे। हार्डवार्ड कंट्रोल यूनिट्स सामान्यतः माइक्रोप्रोग्राम्ड डिज़ाइनों की तुलना में तीव्रता होती हैं।[14]

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

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

जैसे-जैसे कंप्यूटर विकसित हुए हैं, वैसे-वैसे हार्डवार्ड दृष्टिकोण कम लोकप्रिय होता गया है। पूर्व, सीपीयू के लिए कंट्रोल यूनिट्स तदर्थ लॉजिक का उपयोग करती थीं, और उन्हें डिजाइन करना कठिन था।[15]

माइक्रोप्रोग्राम कंट्रोल यूनिट

माइक्रोप्रोग्रामिंग का विचार मौरिस विल्क्स द्वारा 1951 में कंप्यूटर प्रोग्राम निर्देशों को निष्पादित करने के लिए मध्यवर्ती स्तर के रूप में प्रस्तुत किया गया था। माइक्रोप्रोग्राम को सूक्ष्म निर्देशों के अनुक्रम के रूप में व्यवस्थित किया गया था और विशेष कंट्रोल मैमोरी में संग्रहीत किया गया था। माइक्रोप्रोग्राम कंट्रोल यूनिट के लिए एल्गोरिथ्म, हार्डवेयर्ड कंट्रोल यूनिट के विपरीत, सामान्यतः प्रवाह संचित्र विवरण द्वारा निर्दिष्ट किया जाता है।[16] माइक्रोप्रोग्राम्ड कंट्रोल यूनिट का मुख्य लाभ इसकी संरचना की सरलता है। कंट्रोलर से आउटपुट सूक्ष्म निर्देशों द्वारा होते हैं। माइक्रोप्रोग्राम को डिबग किया जा सकता है और सॉफ्टवेयर के जैसे परिवर्तन किया जा सकता है।[17]


कॉम्बिनेशन मेथड्स ऑफ़ डिजाइन

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

यह भी देखें

संदर्भ

  1. von Neumann, John (1945), First Draft of a Report on the EDVAC (PDF), Moore School of Electrical Engineering, University of Pennsylvania, archived from the original (PDF) on March 14, 2013
  2. Astha Singh (24 September 2018). "कंप्यूटर संगठन - नियंत्रण इकाई और डिजाइन". GeeksforGeeks. Retrieved 25 May 2019.
  3. 3.0 3.1 Asanovic, Krste (2017). आरआईएससी वी निर्देश सेट मैनुअल (PDF) (2.2 ed.). Berkeley: RISC-V Foundation.
  4. पावर आईएसए (टीएम) (3.0B ed.). Austin: IBM. 2017. Retrieved 26 December 2019.
  5. Thornton, J.E. (1970). Design of a Computer: The CDC 6600. Atlanta: Scott, Foreman and Co. p. 125. ISBN 9780673059536.
  6. 6.0 6.1 6.2 6.3 6.4 Leighton, Luke. "लिबर आरआईएससी-वी एम-क्लास". Crowd Supply. Retrieved 16 January 2020.
  7. 7.0 7.1 7.2 7.3 7.4 Alsup, Mitch; Leighton, Luke; Zaruba, Florian; Thornton, James; Kimmitt, Jonathon; Petrisko, Dan; Takano, S.; Falvo, Samuel. "RISC-V HW Dev, 6600-style out-of-order scoreboard". Google Groups. RISC-V Foundation. Retrieved 16 January 2020.
  8. Celio, Chris. "बूम डॉक्स, रॉकेटशिप एसओसी जेनरेटर". Retrieved 16 January 2020.
  9. MAXQ आर्किटेक्चर का परिचय. Dallas: Maxim Integrated Inc. Retrieved 26 December 2019.
  10. एआरएम तकनीकी संदर्भ, कॉर्टेक्स (v8 ed.). ARM Ltd.
  11. एआरएम (टीएम) तकनीकी संदर्भ मैनुअल (v6, r0 ed.). Cambridge: ARM Ltd.
  12. PDP-8L Maintenance Manual (PDF). Maynard Mass.: Digital Equipment Corp. 1970. Archived (PDF) from the original on 2015-04-22. Retrieved 26 December 2019.
  13. ऑल्टो हार्डवेयर मैनुअल (PDF). Xerox. 1976. Archived (PDF) from the original on 2010-12-07.
  14. "MICRO-PROGRAMMED VERSUS HARDWIRED CONTROL UNITS;". www.cs.binghamton.edu. Archived from the original on 2017-04-30. Retrieved 2017-02-17.
  15. Williams, R. D.; Klenke, R. H.; Aylor, J. H. (May 2003). "वर्चुअल प्रोटोटाइपिंग का उपयोग करके कंप्यूटर डिजाइन सिखाना". IEEE Transactions on Education. 46 (2): 296–301. doi:10.1109/te.2002.808278. ISSN 0018-9359.
  16. Barkalov, Alexander (2009). Logic synthesis for FSM based control units / Alexander Barkalov and Larysa Titarenko. Berlin: Springer. ISBN 978-3-642-04308-6.
  17. Wiśniewski, Remigiusz (2009). प्रोग्राम करने योग्य उपकरणों के लिए रचनात्मक माइक्रोप्रोग्राम नियंत्रण इकाइयों का संश्लेषण. Zielona Góra: University of Zielona Góra. p. 153. ISBN 978-83-7481-293-1.