The patch:
[PATCH 2/5] cpuset: rebind numa vma mempolicy
requires this fix to avoid a deadlock situation
in certain cpuset removal cases.
It's ok to not complete the refresh_mems() operation
if we notice we are already holding mmap_sem. We
will try again, next time we allocate memory.
Signed-off-by: Paul Jackson <[email protected]>
---
(This fix was included in my testing, but in another
patch that has not been sent in yet.)
kernel/cpuset.c | 5 +++++
1 files changed, 5 insertions(+)
--- 2.6.14-rc5-mm1-cpuset-patches.orig/kernel/cpuset.c 2005-11-03 21:18:26.783391082 -0800
+++ 2.6.14-rc5-mm1-cpuset-patches/kernel/cpuset.c 2005-11-03 23:11:15.480042373 -0800
@@ -656,7 +656,12 @@ static void refresh_mems(void)
if (current->cpuset_mems_generation != my_cpusets_mem_gen) {
struct cpuset *cs;
nodemask_t oldmem = current->mems_allowed;
+ struct mm_struct *mm = current->mm;
+ /* numa_policy_rebind() needs mmap_sem - don't nest */
+ if (!mm || !down_write_trylock(&mm->mmap_sem))
+ return;
+ up_write(&mm->mmap_sem);
down(&callback_sem);
task_lock(current);
cs = current->cpuset;
--
I won't rest till it's the best ...
Programmer, Linux Scalability
Paul Jackson <[email protected]> 1.650.933.1373
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]