:man_page: bson_aligned_alloc

bson_aligned_alloc()
====================

Synopsis
--------

.. code-block:: c

  void *
  bson_aligned_alloc (size_t alignment, size_t num_bytes);

Parameters
----------

* ``alignment``: The alignment of the allocated bytes of memory. Must be a power of 2 and a multiple of ``sizeof (void *)``.
* ``num_bytes``: The number of bytes to allocate. Must be a multiple of ``alignment``.

Description
-----------

This is a portable ``aligned_alloc()`` wrapper.

If there was a failure to allocate ``num_bytes`` bytes aligned to ``alignment``, the process will be aborted.

.. warning::

  This function will abort on failure to allocate memory.

Returns
-------

A pointer to a memory region which *HAS NOT* been zeroed.
