On 12/17/2012 01:31 AM, Samuel Thibault wrote:
Cyril Roelandt, le Mon 17 Dec 2012 00:51:28 +0100, a écrit :
* libtreefs/dir-lookup.c (_treefs_s_dir_lookup): remove a redundant call to
pthread_mutex_unlock.
Signed-off-by: Cyril Roelandt<tipec...@gmail.com>
---
libtreefs/dir-lookup.c | 1 -
1 file changed, 1 deletion(-)
diff --git a/libtreefs/dir-lookup.c b/libtreefs/dir-lookup.c
index ce2acaf..41c34ea 100644
--- a/libtreefs/dir-lookup.c
+++ b/libtreefs/dir-lookup.c
@@ -199,7 +199,6 @@ _treefs_s_dir_lookup (struct treefs_handle *h,
in the right order. */
if (strcmp (path, "..") != 0)
{
- pthread_mutex_unlock (&node->lock);
pthread_mutex_lock (&dir->lock);
pthread_mutex_lock (&node->lock);
At quick sight I don't think this one is spurious, see the comment: this
code seems to be used when one wants to lock dir->lock, which we can
not do when we already have node->lock, that's why we have to release
node->lock before taking dir->lock again.
node->lock is unlocked at line 150 (before the do ... while block), so I
think that unlocking it at line 202 is an error. I'm not even sure where
it is locked in the first place: after line 61, we jump to the gotit label.
Cyril Roelandt.