विधानसभा - अंकगणितीय निर्देश

आईएनसी निर्देश

INC निर्देश का उपयोग किसी एक ऑपरेंड को बढ़ाने के लिए किया जाता है। यह एक एकल ऑपरेंड पर काम करता है जो या तो रजिस्टर में या मेमोरी में हो सकता है।

वाक्य - विन्यास

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

INC destination

ऑपरेंड गंतव्य 8-बिट, 16-बिट या 32-बिट ऑपरेंड हो सकता है।

उदाहरण

INC EBX	     ; Increments 32-bit register
INC DL       ; Increments 8-bit register
INC [count]  ; Increments the count variable

डीईसी निर्देश

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

वाक्य - विन्यास

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

DEC destination

ऑपरेंड गंतव्य 8-बिट, 16-बिट या 32-बिट ऑपरेंड हो सकता है।

उदाहरण

segment .data
   count dw  0
   value db  15
	
segment .text
   inc [count]
   dec [value]
	
   mov ebx, count
   inc word [ebx]
	
   mov esi, value
   dec byte [esi]

ADD और SUB निर्देश

ADD और SUB निर्देशों का उपयोग बाइट, वर्ड और डबलवर्ड साइज में बाइनरी डेटा के सरल जोड़ / घटाव को जोड़ने के लिए किया जाता है, अर्थात, क्रमशः 8-बिट, 16-बिट या 32-बिट ऑपरेंड को जोड़ने या घटाने के लिए।

वाक्य - विन्यास

ADD और SUB निर्देशों के निम्नलिखित सिंटैक्स हैं -

ADD/SUB	destination, source

ADD / SUB निर्देश के बीच जगह ले सकता है -

  • रजिस्टर करने के लिए रजिस्टर करें
  • रजिस्टर करने के लिए मेमोरी
  • मेमोरी में रजिस्टर करें
  • निरंतर डेटा पर रजिस्टर करें
  • निरंतर डेटा के लिए मेमोरी

हालाँकि, अन्य निर्देशों की तरह, मेमोरी-टू-मेमोरी ऑपरेशन ADD / SUB निर्देशों का उपयोग करना संभव नहीं है। एक ADD या SUB ऑपरेशन ओवरफ़्लो और फ़्लैग को सेट या साफ़ करता है।

उदाहरण

निम्नलिखित उदाहरण उपयोगकर्ता से दो अंक पूछेगा, क्रमशः EAX और EBX रजिस्टर में अंकों को संग्रहीत करें, मूल्यों को जोड़ें, परिणाम को मेमोरी स्थान ' रेस ' में संग्रहीत करें और अंत में परिणाम प्रदर्शित करें।

SYS_EXIT  equ 1
SYS_READ  equ 3
SYS_WRITE equ 4
STDIN     equ 0
STDOUT    equ 1

segment .data 

   msg1 db "Enter a digit ", 0xA,0xD 
   len1 equ $- msg1 

   msg2 db "Please enter a second digit", 0xA,0xD 
   len2 equ $- msg2 

   msg3 db "The sum is: "
   len3 equ $- msg3

segment .bss

   num1 resb 2 
   num2 resb 2 
   res resb 1    

section	.text
   global _start    ;must be declared for using gcc
	
_start:             ;tell linker entry point
   mov eax, SYS_WRITE         
   mov ebx, STDOUT         
   mov ecx, msg1         
   mov edx, len1 
   int 0x80                

   mov eax, SYS_READ 
   mov ebx, STDIN  
   mov ecx, num1 
   mov edx, 2
   int 0x80            

   mov eax, SYS_WRITE        
   mov ebx, STDOUT         
   mov ecx, msg2          
   mov edx, len2         
   int 0x80

   mov eax, SYS_READ  
   mov ebx, STDIN  
   mov ecx, num2 
   mov edx, 2
   int 0x80        

   mov eax, SYS_WRITE         
   mov ebx, STDOUT         
   mov ecx, msg3          
   mov edx, len3         
   int 0x80

   ; moving the first number to eax register and second number to ebx
   ; and subtracting ascii '0' to convert it into a decimal number
	
   mov eax, [num1]
   sub eax, '0'
	
   mov ebx, [num2]
   sub ebx, '0'

   ; add eax and ebx
   add eax, ebx
   ; add '0' to to convert the sum from decimal to ASCII
   add eax, '0'

   ; storing the sum in memory location res
   mov [res], eax

   ; print the sum 
   mov eax, SYS_WRITE        
   mov ebx, STDOUT
   mov ecx, res         
   mov edx, 1        
   int 0x80

exit:    
   
   mov eax, SYS_EXIT   
   xor ebx, ebx 
   int 0x80

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

Enter a digit:
3
Please enter a second digit:
4
The sum is:
7

The program with hardcoded variables −

section	.text
   global _start    ;must be declared for using gcc
	
_start:             ;tell linker entry point
   mov	eax,'3'
   sub     eax, '0'
	
   mov 	ebx, '4'
   sub     ebx, '0'
   add 	eax, ebx
   add	eax, '0'
	
   mov 	[sum], eax
   mov	ecx,msg	
   mov	edx, len
   mov	ebx,1	;file descriptor (stdout)
   mov	eax,4	;system call number (sys_write)
   int	0x80	;call kernel
	
   mov	ecx,sum
   mov	edx, 1
   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 "The sum is:", 0xA,0xD 
   len equ $ - msg   
   segment .bss
   sum resb 1

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

The sum is:
7

MUL / IMUL निर्देश

बाइनरी डेटा को गुणा करने के दो निर्देश हैं। MUL (Multiply) निर्देश अहस्ताक्षरित डेटा को संभालता है और IMUL (Integer Multiply) हस्ताक्षरित डेटा को संभालता है। दोनों निर्देश कैरी और ओवरफ्लो ध्वज को प्रभावित करते हैं।

वाक्य - विन्यास

MUL / IMUL निर्देशों का सिंटैक्स निम्नानुसार है -

MUL/IMUL multiplier

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

अनु क्रमांक। परिदृश्यों
1

When two bytes are multiplied −

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

2

When two one-word values are multiplied −

गुणक एक्सएक्स रजिस्टर में होना चाहिए, और गुणक स्मृति या किसी अन्य रजिस्टर में एक शब्द है। उदाहरण के लिए, MUL DX जैसे निर्देश के लिए, आपको DX में गुणक और AX में गुणक को संग्रहीत करना होगा।

परिणामी उत्पाद एक डबलवर्ड है, जिसे दो रजिस्टरों की आवश्यकता होगी। उच्च-क्रम (सबसे बाएं) भाग को DX में संग्रहीत किया जाता है और निचले क्रम (सबसे दाएं) भाग को AX में संग्रहीत किया जाता है।

3

When two doubleword values are multiplied −

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

उदाहरण

MOV AL, 10
MOV DL, 25
MUL DL
...
MOV DL, 0FFH	; DL= -1
MOV AL, 0BEH	; AL = -66
IMUL DL

उदाहरण

निम्न उदाहरण 3 को 2 से गुणा करता है, और परिणाम प्रदर्शित करता है -

section	.text
   global _start    ;must be declared for using gcc
	
_start:             ;tell linker entry point

   mov	al,'3'
   sub     al, '0'
	
   mov 	bl, '2'
   sub     bl, '0'
   mul 	bl
   add	al, '0'
	
   mov 	[res], al
   mov	ecx,msg	
   mov	edx, len
   mov	ebx,1	;file descriptor (stdout)
   mov	eax,4	;system call number (sys_write)
   int	0x80	;call kernel
	
   mov	ecx,res
   mov	edx, 1
   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 "The result is:", 0xA,0xD 
len equ $- msg   
segment .bss
res resb 1

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

The result is:
6

DIV / IDIV निर्देश

डिवीजन ऑपरेशन दो तत्वों को उत्पन्न करता है - ए quotient और एक remainder। गुणन के मामले में, अतिप्रवाह नहीं होता है क्योंकि उत्पाद को रखने के लिए डबल-लंबाई रजिस्टरों का उपयोग किया जाता है। हालांकि, विभाजन के मामले में, अतिप्रवाह हो सकता है। यदि अतिप्रवाह होता है तो प्रोसेसर एक अवरोध उत्पन्न करता है।

DIV (डिवाइड) निर्देश का उपयोग अहस्ताक्षरित डेटा के लिए किया जाता है और IDIV (इंटेगर डिवाइड) का उपयोग हस्ताक्षरित डेटा के लिए किया जाता है।

वाक्य - विन्यास

DIV / IDIV निर्देश के लिए प्रारूप -

DIV/IDIV	divisor

लाभांश एक संचायक में है। दोनों निर्देश 8-बिट, 16-बिट या 32-बिट ऑपरेंड के साथ काम कर सकते हैं। ऑपरेशन सभी छह स्थिति ध्वज को प्रभावित करता है। निम्नलिखित अनुभाग विभिन्न ऑपरेंड आकार के साथ विभाजन के तीन मामलों की व्याख्या करता है -

अनु क्रमांक। परिदृश्यों
1

When the divisor is 1 byte −

लाभांश को AX रजिस्टर (16 बिट्स) में माना जाता है। विभाजन के बाद, भागफल AL रजिस्टर में चला जाता है और शेष AH रजिस्टर में चला जाता है।

2

When the divisor is 1 word −

लाभांश को 32 बिट लंबा और DX में माना जाता है: AX रजिस्टर। उच्च-क्रम वाले 16 बिट्स DX में हैं और लो-ऑर्डर 16 बिट्स AX में हैं। विभाजन के बाद, 16-बिट भागफल AX रजिस्टर में जाता है और 16-बिट शेष DX रजिस्टर में जाता है।

3

When the divisor is doubleword −

लाभांश 64 बिट लंबा और EDX में माना जाता है: EAX रजिस्टर। उच्च-क्रम वाले 32 बिट्स EDX में हैं और निम्न-क्रम वाले 32 बिट्स EAX में हैं। विभाजन के बाद, 32-बिट भागफल EAX रजिस्टर में जाता है और 32-बिट शेष EDX रजिस्टर में जाता है।

उदाहरण

निम्न उदाहरण 2 के साथ 8 को विभाजित करता है dividend 8 में संग्रहित है 16-bit AX register और यह divisor 2 में संग्रहित है 8-bit BL register

section	.text
   global _start    ;must be declared for using gcc
	
_start:             ;tell linker entry point
   mov	ax,'8'
   sub     ax, '0'
	
   mov 	bl, '2'
   sub     bl, '0'
   div 	bl
   add	ax, '0'
	
   mov 	[res], ax
   mov	ecx,msg	
   mov	edx, len
   mov	ebx,1	;file descriptor (stdout)
   mov	eax,4	;system call number (sys_write)
   int	0x80	;call kernel
	
   mov	ecx,res
   mov	edx, 1
   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 "The result is:", 0xA,0xD 
len equ $- msg   
segment .bss
res resb 1

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

The result is:
4