Gamin (File Alteration Monitor) - Python 3 migration
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
2.2 KiB

4 years ago
  1. From cc14440eface093548cb3bc7814da11d9a99d283 Mon Sep 17 00:00:00 2001
  2. From: Anssi Hannula <anssi@mageia.org>
  3. Date: Wed, 4 Jan 2012 00:23:55 +0200
  4. Subject: [PATCH] fix possible server deadlock in ih_sub_cancel
  5. ih_sub_foreach() calls ih_sub_cancel() while inotify_lock is locked.
  6. However, ih_sub_cancel() locks it again, and locking GMutex recursively
  7. causes undefined behaviour.
  8. Fix that by removing locking from ih_sub_cancel() as ih_sub_foreach()
  9. is its only user. Also make the function static so that it won't
  10. accidentally get used by other files without locking (inotify-helper.h
  11. is an internal server header).
  12. This should fix the intermittent deadlocks I've been experiencing
  13. causing KDE applications to no longer start, and probably also
  14. http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=542361
  15. Origin: http://bugzilla-attachments.gnome.org/attachment.cgi?id=204537
  16. Bug-Ubuntu: https://bugs.launchpad.net/ubuntu/+source/gamin/+bug/926862
  17. Bug-Debian: http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=542361
  18. ---
  19. server/inotify-helper.c | 7 ++-----
  20. server/inotify-helper.h | 1 -
  21. 2 files changed, 2 insertions(+), 6 deletions(-)
  22. diff --git a/server/inotify-helper.c b/server/inotify-helper.c
  23. index d77203e..0789fa4 100644
  24. --- a/server/inotify-helper.c
  25. +++ b/server/inotify-helper.c
  26. @@ -123,13 +123,11 @@ ih_sub_add (ih_sub_t * sub)
  27. /**
  28. * Cancels a subscription which was being monitored.
  29. + * inotify_lock must be held when calling.
  30. */
  31. -gboolean
  32. +static gboolean
  33. ih_sub_cancel (ih_sub_t * sub)
  34. {
  35. - G_LOCK(inotify_lock);
  36. -
  37. -
  38. if (!sub->cancelled)
  39. {
  40. IH_W("cancelling %s\n", sub->pathname);
  41. @@ -140,7 +138,6 @@ ih_sub_cancel (ih_sub_t * sub)
  42. sub_list = g_list_remove (sub_list, sub);
  43. }
  44. - G_UNLOCK(inotify_lock);
  45. return TRUE;
  46. }
  47. diff --git a/server/inotify-helper.h b/server/inotify-helper.h
  48. index 5d3b6d0..d36b5fd 100644
  49. --- a/server/inotify-helper.h
  50. +++ b/server/inotify-helper.h
  51. @@ -34,7 +34,6 @@ gboolean ih_startup (event_callback_t ecb,
  52. found_callback_t fcb);
  53. gboolean ih_running (void);
  54. gboolean ih_sub_add (ih_sub_t *sub);
  55. -gboolean ih_sub_cancel (ih_sub_t *sub);
  56. /* Return FALSE from 'f' if the subscription should be cancelled */
  57. void ih_sub_foreach (void *callerdata, gboolean (*f)(ih_sub_t *sub, void *callerdata));
  58. --
  59. 1.7.7.2