Friday, 16 February 2018


CENG 222 – Computer Organization
Lab Work 3

Special Register: FLAGS

The flags register is unlike the other registers on the microprocessor. The other registers hold eight or 16 bit values. The flags register is simply a collection of one bit values which help determine the current state of the processor. Although the flags register is 16 bits wide, some of them are used. Of these flags, four flags you use all the time: zero, carry, sign, and overflow. These flags are the 8086 condition codes. The flags register appears below:
Zero flag bit is set when last instruction produces 0 as a result.
Carry flag bit is set when last instruction produces a number with a carry.
Sign flag bit is set when last instruction produces a negative number.
Overflow flag bit is set when last instruction produces a number which cannot fit in register.

Flag bits are generally used for testing the conditions. For example, if you want to test whether A = B, you need to subtract A from B, then if you have a result 0, zero flag will be set. Therefore, you need to check zero flag to obtain the result of the condition.

Arithmetic operations

Some of the arithmetic operations that are supported by Intel microprocessors are:
ADD, ADC, INC, DEC, SUB, MUL, IMUL, DIV, IDIV

ADD <destination>, <addend>                    ; destination = destination + addend

ADD instruction adds <addend> to <destination>.

ADD ax, bx                ; ax = ax + bx
ADD var, 2                 ; var = var + 2
ADD al, cl                   ; al = al + cl

ADC <destination>, <addend>                    ; destination = destination + addend + C

ADC instruction adds <addend> + Carry to <destination>. It is used to add large sized numbers.
Let AX:BX be 32 bits number. Let CX:DX be another 32 bits number. In order to add these numbers together using 16-bits microprocessor, we need to use ADC.

ADD BX, DX                        ; Add low order digits
ADC AX, CX             ; Add high order digits together with carry

The instructions above simply calculates: (AX:BX) = (AX:BX) + (CX:DX)

INC <destination>                                         ; destination = destination + 1;
DEC <destination>                                       ; destination = destination - 1;

INC instruction increments and DEC instruction decrements the destination.

INC dx
DEX al
INC var


SUB <destination>, <subtrahend>              ; destination = destination – subtrahend

SUB instruction subtracts <subtrahend> from <destination>.

SUB var, 2                  ; var = var - 2;
SUB bl, cl                   ; bl = bl – cl;
SUB bx, ax                 ; bx = bx – ax;

MUL <multiplicand>

MUL instruction multiplies AX or AL register by <multiplicand>. Destination is AX and DX. If <multiplicand> is an 8-bits number, it will be multiplied by AL. The destination is AX. If <multiplicand> is a 16-bits number, it will be multiplied by AX. The destination is (DX:AX). Here are some examples to make it clear:

MUL DL                     ; AX = AL * DL
MUL BX                    ; (DX:AX) = AX * BX
MUL var                     ; AX = AL * var         (Assuming var is a byte)
MUL var                     ; (DX:AX) = AX * var           (Assuming var is a word)

IMUL is the same as MUL, but it is used for signed numbers which are stored in 2’s complement format.

DIV <divisor>

DIV instruction divides AX or (DX:AX) by <divisor>.
If <divisor> is an 8-bits number,
            AL = AX / <divisor>
            AH = AX mod <divisor>
If <divisor> is a 16-bits number,
            AX = (DX:AX) / <divisor>
            DX = (DX:AX) mod <divisor>


Here is piece of code for division.

MOV AX, 1000
MOV DL, 30
DIV DL

The code above divides 1000 by 30. The quotient (33) will be in AL. The remainder (10) will be in AH. If the number is in <divisor> is too small or zero, the quotient will be too large to fit in AL. Therefore you need to select the registers according to their sizes. For example if you want to divide 1000 by 3, you will get 333 as a quotient which cannot be stored in 8-bits register AL! In order to do this, you need to use 16-bits division. Here is how:

MOV AX, 1000          ; The number is 1000.
MOV DX, 0                ; DX = 0, so (DX:AX) is 0000:1000 = 1000.
MOV BX, 3                ; Divisor is 3
DIV BX                      ; AX = (DX:AX) / 3 = 1000 / 3 = 333. AX is capable to store 333.
                                    ; DX = (DX:AX) mod 3 = 1000 mod 3 = 1.

IDIV is the same as DIV, but it is used for signed numbers which are stored in 2’s complement format.

EXPERIMENTS Advanced Arithmetic Operations
I) Write assembly program to do the following substractions.For each value, what is the hexadecimal result? What is the decimal result? Investigate Carry and Sign and Zero Bits.
  • 01h – 01h
  • 00h + 00h
  • 265Ch - 1AFFh.
  • 0000h - 0001h

II)  Write assembly programs to find the sum of the following hexadecimal numbers. For each summation answer following questions. Does the result fit in a 16 bit register? Why? Investigate the Carry and sign bits.
  • 0Fh + 01h
  • FFFFh + 0001h
  • 0FAAh + 1B04h +  F0A0h.

III) Write assembly programs to do the following computations. Chose registers according to the data and state how the resulting number is represented.
  • 03h * 05h
  • A1A1h * 00F0h
  • (A5C4h * 0040h) + 00FFh
  • (A5C4h / 0004h) – 0A0Ah
  • 02h * AAh * F2h




CENG 222 – Computer Organization
Lab Work 2

Arithmetic operations

Some of the arithmetic operations that are supported by Intel microprocessors are:
ADD, ADC, INC, DEC, SUB, MUL, IMUL, DIV, IDIV

ADD <destination>, <addend>                    ; destination = destination + addend

ADD instruction adds <addend> to <destination>.

ADD ax, bx                ; ax = ax + bx
ADD var, 2                 ; var = var + 2
ADD al, cl                   ; al = al + cl

INC <destination>                                         ; destination = destination + 1;
DEC <destination>                                       ; destination = destination - 1;

INC instruction increments and DEC instruction decrements the destination.

INC dx
DEX al
INC var


SUB <destination>, <subtrahend>              ; destination = destination – subtrahend

SUB instruction subtracts <subtrahend> from <destination>.

SUB var, 2                  ; var = var - 2;
SUB bl, cl                   ; bl = bl – cl;
SUB bx, ax                 ; bx = bx – ax;

EXP1 – Direct Addressing and Arithmetic Operations

1.      Convert your year of birth to a hexadecimal number and store write it to memory address 0200h. Is 1 byte enough to store the number? Why/why not? Do the writing to memory accordingly.
2.      Get the last 4 digits of your student number and write it to next memory address. Consider which memory address you should be using according to the answer of the first question.
3.      Find the sum of these two numbers. Store the result in register DX.
4.      Subtract first number from second store the result in register CX.

EXP2 – Indirect Addressing and Arithmetic Operations

1.      Store 50 (decimal) in memory address 0300h, this time use indirect addressing (access with [BX] ). Is 1 byte enough to store the number? Why/why not? Do the writing to memory accordingly.
2.      Store 51  in next address. Consider which memory address you should be using according to the answer of the first question.
3.      Store 52  in next address.
4.      Find the sum of 3 numbers. Store the result in the next adress.

EXP3 – Advanced Data Transfer

Analyze the assembly code below:

title Register test program

.model small
.stack 100h
.data
msg db "AB",0dh,0ah,'$'

.code
main proc
     mov ax,@data
     mov ds,ax

; Add your code here
; ------------------

; ------------------

     mov ah,9
     mov dx,offset msg
     int 21h

     mov ax, 4c00h
     int 21h
main endp

end main

The program above prints “AB” to the console. The message “AB” is stored at msg in data segment. Therefore, “offset msg” is the starting address of the string. Modify the code according to the following experiments (Try both MOV and LEA commands) :

1-      Copy the second byte stored at “msg” (which is ‘B’ currently) to the first byte. The output should be “BB”. In order to do that, load 2-bytes data stored at “msg” into a 16-bits register. Copy one part of the register to the other part. Then, write your register back to msg.
2-      Copy the first byte stored at “msg” (which is ‘A’ currently) to the second byte. The output should be “AA”. To achieve this, load the first byte stored at “msg” into one 8-bits register (high or low part) and copy it onto the other part and write the data stored in register back to msg.
3-      Load the data stored at “msg” into one register and swap the high and low parts of the register using a temporary 8-bits register. Then write back your “swapped” register onto msg. The output should be “BA”.

Advanced usage of MOV in MASM


Previously we used “offset” to point a memory location, but MASM supports a more user friendly way. As explained in previous lab, MASM does not support a moving operation to a memory location directly pointed by an immediate data but actually, currently used Intel microprocessors support it! Fortunately, some advanced usage of MOV instructions in MASM make it possible. Analyze the source and assembled code below:

Source Code
Assembled code
title Register test program

.model small
.stack 100h
.data
msg db "AB",0dh,0ah,'$'

.code
main proc
       mov ax,@data
       mov ds,ax

       mov al,msg
       mov msg+1,al

       mov ah,9
       mov dx,offset msg
       int 21h

       mov ax, 4c00h
       int 21h
main endp

end main









3BA6:0000 B8A73B    MOV AX,3BA7
3BA6:0003 8ED8      MOV DS,AX

3BA6:0005 A00800    MOV AL,BYTE PTR [0008]
3BA6:0008 A20900    MOV BYTE PTR [0009],AL

3BA6:000B B409      MOV AH,09
3BA6:000D BA0800    MOV DX,0008
3BA6:0010 CD21      INT 21

3BA6:0012 B8004C    MOV AX,4C00
3BA6:0015 CD21      INT  21

Since “msg” is defined in data segment, if we use it without “offset”, it denotes the data pointed by msg (not the address of it). As we can see in the assembled code the address is inside [] brackets. ([0008]). Note that if we use “msg+1”, it means that the data stored in the memory location msg+1 that is [0009]. Here it is clear that MASM automatically calculates offsets and uses [] to point the data.
You can choose to use “offset” and denote pointer operations by yourself or use MASM to interpret the instructions. It is important to learn the usage of offset in order to understand how the operation is done exactly. Please do not go any further without understanding the code above.

LEA (Load effective address) instruction


If we use “offset”, we need the following instruction to get the address of a data:
MOV DX, offset msg

Here, msg is defined as name of the data itself. Another way to do this without using offset:
LEA DX, msg
Both instructions above, loads the address of msg into DX.

CENG 222 – Computer Organization
Lab Work 1


16-bits Intel microprocessors have some capabilities of moving data from register to register; register to memory, and vice versa.

Commonly used 16-bits registers are:

AX, BX, CX, DX, SI, DI, SP, DS

First four registers (AX, BX, CX, and DX) consist of two 8-bits parts called high part (denoted by ‘H’) and low part (denoted by ‘L’).

AX = AH, AL                        BX = BH, BL             CX = CH, CL             DX = DH, DL

Note that the high part register is the most significant byte and the low part is the least significant byte of the whole 16-bits register.

Assembly instructions of moving data using memory and registers are given below:

§  Parameters of instructions are denoted by <…> symbols for explaining the usage of the instruction.
§  [] braces in Macro assembly has the same function with * operator in C language. For example, [AX] denotes the data or memory location where AX points to.

1-    Immediate data to register

            MOV <destination register>, <data>

      MOV AX, 4C00H                  ; AX = 4C00h
      MOV DL, 120                        ; DL = 120

      Size of data and destination register must be equal!

2-    Register to register

            MOV <destination register>, <source register>

            MOV AX, CX            ; AX=CX
      MOV CL, BH             ; CL=BH
     
      Note that size of destination and source registers must be the same!

3-    Memory to register (Direct addressing)

            MOV <destination register>, [<address>]

            MOV AX, [1BFFH]               ; Copy 2-bytes (word) data stored at address 1BFF to AX
            MOV DL, [offset msg]           ; Copy 1-byte data at msg to DL

Important:  Size of the data read from memory is determined by the size of the destination register!


4-    Memory to register (Indirect addressing)

            MOV <destination register>, [<register>]

            MOV AX, [BX]         ; AX = (*BX)
      MOV DL, [BX]          ; DL = (*BX)

Important:  Size of the data read from the memory location pointed by register, is determined by the size of the destination register!

5-    Register to memory

            MOV [<register>], <source register>

            MOV [BX], DX         ; *BX = DX    (Writes 2 bytes)
            MOV [BX], DL          ; *BX = DL     (Writes 1 byte)
            MOV [1BFFH], AX   ; *(1BFFH) = AX;      (Writes 2 bytes)
           
Note: Size of the data written is the size of register.

6-    Immediate data to memory
           
            MOV [<register>], <data>

            MOV [BX], 20h         ; *BX = 0020h
            MOV [BX], 4C00h     ; *BX = 4C00h
            MOV [1BFFH], 20h   ; *(1BFFH) = 20h;
           
If the source data is 1-byte, size of the data written to the memory is 16-bits unless you state the size. Leading zeros will be added automatically.

MOV [BX], 20h          ; Copy the word (2-bytes) data to the memory
                                    ; block started at BX. (*BX = 0020h)
MOV WORD PTR [BX], 20h            ; Exactly the same as above
MOV BYTE PTR [BX], 20h              ; Copy 1 byte (*BX = 20h)

If the source data is 2-bytes, size of the data written to the memory is 16-bits and you cannot state the size.
Experiments

Analyze the assembly code below:

title Register test program

.model small
.stack 100h
.data
msg db "AB",0dh,0ah,'$'

.code
main proc
     mov ax,@data
     mov ds,ax

; Add your code here
; ------------------

; ------------------

     mov ah,9
     mov dx,offset msg
     int 21h

     mov ax, 4c00h
     int 21h
main endp

end main

The program above prints “AB” to the console. The message “AB” is stored at msg in data segment. Therefore, “offset msg” is the starting address of the string. Modify the code according to the following experiments:

1-      Copy the second byte stored at “msg” (which is ‘B’ currently) to the first byte. The output should be “BB”. In order to do that, load 2-bytes data stored at “msg” into a 16-bits register. Copy one part of the register to the other part. Then, write your register back to msg.
2-      Copy the first byte stored at “msg” (which is ‘A’ currently) to the second byte. The output should be “AA”. To achieve this, load the first byte stored at “msg” into one 8-bits register (high or low part) and copy it onto the other part and write the data stored in register back to msg.
3-      Load the data stored at “msg” into one register and swap the high and low parts of the register using a temporary 8-bits register. Then write back your “swapped” register onto msg. The output should be “BA”.
Unified Modelling Language Practicals. Below is the case study of it for the construction of different UML diagrams

CASE STUDY: Hospital Management System


Hospital management system helps in registering information about patients and handles patient’s query. A unique ID is generated for each patient after registration. This helps in implementing customer relationship management and also maintains medical history of patient. This system also monitors the doctor appointments, when the ID is generated the patient receives the appointment time and number from the receptionist and accordingly visit the doctor. This system also deals with testing appointments as and when ID is generated the patient receives the appointment time and number and accordingly undergoes the test.

It also deals with bed allotments to various patients by checking their ID. It also undergoes various operations by diagnosing the patients. The system identifies whether the person is a doctor or staff and handles various activities such as draw salary and give salary, also it adds doctor/staff information into database. This system is responsible for handling various other activities like deleting, editing doctor/staff information into the database. As per doctor diagnoses the patient, gives treatment and gives suggestions to patients and prescribe laboratory tests and medicines. This system also takes care of medical equipment, doctor visit, vitals recording, patient case sheet, diet ordering, blood requisition, transfer information and discharge information, maintenance of wards, inter and intrawards transfers also it generates patient’s discharge summary which includes patients health at the time of discharge, medical history, various diagnosis and drug prescriptions, history of patients illness and course in hospital. Patient can pay bill through credit card, cash or cheque whose information is maintained by this system.


Use Case Diagram:-
UML Use Case Diagram for Hospital Management





Activity Diagram:- Patient Payment
UML Activity Diagram for Hospital Management Patient Payment




Activity Diagram:- Setting Doctor Appointment
UML Activity Diagram for Hospital Management Doctor Appointment





Class Diagram:-
UML Class Diagram for Hospital Management





State Chart Diagram :- Patient
UML State Chart Diagram for Hospital Management Patient




State Chart Diagram :- Doctor
UML State Chart Diagram for Hospital Management Doctor




State Chart Diagram:- Receptionist
UML State Chart Diagram for Hospital Management Receptionist




Sequence Diagram:- Test Appointments
UML Sequence Diagram for Hospital Management Test Appointments



Sequence Diagram:- Bed Allotment
UML Sequence Diagram for Hospital Management Bed Allotment




Collaboration Diagram:- Test Appointments




Collaboration Diagram:- Bed Allotments
UML Collaboration Diagram for Hospital Management Bed Allotment




Component Diagram:-






Deployment Diagram:-