VirtualBox

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

Last change on this file since 36564 was 36538, checked in by vboxsync, 14 years ago

wrong fix

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