1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
= Opgaver til gang 8
:stem:
== Opgave 1
Given a periodic taskset : T1=4,c1=3,T2=12,c2=2 with relative deadlines d1=4,d2=7
. Examine the taskset w.r.t. schedulability using the exact criterion for DMA scheduling. Is the taskset EDF schedulable ?
=== Løsning
____
_Examine the taskset w.r.t. schedulability using the exact criterion for DMA scheduling._
____
Her kan man se at følgende priority scheme skal bruges.
(T1, T2)
Nu giver det mening at undersøge om dette er feasable.
For T1 er completion time 3, hvilket er under dens deadline.
For T2.
image::M8f1.png[]
Her kan man se at completion time er 8 hvilket er efter T2's deadline.
Derfor er DMA ikke feasable.
Dette kan man også se hvis man kører det.
----
0 3 2 4 7
1 | 2 2 3 6
2 | 1 2 2 5
3 | 0 2 1 4
4 | 3 1 4 3
5 | 2 1 3 2
6 | 1 1 2 1
Deadline missed in task 1
----
____
Is the taskset EDF schedulable?
____
Når man kører med EDF kan man se at der ikke er mere arbejde efter LCM.
----
0 3 2 4 7
1 | 2 2 3 6
2 | 1 2 2 5
3 | 0 2 1 4
4 | 3 1 4 3
5 | 3 0 3 2
6 | 2 0 2 1
7 | 1 0 1 0
8 | 2 0 4 -1
9 | 1 0 3 -2
10 | 0 0 2 -3
11 0 0 1 -4
----
== Opgave 2
Given a periodic taskset T1=40,c1=10,d1=20,T2=60,c2=20,d2=30,T3=80,c3=20,d3=80,(milliseconds) where task1 and task2 share data protected by semaphore S.
Accessing the shared data lasts no more than 10 (time units-mill sec).
Priority ceiling or immediate ceiling is assumed.
. Is the taskset DMA schedulable ?
. If the data above are instead shared between task1 and task3, is the taskset then DMA schedulable.
=== Løsning
____
_Is the taskset DMA schedulable?_
____
Her bruger jeg den nye formel for at finde completion time.
stem:[C_i = c_i + \sum_{j=1}{i-1}ceil(C_i/T_j) * c_j + B_i]
Ved DMA bliver prioriteten (T1, T2, T3).
Task 1 kan godt vente på T2, men T2 skal ikke vente på nogen.
----
C1 = 10 + 10 = 20
C2 = 20 + ceil(C2/40)*10
C3 = 20 + ceil(C3/60)*20 + ceil(C3/40)*10
----
T1 bliver færdig lige inden dens deadline.
Først plottes C2.
image::M8f2.png[]
Her kan man se at den completer inden dens deadline 30.
Under kan man se at T3 også bliver færdig, når man plotter C3.
image::M8f3.png[]
____
_If the data above are instead shared between task1 and task3, is the taskset then DMA schedulable._
____
Her ændres C1 til C3 sig overhovedet ikke, da T1 alligevel skal vente 10.
----
C1 = 10 + 10 = 20
C2 = 20 + ceil(C2/40)*10
C3 = 20 + ceil(C3/60)*20 + ceil(C3/40)*10
----
== Opgave 3
Implement the example of ex. 2) on JDN's kernel and measure worst case completion times.
|