| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267 |
- /**--------------------------------------------------------------------------**\
- ===================================
- Y Sever Includes - Malloc Functions
- ===================================
- Description:
- Functions for using malloc/calloc/free type functions in PAWN.
- Legal:
- Version: MPL 1.1
-
- The contents of this file are subject to the Mozilla Public License Version
- 1.1 (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
- http://www.mozilla.org/MPL/
-
- Software distributed under the License is distributed on an "AS IS" basis,
- WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- for the specific language governing rights and limitations under the
- License.
-
- The Original Code is the YSI malloc include.
-
- The Initial Developer of the Original Code is Alex "Y_Less" Cole.
- Portions created by the Initial Developer are Copyright (C) 2011
- the Initial Developer. All Rights Reserved.
-
- Contributors:
- ZeeX, koolk, JoeBullet/Google63, g_aSlice/Slice
-
- Thanks:
- JoeBullet/Google63 - Handy arbitrary ASM jump code using SCTRL.
- ZeeX - Very productive conversations.
- koolk - IsPlayerinAreaEx code.
- TheAlpha - Danish translation.
- breadfish - German translation.
- Fireburn - Dutch translation.
- yom - French translation.
- 50p - Polish translation.
- Zamaroht - Spanish translation.
- Dracoblue, sintax, mabako, Xtreme, other coders - Producing other modes
- for me to strive to better.
- Pixels^ - Running XScripters where the idea was born.
- Matite - Pestering me to release it and using it.
-
- Very special thanks to:
- Thiadmer - PAWN, whose limits continue to amaze me!
- Kye/Kalcor - SA:MP.
- SA:MP Team past, present and future - SA:MP.
-
- Version:
- 0.1
- Changelog:
- 02/12/11:
- Added variable argument functions.
- 22/12/08:
- First version.
- Functions:
- Public
- -
- Core:
- -
- Stock:
- malloc - Allocate a block of memory (may be inline).
- calloc - Allocate a block of memory and blank.
- free - Free an allocated block of memory (may be inline).
- Malloc_Set - Set a value in an allocated array (may be inline).
- Malloc_Get - Get a value in an allocated array (may be inline).
- Malloc_SetS - Set a string in an allocated array.
- Malloc_GetS - Get a string in an allocated array.
- Malloc_Allocate - Do the memory allocation (may be static).
- Malloc_Free - Do the memory freeing (may be static).
- Malloc_SlotSize - Get the size of an allocated block (may be inline).
- Malloc_NewS - Allocate for and store a given string.
- Static:
- Malloc_Allocate - Do the memory allocation (may be stock).
- Malloc_Free - Do the memory freeing (may be stock).
- Inline:
- mget - Get data from an allocation unit.
- mset - Set data in an allocation unit.
- mgets - Get a string from an allocation unit.
- msets - Set a string in an allocation unit.
- malloc - Allocate a block of memory (may be stock).
- free - Free an allocated block of memory (may be stock).
- Malloc_Set - Set a value in an allocated array (may be stock).
- Malloc_Get - Get a value in an allocated array (may be stock).
- Malloc_NextSlot - Get the next free data block.
- Malloc_GetSlotSize - Get the size of a slot.
- Malloc_SetSlotSize - Set the size of a block.
- Malloc_GetData - Direct data access getter.
- Malloc_SetData - Direct data access setter.
- Malloc_SlotSize - Get the size of an allocated block (may be stock).
- API:
- -
- Callbacks:
- -
- Definitions:
- MALLOC_KB_TO_CELL - Multiplication value to convert kb to cells.
- NO_ALLOC - A failed allocation (NULL, but YSI already has NULL).
- Enums:
- -
- Macros:
- -
- Tags:
- Alloc - An allocated block handle variable.
- Variables:
- Global:
- YSI_gMallocMemory - Stores the data (may be static).
- Static:
- YSI_gMallocMemory - Stores the data (may be global).
- _YSI_g_sUnusedStart - Start of free memory.
- Commands:
- -
- Compile options:
- MALLOC_MEMORY - Number of cells to reserve.
- MALLOC_MEMORY_KB - Number of killobytes to reserve.
- MALLOC_MEMORY_B - Number of bytes to reserve.
- MALLOC_MEMORY_MB - Number of megabytes to reserve.
- YSI_MALLOC_SECURE - Use enhanced bounds checking.
- YSI_MALLOC_NO_SHORT - Avoid conflicts with mget/mset.
- Operators:
- -
- \**--------------------------------------------------------------------------**/
- #if defined _INC_y_malloc
- #endinput
- #endif
- #define _INC_y_malloc
- #if defined YSI_MALLOC_SECURE
- #error YSI_MALLOC_SECURE has been removed.
- #endif
- #include "..\YSI_Internal\y_version"
- #include "..\YSI_Internal\y_funcinc"
- #include "..\YSI_Core\y_debug"
- #include "..\YSI_Storage\y_amx"
- #include "..\YSI_Core\y_als"
- #include "..\YSI_Core\y_utils"
- #include "..\YSI_Internal\amx_assembly"
- #define GB_TO_MB(%0) ((%0) * 1024)
- #define MB_TO_KB(%0) ((%0) * 1024)
- #define GB_TO_KB(%0) ((%0) * 1024 * 1024)
- #define KB_TO_BYTE(%0) ((%0) * 1024)
- #define MB_TO_BYTE(%0) ((%0) * 1024 * 1024)
- #define GB_TO_BYTE(%0) ((%0) * 1024 * 1024 * 1024)
- #define BYTE_TO_CELL(%0) ((%0) * 8 / cellbits)
- #define KB_TO_CELL(%0) BYTE_TO_CELL(KB_TO_BYTE(%0))
- #define MB_TO_CELL(%0) BYTE_TO_CELL(MB_TO_BYTE(%0))
- #define GB_TO_CELL(%0) BYTE_TO_CELL(GB_TO_BYTE(%0))
- #define NO_ALLOC (Alloc:0)
- #if !defined MALLOC_MEMORY
- #if defined MALLOC_MEMORY_GB
- #define MALLOC_MEMORY GB_TO_CELL(MALLOC_MEMORY_GB)
- #elseif defined MALLOC_MEMORY_MB
- #define MALLOC_MEMORY MB_TO_CELL(MALLOC_MEMORY_MB)
- #elseif defined MALLOC_MEMORY_KB
- #define MALLOC_MEMORY KB_TO_CELL(MALLOC_MEMORY_KB)
- #elseif defined MALLOC_MEMORY_B
- #define MALLOC_MEMORY BYTE_TO_CELL(MALLOC_MEMORY_B)
- #else
- #define MALLOC_MEMORY MB_TO_CELL(16)
- #endif
- #endif
- #if defined YSI_NO_HEAP_MALLOC
- #if defined DYNAMIC_MEMORY
- #pragma dynamic DYNAMIC_MEMORY
- #define dynamic dynamic_is_now_DYNAMIC_MEMORY_ // See below...
- #endif
- #else
- // Allocate extra memory for the normal stack and heap (64k, 16 times the
- // size of the default stack)!
- #if !defined DYNAMIC_MEMORY
- #define DYNAMIC_MEMORY (65536)
- #endif
- #pragma dynamic MALLOC_MEMORY + DYNAMIC_MEMORY
-
- // ====================================================================== //
- // //
- // IMPORTANT! //
- // //
- // ====================================================================== //
- #define dynamic dynamic_is_now_DYNAMIC_MEMORY_ //
- // ====================================================================== //
- // //
- // dynamic_is_now_DYNAMIC_MEMORY_ //
- // //
- // If you get a warning or error about "dynamic_is_now_DYNAMIC_MEMORY_", //
- // hopefully (though doubtfully) you searched for something related to it //
- // and found this. If you are slightly confused, just remember that any //
- // reference to that variable is actually a reference to a variable //
- // called "dynamic", and so the error/warning refers to that. //
- // //
- // _is_now_DYNAMIC_MEMORY_ //
- // //
- // If you get an error or warning about "_is_now_DYNAMIC_MEMORY_", it is //
- // because you have tried to use "#pragma dynamic <number>" after //
- // including "y_malloc" (or another library that eventually includes //
- // "y_malloc"). Because that library allocates memory from the heap, it //
- // needs control over how much memory is in the heap to begin with. You //
- // do this with "#pragma dynamic <number>", which that library does. //
- // Because using that a second time somewhere in your mode will break //
- // "y_malloc", it disables the pragma, and instead outputs that error. //
- // If you need to increase your stack or heap size (due to a stack/heap //
- // collision), add this to the very top of your mode: //
- // //
- // #define DYNAMIC_MEMORY <number> //
- // //
- // ====================================================================== //
- #endif
- // Sort of "module local" variables.
- stock
- __YSI_g_sHeapStart = 0,
- __YSI_g_sUnusedStart = 0;
- #define YSI_g_sHeapStart __YSI_g_sHeapStart
- #define YSI_g_sUnusedStart __YSI_g_sUnusedStart
- forward Alloc:Malloc_Allocate(size, const bool:clear = true);
- forward Alloc:calloc(size);
- #if defined YSI_NO_HEAP_MALLOC
- new
- YSI_gMallocMemory[MALLOC_MEMORY];
-
- public OnScriptInit()
- {
- YSI_g_sHeapStart = 0;
- YSI_gMallocMemory[0] = MALLOC_MEMORY - 1;
- YSI_g_sUnusedStart = 1;
- memset(YSI_gMallocMemory[1], 0, MALLOC_MEMORY - 1);
- #if defined Malloc_OnScriptInit
- Malloc_OnScriptInit();
- #endif
- return 1;
- }
-
- #undef OnScriptInit
- #define OnScriptInit Malloc_OnScriptInit
- #if defined Malloc_OnScriptInit
- forward Malloc_OnScriptInit();
- #endif
- #else
- new
- YSI_gMallocMemory[1];
-
- // Allocate space on the heap permanently.
- #include "y_malloc/heapalloc"
- #endif
- // Functions to access the data on the heap.
- #include "y_malloc/funcs"
- #if defined YSI_TESTS
- #include "..\YSI_Core\y_testing"
- #include "y_malloc/tests"
- #endif
- #undef YSI_g_sHeapStart
- #undef YSI_g_sUnusedStart
|