रजिस्टर विंडो: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
 
(7 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Short description|CPU architecture feature to improve performance}}
{{Short description|CPU architecture feature to improve performance}}
[[File:Register window.png|thumb|4-विंडो रजिस्टर विंडो सिस्टम का उदाहरण]][[कंप्यूटर इंजीनियरिंग]] में '''रजिस्टर विंडो''' एक ऐसी सुविधा है जो आंतरिक रजिस्टरों के एक सबसेट को निश्चित, प्रोग्रामर-दृश्यमान रजिस्टरों में गतिशील रूप से अलियास करके रजिस्टरों को एक सबरूटीन में समर्पित करती है। फ़ंक्शन कॉल और रिटर्न के लिए आवश्यक स्टैक (अमूर्त डेटा प्रकार) संचालन की संख्या को कम करके प्रोसेसर के प्रदर्शन को उत्तम बनाने के लिए रजिस्टर विंडो प्रयुक्त की जाती है। [[बर्कले आरआईएससी]] डिज़ाइन की सबसे प्रभावशाली विशेषताओं में से एक उन्हें बाद में एएमडी एएम29000, इंटेल आई960, [[सन माइक्रोसिस्टम्स]] एसपीएआरसी और इंटेल [[आईए-64]] जैसे [[निर्देश सेट आर्किटेक्चर]] में प्रयुक्त किया गया था।
[[File:Register window.png|thumb|4-विंडो रजिस्टर विंडो सिस्टम का उदाहरण]][[कंप्यूटर इंजीनियरिंग]] में '''रजिस्टर विंडो''' एक ऐसी सुविधा है जो आंतरिक रजिस्टरों के एक सबसेट को निश्चित, प्रोग्रामर-दृश्यमान रजिस्टरों में गतिशील रूप से अलियास करके रजिस्टरों को एक सबरूटीन में समर्पित करती है। फ़ंक्शन कॉल और रिटर्न के लिए आवश्यक स्टैक (अमूर्त डेटा प्रकार) संचालन की संख्या को कम करके प्रोसेसर के प्रदर्शन को उत्तम बनाने के लिए रजिस्टर विंडो प्रयुक्त की जाती है। [[बर्कले आरआईएससी]] डिज़ाइन की सबसे प्रभावशाली विशेषताओं में से एक उन्हें बाद में एएमडी एएम29000, इंटेल आई960, [[सन माइक्रोसिस्टम्स]] एसपीएआरसी और इंटेल [[आईए-64]] जैसे [[निर्देश सेट आर्किटेक्चर]] में प्रयुक्त किया गया था।                                                                              


==सामान्य ऑपरेशन==
==सामान्य ऑपरेशन                                                                   ==
कार्यक्रम के विभिन्न भागों के लिए रजिस्टरों के कई सेट उपलब्ध कराए गए हैं। कई सबरूटीन्स को प्रोसेसर संसाधनों को साझा करने के लिए विवश करने के लिए रजिस्टरों को प्रोग्रामर से जानबूझकर छिपाया जाता है।
कार्यक्रम के विभिन्न भागों के लिए रजिस्टरों के कई सेट उपलब्ध कराए गए हैं। कई सबरूटीन्स को प्रोसेसर संसाधनों को साझा करने के लिए विवश करने के लिए रजिस्टरों को प्रोग्रामर से जानबूझकर छिपाया जाता है।                                                                                                                                                                                                              


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


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


तुलनात्मक रूप से, सन माइक्रोसिस्टम्स स्पार्क आर्किटेक्चर प्रत्येक आठ रजिस्टरों के चार सेटों में एक साथ दृश्यता प्रदान करता है। प्रत्येक आठ रजिस्टरों के तीन सेट विंडो किए गए हैं। आठ रजिस्टर (i0 से i7 तक) वर्तमान प्रक्रिया स्तर पर इनपुट रजिस्टर बनाते हैं। आठ रजिस्टर (L0 से L7) वर्तमान प्रक्रिया स्तर के लिए स्थानीय हैं, और आठ रजिस्टर (o0 से o7) वर्तमान प्रक्रिया स्तर से अगले स्तर तक के आउटपुट हैं जिन्हें कहा जाता है। जब एक प्रक्रिया को बुलाया जाता है, तो रजिस्टर विंडो सोलह रजिस्टरों द्वारा स्थानांतरित हो जाती है, पुराने इनपुट रजिस्टरों और पुराने स्थानीय रजिस्टरों को छिपा देती है और पुराने आउटपुट रजिस्टरों को नया इनपुट रजिस्टर बना देती है। सामान्य रजिस्टर (पुराने आउटपुट रजिस्टर और नए इनपुट रजिस्टर) का उपयोग पैरामीटर पासिंग के लिए किया जाता है। अंत में, आठ रजिस्टर (g0 से g7 तक) विश्व स्तर पर सभी प्रक्रिया स्तरों पर दृश्यमान हैं।
तुलनात्मक रूप से, सन माइक्रोसिस्टम्स स्पार्क आर्किटेक्चर प्रत्येक आठ रजिस्टरों के चार सेटों में एक साथ दृश्यता प्रदान करता है। प्रत्येक आठ रजिस्टरों के तीन सेट विंडो किए गए हैं। आठ रजिस्टर (i0 से i7 तक) वर्तमान प्रक्रिया स्तर पर इनपुट रजिस्टर बनाते हैं। आठ रजिस्टर (L0 से L7) वर्तमान प्रक्रिया स्तर के लिए स्थानीय हैं, और आठ रजिस्टर (o0 से o7) वर्तमान प्रक्रिया स्तर से अगले स्तर तक के आउटपुट हैं जिन्हें कहा जाता है। जब एक प्रक्रिया को बुलाया जाता है, तो रजिस्टर विंडो सोलह रजिस्टरों द्वारा स्थानांतरित हो जाती है, पुराने इनपुट रजिस्टरों और पुराने स्थानीय रजिस्टरों को छिपा देती है और पुराने आउटपुट रजिस्टरों को नया इनपुट रजिस्टर बना देती है। सामान्य रजिस्टर (पुराने आउटपुट रजिस्टर और नए इनपुट रजिस्टर) का उपयोग पैरामीटर पासिंग के लिए किया जाता है। अंत में, आठ रजिस्टर (g0 से g7 तक) विश्व स्तर पर सभी प्रक्रिया स्तरों पर दृश्यमान हैं।                                                      


एएमडी 29000 ने विंडोज़ को परिवर्तनीय आकार की अनुमति देकर डिज़ाइन में सुधार किया जाता है, जो सामान्य स्थिति में उपयोग में सहायता करता है जहां कॉल के लिए आठ से कम रजिस्टरों की आवश्यकता होती है। इसने रजिस्टरों को 64 के वैश्विक सेट और विंडोज़ के लिए अतिरिक्त 128 में भी अलग कर दिया था। इसी के अनुसार, IA-64 (इटेनियम) आर्किटेक्चर में वैरिएबल-आकार की विंडोज़ का उपयोग किया गया, जिसमें 32 वैश्विक रजिस्टर और विंडोज़ के लिए 96 रजिस्टर थे।
एएमडी 29000 ने विंडोज़ को परिवर्तनीय आकार की अनुमति देकर डिज़ाइन में सुधार किया जाता है, जो सामान्य स्थिति में उपयोग में सहायता करता है जहां कॉल के लिए आठ से कम रजिस्टरों की आवश्यकता होती है। इसने रजिस्टरों को 64 के वैश्विक सेट और विंडोज़ के लिए अतिरिक्त 128 में भी भिन्न कर दिया था। इसी के अनुसार, IA-64 (इटेनियम) आर्किटेक्चर में वैरिएबल-आकार की विंडोज़ का उपयोग किया गया, जिसमें 32 वैश्विक रजिस्टर और विंडोज़ के लिए 96 रजिस्टर थे।


[[Infineon|इन्फिनियोन]] [[C166 परिवार|C166 वर्ग]] वास्तुकला में, अधिकांश रजिस्टर केवल आंतरिक रैम में स्थान होते हैं जिनमें रजिस्टर के रूप में पहुंच योग्य होने की अतिरिक्त गुण होती है। इनमें से 16 सामान्य प्रयोजन रजिस्टरों (R0-R15) के पते निश्चित नहीं हैं। इसके अतिरिक्त , R0 रजिस्टर कॉन्टेक्स्ट पॉइंटर (CP) रजिस्टर द्वारा बताए गए पते पर स्थित है, और शेष 15 रजिस्टर उसके बाद क्रमिक रूप से आते हैं।<ref>{{cite web|url=http://www.keil.com/dd/docs/datashts/infineon/c166ism.pdf|title=Infineon C166 Family Instruction Set Manual|publisher=[[Keil (company)|Keil]]|access-date=2020-03-12}}</ref>
[[Infineon|इन्फिनियोन]] [[C166 परिवार|C166 वर्ग]] वास्तुकला में, अधिकांश रजिस्टर केवल आंतरिक रैम में स्थान होते हैं जिनमें रजिस्टर के रूप में पहुंच योग्य होने की अतिरिक्त गुण होती है। इनमें से 16 सामान्य प्रयोजन रजिस्टरों (R0-R15) के पते निश्चित नहीं हैं। इसके अतिरिक्त , R0 रजिस्टर कॉन्टेक्स्ट पॉइंटर (CP) रजिस्टर द्वारा बताए गए पते पर स्थित है, और शेष 15 रजिस्टर उसके बाद क्रमिक रूप से आते हैं।<ref>{{cite web|url=http://www.keil.com/dd/docs/datashts/infineon/c166ism.pdf|title=Infineon C166 Family Instruction Set Manual|publisher=[[Keil (company)|Keil]]|access-date=2020-03-12}}</ref>                                                                                                          


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


==आलोचना==
==आलोचना                                                                                                                               ==
रजिस्टर प्रदर्शन को उत्तम बनाने के लिए रजिस्टर विंडो ही एकमात्र विधि नहीं है। [[स्टैनफोर्ड एमआईपीएस]] को डिजाइन करने वाले [[स्टैनफोर्ड विश्वविद्यालय]] के समूह ने बर्कले के काम को देखा और निर्णय लिया कि समस्या रजिस्टरों की कमी नहीं थी, किंतु उपस्थित रजिस्टरों का व्यर्थ उपयोग था। इसके अतिरिक्त उन्होंने अपने [[ संकलक ]] के रजिस्टर आवंटन में अधिक समय लगाया था यह सुनिश्चित करते हुए कि यह एमआईपीएस में उपलब्ध बड़े सेट का बुद्धिमानी से उपयोग करता है। इसके परिणामस्वरूप चिप की जटिलता कम हो गई, कुल रजिस्टरों की संख्या आधी हो गई, जबकि उन स्थितियों में संभावित रूप से उच्च प्रदर्शन की प्रस्तुति की गई जहां एक एकल प्रक्रिया बड़े दृश्यमान रजिस्टर स्थान का उपयोग कर सकती थी। अंत में यह आधुनिक कंपाइलरों के साथ, एमआईपीएस प्रक्रिया कॉल के समय भी अपने रजिस्टर स्थान का उत्तम उपयोग करता है।{{Citation needed|date=December 2008}}
रजिस्टर प्रदर्शन को उत्तम बनाने के लिए रजिस्टर विंडो ही एकमात्र विधि नहीं है। [[स्टैनफोर्ड एमआईपीएस]] को डिजाइन करने वाले [[स्टैनफोर्ड विश्वविद्यालय]] के समूह ने बर्कले के काम को देखा और निर्णय लिया कि समस्या रजिस्टरों की कमी नहीं थी, किंतु उपस्थित रजिस्टरों का व्यर्थ उपयोग था। इसके अतिरिक्त उन्होंने अपने [[ संकलक |संकलक]] के रजिस्टर आवंटन में अधिक समय लगाया था यह सुनिश्चित करते हुए कि यह एमआईपीएस में उपलब्ध बड़े सेट का बुद्धिमानी से उपयोग करता है। इसके परिणामस्वरूप चिप की सम्मिश्र्ता कम हो गई है , कुल रजिस्टरों की संख्या आधी हो गई, जबकि उन स्थितियों में संभावित रूप से उच्च प्रदर्शन की प्रस्तुति की गई जहां एक एकल प्रक्रिया बड़े दृश्यमान रजिस्टर स्थान का उपयोग कर सकती थी। अंत में यह आधुनिक कंपाइलरों के साथ, एमआईपीएस प्रक्रिया कॉल के समय भी अपने रजिस्टर स्थान का उत्तम उपयोग करता है।


== संदर्भ                                                                                   ==
== संदर्भ                                             ==
{{Reflist}}
{{Reflist}}
* {{Cite conference
* {{Cite conference
Line 51: Line 51:
   | title = setjmp/longjmp
   | title = setjmp/longjmp
   | url = http://compilers.iecc.com/comparch/article/94-02-130 }} Discussing the complex Sparc implementation due to windowing.
   | url = http://compilers.iecc.com/comparch/article/94-02-130 }} Discussing the complex Sparc implementation due to windowing.
[[Category: अनुदेश प्रसंस्करण]] [[Category: सेंट्रल प्रोसेसिंग यूनिट]]


[[Category: Machine Translated Page]]
[[Category:Created On 10/07/2023]]
[[Category:Created On 10/07/2023]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Short description with empty Wikidata description]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]
[[Category:अनुदेश प्रसंस्करण]]
[[Category:सेंट्रल प्रोसेसिंग यूनिट]]

Latest revision as of 13:03, 4 August 2023

4-विंडो रजिस्टर विंडो सिस्टम का उदाहरण

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

सामान्य ऑपरेशन

कार्यक्रम के विभिन्न भागों के लिए रजिस्टरों के कई सेट उपलब्ध कराए गए हैं। कई सबरूटीन्स को प्रोसेसर संसाधनों को साझा करने के लिए विवश करने के लिए रजिस्टरों को प्रोग्रामर से जानबूझकर छिपाया जाता है।

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

सीपीयू में अनुप्रयोग

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

तुलनात्मक रूप से, सन माइक्रोसिस्टम्स स्पार्क आर्किटेक्चर प्रत्येक आठ रजिस्टरों के चार सेटों में एक साथ दृश्यता प्रदान करता है। प्रत्येक आठ रजिस्टरों के तीन सेट विंडो किए गए हैं। आठ रजिस्टर (i0 से i7 तक) वर्तमान प्रक्रिया स्तर पर इनपुट रजिस्टर बनाते हैं। आठ रजिस्टर (L0 से L7) वर्तमान प्रक्रिया स्तर के लिए स्थानीय हैं, और आठ रजिस्टर (o0 से o7) वर्तमान प्रक्रिया स्तर से अगले स्तर तक के आउटपुट हैं जिन्हें कहा जाता है। जब एक प्रक्रिया को बुलाया जाता है, तो रजिस्टर विंडो सोलह रजिस्टरों द्वारा स्थानांतरित हो जाती है, पुराने इनपुट रजिस्टरों और पुराने स्थानीय रजिस्टरों को छिपा देती है और पुराने आउटपुट रजिस्टरों को नया इनपुट रजिस्टर बना देती है। सामान्य रजिस्टर (पुराने आउटपुट रजिस्टर और नए इनपुट रजिस्टर) का उपयोग पैरामीटर पासिंग के लिए किया जाता है। अंत में, आठ रजिस्टर (g0 से g7 तक) विश्व स्तर पर सभी प्रक्रिया स्तरों पर दृश्यमान हैं।

एएमडी 29000 ने विंडोज़ को परिवर्तनीय आकार की अनुमति देकर डिज़ाइन में सुधार किया जाता है, जो सामान्य स्थिति में उपयोग में सहायता करता है जहां कॉल के लिए आठ से कम रजिस्टरों की आवश्यकता होती है। इसने रजिस्टरों को 64 के वैश्विक सेट और विंडोज़ के लिए अतिरिक्त 128 में भी भिन्न कर दिया था। इसी के अनुसार, IA-64 (इटेनियम) आर्किटेक्चर में वैरिएबल-आकार की विंडोज़ का उपयोग किया गया, जिसमें 32 वैश्विक रजिस्टर और विंडोज़ के लिए 96 रजिस्टर थे।

इन्फिनियोन C166 वर्ग वास्तुकला में, अधिकांश रजिस्टर केवल आंतरिक रैम में स्थान होते हैं जिनमें रजिस्टर के रूप में पहुंच योग्य होने की अतिरिक्त गुण होती है। इनमें से 16 सामान्य प्रयोजन रजिस्टरों (R0-R15) के पते निश्चित नहीं हैं। इसके अतिरिक्त , R0 रजिस्टर कॉन्टेक्स्ट पॉइंटर (CP) रजिस्टर द्वारा बताए गए पते पर स्थित है, और शेष 15 रजिस्टर उसके बाद क्रमिक रूप से आते हैं।[1]

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

आलोचना

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

संदर्भ

  1. "Infineon C166 Family Instruction Set Manual" (PDF). Keil. Retrieved 2020-03-12.