summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeremy Huddleston <jeremyhu@apple.com>2012-04-23 16:43:22 -0700
committerJeremy Huddleston <jeremyhu@apple.com>2012-04-24 00:27:07 -0700
commit69d8a25d429bccf960e98e5c126e1ef2ae4ffe9d (patch)
treebe3262ad05eabe313e52e9b90eb0e06de43f9886
parent6095a17534c2694760300701fee59a320950f271 (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.c7
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. */