Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 428e6ce0 authored by Pavel Emelianov's avatar Pavel Emelianov Committed by Linus Torvalds
Browse files

Lockdep treats down_write_trylock like regular down_write



This causes constructions like

down_write(&mm1->mmap_sem);
if (down_write_trylock(&mm2->mmap_sem)) {
       ...
       up_write(&mm2->mmap_sem);
}
up_write(&mm1->mmap_sem);

generate a lockdep warning about circular locking dependence.

Call rwsem_acquire() with trylock set to 1.

Cc: Ingo Molnar <mingo@elte.hu>
Cc: Arjan van de Ven <arjan@infradead.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 644fd4f5
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -60,7 +60,7 @@ int down_write_trylock(struct rw_semaphore *sem)
	int ret = __down_write_trylock(sem);
	int ret = __down_write_trylock(sem);


	if (ret == 1)
	if (ret == 1)
		rwsem_acquire(&sem->dep_map, 0, 0, _RET_IP_);
		rwsem_acquire(&sem->dep_map, 0, 1, _RET_IP_);
	return ret;
	return ret;
}
}