## University of Dhaka Computer Science and Engineering 3rd Year 1st Semester B.Sc. Final Examination, 2021 CSE3103- Microprocessor and Microcontroller (3 Credits)

Time: 3 Hours

Answer any five [At least two(2) from each group] out of 7 questions.

Total marks: 70

(a) (4 points) Briefly describe the features of the Cortex M4 memory model with appropriate diagram. What are the major address ranges?

- (b) (4 points) Explain bit banding with proper diagram. What will be the bit band alias memory location of the 11th bit of the byte offset of 0x1300 of bit band region in SRAM, where base address of bit band region (in SRAM): 0x20000000 and bit band alias region (in SRAM): 0x220000000?
- (c) (4 points) Describe briefly about different operating modes of ARM architecture.
- (d) (2 points) Explain the usability of Control register with different context.
- 2. (a) (3 points) What are the leading causes to trigger a bus fault exception in the Cortex M4 processor?
  - (b) (5 points) Mention the scenario when both the Bus Fault and Hard Fault exceptions enable simultaneously. Introduce all the associated registers with their functionality which will represent the fault status in such a scenario.
  - (c) (2 points) What is the purpose of Cortex M4's feature " lazy stacking"? Explain.
  - (d) (4 points) Mention and describe the instructions required to call and to return from an exception. Also, list the name and functionality of different general and system registers to handle the exception.
- 3. (a) (4 points) Write a subroutine that checks the character in register R0 to see if it is alphabetic (upper- or lower-case). It should set the Zero flag if the character is alphabetic, and reset the flag if it is not.

  Sample Problems:

| 71-7 3 - FT |    | Test A | Test B | Test C | ١ |
|-------------|----|--------|--------|--------|---|
| Input       | R0 | 47 'G' | 36 '6' | 6A 'j' |   |
| Output      | Z  | FF     | 00     | FF     |   |

(b) (4 points) Write down the equivalent ARM assembly code of the following C code : int main(int argc, char \*argv[])

{
 int x,y;
 x = 1;
 switch(x)
 {
 case 0:
 y = 10;

.data

seed: .word 25 #end Random

- 1. Create an array of 100 values, and populate it with 100 random numbers.
- Using the array in previous part, find the minimum and average of all values in the array.
- (a) (4 points) Convert the following ARM assembly code into machine language. Write the instruction in hexadecimal.
  - MOV R10, #63488
  - LSL R9, R6, #7
  - STR R4, [R11, R8]
  - ASR R6, R7, R3
  - (b) (2 points) Translate the following machine code into equivalent ARM assembly code.
    - 0xE5902004
    - 0xE1A04638
- (c) (4 points) Describe different addressing modes used in ARM processor with proper example.
- (d) (2 points) All instructions in the ARM instruction set may be conditionally executed. Discuss the advantages and disadvantages of this feature.
- (e) (2 points) First, write down the ARM instruction to multiply the content of register r0 by nine and store the product in r7. Later, write the equivalent single instruction to perform the same operation without using any multiplication instruction.
- 5. GPIO and UART Configuration questions.
  - (a) (6 points) Configure GPIOA PIN 0-3 for input traffic density at the crossroad and 4-7 as output to control 4-traffic lights. Assume that each pulse changes the light status, such as RED to GREEN or GREEN to YELLOW, and so on. Where MODER, SPEEDER, TYPER, and PUPDR registers have two-bit allocated for each PIN.
  - (b) (4 points) Describe the steps to set a GPIO pin as input and output. Let the GPIO pin-X's speed set to 160 MHz and another GPIO pin-Y's speed set to 50 MHz. Now, to identify a real-time sensor event which pin will result best?
- (c) (4 points) A UART agent is connected to an MCU, and the MCU can read from and write values to the agent registers. MCU writes a value to the agent's register primarily to configure the device and read a register value from the agent (such as sensing the speed of a motor). However, the agent only accepts a baud rate of exactly 2MBps. Determine the mantissa and fractional values for the USARTx\_BRR register to set the baud rate. Assume the register accepts 22 bits for mantissa and only 8 bits for the fractional value.
- 6. Answer the following questions based on I2C deployment in the ARM-M microcontroller.
  - (a) (3 points) How could an I2C slave identify the start and stop conditions of an I2C transmission? Write the steps sequentially to transfer 1MB of data using I2C.
  - (b) (6 points) A temperature sensor has four registers, register-1 address 0x0AH and register-2 address 0x0BH for temperature (F/C) and pressure (p/kp) unit. Write to 0x0CH to 0x0AH set Centigrade and 0x0FH Farenthite accordingly. Writing 0xA0H or 0xB0H to 0x0BH sets the pressure unit to p (pascal) or Kp (kilopascal). Register-3 and Register-4 obtain the current temperature and pressure value. How can we set the temperature and pressure unit F and Kp in a single I2C frame? Similarly, read the temperature and pressure values from the sensor using an I2C frame. The address of the sensor is 0x41H. Addresses of register-3 and 4 are 0x0CH and 0x0DH repectively.



Figure 1: SPI Essential Registers

- (c) (5 points) Many I2C devices do clock stretching to adjust the speed of the clock. However master has a timer to set the limit slave clock stretching duration. If it exceeds I2C Hang, it needs to reset. However, it is not very pleasant in real applications, and resetting may not be a suitable solution. A reset-i2c function may take the place of a hard reset. Write down the reset-i2c function with a suitable explanation.
- 7. Answer the following questions on SPI. Let the SPI slave contains two arrays at 0xA00H and 0xF00H to host the configuration and monitor data of crossroad traffic lights. Each configuration needs a 4-byte (uint32\_t). The registers are (i) Traffic Light 1, (ii) Traffic Light 2, (iii) Traffic Density in a north-south direction, and (iv) Traffic Density in the east-west direction. Whereas 0xF00H has eight 32-bit registers to store the last two monitoring data sets (each contains four pieces of information lights, traffic density). Fig. 1 demostrate the SPI essential registers.
  - (a) (6 points) Write a program to configure two-MCU as master and slave SPI. Figure 1 shows the SPI registers.
  - (b) (4 points) Write two functions to read monitoring data and set traffic light configuration for the Bijoy-Sarani crossroad. The address bit must clearly indicates the salve to identify read and write command. Hints: send data with the starting address.
  - (c) (4 points) Explain the following figure 2 for a typical SPI communication.



Figure 2: SPI Signaling

# University of Dhaka

### CSE-3103: Microprocessor and Microcontroller (3 Credits) Department of Computer Science and Engineering 3rd Year 1st Semester Final Examination, Time: 3 hours Total Marks: 70 2021

Answer any five (5) out of the following seven (7) questions:

(a) Convert the following ARM assembly code into machine language. Write the instructions
(5) (ii) LDR R11. [R3, #4] (i) LSR R4.R8.R6 775 BOA E160 4638

593B004

10

3

Consider the following ARM assembly language snippet. The numbers to the left of each (ii) 0xE3A0201F 2 RN # ox H

3

0x000A002C ADD R5, R3, R5, LSR #2 0x000A0030 SUB R4, R0, R3, ROR R4  $0 \times 000 \text{A}0028 \text{ func} 1 \text{ MOV R4. R1}$ instruction indicate the instruction address 0x000A0034 BL func2 1<u>11</u> A04001 0 M 35/2

\*0x000A0038 fuic2 LDR R2. [R0. #4] \*0x000A003C STR R2. [R1. -R2] -0×0000A0040 CMP R3. #0 0x000A0044 BNE else  $0 \times 0000 A0050 B func2$ 0x000A004C else SUB R3, R3, #1 0x000A0048 MOV PC, LR

- Translate the instruction sequence into machine code. Write the machine code in structions in hexadecimal.
- (ii) List the addressing mode used at each line of code.
- The high-level function strepy copies the character string are to the character string dat // C code

void strcpy(char dst[], char src[]) { do { int } while (src[i++]); dst[i] =  $\dot{\mathbf{1}} = 0$ ; src[i];

Implement the strepy function in ARM assembly code. Use R4 for i.

- 2. (a) A subrontine is passed two integer parameters which it adds together and returns the result in R0. Assuming that the subroutine places the Link Register (LR) on the stack and uses the stack to pass the parameters, sketch the  $\overline{ARM}$  code required for a simple implementation of the subroutine and draw diagrams of the resulting stack structure
- (b) The following code is an implementation of Euclid's GCD algorithm. [This calculates the Bgcd e.g. 6 and 9 would give 3.] Bgcd SUB RO. RO. R1 BEQ end gcd CMP R0. R1 Greatest Common Divisor end less SUB R1, R1, R0 also known as the Highest Common Factor - of two numbers 20 80 I 80 20 1

Rewrite the code using conditionally executed instructions

- (c) Design an algorithm for testing whether a given string is a palindrome. Implement your algorithm using ARM assembly code.
- Describe all the special registers of cortex M4 processor with suitable diagram
- P Explain in details the bus interfaces of cortex M4 processor
- Draw the cortex M4 block diagram and write down the functionality of FPU and MPU
- Ē Explain tail chaining with a timing diagram.

-

4

- B Assume an interrupt EXTLX has the position 17 in interrupt vector table. entry address for EXTLX? What is the N
- write down the assembly instruction to disable all the interrupts with priority level equal or lower than 0x30
- $oldsymbol{\partial}$  Describe with a proper diagram the procedure to handle exception in thread mode.
- About clock and timer configuration

crocontroller has AHB1, APB1, and APB2 buses to connect peripherals. The peripherals connected to the AHB1 bus need an 80MHz clock. Af the same time, APB2 and APB1 tem uses a clock following tables need clocks of 40 and 20 MHz accordingly. Determine the Prescaler values given in the A microcontroller has a  $16MH\sqrt{\text{external}}$  crystal, and the clock configuration for ten uses a clock generated from the PLLCLK module of the microcontroller.

| Sequence Prescaler | Prescaler            | Possible values                                                       |
|--------------------|----------------------|-----------------------------------------------------------------------|
| -                  | PLLM. PLLN. PLLP     | $2 \le PLLM \le 63.50 \le PLLN \le 432.PLLP \in$                      |
|                    |                      | [2, 4, 6, or 8]                                                       |
| 2                  | System Clock Mask    | HSI. HSE, PLLCLK or PLLR                                              |
| ω                  | AHB Prescaler (HPRE) | AHB Prescaler (HPRE) $HPRE \in [2, 4, 8, 16, \dots, 512]$ $\varphi$ , |
| *                  | APB1 Prescaler       | $PPRE1 \in [2, 4, 8, 16]$                                             |
| 4                  | APB2 Prescaler       | $PPRE2 \in [2, 4, 8, 16]$                                             |

that comprises five pulses with thaty cycles 20%, 25%, 35%, 40% and 50% accordingly. Determine the CCR1 Prescaler and ARR hygisters values for the up counter setting of a timer to generate the PWM signal with the given pattern. Note that an MCU changes polarity (low to high to low) whenever the CNT register matches the CCR1 register value. Assume that the input clock of the timer is 80MHz, and the generated target pulses The timer is an independent peripheral and is not influenced by the code running on the microprocessor unless the code modifies its configuration. A timer can generate PWM signals as needed by any application. One application lets 'AppX' need a PWM signal that comprises five pulses with duty cycles 20%, 25%, 35%, 40% and 50% accordingly. 16 ×1 × 160× 1

Two pushdown switches (down represents 'L') are connected to pin PA5 and PA6. Four LEDs are connected to GPIO port B (PB1, PB2, PB3, and PB4). Determine the values of RCC\_AHBIENR, GPIOx\_MODER, GPIOx\_OTYPER, GPIOx\_OSPEEDR registers of RCC\_AHBIENR. However, bit-'0' to bit-'15' needs to configure for pin-'0' to pin-'16'\_of GPIOx\_OTYPER light on LEDs following the conditions given in the following table. Assume that bit-0' to bit-7 must be configured to enable GPIOA to GPIOH. Starting from bit-0' to bit-31 (2-bit register. In addition, bit-'0' to '15' for set a<del>nd '16' to '31' reset the 16 GPIO pins</del> for each pin) of GPIOx\_SPEEDR and GPIO\_MODER registers represent pin 0' to 16 (five altogether) take exactly five microseconds segment of code to recognize the input switches combinations, such as to

| 11         | 10             | 0.1            | 00             | Input (PA5 PA6)              |
|------------|----------------|----------------|----------------|------------------------------|
| off off on | off off on off | off on off off | on off off off | LED Status (PB1 PB2 PB3 PB4) |

Answer the following questions based on UART deployment in the STM32F446re microcon-

A UART slave device is connected to the MCU, and MCU can read from and write valuesto the device registers. MCU writing value to the register of the slave device primarily to 5MBps. of the jet engine of an aircraft). configure the device and read a register value from the device (such as sensing the speed Determine the mantissa and fractional values for the USARTx\_BRR register to However, the device only accepts a band

(b) Write a program to configure a UART communication with a band rate 5MBps to the Jet Engine. Assume that in response to transferring 0x5C to the Jet engine, the Jet engine sends 3KBytes of data to the MCU that contains speed (in rpm), engine health information, angle to the ground height from the sea level, and GPS position. Assume that the controller uses USART6 of MCU with PC6 for Tx and PC7 for Rx. The alternate function for PC6 and 7 is AF8 (0x08). The registers for the alternate function are GPIOx AFRL for '0' to '7' pins and GPIOx AFRH for '8' to '15' pins. RCC APB2ENR bits 4 and 5 for USART1 and 6 clocks enable. The USART registers are listed as follows (SR. CR1, CR2,

| 31             | 30                                         | 29            | 28      |        |                      |       |       |           |       |        |          |       |      |      |              |
|----------------|--------------------------------------------|---------------|---------|--------|----------------------|-------|-------|-----------|-------|--------|----------|-------|------|------|--------------|
|                |                                            |               | 20      | 27     | 26                   | 25    | 24    | 23        | 22    | 21     | 20       | 19    | 18   | 17   | 16           |
| 15             | 14                                         |               |         |        |                      |       |       |           |       |        |          |       |      |      | Tale white a |
| т              |                                            | 13            | 12      | 11     | 10                   | 9     | 8     | 7         |       |        |          |       |      |      |              |
|                |                                            |               |         |        |                      | CTS   | LBD   |           | 6     | 5      | 4        | 3     | 2    | . 1  | 0            |
| Charles Annual | and the state of the state of the state of | - (not into a |         |        |                      | nc_w0 | 0w_21 |           |       | RXNE   | DLE      | ORE   | NF   | FE   | ÞE           |
| 31             | 30                                         | 29            | 28      | 27     | Officer and a second |       | IC_MU |           | rc_wc | tc_wo  | ,        | r     | ٠,   | ,    | r            |
|                |                                            |               |         | 1      | 26                   | 25    | 24    | 23        | 22    | 21     | 20 .     | 19    | 18   | 17   | 16           |
|                |                                            | -             |         | 1      |                      |       |       |           |       |        |          | ·T    |      |      |              |
| 15             | 14                                         | 13            | 12      | 11     | 10                   | 9     |       |           |       |        |          |       |      | -    |              |
| DVER8          |                                            | UE            | М       | WAKE   | PCE                  | PS    | 8     | . 7       | 6     | 5      | 4        | 3     | 2    | 1    | 0            |
| TW             |                                            | tw            | (W      | (W     | IW                   | rw    | PEIE  | TXEIE     | TOIL  | RXNEIE | IDLETE ! | TE    | RE   | RWU  | SB           |
| 31             | 30                                         | 29            | 28      |        |                      | 144   | ΓW    | ΓΨ        | rw    | tw     | rw       | rw    | PW   | r\w  | ľW           |
|                |                                            | 1             | 1       | 27     | 26                   | 25    | 24    | 53        | 22    | 21     | 20       | 19    | 18   | 17   | 16           |
|                |                                            |               |         |        |                      |       | -     |           |       |        |          |       |      |      |              |
| 15             | 14                                         | 13            | 12      | 11     | 10                   | 9     |       |           |       |        |          |       | -    |      |              |
|                | LINEN                                      | ST            | OP[1:0] | CLKEN  |                      | CPHA  | LBCL  | 7         | 6     | 5      | 4        | 3     | 2    | 1    | 0            |
|                | Γ₩                                         | ivy           | rw      | ſw     | TW                   | fw    | LBUL  | Res.      | LBDIE | LBDL   |          |       | ADD  |      |              |
| 31             | 30                                         | 29            | 28      | 27     |                      |       | i     | 1         | rw    | ſw     |          | r/w   | r\w  | ľW   | fw           |
|                |                                            |               | -       | P. C   | 26                   | 25    | 24    | 23        | 22    | 21     | 20       | 19    | 18   | 17   |              |
| 15             | 14                                         | 13            | 12      | 11     | 10                   | 9     | 8     | <u></u>   |       |        |          |       |      | ''   | 16           |
|                |                                            |               |         | ONEBIT | CTSIE                | CTSE  | RTSE  | 7<br>DMAT | 6     | 5      | 4        | 3     | 2    | 1    | 0            |
|                |                                            |               |         | ΓW     | rw                   | rw    | -     | DMAT      | DMAR  | SCEN   | NACK     | HDSEL | IRLP | IREN | EIE          |
|                |                                            |               | -       |        |                      | . "   | TW    | rw        | PW    | rw     | TW       | rw.   | CW.  | rw   | rw.          |

(c) To set the USART reception interrupts, describe the bits that need to be set and check the interrupt service routine. Also, mention when the interrupt service routine for reception is activated.

#### 7. Answer the following questions on I2C?

- (a) Let an I2C master is connected to 32 slaves where each of the I2C slave maintains two addresses: (i) unique slave address and (ii) broadcast address. The broadcast address is 0xFF, and device addresses are assigned from 1 to 31. Configure both addresses for the I2C slaves. Assume that ORA1 and ORA2 contains one of the 7 and 10 bits address. The ORA1: bit-0 is ADDR0, bits-1-7 ADD[7:1] and ADD[8:9] are used for interface address, and bit-15 is the addressing mode (ADD MODE). Bit-0 of ORA2 is the EN\_DUAL, and bit-1 to 7 bits are used for the interface address. Also, draw the packet for writing 0x4C to a register (memory) identified address of 0XD5.
- (b) How could a differential between start, stop, and data in I2C. If an MCU wants to read three registers values with 0xC0, 0xD0, and 0xA1 addresses, then determine the minimum number of start and stop signals that need to transfer by the master to the slave where the slave address is 0x0A. [4]
- (c) When does the slave or master stretch the clock signals (down the clock and hold)? If a master-slave communication is disrupted by clock stretching, write down the steps to release the clock to reset the I2C to the normal operational stage. For every byte of data, master, and slave exchange acknowledgment bit. Do you think the acknowledge bits play a vital role in synchronization? Explain. [4]

|          |              |    | Ор |
|----------|--------------|----|----|
| Mnemonic | Opcode       |    |    |
| ADD      |              | 00 |    |
| SUB      | 0100         | 00 |    |
| MOV      | 0010         | 00 |    |
| BL       | 1101         | 10 |    |
| BNE      | 1110         | 10 |    |
| STR      | 0001<br>1110 | 01 |    |
| LDR      | 1110         | 01 |    |
| LSR      | 1110         | 00 |    |
| CMP      | 1010         | 00 |    |
| В        | 1110         | 10 |    |
| BLT      | 1011         | 10 |    |
|          |              |    |    |

#### **University of Dhaka**

#### Department of Computer Science and Engineering 3rd year 1st Semester B.Sc. Final Examination-2020 CSE-3103: Microprocessors and Microcontrollers

Total Marks: 70 Credits: 3 Time: 2 hours

#### Answer any 03 (THREE) of the following 05 (FIVE) questions

| 1. | a) | Point out the policies adopted in ARM architecture design to address limitations of RISC architecture and to have an edge over CISC machine performance.                                                                                                                                                                                                                                                  | 5.33 |
|----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|    | b) | Among the three machine language representations of ARM assembly instructions given below identify the inconsistencies (if any) and explain. [Treat each instruction individually.] i) 1010-0000-0010-0011-1100-0101-1001-0011 ii) 1100-0101-0111-1000-1000-1010-1010-101                                                                                                                                 | 9    |
|    | c) | Convert the following three ARM assembly data processing instructions into their corresponding machine language representations. You can take help from the Appendix (Page 3) if necessary.  i) ADD r0, r1, r2  ii) SBCLS r3, r5, r6, LSL r0  iii) MOV r0, #&2940 (hex value)                                                                                                                             | 9    |
| 2. | a) | Suppose, $r3 = 0$ ACB, $r5 = A$ CB5, $r6 = 0035$ and $r0 = 0003$ (all values are in hex). What will be the updated value of these registers after executing the following ARM instruction: SUB $r3,r5,r6,L$ SL $r0$ Also provide an explanation for your answer.                                                                                                                                          | 3.33 |
|    | b) | Explain pre-indexed and post-indexed load operation in ARM with examples.                                                                                                                                                                                                                                                                                                                                 | 4    |
|    | c) | How does ARM handle a long range subroutine call in THUMB mode? Can this subroutine be executed in regular ARM mode? Explain.                                                                                                                                                                                                                                                                             | 8    |
|    | d) | Draw block diagram(s) and discuss step-by-step datapath activities in 3-stage pipeline ARM organization for the following instruction: STR r3, [r0, r4, lsl #3]                                                                                                                                                                                                                                           | 8    |
| 3. | a) | What are the similarities and differences between LEA and MOV with the OFFSET directive?                                                                                                                                                                                                                                                                                                                  | 3.33 |
|    | b) | Explain the purpose of the following bits in the flag register of 80386: i) IOPL ii)O iii)VM iv)T                                                                                                                                                                                                                                                                                                         | 4    |
|    | c) | Calculate accessed memory addresses for the following instructions in real mode of 80286 given that, CS = 2000H, DS = 3000H, SS = 3000H, ES = FF00H, BX = FF04H, DI = 1020H, SI = 2030H, SP = 100H, BP = 98H.  You also need to mention the updated value of the registers affected by the execution of each instruction where possible.  Note: Treat all instructions independently.  i) MOV DX, [BX+SI] | 10   |

- ii) POP CX
- iii) MOVSB
- iv) MOV ES:[DI], CX
- v) ADD AX, [BP+2]
- d) Consider the following 80386 descriptor. Find starting and ending location indicated by it when

6

- i) granularity bit = 0
- ii)granularity bit = 1

| 10101100 | G   | D   | L    | AV   | 1100 | Access Rights | 00001111 |
|----------|-----|-----|------|------|------|---------------|----------|
| 010      | 100 | 001 | 0101 | 1111 |      | 00001010      | 00110000 |

- 4 a) Explain pipelined memory access of 80386 showing transition among different BUS states.
  - b) Briefly describe the near and far procedure calls of the 8086 microprocessor.
  - c) What are the benefits and disadvantages of using registers for parameter passing? 4
  - d) Describe the operation of INTO instruction. 3.33
- 5 a) Find the addressing modes for the following operations.
  i) PUSHF ii) MOV [BP+2], CX iii) JNZ YZ iv) OUT 03H
  - b) Give an example of signed overflow. 3
  - c) Which flags are used for the following program control instructions? 4

ii) SBB iii) STC iv) CMPSB

- d) What are the restrictions of MOV and XCHG instructions? 2.33
- e) Explain thread mode and handler mode of Cortex-M3. How does Cortex-M3 achieve 6 low interrupt latency and efficient processing of late arriving interrupts?

| Appendix                  |                 |                           |                       |  |  |  |  |  |  |
|---------------------------|-----------------|---------------------------|-----------------------|--|--|--|--|--|--|
| Opcode<br>124:21)<br>0000 | Mnemonic<br>AND | Opcode<br>[31:28]<br>0000 | Mnemonic extension EQ |  |  |  |  |  |  |
| 0001                      | EOR             | 0001                      | NE                    |  |  |  |  |  |  |
| 0010                      | SUB             | 0010                      | CS/HS                 |  |  |  |  |  |  |
| 0011                      | RSB             | 0011                      | CC/LO                 |  |  |  |  |  |  |
| 0100                      | ADD             | 0100                      | Ml                    |  |  |  |  |  |  |
| 0101                      | ADC             | 0101                      | PL                    |  |  |  |  |  |  |
| 0110                      | SBC             | 0110                      | VS                    |  |  |  |  |  |  |
| 0111                      | RSC             | 0111                      | vc                    |  |  |  |  |  |  |
| 1000                      | TST             | 1000                      | HI                    |  |  |  |  |  |  |
| 1001                      | TEQ             | 1001                      | LS                    |  |  |  |  |  |  |
| 1010                      | CMP             | 1010                      | GE                    |  |  |  |  |  |  |
| 1011                      | CMN             | 1011                      | LT                    |  |  |  |  |  |  |
| 1100                      | ORR             | 1100                      | GT                    |  |  |  |  |  |  |
| 1101                      | MOV             | 1101                      | LE-                   |  |  |  |  |  |  |
| 1110                      | BIC             | 1110                      | AL                    |  |  |  |  |  |  |
| 1111                      | MVN             | 1111                      | NV                    |  |  |  |  |  |  |
| Figure A1: AR             | M DPI Opcodes   | Figure A2: ARI            | M Condition Codes     |  |  |  |  |  |  |

#### **University of Dhaka**

#### **Department of Computer Science and Engineering**

#### 3<sup>rd</sup> Year 1<sup>st</sup> Semester B. Sc. (Hons) Final Examination, 2019

#### CSE-3103: Microprocessor and Microcontroller

Total Marks: 60 Time: 3 Hours

#### (Answer any four (4) of the following questions)

- 1 a) Describe addressing modes of 8086 microprocessor with suitable [10] examples.
  - b) Compare memory mapped I/O and I/O mapped I/O.

[3]

c) Describe function of ALE and DT/ $\overline{R}$  pins of 8086.

[2]

- Suppose your x86 processor is equipped with peripheral controller which is connected to an 8-bit A/D converter chip. To get a sample reading from ADC, you just read at I/O address 300H. Assume that a sine wave is fed to the ADC, your job is to write an assembly language program which calculates the frequency of the sine wave.
  - b) What do you mean by Assembler Directives?

[2]

c) What is the difference between a Macro and a Procedure?

[3] [3]

d) Which of the followings produce the same 4 bytes?

A1 BYTE "1234"

A2 BYTE 1,2,3,4

A3 BYTE 4,3,2,1

- A4 WORD 1,2,3,4
- A5 DWORD 01020304H
- A6 DWORD 01020304
- A7 DWORD 04030201
- a) A typical 7-segment display is shown below. Assume the pins (a-g) of 7-segment display are connected to data bits at I/O address 301H (D0 → a, D1 → b, and so on). Write down an assembly language function which will take any digit between 0-9 and show that number on 7-segment display.



[6]

b) What is a re-entrent procedure?

[3]

c) Explain segment addressing in protected mode.

[4] [2]

[6]

- d) Suppose there were no PUSH instruction. Write a sequence of two other instructions that would accomplish the same as PUSH EAX.
- 4 a) Suppose LSB data bus of I/O port 300h is connected properly to drive a LED. Write an assembly function which can control the intensity of the LED. Intensity of LED is a numerical value from 1 to 100 supplied as a parameter of the function.
  - LED is a
    [4]

b) Use the following data definition for this question:

dArray DWORD 10 DUP(?)

dSize = (\$ - dArray)

bytel BYTE OFFh, 1, 2

word3 SWORD 7FFFh,8000h

Where marked by a letter (a, b, c, d, e, f, g, h) in the following code segment, give your answer and explain your reasons. Suppose the code segment is executed sequentially from top to bottom. Note that some instructions may be illegal.

mov ax,dSize
mov ax,[word3+2]
mov eax,[word3+4]
mov OFFSET byte1,10h
mov ebx,OFFSET byte1

a. ax = ?

b. ax = ?

c. eax = ?
d. byte1 = ?

e. al = ? f. eax = ?

mov al, [ebx+3]
movsx eax, byte1

g. ZF, CF, SF, OF= ?

mov al,80h add al,80h mov al,00110011b test al,2

```
unsigned char data;
       char count;
       while(data)
            data = data & (data - 1);
           count++;
       printf("%d\n", count);
                                                                                        [2]
      Consider the following C code fragment:
       main(void)
       {
           unsigned short
                                 us = 269;
           signed short ss = -35;
           printf("%d %d\n", us, ss);
           printf("%u %u\n", us, ss);
           printf("%hd %hd\n", us, ss);
           printf("%hu %hu\n", us, ss);
       Write down the output from the program above and explain your answer.
                                                                                        [3]
5
  a) What are the functions of Assembler, Linker, and Loader?
                                                                                        [4]
   b) Consider the following C code:
       func(int i)
       {
           char a[8];
           if (i==1) return 1;
           else func(i-1);
       main (void)
        {
            func(5);
        }
       Show how the stack grows before the program terminates.
       Write an assembly language program which can rotate a 64bit binary number (stored in
                                                                                       [4]
       RAX) to 5 places on left. You are not allowed to use the built-in rotate instruction.
       Explain the purpose of the following flags:
                                                                                        [4]
              TF
         i.
         ii.
              IF
        iii.
              OF
        iv.
              DF
  a) Consider the following C code:
                                                                                        [4]
       void f(char *str)
        {
           char buffer[16];
           strcpy(buffer, str);
        }
        void main(int argc, char **argv)
        {
             f(argv[1]);
        }
        Show how stack is used to manage the local variables and function parameters.
       You want to exploit the stack overflow vulnerability and shift the program execution to
        a new address (0x55667788). What will be the input parameter to do so?
       It is very unlikely that you get the address of some malicious code (as assumed in
                                                                                        [5]
        previous question) that you can use to exploit stack overflow. Give a more practical way
        to exploit stack overflow.
       What is the benefit of using EBP to access the parameters of a function instead of ESP?
                                                                                        [3]
```

Translate the following C code snippet into assembly language:

[3]