#### Real Time Embedded Systems. 程Worksheet 45 ne Time Sicing Street 辅导

This week we start work on the central components of an elementary real-time operating system - we will call it a 'runtime the processor's time between separate user tasks. These tasks will need to be a 'software interrupt'.

#### Implementation of Sof

A software interrupt is k and the same and interrupts are some and interrupts from hardware devices to enter the operating system in a consistent way.

There are 16 trap instructions available, numbered 0 to 15, and written

weChat: cstutorcs

trap #0
...
trap #15

Assignment Project Exam Help

Each of the 16 trap instructions may have its own interrupt service routine (ISR). After pushing the PC and SR, the processor then accesses a table in low memory, at address 80H. As for the hardware interrupts, the table contains a 4-byte value corresponding to the address of the ISR for each software interrupt. Vedtos of the table to the table of table of table of the table of table

interrupt vecity 1349389476

org \$64 ;origin 64H

hvec1 dc.l hisr1 ;address of hardware ISR 1

hvec2 dc.l hisr2; https://tutorcs.com

org \$80 ;origin 80H

svec0 dc.l sisr0 ;address of software ISR 0

svec1 dc.l sisr1 ; ... etc

#### **Controlling Interrupts**

There is, however, an important difference between hardware and software interrupts. Hardware interrupts are in order of priority, with 7 being the highest priority and 1 the lowest. If two hardware interrupts occur at the same time, then the one at the higher priority will be accepted and the other one will be kept waiting until the first ISR has completed. If a hardware interrupt occurs shortly after another one, but while the ISR for the first interrupt is still in execution, then the processor will again compare the priorities of the two interrupts. If the new interrupt is of a higher priority, then it will interrupt the lower priority ISR. If the new interrupt is at a lower priority than the currently executing ISR, it will be kept waiting until that ISR completes.

Software interrupts do not behave in an analogous way. Since the processor can only execute one instruction at a time, it would be impossible for two software interrupts to occur at the same time, and unless a programmer includes a trap instruction within an ISR, there will also be no occasions on which a trap takes place during the processing of another trap. There is therefore no point in prioritising the software interrupts, and all 16 are at the same priority. There is, however, the question of the relative priority of the hardware and software interrupts. What if a hardware interrupt is raised at the same time as the processor is executing a software interrupt instruction? This is

handled by assigning all the software interrupts to priority level 0. Processing of a software interrupt is therefore interruptible that hardware interrupt at any of the bridge that

Within your system, however, regardless of the type of interrupt being processed, you will want to

uninterruptible. Once er un to completion and then return to the user task that was running when the ir value for which user task that you will therefore need to disable interrupt acceptance, the procedure for which user task that user task that you will therefore need to disable interrupt acceptance, the procedure for which user task that user task that you will therefore need to disable interrupt acceptance, the priority level of which user task that user task that you will therefore need to disable interrupt acceptance, the priority level of that user task that user task that you will therefore need to disable interrupt acceptance, the priority level of that user task that you will therefore need to disable interrupt acceptance, the priority level of that user task that was running when the ir value that represents the priority level of that user task that was running when the ir value that represents the priority level of that user task that was running when the ir value task that was running when the ir value task that was running when the ir value task that was running when the user task that was running when the ir value task that was running when the ir value task that was running when the user task that was running was running when the user task that was running when the user task that was running was running when the user task that was running was runnin

### or #\$0700,sr As; signmente Paroject Exam Help

The status register will have been automatically saved on the stack at the start of the interrupt servicing. On execution of the 'return from exception' instruction (RTE), it will be restored, and the mask reset to the zero value that it held blevlously thereby a lown the todeplance of any hardware interrupt that might have been raised in the meantime and is currently pending.

interrupt the software ISRV (with a preventible) the following instruction, placed at the very start of a software ISR, sets the mask to binary 111 (decimal 7). Any hardware interrupts will

If you want to enable hardware interrupts at any other time, the following instruction will set the mask to zero.

and #\$f8ff,sr ;enable hardware interrupts\*

now be disabled, and held pending until the mask is returned to zero.

https://tutorcs.com

# 程序代写代做 CS编程辅导

Work in groups of three was a system and the test programmes you used to demonstrate it.

Documentation:

An individual 5 - sentation from each member of the group, explaining parts the system and how they were tested. Each presentation should deal with specific aspects, and the three presentations together should cover the entire system.

The names and student white so all tree group members shown on the software heading and on the front page of the documentation. On the video presentations the name of the group member should be clearly announced or displayed as a caption.

There are therefore five them sold be submitted a single soft of the total phase presentations. These items should be placed into a single zipped file, and uploaded to a Canvas submission point to be advised. The submission deadline is 2pm on Friday 19th January, 2024.

Each item will now be described in detait utores @ 163.com

#### The run-time system

The work consists of writing a pasic/time-slicing system, along the lines of the one discussed in the lecture. It should allow the execution of several concurrent user tasks, with support for task scheduling and inter-task communication. An outline programme is provided on Canvas, but you will write the service routines (including reset), the scheduler, and the user tasks for each application.

The user tasks are located in memory, above the system itself. Each task has its own area of memory, with the programme code at the lowest address, data above it, and top-of-stack at the next address above this task's memory area. For example, the following task occupies memory between 2000H and 2FFFH. It has its code at 2000H, data at 2C00H, and stack at the top of the data area.

| Address |                |
|---------|----------------|
| 2000H   | Programme code |
| 2C00H   | Data           |
| 3000H   | Top-of-stack   |

The system runs in the foreground, and is entered following either a timer interrupt, a software interrupt from one of the tasks requesting service, or another hardware interrupt.

The following system calls should be supported by means of software interrupts. They can either each be allocated to a separate trap number, or (as in the demonstration system) they can all be called on the same trap, with one of the registers used to hold a value identifying the requested function. Some of the calls also require additional parameters in other registers.

1. Create task

A dimenty fundsed TEB is mark to a ir use all set in for a Function:

It is placed on the ready list. The requesting task remains on the ready list. Two parameters indicate the start and end of the memory area occupied by the new task

and its data

Parameters:

new task. stack.

2. Delete task

Function:

erminated, its TCB is removed from the list and memory allocated to it is returned to the system.

Parameters:

3. Wait mutex

Function: If the mutex variable is one, it is set to zero and the requesting task is placed

back onto the ready list. If the mutex is zero, the task is placed onto the wait list and subsequently transferred back to the ready list when another task executes a signal courtex. CSUUTOTCS

Parameters: None.

4. Signal mutex

If the significant of the signif Function:

is transferred to the ready list and the mutex remains at zero. If the mutex is zero and no task is waiting, the mutex is set to one. In either case, the requesting task remains

on the ready list.

tutorcs@163.com Parameters:

5. Initialise mutex

The mutex is set to the value 0 or 1, as specified in the parameter. Function:

Parameters: 749389476

6. Wait time

The requesting task is placed onto the wait list until the passage of the Function:

number of timer interrupts specified in the parameter, when it is transferred back to the ready list UTO CS. COM

Number of timer intervals to wait. Parameters:

The following functions are more difficult. Good results may be obtained without implementing these functions, but it would be expected that they will be included in the best submissions. Function 7 will require the use of an additional interrupt at level 2, and you will need to consider the implications of this for the correct working of the system. Function 8 will require some thought about the internal record-keeping relating to which areas of memory are in use. You will need to devise your own test programmes for these functions.

7. Wait I/O:

Function: The requesting task is placed onto the wait list, until an interrupt signifies

completion of an I/O operation, at which time the task is transferred back to the ready

list.

Parameters: None.

8. Allocate memory

Function: For tasks that require a large amount of memory, it is more efficient to allocate it as

> required when the task runs. A large area of memory is therefore kept free within the system, and a block from it, of say 16 kbytes, is returned to the requesting task. If the

request is satisfied, the requesting task remains on the ready list. If there is insufficient free memory available, then the requesting task is put on the wait list

until memory is returned when another task terminates.

Parameters: On return, the start address of the allocated memory is held in the parameter register. An additional function is executed automatically at start-up, or if the user presses the reset button. 在了代与代数CS编程第号

System reset

The system is initialised: all internal variables are reset, and each TCB is Function: <u>A TCB</u> for task T0 is then created, and T0 becomes

k, T0, is present. The system runs this task immediately The system assumes th redetermined address, which will be coded into the after a reset. It will neec reset function.

Your system should be errors in an intelligent way. For example, what if the user tries to create more e available TCBs?

#### **Test programmes**

Test your system using the following programmes: These are modified versions of the questions in last week's worksheet, this time running under your RTS.

Testing create tas Associate time functions. Project Exam Help 1.

A stopwatch counts in seconds. It starts when button 0 is pressed and stops when the button is

pressed again. It is programmed as follows.

Timer interrupts are set to 100ms. Task 0 starts task 1, and both tasks run concurrently. A shared variable running is held in a memory location, and is set by T1 and read by T0. T0 displays a 2digit value on the 7-segment display, initialised to zero If running is set, T0 increments the display, then waits for 1 time intervals and then repeats of running is not set, T0 does nothing. T1 tests pushbutton 0. Each time the button is pressed, running changes state.

Testing initialise nutex wait mutex and signal mutex functions. 2.

On a gaming device, two players each have a button that fires bullets. Internal counters a and b record the number of bullets fired by each player, and a third counter c records the total number of bullets fired. It would be difficult to programme this application on the simulator because it is not possible to press two buttons at once. This would often happen in reality, and dealing with it represents the most difficult technical challenge in the programming. However, we can focus on this specific problem by programming two tasks, one for each player, and having each task fire bullets continuously.

Timer interrupts are set to 100ms. Task 0 starts task1, and both tasks run concurrently. A shared variable c is held in a memory location (not a register) and is initialised to zero. Task 0 has a variable a, also in memory, and runs in a loop that continuously increments a and c. Task 1 has a variable b in memory, and runs in a loop that continuously increments b and c.

To check that the system is working, one of the tasks calculates a + b - c, which should be zero, and displays it on the 7-segment display.

A test of your own to check the delete task function. Also tests of the wait I/O and allocate memory functions, if you have implemented them.

Your test programmes should be included at the end of the RTS code. Place all the tests together. An individual one can then be selected by commenting out the others.

**Documentation** 

This consists of a user manual. It will explain your system to a user, and will therefore focus on what it does and how to use it. It will include a brief overview of how the system works internally, but only to an extent that is required to use the system correctly. It should be structured as follows.

1.
A general description, ir explanation of the description of the explanation of the

asking and time-slicing, and how they are implemented; he user tasks as shown above;

a default task runs, which may then start other tasks.

A description of each of the user functions and their parameters. Explain all aspects of the behaviour of each function that are protected to the user functions and their parameters. Explain all aspects of the behaviour of each function that are protected to the end of the ready queue? What if two tasks are waiting for the same time, and so become ready together? Give some emphasis to the behaviour of any of the more advanced features that you may have implemented. For example, if you have implemented function 7, you should explain a different interrupt or drifted have been landled interrupt, and how this affects the user. Your descriptions should also state how long each function takes to execute. This time should be quoted in terms of instructions, and may be within a specified range, e.g., a particular function might execute in 30 - 50 instructions.

A description of any other relevant aspects of system behaviour. For example, have you arranged for prioritised scheduling? If so how does it behave? If not, then are all tasks that are ready likely to receive a similar amount of our time? Is there any possibility that a task may receive too little time, or none at all? State the timer interrupt period, and how long (in terms of instructions) the system takes to switch tasks. Using a reasonable average for the instruction execution time, calculate the proportion of time that is spent in the RTS, and how much is available for running the user tasks.

zman: tutores@

With normal typeface and spacing (such as used here) it would be reasonable to expect a length of no more than five or six pages. Submission in .PDF format is preferred, but .DOC(X) is also acceptable.

#### Individual presentation

Each of the three group members should include an individual video presentation explaining particular parts of the system, how they worked, and how they were tested. These will probably be the functions with which that member was most closely involved in writing. Between the three presentations, the entire system should be explained.

These presentations will complement the written material in your documentation. Instead of describing how to use the system, they will explain in more depth how it works internally. They do not need to be long and detailed, but should focus on the underlying working principles of the software. It is unlikely to be necessary to talk about individual machine instructions, unless you are discussing a relevant concept such as mutual exclusion. You should also explain how each part of the system was tested, and how the test results verify its correctness.

Each presentation should last 5 - 10 minutes.

The Demonstration System 字代写代的 CS编程辅导

A system was demonstrated during the lecture. It recognises a hardware interrupt at level 1 from the timer. It also allows system calls by means of software interrupts, all of which have been allocated to trap 0. These system calls by means of software interrupts, all of which have been allocated to trap 0. These system calls by placing a value that identifies the requested function into data register 0, and the programmed by placing a value that identifies the requested function in registers D1 onwards. Figure 1 is used to create a new task. Suppose that this new task is called T1, a task is to be located at address 6000H. It would be programmed as follows

move.l # defined in d0
move.l # address of new task in d1
move.l #56000,d2 ;set stack address in d2
trap #0 ;call system

The main data structure week this system is a little task control blocks (TCBs). Each TCB represents the state of one of the tasks. It contains a copy of all that task's registers, together with some items of control information including a flag that indicates whether the TCB is in use.

At any time, each of the lasks will be in proof three states the currently Ximin ask, ready to run when its turn comes up, or unable to run because it is waiting for the occurrence of some event, which could be a signal operation on a mutex, the expiry of a time interval, or an I/O interrupt.

At initialisation, all the TCBs inthellist are blacked as an Ged. As each new lask is started, one of the unused TCBs is allocated for it and marked as used. These TCBs are organised into two linked lists, in which each element contains a pointer to the next element. These lists are called 'ready' and 'waiting'. Two more data items consist of pointers to the first element in each list. The pointer rdytcb holds the address of the first element in the list of Deady TCBs. The first element in this list is the task that actually is running. The linkage in this list is circular, that is, the last entry points back to the first, so making it easy to access each TCB in rotation. The pointer wttcb holds the address of the first element in the list of TCBs/that are waiting. Each element will contain an indication of the event the task is waiting for TCBs/that are waiting. Each element so this list in rotation, so the last element has its pointer set to zero.



The example above shows a list of 8 elements, each of which has a pointer, labelled N, to the next element. Elements 4, 6, 0 and 1 are on the ready list, with element 4 being the TCB for the running task. Elements 3 and 7 are on the waiting list, and elements 2 and 5 are unused.

The system is organised into the following sections. Some of these sections shown in italics, are provided for you in the office cope of Campas The campas



Fach TCD represents the state of one of the assument tools, and is defined as follows

```
Each TCB represents the state of one of the current tasks, and is defined as follows:

ASSIGNMENT Project Exam Help
tcb
                                                ;tcb record
tcbd0
                      1
                                                ; D register save
           ds.l
tcbd1
tcbd2
tcbd3
           ds.l
           ds.1 1 ds.1 1 ds.1 1
                            Email: tutorcs@163.com

    tcbd4
    ds.1
    1

    tcbd5
    ds.1
    1

    tcbd6
    ds.1
    1

    tcbd7
    ds.1
    1

    tcba0
    ds.1
    1

    tcba1
    ds.1
    1

    tcba2
    ds.1
    1

    tcba3
    ds.1
    1

    tcba4
    ds.1
    1

    tcba5
    ds.1
    1

tcbd4 ds.1
                             QQ: 749389476
                                                ; A register save
                            https://tutorcs.com
tcba5 ds.1
tcba6 ds.1
tcba7 ds.1
tcbsr ds.l
                                               ; SR (status reg) save
tcbpc ds.l 1
tcbnext ds.l 1
                                               ; PC save
                                               ; link to next record
tcbused ds.l 1
                                               ; record in use flag
           ds.l 1
                                               ; other fields as required
            ds.l
tcblen equ
                                                ; length of tcb record in bytes
```

#### Data storage

Storage for a list of TCBs is defined as in the first line below. The constant ntcb represents the number of TCBs in the list, and should be set up as an equate. Other variables are described throughout these notes.

```
tcblst ds.b tcblen*ntcb ;tcb list (length x no of tcbs)
rdytcb ds.l 1 ;^ ready tcb list
wttcb ds.l 1 ;^ waiting tcb list
a0sav ds.l 1 ;A0 temporary save
d0sav ds.l 1 ;D0 temporary save
id ds.l 1 ;function id
```

Interrupt vectors

程序代写代做 CS编程辅导

The interrupt vectors are addresses of the code that will be executed as a result of an interrupt. The following three addresses are defined.



Executable Code

Email: tutorcs@163.com

#### First-level interrupt handler

The first-level interrupt handler (FLH) contains the code that services an interrupt. For convenience it is split into the common PLH entry section that is executed immediately following an interrupt, and the FLIH service routines that carry out the processing specific to each type of interrupt.

### https://tutorcs.com

Hardware interrupts at level 1 are directed by the interrupt vector to enter the FLIH at fltint, while software interrupts arrive at flsint. The FLIH performs three main functions.

It takes the pointer to the TCB of the currently executing task, stored at rdytcb, and saves the values of the registers, including the PC and SR, within that TCB.

It also sets a value within a storage location, known as id, that identifies the source of the interrupt. If an interrupt has been raised by the hardware timer, then id is set to 0. For a software interrupt, id is set to the value, from 1 onwards, of the system call function number. The id will subsequently be used to select the corresponding service routine for processing this interrupt.

Programming the above two operations requires particular care, because saving the value of the user's registers as they were at the time of the interrupt requires the use of certain registers itself. Registers D0 and A0 are in use for this purpose. These registers are therefore saved in temporary locations, before being transferred to their long-term holding locations within the TCB.

The other function performed by the FLIH is to disable interrupts, if this has not already happened. A level-1 hardware interrupt from the timer will have set the interrupt priority mask to 1, thereby preventing any further interrupts. A software interrupt will have left the mask at 0, which would allow the timer device to interrupt the processing of the software interrupt. Therefore the first action taken at the software interrupt entry point is to disable hardware interrupts by setting the mask to 7.

```
程序代写作编辑
fltint
                                        ; ENTRY FROM TIMER INTERRUPT
       move.1
                                        ;save D0
       move.1
                #$0
                                        ; set id = 0
       move.1
               d0,
        move.1
               d0s⊾
                                        ;restore D0
flsint
                                        ; ENTRY FROM TRAP (SOFTWARE INTERRUPT)
                                        ; disable hardware interrupts
        or
       move.1
                d0,
                                        ;store id
       bra
                f11
       move.l a0, WeChat: cstutorcs
f11
                                             1st ready tcb (ie running tcb)
       move.l rdytcb, a0
       move.1 d0, tcbd0(a0)
                                        ;store registers
       move.1 d1, tAcs signment Project Exam Help
       move.1 d3,tcbd3(a0)
       move.1 d4,tcbd4(a0)
       move.1 d5, Epd5 and il: tutores@163.com
       move.1 d7, tcbd7(a0)
       move.l a0sav,d0
       \begin{array}{lll} & \text{move.1} & \text{d0, tcha} & \text{(a0)} \\ \text{move.1} & \text{a1, tcha} & \text{(a0)} \\ \end{array} \\ & \text{749389476} \\ \end{array}
       move.l a2,tcba2(a0)
       move.l a3,tcba3(a0)
       move.1 a4, tcba4(a0)
       move.1 a5, total ps://tutorcs.com
               (sp),d0
       move
                                        ;pop and store SR
        add.1 #2,sp
        move.l d0, tcbsr(a0)
       move.1 (sp),d0
                                        ;pop and store PC
        add.1 #4,sp
       move.1 d0,tcbpc(a0)
       move.l a7,tcba7(a0)
                                        :store SP
```

#### FLIH service routines, including system reset

The service routines are arranged as a large switch statement, using id as the case variable. Each routine carries out one of the functions defined in the specification.

;START OF SERVICE ROUTINES

#### Scheduler

The scheduler examines the ready list, to which rdytcb points to the first element. This is the TCB of the task that was executing when the system was invoked, and which has just been interrupted. By following the links, the scheduler can locate each TCB that is currently ready to run. It selects

one of these tasks for running, and adjusts the value in rdytab to point to the TCB for this task. This TCB will be then used by the dispatche to result execution the task.

The scheduler may make the decision as to which task will run next by doing nothing more than following the link in the ext one in the chain. This will result in each ready task running in rotation, receive a larger proportion of the available run time.

#### **Dispatcher**

;

The dispatcher reverses the action taken by the FLIH. Using the newly set value in rdytcb, it restores the registers of the selected task to the values that were stored when that task was interrupted. Careful housekeeping is again necessary, as this operation itself requires the use of registers D0 and A0. The dispatcher linishes by sected to the stack as it was after the task was interrupted. The processor then uses a 'return from exception' instruction, as though it were returning from any normal interrupt, to transfer control back to the selected task.

## Assignment Project Exam Help

Email: tutores@463.com

```
move.l rdytcb, a0
                                ;A0 ^ new running tcb
move.l tcbd all 749389476 registers move.l tcbd all 61749389476
move.l tcbd3(a0),d3
move.l tcbd4(a0),d4
move.l tcbd5(af),d5.//tutorcs.com
move.1 tcbd7(a0^{+}, d7)
move.l tcba1(a0),a1
move.l tcba2(a0),a2
move.l tcba3(a0),a3
move.l tcba4(a0),a4
move.l tcba5(a0),a5
move.l tcba6(a0),a6
move.l tcba7(a0),a7
sub.1 #4,sp
                                ; push PC
move.l tcbpc(a0),d0
move.1 d0, (sp)
sub.1 #2,sp
move.l tcbsr(a0),d0
                                ; push SR
move
       d0,(sp)
move.l tcbd0(a0),d0
                                ; restore remaining registers
move.l tcba0(a0),a0
rte
                                ;return
```

move.b d0,led

t10

res

bra

END

An example of a user programme running under this system is shown here. It consists of two concurrent tasks. Task To Falls the system start task T1 the some for the FileD. Task T1 calls the system to wait for 3 timer intervals, then switches on the LH LED. From then on, the two tasks run alternately. If the timer is set to interrupt at one-second intervals, the result is that the RH LED lights immediately. the two LEDs start alternating. ;USER APPLICATION TASKS tem call equates 0 stem call trap (trap 0) sys 1 syscr equ **L**reate new task 2 sysdel equ delete task syswttm equ wait on timer ssignment Project Exam Help orq \$e00010 ;led led equ \$e00014 ;switch SW equ tutores@163.com t0: ;start task 1 #sysscr,d0 move.1 #t1,d1 address move.1 #\$4000, move.1 trap #sys プ**う**orepeat t00: move.1 #\$01,d1 set led 0 d1,led move.b toohttps://tutorcs.com bra t1: ;TASK 1 move.1 #syswttm,d0 ; wait for 3 clocks move.1 #3,d1 trap #sys ;repeat t10: move.1 #\$02,d0 ; set led 1