विधानसभा - रजिस्टर

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

प्रोसेसर के संचालन को गति देने के लिए, प्रोसेसर में कुछ आंतरिक मेमोरी स्टोरेज स्थान शामिल हैं, जिन्हें कहा जाता है registers

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

प्रोसेसर रजिस्टर

IA-32 आर्किटेक्चर में दस 32-बिट और छह 16-बिट प्रोसेसर रजिस्टर हैं। रजिस्टर को तीन श्रेणियों में बांटा गया है -

  • सामान्य रजिस्टर,
  • नियंत्रण रजिस्टर, और
  • खंड रजिस्टर।

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

  • डेटा रजिस्टर,
  • सूचक रजिस्टर, और
  • सूचकांक रजिस्टर।

डेटा रजिस्टर

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

  • पूर्ण 32-बिट डेटा रजिस्टर के रूप में: EAX, EBX, ECX, EDX।

  • 32-बिट रजिस्टरों के निचले हिस्सों का उपयोग चार 16-बिट डेटा रजिस्टरों के रूप में किया जा सकता है: AX, BX, CX और DX।

  • उपर्युक्त चार 16-बिट रजिस्टरों के निचले और उच्चतर हिस्सों को आठ 8-बिट डेटा रजिस्टरों के रूप में इस्तेमाल किया जा सकता है: एएच, एएल, बीएच, बीएल, सीएच, सीएल, डीएच और डीएल।

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

AX is the primary accumulator; इसका उपयोग इनपुट / आउटपुट और अधिकांश अंकगणितीय निर्देशों में किया जाता है। उदाहरण के लिए, गुणन ऑपरेशन में, एक ऑपरेंड EAX या AX या AL रजिस्टर में संचित होता है, जो ऑपरेंड के आकार के अनुसार होता है।

BX is known as the base register, क्योंकि इसका उपयोग अनुक्रमित संबोधन में किया जा सकता है।

CX is known as the count register, ECX के रूप में, सीएक्स रजिस्टर्स लूप काउंट को पुनरावृत्तियों के संचालन में संग्रहीत करते हैं।

DX is known as the data register। इसका उपयोग इनपुट / आउटपुट संचालन में भी किया जाता है। इसका उपयोग AX रजिस्टर के साथ-साथ DX के साथ-साथ बड़े मूल्यों को शामिल करने के लिए बहुगुणित और विभाजित कार्यों के लिए भी किया जाता है।

सूचक रजिस्टर

सूचक रजिस्टर 32-बिट ईआईपी, ईएसपी और ईबीपी रजिस्टर और इसी 16-बिट सही हिस्से आईपी, एसपी और बीपी हैं। सूचक रजिस्टर की तीन श्रेणियां हैं -

  • Instruction Pointer (IP)- 16-बिट आईपी रजिस्टर निष्पादित होने वाले अगले निर्देश के ऑफसेट पते को संग्रहीत करता है। सीएस रजिस्टर के साथ आईपी (सीएस के रूप में: आईपी) कोड सेगमेंट में वर्तमान निर्देश का पूरा पता देता है।

  • Stack Pointer (SP)- 16-बिट एसपी रजिस्टर प्रोग्राम स्टैक के भीतर ऑफसेट मूल्य प्रदान करता है। एसएस रजिस्टर (एसएस: एसपी) के साथ एसपी कार्यक्रम स्टैक के भीतर डेटा या पते की वर्तमान स्थिति को संदर्भित करता है।

  • Base Pointer (BP)- 16-बिट बीपी रजिस्टर मुख्य रूप से सबरूटीन को पारित पैरामीटर चर को संदर्भित करने में मदद करता है। एसएस रजिस्टर में पता पैरामीटर के स्थान को प्राप्त करने के लिए बीपी में ऑफसेट के साथ संयुक्त है। बीपी को विशेष पते के लिए आधार रजिस्टर के रूप में डीआई और एसआई के साथ भी जोड़ा जा सकता है।

सूचकांक रजिस्टर

32-बिट इंडेक्स रजिस्टर, ईएसआई और ईडीआई, और उनके 16-बिट दाहिने हिस्से। SI और DI, का उपयोग अनुक्रमित पते के लिए किया जाता है और कभी-कभी इसके अलावा और घटाव में उपयोग किया जाता है। सूचकांक सूचक के दो सेट हैं -

  • Source Index (SI) - यह स्ट्रिंग संचालन के लिए स्रोत सूचकांक के रूप में उपयोग किया जाता है।

  • Destination Index (DI) - इसे स्ट्रिंग ऑपरेशंस के लिए डेस्टिनेशन इंडेक्स के रूप में इस्तेमाल किया जाता है।

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

32-बिट इंस्ट्रक्शन पॉइंटर रजिस्टर और 32-बिट फ्लैग रजिस्टर को संयुक्त रूप से कंट्रोल रजिस्टर माना जाता है।

कई निर्देशों में तुलना और गणितीय गणना शामिल है और झंडे की स्थिति को बदलते हैं और कुछ अन्य सशर्त निर्देश नियंत्रण प्रवाह को अन्य स्थान पर ले जाने के लिए इन स्थिति झंडे के मूल्य का परीक्षण करते हैं।

सामान्य ध्वज बिट्स हैं:

  • Overflow Flag (OF) - यह एक हस्ताक्षरित अंकगणितीय ऑपरेशन के बाद डेटा के उच्च-क्रम बिट (सबसे बाईं ओर) के अतिप्रवाह को इंगित करता है।

  • Direction Flag (DF)- यह स्ट्रिंग डेटा को ले जाने या तुलना करने के लिए बाएं या दाएं दिशा निर्धारित करता है। जब DF मान 0 होता है, तो स्ट्रिंग ऑपरेशन बाएँ-से-दाएँ दिशा लेता है और जब मान 1 पर सेट होता है, तो स्ट्रिंग ऑपरेशन दाएँ-से-बाएँ दिशा लेता है।

  • Interrupt Flag (IF)- यह निर्धारित करता है कि क्या कुंजीपटल, आदि जैसे बाहरी व्यवधानों को अनदेखा या संसाधित किया जाना है। जब मान 0 होता है तो यह बाहरी व्यवधान को निष्क्रिय कर देता है और 1 पर सेट होने पर व्यवधान को सक्षम बनाता है।

  • Trap Flag (TF)- यह एकल-चरण मोड में प्रोसेसर के संचालन को स्थापित करने की अनुमति देता है। DEBUG प्रोग्राम का उपयोग हमने ट्रैप फ़्लैग सेट किया है, इसलिए हम एक समय में निष्पादन एक निर्देश के माध्यम से कदम बढ़ा सकते हैं।

  • Sign Flag (SF)- यह एक अंकगणितीय ऑपरेशन के परिणाम का संकेत दिखाता है। यह ध्वज अंकगणितीय ऑपरेशन के बाद डेटा आइटम के संकेत के अनुसार सेट किया गया है। संकेत को सबसे बाईं ओर के उच्च-क्रम द्वारा दर्शाया गया है। एक सकारात्मक परिणाम SF के मान को 0 पर साफ करता है और नकारात्मक परिणाम इसे 1 पर सेट करता है।

  • Zero Flag (ZF)- यह एक अंकगणित या तुलना ऑपरेशन के परिणाम को इंगित करता है। एक नॉनज़रो परिणाम शून्य ध्वज को 0 पर साफ़ करता है, और एक शून्य परिणाम इसे 1 पर सेट करता है।

  • Auxiliary Carry Flag (AF)- इसमें अंकगणितीय ऑपरेशन के बाद बिट 3 से बिट 4 तक कैरी होता है; विशेष अंकगणित के लिए उपयोग किया जाता है। AF तब सेट होता है जब 1-बाइट अंकगणितीय ऑपरेशन के कारण बिट 3 से बिट 4 में ले जाता है।

  • Parity Flag (PF)- यह अंकगणितीय ऑपरेशन से प्राप्त परिणाम में कुल 1-बिट्स को इंगित करता है। 1-बिट्स की एक समान संख्या समता ध्वज को 0 पर साफ़ करती है और 1-बिट्स की विषम संख्या समता ध्वज को 1 पर सेट करती है।

  • Carry Flag (CF)- इसमें अंकगणित ऑपरेशन के बाद एक उच्च-क्रम बिट (सबसे बाएं) से 0 या 1 का कैरी होता है। यह अंतिम बिट के शिफ्ट या रोटेट ऑपरेशन की सामग्री को भी संग्रहीत करता है ।

निम्नलिखित तालिका 16-बिट फ़्लैग्स रजिस्टर में ध्वज बिट्स की स्थिति को इंगित करती है:

झंडा: हे मैं टी रों जेड पी सी
बिट नं: 15 14 13 12 1 1 10 9 8 7 6 5 4 3 2 1 0

खंड रजिस्टर

सेगमेंट डेटा, कोड और स्टैक युक्त प्रोग्राम में परिभाषित विशिष्ट क्षेत्र हैं। तीन मुख्य खंड हैं -

  • Code Segment- इसमें सभी निर्देशों को निष्पादित किया जाना है। 16-बिट कोड सेगमेंट रजिस्टर या सीएस रजिस्टर कोड सेगमेंट के शुरुआती पते को संग्रहीत करता है।

  • Data Segment- इसमें डेटा, स्थिरांक और कार्य क्षेत्र शामिल हैं। एक 16-बिट डेटा सेगमेंट रजिस्टर या डीएस रजिस्टर डेटा सेगमेंट के शुरुआती पते को स्टोर करता है।

  • Stack Segment- इसमें प्रक्रियाओं या सबरूटीन्स के डेटा और रिटर्न एड्रेस शामिल हैं। इसे 'स्टैक' डेटा संरचना के रूप में कार्यान्वित किया जाता है। स्टैक सेगमेंट रजिस्टर या एसएस रजिस्टर स्टैक के शुरुआती पते को संग्रहीत करता है।

डीएस, सीएस और एसएस रजिस्टर के अलावा, अन्य अतिरिक्त खंड रजिस्टर हैं - ईएस (अतिरिक्त खंड), एफएस और जीएस, जो डेटा संग्रहीत करने के लिए अतिरिक्त खंड प्रदान करते हैं।

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

सेगमेंट रजिस्टर एक सेगमेंट के शुरुआती पतों को संग्रहीत करता है। एक खंड के भीतर डेटा या निर्देश का सटीक स्थान प्राप्त करने के लिए, एक ऑफसेट मूल्य (या विस्थापन) की आवश्यकता होती है। किसी सेगमेंट में किसी मेमोरी लोकेशन को रेफर करने के लिए, प्रोसेसर सेगमेंट रजिस्टर में सेगमेंट एड्रेस को लोकेशन की ऑफसेट वैल्यू के साथ जोड़ देता है।

उदाहरण

असेंबली प्रोग्रामिंग में रजिस्टरों के उपयोग को समझने के लिए निम्नलिखित सरल कार्यक्रम को देखें। यह कार्यक्रम एक साधारण संदेश के साथ स्क्रीन पर 9 सितारों को प्रदर्शित करता है -

section	.text
   global _start	 ;must be declared for linker (gcc)
	
_start:	         ;tell linker entry point
   mov	edx,len  ;message length
   mov	ecx,msg  ;message to write
   mov	ebx,1    ;file descriptor (stdout)
   mov	eax,4    ;system call number (sys_write)
   int	0x80     ;call kernel
	
   mov	edx,9    ;message length
   mov	ecx,s2   ;message to write
   mov	ebx,1    ;file descriptor (stdout)
   mov	eax,4    ;system call number (sys_write)
   int	0x80     ;call kernel
	
   mov	eax,1    ;system call number (sys_exit)
   int	0x80     ;call kernel
	
section	.data
msg db 'Displaying 9 stars',0xa ;a message
len equ $ - msg  ;length of message
s2 times 9 db '*'

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Displaying 9 stars
*********