Already have an account? Get multiple benefits of using own account!
Login in your account..!
Remember me
Don't have an account? Create your account in less than a minutes,
Forgot password? how can I recover my password now!
Enter right registered email to receive password!
In this Lab you will code 8086 assembler equivalents (Virgo) for common C control flow instructions. This will give you an appreciation for how control flow is implemented in assembly (and machine) language. You will find that it is not quite as simple as it is with a high-level language. See special instructions for submission at the end of this file.This lab contains a BONUS section worth an additional 4 points on your final mark! Here is a list of the C instructions for which you will code assembly language equivalents:
If statementC codeif (condition) {statements}If-Else statementC codeif (condition) {then_statements} else {else_statements}While loopC codewhile (condition) {statements}Do-While loopC codedo {statements} while (condition);For loopC codefor (initialization; condition; increment) {statements}Switch statementC codeswitch (expression) {case val_1:case_1_statementscase val_2:case_2_statementscase val_n:case_n_statementsdefault:default_statements}Normally, C Switch statements have a Break statement at the end of each case. You will also need to implement Break and Continue statements which can be used inside some of these control flow instructions.Break statementsA Break statement can occur inside a C loop or Switch statement. It is implemented as an unconditional branch to a label immediately following the loop or Switch statement.Continue statementsA Continue statement can occur inside a C loop. For While and Do-While loops, it is implemented as an unconditional branch to a label for the condition test of the While or Do-While statement.A Continue statement in a For loop is implemented as an unconditional branch to a label immediately preceding the code to implement the increment statement.
Note that the assembly code you develop for these C-structure equivalents need only be shown as pseudocode; that is, since the actual conditions are not given, neither the test for the condition nor the jump statement for this test can actually be shown. Typically, the test will be some sort of compare (cmp) instruction and the jump will be one of the many jmp variants. It is only necessary to state that a test must be done at a certain point and that a jump relating to that test should then be done at some other point. In the second and third parts of the assignment, you will code and test two of these instructions using actual assembly language.
Coding for the IF statement is given below as an example of the syntax required. Use a similar syntax for the remaining control flow instructions.
If statementC codeif (condition) {statements}Assembler pseudo-codeIF:test conditionjump to Next if falseassembly code for statementsNext:Part A) Write pseudo-code for the remaining five control flow statements given above and for the Break and Continue statements.Part B) Code a Do-While loop for the following C-code example in Virgo assembly language (assumeint's are words of 2 bytes). Place each C-code statement at the appropriate place in your assembly code as a comment:int x = 0;do{x++;if (x == 5) continue;sum += x;} while (x < 10);Bonus) Code a Switch statement for the following C-code example in assembly language (assume int's are words of 2 bytes). Place each C-code statement at the appropriate place in your assembly code as a comment:
int a;int b = 0x12;int c = 0x34;int p = some constant value;switch (p){case 0: a = b + c; break;case 1: a = b - c; break;case 3: a = b; break;case 7: a = c; break;default: a = 0;}
Op e r a t o r P r e c e d e n c e a n d A s s o c i a t i v e l y : T h e op e r a t o r p r e c e d e n c e a n d i
Shell sort - C Program: Write a program to define shell sort. void main() { //program for sorting by select sort int a[20],i,k,j,n; clrscr();
Function Overloading Function overloading is a form of polymorphism. Function overloading facilitates explaining one function having many forms. In other words it facilitates e
The continue statement The continue statement causes the next iteration of the enclosing loop to start. When this is encountered in the loop , the rest of the statements in the
Generate a class node that contains an integer id, a position (x, y) and a vector of 0 5, generate a set of x nodes each with random connectivity n. Implement an algorith
Question : (a) How does a structure differ from an array? (b) Describe how a structure differs from a union? (c) Declare a union called ‘clothes' which consists of the
Define the Recursion Function in C? In C, it is potential for the function to call themselves a function is describing 'recursive' if a statement within the body of a function
Two kinds of line detection are implemented in OpenCV, the Hough Transform and the probabilistic Hough transform. Assume that there are n feature points in an image and that it tak
The car’s measurements are illustrated, using two arrays. Array 1 = {L, R, L, R, R, L, R, R, L, R, R, L, R, L, L, R, Z}
Objective of this Program: (a) To learn more about modularization of a program into independent modules, (b) To use arrays in a program, (c) To get some experience with us
Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!
whatsapp: +91-977-207-8620
Phone: +91-977-207-8620
Email: [email protected]
All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd