[vlc-devel] [PATCH v3] keystore/file: use POSIX file locking when flock() is unavailable

Sean McGovern gseanmcg at gmail.com
Tue Apr 12 17:14:37 CEST 2016


Additionally, remove the unlock call as fclose() will drop
the lock for us.
---
I helieve this properly handles both read and write locking as necessary now.
---
 modules/keystore/file.c |   42 +++++++++++++++++++++++++++++++++++-------
 1 file changed, 35 insertions(+), 7 deletions(-)

diff --git a/modules/keystore/file.c b/modules/keystore/file.c
index 381ec87..794cb04 100644
--- a/modules/keystore/file.c
+++ b/modules/keystore/file.c
@@ -27,6 +27,9 @@
 #ifdef HAVE_FLOCK
 #include <sys/file.h>
 #endif
+#ifdef HAVE_FCNTL
+#include <fcntl.h>
+#endif
 
 #include <vlc_common.h>
 #include <vlc_plugin.h>
@@ -262,6 +265,27 @@ end:
     }
     return VLC_SUCCESS;
 }
+ 
+#if (!defined(HAVE_FLOCK) && defined (HAVE_FCNTL) && defined (F_SETLKW))
+static int
+posix_lock_fd(int fd)
+{
+    struct flock lock;
+    int flags;
+    
+    if(fd == -1)
+        return -1;
+
+    flags = fcntl(fd, F_GETFL);
+    
+    lock.l_start = 0;
+    lock.l_len = 0;
+    lock.l_whence = SEEK_SET;
+    lock.l_type = (flags & O_ACCMODE) == O_RDONLY ? F_RDLCK : F_WRLCK;
+    
+    return fcntl(fd, F_SETLKW, &lock);
+}
+#endif
 
 static int
 file_open(const char *psz_file, const char *psz_mode, FILE **pp_file)
@@ -279,17 +303,21 @@ file_open(const char *psz_file, const char *psz_mode, FILE **pp_file)
     {
         fclose(p_file);
     }
+#else
+#if defined (HAVE_FCNTL) && defined (F_SETLKW)
+    if (posix_lock_fd(i_fd) != 0)
+    {
+        fclose(p_file);
+    }
+#endif
 #endif
     *pp_file = p_file;
     return i_fd;
 }
 
 static void
-file_close(FILE *p_file, int i_fd)
+file_close(FILE *p_file)
 {
-#ifdef HAVE_FLOCK
-    flock(i_fd, LOCK_UN);
-#endif
     fclose(p_file);
 }
 
@@ -349,7 +377,7 @@ Store(vlc_keystore *p_keystore, const char *const ppsz_values[KEY_MAX],
     i_ret = file_save(p_keystore, p_file, i_fd, &list);
 
 end:
-    file_close(p_file, i_fd);
+    file_close(p_file);
     ks_list_free(&list);
     return i_ret;
 }
@@ -413,7 +441,7 @@ Find(vlc_keystore *p_keystore, const char *const ppsz_values[KEY_MAX],
 
     *pp_entries = out_list.p_entries;
 end:
-    file_close(p_file, i_fd);
+    file_close(p_file);
     ks_list_free(&list);
     return out_list.i_count;
 }
@@ -445,7 +473,7 @@ Remove(vlc_keystore *p_keystore, const char *const ppsz_values[KEY_MAX])
         i_count = 0;
 
 end:
-    file_close(p_file, i_fd);
+    file_close(p_file);
     ks_list_free(&list);
     return i_count;
 }
-- 
1.7.9.2



More information about the vlc-devel mailing list