blob: cfccd595fda5985b197d5a2e59f72047dd0db462 [file] [log] [blame]
/*************************************************************************/ /*!
@File
@Title Resource Allocator API
@Copyright Copyright (c) Imagination Technologies Ltd. All Rights Reserved
@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 _RA_H_
#define _RA_H_
#include "img_types.h"
#include "pvrsrv_error.h"
/** Resource arena.
* struct _RA_ARENA_ deliberately opaque
*/
typedef struct _RA_ARENA_ RA_ARENA; //PRQA S 3313
/*
* Per-Arena handle - this is private data for the caller of the RA.
* The RA knows nothing about this data. It is given it upon
* RA_Create, and promises to pass it to calls to the ImportAlloc and
* ImportFree callbacks
*/
typedef IMG_HANDLE RA_PERARENA_HANDLE;
/*
* Per-Import handle - this is private data for the caller of the RA.
* The RA knows nothing about this data. It is given it on a
* per-import basis, either the "initial" import at RA_Create time, or
* further imports via the ImportAlloc callback. It sends it back via
* the ImportFree callback, and also provides it in answer to any
* RA_Alloc request to signify from which "import" the allocation came
*/
typedef IMG_HANDLE RA_PERISPAN_HANDLE;
typedef IMG_UINT64 RA_BASE_T;
typedef IMG_UINT32 RA_LOG2QUANTUM_T;
typedef IMG_UINT64 RA_LENGTH_T;
/* Lock classes: describes the level of nesting between different arenas. */
#define RA_LOCKCLASS_0 0
#define RA_LOCKCLASS_1 1
#define RA_LOCKCLASS_2 2
#define RA_NO_IMPORT_MULTIPLIER 1
/*
* Flags in an "import" must much the flags for an allocation
*/
typedef IMG_UINT32 RA_FLAGS_T;
/**
* @Function RA_Create
*
* @Description
*
* To create a resource arena.
*
* @Input name - the name of the arena for diagnostic purposes.
* @Input uQuantum - the arena allocation quantum.
* @Input ui32LockClass - the lock class level this arena uses.
* @Input alloc - a resource allocation callback or 0.
* @Input free - a resource de-allocation callback or 0.
* @Input per_arena_handle - user private handle passed to alloc and free or 0.
* @Input bNoSplit - Disable splitting up imports.
* @Return pointer to arena, or NULL.
*/
RA_ARENA *
RA_Create (IMG_CHAR *name,
/* subsequent imports: */
RA_LOG2QUANTUM_T uLog2Quantum,
IMG_UINT32 ui32LockClass,
PVRSRV_ERROR (*imp_alloc)(RA_PERARENA_HANDLE _h,
RA_LENGTH_T uSize,
RA_FLAGS_T uFlags,
const IMG_CHAR *pszAnnotation,
RA_BASE_T *pBase,
RA_LENGTH_T *pActualSize,
RA_PERISPAN_HANDLE *phPriv),
void (*imp_free) (RA_PERARENA_HANDLE,
RA_BASE_T,
RA_PERISPAN_HANDLE),
RA_PERARENA_HANDLE per_arena_handle,
IMG_BOOL bNoSplit);
/**
* @Function RA_Delete
*
* @Description
*
* To delete a resource arena. All resources allocated from the arena
* must be freed before deleting the arena.
*
* @Input pArena - the arena to delete.
* @Return None
*/
void
RA_Delete (RA_ARENA *pArena);
/**
* @Function RA_Add
*
* @Description
*
* To add a resource span to an arena. The span must not overlap with
* any span previously added to the arena.
*
* @Input pArena - the arena to add a span into.
* @Input base - the base of the span.
* @Input uSize - the extent of the span.
* @Input hPriv - handle associated to the span (reserved to user uses)
* @Return IMG_TRUE - success, IMG_FALSE - failure
*/
IMG_BOOL
RA_Add (RA_ARENA *pArena,
RA_BASE_T base,
RA_LENGTH_T uSize,
RA_FLAGS_T uFlags,
RA_PERISPAN_HANDLE hPriv);
/**
* @Function RA_Alloc
*
* @Description
*
* To allocate resource from an arena.
*
* @Input pArena - the arena
* @Input uRequestSize - the size of resource segment requested.
* @Input uImportMultiplier - Import x-times of the uRequestSize
* for future RA_Alloc calls.
* Use RA_NO_IMPORT_MULTIPLIER to import the exact size.
* @Output pActualSize - the actual_size of resource segment allocated,
* typcially rounded up by quantum.
* @Input uImportFlags - flags influencing allocation policy.
* @Input uAlignment - the alignment constraint required for the
* allocated segment, use 0 if alignment not required.
* @Input pszAnnotation - a string to describe the allocation
* @Output pBase - allocated base resource
* @Output phPriv - the user reference associated with allocated
* resource span.
* @Return PVRSRV_OK - success
*/
PVRSRV_ERROR
RA_Alloc (RA_ARENA *pArena,
RA_LENGTH_T uSize,
IMG_UINT8 uImportMultiplier,
RA_FLAGS_T uFlags,
RA_LENGTH_T uAlignment,
const IMG_CHAR *pszAnnotation,
RA_BASE_T *pBase,
RA_LENGTH_T *pActualSize,
RA_PERISPAN_HANDLE *phPriv);
/**
* @Function RA_Free
*
* @Description To free a resource segment.
*
* @Input pArena - the arena the segment was originally allocated from.
* @Input base - the base of the resource span to free.
* @Input bFreeBackingStore - Should backing store memory be freed?
*
* @Return None
*/
void
RA_Free (RA_ARENA *pArena, RA_BASE_T base);
#endif