VirtualBox

source: vbox/trunk/include/iprt/assert.h@ 27130

Last change on this file since 27130 was 25984, checked in by vboxsync, 15 years ago

pdmifs.h: the penultimate batch of refactored interface ID code.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 76.2 KB
Line 
1/** @file
2 * IPRT - Assertions.
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
26 * Clara, CA 95054 USA or visit http://www.sun.com if you need
27 * additional information or have any questions.
28 */
29
30#ifndef ___iprt_assert_h
31#define ___iprt_assert_h
32
33#include <iprt/cdefs.h>
34#include <iprt/types.h>
35#include <iprt/stdarg.h>
36
37/** @defgroup grp_rt_assert Assert - Assertions
38 * @ingroup grp_rt
39 *
40 * Assertions are generally used to check preconditions and other
41 * assumptions. Sometimes it is also used to catch odd errors or errors
42 * that one would like to inspect in the debugger. They should not be
43 * used for errors that happen frequently.
44 *
45 * IPRT provides a host of assertion macros, so many that it can be a bit
46 * overwhelming at first. Don't despair, there is a system (surprise).
47 *
48 * First there are four families of assertions:
49 * - Assert - The normal strict build only assertions.
50 * - AssertLogRel - Calls LogRel() in non-strict builds, otherwise like Assert.
51 * - AssertRelease - Triggers in all builds.
52 * - AssertFatal - Triggers in all builds and cannot be continued.
53 *
54 * Then there are variations wrt to argument list and behavior on failure:
55 * - Msg - Custom RTStrPrintf-like message with the assertion message.
56 * - Return - Return the specific rc on failure.
57 * - ReturnVoid - Return (void) on failure.
58 * - Break - Break (out of switch/loop) on failure.
59 * - Stmt - Execute the specified statement(s) on failure.
60 * - RC - Assert RT_SUCCESS.
61 * - RCSuccess - Assert VINF_SUCCESS.
62 *
63 * In addition there is a very special family AssertCompile that can be
64 * used for some limited compile-time checking, like structure sizes and member
65 * alignment. This family doesn't have the same variations.
66 *
67 *
68 * @remarks As you might have noticed, the macros don't follow the
69 * coding guidelines wrt to macros supposedly being all uppercase
70 * and underscored. For various reasons they don't, and nobody
71 * has complained yet. Wonder why... :-)
72 *
73 * @remarks Each project has its own specific guidelines on how to use
74 * assertions, so the above is just trying to give you the general idea
75 * from the IPRT point of view.
76 *
77 * @{
78 */
79
80RT_C_DECLS_BEGIN
81
82/**
83 * The 1st part of an assert message.
84 *
85 * @param pszExpr Expression. Can be NULL.
86 * @param uLine Location line number.
87 * @param pszFile Location file name.
88 * @param pszFunction Location function name.
89 */
90RTDECL(void) RTAssertMsg1(const char *pszExpr, unsigned uLine, const char *pszFile, const char *pszFunction);
91/**
92 * Weak version of RTAssertMsg1 that can be overridden locally in a module to
93 * modify, redirect or otherwise mess with the assertion output.
94 *
95 * @copydoc RTAssertMsg1
96 */
97RTDECL(void) RTAssertMsg1Weak(const char *pszExpr, unsigned uLine, const char *pszFile, const char *pszFunction);
98
99/**
100 * The 2nd (optional) part of an assert message.
101 *
102 * @param pszFormat Printf like format string.
103 * @param ... Arguments to that string.
104 */
105RTDECL(void) RTAssertMsg2(const char *pszFormat, ...);
106/**
107 * Weak version of RTAssertMsg2 that forwards to RTAssertMsg2WeakV.
108 *
109 * There is not need to override this, check out RTAssertMsg2WeakV instead!
110 *
111 * @copydoc RTAssertMsg2
112 */
113RTDECL(void) RTAssertMsg2Weak(const char *pszFormat, ...);
114
115/**
116 * The 2nd (optional) part of an assert message.
117 *
118 * @param pszFormat Printf like format string.
119 * @param va Arguments to that string.
120 */
121RTDECL(void) RTAssertMsg2V(const char *pszFormat, va_list va);
122/**
123 * Weak version of RTAssertMsg2V that can be overridden locally in a module to
124 * modify, redirect or otherwise mess with the assertion output.
125 *
126 * @copydoc RTAssertMsg2V
127 */
128RTDECL(void) RTAssertMsg2WeakV(const char *pszFormat, va_list va);
129
130/**
131 * Additional information which should be appended to the 2nd part of an
132 * assertion message.
133 *
134 * @param pszFormat Printf like format string.
135 * @param ... Arguments to that string.
136 */
137RTDECL(void) RTAssertMsg2Add(const char *pszFormat, ...);
138/**
139 * Weak version of RTAssertMsg2Add that forwards to RTAssertMsg2AddWeakV.
140 *
141 * There is not need to override this, check out RTAssertMsg2AddWeakV instead!
142 *
143 * @copydoc RTAssertMsg2Add
144 */
145RTDECL(void) RTAssertMsg2AddWeak(const char *pszFormat, ...);
146
147/**
148 * Additional information which should be appended to the 2nd part of an
149 * assertion message.
150 *
151 * @param pszFormat Printf like format string.
152 * @param va Arguments to that string.
153 */
154RTDECL(void) RTAssertMsg2AddV(const char *pszFormat, va_list va);
155/**
156 * Weak version of RTAssertMsg2AddV that can be overridden locally in a module
157 * to modify, redirect or otherwise mess with the assertion output.
158 *
159 * @copydoc RTAssertMsg2AddV
160 */
161RTDECL(void) RTAssertMsg2AddWeakV(const char *pszFormat, va_list va);
162
163#ifdef IN_RING0
164/**
165 * Panics the system as the result of a fail assertion.
166 */
167RTR0DECL(void) RTR0AssertPanicSystem(void);
168#endif /* IN_RING0 */
169
170/**
171 * Overridable function that decides whether assertions executes the panic
172 * (breakpoint) or not.
173 *
174 * The generic implementation will return true.
175 *
176 * @returns true if the breakpoint should be hit, false if it should be ignored.
177 *
178 * @remark The RTDECL() makes this a bit difficult to override on Windows. So,
179 * you'll have to use RTASSERT_HAVE_SHOULD_PANIC or
180 * RTASSERT_HAVE_SHOULD_PANIC_PRIVATE there to control the kind of
181 * prototype.
182 */
183#if !defined(RTASSERT_HAVE_SHOULD_PANIC) && !defined(RTASSERT_HAVE_SHOULD_PANIC_PRIVATE)
184RTDECL(bool) RTAssertShouldPanic(void);
185#elif defined(RTASSERT_HAVE_SHOULD_PANIC_PRIVATE)
186bool RTAssertShouldPanic(void);
187#else
188DECLEXPORT(bool) RTCALL RTAssertShouldPanic(void);
189#endif
190
191/**
192 * Controls whether the assertions should be quiet or noisy (default).
193 *
194 * @returns The old setting.
195 * @param fQuiet The new setting.
196 */
197RTDECL(bool) RTAssertSetQuiet(bool fQuiet);
198
199/**
200 * Are assertions quiet or noisy?
201 *
202 * @returns True if they are quiet, false if noisy.
203 */
204RTDECL(bool) RTAssertAreQuiet(void);
205
206/**
207 * Makes the assertions panic (default) or not.
208 *
209 * @returns The old setting.
210 * @param fPanic The new setting.
211 */
212RTDECL(bool) RTAssertSetMayPanic(bool fPanic);
213
214/**
215 * Can assertion panic.
216 *
217 * @returns True if they can, false if not.
218 */
219RTDECL(bool) RTAssertMayPanic(void);
220
221
222/** @name Globals for crash analysis
223 * @remarks This is the full potential set, it
224 * @{
225 */
226/** The last assert message, 1st part. */
227extern RTDATADECL(char) g_szRTAssertMsg1[1024];
228/** The last assert message, 2nd part. */
229extern RTDATADECL(char) g_szRTAssertMsg2[4096];
230/** The last assert message, expression. */
231extern RTDATADECL(const char * volatile) g_pszRTAssertExpr;
232/** The last assert message, file name. */
233extern RTDATADECL(const char * volatile) g_pszRTAssertFile;
234/** The last assert message, line number. */
235extern RTDATADECL(uint32_t volatile) g_u32RTAssertLine;
236/** The last assert message, function name. */
237extern RTDATADECL(const char * volatile) g_pszRTAssertFunction;
238/** @} */
239
240RT_C_DECLS_END
241
242/** @def RTAssertDebugBreak()
243 * Debugger breakpoint instruction.
244 *
245 * @remarks In the gnu world we add a nop instruction after the int3 to
246 * force gdb to remain at the int3 source line.
247 * @remarks The L4 kernel will try make sense of the breakpoint, thus the jmp.
248 * @remarks This macro does not depend on RT_STRICT.
249 */
250#ifdef __GNUC__
251# ifndef __L4ENV__
252# define RTAssertDebugBreak() do { __asm__ __volatile__ ("int3\n\tnop"); } while (0)
253# else
254# define RTAssertDebugBreak() do { __asm__ __volatile__ ("int3; jmp 1f; 1:"); } while (0)
255# endif
256#elif defined(_MSC_VER) || defined(DOXYGEN_RUNNING)
257# define RTAssertDebugBreak() do { __debugbreak(); } while (0)
258#else
259# error "Unknown compiler"
260#endif
261
262
263
264/** @name Compile time assertions.
265 *
266 * These assertions are used to check structure sizes, member/size alignments
267 * and similar compile time expressions.
268 *
269 * @{
270 */
271
272/**
273 * RTASSERTTYPE is the type the AssertCompile() macro redefines.
274 * It has no other function and shouldn't be used.
275 * Visual C++ uses this.
276 */
277typedef int RTASSERTTYPE[1];
278
279/**
280 * RTASSERTVAR is the type the AssertCompile() macro redefines.
281 * It has no other function and shouldn't be used.
282 * GCC uses this.
283 */
284#ifdef __GNUC__
285RT_C_DECLS_BEGIN
286#endif
287extern int RTASSERTVAR[1];
288#ifdef __GNUC__
289RT_C_DECLS_END
290#endif
291
292/** @def AssertCompile
293 * Asserts that a compile-time expression is true. If it's not break the build.
294 * @param expr Expression which should be true.
295 */
296#ifdef __GNUC__
297# define AssertCompile(expr) extern int RTASSERTVAR[1] __attribute__((unused)), RTASSERTVAR[(expr) ? 1 : 0] __attribute__((unused))
298#else
299# define AssertCompile(expr) typedef int RTASSERTTYPE[(expr) ? 1 : 0]
300#endif
301
302/** @def AssertCompileSize
303 * Asserts a size at compile.
304 * @param type The type.
305 * @param size The expected type size.
306 */
307#define AssertCompileSize(type, size) \
308 AssertCompile(sizeof(type) == (size))
309
310/** @def AssertCompileSizeAlignment
311 * Asserts a size alignment at compile.
312 * @param type The type.
313 * @param align The size alignment to assert.
314 */
315#define AssertCompileSizeAlignment(type, align) \
316 AssertCompile(!(sizeof(type) & ((align) - 1)))
317
318/** @def AssertCompileMemberSize
319 * Asserts a member offset alignment at compile.
320 * @param type The type.
321 * @param member The member.
322 * @param size The member size to assert.
323 */
324#define AssertCompileMemberSize(type, member, size) \
325 AssertCompile(RT_SIZEOFMEMB(type, member) == (size))
326
327/** @def AssertCompileMemberSizeAlignment
328 * Asserts a member size alignment at compile.
329 * @param type The type.
330 * @param member The member.
331 * @param align The member size alignment to assert.
332 */
333#define AssertCompileMemberSizeAlignment(type, member, align) \
334 AssertCompile(!(RT_SIZEOFMEMB(type, member) & ((align) - 1)))
335
336/** @def AssertCompileMemberAlignment
337 * Asserts a member offset alignment at compile.
338 * @param type The type.
339 * @param member The member.
340 * @param align The member offset alignment to assert.
341 */
342#if defined(__GNUC__) && defined(__cplusplus)
343# if __GNUC__ >= 4
344# define AssertCompileMemberAlignment(type, member, align) \
345 AssertCompile(!(__builtin_offsetof(type, member) & ((align) - 1)))
346# else
347# define AssertCompileMemberAlignment(type, member, align) \
348 AssertCompile(!(RT_OFFSETOF(type, member) & ((align) - 1)))
349# endif
350#else
351# define AssertCompileMemberAlignment(type, member, align) \
352 AssertCompile(!(RT_OFFSETOF(type, member) & ((align) - 1)))
353#endif
354
355/** @def AssertCompileMemberOffset
356 * Asserts a offset of a structure member at compile.
357 * @param type The type.
358 * @param member The member.
359 * @param off The expected offset.
360 */
361#if defined(__GNUC__) && defined(__cplusplus)
362# if __GNUC__ >= 4
363# define AssertCompileMemberOffset(type, member, off) \
364 AssertCompile(__builtin_offsetof(type, member) == (off))
365# else
366# define AssertCompileMemberOffset(type, member, off) \
367 AssertCompile(RT_OFFSETOF(type, member) == (off))
368# endif
369#else
370# define AssertCompileMemberOffset(type, member, off) \
371 AssertCompile(RT_OFFSETOF(type, member) == (off))
372#endif
373
374/** @def AssertCompile2MemberOffsets
375 * Asserts that two (sub-structure) members in union have the same offset.
376 * @param type The type.
377 * @param member1 The first member.
378 * @param member2 The second member.
379 */
380#if defined(__GNUC__) && defined(__cplusplus)
381# if __GNUC__ >= 4
382# define AssertCompile2MemberOffsets(type, member1, member2) \
383 AssertCompile(__builtin_offsetof(type, member1) == __builtin_offsetof(type, member2))
384# else
385# define AssertCompile2MemberOffsets(type, member1, member2) \
386 AssertCompile(RT_OFFSETOF(type, member1) == RT_OFFSETOF(type, member2))
387# endif
388#else
389# define AssertCompile2MemberOffsets(type, member1, member2) \
390 AssertCompile(RT_OFFSETOF(type, member1) == RT_OFFSETOF(type, member2))
391#endif
392
393/** @} */
394
395
396
397/** @name Assertions
398 *
399 * These assertions will only trigger when RT_STRICT is defined. When it is
400 * undefined they will all be no-ops and generate no code.
401 *
402 * @{
403 */
404
405
406/** @def RTASSERT_QUIET
407 * This can be defined to shut up the messages for a file where this would be
408 * problematic because the message printing code path passes thru it.
409 * @internal */
410#ifdef DOXYGEN_RUNNING
411# define RTASSERT_QUIET
412#endif
413#if defined(RTASSERT_QUIET) && !defined(DOXYGEN_RUNNING)
414# define RTAssertMsg1Weak(pszExpr, uLine, pszfile, pszFunction) \
415 do { } while (0)
416# define RTAssertMsg2Weak if (0) RTAssertMsg2Weak
417#endif
418
419/** @def RTAssertDoPanic
420 * Raises an assertion panic appropriate to the current context.
421 * @remarks This macro does not depend on RT_STRICT.
422 */
423#if defined(IN_RING0) \
424 && (defined(RT_OS_DARWIN) || defined(RT_OS_SOLARIS))
425# define RTAssertDoPanic() RTR0AssertPanicSystem()
426#else
427# define RTAssertDoPanic() RTAssertDebugBreak()
428#endif
429
430/** @def AssertBreakpoint()
431 * Assertion Breakpoint.
432 * @deprecated Use RTAssertPanic or RTAssertDebugBreak instead.
433 */
434#ifdef RT_STRICT
435# define AssertBreakpoint() RTAssertDebugBreak()
436#else
437# define AssertBreakpoint() do { } while (0)
438#endif
439
440/** @def RTAssertPanic()
441 * If RT_STRICT is defined this macro will invoke RTAssertDoPanic if
442 * RTAssertShouldPanic returns true. If RT_STRICT isn't defined it won't do any
443 * thing.
444 */
445#ifdef RT_STRICT
446# define RTAssertPanic() do { if (RTAssertShouldPanic()) RTAssertDoPanic(); } while (0)
447#else
448# define RTAssertPanic() do { } while (0)
449#endif
450
451/** @def Assert
452 * Assert that an expression is true. If false, hit breakpoint.
453 * @param expr Expression which should be true.
454 */
455#ifdef RT_STRICT
456# define Assert(expr) \
457 do { \
458 if (RT_UNLIKELY(!(expr))) \
459 { \
460 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
461 RTAssertPanic(); \
462 } \
463 } while (0)
464#else
465# define Assert(expr) do { } while (0)
466#endif
467
468
469/** @def AssertStmt
470 * Assert that an expression is true. If false, hit breakpoint and execute the
471 * statement.
472 * @param expr Expression which should be true.
473 * @param stmt Statement to execute on failure.
474 */
475#ifdef RT_STRICT
476# define AssertStmt(expr, stmt) \
477 do { \
478 if (RT_UNLIKELY(!(expr))) \
479 { \
480 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
481 RTAssertPanic(); \
482 stmt; \
483 } \
484 } while (0)
485#else
486# define AssertStmt(expr, stmt) \
487 do { \
488 if (RT_UNLIKELY(!(expr))) \
489 { \
490 stmt; \
491 } \
492 } while (0)
493#endif
494
495
496/** @def AssertReturn
497 * Assert that an expression is true and returns if it isn't.
498 * In RT_STRICT mode it will hit a breakpoint before returning.
499 *
500 * @param expr Expression which should be true.
501 * @param rc What is to be presented to return.
502 */
503#ifdef RT_STRICT
504# define AssertReturn(expr, rc) \
505 do { \
506 if (RT_UNLIKELY(!(expr))) \
507 { \
508 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
509 RTAssertPanic(); \
510 return (rc); \
511 } \
512 } while (0)
513#else
514# define AssertReturn(expr, rc) \
515 do { \
516 if (RT_UNLIKELY(!(expr))) \
517 return (rc); \
518 } while (0)
519#endif
520
521/** @def AssertReturnStmt
522 * Assert that an expression is true, if it isn't execute the given statement
523 * and return rc.
524 *
525 * In RT_STRICT mode it will hit a breakpoint before executing the statement and
526 * returning.
527 *
528 * @param expr Expression which should be true.
529 * @param stmt Statement to execute before returning on failure.
530 * @param rc What is to be presented to return.
531 */
532#ifdef RT_STRICT
533# define AssertReturnStmt(expr, stmt, rc) \
534 do { \
535 if (RT_UNLIKELY(!(expr))) \
536 { \
537 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
538 RTAssertPanic(); \
539 stmt; \
540 return (rc); \
541 } \
542 } while (0)
543#else
544# define AssertReturnStmt(expr, stmt, rc) \
545 do { \
546 if (RT_UNLIKELY(!(expr))) \
547 { \
548 stmt; \
549 return (rc); \
550 } \
551 } while (0)
552#endif
553
554/** @def AssertReturnVoid
555 * Assert that an expression is true and returns if it isn't.
556 * In RT_STRICT mode it will hit a breakpoint before returning.
557 *
558 * @param expr Expression which should be true.
559 */
560#ifdef RT_STRICT
561# define AssertReturnVoid(expr) \
562 do { \
563 if (RT_UNLIKELY(!(expr))) \
564 { \
565 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
566 RTAssertPanic(); \
567 return; \
568 } \
569 } while (0)
570#else
571# define AssertReturnVoid(expr) \
572 do { \
573 if (RT_UNLIKELY(!(expr))) \
574 return; \
575 } while (0)
576#endif
577
578/** @def AssertReturnVoidStmt
579 * Assert that an expression is true, if it isn't execute the given statement
580 * and return.
581 *
582 * In RT_STRICT mode it will hit a breakpoint before returning.
583 *
584 * @param expr Expression which should be true.
585 * @param stmt Statement to execute before returning on failure.
586 */
587#ifdef RT_STRICT
588# define AssertReturnVoidStmt(expr, stmt) \
589 do { \
590 if (RT_UNLIKELY(!(expr))) \
591 { \
592 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
593 RTAssertPanic(); \
594 stmt; \
595 return; \
596 } \
597 } while (0)
598#else
599# define AssertReturnVoidStmt(expr, stmt) \
600 do { \
601 if (RT_UNLIKELY(!(expr))) \
602 { \
603 stmt; \
604 return; \
605 } \
606 } while (0)
607#endif
608
609
610/** @def AssertBreak
611 * Assert that an expression is true and breaks if it isn't.
612 * In RT_STRICT mode it will hit a breakpoint before returning.
613 *
614 * @param expr Expression which should be true.
615 */
616#ifdef RT_STRICT
617# define AssertBreak(expr) \
618 if (RT_UNLIKELY(!(expr))) \
619 { \
620 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
621 RTAssertPanic(); \
622 break; \
623 } else do {} while (0)
624#else
625# define AssertBreak(expr) \
626 if (RT_UNLIKELY(!(expr))) \
627 break; \
628 else do {} while (0)
629#endif
630
631/** @def AssertBreakStmt
632 * Assert that an expression is true and breaks if it isn't.
633 * In RT_STRICT mode it will hit a breakpoint before doing break.
634 *
635 * @param expr Expression which should be true.
636 * @param stmt Statement to execute before break in case of a failed assertion.
637 */
638#ifdef RT_STRICT
639# define AssertBreakStmt(expr, stmt) \
640 if (RT_UNLIKELY(!(expr))) { \
641 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
642 RTAssertPanic(); \
643 stmt; \
644 break; \
645 } else do {} while (0)
646#else
647# define AssertBreakStmt(expr, stmt) \
648 if (RT_UNLIKELY(!(expr))) { \
649 stmt; \
650 break; \
651 } else do {} while (0)
652#endif
653
654
655/** @def AssertMsg
656 * Assert that an expression is true. If it's not print message and hit breakpoint.
657 * @param expr Expression which should be true.
658 * @param a printf argument list (in parenthesis).
659 */
660#ifdef RT_STRICT
661# define AssertMsg(expr, a) \
662 do { \
663 if (RT_UNLIKELY(!(expr))) \
664 { \
665 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
666 RTAssertMsg2Weak a; \
667 RTAssertPanic(); \
668 } \
669 } while (0)
670#else
671# define AssertMsg(expr, a) do { } while (0)
672#endif
673
674/** @def AssertMsgStmt
675 * Assert that an expression is true. If it's not print message and hit
676 * breakpoint and execute the statement.
677 *
678 * @param expr Expression which should be true.
679 * @param a printf argument list (in parenthesis).
680 * @param stmt Statement to execute in case of a failed assertion.
681 *
682 * @remarks The expression and statement will be evaluated in all build types.
683 */
684#ifdef RT_STRICT
685# define AssertMsgStmt(expr, a, stmt) \
686 do { \
687 if (RT_UNLIKELY(!(expr))) \
688 { \
689 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
690 RTAssertMsg2Weak a; \
691 RTAssertPanic(); \
692 stmt; \
693 } \
694 } while (0)
695#else
696# define AssertMsgStmt(expr, a, stmt) \
697 do { \
698 if (RT_UNLIKELY(!(expr))) \
699 { \
700 stmt; \
701 } \
702 } while (0)
703#endif
704
705/** @def AssertMsgReturn
706 * Assert that an expression is true and returns if it isn't.
707 * In RT_STRICT mode it will hit a breakpoint before returning.
708 *
709 * @param expr Expression which should be true.
710 * @param a printf argument list (in parenthesis).
711 * @param rc What is to be presented to return.
712 */
713#ifdef RT_STRICT
714# define AssertMsgReturn(expr, a, rc) \
715 do { \
716 if (RT_UNLIKELY(!(expr))) \
717 { \
718 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
719 RTAssertMsg2Weak a; \
720 RTAssertPanic(); \
721 return (rc); \
722 } \
723 } while (0)
724#else
725# define AssertMsgReturn(expr, a, rc) \
726 do { \
727 if (RT_UNLIKELY(!(expr))) \
728 return (rc); \
729 } while (0)
730#endif
731
732/** @def AssertMsgReturnStmt
733 * Assert that an expression is true, if it isn't execute the statement and
734 * return.
735 *
736 * In RT_STRICT mode it will hit a breakpoint before returning.
737 *
738 * @param expr Expression which should be true.
739 * @param a printf argument list (in parenthesis).
740 * @param stmt Statement to execute before break in case of a failed assertion.
741 * @param rc What is to be presented to return.
742 */
743#ifdef RT_STRICT
744# define AssertMsgReturnStmt(expr, a, stmt, rc) \
745 do { \
746 if (RT_UNLIKELY(!(expr))) \
747 { \
748 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
749 RTAssertMsg2Weak a; \
750 RTAssertPanic(); \
751 stmt; \
752 return (rc); \
753 } \
754 } while (0)
755#else
756# define AssertMsgReturnStmt(expr, a, stmt, rc) \
757 do { \
758 if (RT_UNLIKELY(!(expr))) \
759 { \
760 stmt; \
761 return (rc); \
762 } \
763 } while (0)
764#endif
765
766/** @def AssertMsgReturnVoid
767 * Assert that an expression is true and returns if it isn't.
768 * In RT_STRICT mode it will hit a breakpoint before returning.
769 *
770 * @param expr Expression which should be true.
771 * @param a printf argument list (in parenthesis).
772 */
773#ifdef RT_STRICT
774# define AssertMsgReturnVoid(expr, a) \
775 do { \
776 if (RT_UNLIKELY(!(expr))) \
777 { \
778 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
779 RTAssertMsg2Weak a; \
780 RTAssertPanic(); \
781 return; \
782 } \
783 } while (0)
784#else
785# define AssertMsgReturnVoid(expr, a) \
786 do { \
787 if (RT_UNLIKELY(!(expr))) \
788 return; \
789 } while (0)
790#endif
791
792/** @def AssertMsgReturnVoidStmt
793 * Assert that an expression is true, if it isn't execute the statement and
794 * return.
795 *
796 * In RT_STRICT mode it will hit a breakpoint before returning.
797 *
798 * @param expr Expression which should be true.
799 * @param a printf argument list (in parenthesis).
800 * @param stmt Statement to execute before break in case of a failed assertion.
801 */
802#ifdef RT_STRICT
803# define AssertMsgReturnVoidStmt(expr, a, stmt) \
804 do { \
805 if (RT_UNLIKELY(!(expr))) \
806 { \
807 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
808 RTAssertMsg2Weak a; \
809 RTAssertPanic(); \
810 stmt; \
811 return; \
812 } \
813 } while (0)
814#else
815# define AssertMsgReturnVoidStmt(expr, a, stmt) \
816 do { \
817 if (RT_UNLIKELY(!(expr))) \
818 { \
819 stmt; \
820 return; \
821 } \
822 } while (0)
823#endif
824
825
826/** @def AssertMsgBreak
827 * Assert that an expression is true and breaks if it isn't.
828 * In RT_STRICT mode it will hit a breakpoint before returning.
829 *
830 * @param expr Expression which should be true.
831 * @param a printf argument list (in parenthesis).
832 */
833#ifdef RT_STRICT
834# define AssertMsgBreak(expr, a) \
835 if (RT_UNLIKELY(!(expr))) \
836 { \
837 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
838 RTAssertMsg2Weak a; \
839 RTAssertPanic(); \
840 break; \
841 } else do {} while (0)
842#else
843# define AssertMsgBreak(expr, a) \
844 if (RT_UNLIKELY(!(expr))) \
845 break; \
846 else do {} while (0)
847#endif
848
849/** @def AssertMsgBreakStmt
850 * Assert that an expression is true and breaks if it isn't.
851 * In RT_STRICT mode it will hit a breakpoint before doing break.
852 *
853 * @param expr Expression which should be true.
854 * @param a printf argument list (in parenthesis).
855 * @param stmt Statement to execute before break in case of a failed assertion.
856 */
857#ifdef RT_STRICT
858# define AssertMsgBreakStmt(expr, a, stmt) \
859 if (RT_UNLIKELY(!(expr))) { \
860 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
861 RTAssertMsg2Weak a; \
862 RTAssertPanic(); \
863 stmt; \
864 break; \
865 } else do {} while (0)
866#else
867# define AssertMsgBreakStmt(expr, a, stmt) \
868 if (RT_UNLIKELY(!(expr))) { \
869 stmt; \
870 break; \
871 } else do {} while (0)
872#endif
873
874/** @def AssertFailed
875 * An assertion failed hit breakpoint.
876 */
877#ifdef RT_STRICT
878# define AssertFailed() \
879 do { \
880 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
881 RTAssertPanic(); \
882 } while (0)
883#else
884# define AssertFailed() do { } while (0)
885#endif
886
887/** @def AssertFailedReturn
888 * An assertion failed, hit breakpoint (RT_STRICT mode only) and return.
889 *
890 * @param rc The rc to return.
891 */
892#ifdef RT_STRICT
893# define AssertFailedReturn(rc) \
894 do { \
895 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
896 RTAssertPanic(); \
897 return (rc); \
898 } while (0)
899#else
900# define AssertFailedReturn(rc) \
901 do { \
902 return (rc); \
903 } while (0)
904#endif
905
906/** @def AssertFailedReturnStmt
907 * An assertion failed, hit breakpoint (RT_STRICT mode only), execute a
908 * statement and return a value.
909 *
910 * @param stmt The statement to execute before returning.
911 * @param rc The value to return.
912 */
913#ifdef RT_STRICT
914# define AssertFailedReturnStmt(stmt, rc) \
915 do { \
916 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
917 RTAssertPanic(); \
918 stmt; \
919 return (rc); \
920 } while (0)
921#else
922# define AssertFailedReturnStmt(stmt, rc) \
923 do { \
924 stmt; \
925 return (rc); \
926 } while (0)
927#endif
928
929/** @def AssertFailedReturnVoid
930 * An assertion failed, hit breakpoint (RT_STRICT mode only) and return.
931 */
932#ifdef RT_STRICT
933# define AssertFailedReturnVoid() \
934 do { \
935 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
936 RTAssertPanic(); \
937 return; \
938 } while (0)
939#else
940# define AssertFailedReturnVoid() \
941 do { \
942 return; \
943 } while (0)
944#endif
945
946/** @def AssertFailedReturnVoidStmt
947 * An assertion failed, hit breakpoint (RT_STRICT mode only), execute a
948 * statement and return.
949 *
950 * @param stmt The statement to execute before returning.
951 */
952#ifdef RT_STRICT
953# define AssertFailedReturnVoidStmt(stmt) \
954 do { \
955 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
956 RTAssertPanic(); \
957 stmt; \
958 return; \
959 } while (0)
960#else
961# define AssertFailedReturnVoidStmt(stmt) \
962 do { \
963 stmt; \
964 return; \
965 } while (0)
966#endif
967
968
969/** @def AssertFailedBreak
970 * An assertion failed, hit breakpoint (RT_STRICT mode only) and break.
971 */
972#ifdef RT_STRICT
973# define AssertFailedBreak() \
974 if (1) { \
975 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
976 RTAssertPanic(); \
977 break; \
978 } else do {} while (0)
979#else
980# define AssertFailedBreak() \
981 if (1) \
982 break; \
983 else do {} while (0)
984#endif
985
986/** @def AssertFailedBreakStmt
987 * An assertion failed, hit breakpoint (RT_STRICT mode only), execute
988 * the given statement and break.
989 *
990 * @param stmt Statement to execute before break.
991 */
992#ifdef RT_STRICT
993# define AssertFailedBreakStmt(stmt) \
994 if (1) { \
995 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
996 RTAssertPanic(); \
997 stmt; \
998 break; \
999 } else do {} while (0)
1000#else
1001# define AssertFailedBreakStmt(stmt) \
1002 if (1) { \
1003 stmt; \
1004 break; \
1005 } else do {} while (0)
1006#endif
1007
1008
1009/** @def AssertMsgFailed
1010 * An assertion failed print a message and a hit breakpoint.
1011 *
1012 * @param a printf argument list (in parenthesis).
1013 */
1014#ifdef RT_STRICT
1015# define AssertMsgFailed(a) \
1016 do { \
1017 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1018 RTAssertMsg2Weak a; \
1019 RTAssertPanic(); \
1020 } while (0)
1021#else
1022# define AssertMsgFailed(a) do { } while (0)
1023#endif
1024
1025/** @def AssertMsgFailedReturn
1026 * An assertion failed, hit breakpoint with message (RT_STRICT mode only) and return.
1027 *
1028 * @param a printf argument list (in parenthesis).
1029 * @param rc What is to be presented to return.
1030 */
1031#ifdef RT_STRICT
1032# define AssertMsgFailedReturn(a, rc) \
1033 do { \
1034 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1035 RTAssertMsg2Weak a; \
1036 RTAssertPanic(); \
1037 return (rc); \
1038 } while (0)
1039#else
1040# define AssertMsgFailedReturn(a, rc) \
1041 do { \
1042 return (rc); \
1043 } while (0)
1044#endif
1045
1046/** @def AssertMsgFailedReturnVoid
1047 * An assertion failed, hit breakpoint with message (RT_STRICT mode only) and return.
1048 *
1049 * @param a printf argument list (in parenthesis).
1050 */
1051#ifdef RT_STRICT
1052# define AssertMsgFailedReturnVoid(a) \
1053 do { \
1054 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1055 RTAssertMsg2Weak a; \
1056 RTAssertPanic(); \
1057 return; \
1058 } while (0)
1059#else
1060# define AssertMsgFailedReturnVoid(a) \
1061 do { \
1062 return; \
1063 } while (0)
1064#endif
1065
1066
1067/** @def AssertMsgFailedBreak
1068 * An assertion failed, hit breakpoint with message (RT_STRICT mode only) and break.
1069 *
1070 * @param a printf argument list (in parenthesis).
1071 */
1072#ifdef RT_STRICT
1073# define AssertMsgFailedBreak(a) \
1074 if (1) { \
1075 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1076 RTAssertMsg2Weak a; \
1077 RTAssertPanic(); \
1078 break; \
1079 } else do {} while (0)
1080#else
1081# define AssertMsgFailedBreak(a) \
1082 if (1) \
1083 break; \
1084 else do {} while (0)
1085#endif
1086
1087/** @def AssertMsgFailedBreakStmt
1088 * An assertion failed, hit breakpoint (RT_STRICT mode only), execute
1089 * the given statement and break.
1090 *
1091 * @param a printf argument list (in parenthesis).
1092 * @param stmt Statement to execute before break.
1093 */
1094#ifdef RT_STRICT
1095# define AssertMsgFailedBreakStmt(a, stmt) \
1096 if (1) { \
1097 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1098 RTAssertMsg2Weak a; \
1099 RTAssertPanic(); \
1100 stmt; \
1101 break; \
1102 } else do {} while (0)
1103#else
1104# define AssertMsgFailedBreakStmt(a, stmt) \
1105 if (1) { \
1106 stmt; \
1107 break; \
1108 } else do {} while (0)
1109#endif
1110
1111/** @} */
1112
1113
1114
1115/** @name Release Log Assertions
1116 *
1117 * These assertions will work like normal strict assertion when RT_STRICT is
1118 * defined and LogRel statements when RT_STRICT is undefined. Typically used for
1119 * things which shouldn't go wrong, but when it does you'd like to know one way
1120 * or the other.
1121 *
1122 * @{
1123 */
1124
1125/** @def RTAssertLogRelMsg1
1126 * RTAssertMsg1Weak (strict builds) / LogRel wrapper (non-strict).
1127 */
1128#ifdef RT_STRICT
1129# define RTAssertLogRelMsg1(pszExpr, iLine, pszFile, pszFunction) \
1130 RTAssertMsg1Weak(pszExpr, iLine, pszFile, pszFunction)
1131#else
1132# define RTAssertLogRelMsg1(pszExpr, iLine, pszFile, pszFunction) \
1133 LogRel(("AssertLogRel %s(%d) %s: %s\n",\
1134 (pszFile), (iLine), (pszFunction), (pszExpr) ))
1135#endif
1136
1137/** @def RTAssertLogRelMsg2
1138 * RTAssertMsg2Weak (strict builds) / LogRel wrapper (non-strict).
1139 */
1140#ifdef RT_STRICT
1141# define RTAssertLogRelMsg2(a) RTAssertMsg2Weak a
1142#else
1143# define RTAssertLogRelMsg2(a) LogRel(a)
1144#endif
1145
1146/** @def AssertLogRel
1147 * Assert that an expression is true.
1148 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1149 *
1150 * @param expr Expression which should be true.
1151 */
1152#define AssertLogRel(expr) \
1153 do { \
1154 if (RT_UNLIKELY(!(expr))) \
1155 { \
1156 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1157 RTAssertPanic(); \
1158 } \
1159 } while (0)
1160
1161/** @def AssertLogRelReturn
1162 * Assert that an expression is true, return \a rc if it isn't.
1163 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1164 *
1165 * @param expr Expression which should be true.
1166 * @param rc What is to be presented to return.
1167 */
1168#define AssertLogRelReturn(expr, rc) \
1169 do { \
1170 if (RT_UNLIKELY(!(expr))) \
1171 { \
1172 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1173 RTAssertPanic(); \
1174 return (rc); \
1175 } \
1176 } while (0)
1177
1178/** @def AssertLogRelReturnVoid
1179 * Assert that an expression is true, return void if it isn't.
1180 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1181 *
1182 * @param expr Expression which should be true.
1183 */
1184#define AssertLogRelReturnVoid(expr) \
1185 do { \
1186 if (RT_UNLIKELY(!(expr))) \
1187 { \
1188 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1189 RTAssertPanic(); \
1190 return; \
1191 } \
1192 } while (0)
1193
1194/** @def AssertLogRelBreak
1195 * Assert that an expression is true, break if it isn't.
1196 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1197 *
1198 * @param expr Expression which should be true.
1199 */
1200#define AssertLogRelBreak(expr) \
1201 if (RT_UNLIKELY(!(expr))) \
1202 { \
1203 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1204 RTAssertPanic(); \
1205 break; \
1206 } \
1207 else do {} while (0)
1208
1209/** @def AssertLogRelBreakStmt
1210 * Assert that an expression is true, execute \a stmt and break if it isn't.
1211 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1212 *
1213 * @param expr Expression which should be true.
1214 * @param stmt Statement to execute before break in case of a failed assertion.
1215 */
1216#define AssertLogRelBreakStmt(expr, stmt) \
1217 if (RT_UNLIKELY(!(expr))) \
1218 { \
1219 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1220 RTAssertPanic(); \
1221 stmt; \
1222 break; \
1223 } else do {} while (0)
1224
1225/** @def AssertLogRelMsg
1226 * Assert that an expression is true.
1227 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1228 *
1229 * @param expr Expression which should be true.
1230 * @param a printf argument list (in parenthesis).
1231 */
1232#define AssertLogRelMsg(expr, a) \
1233 do { \
1234 if (RT_UNLIKELY(!(expr))) \
1235 { \
1236 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1237 RTAssertLogRelMsg2(a); \
1238 RTAssertPanic(); \
1239 } \
1240 } while (0)
1241
1242/** @def AssertLogRelMsgReturn
1243 * Assert that an expression is true, return \a rc if it isn't.
1244 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1245 *
1246 * @param expr Expression which should be true.
1247 * @param a printf argument list (in parenthesis).
1248 * @param rc What is to be presented to return.
1249 */
1250#define AssertLogRelMsgReturn(expr, a, rc) \
1251 do { \
1252 if (RT_UNLIKELY(!(expr))) \
1253 { \
1254 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1255 RTAssertLogRelMsg2(a); \
1256 RTAssertPanic(); \
1257 return (rc); \
1258 } \
1259 } while (0)
1260
1261/** @def AssertLogRelMsgReturnVoid
1262 * Assert that an expression is true, return (void) if it isn't.
1263 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1264 *
1265 * @param expr Expression which should be true.
1266 * @param a printf argument list (in parenthesis).
1267 */
1268#define AssertLogRelMsgReturnVoid(expr, a) \
1269 do { \
1270 if (RT_UNLIKELY(!(expr))) \
1271 { \
1272 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1273 RTAssertLogRelMsg2(a); \
1274 RTAssertPanic(); \
1275 return; \
1276 } \
1277 } while (0)
1278
1279/** @def AssertLogRelMsgBreak
1280 * Assert that an expression is true, break if it isn't.
1281 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1282 *
1283 * @param expr Expression which should be true.
1284 * @param a printf argument list (in parenthesis).
1285 */
1286#define AssertLogRelMsgBreak(expr, a) \
1287 if (RT_UNLIKELY(!(expr))) \
1288 { \
1289 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1290 RTAssertLogRelMsg2(a); \
1291 RTAssertPanic(); \
1292 break; \
1293 } \
1294 else do {} while (0)
1295
1296/** @def AssertLogRelMsgBreakStmt
1297 * Assert that an expression is true, execute \a stmt and break if it isn't.
1298 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1299 *
1300 * @param expr Expression which should be true.
1301 * @param a printf argument list (in parenthesis).
1302 * @param stmt Statement to execute before break in case of a failed assertion.
1303 */
1304#define AssertLogRelMsgBreakStmt(expr, a, stmt) \
1305 if (RT_UNLIKELY(!(expr))) \
1306 { \
1307 RTAssertLogRelMsg1(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1308 RTAssertLogRelMsg2(a); \
1309 RTAssertPanic(); \
1310 stmt; \
1311 break; \
1312 } else do {} while (0)
1313
1314/** @def AssertLogRelFailed
1315 * An assertion failed.
1316 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1317 */
1318#define AssertLogRelFailed() \
1319 do { \
1320 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1321 RTAssertPanic(); \
1322 } while (0)
1323
1324/** @def AssertLogRelFailedReturn
1325 * An assertion failed.
1326 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1327 *
1328 * @param rc What is to be presented to return.
1329 */
1330#define AssertLogRelFailedReturn(rc) \
1331 do { \
1332 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1333 RTAssertPanic(); \
1334 return (rc); \
1335 } while (0)
1336
1337/** @def AssertLogRelFailedReturnVoid
1338 * An assertion failed, hit a breakpoint and return.
1339 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1340 */
1341#define AssertLogRelFailedReturnVoid() \
1342 do { \
1343 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1344 RTAssertPanic(); \
1345 return; \
1346 } while (0)
1347
1348/** @def AssertLogRelFailedBreak
1349 * An assertion failed, break.
1350 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1351 */
1352#define AssertLogRelFailedBreak() \
1353 if (1) \
1354 { \
1355 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1356 RTAssertPanic(); \
1357 break; \
1358 } else do {} while (0)
1359
1360/** @def AssertLogRelFailedBreakStmt
1361 * An assertion failed, execute \a stmt and break.
1362 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1363 *
1364 * @param stmt Statement to execute before break.
1365 */
1366#define AssertLogRelFailedBreakStmt(stmt) \
1367 if (1) \
1368 { \
1369 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1370 RTAssertPanic(); \
1371 stmt; \
1372 break; \
1373 } else do {} while (0)
1374
1375/** @def AssertLogRelMsgFailed
1376 * An assertion failed.
1377 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1378 *
1379 * @param a printf argument list (in parenthesis).
1380 */
1381#define AssertLogRelMsgFailed(a) \
1382 do { \
1383 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1384 RTAssertLogRelMsg2(a); \
1385 RTAssertPanic(); \
1386 } while (0)
1387
1388/** @def AssertLogRelMsgFailedReturn
1389 * An assertion failed, return \a rc.
1390 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1391 *
1392 * @param a printf argument list (in parenthesis).
1393 * @param rc What is to be presented to return.
1394 */
1395#define AssertLogRelMsgFailedReturn(a, rc) \
1396 do { \
1397 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1398 RTAssertLogRelMsg2(a); \
1399 RTAssertPanic(); \
1400 return (rc); \
1401 } while (0)
1402
1403/** @def AssertLogRelMsgFailedReturnVoid
1404 * An assertion failed, return void.
1405 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1406 *
1407 * @param a printf argument list (in parenthesis).
1408 */
1409#define AssertLogRelMsgFailedReturnVoid(a) \
1410 do { \
1411 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1412 RTAssertLogRelMsg2(a); \
1413 RTAssertPanic(); \
1414 return; \
1415 } while (0)
1416
1417/** @def AssertLogRelMsgFailedBreak
1418 * An assertion failed, break.
1419 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1420 *
1421 * @param a printf argument list (in parenthesis).
1422 */
1423#define AssertLogRelMsgFailedBreak(a) \
1424 if (1)\
1425 { \
1426 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1427 RTAssertLogRelMsg2(a); \
1428 RTAssertPanic(); \
1429 break; \
1430 } else do {} while (0)
1431
1432/** @def AssertLogRelMsgFailedBreakStmt
1433 * An assertion failed, execute \a stmt and break.
1434 * Strict builds will hit a breakpoint, non-strict will only do LogRel.
1435 *
1436 * @param a printf argument list (in parenthesis).
1437 * @param stmt Statement to execute before break.
1438 */
1439#define AssertLogRelMsgFailedBreakStmt(a, stmt) \
1440 if (1) \
1441 { \
1442 RTAssertLogRelMsg1((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1443 RTAssertLogRelMsg2(a); \
1444 RTAssertPanic(); \
1445 stmt; \
1446 break; \
1447 } else do {} while (0)
1448
1449/** @} */
1450
1451
1452
1453/** @name Release Assertions
1454 *
1455 * These assertions are always enabled.
1456 * @{
1457 */
1458
1459/** @def RTAssertReleasePanic()
1460 * Invokes RTAssertShouldPanic and RTAssertDoPanic.
1461 *
1462 * It might seem odd that RTAssertShouldPanic is necessary when its result isn't
1463 * checked, but it's done since RTAssertShouldPanic is overrideable and might be
1464 * used to bail out before taking down the system (the VMMR0 case).
1465 */
1466#define RTAssertReleasePanic() do { RTAssertShouldPanic(); RTAssertDoPanic(); } while (0)
1467
1468
1469/** @def AssertRelease
1470 * Assert that an expression is true. If it's not hit a breakpoint.
1471 *
1472 * @param expr Expression which should be true.
1473 */
1474#define AssertRelease(expr) \
1475 do { \
1476 if (RT_UNLIKELY(!(expr))) \
1477 { \
1478 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1479 RTAssertReleasePanic(); \
1480 } \
1481 } while (0)
1482
1483/** @def AssertReleaseReturn
1484 * Assert that an expression is true, hit a breakpoint and return if it isn't.
1485 *
1486 * @param expr Expression which should be true.
1487 * @param rc What is to be presented to return.
1488 */
1489#define AssertReleaseReturn(expr, rc) \
1490 do { \
1491 if (RT_UNLIKELY(!(expr))) \
1492 { \
1493 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1494 RTAssertReleasePanic(); \
1495 return (rc); \
1496 } \
1497 } while (0)
1498
1499/** @def AssertReleaseReturnVoid
1500 * Assert that an expression is true, hit a breakpoint and return if it isn't.
1501 *
1502 * @param expr Expression which should be true.
1503 */
1504#define AssertReleaseReturnVoid(expr) \
1505 do { \
1506 if (RT_UNLIKELY(!(expr))) \
1507 { \
1508 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1509 RTAssertReleasePanic(); \
1510 return; \
1511 } \
1512 } while (0)
1513
1514
1515/** @def AssertReleaseBreak
1516 * Assert that an expression is true, hit a breakpoint and break if it isn't.
1517 *
1518 * @param expr Expression which should be true.
1519 */
1520#define AssertReleaseBreak(expr) \
1521 if { \
1522 if (RT_UNLIKELY(!(expr))) \
1523 { \
1524 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1525 RTAssertReleasePanic(); \
1526 break; \
1527 } \
1528 } else do {} while (0)
1529
1530/** @def AssertReleaseBreakStmt
1531 * Assert that an expression is true, hit a breakpoint and break if it isn't.
1532 *
1533 * @param expr Expression which should be true.
1534 * @param stmt Statement to execute before break in case of a failed assertion.
1535 */
1536#define AssertReleaseBreakStmt(expr, stmt) \
1537 if (RT_UNLIKELY(!(expr))) \
1538 { \
1539 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1540 RTAssertReleasePanic(); \
1541 stmt; \
1542 break; \
1543 } else do {} while (0)
1544
1545
1546/** @def AssertReleaseMsg
1547 * Assert that an expression is true, print the message and hit a breakpoint if it isn't.
1548 *
1549 * @param expr Expression which should be true.
1550 * @param a printf argument list (in parenthesis).
1551 */
1552#define AssertReleaseMsg(expr, a) \
1553 do { \
1554 if (RT_UNLIKELY(!(expr))) \
1555 { \
1556 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1557 RTAssertMsg2Weak a; \
1558 RTAssertReleasePanic(); \
1559 } \
1560 } while (0)
1561
1562/** @def AssertReleaseMsgReturn
1563 * Assert that an expression is true, print the message and hit a breakpoint and return if it isn't.
1564 *
1565 * @param expr Expression which should be true.
1566 * @param a printf argument list (in parenthesis).
1567 * @param rc What is to be presented to return.
1568 */
1569#define AssertReleaseMsgReturn(expr, a, rc) \
1570 do { \
1571 if (RT_UNLIKELY(!(expr))) \
1572 { \
1573 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1574 RTAssertMsg2Weak a; \
1575 RTAssertReleasePanic(); \
1576 return (rc); \
1577 } \
1578 } while (0)
1579
1580/** @def AssertReleaseMsgReturnVoid
1581 * Assert that an expression is true, print the message and hit a breakpoint and return if it isn't.
1582 *
1583 * @param expr Expression which should be true.
1584 * @param a printf argument list (in parenthesis).
1585 */
1586#define AssertReleaseMsgReturnVoid(expr, a) \
1587 do { \
1588 if (RT_UNLIKELY(!(expr))) \
1589 { \
1590 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1591 RTAssertMsg2Weak a; \
1592 RTAssertReleasePanic(); \
1593 return; \
1594 } \
1595 } while (0)
1596
1597
1598/** @def AssertReleaseMsgBreak
1599 * Assert that an expression is true, print the message and hit a breakpoint and break if it isn't.
1600 *
1601 * @param expr Expression which should be true.
1602 * @param a printf argument list (in parenthesis).
1603 */
1604#define AssertReleaseMsgBreak(expr, a) \
1605 if (RT_UNLIKELY(!(expr))) \
1606 { \
1607 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1608 RTAssertMsg2Weak a; \
1609 RTAssertReleasePanic(); \
1610 break; \
1611 } else do {} while (0)
1612
1613/** @def AssertReleaseMsgBreakStmt
1614 * Assert that an expression is true, print the message and hit a breakpoint and break if it isn't.
1615 *
1616 * @param expr Expression which should be true.
1617 * @param a printf argument list (in parenthesis).
1618 * @param stmt Statement to execute before break in case of a failed assertion.
1619 */
1620#define AssertReleaseMsgBreakStmt(expr, a, stmt) \
1621 if (RT_UNLIKELY(!(expr))) { \
1622 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1623 RTAssertMsg2Weak a; \
1624 RTAssertReleasePanic(); \
1625 stmt; \
1626 break; \
1627 } else do {} while (0)
1628
1629
1630/** @def AssertReleaseFailed
1631 * An assertion failed, hit a breakpoint.
1632 */
1633#define AssertReleaseFailed() \
1634 do { \
1635 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1636 RTAssertReleasePanic(); \
1637 } while (0)
1638
1639/** @def AssertReleaseFailedReturn
1640 * An assertion failed, hit a breakpoint and return.
1641 *
1642 * @param rc What is to be presented to return.
1643 */
1644#define AssertReleaseFailedReturn(rc) \
1645 do { \
1646 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1647 RTAssertReleasePanic(); \
1648 return (rc); \
1649 } while (0)
1650
1651/** @def AssertReleaseFailedReturnVoid
1652 * An assertion failed, hit a breakpoint and return.
1653 */
1654#define AssertReleaseFailedReturnVoid() \
1655 do { \
1656 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1657 RTAssertReleasePanic(); \
1658 return; \
1659 } while (0)
1660
1661
1662/** @def AssertReleaseFailedBreak
1663 * An assertion failed, hit a breakpoint and break.
1664 */
1665#define AssertReleaseFailedBreak() \
1666 if (1) { \
1667 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1668 RTAssertReleasePanic(); \
1669 break; \
1670 } else do {} while (0)
1671
1672/** @def AssertReleaseFailedBreakStmt
1673 * An assertion failed, hit a breakpoint and break.
1674 *
1675 * @param stmt Statement to execute before break.
1676 */
1677#define AssertReleaseFailedBreakStmt(stmt) \
1678 if (1) { \
1679 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1680 RTAssertReleasePanic(); \
1681 stmt; \
1682 break; \
1683 } else do {} while (0)
1684
1685
1686/** @def AssertReleaseMsgFailed
1687 * An assertion failed, print a message and hit a breakpoint.
1688 *
1689 * @param a printf argument list (in parenthesis).
1690 */
1691#define AssertReleaseMsgFailed(a) \
1692 do { \
1693 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1694 RTAssertMsg2Weak a; \
1695 RTAssertReleasePanic(); \
1696 } while (0)
1697
1698/** @def AssertReleaseMsgFailedReturn
1699 * An assertion failed, print a message, hit a breakpoint and return.
1700 *
1701 * @param a printf argument list (in parenthesis).
1702 * @param rc What is to be presented to return.
1703 */
1704#define AssertReleaseMsgFailedReturn(a, rc) \
1705 do { \
1706 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1707 RTAssertMsg2Weak a; \
1708 RTAssertReleasePanic(); \
1709 return (rc); \
1710 } while (0)
1711
1712/** @def AssertReleaseMsgFailedReturnVoid
1713 * An assertion failed, print a message, hit a breakpoint and return.
1714 *
1715 * @param a printf argument list (in parenthesis).
1716 */
1717#define AssertReleaseMsgFailedReturnVoid(a) \
1718 do { \
1719 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1720 RTAssertMsg2Weak a; \
1721 RTAssertReleasePanic(); \
1722 return; \
1723 } while (0)
1724
1725
1726/** @def AssertReleaseMsgFailedBreak
1727 * An assertion failed, print a message, hit a breakpoint and break.
1728 *
1729 * @param a printf argument list (in parenthesis).
1730 */
1731#define AssertReleaseMsgFailedBreak(a) \
1732 if (1) { \
1733 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1734 RTAssertMsg2Weak a; \
1735 RTAssertReleasePanic(); \
1736 break; \
1737 } else do {} while (0)
1738
1739/** @def AssertReleaseMsgFailedBreakStmt
1740 * An assertion failed, print a message, hit a breakpoint and break.
1741 *
1742 * @param a printf argument list (in parenthesis).
1743 * @param stmt Statement to execute before break.
1744 */
1745#define AssertReleaseMsgFailedBreakStmt(a, stmt) \
1746 if (1) { \
1747 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1748 RTAssertMsg2Weak a; \
1749 RTAssertReleasePanic(); \
1750 stmt; \
1751 break; \
1752 } else do {} while (0)
1753
1754/** @} */
1755
1756
1757
1758/** @name Fatal Assertions
1759 * These are similar to release assertions except that you cannot ignore them in
1760 * any way, they will loop for ever if RTAssertDoPanic returns.
1761 *
1762 * @{
1763 */
1764
1765/** @def AssertFatal
1766 * Assert that an expression is true. If it's not hit a breakpoint (for ever).
1767 *
1768 * @param expr Expression which should be true.
1769 */
1770#define AssertFatal(expr) \
1771 do { \
1772 if (RT_UNLIKELY(!(expr))) \
1773 for (;;) \
1774 { \
1775 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1776 RTAssertReleasePanic(); \
1777 } \
1778 } while (0)
1779
1780/** @def AssertFatalMsg
1781 * Assert that an expression is true, print the message and hit a breakpoint (for ever) if it isn't.
1782 *
1783 * @param expr Expression which should be true.
1784 * @param a printf argument list (in parenthesis).
1785 */
1786#define AssertFatalMsg(expr, a) \
1787 do { \
1788 if (RT_UNLIKELY(!(expr))) \
1789 for (;;) \
1790 { \
1791 RTAssertMsg1Weak(#expr, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1792 RTAssertMsg2Weak a; \
1793 RTAssertReleasePanic(); \
1794 } \
1795 } while (0)
1796
1797/** @def AssertFatalFailed
1798 * An assertion failed, hit a breakpoint (for ever).
1799 */
1800#define AssertFatalFailed() \
1801 do { \
1802 for (;;) \
1803 { \
1804 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1805 RTAssertReleasePanic(); \
1806 } \
1807 } while (0)
1808
1809/** @def AssertFatalMsgFailed
1810 * An assertion failed, print a message and hit a breakpoint (for ever).
1811 *
1812 * @param a printf argument list (in parenthesis).
1813 */
1814#define AssertFatalMsgFailed(a) \
1815 do { \
1816 for (;;) \
1817 { \
1818 RTAssertMsg1Weak((const char *)0, __LINE__, __FILE__, __PRETTY_FUNCTION__); \
1819 RTAssertMsg2Weak a; \
1820 RTAssertReleasePanic(); \
1821 } \
1822 } while (0)
1823
1824/** @} */
1825
1826
1827
1828/** @name Convenience Assertions Macros
1829 * @{
1830 */
1831
1832/** @def AssertRC
1833 * Asserts a iprt status code successful.
1834 *
1835 * On failure it will print info about the rc and hit a breakpoint.
1836 *
1837 * @param rc iprt status code.
1838 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1839 */
1840#define AssertRC(rc) AssertMsgRC(rc, ("%Rra\n", (rc)))
1841
1842/** @def AssertRCReturn
1843 * Asserts a iprt status code successful, bitch (RT_STRICT mode only) and return if it isn't.
1844 *
1845 * @param rc iprt status code.
1846 * @param rcRet What is to be presented to return.
1847 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1848 */
1849#define AssertRCReturn(rc, rcRet) AssertMsgRCReturn(rc, ("%Rra\n", (rc)), rcRet)
1850
1851/** @def AssertRCReturnVoid
1852 * Asserts a iprt status code successful, bitch (RT_STRICT mode only) and return if it isn't.
1853 *
1854 * @param rc iprt status code.
1855 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1856 */
1857#define AssertRCReturnVoid(rc) AssertMsgRCReturnVoid(rc, ("%Rra\n", (rc)))
1858
1859/** @def AssertRCBreak
1860 * Asserts a iprt status code successful, bitch (RT_STRICT mode only) and break if it isn't.
1861 *
1862 * @param rc iprt status code.
1863 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1864 */
1865#define AssertRCBreak(rc) AssertMsgRCBreak(rc, ("%Rra\n", (rc)))
1866
1867/** @def AssertRCBreakStmt
1868 * Asserts a iprt status code successful, bitch (RT_STRICT mode only) and break if it isn't.
1869 *
1870 * @param rc iprt status code.
1871 * @param stmt Statement to execute before break in case of a failed assertion.
1872 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1873 */
1874#define AssertRCBreakStmt(rc, stmt) AssertMsgRCBreakStmt(rc, ("%Rra\n", (rc)), stmt)
1875
1876/** @def AssertMsgRC
1877 * Asserts a iprt status code successful.
1878 *
1879 * It prints a custom message and hits a breakpoint on FAILURE.
1880 *
1881 * @param rc iprt status code.
1882 * @param msg printf argument list (in parenthesis).
1883 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1884 */
1885#define AssertMsgRC(rc, msg) \
1886 do { AssertMsg(RT_SUCCESS_NP(rc), msg); NOREF(rc); } while (0)
1887
1888/** @def AssertMsgRCReturn
1889 * Asserts a iprt status code successful and if it's not return the specified status code.
1890 *
1891 * If RT_STRICT is defined the message will be printed and a breakpoint hit before it returns
1892 *
1893 * @param rc iprt status code.
1894 * @param msg printf argument list (in parenthesis).
1895 * @param rcRet What is to be presented to return.
1896 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1897 */
1898#define AssertMsgRCReturn(rc, msg, rcRet) \
1899 do { AssertMsgReturn(RT_SUCCESS_NP(rc), msg, rcRet); NOREF(rc); } while (0)
1900
1901/** @def AssertMsgRCReturnVoid
1902 * Asserts a iprt status code successful and if it's not return.
1903 *
1904 * If RT_STRICT is defined the message will be printed and a breakpoint hit before it returns
1905 *
1906 * @param rc iprt status code.
1907 * @param msg printf argument list (in parenthesis).
1908 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1909 */
1910#define AssertMsgRCReturnVoid(rc, msg) \
1911 do { AssertMsgReturnVoid(RT_SUCCESS_NP(rc), msg); NOREF(rc); } while (0)
1912
1913/** @def AssertMsgRCBreak
1914 * Asserts a iprt status code successful and if it's not break.
1915 *
1916 * If RT_STRICT is defined the message will be printed and a breakpoint hit before it breaks
1917 *
1918 * @param rc iprt status code.
1919 * @param msg printf argument list (in parenthesis).
1920 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1921 */
1922#define AssertMsgRCBreak(rc, msg) \
1923 if (1) { AssertMsgBreak(RT_SUCCESS(rc), msg); NOREF(rc); } else do {} while (0)
1924
1925/** @def AssertMsgRCBreakStmt
1926 * Asserts a iprt status code successful and break if it's not.
1927 *
1928 * If RT_STRICT is defined the message will be printed and a breakpoint hit before it returns
1929 *
1930 * @param rc iprt status code.
1931 * @param msg printf argument list (in parenthesis).
1932 * @param stmt Statement to execute before break in case of a failed assertion.
1933 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1934 */
1935#define AssertMsgRCBreakStmt(rc, msg, stmt) \
1936 if (1) { AssertMsgBreakStmt(RT_SUCCESS_NP(rc), msg, stmt); NOREF(rc); } else do {} while (0)
1937
1938/** @def AssertRCSuccess
1939 * Asserts an iprt status code equals VINF_SUCCESS.
1940 *
1941 * On failure it will print info about the rc and hit a breakpoint.
1942 *
1943 * @param rc iprt status code.
1944 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1945 */
1946#define AssertRCSuccess(rc) AssertMsg((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
1947
1948/** @def AssertRCSuccessReturn
1949 * Asserts that an iprt status code equals VINF_SUCCESS, bitch (RT_STRICT mode only) and return if it isn't.
1950 *
1951 * @param rc iprt status code.
1952 * @param rcRet What is to be presented to return.
1953 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1954 */
1955#define AssertRCSuccessReturn(rc, rcRet) AssertMsgReturn((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), rcRet)
1956
1957/** @def AssertRCSuccessReturnVoid
1958 * Asserts that an iprt status code equals VINF_SUCCESS, bitch (RT_STRICT mode only) and return if it isn't.
1959 *
1960 * @param rc iprt status code.
1961 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1962 */
1963#define AssertRCSuccessReturnVoid(rc) AssertMsgReturnVoid((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
1964
1965/** @def AssertRCSuccessBreak
1966 * Asserts that an iprt status code equals VINF_SUCCESS, bitch (RT_STRICT mode only) and break if it isn't.
1967 *
1968 * @param rc iprt status code.
1969 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1970 */
1971#define AssertRCSuccessBreak(rc) AssertMsgBreak((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
1972
1973/** @def AssertRCSuccessBreakStmt
1974 * Asserts that an iprt status code equals VINF_SUCCESS, bitch (RT_STRICT mode only) and break if it isn't.
1975 *
1976 * @param rc iprt status code.
1977 * @param stmt Statement to execute before break in case of a failed assertion.
1978 * @remark rc is referenced multiple times. In release mode is NOREF()'ed.
1979 */
1980#define AssertRCSuccessBreakStmt(rc, stmt) AssertMsgBreakStmt((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), stmt)
1981
1982
1983/** @def AssertLogRelRC
1984 * Asserts a iprt status code successful.
1985 *
1986 * @param rc iprt status code.
1987 * @remark rc is referenced multiple times.
1988 */
1989#define AssertLogRelRC(rc) AssertLogRelMsgRC(rc, ("%Rra\n", (rc)))
1990
1991/** @def AssertLogRelRCReturn
1992 * Asserts a iprt status code successful, returning \a rc if it isn't.
1993 *
1994 * @param rc iprt status code.
1995 * @param rcRet What is to be presented to return.
1996 * @remark rc is referenced multiple times.
1997 */
1998#define AssertLogRelRCReturn(rc, rcRet) AssertLogRelMsgRCReturn(rc, ("%Rra\n", (rc)), rcRet)
1999
2000/** @def AssertLogRelRCReturnVoid
2001 * Asserts a iprt status code successful, returning (void) if it isn't.
2002 *
2003 * @param rc iprt status code.
2004 * @remark rc is referenced multiple times.
2005 */
2006#define AssertLogRelRCReturnVoid(rc) AssertLogRelMsgRCReturnVoid(rc, ("%Rra\n", (rc)))
2007
2008/** @def AssertLogRelRCBreak
2009 * Asserts a iprt status code successful, breaking if it isn't.
2010 *
2011 * @param rc iprt status code.
2012 * @remark rc is referenced multiple times.
2013 */
2014#define AssertLogRelRCBreak(rc) AssertLogRelMsgRCBreak(rc, ("%Rra\n", (rc)))
2015
2016/** @def AssertLogRelRCBreakStmt
2017 * Asserts a iprt status code successful, execute \a statement and break if it isn't.
2018 *
2019 * @param rc iprt status code.
2020 * @param stmt Statement to execute before break in case of a failed assertion.
2021 * @remark rc is referenced multiple times.
2022 */
2023#define AssertLogRelRCBreakStmt(rc, stmt) AssertLogRelMsgRCBreakStmt(rc, ("%Rra\n", (rc)), stmt)
2024
2025/** @def AssertLogRelMsgRC
2026 * Asserts a iprt status code successful.
2027 *
2028 * @param rc iprt status code.
2029 * @param msg printf argument list (in parenthesis).
2030 * @remark rc is referenced multiple times.
2031 */
2032#define AssertLogRelMsgRC(rc, msg) AssertLogRelMsg(RT_SUCCESS_NP(rc), msg)
2033
2034/** @def AssertLogRelMsgRCReturn
2035 * Asserts a iprt status code successful.
2036 *
2037 * @param rc iprt status code.
2038 * @param msg printf argument list (in parenthesis).
2039 * @param rcRet What is to be presented to return.
2040 * @remark rc is referenced multiple times.
2041 */
2042#define AssertLogRelMsgRCReturn(rc, msg, rcRet) AssertLogRelMsgReturn(RT_SUCCESS_NP(rc), msg, rcRet)
2043
2044/** @def AssertLogRelMsgRCReturnVoid
2045 * Asserts a iprt status code successful.
2046 *
2047 * @param rc iprt status code.
2048 * @param msg printf argument list (in parenthesis).
2049 * @remark rc is referenced multiple times.
2050 */
2051#define AssertLogRelMsgRCReturnVoid(rc, msg) AssertLogRelMsgReturnVoid(RT_SUCCESS_NP(rc), msg)
2052
2053/** @def AssertLogRelMsgRCBreak
2054 * Asserts a iprt status code successful.
2055 *
2056 * @param rc iprt status code.
2057 * @param msg printf argument list (in parenthesis).
2058 * @remark rc is referenced multiple times.
2059 */
2060#define AssertLogRelMsgRCBreak(rc, msg) AssertLogRelMsgBreak(RT_SUCCESS(rc), msg)
2061
2062/** @def AssertLogRelMsgRCBreakStmt
2063 * Asserts a iprt status code successful, execute \a stmt and break if it isn't.
2064 *
2065 * @param rc iprt status code.
2066 * @param msg printf argument list (in parenthesis).
2067 * @param stmt Statement to execute before break in case of a failed assertion.
2068 * @remark rc is referenced multiple times.
2069 */
2070#define AssertLogRelMsgRCBreakStmt(rc, msg, stmt) AssertLogRelMsgBreakStmt(RT_SUCCESS_NP(rc), msg, stmt)
2071
2072/** @def AssertLogRelRCSuccess
2073 * Asserts that an iprt status code equals VINF_SUCCESS.
2074 *
2075 * @param rc iprt status code.
2076 * @remark rc is referenced multiple times.
2077 */
2078#define AssertLogRelRCSuccess(rc) AssertLogRelMsg((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2079
2080/** @def AssertLogRelRCSuccessReturn
2081 * Asserts that an iprt status code equals VINF_SUCCESS.
2082 *
2083 * @param rc iprt status code.
2084 * @param rcRet What is to be presented to return.
2085 * @remark rc is referenced multiple times.
2086 */
2087#define AssertLogRelRCSuccessReturn(rc, rcRet) AssertLogRelMsgReturn((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), rcRet)
2088
2089/** @def AssertLogRelRCSuccessReturnVoid
2090 * Asserts that an iprt status code equals VINF_SUCCESS.
2091 *
2092 * @param rc iprt status code.
2093 * @remark rc is referenced multiple times.
2094 */
2095#define AssertLogRelRCSuccessReturnVoid(rc) AssertLogRelMsgReturnVoid((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2096
2097/** @def AssertLogRelRCSuccessBreak
2098 * Asserts that an iprt status code equals VINF_SUCCESS.
2099 *
2100 * @param rc iprt status code.
2101 * @remark rc is referenced multiple times.
2102 */
2103#define AssertLogRelRCSuccessBreak(rc) AssertLogRelMsgBreak((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2104
2105/** @def AssertLogRelRCSuccessBreakStmt
2106 * Asserts that an iprt status code equals VINF_SUCCESS.
2107 *
2108 * @param rc iprt status code.
2109 * @param stmt Statement to execute before break in case of a failed assertion.
2110 * @remark rc is referenced multiple times.
2111 */
2112#define AssertLogRelRCSuccessBreakStmt(rc, stmt) AssertLogRelMsgBreakStmt((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), stmt)
2113
2114
2115/** @def AssertReleaseRC
2116 * Asserts a iprt status code successful.
2117 *
2118 * On failure information about the error will be printed and a breakpoint hit.
2119 *
2120 * @param rc iprt status code.
2121 * @remark rc is referenced multiple times.
2122 */
2123#define AssertReleaseRC(rc) AssertReleaseMsgRC(rc, ("%Rra\n", (rc)))
2124
2125/** @def AssertReleaseRCReturn
2126 * Asserts a iprt status code successful, returning if it isn't.
2127 *
2128 * On failure information about the error will be printed, a breakpoint hit
2129 * and finally returning from the function if the breakpoint is somehow ignored.
2130 *
2131 * @param rc iprt status code.
2132 * @param rcRet What is to be presented to return.
2133 * @remark rc is referenced multiple times.
2134 */
2135#define AssertReleaseRCReturn(rc, rcRet) AssertReleaseMsgRCReturn(rc, ("%Rra\n", (rc)), rcRet)
2136
2137/** @def AssertReleaseRCReturnVoid
2138 * Asserts a iprt status code successful, returning if it isn't.
2139 *
2140 * On failure information about the error will be printed, a breakpoint hit
2141 * and finally returning from the function if the breakpoint is somehow ignored.
2142 *
2143 * @param rc iprt status code.
2144 * @remark rc is referenced multiple times.
2145 */
2146#define AssertReleaseRCReturnVoid(rc) AssertReleaseMsgRCReturnVoid(rc, ("%Rra\n", (rc)))
2147
2148/** @def AssertReleaseRCBreak
2149 * Asserts a iprt status code successful, breaking if it isn't.
2150 *
2151 * On failure information about the error will be printed, a breakpoint hit
2152 * and finally breaking the current statement if the breakpoint is somehow ignored.
2153 *
2154 * @param rc iprt status code.
2155 * @remark rc is referenced multiple times.
2156 */
2157#define AssertReleaseRCBreak(rc) AssertReleaseMsgRCBreak(rc, ("%Rra\n", (rc)))
2158
2159/** @def AssertReleaseRCBreakStmt
2160 * Asserts a iprt status code successful, break if it isn't.
2161 *
2162 * On failure information about the error will be printed, a breakpoint hit
2163 * and finally the break statement will be issued if the breakpoint is somehow ignored.
2164 *
2165 * @param rc iprt status code.
2166 * @param stmt Statement to execute before break in case of a failed assertion.
2167 * @remark rc is referenced multiple times.
2168 */
2169#define AssertReleaseRCBreakStmt(rc, stmt) AssertReleaseMsgRCBreakStmt(rc, ("%Rra\n", (rc)), stmt)
2170
2171/** @def AssertReleaseMsgRC
2172 * Asserts a iprt status code successful.
2173 *
2174 * On failure a custom message is printed and a breakpoint is hit.
2175 *
2176 * @param rc iprt status code.
2177 * @param msg printf argument list (in parenthesis).
2178 * @remark rc is referenced multiple times.
2179 */
2180#define AssertReleaseMsgRC(rc, msg) AssertReleaseMsg(RT_SUCCESS_NP(rc), msg)
2181
2182/** @def AssertReleaseMsgRCReturn
2183 * Asserts a iprt status code successful.
2184 *
2185 * On failure a custom message is printed, a breakpoint is hit, and finally
2186 * returning from the function if the breakpoint is somehow ignored.
2187 *
2188 * @param rc iprt status code.
2189 * @param msg printf argument list (in parenthesis).
2190 * @param rcRet What is to be presented to return.
2191 * @remark rc is referenced multiple times.
2192 */
2193#define AssertReleaseMsgRCReturn(rc, msg, rcRet) AssertReleaseMsgReturn(RT_SUCCESS_NP(rc), msg, rcRet)
2194
2195/** @def AssertReleaseMsgRCReturnVoid
2196 * Asserts a iprt status code successful.
2197 *
2198 * On failure a custom message is printed, a breakpoint is hit, and finally
2199 * returning from the function if the breakpoint is somehow ignored.
2200 *
2201 * @param rc iprt status code.
2202 * @param msg printf argument list (in parenthesis).
2203 * @remark rc is referenced multiple times.
2204 */
2205#define AssertReleaseMsgRCReturnVoid(rc, msg) AssertReleaseMsgReturnVoid(RT_SUCCESS_NP(rc), msg)
2206
2207/** @def AssertReleaseMsgRCBreak
2208 * Asserts a iprt status code successful.
2209 *
2210 * On failure a custom message is printed, a breakpoint is hit, and finally
2211 * breaking the current status if the breakpoint is somehow ignored.
2212 *
2213 * @param rc iprt status code.
2214 * @param msg printf argument list (in parenthesis).
2215 * @remark rc is referenced multiple times.
2216 */
2217#define AssertReleaseMsgRCBreak(rc, msg) AssertReleaseMsgBreak(RT_SUCCESS(rc), msg)
2218
2219/** @def AssertReleaseMsgRCBreakStmt
2220 * Asserts a iprt status code successful.
2221 *
2222 * On failure a custom message is printed, a breakpoint is hit, and finally
2223 * the break statement is issued if the breakpoint is somehow ignored.
2224 *
2225 * @param rc iprt status code.
2226 * @param msg printf argument list (in parenthesis).
2227 * @param stmt Statement to execute before break in case of a failed assertion.
2228 * @remark rc is referenced multiple times.
2229 */
2230#define AssertReleaseMsgRCBreakStmt(rc, msg, stmt) AssertReleaseMsgBreakStmt(RT_SUCCESS_NP(rc), msg, stmt)
2231
2232/** @def AssertReleaseRCSuccess
2233 * Asserts that an iprt status code equals VINF_SUCCESS.
2234 *
2235 * On failure information about the error will be printed and a breakpoint hit.
2236 *
2237 * @param rc iprt status code.
2238 * @remark rc is referenced multiple times.
2239 */
2240#define AssertReleaseRCSuccess(rc) AssertReleaseMsg((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2241
2242/** @def AssertReleaseRCSuccessReturn
2243 * Asserts that an iprt status code equals VINF_SUCCESS.
2244 *
2245 * On failure information about the error will be printed, a breakpoint hit
2246 * and finally returning from the function if the breakpoint is somehow ignored.
2247 *
2248 * @param rc iprt status code.
2249 * @param rcRet What is to be presented to return.
2250 * @remark rc is referenced multiple times.
2251 */
2252#define AssertReleaseRCSuccessReturn(rc, rcRet) AssertReleaseMsgReturn((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), rcRet)
2253
2254/** @def AssertReleaseRCSuccessReturnVoid
2255 * Asserts that an iprt status code equals VINF_SUCCESS.
2256 *
2257 * On failure information about the error will be printed, a breakpoint hit
2258 * and finally returning from the function if the breakpoint is somehow ignored.
2259 *
2260 * @param rc iprt status code.
2261 * @remark rc is referenced multiple times.
2262 */
2263#define AssertReleaseRCSuccessReturnVoid(rc) AssertReleaseMsgReturnVoid((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2264
2265/** @def AssertReleaseRCSuccessBreak
2266 * Asserts that an iprt status code equals VINF_SUCCESS.
2267 *
2268 * On failure information about the error will be printed, a breakpoint hit
2269 * and finally breaking the current statement if the breakpoint is somehow ignored.
2270 *
2271 * @param rc iprt status code.
2272 * @remark rc is referenced multiple times.
2273 */
2274#define AssertReleaseRCSuccessBreak(rc) AssertReleaseMsgBreak((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2275
2276/** @def AssertReleaseRCSuccessBreakStmt
2277 * Asserts that an iprt status code equals VINF_SUCCESS.
2278 *
2279 * On failure information about the error will be printed, a breakpoint hit
2280 * and finally the break statement will be issued if the breakpoint is somehow ignored.
2281 *
2282 * @param rc iprt status code.
2283 * @param stmt Statement to execute before break in case of a failed assertion.
2284 * @remark rc is referenced multiple times.
2285 */
2286#define AssertReleaseRCSuccessBreakStmt(rc, stmt) AssertReleaseMsgBreakStmt((rc) == VINF_SUCCESS, ("%Rra\n", (rc)), stmt)
2287
2288
2289/** @def AssertFatalRC
2290 * Asserts a iprt status code successful.
2291 *
2292 * On failure information about the error will be printed and a breakpoint hit.
2293 *
2294 * @param rc iprt status code.
2295 * @remark rc is referenced multiple times.
2296 */
2297#define AssertFatalRC(rc) AssertFatalMsgRC(rc, ("%Rra\n", (rc)))
2298
2299/** @def AssertReleaseMsgRC
2300 * Asserts a iprt status code successful.
2301 *
2302 * On failure a custom message is printed and a breakpoint is hit.
2303 *
2304 * @param rc iprt status code.
2305 * @param msg printf argument list (in parenthesis).
2306 * @remark rc is referenced multiple times.
2307 */
2308#define AssertFatalMsgRC(rc, msg) AssertFatalMsg(RT_SUCCESS_NP(rc), msg)
2309
2310/** @def AssertFatalRCSuccess
2311 * Asserts that an iprt status code equals VINF_SUCCESS.
2312 *
2313 * On failure information about the error will be printed and a breakpoint hit.
2314 *
2315 * @param rc iprt status code.
2316 * @remark rc is referenced multiple times.
2317 */
2318#define AssertFatalRCSuccess(rc) AssertFatalMsg((rc) == VINF_SUCCESS, ("%Rra\n", (rc)))
2319
2320
2321/** @def AssertPtr
2322 * Asserts that a pointer is valid.
2323 *
2324 * @param pv The pointer.
2325 */
2326#define AssertPtr(pv) AssertMsg(VALID_PTR(pv), ("%p\n", (pv)))
2327
2328/** @def AssertPtrReturn
2329 * Asserts that a pointer is valid.
2330 *
2331 * @param pv The pointer.
2332 * @param rcRet What is to be presented to return.
2333 */
2334#define AssertPtrReturn(pv, rcRet) AssertMsgReturn(VALID_PTR(pv), ("%p\n", (pv)), rcRet)
2335
2336/** @def AssertPtrReturnVoid
2337 * Asserts that a pointer is valid.
2338 *
2339 * @param pv The pointer.
2340 */
2341#define AssertPtrReturnVoid(pv) AssertMsgReturnVoid(VALID_PTR(pv), ("%p\n", (pv)))
2342
2343/** @def AssertPtrBreak
2344 * Asserts that a pointer is valid.
2345 *
2346 * @param pv The pointer.
2347 */
2348#define AssertPtrBreak(pv) AssertMsgBreak(VALID_PTR(pv), ("%p\n", (pv)))
2349
2350/** @def AssertPtrBreakStmt
2351 * Asserts that a pointer is valid.
2352 *
2353 * @param pv The pointer.
2354 * @param stmt Statement to execute before break in case of a failed assertion.
2355 */
2356#define AssertPtrBreakStmt(pv, stmt) AssertMsgBreakStmt(VALID_PTR(pv), ("%p\n", (pv)), stmt)
2357
2358/** @def AssertPtrNull
2359 * Asserts that a pointer is valid or NULL.
2360 *
2361 * @param pv The pointer.
2362 */
2363#define AssertPtrNull(pv) AssertMsg(VALID_PTR(pv) || (pv) == NULL, ("%p\n", (pv)))
2364
2365/** @def AssertPtrNullReturn
2366 * Asserts that a pointer is valid or NULL.
2367 *
2368 * @param pv The pointer.
2369 * @param rcRet What is to be presented to return.
2370 */
2371#define AssertPtrNullReturn(pv, rcRet) AssertMsgReturn(VALID_PTR(pv) || (pv) == NULL, ("%p\n", (pv)), rcRet)
2372
2373/** @def AssertPtrNullReturnVoid
2374 * Asserts that a pointer is valid or NULL.
2375 *
2376 * @param pv The pointer.
2377 */
2378#define AssertPtrNullReturnVoid(pv) AssertMsgReturnVoid(VALID_PTR(pv) || (pv) == NULL, ("%p\n", (pv)))
2379
2380/** @def AssertPtrNullBreak
2381 * Asserts that a pointer is valid or NULL.
2382 *
2383 * @param pv The pointer.
2384 */
2385#define AssertPtrNullBreak(pv) AssertMsgBreak(VALID_PTR(pv) || (pv) == NULL, ("%p\n", (pv)))
2386
2387/** @def AssertPtrNullBreakStmt
2388 * Asserts that a pointer is valid or NULL.
2389 *
2390 * @param pv The pointer.
2391 * @param stmt Statement to execute before break in case of a failed assertion.
2392 */
2393#define AssertPtrNullBreakStmt(pv, stmt) AssertMsgBreakStmt(VALID_PTR(pv) || (pv) == NULL, ("%p\n", (pv)), stmt)
2394
2395/** @def AssertGCPhys32
2396 * Asserts that the high dword of a physical address is zero
2397 *
2398 * @param GCPhys The address (RTGCPHYS).
2399 */
2400#define AssertGCPhys32(GCPhys) AssertMsg(VALID_PHYS32(GCPhys), ("%RGp\n", (RTGCPHYS)(GCPhys)))
2401
2402/** @def AssertGCPtr32
2403 * Asserts that the high dword of a physical address is zero
2404 *
2405 * @param GCPtr The address (RTGCPTR).
2406 */
2407#if GC_ARCH_BITS == 32
2408# define AssertGCPtr32(GCPtr) do { } while (0)
2409#else
2410# define AssertGCPtr32(GCPtr) AssertMsg(!((GCPtr) & UINT64_C(0xffffffff00000000)), ("%RGv\n", GCPtr))
2411#endif
2412
2413/** @def AssertForEach
2414 * Equivalent to Assert for each value of the variable from the starting
2415 * value to the finishing one.
2416 *
2417 * @param var Name of the counter variable.
2418 * @param vartype Type of the counter variable.
2419 * @param first Lowest inclusive value of the counter variable.
2420 * This must be free from side effects.
2421 * @param end Highest exclusive value of the counter variable.
2422 * This must be free from side effects.
2423 * @param expr Expression which should be true for each value of @a var.
2424 */
2425#define AssertForEach(var, vartype, first, end, expr) \
2426 do { \
2427 vartype var; \
2428 Assert((first) == (first) && (end) == (end)); /* partial check for side effects */ \
2429 for (var = (first); var < (end); var++) \
2430 AssertMsg(expr, ("%s = %#RX64 (%RI64)", #var, (uint64_t)var, (int64_t)var)); \
2431 } while (0)
2432
2433/** @} */
2434
2435/** @} */
2436
2437#endif
2438
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