स्टेटस रजिस्टर: Difference between revisions
(Created page with "{{short description|Register containing flags giving additional information concerning a result in a processor}} एक स्टेटस रजिस्टर, फ्लै...") |
No edit summary |
||
Line 1: | Line 1: | ||
{{short description|Register containing flags giving additional information concerning a result in a processor}} | {{short description|Register containing flags giving additional information concerning a result in a processor}} | ||
एक स्टेटस रजिस्टर, फ्लैग रजिस्टर, या कंडीशन कोड रजिस्टर (सीसीआर) एक [[सेंट्रल प्रोसेसिंग यूनिट]] के लिए स्टेटस [[ फ़्लैग (कंप्यूटिंग) ]] [[ अंश ]]्स का एक संग्रह है। ऐसे रजिस्टरों के उदाहरणों में [[x86 आर्किटेक्चर]] में FLAGS रजिस्टर (कंप्यूटिंग), [[ कार्यक्रम स्थिति शब्द ]] (PSW) में | एक स्टेटस रजिस्टर, फ्लैग रजिस्टर, या कंडीशन कोड रजिस्टर (सीसीआर) एक [[सेंट्रल प्रोसेसिंग यूनिट]] के लिए स्टेटस [[ फ़्लैग (कंप्यूटिंग) ]] [[ अंश ]]्स का एक संग्रह है। ऐसे रजिस्टरों के उदाहरणों में [[x86 आर्किटेक्चर]] में FLAGS रजिस्टर (कंप्यूटिंग), [[ कार्यक्रम स्थिति शब्द ]] (PSW) में फ्लैग, IBM सिस्टम/360 आर्किटेक्चर में z/आर्किटेक्चर के माध्यम से रजिस्टर, और ARM कॉर्टेक्स में एप्लिकेशन प्रोग्राम स्टेटस रजिस्टर (APSR) शामिल हैं। -एक वास्तुकला.<ref>{{Cite web|url=http://infocenter.arm.com/help/index.jsp?topic=/com.arm.doc.dui0473c/Babcfejg.html|title=एआरएम सूचना केंद्र|website=infocenter.arm.com|access-date=2019-05-18}}</ref> | ||
स्टेटस रजिस्टर एक [[हार्डवेयर रजिस्टर]] है जिसमें सेंट्रल प्रोसेसिंग यूनिट की स्थिति के बारे में जानकारी होती है। अलग-अलग बिट्स को प्रोसेसर पर निष्पादित होने वाले [[मशीन कोड]] निर्देशों द्वारा स्पष्ट रूप से पढ़ा और/या लिखा जाता है। स्थिति रजिस्टर किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्रवाई करने की अनुमति देता है। | स्टेटस रजिस्टर एक [[हार्डवेयर रजिस्टर]] है जिसमें सेंट्रल प्रोसेसिंग यूनिट की स्थिति के बारे में जानकारी होती है। अलग-अलग बिट्स को प्रोसेसर पर निष्पादित होने वाले [[मशीन कोड]] निर्देशों द्वारा स्पष्ट रूप से पढ़ा और/या लिखा जाता है। स्थिति रजिस्टर किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्रवाई करने की अनुमति देता है। | ||
आमतौर पर, स्थिति रजिस्टर में | आमतौर पर, स्थिति रजिस्टर में फ्लैग अंकगणित और बिट हेरफेर संचालन के प्रभाव के रूप में संशोधित किए जाते हैं। उदाहरण के लिए, यदि ऑपरेशन का परिणाम शून्य है तो एक Z बिट सेट किया जा सकता है और यदि यह गैर-शून्य है तो साफ़ किया जा सकता है। निर्देशों के अन्य वर्ग भी स्थिति दर्शाने के लिए झंडों को संशोधित कर सकते हैं। उदाहरण के लिए, एक स्ट्रिंग निर्देश यह संकेत करने के लिए ऐसा कर सकता है कि क्या निर्देश समाप्त हो गया क्योंकि उसे एक मिलान/बेमेल मिला या क्योंकि उसे स्ट्रिंग का अंत मिला। फ्लैग को बाद के सशर्त निर्देश द्वारा पढ़ा जाता है ताकि निर्दिष्ट कार्रवाई (प्रोसेसर, जंप, कॉल, रिटर्न, आदि के आधार पर) केवल तभी होती है जब फ्लैग पिछले निर्देश के निर्दिष्ट परिणाम को संकेत करते हैं। | ||
कुछ सीपीयू आर्किटेक्चर, जैसे [[एमआईपीएस वास्तुकला]] और [[डीईसी अल्फा]], एक समर्पित ध्वज रजिस्टर का उपयोग नहीं करते हैं। अन्य लोग अप्रत्यक्ष रूप से | कुछ सीपीयू आर्किटेक्चर, जैसे [[एमआईपीएस वास्तुकला]] और [[डीईसी अल्फा]], एक समर्पित ध्वज रजिस्टर का उपयोग नहीं करते हैं। अन्य लोग अप्रत्यक्ष रूप से फ्लैग सेट नहीं करते और/या पढ़ते नहीं हैं। ऐसी मशीनें या तो निर्देशों के मध्य अंतर्निहित स्थिति की जानकारी को पास नहीं करती हैं, या वे इसे स्पष्ट रूप से चयनित सामान्य प्रयोजन रजिस्टर में पास कर देती हैं। | ||
एक स्थिति रजिस्टर में अक्सर अन्य फ़ील्ड भी हो सकते हैं, जैसे अधिक विशिष्ट | एक स्थिति रजिस्टर में अक्सर अन्य फ़ील्ड भी हो सकते हैं, जैसे अधिक विशिष्ट फ्लैग, [[ बाधा डालना ]] सक्षम बिट्स और इसी प्रकार की जानकारी। किसी रुकावट के दौरान, वर्तमान में निष्पादित थ्रेड की स्थिति को [[ कार्यक्रम गणक ]] और अन्य सक्रिय रजिस्टरों के साथ [[कॉल स्टैक]] या मेमोरी के किसी अन्य आरक्षित क्षेत्र में स्टेटस रजिस्टर के वर्तमान मूल्य को संग्रहीत करके संरक्षित (और बाद में वापस बुलाया जा सकता है) किया जा सकता है। | ||
==सामान्य | ==सामान्य फ्लैग== | ||
यह सबसे आम सीपीयू स्टेटस रजिस्टर फ़्लैग की एक सूची है, जो लगभग सभी आधुनिक प्रोसेसर में | यह सबसे आम सीपीयू स्टेटस रजिस्टर फ़्लैग की एक सूची है, जो लगभग सभी आधुनिक प्रोसेसर में प्रयुक्त किया गया है। | ||
{| class="wikitable" | {| class="wikitable" | ||
Line 36: | Line 36: | ||
==अन्य | ==अन्य फ्लैग== | ||
कुछ प्रोसेसरों पर, स्थिति रजिस्टर में निम्न जैसे | कुछ प्रोसेसरों पर, स्थिति रजिस्टर में निम्न जैसे फ्लैग भी होते हैं: | ||
{| class="wikitable" | {| class="wikitable" | ||
|- | |- | ||
! style="background:#D0E0FF; width:10%" | | ! style="background:#D0E0FF; width:10%" |फ्लैग | ||
! style="background:#D0E0FF; width:25%" | | ! style="background:#D0E0FF; width:25%" |नाम | ||
! style="background:#D0E0FF; width:60%" | | ! style="background:#D0E0FF; width:60%" |विवरण | ||
|- style="vertical-align:top" | |- style="vertical-align:top" | ||
| align="center" |'''H''' / '''A''' / '''DC''' | | align="center" |'''H''' / '''A''' / '''DC''' | ||
| [[Half-carry flag]]<br/> Auxiliary flag<br/> Digit Carry<br/> Decimal adjust flag | | [[Half-carry flag]]<br/> Auxiliary flag<br/> Digit Carry<br/> Decimal adjust flag | ||
| | | संकेत करता है कि अंतिम अंकगणितीय ऑपरेशन के परिणामस्वरूप [[nibble|निबल्स]] (सामान्यतः बाइट ऑपरेंड के 4-बिट भाग के मध्य) के मध्य एक बिट कैरी उत्पन्न हुआ था। ऐसा ध्वज आम तौर पर बाइनरी हार्डवेयर पर बीसीडी अंकगणितीय संचालन को प्रयुक्त करने के लिए उपयोगी होता है। | ||
|- style="vertical-align:top" | |- style="vertical-align:top" | ||
| align="center" |'''P''' | | align="center" |'''P''' | ||
| [[Parity flag]] | | [[Parity flag]] | ||
| | | संकेत करता है कि अंतिम परिणाम के सेट बिट्स की संख्या विषम है या सम। | ||
|- style="vertical-align:top" | |- style="vertical-align:top" | ||
| align="center" |'''I''' | | align="center" |'''I''' | ||
| [[Interrupt flag]] | | [[Interrupt flag]] | ||
| | | कुछ प्रोसेसरों पर, यह बिट संकेत करता है कि इंटरप्ट सक्षम हैं या मास्क्ड हैं।<ref>{{cite web|url=http://ww1.microchip.com/downloads/en/devicedoc/atmel-8271-8-bit-avr-microcontroller-atmega48a-48pa-88a-88pa-168a-168pa-328-328p_datasheet_complete.pdf|title=Atmel 8-Bit Microcontroller With 4/8/16/32KBytes In-system Programmable Flash - Datasheet|website=[[Microchip Technology]]}}</ref> यदि प्रोसेसर में एकाधिक [[interrupt|इंटरप्ट]] प्राथमिकता स्तर हैं, जैसे कि [[PDP-11 architecture#Interrupts|पीडीपी-11]], तो वर्तमान थ्रेड की प्राथमिकता को संकेत करने के लिए कई बिट्स का उपयोग किया जा सकता है, जिससे इसे केवल उच्च प्राथमिकता पर सेट हार्डवेयर द्वारा बाधित किया जा सकता है। अन्य आर्किटेक्चर पर, एक बिट यह संकेत दे सकता है कि एक इंटरप्ट वर्तमान में सक्रिय है, और वर्तमान थ्रेड एक [[interrupt handler|इंटरप्ट हैंडलर]] का भाग है। | ||
|- style="vertical-align:top" | |- style="vertical-align:top" | ||
| align="center" |'''S''' | | align="center" |'''S''' | ||
| Supervisor flag | | Supervisor flag | ||
| | | उन प्रोसेसर पर जो दो या अधिक [[protection ring|सुरक्षा रिंग]] प्रदान करते हैं, स्थिति रजिस्टर में एक या अधिक बिट्स वर्तमान थ्रेड की रिंग को संकेत करते हैं (यह कितना विश्वसनीय है, या क्या इसे उन अनुरोधों के लिए ऑपरेटिंग सिस्टम का उपयोग करना चाहिए जो अन्य थ्रेड में बाधा डाल सकते हैं)। केवल दो रिंग वाले प्रोसेसर पर, एक बिट सुपरवाइज़र को उपयोगकर्ता मोड से अलग कर सकता है। | ||
|} | |} | ||
Line 65: | Line 65: | ||
==अंकगणितीय झंडों के बिना सीपीयू आर्किटेक्चर== | ==अंकगणितीय झंडों के बिना सीपीयू आर्किटेक्चर== | ||
स्थिति ध्वज किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्य करने में सक्षम बनाते हैं। निर्देश पाइपलाइन प्रोसेसर में, जैसे कि [[सुपरस्केलर]] और [[सट्टा निष्पादन]] प्रोसेसर, यह खतरा (कंप्यूटर आर्किटेक्चर) बना सकता है जो धीमी गति से प्रसंस्करण करता है या उनके आसपास काम करने के लिए अतिरिक्त हार्डवेयर की आवश्यकता होती है।<ref name="carry-trap">{{cite web|url=http://yarchive.net/comp/carry_bit.html|title=Carry bits; The Architect's Trap|last=Mashey|first=John|date=1996-06-04|access-date=2013-10-05}}</ref> | स्थिति ध्वज किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्य करने में सक्षम बनाते हैं। निर्देश पाइपलाइन प्रोसेसर में, जैसे कि [[सुपरस्केलर]] और [[सट्टा निष्पादन]] प्रोसेसर, यह खतरा (कंप्यूटर आर्किटेक्चर) बना सकता है जो धीमी गति से प्रसंस्करण करता है या उनके आसपास काम करने के लिए अतिरिक्त हार्डवेयर की आवश्यकता होती है।<ref name="carry-trap">{{cite web|url=http://yarchive.net/comp/carry_bit.html|title=Carry bits; The Architect's Trap|last=Mashey|first=John|date=1996-06-04|access-date=2013-10-05}}</ref> | ||
कुछ बहुत लंबे निर्देश वाले वर्ड प्रोसेसर स्टेटस फ़्लैग के बिना होते हैं। एक एकल निर्देश एक परीक्षण करता है और | कुछ बहुत लंबे निर्देश वाले वर्ड प्रोसेसर स्टेटस फ़्लैग के बिना होते हैं। एक एकल निर्देश एक परीक्षण करता है और संकेत करता है कि उस परीक्षण के किस परिणाम पर कार्रवाई की जानी है, जैसे कि ए की तुलना बी से करें और यदि बराबर हो तो सी पर जाएं। परीक्षण का परिणाम आगामी अनुदेशों के लिए सहेजा नहीं गया है। | ||
स्थिति रजिस्टर का एक अन्य विकल्प प्रोसेसर निर्देशों के लिए यह है कि जब प्रोग्राम अनुरोध करता है तो स्थिति की जानकारी सामान्य प्रयोजन रजिस्टर में जमा करें। एमआईपीएस आर्किटेक्चर, [[एएमडी 29000]], डीईसी अल्फा और [[ RISC-वी ]]ी आर्किटेक्चर के उदाहरण हैं जो तुलना निर्देश प्रदान करते हैं जो तुलना परिणाम को सामान्य प्रयोजन रजिस्टर में एकल बिट या 0 या 1 के संख्यात्मक मान के रूप में संग्रहीत करते हैं। सशर्त शाखाएं कार्य आधारित होती हैं सामान्य प्रयोजन रजिस्टर में मूल्य पर. | स्थिति रजिस्टर का एक अन्य विकल्प प्रोसेसर निर्देशों के लिए यह है कि जब प्रोग्राम अनुरोध करता है तो स्थिति की जानकारी सामान्य प्रयोजन रजिस्टर में जमा करें। एमआईपीएस आर्किटेक्चर, [[एएमडी 29000]], डीईसी अल्फा और [[ RISC-वी ]]ी आर्किटेक्चर के उदाहरण हैं जो तुलना निर्देश प्रदान करते हैं जो तुलना परिणाम को सामान्य प्रयोजन रजिस्टर में एकल बिट या 0 या 1 के संख्यात्मक मान के रूप में संग्रहीत करते हैं। सशर्त शाखाएं कार्य आधारित होती हैं सामान्य प्रयोजन रजिस्टर में मूल्य पर. | ||
Line 72: | Line 72: | ||
<syntaxhighlight lang="asm"> | <syntaxhighlight lang="asm"> | ||
# alow = blow + clow | # alow = blow + clow | ||
addu alow, blow, clow | addu alow, blow, clow | ||
# set tmp = 1 if alow < clow, else 0 | # set tmp = 1 if alow < clow, else 0 | ||
sltu tmp, alow, clow | sltu tmp, alow, clow | ||
addu ahigh, bhigh, chigh | addu ahigh, bhigh, chigh | ||
addu ahigh, ahigh, tmp | addu ahigh, ahigh, tmp | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<code>sltu</code> ई> निर्देश सेट <code>tmp</code> इसके दो अन्य ऑपरेंड की निर्दिष्ट तुलना के आधार पर 1 या 0 तक। (यहां, सामान्य प्रयोजन रजिस्टर <code>tmp</code> सशर्त छलांग को नियंत्रित करने के लिए स्थिति रजिस्टर के रूप में उपयोग नहीं किया जाता है; बल्कि, 1 का संभावित मान, जो निम्न-क्रम जोड़ से आगे बढ़ने का संकेत देता है, उच्च-क्रम वाले शब्द में जोड़ा जाता है।) | <code>sltu</code> ई> निर्देश सेट <code>tmp</code> इसके दो अन्य ऑपरेंड की निर्दिष्ट तुलना के आधार पर 1 या 0 तक। (यहां, सामान्य प्रयोजन रजिस्टर <code>tmp</code> सशर्त छलांग को नियंत्रित करने के लिए स्थिति रजिस्टर के रूप में उपयोग नहीं किया जाता है; बल्कि, 1 का संभावित मान, जो निम्न-क्रम जोड़ से आगे बढ़ने का संकेत देता है, उच्च-क्रम वाले शब्द में जोड़ा जाता है।) | ||
तीन या अधिक शब्द जोड़ते समय यह योजना कम सुविधाजनक हो जाती है, क्योंकि गणना करते समय दो जोड़ होते हैं <code>b + c + tmp</code>, जिनमें से कोई भी कैरी उत्पन्न कर सकता है, जिसे दो के साथ पता लगाया जाना चाहिए <code>sltu</code> निर्देश। सौभाग्य से, उन दो कैरीज़ को अतिप्रवाह के जोखिम के बिना एक-दूसरे में जोड़ा जा सकता है, इसलिए स्थिति प्रति शब्द पांच निर्देशों पर स्थिर हो जाती है। | |||
तीन या अधिक शब्द जोड़ते समय यह योजना कम सुविधाजनक हो जाती है, क्योंकि गणना करते समय दो जोड़ होते हैं <code>b + c + tmp</code>, जिनमें से कोई भी कैरी उत्पन्न कर सकता है, जिसे दो के साथ पता लगाया जाना चाहिए <code>sltu</code> निर्देश। सौभाग्य से, उन दो कैरीज़ को अतिप्रवाह के जोखिम के बिना एक-दूसरे में जोड़ा जा सकता है, इसलिए स्थिति प्रति शब्द पांच निर्देशों पर स्थिर हो जाती है। | तीन या अधिक शब्द जोड़ते समय यह योजना कम सुविधाजनक हो जाती है, क्योंकि गणना करते समय दो जोड़ होते हैं <code>b + c + tmp</code>, जिनमें से कोई भी कैरी उत्पन्न कर सकता है, जिसे दो के साथ पता लगाया जाना चाहिए <code>sltu</code> निर्देश। सौभाग्य से, उन दो कैरीज़ को अतिप्रवाह के जोखिम के बिना एक-दूसरे में जोड़ा जा सकता है, इसलिए स्थिति प्रति शब्द पांच निर्देशों पर स्थिर हो जाती है। |
Revision as of 10:29, 18 July 2023
एक स्टेटस रजिस्टर, फ्लैग रजिस्टर, या कंडीशन कोड रजिस्टर (सीसीआर) एक सेंट्रल प्रोसेसिंग यूनिट के लिए स्टेटस फ़्लैग (कंप्यूटिंग) अंश ्स का एक संग्रह है। ऐसे रजिस्टरों के उदाहरणों में x86 आर्किटेक्चर में FLAGS रजिस्टर (कंप्यूटिंग), कार्यक्रम स्थिति शब्द (PSW) में फ्लैग, IBM सिस्टम/360 आर्किटेक्चर में z/आर्किटेक्चर के माध्यम से रजिस्टर, और ARM कॉर्टेक्स में एप्लिकेशन प्रोग्राम स्टेटस रजिस्टर (APSR) शामिल हैं। -एक वास्तुकला.[1] स्टेटस रजिस्टर एक हार्डवेयर रजिस्टर है जिसमें सेंट्रल प्रोसेसिंग यूनिट की स्थिति के बारे में जानकारी होती है। अलग-अलग बिट्स को प्रोसेसर पर निष्पादित होने वाले मशीन कोड निर्देशों द्वारा स्पष्ट रूप से पढ़ा और/या लिखा जाता है। स्थिति रजिस्टर किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्रवाई करने की अनुमति देता है।
आमतौर पर, स्थिति रजिस्टर में फ्लैग अंकगणित और बिट हेरफेर संचालन के प्रभाव के रूप में संशोधित किए जाते हैं। उदाहरण के लिए, यदि ऑपरेशन का परिणाम शून्य है तो एक Z बिट सेट किया जा सकता है और यदि यह गैर-शून्य है तो साफ़ किया जा सकता है। निर्देशों के अन्य वर्ग भी स्थिति दर्शाने के लिए झंडों को संशोधित कर सकते हैं। उदाहरण के लिए, एक स्ट्रिंग निर्देश यह संकेत करने के लिए ऐसा कर सकता है कि क्या निर्देश समाप्त हो गया क्योंकि उसे एक मिलान/बेमेल मिला या क्योंकि उसे स्ट्रिंग का अंत मिला। फ्लैग को बाद के सशर्त निर्देश द्वारा पढ़ा जाता है ताकि निर्दिष्ट कार्रवाई (प्रोसेसर, जंप, कॉल, रिटर्न, आदि के आधार पर) केवल तभी होती है जब फ्लैग पिछले निर्देश के निर्दिष्ट परिणाम को संकेत करते हैं।
कुछ सीपीयू आर्किटेक्चर, जैसे एमआईपीएस वास्तुकला और डीईसी अल्फा, एक समर्पित ध्वज रजिस्टर का उपयोग नहीं करते हैं। अन्य लोग अप्रत्यक्ष रूप से फ्लैग सेट नहीं करते और/या पढ़ते नहीं हैं। ऐसी मशीनें या तो निर्देशों के मध्य अंतर्निहित स्थिति की जानकारी को पास नहीं करती हैं, या वे इसे स्पष्ट रूप से चयनित सामान्य प्रयोजन रजिस्टर में पास कर देती हैं।
एक स्थिति रजिस्टर में अक्सर अन्य फ़ील्ड भी हो सकते हैं, जैसे अधिक विशिष्ट फ्लैग, बाधा डालना सक्षम बिट्स और इसी प्रकार की जानकारी। किसी रुकावट के दौरान, वर्तमान में निष्पादित थ्रेड की स्थिति को कार्यक्रम गणक और अन्य सक्रिय रजिस्टरों के साथ कॉल स्टैक या मेमोरी के किसी अन्य आरक्षित क्षेत्र में स्टेटस रजिस्टर के वर्तमान मूल्य को संग्रहीत करके संरक्षित (और बाद में वापस बुलाया जा सकता है) किया जा सकता है।
सामान्य फ्लैग
यह सबसे आम सीपीयू स्टेटस रजिस्टर फ़्लैग की एक सूची है, जो लगभग सभी आधुनिक प्रोसेसर में प्रयुक्त किया गया है।
Flag | Name | Description |
---|---|---|
Z | Zero flag | Indicates that the result of an arithmetic or logical operation (or, sometimes, a load) was zero. |
C | Carry flag | Enables numbers larger than a single word to be added/subtracted by carrying a binary digit from a less significant word to the least significant bit of a more significant word as needed. It is also used to extend bit shifts and rotates in a similar manner on many processors (sometimes done via a dedicated X flag). |
S / N | Sign flag Negative flag |
Indicates that the result of a mathematical operation is negative. In some processors,[2] the N and S flags are distinct with different meanings and usage: One indicates whether the last result was negative whereas the other indicates whether a subtraction or addition has taken place. |
V / O / W | Overflow flag | Indicates that the signed result of an operation is too large to fit in the register width using two's complement representation. |
अन्य फ्लैग
कुछ प्रोसेसरों पर, स्थिति रजिस्टर में निम्न जैसे फ्लैग भी होते हैं:
फ्लैग | नाम | विवरण |
---|---|---|
H / A / DC | Half-carry flag Auxiliary flag Digit Carry Decimal adjust flag |
संकेत करता है कि अंतिम अंकगणितीय ऑपरेशन के परिणामस्वरूप निबल्स (सामान्यतः बाइट ऑपरेंड के 4-बिट भाग के मध्य) के मध्य एक बिट कैरी उत्पन्न हुआ था। ऐसा ध्वज आम तौर पर बाइनरी हार्डवेयर पर बीसीडी अंकगणितीय संचालन को प्रयुक्त करने के लिए उपयोगी होता है। |
P | Parity flag | संकेत करता है कि अंतिम परिणाम के सेट बिट्स की संख्या विषम है या सम। |
I | Interrupt flag | कुछ प्रोसेसरों पर, यह बिट संकेत करता है कि इंटरप्ट सक्षम हैं या मास्क्ड हैं।[3] यदि प्रोसेसर में एकाधिक इंटरप्ट प्राथमिकता स्तर हैं, जैसे कि पीडीपी-11, तो वर्तमान थ्रेड की प्राथमिकता को संकेत करने के लिए कई बिट्स का उपयोग किया जा सकता है, जिससे इसे केवल उच्च प्राथमिकता पर सेट हार्डवेयर द्वारा बाधित किया जा सकता है। अन्य आर्किटेक्चर पर, एक बिट यह संकेत दे सकता है कि एक इंटरप्ट वर्तमान में सक्रिय है, और वर्तमान थ्रेड एक इंटरप्ट हैंडलर का भाग है। |
S | Supervisor flag | उन प्रोसेसर पर जो दो या अधिक सुरक्षा रिंग प्रदान करते हैं, स्थिति रजिस्टर में एक या अधिक बिट्स वर्तमान थ्रेड की रिंग को संकेत करते हैं (यह कितना विश्वसनीय है, या क्या इसे उन अनुरोधों के लिए ऑपरेटिंग सिस्टम का उपयोग करना चाहिए जो अन्य थ्रेड में बाधा डाल सकते हैं)। केवल दो रिंग वाले प्रोसेसर पर, एक बिट सुपरवाइज़र को उपयोगकर्ता मोड से अलग कर सकता है। |
अंकगणितीय झंडों के बिना सीपीयू आर्किटेक्चर
स्थिति ध्वज किसी निर्देश को पिछले निर्देश के परिणाम के आधार पर कार्य करने में सक्षम बनाते हैं। निर्देश पाइपलाइन प्रोसेसर में, जैसे कि सुपरस्केलर और सट्टा निष्पादन प्रोसेसर, यह खतरा (कंप्यूटर आर्किटेक्चर) बना सकता है जो धीमी गति से प्रसंस्करण करता है या उनके आसपास काम करने के लिए अतिरिक्त हार्डवेयर की आवश्यकता होती है।[4] कुछ बहुत लंबे निर्देश वाले वर्ड प्रोसेसर स्टेटस फ़्लैग के बिना होते हैं। एक एकल निर्देश एक परीक्षण करता है और संकेत करता है कि उस परीक्षण के किस परिणाम पर कार्रवाई की जानी है, जैसे कि ए की तुलना बी से करें और यदि बराबर हो तो सी पर जाएं। परीक्षण का परिणाम आगामी अनुदेशों के लिए सहेजा नहीं गया है।
स्थिति रजिस्टर का एक अन्य विकल्प प्रोसेसर निर्देशों के लिए यह है कि जब प्रोग्राम अनुरोध करता है तो स्थिति की जानकारी सामान्य प्रयोजन रजिस्टर में जमा करें। एमआईपीएस आर्किटेक्चर, एएमडी 29000, डीईसी अल्फा और RISC-वी ी आर्किटेक्चर के उदाहरण हैं जो तुलना निर्देश प्रदान करते हैं जो तुलना परिणाम को सामान्य प्रयोजन रजिस्टर में एकल बिट या 0 या 1 के संख्यात्मक मान के रूप में संग्रहीत करते हैं। सशर्त शाखाएं कार्य आधारित होती हैं सामान्य प्रयोजन रजिस्टर में मूल्य पर.
आमतौर पर, तुलना निर्देश समानता या हस्ताक्षरित/अहस्ताक्षरित परिमाण का परीक्षण करते हैं। अन्य स्थितियों के परीक्षण के लिए, एक प्रोग्राम एक तुल्यता सूत्र का उपयोग करता है। उदाहरण के लिए, एमआईपीएस में कोई कैरी बिट नहीं है, लेकिन एकाधिक-शब्द जोड़ करने वाला प्रोग्राम यह परीक्षण कर सकता है कि रजिस्टरों का एक-शब्द जोड़ ओवरफ्लो हो गया है या नहीं, यह परीक्षण करके कि योग ऑपरेंड से कम है या नहीं:[4]
# alow = blow + clow
addu alow, blow, clow
# set tmp = 1 if alow < clow, else 0
sltu tmp, alow, clow
addu ahigh, bhigh, chigh
addu ahigh, ahigh, tmp
sltu
ई> निर्देश सेटtmp
इसके दो अन्य ऑपरेंड की निर्दिष्ट तुलना के आधार पर 1 या 0 तक। (यहां, सामान्य प्रयोजन रजिस्टरtmp
सशर्त छलांग को नियंत्रित करने के लिए स्थिति रजिस्टर के रूप में उपयोग नहीं किया जाता है; बल्कि, 1 का संभावित मान, जो निम्न-क्रम जोड़ से आगे बढ़ने का संकेत देता है, उच्च-क्रम वाले शब्द में जोड़ा जाता है।)
तीन या अधिक शब्द जोड़ते समय यह योजना कम सुविधाजनक हो जाती है, क्योंकि गणना करते समय दो जोड़ होते हैं b + c + tmp
, जिनमें से कोई भी कैरी उत्पन्न कर सकता है, जिसे दो के साथ पता लगाया जाना चाहिए sltu
निर्देश। सौभाग्य से, उन दो कैरीज़ को अतिप्रवाह के जोखिम के बिना एक-दूसरे में जोड़ा जा सकता है, इसलिए स्थिति प्रति शब्द पांच निर्देशों पर स्थिर हो जाती है।
तीन या अधिक शब्द जोड़ते समय यह योजना कम सुविधाजनक हो जाती है, क्योंकि गणना करते समय दो जोड़ होते हैं b + c + tmp
, जिनमें से कोई भी कैरी उत्पन्न कर सकता है, जिसे दो के साथ पता लगाया जाना चाहिए sltu
निर्देश। सौभाग्य से, उन दो कैरीज़ को अतिप्रवाह के जोखिम के बिना एक-दूसरे में जोड़ा जा सकता है, इसलिए स्थिति प्रति शब्द पांच निर्देशों पर स्थिर हो जाती है।
यह भी देखें
संदर्भ
- ↑ "एआरएम सूचना केंद्र". infocenter.arm.com. Retrieved 2019-05-18.
- ↑ "Toshiba 900 Operation Manual, chap. 3" (PDF). Archived from the original (PDF) on 2006-01-15.
- ↑ "Atmel 8-Bit Microcontroller With 4/8/16/32KBytes In-system Programmable Flash - Datasheet" (PDF). Microchip Technology.
- ↑ 4.0 4.1 Mashey, John (1996-06-04). "Carry bits; The Architect's Trap". Retrieved 2013-10-05.