struct context
{
GSList *pending_tokens;
- GStaticMutex lock;
+ GMutex lock;
GWakeup *wakeup;
gboolean quit;
};
static void
context_init (struct context *ctx)
{
- GStaticMutex lock = G_STATIC_MUTEX_INIT;
-
ctx->pending_tokens = NULL;
- ctx->lock = lock;
+ g_mutex_init (&ctx->lock);
ctx->wakeup = g_wakeup_new ();
ctx->quit = FALSE;
}
{
struct token *token;
- g_static_mutex_lock (&ctx->lock);
+ g_mutex_lock (&ctx->lock);
token = ctx->pending_tokens->data;
ctx->pending_tokens = g_slist_remove_link (ctx->pending_tokens,
ctx->pending_tokens);
- g_static_mutex_unlock (&ctx->lock);
+ g_mutex_unlock (&ctx->lock);
return token;
}
{
g_assert (token->owner == ctx);
- g_static_mutex_lock (&ctx->lock);
+ g_mutex_lock (&ctx->lock);
ctx->pending_tokens = g_slist_prepend (ctx->pending_tokens, token);
- g_static_mutex_unlock (&ctx->lock);
+ g_mutex_unlock (&ctx->lock);
g_wakeup_signal (ctx->wakeup);
}
static GStaticPrivate test_g_static_private_private1 = G_STATIC_PRIVATE_INIT;
static GStaticPrivate test_g_static_private_private2 = G_STATIC_PRIVATE_INIT;
-static GStaticMutex test_g_static_private_mutex = G_STATIC_MUTEX_INIT;
+static GMutex test_g_static_private_mutex = G_MUTEX_INIT;
static guint test_g_static_private_counter = 0;
static guint test_g_static_private_ready = 0;
static gpointer
test_g_static_private_constructor (void)
{
- g_static_mutex_lock (&test_g_static_private_mutex);
+ g_mutex_lock (&test_g_static_private_mutex);
test_g_static_private_counter++;
- g_static_mutex_unlock (&test_g_static_private_mutex);
+ g_mutex_unlock (&test_g_static_private_mutex);
return g_new (guint,1);
}
static void
test_g_static_private_destructor (gpointer data)
{
- g_static_mutex_lock (&test_g_static_private_mutex);
+ g_mutex_lock (&test_g_static_private_mutex);
test_g_static_private_counter--;
- g_static_mutex_unlock (&test_g_static_private_mutex);
+ g_mutex_unlock (&test_g_static_private_mutex);
g_free (data);
}
g_assert (number == *private1);
g_assert (number * 2 == *private2);
}
- g_static_mutex_lock (&test_g_static_private_mutex);
+ g_mutex_lock (&test_g_static_private_mutex);
test_g_static_private_ready++;
- g_static_mutex_unlock (&test_g_static_private_mutex);
+ g_mutex_unlock (&test_g_static_private_mutex);
/* Busy wait is not nice but that's just a test */
while (test_g_static_private_ready != 0)