summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorBernd Schmidt <bernd.schmidt@analog.com>2007-10-21 22:32:27 +0800
committerBryan Wu <bryan.wu@analog.com>2007-10-21 22:32:27 +0800
commitc1e7399da76646f34c3857147cca649cd58745af (patch)
tree5e40d681f6d1186102f250b9c0659fbeff29d5fe /arch
parenteaa854902aaeeade4a28cc8987de2b2ce182003b (diff)
downloadlinux-c1e7399da76646f34c3857147cca649cd58745af.tar.gz
linux-c1e7399da76646f34c3857147cca649cd58745af.tar.bz2
linux-c1e7399da76646f34c3857147cca649cd58745af.zip
Blackfin arch: Fixing Bug: balance calls to get_task_mm with corresponding mmput calls
We must balance calls to get_task_mm with corresponding mmput calls, otherwise refcounting is screwed up and mms don't get freed when their task exits. Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/blackfin/kernel/traps.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/blackfin/kernel/traps.c b/arch/blackfin/kernel/traps.c
index 8823e9ade584..afd044e78af6 100644
--- a/arch/blackfin/kernel/traps.c
+++ b/arch/blackfin/kernel/traps.c
@@ -118,12 +118,14 @@ static int printk_address(unsigned long address)
offset = (address - vma->vm_start) + (vma->vm_pgoff << PAGE_SHIFT);
write_unlock_irq(&tasklist_lock);
+ mmput(mm);
return printk("<0x%p> [ %s + 0x%lx ]",
(void *)address, name, offset);
}
vml = vml->next;
}
+ mmput(mm);
}
write_unlock_irq(&tasklist_lock);