VirtualBox

source: vbox/trunk/include/iprt/mem.h@ 39654

Last change on this file since 39654 was 36569, checked in by vboxsync, 14 years ago

iprt/mem.h: an alternative RTMEM_TAG including the line number

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 31.7 KB
Line 
1/** @file
2 * IPRT - Memory Management and Manipulation.
3 */
4
5/*
6 * Copyright (C) 2006-2011 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___iprt_mem_h
27#define ___iprt_mem_h
28
29
30#include <iprt/cdefs.h>
31#include <iprt/types.h>
32
33
34#ifdef IN_RC
35# error "There are no RTMem APIs available Guest Context!"
36#endif
37
38
39/** @defgroup grp_rt_mem RTMem - Memory Management and Manipulation
40 * @ingroup grp_rt
41 * @{
42 */
43
44RT_C_DECLS_BEGIN
45
46/** @def RTMEM_ALIGNMENT
47 * The alignment of the memory blocks returned by RTMemAlloc(), RTMemAllocZ(),
48 * RTMemRealloc(), RTMemTmpAlloc() and RTMemTmpAllocZ() for allocations greater
49 * than RTMEM_ALIGNMENT.
50 *
51 * @note This alignment is not forced if the electric fence is active!
52 */
53#define RTMEM_ALIGNMENT 8
54
55/** @def RTMEM_TAG
56 * The default allocation tag used by the RTMem allocation APIs.
57 *
58 * When not defined before the inclusion of iprt/mem.h or iprt/memobj.h, this
59 * will default to the pointer to the current file name. The memory API will
60 * make of use of this as pointer to a volatile but read-only string.
61 * The alternative tag includes the line number for a more-detailed analysis.
62 */
63#ifndef RTMEM_TAG
64# if 0
65# define RTMEM_TAG (__FILE__ ":" RT_XSTR(__LINE__))
66# else
67# define RTMEM_TAG (__FILE__)
68# endif
69#endif
70
71
72/** @name Allocate temporary memory.
73 * @{ */
74/**
75 * Allocates temporary memory with default tag.
76 *
77 * Temporary memory blocks are used for not too large memory blocks which
78 * are believed not to stick around for too long. Using this API instead
79 * of RTMemAlloc() not only gives the heap manager room for optimization
80 * but makes the code easier to read.
81 *
82 * @returns Pointer to the allocated memory.
83 * @returns NULL on failure, assertion raised in strict builds.
84 * @param cb Size in bytes of the memory block to allocated.
85 */
86#define RTMemTmpAlloc(cb) RTMemTmpAllocTag((cb), RTMEM_TAG)
87
88/**
89 * Allocates temporary memory with custom tag.
90 *
91 * Temporary memory blocks are used for not too large memory blocks which
92 * are believed not to stick around for too long. Using this API instead
93 * of RTMemAlloc() not only gives the heap manager room for optimization
94 * but makes the code easier to read.
95 *
96 * @returns Pointer to the allocated memory.
97 * @returns NULL on failure, assertion raised in strict builds.
98 * @param cb Size in bytes of the memory block to allocated.
99 * @param pszTag Allocation tag used for statistics and such.
100 */
101RTDECL(void *) RTMemTmpAllocTag(size_t cb, const char *pszTag) RT_NO_THROW;
102
103/**
104 * Allocates zero'd temporary memory with default tag.
105 *
106 * Same as RTMemTmpAlloc() but the memory will be zero'd.
107 *
108 * @returns Pointer to the allocated memory.
109 * @returns NULL on failure, assertion raised in strict builds.
110 * @param cb Size in bytes of the memory block to allocated.
111 */
112#define RTMemTmpAllocZ(cb) RTMemTmpAllocZTag((cb), RTMEM_TAG)
113
114/**
115 * Allocates zero'd temporary memory with custom tag.
116 *
117 * Same as RTMemTmpAlloc() but the memory will be zero'd.
118 *
119 * @returns Pointer to the allocated memory.
120 * @returns NULL on failure, assertion raised in strict builds.
121 * @param cb Size in bytes of the memory block to allocated.
122 * @param pszTag Allocation tag used for statistics and such.
123 */
124RTDECL(void *) RTMemTmpAllocZTag(size_t cb, const char *pszTag) RT_NO_THROW;
125
126/**
127 * Free temporary memory.
128 *
129 * @param pv Pointer to memory block.
130 */
131RTDECL(void) RTMemTmpFree(void *pv) RT_NO_THROW;
132
133/** @} */
134
135
136/**
137 * Allocates memory with default tag.
138 *
139 * @returns Pointer to the allocated memory.
140 * @returns NULL on failure, assertion raised in strict builds.
141 * @param cb Size in bytes of the memory block to allocated.
142 * @param pszTag Allocation tag used for statistics and such.
143 */
144#define RTMemAlloc(cb) RTMemAllocTag((cb), RTMEM_TAG)
145
146/**
147 * Allocates memory with custom tag.
148 *
149 * @returns Pointer to the allocated memory.
150 * @returns NULL on failure, assertion raised in strict builds.
151 * @param cb Size in bytes of the memory block to allocated.
152 * @param pszTag Allocation tag used for statistics and such.
153 */
154RTDECL(void *) RTMemAllocTag(size_t cb, const char *pszTag) RT_NO_THROW;
155
156/**
157 * Allocates zero'd memory with default tag.
158 *
159 * Instead of memset(pv, 0, sizeof()) use this when you want zero'd
160 * memory. This keeps the code smaller and the heap can skip the memset
161 * in about 0.42% of calls :-).
162 *
163 * @returns Pointer to the allocated memory.
164 * @returns NULL on failure.
165 * @param cb Size in bytes of the memory block to allocated.
166 */
167#define RTMemAllocZ(cb) RTMemAllocZTag((cb), RTMEM_TAG)
168
169/**
170 * Allocates zero'd memory with custom tag.
171 *
172 * Instead of memset(pv, 0, sizeof()) use this when you want zero'd
173 * memory. This keeps the code smaller and the heap can skip the memset
174 * in about 0.42% of calls :-).
175 *
176 * @returns Pointer to the allocated memory.
177 * @returns NULL on failure.
178 * @param cb Size in bytes of the memory block to allocated.
179 * @param pszTag Allocation tag used for statistics and such.
180 */
181RTDECL(void *) RTMemAllocZTag(size_t cb, const char *pszTag) RT_NO_THROW;
182
183/**
184 * Wrapper around RTMemAlloc for automatically aligning variable sized
185 * allocations so that the various electric fence heaps works correctly.
186 *
187 * @returns See RTMemAlloc.
188 * @param cbUnaligned The unaligned size.
189 */
190#define RTMemAllocVar(cbUnaligned) RTMemAllocVarTag((cbUnaligned), RTMEM_TAG)
191
192/**
193 * Wrapper around RTMemAllocTag for automatically aligning variable sized
194 * allocations so that the various electric fence heaps works correctly.
195 *
196 * @returns See RTMemAlloc.
197 * @param cbUnaligned The unaligned size.
198 * @param pszTag Allocation tag used for statistics and such.
199 */
200RTDECL(void *) RTMemAllocVarTag(size_t cbUnaligned, const char *pszTag) RT_NO_THROW;
201
202/**
203 * Wrapper around RTMemAllocZ for automatically aligning variable sized
204 * allocations so that the various electric fence heaps works correctly.
205 *
206 * @returns See RTMemAllocZ.
207 * @param cbUnaligned The unaligned size.
208 */
209#define RTMemAllocZVar(cbUnaligned) RTMemAllocZVarTag((cbUnaligned), RTMEM_TAG)
210
211/**
212 * Wrapper around RTMemAllocZTag for automatically aligning variable sized
213 * allocations so that the various electric fence heaps works correctly.
214 *
215 * @returns See RTMemAllocZ.
216 * @param cbUnaligned The unaligned size.
217 * @param pszTag Allocation tag used for statistics and such.
218 */
219RTDECL(void *) RTMemAllocZVarTag(size_t cbUnaligned, const char *pszTag) RT_NO_THROW;
220
221/**
222 * Duplicates a chunk of memory into a new heap block (default tag).
223 *
224 * @returns New heap block with the duplicate data.
225 * @returns NULL if we're out of memory.
226 * @param pvSrc The memory to duplicate.
227 * @param cb The amount of memory to duplicate.
228 */
229#define RTMemDup(pvSrc, cb) RTMemDupTag((pvSrc), (cb), RTMEM_TAG)
230
231/**
232 * Duplicates a chunk of memory into a new heap block (custom tag).
233 *
234 * @returns New heap block with the duplicate data.
235 * @returns NULL if we're out of memory.
236 * @param pvSrc The memory to duplicate.
237 * @param cb The amount of memory to duplicate.
238 * @param pszTag Allocation tag used for statistics and such.
239 */
240RTDECL(void *) RTMemDupTag(const void *pvSrc, size_t cb, const char *pszTag) RT_NO_THROW;
241
242/**
243 * Duplicates a chunk of memory into a new heap block with some additional
244 * zeroed memory (default tag).
245 *
246 * @returns New heap block with the duplicate data.
247 * @returns NULL if we're out of memory.
248 * @param pvSrc The memory to duplicate.
249 * @param cbSrc The amount of memory to duplicate.
250 * @param cbExtra The amount of extra memory to allocate and zero.
251 */
252#define RTMemDupEx(pvSrc, cbSrc, cbExtra) RTMemDupExTag((pvSrc), (cbSrc), (cbExtra), RTMEM_TAG)
253
254/**
255 * Duplicates a chunk of memory into a new heap block with some additional
256 * zeroed memory (default tag).
257 *
258 * @returns New heap block with the duplicate data.
259 * @returns NULL if we're out of memory.
260 * @param pvSrc The memory to duplicate.
261 * @param cbSrc The amount of memory to duplicate.
262 * @param cbExtra The amount of extra memory to allocate and zero.
263 * @param pszTag Allocation tag used for statistics and such.
264 */
265RTDECL(void *) RTMemDupExTag(const void *pvSrc, size_t cbSrc, size_t cbExtra, const char *pszTag) RT_NO_THROW;
266
267/**
268 * Reallocates memory with default tag.
269 *
270 * @returns Pointer to the allocated memory.
271 * @returns NULL on failure.
272 * @param pvOld The memory block to reallocate.
273 * @param cbNew The new block size (in bytes).
274 */
275#define RTMemRealloc(pvOld, cbNew) RTMemReallocTag((pvOld), (cbNew), RTMEM_TAG)
276
277/**
278 * Reallocates memory with custom tag.
279 *
280 * @returns Pointer to the allocated memory.
281 * @returns NULL on failure.
282 * @param pvOld The memory block to reallocate.
283 * @param cbNew The new block size (in bytes).
284 * @param pszTag Allocation tag used for statistics and such.
285 */
286RTDECL(void *) RTMemReallocTag(void *pvOld, size_t cbNew, const char *pszTag) RT_NO_THROW;
287
288/**
289 * Frees memory.
290 *
291 * @param pv Pointer to memory block.
292 */
293RTDECL(void) RTMemFree(void *pv) RT_NO_THROW;
294
295
296
297/** @def RTR0MemAllocEx and RTR0MemAllocExTag flags.
298 * @{ */
299/** The returned memory should be zeroed. */
300#define RTMEMALLOCEX_FLAGS_ZEROED RT_BIT(0)
301/** It must be load code into the returned memory block and execute it. */
302#define RTMEMALLOCEX_FLAGS_EXEC RT_BIT(1)
303/** Allocation from any context.
304 * Will return VERR_NOT_SUPPORTED if not supported. */
305#define RTMEMALLOCEX_FLAGS_ANY_CTX_ALLOC RT_BIT(2)
306/** Allocate the memory such that it can be freed from any context.
307 * Will return VERR_NOT_SUPPORTED if not supported. */
308#define RTMEMALLOCEX_FLAGS_ANY_CTX_FREE RT_BIT(3)
309/** Allocate and free from any context.
310 * Will return VERR_NOT_SUPPORTED if not supported. */
311#define RTMEMALLOCEX_FLAGS_ANY_CTX (RTMEMALLOCEX_FLAGS_ANY_CTX_ALLOC | RTMEMALLOCEX_FLAGS_ANY_CTX_FREE)
312/** Mask of valid flags. */
313#define RTMEMALLOCEX_FLAGS_VALID_MASK UINT32_C(0x0000000f)
314/** @} */
315
316/**
317 * Extended heap allocation API, default tag.
318 *
319 * @returns IPRT status code.
320 * @retval VERR_NO_MEMORY if we're out of memory.
321 * @retval VERR_NO_EXEC_MEMORY if we're out of executable memory.
322 * @retval VERR_NOT_SUPPORTED if any of the specified flags are unsupported.
323 *
324 * @param cb The amount of memory to allocate.
325 * @param cbAlignment The alignment requirements. Use 0 to indicate
326 * default alignment.
327 * @param fFlags A combination of the RTMEMALLOCEX_FLAGS_XXX
328 * defines.
329 * @param ppv Where to return the memory.
330 */
331#define RTMemAllocEx(cb, cbAlignment, fFlags, ppv) RTMemAllocExTag((cb), (cbAlignment), (fFlags), RTMEM_TAG, (ppv))
332
333/**
334 * Extended heap allocation API, custom tag.
335 *
336 * @returns IPRT status code.
337 * @retval VERR_NO_MEMORY if we're out of memory.
338 * @retval VERR_NO_EXEC_MEMORY if we're out of executable memory.
339 * @retval VERR_NOT_SUPPORTED if any of the specified flags are unsupported.
340 *
341 * @param cb The amount of memory to allocate.
342 * @param cbAlignment The alignment requirements. Use 0 to indicate
343 * default alignment.
344 * @param fFlags A combination of the RTMEMALLOCEX_FLAGS_XXX
345 * defines.
346 * @param pszTag The tag.
347 * @param ppv Where to return the memory.
348 */
349RTDECL(int) RTMemAllocExTag(size_t cb, size_t cbAlignment, uint32_t fFlags, const char *pszTag, void **ppv) RT_NO_THROW;
350
351/**
352 * For freeing memory allocated by RTMemAllocEx or RTMemAllocExTag.
353 *
354 * @param pv What to free, NULL is fine.
355 * @param cb The amount of allocated memory.
356 */
357RTDECL(void) RTMemFreeEx(void *pv, size_t cb) RT_NO_THROW;
358
359
360
361/**
362 * Allocates memory which may contain code (default tag).
363 *
364 * @returns Pointer to the allocated memory.
365 * @returns NULL on failure.
366 * @param cb Size in bytes of the memory block to allocate.
367 */
368#define RTMemExecAlloc(cb) RTMemExecAllocTag((cb), RTMEM_TAG)
369
370/**
371 * Allocates memory which may contain code (custom tag).
372 *
373 * @returns Pointer to the allocated memory.
374 * @returns NULL on failure.
375 * @param cb Size in bytes of the memory block to allocate.
376 * @param pszTag Allocation tag used for statistics and such.
377 */
378RTDECL(void *) RTMemExecAllocTag(size_t cb, const char *pszTag) RT_NO_THROW;
379
380/**
381 * Free executable/read/write memory allocated by RTMemExecAlloc().
382 *
383 * @param pv Pointer to memory block.
384 * @param cb The allocation size.
385 */
386RTDECL(void) RTMemExecFree(void *pv, size_t cb) RT_NO_THROW;
387
388#if defined(IN_RING0) && defined(RT_ARCH_AMD64) && defined(RT_OS_LINUX)
389/**
390 * Donate read+write+execute memory to the exec heap.
391 *
392 * This API is specific to AMD64 and Linux/GNU. A kernel module that desires to
393 * use RTMemExecAlloc on AMD64 Linux/GNU will have to donate some statically
394 * allocated memory in the module if it wishes for GCC generated code to work.
395 * GCC can only generate modules that work in the address range ~2GB to ~0
396 * currently.
397 *
398 * The API only accept one single donation.
399 *
400 * @returns IPRT status code.
401 * @param pvMemory Pointer to the memory block.
402 * @param cb The size of the memory block.
403 */
404RTR0DECL(int) RTR0MemExecDonate(void *pvMemory, size_t cb) RT_NO_THROW;
405
406/**
407 * Allocate read+write+execute memory to the exec heap.
408 *
409 * This API is specific to AMD64 and Linux/GNU. A kernel module that desires to
410 * use RTMemExecAlloc on AMD64 Linux/GNU will have to initialize some allocated
411 * memory in the module range if it wishes for GCC generated code to work. GCC
412 * can only generate modules that work in the address range ~2GB to ~0 currently.
413 * As RTR0MemExecDonate() does not work if CONFIG_DEBUG_SET_MODULE_RONX is
414 * enabled, use a different approach (only very recent Linux kernels).
415 *
416 * The API only accept one single initialization.
417 *
418 * @returns IPRT status code.
419 * @param cb The size of the memory block.
420 */
421RTR0DECL(int) RTR0MemExecInit(size_t cb) RT_NO_THROW;
422#endif /* R0+AMD64+LINUX */
423
424/**
425 * Allocate page aligned memory with default tag.
426 *
427 * @returns Pointer to the allocated memory.
428 * @returns NULL if we're out of memory.
429 * @param cb Size of the memory block. Will be rounded up to page size.
430 */
431#define RTMemPageAlloc(cb) RTMemPageAllocTag((cb), RTMEM_TAG)
432
433/**
434 * Allocate page aligned memory with custom tag.
435 *
436 * @returns Pointer to the allocated memory.
437 * @returns NULL if we're out of memory.
438 * @param cb Size of the memory block. Will be rounded up to page size.
439 * @param pszTag Allocation tag used for statistics and such.
440 */
441RTDECL(void *) RTMemPageAllocTag(size_t cb, const char *pszTag) RT_NO_THROW;
442
443/**
444 * Allocate zero'd page aligned memory with default tag.
445 *
446 * @returns Pointer to the allocated memory.
447 * @returns NULL if we're out of memory.
448 * @param cb Size of the memory block. Will be rounded up to page size.
449 */
450#define RTMemPageAllocZ(cb) RTMemPageAllocZTag((cb), RTMEM_TAG)
451
452/**
453 * Allocate zero'd page aligned memory with custom tag.
454 *
455 * @returns Pointer to the allocated memory.
456 * @returns NULL if we're out of memory.
457 * @param cb Size of the memory block. Will be rounded up to page size.
458 * @param pszTag Allocation tag used for statistics and such.
459 */
460RTDECL(void *) RTMemPageAllocZTag(size_t cb, const char *pszTag) RT_NO_THROW;
461
462/**
463 * Free a memory block allocated with RTMemPageAlloc() or RTMemPageAllocZ().
464 *
465 * @param pv Pointer to the block as it was returned by the allocation function.
466 * NULL will be ignored.
467 * @param cb The allocation size. Will be rounded up to page size.
468 * Ignored if @a pv is NULL.
469 */
470RTDECL(void) RTMemPageFree(void *pv, size_t cb) RT_NO_THROW;
471
472/** Page level protection flags for RTMemProtect().
473 * @{
474 */
475/** No access at all. */
476#define RTMEM_PROT_NONE 0
477/** Read access. */
478#define RTMEM_PROT_READ 1
479/** Write access. */
480#define RTMEM_PROT_WRITE 2
481/** Execute access. */
482#define RTMEM_PROT_EXEC 4
483/** @} */
484
485/**
486 * Change the page level protection of a memory region.
487 *
488 * @returns iprt status code.
489 * @param pv Start of the region. Will be rounded down to nearest page boundary.
490 * @param cb Size of the region. Will be rounded up to the nearest page boundary.
491 * @param fProtect The new protection, a combination of the RTMEM_PROT_* defines.
492 */
493RTDECL(int) RTMemProtect(void *pv, size_t cb, unsigned fProtect) RT_NO_THROW;
494
495/**
496 * Goes thru some pains to make sure the specified memory block is thoroughly
497 * scrambled.
498 *
499 * @param pv The start of the memory block.
500 * @param cb The size of the memory block.
501 * @param cMinPasses The minimum number of passes to make.
502 */
503RTDECL(void) RTMemWipeThoroughly(void *pv, size_t cb, size_t cMinPasses) RT_NO_THROW;
504
505#ifdef IN_RING0
506
507/**
508 * Allocates physical contiguous memory (below 4GB).
509 * The allocation is page aligned and the content is undefined.
510 *
511 * @returns Pointer to the memory block. This is page aligned.
512 * @param pPhys Where to store the physical address.
513 * @param cb The allocation size in bytes. This is always
514 * rounded up to PAGE_SIZE.
515 */
516RTR0DECL(void *) RTMemContAlloc(PRTCCPHYS pPhys, size_t cb) RT_NO_THROW;
517
518/**
519 * Frees memory allocated ysing RTMemContAlloc().
520 *
521 * @param pv Pointer to return from RTMemContAlloc().
522 * @param cb The cb parameter passed to RTMemContAlloc().
523 */
524RTR0DECL(void) RTMemContFree(void *pv, size_t cb) RT_NO_THROW;
525
526/**
527 * Copy memory from an user mode buffer into a kernel buffer.
528 *
529 * @retval VINF_SUCCESS on success.
530 * @retval VERR_ACCESS_DENIED on error.
531 *
532 * @param pvDst The kernel mode destination address.
533 * @param R3PtrSrc The user mode source address.
534 * @param cb The number of bytes to copy.
535 */
536RTR0DECL(int) RTR0MemUserCopyFrom(void *pvDst, RTR3PTR R3PtrSrc, size_t cb);
537
538/**
539 * Copy memory from a kernel buffer into a user mode one.
540 *
541 * @retval VINF_SUCCESS on success.
542 * @retval VERR_ACCESS_DENIED on error.
543 *
544 * @param R3PtrDst The user mode destination address.
545 * @param pvSrc The kernel mode source address.
546 * @param cb The number of bytes to copy.
547 */
548RTR0DECL(int) RTR0MemUserCopyTo(RTR3PTR R3PtrDst, void const *pvSrc, size_t cb);
549
550/**
551 * Tests if the specified address is in the user addressable range.
552 *
553 * This function does not check whether the memory at that address is accessible
554 * or anything of that sort, only if the address it self is in the user mode
555 * range.
556 *
557 * @returns true if it's in the user addressable range. false if not.
558 * @param R3Ptr The user mode pointer to test.
559 *
560 * @remarks Some systems may have overlapping kernel and user address ranges.
561 * One prominent example of this is the x86 version of Mac OS X. Use
562 * RTR0MemAreKrnlAndUsrDifferent() to check.
563 */
564RTR0DECL(bool) RTR0MemUserIsValidAddr(RTR3PTR R3Ptr);
565
566/**
567 * Tests if the specified address is in the kernel mode range.
568 *
569 * This function does not check whether the memory at that address is accessible
570 * or anything of that sort, only if the address it self is in the kernel mode
571 * range.
572 *
573 * @returns true if it's in the kernel range. false if not.
574 * @param pv The alleged kernel mode pointer.
575 *
576 * @remarks Some systems may have overlapping kernel and user address ranges.
577 * One prominent example of this is the x86 version of Mac OS X. Use
578 * RTR0MemAreKrnlAndUsrDifferent() to check.
579 */
580RTR0DECL(bool) RTR0MemKernelIsValidAddr(void *pv);
581
582/**
583 * Are user mode and kernel mode address ranges distinctly different.
584 *
585 * This determines whether RTR0MemKernelIsValidAddr and RTR0MemUserIsValidAddr
586 * can be used for deciding whether some arbitrary address is a user mode or a
587 * kernel mode one.
588 *
589 * @returns true if they are, false if not.
590 */
591RTR0DECL(bool) RTR0MemAreKrnlAndUsrDifferent(void);
592
593#endif /* IN_RING0 */
594
595
596/** @name Electrical Fence Version of some APIs.
597 * @{
598 */
599
600/**
601 * Same as RTMemTmpAllocTag() except that it's fenced.
602 *
603 * @returns Pointer to the allocated memory.
604 * @returns NULL on failure.
605 * @param cb Size in bytes of the memory block to allocate.
606 * @param pszTag Allocation tag used for statistics and such.
607 */
608RTDECL(void *) RTMemEfTmpAlloc(size_t cb, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
609
610/**
611 * Same as RTMemTmpAllocZTag() except that it's fenced.
612 *
613 * @returns Pointer to the allocated memory.
614 * @returns NULL on failure.
615 * @param cb Size in bytes of the memory block to allocate.
616 * @param pszTag Allocation tag used for statistics and such.
617 */
618RTDECL(void *) RTMemEfTmpAllocZ(size_t cb, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
619
620/**
621 * Same as RTMemTmpFree() except that it's for fenced memory.
622 *
623 * @param pv Pointer to memory block.
624 */
625RTDECL(void) RTMemEfTmpFree(void *pv, RT_SRC_POS_DECL) RT_NO_THROW;
626
627/**
628 * Same as RTMemAllocTag() except that it's fenced.
629 *
630 * @returns Pointer to the allocated memory. Free with RTMemEfFree().
631 * @returns NULL on failure.
632 * @param cb Size in bytes of the memory block to allocate.
633 * @param pszTag Allocation tag used for statistics and such.
634 */
635RTDECL(void *) RTMemEfAlloc(size_t cb, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
636
637/**
638 * Same as RTMemAllocZTag() except that it's fenced.
639 *
640 * @returns Pointer to the allocated memory.
641 * @returns NULL on failure.
642 * @param cb Size in bytes of the memory block to allocate.
643 * @param pszTag Allocation tag used for statistics and such.
644 */
645RTDECL(void *) RTMemEfAllocZ(size_t cb, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
646
647/**
648 * Same as RTMemAllocVarTag() except that it's fenced.
649 *
650 * @returns Pointer to the allocated memory. Free with RTMemEfFree().
651 * @returns NULL on failure.
652 * @param cbUnaligned Size in bytes of the memory block to allocate.
653 * @param pszTag Allocation tag used for statistics and such.
654 */
655RTDECL(void *) RTMemEfAllocVar(size_t cbUnaligned, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
656
657/**
658 * Same as RTMemAllocZVarTag() except that it's fenced.
659 *
660 * @returns Pointer to the allocated memory.
661 * @returns NULL on failure.
662 * @param cbUnaligned Size in bytes of the memory block to allocate.
663 * @param pszTag Allocation tag used for statistics and such.
664 */
665RTDECL(void *) RTMemEfAllocZVar(size_t cbUnaligned, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
666
667/**
668 * Same as RTMemReallocTag() except that it's fenced.
669 *
670 * @returns Pointer to the allocated memory.
671 * @returns NULL on failure.
672 * @param pvOld The memory block to reallocate.
673 * @param cbNew The new block size (in bytes).
674 * @param pszTag Allocation tag used for statistics and such.
675 */
676RTDECL(void *) RTMemEfRealloc(void *pvOld, size_t cbNew, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
677
678/**
679 * Free memory allocated by any of the RTMemEf* allocators.
680 *
681 * @param pv Pointer to memory block.
682 */
683RTDECL(void) RTMemEfFree(void *pv, RT_SRC_POS_DECL) RT_NO_THROW;
684
685/**
686 * Same as RTMemDupTag() except that it's fenced.
687 *
688 * @returns New heap block with the duplicate data.
689 * @returns NULL if we're out of memory.
690 * @param pvSrc The memory to duplicate.
691 * @param cb The amount of memory to duplicate.
692 * @param pszTag Allocation tag used for statistics and such.
693 */
694RTDECL(void *) RTMemEfDup(const void *pvSrc, size_t cb, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
695
696/**
697 * Same as RTMemEfDupExTag except that it's fenced.
698 *
699 * @returns New heap block with the duplicate data.
700 * @returns NULL if we're out of memory.
701 * @param pvSrc The memory to duplicate.
702 * @param cbSrc The amount of memory to duplicate.
703 * @param cbExtra The amount of extra memory to allocate and zero.
704 * @param pszTag Allocation tag used for statistics and such.
705 */
706RTDECL(void *) RTMemEfDupEx(const void *pvSrc, size_t cbSrc, size_t cbExtra, const char *pszTag, RT_SRC_POS_DECL) RT_NO_THROW;
707
708/** @def RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF
709 * Define RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF to enable electric fence new and
710 * delete operators for classes which uses the RTMEMEF_NEW_AND_DELETE_OPERATORS
711 * macro.
712 */
713/** @def RTMEMEF_NEW_AND_DELETE_OPERATORS
714 * Defines the electric fence new and delete operators for a class when
715 * RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF is define.
716 */
717#if defined(RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF) && !defined(RTMEM_NO_WRAP_SOME_NEW_AND_DELETE_TO_EF)
718# if defined(RT_EXCEPTIONS_ENABLED)
719# define RTMEMEF_NEW_AND_DELETE_OPERATORS() \
720 void *operator new(size_t cb) throw(std::bad_alloc) \
721 { \
722 void *pv = RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
723 if (RT_UNLIKELY(!pv)) \
724 throw std::bad_alloc(); \
725 return pv; \
726 } \
727 void *operator new(size_t cb, const std::nothrow_t &nothrow_constant) throw() \
728 { \
729 NOREF(nothrow_constant); \
730 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
731 } \
732 void *operator new[](size_t cb) throw(std::bad_alloc) \
733 { \
734 void *pv = RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
735 if (RT_UNLIKELY(!pv)) \
736 throw std::bad_alloc(); \
737 return pv; \
738 } \
739 void *operator new[](size_t cb, const std::nothrow_t &nothrow_constant) throw() \
740 { \
741 NOREF(nothrow_constant); \
742 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
743 } \
744 \
745 void operator delete(void *pv) throw() \
746 { \
747 RTMemEfFree(pv, RT_SRC_POS); \
748 } \
749 void operator delete(void *pv, const std::nothrow_t &nothrow_constant) throw() \
750 { \
751 NOREF(nothrow_constant); \
752 RTMemEfFree(pv, RT_SRC_POS); \
753 } \
754 void operator delete[](void *pv) throw() \
755 { \
756 RTMemEfFree(pv, RT_SRC_POS); \
757 } \
758 void operator delete[](void *pv, const std::nothrow_t &nothrow_constant) throw() \
759 { \
760 NOREF(nothrow_constant); \
761 RTMemEfFree(pv, RT_SRC_POS); \
762 } \
763 \
764 typedef int UsingElectricNewAndDeleteOperators
765# else
766# define RTMEMEF_NEW_AND_DELETE_OPERATORS() \
767 void *operator new(size_t cb) \
768 { \
769 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
770 } \
771 void *operator new(size_t cb, const std::nothrow_t &nothrow_constant) \
772 { \
773 NOREF(nothrow_constant); \
774 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
775 } \
776 void *operator new[](size_t cb) \
777 { \
778 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
779 } \
780 void *operator new[](size_t cb, const std::nothrow_t &nothrow_constant) \
781 { \
782 NOREF(nothrow_constant); \
783 return RTMemEfAlloc(cb, RTMEM_TAG, RT_SRC_POS); \
784 } \
785 \
786 void operator delete(void *pv) \
787 { \
788 RTMemEfFree(pv, RT_SRC_POS); \
789 } \
790 void operator delete(void *pv, const std::nothrow_t &nothrow_constant) \
791 { \
792 NOREF(nothrow_constant); \
793 RTMemEfFree(pv, RT_SRC_POS); \
794 } \
795 void operator delete[](void *pv) \
796 { \
797 RTMemEfFree(pv, RT_SRC_POS); \
798 } \
799 void operator delete[](void *pv, const std::nothrow_t &nothrow_constant) \
800 { \
801 NOREF(nothrow_constant); \
802 RTMemEfFree(pv, RT_SRC_POS); \
803 } \
804 \
805 typedef int UsingElectricNewAndDeleteOperators
806# endif
807#else
808# define RTMEMEF_NEW_AND_DELETE_OPERATORS() \
809 typedef int UsingDefaultNewAndDeleteOperators
810#endif
811#ifdef DOXYGEN_RUNNING
812# define RTMEM_WRAP_SOME_NEW_AND_DELETE_TO_EF
813#endif
814
815/** @def RTMEM_WRAP_TO_EF_APIS
816 * Define RTMEM_WRAP_TO_EF_APIS to wrap RTMem APIs to RTMemEf APIs.
817 */
818#if defined(RTMEM_WRAP_TO_EF_APIS) && defined(IN_RING3) && !defined(RTMEM_NO_WRAP_TO_EF_APIS)
819# define RTMemTmpAllocTag(cb, pszTag) RTMemEfTmpAlloc((cb), (pszTag), RT_SRC_POS)
820# define RTMemTmpAllocZTag(cb, pszTag) RTMemEfTmpAllocZ((cb), (pszTag), RT_SRC_POS)
821# define RTMemTmpFree(pv) RTMemEfTmpFree((pv), RT_SRC_POS)
822# define RTMemAllocTag(cb, pszTag) RTMemEfAlloc((cb), (pszTag), RT_SRC_POS)
823# define RTMemAllocZTag(cb, pszTag) RTMemEfAllocZ((cb), (pszTag), RT_SRC_POS)
824# define RTMemAllocVarTag(cbUnaligned, pszTag) RTMemEfAllocVar((cbUnaligned), (pszTag), RT_SRC_POS)
825# define RTMemAllocZVarTag(cbUnaligned, pszTag) RTMemEfAllocZVar((cbUnaligned), (pszTag), RT_SRC_POS)
826# define RTMemReallocTag(pvOld, cbNew, pszTag) RTMemEfRealloc((pvOld), (cbNew), (pszTag), RT_SRC_POS)
827# define RTMemFree(pv) RTMemEfFree((pv), RT_SRC_POS)
828# define RTMemDupTag(pvSrc, cb, pszTag) RTMemEfDup((pvSrc), (cb), (pszTag), RT_SRC_POS)
829# define RTMemDupExTag(pvSrc, cbSrc, cbExtra, pszTag) RTMemEfDupEx((pvSrc), (cbSrc), (cbExtra), (pszTag), RT_SRC_POS)
830#endif
831#ifdef DOXYGEN_RUNNING
832# define RTMEM_WRAP_TO_EF_APIS
833#endif
834
835/**
836 * Fenced drop-in replacement for RTMemTmpAllocTag.
837 * @copydoc RTMemTmpAllocTag
838 */
839RTDECL(void *) RTMemEfTmpAllocNP(size_t cb, const char *pszTag) RT_NO_THROW;
840
841/**
842 * Fenced drop-in replacement for RTMemTmpAllocZTag.
843 * @copydoc RTMemTmpAllocZTag
844 */
845RTDECL(void *) RTMemEfTmpAllocZNP(size_t cb, const char *pszTag) RT_NO_THROW;
846
847/**
848 * Fenced drop-in replacement for RTMemTmpFreeTag.
849 * @copydoc RTMemTmpFreeTag
850 */
851RTDECL(void) RTMemEfTmpFreeNP(void *pv) RT_NO_THROW;
852
853/**
854 * Fenced drop-in replacement for RTMemAllocTag.
855 * @copydoc RTMemAllocTag
856 */
857RTDECL(void *) RTMemEfAllocNP(size_t cb, const char *pszTag) RT_NO_THROW;
858
859/**
860 * Fenced drop-in replacement for RTMemAllocZTag.
861 * @copydoc RTMemAllocZTag
862 */
863RTDECL(void *) RTMemEfAllocZNP(size_t cb, const char *pszTag) RT_NO_THROW;
864
865/**
866 * Fenced drop-in replacement for RTMemAllocVarTag
867 * @copydoc RTMemAllocVarTag
868 */
869RTDECL(void *) RTMemEfAllocVarNP(size_t cbUnaligned, const char *pszTag) RT_NO_THROW;
870
871/**
872 * Fenced drop-in replacement for RTMemAllocZVarTag.
873 * @copydoc RTMemAllocZVarTag
874 */
875RTDECL(void *) RTMemEfAllocZVarNP(size_t cbUnaligned, const char *pszTag) RT_NO_THROW;
876
877/**
878 * Fenced drop-in replacement for RTMemReallocTag.
879 * @copydoc RTMemReallocTag
880 */
881RTDECL(void *) RTMemEfReallocNP(void *pvOld, size_t cbNew, const char *pszTag) RT_NO_THROW;
882
883/**
884 * Fenced drop-in replacement for RTMemFree.
885 * @copydoc RTMemFree
886 */
887RTDECL(void) RTMemEfFreeNP(void *pv) RT_NO_THROW;
888
889/**
890 * Fenced drop-in replacement for RTMemDupExTag.
891 * @copydoc RTMemDupExTag
892 */
893RTDECL(void *) RTMemEfDupNP(const void *pvSrc, size_t cb, const char *pszTag) RT_NO_THROW;
894
895/**
896 * Fenced drop-in replacement for RTMemDupExTag.
897 * @copydoc RTMemDupExTag
898 */
899RTDECL(void *) RTMemEfDupExNP(const void *pvSrc, size_t cbSrc, size_t cbExtra, const char *pszTag) RT_NO_THROW;
900
901/** @} */
902
903RT_C_DECLS_END
904
905/** @} */
906
907
908#endif
909
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette