विधानसभा - तार्किक निर्देश
प्रोसेसर निर्देश सेट निर्देश और, या, XOR, परीक्षण, और बुलियन तर्क प्रदान नहीं करता है, जो प्रोग्राम की आवश्यकता के अनुसार बिट्स का परीक्षण, सेट और क्लीयर करता है।
इन निर्देशों के लिए प्रारूप -
अनु क्रमांक। | अनुदेश | स्वरूप |
---|---|---|
1 | तथा | और ऑपरेंड 1, ऑपरेंड 2 |
2 | या | OR ऑपरेंड 1, ऑपरेंड 2 |
3 | XOR | XOR operand1, operand2 |
4 | परीक्षा | परीक्षण ऑपरेंड 1, ऑपरेंड 2 |
5 | नहीं | नहीं ऑपरेंड १ |
सभी मामलों में पहला ऑपरेंड या तो रजिस्टर में या मेमोरी में हो सकता है। दूसरा ऑपरेंड या तो रजिस्टर / मेमोरी या एक तत्काल (स्थिर) मान में हो सकता है। हालाँकि, मेमोरी-टू-मेमोरी ऑपरेशन संभव नहीं हैं। ये निर्देश ऑपरेंड के बिट्स की तुलना या मिलान करते हैं और CF, OF, PF, SF और ZF झंडे सेट करते हैं।
और निर्देश
AND निर्देश बिटवाइज़ और ऑपरेशन करके लॉजिकल एक्सप्रेशंस को सपोर्ट करने के लिए उपयोग किया जाता है। बिटवाइज और ऑपरेशन रिटर्न 1, यदि दोनों ऑपरेंड्स से मिलान बिट्स 1 हैं, अन्यथा यह 0. लौटाता है। उदाहरण के लिए -
Operand1: 0101
Operand2: 0011
----------------------------
After AND -> Operand1: 0001
AND ऑपरेशन का उपयोग एक या अधिक बिट्स को साफ़ करने के लिए किया जा सकता है। उदाहरण के लिए, मान लें कि बीएल रजिस्टर में 0011 1010 शामिल हैं। यदि आपको उच्च-क्रम के बिट्स को शून्य करने की आवश्यकता है, तो आपको और एफएफएच के साथ।
AND BL, 0FH ; This sets BL to 0000 1010
चलिए एक और उदाहरण लेते हैं। यदि आप यह जांचना चाहते हैं कि क्या दी गई संख्या विषम है या यहां तक कि, एक साधारण परीक्षण संख्या की कम से कम महत्वपूर्ण बिट की जांच करना होगा। यदि यह 1 है, तो संख्या विषम है, अन्यथा संख्या सम है।
मान लिया गया कि संख्या AL रजिस्टर में है, हम लिख सकते हैं -
AND AL, 01H ; ANDing with 0000 0001
JZ EVEN_NUMBER
निम्नलिखित कार्यक्रम यह दिखाता है -
उदाहरण
section .text
global _start ;must be declared for using gcc
_start: ;tell linker entry point
mov ax, 8h ;getting 8 in the ax
and ax, 1 ;and ax with 1
jz evnn
mov eax, 4 ;system call number (sys_write)
mov ebx, 1 ;file descriptor (stdout)
mov ecx, odd_msg ;message to write
mov edx, len2 ;length of message
int 0x80 ;call kernel
jmp outprog
evnn:
mov ah, 09h
mov eax, 4 ;system call number (sys_write)
mov ebx, 1 ;file descriptor (stdout)
mov ecx, even_msg ;message to write
mov edx, len1 ;length of message
int 0x80 ;call kernel
outprog:
mov eax,1 ;system call number (sys_exit)
int 0x80 ;call kernel
section .data
even_msg db 'Even Number!' ;message showing even number
len1 equ $ - even_msg
odd_msg db 'Odd Number!' ;message showing odd number
len2 equ $ - odd_msg
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Even Number!
कुल्हाड़ी रजिस्टर में एक अजीब अंक के साथ मान बदलें, जैसे -
mov ax, 9h ; getting 9 in the ax
कार्यक्रम प्रदर्शित होगा:
Odd Number!
इसी तरह आप पूरे रजिस्टर को क्लियर कर सकते हैं और 00H के साथ कर सकते हैं।
या निर्देश
OR निर्देश बिटवाइज़ या ऑपरेशन करके तार्किक अभिव्यक्ति का समर्थन करने के लिए उपयोग किया जाता है। बिटवाइज़ या ऑपरेटर 1 लौटाता है, यदि दोनों या दोनों ऑपरेंड से मिलान बिट्स एक हैं। यह 0 देता है, यदि दोनों बिट्स शून्य हैं।
उदाहरण के लिए,
Operand1: 0101
Operand2: 0011
----------------------------
After OR -> Operand1: 0111
OR ऑपरेशन का उपयोग एक या अधिक बिट्स सेट करने के लिए किया जा सकता है। उदाहरण के लिए, मान लें कि AL रजिस्टर में 0011 1010 शामिल है, आपको चार निम्न-क्रम बिट्स सेट करने की आवश्यकता है, आप इसे 0000 1111 मान के साथ या FH कर सकते हैं।
OR BL, 0FH ; This sets BL to 0011 1111
उदाहरण
निम्न उदाहरण OR निर्देश को प्रदर्शित करता है। मान 5 और 3 को एएल और बीएल रजिस्टरों में क्रमशः स्टोर करें, फिर निर्देश,
OR AL, BL
AL रजिस्टर में 7 स्टोर करना चाहिए -
section .text
global _start ;must be declared for using gcc
_start: ;tell linker entry point
mov al, 5 ;getting 5 in the al
mov bl, 3 ;getting 3 in the bl
or al, bl ;or al and bl registers, result should be 7
add al, byte '0' ;converting decimal to ascii
mov [result], al
mov eax, 4
mov ebx, 1
mov ecx, result
mov edx, 1
int 0x80
outprog:
mov eax,1 ;system call number (sys_exit)
int 0x80 ;call kernel
section .bss
result resb 1
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
7
XOR निर्देश
XOR निर्देश बिटवाइज XOR ऑपरेशन को लागू करता है। XOR ऑपरेशन परिणामी बिट को 1 पर सेट करता है, यदि और केवल यदि ऑपरेंड से बिट्स भिन्न हैं। यदि ऑपरेंड से बिट समान हैं (दोनों 0 या दोनों 1), तो परिणामी बिट 0 पर साफ हो जाता है।
उदाहरण के लिए,
Operand1: 0101
Operand2: 0011
----------------------------
After XOR -> Operand1: 0110
XORing एक ऑपरेंड अपने साथ ऑपरेंड को बदल देता है 0। इसका उपयोग किसी रजिस्टर को साफ़ करने के लिए किया जाता है।
XOR EAX, EAX
परीक्षण निर्देश
परीक्षण निर्देश AND और ऑपरेशन के समान ही काम करता है, लेकिन AND निर्देश के विपरीत, यह पहले ऑपरेंड को नहीं बदलता है। इसलिए, अगर हमें यह जांचने की आवश्यकता है कि रजिस्टर में कोई संख्या सम या विषम है, तो हम मूल संख्या को बदले बिना TEST निर्देश का उपयोग करके भी ऐसा कर सकते हैं।
TEST AL, 01H
JZ EVEN_NUMBER
निर्देश नहीं
नहीं अनुदेश बिटवाइज़ नहीं ऑपरेशन को कार्यान्वित करता है। ऑपरेशन एक ऑपरेंड में बिट्स को उलट नहीं करता है। ऑपरेंड या तो एक रजिस्टर में या मेमोरी में हो सकता है।
उदाहरण के लिए,
Operand1: 0101 0011
After NOT -> Operand1: 1010 1100