Blame malloc/tst-obstack.c

Packit 6c4009
/* Test case by Alexandre Duret-Lutz <duret_g@epita.fr>.  */
Packit 6c4009
#include <obstack.h>
Packit 6c4009
#include <stdint.h>
Packit 6c4009
#include <stdio.h>
Packit 6c4009
#include <stdlib.h>
Packit 6c4009
Packit 6c4009
#define obstack_chunk_alloc verbose_malloc
Packit 6c4009
#define obstack_chunk_free verbose_free
Packit 6c4009
#define ALIGN_BOUNDARY 64
Packit 6c4009
#define ALIGN_MASK (ALIGN_BOUNDARY - 1)
Packit 6c4009
#define OBJECT_SIZE 1000
Packit 6c4009
Packit 6c4009
static void *
Packit 6c4009
verbose_malloc (size_t size)
Packit 6c4009
{
Packit 6c4009
  void *buf = malloc (size);
Packit 6c4009
  printf ("malloc (%zu) => %p\n", size, buf);
Packit 6c4009
  return buf;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
static void
Packit 6c4009
verbose_free (void *buf)
Packit 6c4009
{
Packit 6c4009
  free (buf);
Packit 6c4009
  printf ("free (%p)\n", buf);
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
static int
Packit 6c4009
do_test (void)
Packit 6c4009
{
Packit 6c4009
  int result = 0;
Packit 6c4009
  int align = 2;
Packit 6c4009
Packit 6c4009
  while (align <= 64)
Packit 6c4009
    {
Packit 6c4009
      struct obstack obs;
Packit 6c4009
      int i;
Packit 6c4009
      int align_mask = align - 1;
Packit 6c4009
Packit 6c4009
      printf ("\n Alignment mask: %d\n", align_mask);
Packit 6c4009
Packit 6c4009
      obstack_init (&obs);
Packit 6c4009
      obstack_alignment_mask (&obs) = align_mask;
Packit 6c4009
      /* finish an empty object to take alignment into account */
Packit 6c4009
      obstack_finish (&obs);
Packit 6c4009
Packit 6c4009
      /* let's allocate some objects and print their addresses */
Packit 6c4009
      for (i = 15; i > 0; --i)
Packit 6c4009
	{
Packit 6c4009
	  void *obj = obstack_alloc (&obs, OBJECT_SIZE);
Packit 6c4009
Packit 6c4009
	  printf ("obstack_alloc (%u) => %p \t%s\n", OBJECT_SIZE, obj,
Packit 6c4009
		  ((uintptr_t) obj & align_mask) ? "(not aligned)" : "");
Packit 6c4009
	  result |= ((uintptr_t) obj & align_mask) != 0;
Packit 6c4009
	}
Packit 6c4009
Packit 6c4009
      /* clean up */
Packit 6c4009
      obstack_free (&obs, 0);
Packit 6c4009
Packit 6c4009
      align <<= 1;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return result;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
#define TEST_FUNCTION do_test ()
Packit 6c4009
#include "../test-skeleton.c"