/*************************************************************************/ /*!
|
@File allocmem.h
|
@Title memory allocation header
|
@Copyright Copyright (c) Imagination Technologies Ltd. All Rights Reserved
|
@Description Memory-Allocation API definitions
|
@License Dual MIT/GPLv2
|
|
The contents of this file are subject to the MIT license as set out below.
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
of this software and associated documentation files (the "Software"), to deal
|
in the Software without restriction, including without limitation the rights
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
copies of the Software, and to permit persons to whom the Software is
|
furnished to do so, subject to the following conditions:
|
|
The above copyright notice and this permission notice shall be included in
|
all copies or substantial portions of the Software.
|
|
Alternatively, the contents of this file may be used under the terms of
|
the GNU General Public License Version 2 ("GPL") in which case the provisions
|
of GPL are applicable instead of those above.
|
|
If you wish to allow use of your version of this file only under the terms of
|
GPL, and not to allow others to use your version of this file under the terms
|
of the MIT license, indicate your decision by deleting the provisions above
|
and replace them with the notice and other provisions required by GPL as set
|
out in the file called "GPL-COPYING" included in this distribution. If you do
|
not delete the provisions above, a recipient may use your version of this file
|
under the terms of either the MIT license or GPL.
|
|
This License is also included in this distribution in the file called
|
"MIT-COPYING".
|
|
EXCEPT AS OTHERWISE STATED IN A NEGOTIATED AGREEMENT: (A) THE SOFTWARE IS
|
PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
|
BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
PURPOSE AND NONINFRINGEMENT; AND (B) IN NO EVENT SHALL THE AUTHORS OR
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
*/ /**************************************************************************/
|
|
#ifndef __ALLOCMEM_H__
|
#define __ALLOCMEM_H__
|
|
#include "img_types.h"
|
#include "pvr_debug.h"
|
|
#if defined (__cplusplus)
|
extern "C" {
|
#endif
|
|
#if !defined(PVRSRV_DEBUG_LINUX_MEMORY_STATS) || !defined(DEBUG) || !defined(PVRSRV_ENABLE_PROCESS_STATS) || !defined(PVRSRV_ENABLE_MEMORY_STATS)
|
/**************************************************************************/ /*!
|
@Function OSAllocMem
|
@Description Allocates CPU memory. Contents are uninitialized.
|
If passed a size of zero, function should not assert,
|
but just return a NULL pointer.
|
@Input ui32Size Size of required allocation (in bytes)
|
@Return Pointer to allocated memory on success.
|
Otherwise NULL.
|
*/ /**************************************************************************/
|
void *OSAllocMem(IMG_UINT32 ui32Size);
|
/**************************************************************************/ /*!
|
@Function OSAllocZMem
|
@Description Allocates CPU memory and initializes the contents to zero.
|
If passed a size of zero, function should not assert,
|
but just return a NULL pointer.
|
@Input ui32Size Size of required allocation (in bytes)
|
@Return Pointer to allocated memory on success.
|
Otherwise NULL.
|
*/ /**************************************************************************/
|
void *OSAllocZMem(IMG_UINT32 ui32Size);
|
#else
|
void *_OSAllocMem(IMG_UINT32 ui32Size, void *pvAllocFromFile, IMG_UINT32 ui32AllocFromLine);
|
void *_OSAllocZMem(IMG_UINT32 ui32Size, void *pvAllocFromFile, IMG_UINT32 ui32AllocFromLine);
|
#define OSAllocMem(_size) \
|
_OSAllocMem ((_size), (__FILE__), (__LINE__));
|
#define OSAllocZMem(_size) \
|
_OSAllocZMem ((_size), (__FILE__), (__LINE__));
|
#endif
|
|
/**************************************************************************/ /*!
|
@Function OSAllocMemNoStats
|
@Description Allocates CPU memory. Contents are uninitialized.
|
If passed a size of zero, function should not assert,
|
but just return a NULL pointer.
|
The allocated memory is not accounted for by process stats.
|
Process stats are an optional feature (enabled only when
|
PVRSRV_ENABLE_PROCESS_STATS is defined) which track the amount
|
of memory allocated to help in debugging. Where this is not
|
required, OSAllocMem() and OSAllocMemNoStats() equate to
|
the same operation.
|
@Input ui32Size Size of required allocation (in bytes)
|
@Return Pointer to allocated memory on success.
|
Otherwise NULL.
|
*/ /**************************************************************************/
|
void *OSAllocMemNoStats(IMG_UINT32 ui32Size);
|
|
/**************************************************************************/ /*!
|
@Function OSAllocZMemNoStats
|
@Description Allocates CPU memory and initializes the contents to zero.
|
If passed a size of zero, function should not assert,
|
but just return a NULL pointer.
|
The allocated memory is not accounted for by process stats.
|
Process stats are an optional feature (enabled only when
|
PVRSRV_ENABLE_PROCESS_STATS is defined) which track the amount
|
of memory allocated to help in debugging. Where this is not
|
required, OSAllocZMem() and OSAllocZMemNoStats() equate to
|
the same operation.
|
@Input ui32Size Size of required allocation (in bytes)
|
@Return Pointer to allocated memory on success.
|
Otherwise NULL.
|
*/ /**************************************************************************/
|
void *OSAllocZMemNoStats(IMG_UINT32 ui32Size);
|
|
/**************************************************************************/ /*!
|
@Function OSFreeMem
|
@Description Frees previously allocated CPU memory.
|
@Input pvCpuVAddr Pointer to the memory to be freed.
|
@Return None.
|
*/ /**************************************************************************/
|
void OSFreeMem(void *pvCpuVAddr);
|
|
/**************************************************************************/ /*!
|
@Function OSFreeMemNoStats
|
@Description Frees previously allocated CPU memory.
|
The freed memory does not update the figures in process stats.
|
Process stats are an optional feature (enabled only when
|
PVRSRV_ENABLE_PROCESS_STATS is defined) which track the amount
|
of memory allocated to help in debugging. Where this is not
|
required, OSFreeMem() and OSFreeMemNoStats() equate to the
|
same operation.
|
@Input pvCpuVAddr Pointer to the memory to be freed.
|
@Return None.
|
*/ /**************************************************************************/
|
void OSFreeMemNoStats(void *pvCpuVAddr);
|
|
/*
|
* These macros allow us to catch double-free bugs on DEBUG builds and
|
* prevent crashes on RELEASE builds.
|
*/
|
|
#if defined(DEBUG)
|
#define double_free_sentinel (void*) &OSFreeMem
|
#define ALLOCMEM_ASSERT(exp) PVR_ASSERT(exp)
|
#else
|
#define double_free_sentinel NULL
|
#define ALLOCMEM_ASSERT(exp) do {} while(0)
|
#endif
|
|
#define OSFreeMem(_ptr) do { \
|
ALLOCMEM_ASSERT((_ptr) != double_free_sentinel); \
|
(OSFreeMem)(_ptr); \
|
(_ptr) = double_free_sentinel; \
|
MSC_SUPPRESS_4127 \
|
} while (0)
|
|
#define OSFreeMemNoStats(_ptr) do { \
|
ALLOCMEM_ASSERT((_ptr) != double_free_sentinel); \
|
(OSFreeMemNoStats)(_ptr); \
|
(_ptr) = double_free_sentinel; \
|
MSC_SUPPRESS_4127 \
|
} while (0)
|
|
#if defined (__cplusplus)
|
}
|
#endif
|
|
#endif /* __ALLOCMEM_H__ */
|
|
/******************************************************************************
|
End of file (allocmem.h)
|
******************************************************************************/
|