Linux tutorial made for Introduction to Linux - A Hands-on Workshop, a pre FOSSMeet event, 2013
https://www.dropbox.com/s/y3pg4hgij880kib/Linux.pdf
https://www.dropbox.com/s/y3pg4hgij880kib/Linux.pdf
Key Combination
|
Use
|
Ctrl + D
|
Same as exit , exits
or terminates current session
|
Ctrl + C
|
Closes the currently running program in foreground |
Ctrl + Z
|
Suspends the currently running program |
Ctrl + H
|
Same as backspace |
Ctrl + L
|
Clears the terminal Same as clear command |
TAB
|
Predicts and completes a command |
TAB TAB
|
Lists all command completion possibilities. |
section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 matrix1: resw 200 matrix2: resw 200 matrix3: resw 200 m: resw 1 n: resw 1 i: resw 1 j: resw 1 section .text msg1: db "Enter the number of rows in the matrix : " msg_size1: equ $-msg1 msg2: db "Enter the elements one by one(row by row) : " msg_size2: equ $-msg2 msg3: db "Enter the number of columns in the matrix : " msg_size3: equ $-msg3 msg_matrix1: db "First matrix : ", 10 msg_matrix1_size: equ $-msg_matrix1 msg_matrix2: db "Second matrix : ", 10 msg_matrix2_size: equ $-msg_matrix2 msg_matrix3: db "Second matrix : ", 10 msg_matrix3_size: equ $-msg_matrix3 tab: db 9 ;ASCII for vertical tab new_line: db 10 ;ASCII for new line section .text global _start _start: mov eax, 4 mov ebx, 1 mov ecx, msg1 mov edx, msg_size1 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[m], cx mov eax, 4 mov ebx, 1 mov ecx, msg3 mov edx, msg_size3 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[n], cx mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, msg_size2 int 80h ;Reading each element of the matrix........ mov eax, 0 mov ebx, matrix1 mov word[i], 0 mov word[j], 0 i_loop: mov word[j], 0 j_loop: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, msg_size2 int 80h ;Reading each element of the matrix........ mov eax, 0 mov ebx, matrix2 mov word[i], 0 mov word[j], 0 i_loop2: mov word[j], 0 j_loop2: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop2 inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop2 ;Adding the two matrices ie. matrix3 = matrxi1 + matrix2 mov eax, 0 ;Initializing base pointers..... mov ebx, matrix1 mov esi, matrix2 mov edi, matrix3 mov word[i], 0 mov word[j], 0 i_loop3: mov word[j], 0 j_loop3: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx , word[ebx + 2 * eax] add dx, word[esi + 2 * eax] mov word[edi + 2 * eax], dx inc eax ;Incrementing array index by one.... inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop3 inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop3 mov eax, 4 mov ebx, 1 mov ecx, msg_matrix1 mov edx, msg_matrix1_size int 80h ;Printing the matrix1.... mov eax, 0 mov ebx, matrix1 mov word[i], 0 mov word[j], 0 i_loop4: mov word[j], 0 j_loop4: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx, word[ebx + 2 * eax] ; mov word[num] , dx call print_num ;Printing a space after each element..... pusha mov eax, 4 mov ebx, 1 mov ecx, tab mov edx, 1 int 80h popa inc eax inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop4 pusha mov eax, 4 mov ebx, 1 mov ecx, new_line mov edx, 1 int 80h popa inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop4 ;Printing the final matrix2.... mov eax, 4 mov ebx, 1 mov ecx, msg_matrix2 mov edx, msg_matrix2_size int 80h mov eax, 0 mov ebx, matrix2 mov word[i], 0 mov word[j], 0 i_loop5: mov word[j], 0 j_loop5: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx, word[ebx + 2 * eax] ; mov word[num] , dx call print_num ;Printing a space after each element..... pusha mov eax, 4 mov ebx, 1 mov ecx, tab mov edx, 1 int 80h popa inc eax inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop5 pusha mov eax, 4 mov ebx, 1 mov ecx, new_line mov edx, 1 int 80h popa inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop5 ;Printing the final matrix.... mov eax, 4 mov ebx, 1 mov ecx, msg_matrix3 mov edx, msg_matrix3_size int 80h mov eax, 0 mov ebx, matrix3 mov word[i], 0 mov word[j], 0 i_loop6: mov word[j], 0 j_loop6: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx, word[ebx + 2 * eax] ; mov word[num] , dx call print_num ;Printing a space after each element..... pusha mov eax, 4 mov ebx, 1 mov ecx, tab mov edx, 1 int 80h popa inc eax inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop6 pusha mov eax, 4 mov ebx, 1 mov ecx, new_line mov edx, 1 int 80h popa inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop6 ;Exit System Call..... exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number stored in num... print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 matrix1: resw 200 m: resw 1 n: resw 1 i: resw 1 j: resw 1 section .text msg1: db "Enter the number of rows in the matrix : " msg_size1: equ $-msg1 msg2: db "Enter the elements one by one(row by row) : " msg_size2: equ $-msg2 msg3: db "Enter the number of columns in the matrix : " msg_size3: equ $-msg3 tab: db 9 ;ASCII for vertical tab new_line: db 10 ;ASCII for new line section .text global _start _start: mov eax, 4 mov ebx, 1 mov ecx, msg1 mov edx, msg_size1 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[m], cx mov eax, 4 mov ebx, 1 mov ecx, msg3 mov edx, msg_size3 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[n], cx mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, msg_size2 int 80h ;Reading each element of the matrix........ mov eax, 0 mov ebx, matrix1 mov word[i], 0 mov word[j], 0 i_loop: mov word[j], 0 j_loop: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop ;Reading each element of the matrix.(Storing the elements in row major order)....... mov eax, 0 mov ebx, matrix1 mov word[i], 0 mov word[j], 0 i_loop2: mov word[j], 0 j_loop2: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx, word[ebx + 2 * eax] ; mov word[num] , dx call print_num ;Printing a space after each element..... pusha mov eax, 4 mov ebx, 1 mov ecx, tab mov edx, 1 int 80h popa inc eax inc word[j] mov cx, word[j] cmp cx, word[n] jb j_loop2 pusha mov eax, 4 mov ebx, 1 mov ecx, new_line mov edx, 1 int 80h popa inc word[i] mov cx, word[i] cmp cx, word[m] jb i_loop2 ;Exit System Call..... exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number stored in num... print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
;Program to search for an element in an array... section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 array1: resw 50 size1: resw 1 section .text msg1: db "Enter the number of elements in the array : " msg_size1: equ $-msg1 msg2: db "Enter the elements one by one" msg_size2: equ $-msg2 space: db " " msg3: db "Enter the element to be searched : " msg_size3: equ $-msg3 msg_found: db "Element Found..." msg_found_size: equ $-msg_found msg_not_found: db "Element Not Found..." msg_not_found_size: equ $-msg_not_found section .text global _start _start: mov eax, 4 mov ebx, 1 mov ecx, msg1 mov edx, msg_size1 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[size1], cx push ecx mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, msg_size2 int 80h pop ecx ;Array length in ecx, so we can loop to read elements ;Reading the array elements.... mov eax, 0 mov ebx, array1 read_element: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... loop read_element mov eax, 4 mov ebx, 1 mov ecx, msg3 mov edx, msg_size3 int 80h call read_num mov ax, word[num] ;Element to be searched.... ;Searching for the element.... CLD ;Clears the Direction Flag mov edi, array1 ;Copy Base address of array to index registers mov ecx, 10 ;No: of element in the array scan: SCASW je found loop scan ;Code to display element not found.. mov eax, 4 mov ebx, 1 mov ecx, msg_not_found mov edx, msg_not_found_size int 80h jmp exit found: mov eax, 4 mov ebx, 1 mov ecx, msg_found mov edx, msg_found_size int 80h ;Exit System Call..... exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number stored in num... print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
;Program to search for an element in an array... section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 array1: resw 50 size1: resw 1 section .text msg1: db "Enter the number of elements in the array : " msg_size1: equ $-msg1 msg2: db "Enter the elements one by one" msg_size2: equ $-msg2 space: db " " msg3: db "Enter the element to be searched : " msg_size3: equ $-msg3 msg_found: db "Element Found..." msg_found_size: equ $-msg_found msg_not_found: db "Element Not Found..." msg_not_found_size: equ $-msg_not_found section .text global _start _start: mov eax, 4 mov ebx, 1 mov ecx, msg1 mov edx, msg_size1 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[size1], cx push ecx mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, msg_size2 int 80h pop ecx ;Array length in ecx, so we can loop to read elements ;Reading the array elements.... mov eax, 0 mov ebx, array1 read_element: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... loop read_element mov eax, 4 mov ebx, 1 mov ecx, msg3 mov edx, msg_size3 int 80h call read_num mov ax, word[num] ;Element to be searched.... ;Searching for the element.... CLD ;Clears the Direction Flag mov edi, array1 ;Copy Base address of array to index registers mov ecx, 10 ;No: of element in the array scan: SCASW je found loop scan ;Code to display element not found.. mov eax, 4 mov ebx, 1 mov ecx, msg_not_found mov edx, msg_not_found_size int 80h jmp exit found: mov eax, 4 mov ebx, 1 mov ecx, msg_found mov edx, msg_found_size int 80h ;Exit System Call..... exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number stored in num... print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 section .text global _start _start: call read_num call print_num exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 array1: resw 50 size1: resw 1 section .text msg1: db "Enter the number of elements in the array : " siz1: equ $-msg1 msg2: db "Enter the elements one by one" size2: equ $-msg2 space: db " " section .text global _start _start: mov eax, 4 mov ebx, 1 mov ecx, msg1 mov edx, siz1 int 80h mov ecx, 0 call read_num mov cx, word[num] mov word[size1], cx push ecx mov eax, 4 mov ebx, 1 mov ecx, msg2 mov edx, size2 int 80h pop ecx ;Array length in ecx, so we can loop to read elements ;Reading the array elements.... mov eax, 0 mov ebx, array1 read_element: call read_num mov dx , word[num] ;eax will contain the array index and each element is 2 bytes(1 word) long mov word[ebx + 2 * eax], dx inc eax ;Incrementing array index by one.... loop read_element ;Printing the elements..... movzx ecx, word[size1] mov eax, 0 mov ebx, array1 print_element: ;eax will contain the array index and each element is 2 bytes(1 word) long mov dx, word[ebx + 2 * eax] ; mov word[num] , dx call print_num ;Printing a space after each element..... pusha mov eax, 4 mov ebx, 1 mov ecx, space mov edx, 1 int 80h popa inc eax loop print_element ;Exit System Call..... exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number stored in num... print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret
section .bss num: resw 1 ;For storing a number, to be read of printed.... nod: resb 1 ;For storing the number of digits.... temp: resb 2 section .text global _start _start: call read_num call print_num exit: mov eax, 1 mov ebx, 0 int 80h ;Function to read a number from console and to store that in num read_num: pusha mov word[num], 0 loop_read: mov eax, 3 mov ebx, 0 mov ecx, temp mov edx, 1 int 80h cmp byte[temp], 10 je end_read mov ax, word[num] mov bx, 10 mul bx mov bl, byte[temp] sub bl, 30h mov bh, 0 add ax, bx mov word[num], ax jmp loop_read end_read: popa ret ;Function to print any number print_num: pusha extract_no: cmp word[num], 0 je print_no inc byte[nod] mov dx, 0 mov ax, word[num] mov bx, 10 div bx push dx mov word[num], ax jmp extract_no print_no: cmp byte[nod], 0 je end_print dec byte[nod] pop dx mov byte[temp], dl add byte[temp], 30h mov eax, 4 mov ebx, 1 mov ecx, temp mov edx, 1 int 80h jmp print_no end_print: popa ret