diff options
author | Jeremy Huddleston <jeremyhu@apple.com> | 2012-04-23 16:43:22 -0700 |
---|---|---|
committer | Jeremy Huddleston <jeremyhu@apple.com> | 2012-04-24 00:27:07 -0700 |
commit | 69d8a25d429bccf960e98e5c126e1ef2ae4ffe9d (patch) | |
tree | be3262ad05eabe313e52e9b90eb0e06de43f9886 | |
parent | 6095a17534c2694760300701fee59a320950f271 (diff) |
darwin: Eliminate a pthread mutex leak
Signed-off-by: Jeremy Huddleston <jeremyhu@apple.com>
Tested-by: Charles Davis <cdavis@mines.edu>
(cherry picked from commit 1a33c1b2b895566299ec76643659adacc239a3dc)
-rw-r--r-- | src/glx/apple/apple_glx_drawable.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/glx/apple/apple_glx_drawable.c b/src/glx/apple/apple_glx_drawable.c index 55302243358..db283023a63 100644 --- a/src/glx/apple/apple_glx_drawable.c +++ b/src/glx/apple/apple_glx_drawable.c @@ -135,6 +135,7 @@ release_drawable(struct apple_glx_drawable *d) static bool destroy_drawable(struct apple_glx_drawable *d) { + int err; d->lock(d); @@ -172,6 +173,12 @@ destroy_drawable(struct apple_glx_drawable *d) apple_glx_diagnostic("%s: freeing %p\n", __func__, (void *) d); + err = pthread_mutex_destroy(&d->mutex); + if (err) { + fprintf(stderr, "pthread_mutex_destroy error: %s\n", strerror(err)); + abort(); + } + free(d); /* So that the locks are balanced and the caller correctly unlocks. */ |