Blame glib/tests/slice.c

Packit ae235b
#include <string.h>
Packit ae235b
#include <glib.h>
Packit ae235b
Packit ae235b
/* We test deprecated functionality here */
Packit ae235b
G_GNUC_BEGIN_IGNORE_DEPRECATIONS
Packit ae235b
Packit ae235b
#ifdef G_ENABLE_DEBUG
Packit ae235b
static void
Packit ae235b
test_slice_nodebug (void)
Packit ae235b
{
Packit ae235b
  const gchar *oldval;
Packit ae235b
Packit ae235b
  oldval = g_getenv ("G_SLICE");
Packit ae235b
  g_unsetenv ("G_SLICE");
Packit ae235b
Packit ae235b
  if (g_test_subprocess ())
Packit ae235b
    {
Packit ae235b
      gpointer p, q;
Packit ae235b
Packit ae235b
      p = g_slice_alloc (237);
Packit ae235b
      q = g_slice_alloc (259);
Packit ae235b
      g_slice_free1 (237, p);
Packit ae235b
      g_slice_free1 (259, q);
Packit ae235b
Packit ae235b
      g_slice_debug_tree_statistics ();
Packit ae235b
      return;
Packit ae235b
    }
Packit ae235b
  g_test_trap_subprocess (NULL, 1000000, 0);
Packit ae235b
  g_test_trap_assert_passed ();
Packit ae235b
  g_test_trap_assert_stderr ("*GSlice: MemChecker: root=NULL*");
Packit ae235b
Packit ae235b
  if (oldval)
Packit ae235b
    g_setenv ("G_SLICE", oldval, TRUE);
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_slice_debug (void)
Packit ae235b
{
Packit ae235b
  const gchar *oldval;
Packit ae235b
Packit ae235b
  oldval = g_getenv ("G_SLICE");
Packit ae235b
  g_setenv ("G_SLICE", "debug-blocks:always-malloc", TRUE);
Packit ae235b
Packit ae235b
  if (g_test_subprocess ())
Packit ae235b
    {
Packit ae235b
      gpointer p, q;
Packit ae235b
Packit ae235b
      p = g_slice_alloc (237);
Packit ae235b
      q = g_slice_alloc (259);
Packit ae235b
      g_slice_free1 (237, p);
Packit ae235b
      g_slice_free1 (259, q);
Packit ae235b
Packit ae235b
      g_slice_debug_tree_statistics ();
Packit ae235b
      return;
Packit ae235b
    }
Packit ae235b
  g_test_trap_subprocess (NULL, 1000000, 0);
Packit ae235b
  g_test_trap_assert_passed ();
Packit ae235b
  g_test_trap_assert_stderr ("*GSlice: MemChecker: * trunks, * branches, * old branches*");
Packit ae235b
Packit ae235b
  if (oldval)
Packit ae235b
    g_setenv ("G_SLICE", oldval, TRUE);
Packit ae235b
  else
Packit ae235b
    g_unsetenv ("G_SLICE");
Packit ae235b
}
Packit ae235b
#endif
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_slice_copy (void)
Packit ae235b
{
Packit ae235b
  const gchar *block = "0123456789ABCDEF";
Packit ae235b
  gpointer p;
Packit ae235b
Packit ae235b
  p = g_slice_copy (12, block);
Packit ae235b
  g_assert (memcmp (p, block, 12) == 0);
Packit ae235b
  g_slice_free1 (12, p);
Packit ae235b
}
Packit ae235b
Packit ae235b
typedef struct {
Packit ae235b
  gint int1;
Packit ae235b
  gint int2;
Packit ae235b
  gchar byte;
Packit ae235b
  gpointer next;
Packit ae235b
  gint64 more;
Packit ae235b
} TestStruct;
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_chain (void)
Packit ae235b
{
Packit ae235b
  TestStruct *ts, *head;
Packit ae235b
Packit ae235b
  head = ts = g_slice_new (TestStruct);
Packit ae235b
  ts->next = g_slice_new (TestStruct);
Packit ae235b
  ts = ts->next;
Packit ae235b
  ts->next = g_slice_new (TestStruct);
Packit ae235b
  ts = ts->next;
Packit ae235b
  ts->next = NULL;
Packit ae235b
Packit ae235b
  g_slice_free_chain (TestStruct, head, next);
Packit ae235b
}
Packit ae235b
Packit ae235b
static gpointer chunks[4096][30];
Packit ae235b
Packit ae235b
static gpointer
Packit ae235b
thread_allocate (gpointer data)
Packit ae235b
{
Packit ae235b
  gint i;
Packit ae235b
  gint b;
Packit ae235b
  gint size;
Packit ae235b
  gpointer p;
Packit ae235b
  volatile gpointer *loc;
Packit ae235b
Packit ae235b
  for (i = 0; i < 10000; i++)
Packit ae235b
    {
Packit ae235b
      b = g_random_int_range (0, 30);
Packit ae235b
      size = g_random_int_range (0, 4096);
Packit ae235b
      loc = &(chunks[size][b]);
Packit ae235b
Packit ae235b
      p = g_atomic_pointer_get (loc);
Packit ae235b
      if (p == NULL)
Packit ae235b
        {
Packit ae235b
          p = g_slice_alloc (size + 1);
Packit ae235b
          if (!g_atomic_pointer_compare_and_exchange (loc, NULL, p))
Packit ae235b
            g_slice_free1 (size + 1, p);
Packit ae235b
        }
Packit ae235b
      else
Packit ae235b
        {
Packit ae235b
          if (g_atomic_pointer_compare_and_exchange (loc, p, NULL))
Packit ae235b
            g_slice_free1 (size + 1, p);
Packit ae235b
        }
Packit ae235b
    }
Packit ae235b
Packit ae235b
  return NULL;
Packit ae235b
}
Packit ae235b
Packit ae235b
static void
Packit ae235b
test_allocate (void)
Packit ae235b
{
Packit ae235b
  GThread *threads[30];
Packit ae235b
  gint size;
Packit ae235b
  gint i;
Packit ae235b
Packit ae235b
  for (i = 0; i < 30; i++)
Packit ae235b
    for (size = 1; size <= 4096; size++)
Packit ae235b
      chunks[size - 1][i] = NULL;
Packit ae235b
Packit ae235b
  for (i = 0; i < G_N_ELEMENTS(threads); i++)
Packit ae235b
    threads[i] = g_thread_create (thread_allocate, NULL, TRUE, NULL);
Packit ae235b
Packit ae235b
  for (i = 0; i < G_N_ELEMENTS(threads); i++)
Packit ae235b
    g_thread_join (threads[i]);
Packit ae235b
}
Packit ae235b
Packit ae235b
int
Packit ae235b
main (int argc, char **argv)
Packit ae235b
{
Packit ae235b
  g_test_init (&argc, &argv, NULL);
Packit ae235b
Packit ae235b
#ifdef G_ENABLE_DEBUG
Packit ae235b
  g_test_add_func ("/slice/nodebug", test_slice_nodebug);
Packit ae235b
  g_test_add_func ("/slice/debug", test_slice_debug);
Packit ae235b
#endif
Packit ae235b
  g_test_add_func ("/slice/copy", test_slice_copy);
Packit ae235b
  g_test_add_func ("/slice/chain", test_chain);
Packit ae235b
  g_test_add_func ("/slice/allocate", test_allocate);
Packit ae235b
Packit ae235b
  return g_test_run ();
Packit ae235b
}