Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 16887
b: refs/heads/master
c: 4369ef3
h: refs/heads/master
i:
  16885: 4bb1eaa
  16883: b2300e1
  16879: ee325b6
v: v3
  • Loading branch information
Paul E. McKenney authored and Linus Torvalds committed Jan 9, 2006
1 parent cada9d0 commit b6e7b66
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 16 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: eafbaa94691f6a1fa67c3b076caa3ce4e2920100
refs/heads/master: 4369ef3c3e9d3bd9b879580678778f558d481e90
30 changes: 15 additions & 15 deletions trunk/drivers/oprofile/buffer_sync.c
Original file line number Diff line number Diff line change
Expand Up @@ -43,13 +43,16 @@ static void process_task_mortuary(void);
* list for processing. Only after two full buffer syncs
* does the task eventually get freed, because by then
* we are sure we will not reference it again.
* Can be invoked from softirq via RCU callback due to
* call_rcu() of the task struct, hence the _irqsave.
*/
static int task_free_notify(struct notifier_block * self, unsigned long val, void * data)
{
unsigned long flags;
struct task_struct * task = data;
spin_lock(&task_mortuary);
spin_lock_irqsave(&task_mortuary, flags);
list_add(&task->tasks, &dying_tasks);
spin_unlock(&task_mortuary);
spin_unlock_irqrestore(&task_mortuary, flags);
return NOTIFY_OK;
}

Expand Down Expand Up @@ -431,25 +434,22 @@ static void increment_tail(struct oprofile_cpu_buffer * b)
*/
static void process_task_mortuary(void)
{
struct list_head * pos;
struct list_head * pos2;
unsigned long flags;
LIST_HEAD(local_dead_tasks);
struct task_struct * task;
struct task_struct * ttask;

spin_lock(&task_mortuary);
spin_lock_irqsave(&task_mortuary, flags);

list_for_each_safe(pos, pos2, &dead_tasks) {
task = list_entry(pos, struct task_struct, tasks);
list_del(&task->tasks);
free_task(task);
}
list_splice_init(&dead_tasks, &local_dead_tasks);
list_splice_init(&dying_tasks, &dead_tasks);

list_for_each_safe(pos, pos2, &dying_tasks) {
task = list_entry(pos, struct task_struct, tasks);
spin_unlock_irqrestore(&task_mortuary, flags);

list_for_each_entry_safe(task, ttask, &local_dead_tasks, tasks) {
list_del(&task->tasks);
list_add_tail(&task->tasks, &dead_tasks);
free_task(task);
}

spin_unlock(&task_mortuary);
}


Expand Down

0 comments on commit b6e7b66

Please sign in to comment.