Computer Organization

CS 220 Test #1 Page 1

Open book and notes, no calculator

Fall 1996 9/24/96

Name ______

1. Compute the following equivalencies.

[13 pts]

a. 32610 = ______2

b. 110111012 = ______8

c. -2110 = ______6 bit signed magnitude

= ______6 bit 1's complement representation

= ______6 bit 2's complement representation

d. 1247 = ______10

e. character '9' = ______10 = ______16= ______2

2. Assume there is a hypothetical machine that has 9 bit data storage words.

[6 pts]

a. What “binary equivalent” number base would best represent binary values? ______

b. What is the largest unsigned value in decimal that can be held in a word? ______

c. What is the range of 2's complement values that can be represented? ______to ______

3. Types of assembler statements.

[5 pts]

a. Is the statement VALUE: .LONG 5 imperative or declarative? ______

b. True or false: declarative statements always have a label associated with it. ______

c. How many operands can an instruction have? ______

d. The notation in VAX assembler #^A/Q/ reduces the need to refer to an ______table.

e. In VAX assembler, the last letter of the operation code typically indicates the _____ of the data the instruction operates on.

4. True/false on registers

[5 pts]

______No special instructions are necessary to allocate registers.

______All programmer accessible registers can be used at the discretion of the programmer.

______Registers are always involved in arithmetic operations in some way.

______Registers are the fastest place to store data.

______Registers contain information whether it contains data or addresses.

5. High level language control structures.

[21 pts]

Rewrite each of the following segments in reasonably efficient assembly language. You may assume correct syntax and logic for each of the segments. You should assume that high level language variables are represented in these segments by registers. Thus, you can just give the corresponding code segments, not full programs.

a.IF w > x THEN

w = w - x;

ELSE

w = w + 1;

b.sum := 0;
i:=10;
REPEAT

sum := sum+ i;

call foo();
i:=i-1;

UNTIL i==0;

c. w := x*x - 2*(y+1)

6. Array processing.

[12 pts]

a) Assume R0 points to the beginning of a string (an array of characters) and the string ends with a null character. Write a program segment to count the number of digits in the string up to the null character and sets R2 to this count.

b) Assume an array of integers is defined at label TABLE. The array has N elements in which that value is in a variable labeled N. Write a program segment to count the negative values in the array and put the count in R5. Use index mode here.

[12 pts]

7. Stack usage.

Describe what the following assembler subroutine prints. Assume R1 contains a positive integer. Do not describe it line by line!

[10 pts]

FOO:MOVL#-1,-(SP)

MOVLR1,R2

L1:DIVL#10,R1

MOVLR1,R3

MULL#10,R3

SUBLR3,R2

MOVLR2,-(SP)

MOVLR1,R2

jump.greater L1

L5:MOVL(SP)+,R0

jump.less L9

ADDL#^A/0/,R0

output

jumpL5

L9:return

8. Refer to the above subroutine written in VAX Macro to answer the remaining questions.

[16 pts]

a. Give an equivalent assembler statement to the CLRL instruction.

b. What carries the information from a compare instruction that normally precedes a conditional jump to the jump?

c. There are no compare instruction preceding the jump.greater instruction. What datum is the jump instruction acting upon?

d. ...and why wasn’t a compare instruction necessary?