diff options
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/workqueue.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/include/linux/workqueue.h b/include/linux/workqueue.h index 25e02c941bac..a5c6cd3210be 100644 --- a/include/linux/workqueue.h +++ b/include/linux/workqueue.h | |||
| @@ -83,6 +83,9 @@ struct work_struct { | |||
| 83 | #ifdef CONFIG_LOCKDEP | 83 | #ifdef CONFIG_LOCKDEP |
| 84 | struct lockdep_map lockdep_map; | 84 | struct lockdep_map lockdep_map; |
| 85 | #endif | 85 | #endif |
| 86 | #ifdef CONFIG_LITMUS_SOFTIRQD | ||
| 87 | struct task_struct *owner; | ||
| 88 | #endif | ||
| 86 | }; | 89 | }; |
| 87 | 90 | ||
| 88 | #define WORK_DATA_INIT() ATOMIC_LONG_INIT(WORK_STRUCT_NO_CPU) | 91 | #define WORK_DATA_INIT() ATOMIC_LONG_INIT(WORK_STRUCT_NO_CPU) |
| @@ -115,11 +118,25 @@ struct execute_work { | |||
| 115 | #define __WORK_INIT_LOCKDEP_MAP(n, k) | 118 | #define __WORK_INIT_LOCKDEP_MAP(n, k) |
| 116 | #endif | 119 | #endif |
| 117 | 120 | ||
| 121 | #ifdef CONFIG_LITMUS_SOFTIRQD | ||
| 122 | #define __WORK_INIT_OWNER() \ | ||
| 123 | .owner = NULL, | ||
| 124 | |||
| 125 | #define PREPARE_OWNER(_work, _owner) \ | ||
| 126 | do { \ | ||
| 127 | (_work)->owner = (_owner); \ | ||
| 128 | } while(0) | ||
| 129 | #else | ||
| 130 | #define __WORK_INIT_OWNER() | ||
| 131 | #define PREPARE_OWNER(_work, _owner) | ||
| 132 | #endif | ||
| 133 | |||
| 118 | #define __WORK_INITIALIZER(n, f) { \ | 134 | #define __WORK_INITIALIZER(n, f) { \ |
| 119 | .data = WORK_DATA_STATIC_INIT(), \ | 135 | .data = WORK_DATA_STATIC_INIT(), \ |
| 120 | .entry = { &(n).entry, &(n).entry }, \ | 136 | .entry = { &(n).entry, &(n).entry }, \ |
| 121 | .func = (f), \ | 137 | .func = (f), \ |
| 122 | __WORK_INIT_LOCKDEP_MAP(#n, &(n)) \ | 138 | __WORK_INIT_LOCKDEP_MAP(#n, &(n)) \ |
| 139 | __WORK_INIT_OWNER() \ | ||
| 123 | } | 140 | } |
| 124 | 141 | ||
| 125 | #define __DELAYED_WORK_INITIALIZER(n, f) { \ | 142 | #define __DELAYED_WORK_INITIALIZER(n, f) { \ |
