# The University of Texas at Austin Department of Electrical and Computer Engineering ## **Real-Time Systems / Real-Time Operating Systems** EE445M/EE380L.6, Spring 2015 ## **Final Exam Solutions** **Date:** May 14, 2015 | UT EID: | | | |------------------------------------------------|-------|----------------------------------------| | Printed Name: | | | | | Last, | First | | Your signature is your will you help others to | • | d and will not cheat on this exam, not | | Signature: | | | #### **Instructions:** - This exam has 10 pages. Please make sure that you have all sheets. - Open book and open notes. - No calculators or any electronic devices (turn cell phones off). - Please be sure that your answers to all questions (and all supporting work that is required) are contained in the space (boxes) provided. *Anything outside the boxes will be ignored*. - For all questions, unless otherwise stated, find the most efficient (time, resources) solution. | Problem 1 | 15 | | |-----------|-----|--| | Problem 2 | 15 | | | Problem 3 | 15 | | | Problem 4 | 10 | | | Problem 5 | 10 | | | Problem 6 | 20 | | | Problem 7 | 15 | | | Total | 100 | | ## Problem 1 (15 points): Hold and wait a) In class we discussed deadlock prevention by ensuring that hold and wait conditions can never occur. Show the C implementation of the spinlock realization of *OS\_Wait2()* and *OS\_Signal2()* functions that simultaneously acquire and release two semaphores. Your implementation must ensure that neither routine is ever waiting (spinning) for one semaphore while holding the other. Also, both functions must only return once both semaphores have been acquire or released, respectively. ``` void OS_Wait2(long *s1, long *s2) void OS_Signal2(long *s1, long *s2) disableInterrupts(); disableInterrupts(); int flag = 0; *s1 = *s1 + 1; *s2 = *s2 + 1; while(!flag) { while(*s1 <=0){ enableInterrupts(); enableInterrupts(); disableInterrupts(); if (*s2 <= 0) { enableInterrupts(); disableInterrupts(); } else flag = 1; *s1 = *s1 - 1; *s2 = *s2 - 1; enableInterrupts(); or: disableInterrupts(); while (*s1 <=0 || *s2 <=0) { enableInterrupts(); disableInterrupts(); *s1 = *s1 - 1; *s2 = *s2 - 1; enableInterrupts(); ``` b) How could your OS ensure that programmers never accidentally create a hold-and-wait condition, i.e. wait for two semaphores by simply calling the normal *OS\_Wait()* twice? Just describe the idea, no code needed. Record in the TCB if/what semaphores a thread is holding, and throw error if OS\_Wait() is called while already holding a semaphore. ## **Problem 2 (15 points): Real-Time Scheduling** Consider a priority scheduled real-time system running three periodic tasks with the following priorities and execution times. You can assume zero context switch and interrupt overhead. | Task | Priority | <b>Execution Time</b> | Period | |-------------|----------|-----------------------|--------| | Airbag (A) | High | 10μs | 30µs | | Warning (W) | Medium | 20μs | 60μs | | Engine (E) | Low | 30µs | 120µs | a) Does this task set follow a rate monotonic scheduling (RMS) strategy? If so, why? If not, why not? Yes, it is RMS, priorities are inversely related to periods. Bonus points: the processor utilization here is $1/3+1/3+1/4=11/12\approx 92\%$ , i.e. greater than the 69% maximum that guarantees RMS schedulability. The key with RMS is that the 69% bound is a sufficient, but not necessary condition. There can be task sets that exceed the bound, but are schedulable (see below). b) Draw the task executions over time. Assume that all tasks become ready to execute, i.e. start their first period at time zero. Draw one iteration of the schedule until it starts repeating. Is the task set schedulable, i.e. do all task finish their execution before the start of their next period (=deadline)? Is there any priority inversion? If so, mark the duration of the inversion. c) Now assume that tasks A and E share a mutex (binary semaphore) that they acquire at the beginning of each execution and hold for the whole duration of their execution. Draw one iteration of the schedule. Is the task set schedulable? Is there any priority inversion? If so, mark the beginning and end of the inversion. ## **Problem 3 (15 points): Signal Processing** You are asked to design a signal processing chain with typical blocks as given below: The maximum sampling rate of the ADC is limited to 12kHz. The frequency domain spectrum of the input x(t) is as shown below. The desired signal is in the 1kHz - 4kHz band. There are interferers at 500Hz and 10kHz. You can assume that there are no other signals (noise, etc). a) Choose a sampling rate (f<sub>s</sub>) for the ADC (< 12kHz) and give the cut-off frequencies of the analog low-pass filter (LPF) and of a digital filter of your choice such that x2[n] has minimal components of the interferers. | ADC f <sub>s</sub> | $f_s > 8kHz$ , best to just go with $f_s = 12kHz$ | | |---------------------------------------|---------------------------------------------------|--| | Analog LPF cutoff | > f <sub>s</sub> / 2, e.g. 6kHz | | | Digital filter response type & cutoff | Bandpass filter, 1kHz4Khz | | b) Why do we need the analog filter? | To avoid aliasing. | | | | |--------------------|--|--|--| | 8. | | | | c) Is there a way to design the system without using an analog filter? If so, give a range of ADC sampling frequencies that can be used so that your interferer doesn't destroy your signal. Pick a sampling frequency and give the cut-off frequencies for the digital filter such that there are minimal interferer components in x2[n]. Hint: From the sampling theorem, it follows that after sampling, $X(f+nf_s) = X(f)$ , where n is an integer. Hence, $X(f_s/2 + f) = X(f_s/2 - f)$ , i.e. the sampled signal is symmetrical around $f_s/2$ . | Possible f <sub>s</sub> range | 9kHz to 11kHz | |---------------------------------------|--------------------------------------------------| | ADC f <sub>s</sub> and Digital cutoff | $f_s = 10kHz$ , digital bandpass $1kHz$ $4kHz$ . | ## Problem 4 (10 points): Filter Design and Analysis a) Given the following pole-zero plots, sketch the frequency response of the corresponding filters, i.e. the magnitude of the gain of the filter's transfer function over the frequency f. Also indicate whether the filters are analog or digital, and whether they are IIR or FIR. b) Draw the pole-zero plot of a digital 60Hz notch filter that uses an ADC sampling frequency of 240Hz. ## Problem 5 (10 points): Filesystem In class, we discussed the Unix/Linux filesystem, which uses a form of indexed allocation that stores separate index tables for each file in so-called *inodes* on disk. Each file is associated with exactly one inode given in its corresponding directory entry. Each inode contains meta-information about the file (such as permissions) next to the index table of allocated blocks. Assume that the master directory is stored in disc block 0, followed by up to N inodes. Furthermore, assume that disc blocks have a size of 1kB, that 8 bytes in each inode are used to store meta-information, and that each block index number in the inodes has 32 bits. | | Disk | |-------|------------| | 0 | Master Dir | | 1 | inode 0 | | 2 | inode 1 | | | | | N | inode N-1 | | ••• | | | | | | 42 | | | 43 | | | 44 | | | 45 | | | 46 | | | 47 | | | 48 | | | • • • | | | | | a) Does this filesystem have internal or external fragmentation? If so, why? If not, why not? | Internal fragmentation | Yes, on average 512 bytes are wasted in last block in file. | |------------------------|-------------------------------------------------------------| | External fragmentation | No, all free blocks are available to any file. | b) What is the largest supported disk size? What is the largest file that can be created? | Largest disk size | 32-bit index numbers, i.e. $2^{32}$ blocks of $1kB$ each = $4TiB$ | |-------------------|----------------------------------------------------------------------| | Largest file size | 1024/4 - 2 index entries per inode = 254 blocks of 1kB each = 254 kB | c) How could the file system be changed to support larger file sizes? Create multiple levels of inodes, i.e. designate some of the inode entries as special pointers to other inodes, thus effectively creating a tree of inodes. This is actually how the Unix/Linux filesystem works. Alternatively: let each inode be larger than 1 disc block. That still limits max. file size, though, and also creates more internal fragmentation (within inodes). ## Problem 6 (20 points): Distributed Barrier In the midterm, we developed an implementation of a *OS\_Barrier()* synchronization between *N* tasks running on the same microcontroller. You are now asked to implement a distributed barrier that synchronizes *N* microcontrollers connected via a single, shared CAN bus. You can assume that the CAN bus will not be used for any purpose other than realizing the distributed barrier. Make any additions or modifications to the CAN starter code shown below. Then show the C code for a spinlock realization of the *OS\_Barrier()* function. Clearly indicate modifications that are specific to the microcontroller the code is running on. Hint: keep in mind that the CAN is a shared bus that supports broadcast operations where all connected computers, including the sender itself, can simultaneously receive any desired message on the bus. ``` #define N ... // Message IDs #define RCV ID \#define XMT_ID \overline{\phantom{a}} // unique microcontroller ID between 0 and N-1 // largest ID the microcontroller supports #define MAX_ID 31 // global barrier count sema4_t barrier = N; // N must be less than MAX_ID-1 // setup object in CAN controller message RAM uint32_t MessageFlags, uint32_t MessageLength, uint8 t * MessageData, uint32 t ObjectID, tMsqObjType eMsqType) { // Initialize CAN port void CAN0_Open(void) { int i; CANInit(CAN0 BASE); CANBitRateSet(CAN0_BASE, 80000000, CAN_BITRATE); CANEnable(CANO BASE); CANIntEnable(CANO_BASE, CAN_INT_MASTER|CAN_INT_ERROR|CAN_INT_STATUS); for(i = 0; i < N; i++) { // Set up filter to receive 4 byte message with RCV_MSG_ID // from all controllers participating in the barrier // including message coming from ourselves CANO_Setup_Message_Object(RCV_ID, i, MSG_OBJ_RX_INT_ENABLE, 4, 0, NULL, RCV_ID, i, MSG_OBJ_TYPE_RX); } NVIC_EN1_R = (1 << (INT_CAN0 - 48)); //IntEnable(INT_CAN0); return; ``` *Name*:\_\_\_\_\_ ``` // send <del>4 bytes of</del> data to other microcontroller void CAN0_SendMessage(uint8_t *data){ CANO_Setup_Message_Object(XMT_ID, NULL, 4, data, 0, NULL, XMT ID, MAX ID, MSG OBJ TYPE TX); // The CAN controller interrupt handler. void CAN0_Handler(void){ uint32_t ulIntStatus, ulIDStatus; int i; tCANMsgObject xTempMsgObject; xTempMsgObject.pucMsgData = data; 0; ulIntStatus = CANIntStatus(CANO_BASE, CAN_INT_STS_CAUSE); // cause? if(ulIntStatus & CAN_INT_INTID_STATUS){ // receive? ulIDStatus = CANStatusGet(CANO BASE, CAN STS NEWDAT); for(i = 0; i < 32; i++){ //test every bit of the mask if( (0x1 << i) & ulIDStatus){ // if active, get data CANMessageGet(CAN0_BASE, (i+1), &xTempMsgObject, true); if(xTempMsgObject.ulMsgID == RCV_ID < N){</pre> barrier = barrier - 1; } CANIntClear(CAN0_BASE, ulIntStatus); // acknowledge extern sema4_t barrier; ) // send message to others, including ourselves CANO_SendMessage(); // wait until N messages from others, including ourselves, // are received while (*b > 0) \{ \}; // not a critical section here, we are only reading ``` ## **Problem 7 (15 points): Motor Interface** You are asked to design the interface for a DC motor that has a time constant of 40ms. a) Design and interface an H-bridge using N- and P-type power BJT/Darlington transistors. Add resistors as necessary, but do not add any other components not already shown. b) Show the output signals you need to create on the microcontroller's PB6 and PB7 ports to drive the motor in forward and backward direction at 1/4 of its maximum power. Also indicate (e.g. using dashed lines) how the signals would have to change to go to 3/4 power in either direction. c) For any PWM port that you use, what divider should the clock prescaler be set to (/2, /4, /8, etc.) and what period and duty cycle values should the PWM\_LOAD and PWM\_CMPA registers be loaded with, respectively, to generate the desired signals with maximum resolution? Assume a 80Mhz bus clock. | | ¼ speed ahead | 3/4 speed ahead | 1/4 speed astern | 3/4 speed astern | |-------------|---------------|-----------------|------------------|------------------| | PWM Divider | /8 | /8 | /8 | /8 | | PWM_x_LOAD | 40,000 | 40,000 | 40,000 | 40,000 | | PWM_x_CMPA | 10,000 | 30,000 | 30,000 | 10,000 |