King Fahd University of Petroleum and Minerals
College of Computer Science and Engineering Computer Engineering Department

## COE 306: INTRODUCTION TO EMBEDDED SYSTEMS

Term 171 (Fall 2017-2018)
Major Exam II
Wednesday Nov. 29, 2017

Time: 150 minutes, Total Pages: 13

Name: $\qquad$ ID: $\qquad$ Section: $\qquad$

## Notes:

- Do not open the exam book until instructed
- Answer all questions
- All steps must be shown
- Any assumptions made must be clearly stated

| Question | Max Points | Score |
| :---: | :---: | :---: |
| Q1 | $\mathbf{2 7}$ |  |
| Q2 | $\mathbf{1 1}$ |  |
| Q3 | $\mathbf{1 0}$ |  |
| Q4 | $\mathbf{1 4}$ |  |
| Q5 | $\mathbf{1 2}$ |  |
| Total | $\mathbf{7 4}$ |  |

(Q1) Fill in the blank in each of the following questions:
(1) A HAL (Hardware Abstraction Layer) defines $\qquad$
$\qquad$
and has the advantage of $\qquad$
$\qquad$ .
(2) An API (Application Programming Interface) defines $\qquad$
$\qquad$ .
(3) To start a transfer using Direct Memory Access (DMA), the CPU sets the 3 registers
$\qquad$ and once the transfer is complete, the DMA $\qquad$ .
(4) Reasons for using multiple buses in a microcontroller system are $\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$ .
(5) In a microcontroller system, two devices connected on the high speed bus are $\qquad$ and two devices connected on the low-speed bus are $\qquad$
$\qquad$ .
(6) In AMBA AHB bus, during a read operation the HRDATA is selected from the slave being read based on $\qquad$
$\qquad$ .
(7) Complete the given timing diagram for an AMBA AHB read transfer:

(8) Complete the given timing diagram for AMBA AHB burst write transfers:

(9) During an AMBA AHB transfer, whenever a slave sends a transfer response as ERROR, RETRY or SPLIT, a $\qquad$ cycle response is required.
(10) Complete the given timing diagram for an AMBA APB read transfer:

(11) In AMBA AHP bus, a split transfer works as follows:
$\qquad$
$\qquad$
$\qquad$
(12) Given a pulse width modulated signal with duty cycle of $40 \%, \mathrm{~V}_{\mathrm{L}}=0 \mathrm{v}$ and $\mathrm{V}_{\mathrm{H}}=5 \mathrm{v}$, the average value of the signal is
(13) Complete the given diagram for a pulse width modulated signal. The modulation type used is $\qquad$ :

(14) Three example applications of pulse width modulation include $\qquad$
$\qquad$ .
(15) Given that MR0=100, PWMEN2, PWMSEL2, to configure PWM2 channel to be leading edge modulated with $80 \%$ duty cycle, we need to set MR1 to be equal to
$\qquad$ and MR2 to be equal to $\qquad$ .
(Q2) It is required to implement the following IIR filter using circular buffers:


The C code for the function init(buf, $\mathrm{n}, \& p o s$ ) for initializing buffer buf with size n and position pos is given below:

```
void init(int buf[], int n, int *pos) {
    for (int i = 0; i < n; i++)
            buf[i] = 0;
    *pos = n-1;
}
```

(i) Define the needed buffers, their sizes, their needed position variables and the code for initializing the buffers.
(ii) Show the C code for the function put(buf, $\mathrm{n}, \&$ pos, val) for adding a new value, val, to buffer buf with size n and position pos.
(iii) Show the C code for the function get(buf, n , \&pos, i) for getting the ith value earlier from buffer buf of size $n$ and position pos, with zero being the latest value put in the buffer.
(iv) Show the C code for the function $\operatorname{iir}(\mathrm{x})$ that receives a new value x and returns a computed value $y$. Assume that the coefficients $a$ and $b$ are stored in two integer arrays as given below.

$$
\begin{aligned}
& \text { int } \mathrm{a}[3]=\{\mathrm{a} 0, \mathrm{a} 1, \mathrm{a} 2\} ; \\
& \text { int } \mathrm{b}[3]=\{\mathrm{b} 0, \mathrm{~b} 1, \mathrm{~b} 2\} ;
\end{aligned}
$$

(Q3) Suppose that you are hired with a company that designs electronics for high-end furniture. You were asked to work on a motorized couch, with drink holders and a built-in drink cooler and reclining seats that tilt up and down. You are asked to write an embedded program that controls the tilt motor using a microcontroller. There's an up button and a down button. When the person switches from down to up, or up to down, you have to wait 100 milliseconds so that the motor doesn't burn out (i.e., move the motor from up/down to off and then to down/up positions).

Draw the state machine diagram for the motorized couch controller using a Moore model.
(Q4) It is required to design an embedded system that controls the traffic lights at an intersection of main and side streets. It receives inputs from all four corners indicating pedestrians that want to cross. In absence of crossing requests, it should allow each direction 10 seconds of green light, followed by 2 seconds of yellow light while the other traffic light will be red light (i.e., for 12 seconds). In presence of crossing requests at or after 5 seconds, immediately proceed with yellow. Two buttons, Cross1 and Cross2, are used to indicate request for crossing across the main and side streets respectively. A pair of Red, Yellow and Green leds will be used for the two traffic lights.


A Mealy state machine diagram for the traffic light controller unit is given below:


It is required to write a C program that implements this state machine of the traffic light controller. Assume that any change in the inputs Cross1 and Cross2 will cause interrupts to update their values. Timer0 and Timer1 will be used to implement the required timing requirements. The two functions SetTimer0 and SetTimer1 are used to set Timer0 and Timer1 to call their respective timer handler for a given delay in secs.

Complete the given C code for implementing the state machine of the traffic light controller.

Page 9 of 13

```
#ifdef __USE_CMSIS
#include "LPC17xx.h"
#endif
#include <cr_section_macros.h>
#define GR 0
#define YR 1
#define RG 2
#define RY 3
int state=0;
int Cross1=0, Cross2=0;
int timer0=0; timer1=0;
void TIMERO_IRQHandler() {
    timer0=1;
    LPC_TIMO->IR |= 1;
}
void TIMER1_IRQHandler() {
    timerl=1;
    LPC_TIM1->IR |= 1;
}
void EINTO_IRQHandler()
{
    if (state==GR) Cross1=1;
    LPC_SC->EXTINT |= 1;
    for (int j=0; j<1000000; j++); // to avoid effect of bouncing
}
void EINT1_IRQHandler()
{
    if (state==RG) Cross2=1;
    LPC_SC->EXTINT |= 2;
    for-(int j=0; j<1000000; j++); // to avoid effect of bouncing
}
void SetTimer0(uint32_t delayInSec) {
        LPC_TIMO->TCR = 0x02; /* reset timer */
        LPC_TIMO->MR0 = delayInSec*2000 * (12500000 / 1000 - 1);
        LPC_TIMO->MCR = 0x05; /* stop timer on match and enable interrupt*/
        LPC_TIMO->TCR = 0x01; /* start timer */
}
void SetTimer1(uint32_t delayInSec) {
        LPC_TIM1->TCR =- 0x02; /* reset timer */
        LPC_TIM1->MR0 = delayInSec*2000 * (12500000 / 1000 - 1);
        LPC_TIM1->MCR = 0x05; /* stop timer on match and enable interrupt*/
        LPC_TIM1->TCR = 0x01; /* start timer */
}
```

int main(void) \{
LPC_GPIOO->FIODIR $\mid=7 \ll 7$; // set pins $0.7,0.8,0.9$ for GYR for
Main Street TL
LPC_GPIOO->FIODIR |= 7<<23; // set pins $0.23,0.24,0.25$ for GYR for
Side Street TL

```
LPC_PINCON->PINSEL4 |= (1<<20); // using pin p2.10 for Cross1
LPC_PINCON->PINSEL4 |= (1<<22); // using pin p2.11 for Cross2
LPC_SC->EXTMODE |= 3;
LPC_SC->EXTPOLAR |= 3;
NVIC_EnableIRQ(EINTO_IRQn);
NVIC_EnableIRQ(EINTI_IRQn);
NVIC EnableIRQ(TIMERO_IRQn); // Enable interrupt for timer 0
NVIC_EnableIRQ(TIMERI_IRQn); // Enable interrupt for timer 1
Cross1=0; Cross2=0;
LPC_TIMO->PR = 0x00; /* set prescaler to zero */
SetTimer0(10);
timer0=0;
LPC_TIM1->PR = 0x00; /* set prescaler to zero */
SetTimer1(5);
timer1=0;
```

(i) (3 Points) Assume an A/D converter is supplying samples at 44.1 kHz .
(a) How much time is available per sample for CPU operations?
(b) If the interrupt handler executes 100 instructions obtaining the sample and passing it to the application routine, what is the CPU utilization of a 20 MHz RISC processor that executes 1 instruction per cycle?
(ii) (9 Points) A real-time system receives data through an I/O device, the CPU processes the data, then the results of the processing are transferred to system memory. The I/O device, the CPU, and the memory controller are all on the same system bus, which runs at 1 MHz . The CPU runs at 10 MHz . Each bus transaction (transfer) between any two devices on the bus takes 5 bus cycles, 1 of which is used to transfer data, and the remaining cycles are used by the bus protocol. The bus has 32 data lines, transferring 32 bits per data-transfer cycle.

The I/O device receives 512 bytes at a time. While processing the received data, for each received byte, the CPU generates 4 bytes. Only generated data is transferred from the CPU to system memory.

If the I/O device receives new data at a rate of 200 times per second ( 512 bytes each), how many CPU cycles can be spent processing each byte without violating the real-time requirements? Assume that the memory is fast enough to handle any requests received by the memory controller.

