Boolean, Shift and Rotate instructions Dr.Hadi AL Saadi
Boolean,SHIFT and Rotate Instructions AND Instruction OR Instruction XOR Instruction NOT Instruction BT Instruction Applications TEST Instruction SHL,SHR, SAR and SAL instructions ROR,ROL, RCR and RCL instructions
Logic, Shift and Rotate Instructions: AND, OR and XOR instructions: Syntax: AND destination,source OR destination,source XOR destination,source Result stored in destination, which must be: Reg. or memory location source may be: constant, Reg., or Mem. Location. But Mem. not allowed. Effect on Flags: S,Z, and P indicate result, and CF=OF=0, A is undefined
AND Instruction Performs a Boolean AND operation between each pair of matching bits in two operands Syntax: AND destination, source AND
OR Instruction Performs a Boolean OR operation between each pair of matching bits in two operands Syntax: OR destination, source OR
XOR Instruction Performs a Boolean exclusive-OR operation between each pair of matching bits in two operands Syntax: XOR destination, source XOR XOR is a useful way to toggle (invert) the bits in an operand.
NOT Instruction Performs a Boolean NOT operation on a single destination operand Syntax: NOT destination NOT
Bit-Mapped Sets Binary bits indicate set membership Efficient use of storage Also known as bit vectors
Bit-Mapped Set Operations Set Complement mov ax,SetX not ax Set Intersection mov ax,setX and ax,setY Set Union mov ax,setX or ax,setY Selectivity modify bits in destination, by constructing a source bit pattern (MASK), by masking use of their properties, thus 1. AND Inst. Clear specific bit (0 mask), while keep others (1 mask) 2. OR Inst. Set specific bits (1 mask), while keep others ( 0 mask) 3. XOR inst. Complement specific bits (1 mask), while keep others ( 0 mask)
mov al,'a'; AL = b and al, b; AL = b Task: Convert the character in AL to upper case. Solution: Use the AND instruction to clear bit 5. Applications mov al,6; AL = b or al, b; AL = b Task: Convert a binary decimal byte into its equivalent ASCII decimal digit. Solution: Use the OR instruction to set bits 4 and 5. The ASCII digit '6' = b
Task: Jump to label L1 if bits 0, 1, and 3 in AL are all set. Solution: Clear all bits except bits 0, 1,and 3. Then compare the result with binary. and al, b; clear unwanted bits cmp al, b; check remaining bits je L1; all set? jump to L1 Task: Jump to a label if an integer is even. Solution: AND the lowest bit with a 1. If the result is Zero, the number was even. mov ax,wordVal and ax,1; low bit set? jz EvenValue; jump if Zero flag set Applications
or al,al jnz IsNotZero; jump if not zero Task: Jump to a label if the value in AL is not zero. Solution: OR the byte with itself, then use the JNZ (jump if not zero) instruction. Applications and al, b; clear unwanted bits cmp al, b; check remaining bits je L1; all set? jump to L1 Task: Jump to label L1 if bits 0, 1, and 3 in AL are all set. Solution: Clear all bits except bits 0, 1,and 3. Then compare the result with binary.
mov ah,1 Int 21h ; get character in ; AL cmp al,'0'; ZF = 0 jb ID1 cmp al,'9'; ZF = 0 ja ID1 test ax,0 ; ZF = 1 ID1: Write a code to receives a character in AL. Sets the Zero flag if the character is a decimal digit.
Your turn... Write code that jumps to label L1 if either bit 4, 5, or 6 is set in the BL register. Write code that jumps to label L1 if bits 4, 5, and 6 are all set in the BL register. Write code that jumps to label L2 if AL has even parity. Write code that jumps to label L3 if AX is negative. Write code that jumps to label L4 if the expression (BX – CX) is greater than zero.
TEST Instruction Performs a nondestructive AND operation between each pair of matching bits in two operands Effect on Flags: S,Z, P reflect the result, CF=OF, and AF unchanged Syntax : TEST destination, source TEST instruction can be used to examine individual bits in operand, thus the MASK must contain 1’s at tested bit – positions, and 0’s elsewhere test al, b jnz ValueFound Example: jump to a label if neither bit 0 nor bit 1 in AL is set. test al, b jz ValueNotFound Example: Jump to label BELLOW if AL contains even number, Solution : even number have 0 in 1sb, thus MASK= b=1d TEST AL,1 ; is an even ? JZ BELLOW ; yes, go to BELLOW
Encrypting a String KEY = 239; can be any byte value BUFMAX = 128.data buffer BYTE BUFMAX+1 DUP(0) bufSize DWORD BUFMAX.code mov ecx,bufSize; loop counter mov esi,0; index 0 in buffer L1: xor buffer[esi],KEY; translate a byte inc esi; point to next byte loop L1 The following loop uses the XOR instruction to transform every character in a string into a new value.
String Encryption Program Tasks: Input a message (string) from the user Encrypt the message Display the encrypted message Decrypt the message Display the decrypted message Enter the plain text: Attack at dawn. Cipher text: «¢¢Äîä-Ä¢-ïÄÿü-Gs Decrypted: Attack at dawn.
BT (Bit Test) Instruction Copies bit n from an operand into the Carry flag Syntax: BT bitBase, n bitBase may be r/m16 or r/m32 n may be r16, r32, or imm8 Example: jump to label L1 if bit 9 is set in the AX register: bt AX,9; CF = bit 9 jc L1; jump if Carry
Shift and Rotate Instructions Logical vs Arithmetic Shifts SHL Instruction SHR Instruction SAL and SAR Instructions ROL Instruction ROR Instruction RCL and RCR Instructions
SHIFT and Rotate Instruction: Shift and Rotate instructions, shift Bits in destination by 1 or more bit-position, either to Left or to Right. Shift inst. : bit-shifted out are lost. Rotate Inst. Bits Shifted-out from one-end Re-input at the other-end There are two possible forms: Opcode destination,1 ;single shift or Rotate Opcode destination,CL; CL contain number (N) of bit-positions to be Shifted destination is 8 or 16 bit Reg. or Memory location.
Logical Shift A logical shift fills the newly created bit position with zero:
Arithmetic Shift An arithmetic shift fills the newly created bit position with a copy of the number’s sign bit:
SHL Instruction The SHL (shift left) instruction performs a logical left shift on the destination operand, filling the lowest bit with 0. Operand types for SHL: SHL reg,imm8 SHL mem,imm8 SHL reg,CL SHL mem,CL (Same for all shift and rotate instructions)
Fast Multiplication mov dl,5 shl dl,1 Shifting left 1 bit multiplies a number by 2 mov dl,5 shl dl,2; DL = 20 Shifting left n bits multiplies the operand by 2 n For example, 5 * 2 2 = 20
SHR Instruction The SHR (shift right) instruction performs a logical right shift on the destination operand. The highest bit position is filled with a zero. mov dl,80 shr dl,1; DL = 40 shr dl,2; DL = 10 Shifting right n bits divides the operand by 2 n
SAL and SAR Instructions SAL (shift arithmetic left) is identical to SHL. SAR (shift arithmetic right) performs a right arithmetic shift on the destination operand. An arithmetic shift preserves the number's sign. mov dl,-80 sar dl,1; DL = -40 sar dl,2; DL = -10
Example: if AX=FFFFh =-1d then SAL 3-times MOV CL,3 SAL AL,CL makes AX=FFF8=-8 Overflow may occur, then; Flags : OF (signed), and CF (unsigned) indicate result of last shift. Example: If DH=8A h, CL=2, what is the value of DH, CF after: SHR DH, CL? Solution :initial DH= then DH= b=22h CF=1 Example: use Right Shift to divide unsigned number by 4, put result in AX. MOV AX, ; AX has the number MOV CL,2 SHR AX, CL ; divide by 4
Your turn... mov al,6Bh shr al,1a. shl al,3b. mov al,8Ch sar al,1c. sar al,3d. Indicate the hexadecimal value of AL after each shift: 35h A8h C6h F8h
ROL Instruction ROL (rotate) shifts each bit to the left The highest bit is copied into both the Carry flag and into the lowest bit No bits are lost mov al, b rol al,1; AL = b mov dl,3Fh rol dl,4; DL = F3h
ROR Instruction ROR (rotate right) shifts each bit to the right The lowest bit is copied into both the Carry flag and into the highest bit No bits are lost mov al, b ror al,1; AL = b mov dl,3Fh ror dl,4; DL = F3h
Your turn... mov al,6Bh ror al,1a. rol al,3b. Indicate the hexadecimal value of AL after each rotation: B5h ADh
Example: show how to inspect bits in a Byte or Word, without changing their contents. Use ROL to count the number of 1-bits in BX without changing BX, put the answer in AX. solution: XOR AX, AX ; AX counts bit MOV CX,16 ; loop control count TOP: ROL BX,1 ; CF contain bit rotated - out JNC NEXT ; is 0-bit (no carry) INC AX ; is 1-bit (carry), increment counter NEXT: LOOP TOP ; loop until completed
RCL Instruction RCL (rotate carry left) shifts each bit to the left Copies the Carry flag to the least significant bit Copies the most significant bit to the Carry flag clc; CF = 0 mov bl,88h; CF,BL = b rcl bl,1; CF,BL = b rcl bl,1; CF,BL = b
RCR Instruction RCR (rotate carry right) shifts each bit to the right Copies the Carry flag to the most significant bit Copies the least significant bit to the Carry flag stc; CF = 1 mov ah,10h; CF,AH = b rcr ah,1; CF,AH = b
Your turn... stc mov al,6Bh rcr al,1a. rcl al,3b. Indicate the hexadecimal value of AL after each rotation: B5h AEh
Application of Shift and Rotate Instructions : Reversing Bit pattern in a BYTE or Word. If AL= , we want to make it = Initialize CX to LOOP_Count MOV CX,8 ; number of reverse operations to do REVERSE: SHL AL,1 ; get bit into CF RCR BL,1 ; rotate it into BL LOOP REVERSE ; loop until done MOV AL,BL ; AL gets reverse pattern
Binary Multiplication mutiply 123 * 36
Binary Multiplication We already know that SHL performs unsigned multiplication efficiently when the multiplier is a power of 2. You can factor any binary number into powers of 2. For example, to multiply AX * 36, factor 36 into and use the distributive property of multiplication to carry out the operation: AX * 36 = AX * (32 + 4) = (AX * 32)+(AX * 4) mov ax,123 mov bx,ax shl ax,5; mult by 2 5 shl bx,2; mult by 2 2 add ax,bx
Your turn... mov ax,2; test value mov dx,ax shl dx,4; AX * 16 push edx; save for later mov dx,ax shl dx,3; AX * 8 shl ax,1; AX * 2 add ax,dx; AX * 10 pop edx; recall AX * 16 add ax,dx; AX * 26 Multiply AX by 26, using shifting and addition instructions. Hint: 26 =
Displaying Binary Bits Algorithm: Shift MSB into the Carry flag; If CF = 1, append a "1" character to a string; otherwise, append a "0" character. Repeat in a loop, 32 times..data buffer BYTE 32 DUP(0),0.code mov cx,32 LEA si, buffer L1:shl ax,1 mov [si],'0' jnc L2 mov [si],'1' L2:inc si loop L1
Isolating a Bit String The MS-DOS file date field packs the year, month, and day into 16 bits: mov ax,dx; make a copy of DX shr ax,5; shift right 5 bits and al, b; clear bits 4-7 mov month,al; save in month variable Isolate the Month field: