विधानसभा - तार्किक निर्देश

प्रोसेसर निर्देश सेट निर्देश और, या, 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