विधानसभा - अंकगणितीय निर्देश
आईएनसी निर्देश
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