diff options
author | Glenn Elliott <gelliott@cs.unc.edu> | 2010-07-12 13:03:42 -0400 |
---|---|---|
committer | Glenn Elliott <gelliott@cs.unc.edu> | 2010-08-03 12:42:59 -0400 |
commit | 25b7346d1cf87d2eeb86f4d3a584b04aca5509a0 (patch) | |
tree | cfdde9e4656f0f0316fc2e393edc4bda2b4c2cae | |
parent | 136a08dbe8c28e751b01e932420f715edb229f6b (diff) |
Restructure pi_semaphore struct for generic inheritance framework.
First patch in a series to implement a generic priority inheritance
framework that can be used by semaphores that use priority inheritance.
This patch makes pi_semaphore a 'base class' for pi-protocols. pi_semaphore
is updated to include a pi_sem_record field named stack_node. This stack_node
is a linked-list node that a task holding the pi_semaphore instance adds to
their semaphore stack. Note that the task's semaphore stack (or linked-list)
simply chains stack_node's of held semaphores into a single linked-list.
This is safe since there is only one semaphore holder at any given moment.
Finally, FMLP-specific data members out to child class fmlp_semaphore.
-rw-r--r-- | include/litmus/fdso.h | 2 | ||||
-rw-r--r-- | include/litmus/rt_param.h | 22 | ||||
-rw-r--r-- | include/litmus/sched_plugin.h | 29 | ||||
-rw-r--r-- | litmus/Kconfig | 8 |
4 files changed, 56 insertions, 5 deletions
diff --git a/include/litmus/fdso.h b/include/litmus/fdso.h index 61f1b5baf42c..b0e62a9098bd 100644 --- a/include/litmus/fdso.h +++ b/include/litmus/fdso.h | |||
@@ -62,7 +62,7 @@ static inline void* od_lookup(int od, obj_type_t type) | |||
62 | return e && e->obj->type == type ? e->obj->obj : NULL; | 62 | return e && e->obj->type == type ? e->obj->obj : NULL; |
63 | } | 63 | } |
64 | 64 | ||
65 | #define lookup_fmlp_sem(od)((struct pi_semaphore*) od_lookup(od, FMLP_SEM)) | 65 | #define lookup_fmlp_sem(od)((struct fmlp_semaphore*) od_lookup(od, FMLP_SEM)) |
66 | #define lookup_srp_sem(od) ((struct srp_semaphore*) od_lookup(od, SRP_SEM)) | 66 | #define lookup_srp_sem(od) ((struct srp_semaphore*) od_lookup(od, SRP_SEM)) |
67 | #define lookup_ics(od) ((struct ics*) od_lookup(od, ICS_ID)) | 67 | #define lookup_ics(od) ((struct ics*) od_lookup(od, ICS_ID)) |
68 | 68 | ||
diff --git a/include/litmus/rt_param.h b/include/litmus/rt_param.h index a7a183f34a80..6f40b52f0802 100644 --- a/include/litmus/rt_param.h +++ b/include/litmus/rt_param.h | |||
@@ -92,6 +92,28 @@ struct rt_job { | |||
92 | unsigned int job_no; | 92 | unsigned int job_no; |
93 | }; | 93 | }; |
94 | 94 | ||
95 | #ifdef CONFIG_PI_SEMAPHORES | ||
96 | /* Record for storing a held lock and associated priority inheritance. | ||
97 | * Records are stored in a linked-list stack to support priority | ||
98 | * inheritance of nested critical sections. | ||
99 | * | ||
100 | * When strung together in a stack, nodes provide a record | ||
101 | * of currently held semaphores and order in which they were | ||
102 | * acquired. | ||
103 | */ | ||
104 | struct pi_sem_record { | ||
105 | /* Pointer to inheritance-donating job. | ||
106 | * May be set to "self" if there is no active | ||
107 | * inheritance from this semaphore. | ||
108 | */ | ||
109 | struct task_struct *inh_task; | ||
110 | |||
111 | struct list_head list; | ||
112 | }; | ||
113 | |||
114 | typedef struct pi_sem_record pi_sem_record_t; | ||
115 | #endif | ||
116 | |||
95 | struct pfair_param; | 117 | struct pfair_param; |
96 | 118 | ||
97 | /* RT task parameters for scheduling extensions | 119 | /* RT task parameters for scheduling extensions |
diff --git a/include/litmus/sched_plugin.h b/include/litmus/sched_plugin.h index 9c1c9f28ba79..071e809564b2 100644 --- a/include/litmus/sched_plugin.h +++ b/include/litmus/sched_plugin.h | |||
@@ -7,6 +7,7 @@ | |||
7 | 7 | ||
8 | #include <linux/sched.h> | 8 | #include <linux/sched.h> |
9 | 9 | ||
10 | #ifdef CONFIG_PI_SEMAPHORES | ||
10 | /* struct for semaphore with priority inheritance */ | 11 | /* struct for semaphore with priority inheritance */ |
11 | struct pi_semaphore { | 12 | struct pi_semaphore { |
12 | atomic_t count; | 13 | atomic_t count; |
@@ -17,10 +18,29 @@ struct pi_semaphore { | |||
17 | struct task_struct *task; | 18 | struct task_struct *task; |
18 | struct task_struct* cpu_task[NR_CPUS]; | 19 | struct task_struct* cpu_task[NR_CPUS]; |
19 | } hp; | 20 | } hp; |
21 | |||
22 | /* lock stack */ | ||
23 | struct pi_sem_record stack_node; | ||
24 | }; | ||
25 | |||
26 | static inline struct pi_semaphore* to_pi(void *sem) { | ||
27 | return (struct pi_semaphore*)sem; | ||
28 | } | ||
29 | #endif | ||
30 | |||
31 | #ifdef CONFIG_FMLP | ||
32 | struct fmlp_semaphore { | ||
33 | struct pi_semaphore pi; /* must always be first. */ | ||
34 | |||
20 | /* current lock holder */ | 35 | /* current lock holder */ |
21 | struct task_struct *holder; | 36 | struct task_struct *holder; |
22 | }; | 37 | }; |
23 | 38 | ||
39 | static inline struct fmlp_semaphore* to_fmlp(struct pi_semaphore* sem) { | ||
40 | return (struct fmlp_semaphore*)sem; | ||
41 | } | ||
42 | #endif | ||
43 | |||
24 | /************************ setup/tear down ********************/ | 44 | /************************ setup/tear down ********************/ |
25 | 45 | ||
26 | typedef long (*activate_plugin_t) (void); | 46 | typedef long (*activate_plugin_t) (void); |
@@ -63,6 +83,7 @@ typedef void (*task_block_t) (struct task_struct *task); | |||
63 | */ | 83 | */ |
64 | typedef void (*task_exit_t) (struct task_struct *); | 84 | typedef void (*task_exit_t) (struct task_struct *); |
65 | 85 | ||
86 | #ifdef CONFIG_PI_SEMAPHORES | ||
66 | /* Called when the new_owner is released from the wait queue | 87 | /* Called when the new_owner is released from the wait queue |
67 | * it should now inherit the priority from sem, _before_ it gets readded | 88 | * it should now inherit the priority from sem, _before_ it gets readded |
68 | * to any queue | 89 | * to any queue |
@@ -79,7 +100,7 @@ typedef long (*return_priority_t) (struct pi_semaphore *sem); | |||
79 | * priority is higher than that of the current holder. | 100 | * priority is higher than that of the current holder. |
80 | */ | 101 | */ |
81 | typedef long (*pi_block_t) (struct pi_semaphore *sem, struct task_struct *t); | 102 | typedef long (*pi_block_t) (struct pi_semaphore *sem, struct task_struct *t); |
82 | 103 | #endif | |
83 | 104 | ||
84 | 105 | ||
85 | 106 | ||
@@ -124,9 +145,9 @@ struct sched_plugin { | |||
124 | #ifdef CONFIG_FMLP | 145 | #ifdef CONFIG_FMLP |
125 | /* priority inheritance */ | 146 | /* priority inheritance */ |
126 | unsigned int fmlp_active; | 147 | unsigned int fmlp_active; |
127 | inherit_priority_t inherit_priority; | 148 | inherit_priority_t fmlp_inherit_priority; |
128 | return_priority_t return_priority; | 149 | return_priority_t fmlp_return_priority; |
129 | pi_block_t pi_block; | 150 | pi_block_t fmlp_pi_block; |
130 | #endif | 151 | #endif |
131 | } __attribute__ ((__aligned__(SMP_CACHE_BYTES))); | 152 | } __attribute__ ((__aligned__(SMP_CACHE_BYTES))); |
132 | 153 | ||
diff --git a/litmus/Kconfig b/litmus/Kconfig index 9888589ef126..e00887e672df 100644 --- a/litmus/Kconfig +++ b/litmus/Kconfig | |||
@@ -58,9 +58,17 @@ config SRP | |||
58 | Say Yes if you want FMLP local long critical section | 58 | Say Yes if you want FMLP local long critical section |
59 | synchronization support. | 59 | synchronization support. |
60 | 60 | ||
61 | config PI_SEMAPHORES | ||
62 | bool "Semaphores with Priority Inheritance" | ||
63 | default n | ||
64 | help | ||
65 | Generalized support for all Litmus priority inheriting semaphore | ||
66 | protocols. | ||
67 | |||
61 | config FMLP | 68 | config FMLP |
62 | bool "FMLP support" | 69 | bool "FMLP support" |
63 | depends on NP_SECTION | 70 | depends on NP_SECTION |
71 | depends on PI_SEMAPHORES | ||
64 | default n | 72 | default n |
65 | help | 73 | help |
66 | Include support for deterministic multiprocessor real-time | 74 | Include support for deterministic multiprocessor real-time |