Part 10: Procedures and Recursion used in Assembly  Language

Assembly Language | 0 comments

Procedures and Recursion used in Assembly  Language:

By nature in Assembly there is an inclination towards to be big size of Assembly program.  Also there is some way to keep remain in smaller in code size by subroutines or procedures. The article is concerned with the procedures and its various kind of implementation with example.

Procedures in Assembly

Assembly language programs intend to be large in size. Procedures or subroutines are very vital in assembly language which are identified by a name. Following this name, the body of the procedure is defined which accomplishes a well-defined job. End of the procedure is indicated by a return statement.

Syntax

proc_name:

   procedure body

   ...

   ret

The procedure is called from another function by using the CALL instruction. The CALL instruction should have the name of the called procedure as an argument as shown below:

CALL proc_name

The called procedure returns the control to the calling procedure by using the RET instruction.

Example:  Write a very simple procedure named sum that adds the variables stored in the ECX and EDX register and returns the sum in the EAX register.

section .text

   global _start        ;must be declared for using gcc               

_start:                   ;tell linker entry point

   mov    ecx,'4'

   sub     ecx, '0'               

   mov    edx, '5'

   sub     edx, '0'               

   call    sum          ;call sum procedure

   mov    [res], 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, 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

sum:

   mov     eax, ecx

   add     eax, edx

   add     eax, '0'

   ret               

section .data

msg db "The sum is:", 0xA,0xD

len equ $- msg  

segment .bss

res resb 1

OUTPUT:

The sum is:
9

Stacks Data Structure

A stack is an array-like data structure in the memory in which data can be stored and removed from a location called the ‘top’ of the stack. The data desires to be stored is ‘pushed’ into the stack and data to be retrieved is ‘popped’ out from the stack in LIFO structure. So, the data stored first is retrieved last. Assembly language provides two instructions for stack operations: PUSH and POP. These instructions have syntaxes like:

PUSH    operand

POP     address/register

The memory space used in the stack segment is used for implementing stack. The registers SS and ESP (or SP) are used for implementing the stack. The top of the stack, which points to the last data item injected into the stack is pointed to by the SS: ESP register, where the SS register points to the opening of the stack segment and the SP (or ESP) gives the offset into the stack segment. The stack implementation has the following characteristics:

Only words or doublewords could be saved into the stack, not a byte. The stack grows in the reverse direction. For example, toward the lower memory address. The top of the stack points to the last item inserted in the stack; it points to the lower byte of the last word inserted. For storing the values of the registers in the stack before using them for some use; it can be done in following way:

; Save the AX and BX registers in the stack

PUSH    AX

PUSH    BX

; Use the registers for other purpose

MOV     AX, VALUE1

MOV      BX, VALUE2

...

MOV      VALUE1, AX

MOV     VALUE2, BX

; Restore the original values

POP       BX

POP       AX

 

Example

The following program displays the entire ASCII character set. The main program calls a procedure named display, which displays the ASCII character set.

section .text

   global _start        ;must be declared for using gcc            

_start:                   ;tell linker entry point

   call    display

   mov    eax,1             ;system call number (sys_exit)

   int       0x80               ;call kernel

display:

   mov    ecx, 256               

next:

   push    ecx

   mov     eax, 4

   mov     ebx, 1

   mov     ecx, achar

   mov     edx, 1

   int     80h         

   pop     ecx       

   mov    dx, [achar]

   cmp    byte [achar], 0dh

   inc       byte [achar]

   loop    next

   ret      

section .data

achar db '0'

OUTPUT:

0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}

Recursion in Assembly

A recursive procedure is one that calls itself. There are two types of recursion:

  • direct and
  • indirect

In direct recursion, the procedure calls itself and in indirect recursion, the first procedure calls a second procedure, which in turn calls the first procedure. Recursion could be observed in numerous mathematical algorithms. For instance, suppose the case of calculating the factorial of a number. Factorial of a number is given by the equation:

Fact (n) = n * fact (n-1) for n > 0

For instance: factorial of 5 is 1 x 2 x 3 x 4 x 5 = 5 x factorial of 4 and this can be a good instance of showing a recursive procedure. Every recursive algorithm must have an ending condition. In the case of factorial algorithm, the end condition is reached when n is 0.

Example: The following program shows how factorial n is implemented in assembly language. To keep the program simple, we will calculate factorial 3.

section .text

   global _start         ;must be declared for using gcc           

_start:                  ;tell linker entry point

   mov bx, 3             ;for calculating factorial 3

   call  proc_fact

   add   ax, 30h

   mov  [fact], ax   

   mov      edx,len        ;message length

   mov      ecx,msg        ;message to write

   mov      ebx,1          ;file descriptor (stdout)

   mov      eax,4          ;system call number (sys_write)

   int         0x80           ;call kernel

   mov   edx,1            ;message length

   mov      ecx,fact       ;message to write

   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 

proc_fact:

   cmp   bl, 1

   jg    do_calculation

   mov   ax, 1

   ret      

do_calculation:

   dec   bl

   call  proc_fact

   inc   bl

   mul   bl        ;ax = al * bl

   ret

section .data

msg db 'Factorial 3 is:',0xa           

len equ $ - msg

section .bss

fact resb 1

OUTPUT:

Factorial 3 is:

6

Chapter 4 Relational Algebra

Relational Algebra The part of mathematics in which letters and other general symbols are used to represent numbers and quantities in formula and equations. Ex: (x + y) · z = (x · z) + (y · z). The main application of relational algebra is providing a theoretical...

Chapter 3 Components of the Database System Environment

Components of the Database System Environment There are five major components in the database system environment and their interrelationships are. Hardware Software Data Users Procedures Hardware:  The hardware is the actual computer system used for keeping and...

Chapter 2: Database Languages and their information

Database Languages A DBMS must provide appropriate languages and interfaces for each category of users to express database queries and updates. Database Languages are used to create and maintain database on computer. There are large numbers of database languages like...

Database basic overview

What is DBMS? A Database Management System (DBMS) is a collection of interrelated data and a set of programs to access those data. Database management systems (DBMS) are computer software applications that interact with the user, other applications, and the database...

Laravel – Scopes (3 Easy Steps)

Scoping is one of the superpowers that eloquent grants to developers when querying a model. Scopes allow developers to add constraints to queries for a given model. In simple terms laravel scope is just a query, a query to make the code shorter and faster. We can...

CAMBRIDGE IELTS 17 TEST 3

READING PASSAGE 1: The thylacine Q1. carnivorous keywords: Looked like a dog had series of stripes ate, diet ate an entirely 1 .......................................... diet (2nd paragraph 3rd and 4th line) 1st and 2nd paragraph, 1st  paragraph,resemblance to a...

You may find interest following article

Chapter 4 Relational Algebra

Relational Algebra The part of mathematics in which letters and other general symbols are used to represent numbers and quantities in formula and equations. Ex: (x + y) · z = (x · z) + (y · z). The main application of relational algebra is providing a theoretical foundation for relational databases, particularly query languages for such databases. Relational algebra...

Chapter 3 Components of the Database System Environment

Components of the Database System Environment There are five major components in the database system environment and their interrelationships are. Hardware Software Data Users Procedures Hardware:  The hardware is the actual computer system used for keeping and accessing the database. Conventional DBMS hardware consists of secondary storage devices, usually...

Chapter 2: Database Languages and their information

Database Languages A DBMS must provide appropriate languages and interfaces for each category of users to express database queries and updates. Database Languages are used to create and maintain database on computer. There are large numbers of database languages like Oracle, MySQL, MS Access, dBase, FoxPro etc. Database Languages: Refers to the languages used to...

Database basic overview

What is DBMS? A Database Management System (DBMS) is a collection of interrelated data and a set of programs to access those data. Database management systems (DBMS) are computer software applications that interact with the user, other applications, and the database itself to capture and analyze data. Purpose of Database Systems The collection of data, usually...

Laravel – Scopes (3 Easy Steps)

Scoping is one of the superpowers that eloquent grants to developers when querying a model. Scopes allow developers to add constraints to queries for a given model. In simple terms laravel scope is just a query, a query to make the code shorter and faster. We can create custom query with relation or anything with scopes. In any admin project we need to get data...

CAMBRIDGE IELTS 17 TEST 3

READING PASSAGE 1: The thylacine Q1. carnivorous keywords: Looked like a dog had series of stripes ate, diet ate an entirely 1 .......................................... diet (2nd paragraph 3rd and 4th line) 1st and 2nd paragraph, 1st  paragraph,resemblance to a dog. … dark brown stripes over its back, beginning at the rear of the body and extending onto the...

CAMBRIDGE IELTS 17 TEST 4

PASSAGE 1 Q1 (False) (Many Madagascan forests are being destroyed by attacks from insects.) Madagascar's forests are being converted to agricultural land at a rate of one percent every year. Much of this destruction is fuelled by the cultivation of the country's main staple crop: rice. And a key reason for this destruction is that insect pests are destroying vast...

Cambridge IELTS 16 Test 4

Here we will discuss pros and cons of all the questions of the passage with step by step Solution included Tips and Strategies. Reading Passage 1 –Roman Tunnels IELTS Cambridge 16, Test 4, Academic Reading Module, Reading Passage 1 Questions 1-6. Label the diagrams below. The Persian Qanat Method 1. ………………………. to direct the tunnelingAnswer: posts – First...

Cambridge IELTS 16 Test 3

Reading Passage 1: Roman Shipbuilding and Navigation, Solution with Answer Key , Reading Passage 1: Roman Shipbuilding and Navigation IELTS Cambridge 16, Test 3, Academic Reading Module Cambridge IELTS 16, Test 3: Reading Passage 1 – Roman Shipbuilding and Navigation with Answer Key. Here we will discuss pros and cons of all the questions of the...

Cambridge IELTS 16 Test 2

Reading Passage 1: The White Horse of Uffington, Solution with Answer Key The White Horse of Uffington IELTS Cambridge 16, Test 2, Academic Reading Module, Reading Passage 1 Cambridge IELTS 16, Test 2: Reading Passage 1 – The White Horse of Uffington  with Answer Key. Here we will discuss pros and cons of all the questions of the passage with...

Cambridge IELTS 16 Test 1

Cambridge IELTS 16, Test 1, Reading Passage 1: Why We Need to Protect Bolar Bears, Solution with Answer Key Cambridge IELTS 16, Test 1: Reading Passage 1 – Why We Need to Protect Bolar Bears with Answer Key. Here we will discuss pros and cons of all the questions of the passage with step by step...

Cambridge IELTS 15 Reading Test 4 Answers

PASSAGE 1: THE RETURN OF THE HUARANGO QUESTIONS 1-5: COMPLETE THE NOTES BELOW. 1. Answer: water Key words:  access, deep, surface Paragraph 2 provides information on the role of the huarango tree: “it could reach deep water sources”. So the answer is ‘water’. access = reach Answer: water. 2. Answer: diet Key words: crucial,...

Cambridge IELTS 15 Reading Test 3 Answers

PASSAGE 1: HENRY MOORE (1898 – 1986 ) QUESTIONS 1-7: DO THE FOLLOWING STATEMENTS AGREE WITH THE INFORMATION GIVEN IN READING PASSAGE 1? 1. Answer: TRUE Key words: leaving school, Moore, did, father, wanted It is mentioned in the first paragraph that “After leaving school, Moore hoped to become a sculptor, but instead he complied with his father’s...

Cambridge IELTS 15 Reading Test 2 Answers 

PASSAGE 1: COULD URBAN ENGINEERS LEARN FROM DANCE ?  QUESTIONS 1- 6: READING PASSAGE 1 HAS SEVEN PARAGRAPHS, A-G. 1. Answer: B Key words: way of using dance, not proposing By using the skimming and scanning technique, we would find that before going into details about how engineers can learn from dance, the author first briefly mentions ways of...

Cambridge IELTS 15 Reading Test 1 Answers

PASSAGE 1: NUTMEG – A VALUABLE SPICE QUESTIONS 1- 4: COMPLETE THE NOTES BELOW.CHOOSE ONE WORD ONLY FROM THE PASSAGE FOR EACH ANSWER.WRITE YOUR ANSWER IN BOXES 1-8 ON YOUR ANSWER SHEET. 1. Answer: oval Key words: leaves, shape Using the scanning skill, we can see that the first paragraph describes the characteristics of the tree in detail, including...

CAMBRIDGE IELTS 14 READING TEST 4 ANSWERS 

PASSAGE 1: THE SECRET OF STAYING YOUNG QUESTIONS 1-8: COMPLETE THE NOTES BELOW. 1. ANSWER: FOUR / 4 Explain– Key words: focused age groups, ants– In paragraph 3, it is stated that “Giraldo focused on ants at four age ranges”,so the answer must be “four/4”. 2. ANSWER: YOUNG Explain– Key words: how well, ants, looked after– The first sentence of...

CAMBRIDGE IELTS 14 READING TEST 3 ANSWERS

PASSAGE 1: THE CONCEPT OF INTELLIGENCE QUESTIONS 1-3: READING PASSAGE 1 HAS SIX PARAGRAPHS, A-F. 1. ANSWER: B Explain ·     Key words: non-scientists, assumptions, intelligence, influence, behavior ·    People‟s behavior towards others‟ intelligence is mentioned in the first sentence of paragraph B: “implicit theories of...

CAMBRIDGE IELTS 14 READING TEST 2 ANSWERS

Cambridge IELTS 14 is the latest IELTS exam preparation.https://draftsbook.com/ will help you to answer all questions in cambridge ielts 14 reading test 2 with detail explanations. PASSAGE 1: ALEXANDER HENDERSON (1831-1913) QUESTIONS 1-8: DO THE FOLLOWING STATEMENTS AGREE WITH THE INFORMATION GIVEN IN READING PASSAGE 1? 1. ANSWER: FALSE Explain Henderson rarely...

Cambridge IELTS 14 Reading Test 1 Answers

Cambridge IELTS 14 is the latest IELTS exam preparation.https://draftsbook.com/ will help you to answer all questions in cambridge ielts 14 reading test 1 with detail explanations. PASSAGE 1: THE IMPORTANCE OF CHILDREN’S PLAY QUESTIONS 1-8: COMPLETE THE NOTES BELOW. 1. ANSWER: CREATIVITY Explain building a “magical kingdom” may help develop … – Key words: magical...

Cambridge IELTS 13 Reading Test 4 Answers 

PASSAGE 1: CUTTY SARK: THE FASTEST SAILING SHIP OF ALL TIME QUESTIONS 1-8: DO THE FOLLOWING STATEMENTS AGREE WITH THE INFORMATION GIVEN IN READING PASSAGE 1? 1. CLIPPERS WERE ORIGINALLY INTENDED TO BE USED AS PASSENGER SHIPS Key words: clippers, originally, passengerAt the beginning of paragraph 2, we find the statement: “The fastest commercial sailing...