1*bbb1b6f9SApple OSS Distributions /* 2*bbb1b6f9SApple OSS Distributions * Copyright (c) 2000-2016 Apple Inc. All rights reserved. 3*bbb1b6f9SApple OSS Distributions * 4*bbb1b6f9SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5*bbb1b6f9SApple OSS Distributions * 6*bbb1b6f9SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code 7*bbb1b6f9SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License 8*bbb1b6f9SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in 9*bbb1b6f9SApple OSS Distributions * compliance with the License. The rights granted to you under the License 10*bbb1b6f9SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of, 11*bbb1b6f9SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to 12*bbb1b6f9SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any 13*bbb1b6f9SApple OSS Distributions * terms of an Apple operating system software license agreement. 14*bbb1b6f9SApple OSS Distributions * 15*bbb1b6f9SApple OSS Distributions * Please obtain a copy of the License at 16*bbb1b6f9SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file. 17*bbb1b6f9SApple OSS Distributions * 18*bbb1b6f9SApple OSS Distributions * The Original Code and all software distributed under the License are 19*bbb1b6f9SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20*bbb1b6f9SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21*bbb1b6f9SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22*bbb1b6f9SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23*bbb1b6f9SApple OSS Distributions * Please see the License for the specific language governing rights and 24*bbb1b6f9SApple OSS Distributions * limitations under the License. 25*bbb1b6f9SApple OSS Distributions * 26*bbb1b6f9SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27*bbb1b6f9SApple OSS Distributions */ 28*bbb1b6f9SApple OSS Distributions /* 29*bbb1b6f9SApple OSS Distributions * @OSF_COPYRIGHT@ 30*bbb1b6f9SApple OSS Distributions */ 31*bbb1b6f9SApple OSS Distributions /* 32*bbb1b6f9SApple OSS Distributions * Mach Operating System 33*bbb1b6f9SApple OSS Distributions * Copyright (c) 1991,1990,1989,1988,1987 Carnegie Mellon University 34*bbb1b6f9SApple OSS Distributions * All Rights Reserved. 35*bbb1b6f9SApple OSS Distributions * 36*bbb1b6f9SApple OSS Distributions * Permission to use, copy, modify and distribute this software and its 37*bbb1b6f9SApple OSS Distributions * documentation is hereby granted, provided that both the copyright 38*bbb1b6f9SApple OSS Distributions * notice and this permission notice appear in all copies of the 39*bbb1b6f9SApple OSS Distributions * software, derivative works or modified versions, and any portions 40*bbb1b6f9SApple OSS Distributions * thereof, and that both notices appear in supporting documentation. 41*bbb1b6f9SApple OSS Distributions * 42*bbb1b6f9SApple OSS Distributions * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" 43*bbb1b6f9SApple OSS Distributions * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR 44*bbb1b6f9SApple OSS Distributions * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. 45*bbb1b6f9SApple OSS Distributions * 46*bbb1b6f9SApple OSS Distributions * Carnegie Mellon requests users of this software to return to 47*bbb1b6f9SApple OSS Distributions * 48*bbb1b6f9SApple OSS Distributions * Software Distribution Coordinator or [email protected] 49*bbb1b6f9SApple OSS Distributions * School of Computer Science 50*bbb1b6f9SApple OSS Distributions * Carnegie Mellon University 51*bbb1b6f9SApple OSS Distributions * Pittsburgh PA 15213-3890 52*bbb1b6f9SApple OSS Distributions * 53*bbb1b6f9SApple OSS Distributions * any improvements or extensions that they make and grant Carnegie Mellon 54*bbb1b6f9SApple OSS Distributions * the rights to redistribute these changes. 55*bbb1b6f9SApple OSS Distributions */ 56*bbb1b6f9SApple OSS Distributions /* 57*bbb1b6f9SApple OSS Distributions */ 58*bbb1b6f9SApple OSS Distributions 59*bbb1b6f9SApple OSS Distributions #ifndef _KERN_ASSERT_H_ 60*bbb1b6f9SApple OSS Distributions #define _KERN_ASSERT_H_ 61*bbb1b6f9SApple OSS Distributions 62*bbb1b6f9SApple OSS Distributions /* assert.h 4.2 85/01/21 */ 63*bbb1b6f9SApple OSS Distributions 64*bbb1b6f9SApple OSS Distributions #include <kern/macro_help.h> 65*bbb1b6f9SApple OSS Distributions #include <sys/cdefs.h> 66*bbb1b6f9SApple OSS Distributions #include <machine/trap.h> 67*bbb1b6f9SApple OSS Distributions 68*bbb1b6f9SApple OSS Distributions #ifdef XNU_KERNEL_PRIVATE 69*bbb1b6f9SApple OSS Distributions #include <machine/static_if.h> 70*bbb1b6f9SApple OSS Distributions #endif 71*bbb1b6f9SApple OSS Distributions #ifdef MACH_KERNEL_PRIVATE 72*bbb1b6f9SApple OSS Distributions #include <mach_assert.h> 73*bbb1b6f9SApple OSS Distributions #endif 74*bbb1b6f9SApple OSS Distributions 75*bbb1b6f9SApple OSS Distributions __BEGIN_DECLS 76*bbb1b6f9SApple OSS Distributions 77*bbb1b6f9SApple OSS Distributions __abortlike 78*bbb1b6f9SApple OSS Distributions extern void Assert( 79*bbb1b6f9SApple OSS Distributions const char *file, 80*bbb1b6f9SApple OSS Distributions int line, 81*bbb1b6f9SApple OSS Distributions const char *expression) __attribute__((noinline)); 82*bbb1b6f9SApple OSS Distributions 83*bbb1b6f9SApple OSS Distributions extern int kext_assertions_enable; 84*bbb1b6f9SApple OSS Distributions 85*bbb1b6f9SApple OSS Distributions #ifndef __FILE_NAME__ 86*bbb1b6f9SApple OSS Distributions #define __FILE_NAME__ __FILE__ 87*bbb1b6f9SApple OSS Distributions #endif 88*bbb1b6f9SApple OSS Distributions #define __Panic(fmt, args...) (panic)(fmt, ##args) 89*bbb1b6f9SApple OSS Distributions 90*bbb1b6f9SApple OSS Distributions __END_DECLS 91*bbb1b6f9SApple OSS Distributions 92*bbb1b6f9SApple OSS Distributions #ifndef APPLE_KEXT_ASSERTIONS 93*bbb1b6f9SApple OSS Distributions #define APPLE_KEXT_ASSERTIONS 0 94*bbb1b6f9SApple OSS Distributions #endif 95*bbb1b6f9SApple OSS Distributions 96*bbb1b6f9SApple OSS Distributions __enum_decl(mach_assert_type_t, unsigned char, { 97*bbb1b6f9SApple OSS Distributions MACH_ASSERT_DEFAULT, 98*bbb1b6f9SApple OSS Distributions MACH_ASSERT_3P, 99*bbb1b6f9SApple OSS Distributions MACH_ASSERT_3S, 100*bbb1b6f9SApple OSS Distributions MACH_ASSERT_3U, 101*bbb1b6f9SApple OSS Distributions }); 102*bbb1b6f9SApple OSS Distributions 103*bbb1b6f9SApple OSS Distributions #ifndef __BUILDING_XNU_LIBRARY__ 104*bbb1b6f9SApple OSS Distributions #define MACH_ASSERT_DESC_ALIGN __attribute__((packed, aligned(4))) 105*bbb1b6f9SApple OSS Distributions #else /* __BUILDING_XNU_LIBRARY__ */ 106*bbb1b6f9SApple OSS Distributions /* The assert __desc struct is packed to 4 bytes to save stack usage. 107*bbb1b6f9SApple OSS Distributions * This is not done in user build since there is some difference between the 108*bbb1b6f9SApple OSS Distributions * user-mode linker and the kernel linker which causes this to produce 109*bbb1b6f9SApple OSS Distributions * unaligned pointer exception */ 110*bbb1b6f9SApple OSS Distributions #define MACH_ASSERT_DESC_ALIGN 111*bbb1b6f9SApple OSS Distributions #endif /* __BUILDING_XNU_LIBRARY__ */ 112*bbb1b6f9SApple OSS Distributions 113*bbb1b6f9SApple OSS Distributions struct mach_assert_hdr { 114*bbb1b6f9SApple OSS Distributions mach_assert_type_t type; 115*bbb1b6f9SApple OSS Distributions unsigned lineno : 24; 116*bbb1b6f9SApple OSS Distributions const char *filename; 117*bbb1b6f9SApple OSS Distributions } MACH_ASSERT_DESC_ALIGN; 118*bbb1b6f9SApple OSS Distributions 119*bbb1b6f9SApple OSS Distributions struct mach_assert_default { 120*bbb1b6f9SApple OSS Distributions struct mach_assert_hdr hdr; 121*bbb1b6f9SApple OSS Distributions const char *expr; 122*bbb1b6f9SApple OSS Distributions } MACH_ASSERT_DESC_ALIGN; 123*bbb1b6f9SApple OSS Distributions 124*bbb1b6f9SApple OSS Distributions struct mach_assert_3x { 125*bbb1b6f9SApple OSS Distributions struct mach_assert_hdr hdr; 126*bbb1b6f9SApple OSS Distributions const char *a; 127*bbb1b6f9SApple OSS Distributions const char *op; 128*bbb1b6f9SApple OSS Distributions const char *b; 129*bbb1b6f9SApple OSS Distributions } MACH_ASSERT_DESC_ALIGN; 130*bbb1b6f9SApple OSS Distributions 131*bbb1b6f9SApple OSS Distributions #if MACH_ASSERT 132*bbb1b6f9SApple OSS Distributions # if XNU_KERNEL_PRIVATE 133*bbb1b6f9SApple OSS Distributions STATIC_IF_KEY_DECLARE_TRUE(mach_assert); 134*bbb1b6f9SApple OSS Distributions # define mach_assert_enabled() improbable_static_if(mach_assert) 135*bbb1b6f9SApple OSS Distributions # else 136*bbb1b6f9SApple OSS Distributions # define mach_assert_enabled() 1 137*bbb1b6f9SApple OSS Distributions # endif /* !XNU_KERNEL_PRIVATE */ 138*bbb1b6f9SApple OSS Distributions #elif APPLE_KEXT_ASSERTIONS 139*bbb1b6f9SApple OSS Distributions # define mach_assert_enabled() __builtin_expect(kext_assertions_enable, 0L) 140*bbb1b6f9SApple OSS Distributions #else /* !MACH_ASSERT && !APPLE_KEXT_ASSERTIONS */ 141*bbb1b6f9SApple OSS Distributions # define mach_assert_enabled() 0 142*bbb1b6f9SApple OSS Distributions #endif /* !MACH_ASSERT && !APPLE_KEXT_ASSERTIONS */ 143*bbb1b6f9SApple OSS Distributions 144*bbb1b6f9SApple OSS Distributions #define MACH_ASSERT_TRAP_CODE 0xbffc /* XNU_HARD_TRAP_ASSERT_FAILURE */ 145*bbb1b6f9SApple OSS Distributions #define MACH_ASSERT_SEGSECT "__DATA_CONST,__assert" 146*bbb1b6f9SApple OSS Distributions 147*bbb1b6f9SApple OSS Distributions /*! 148*bbb1b6f9SApple OSS Distributions * @abstract 149*bbb1b6f9SApple OSS Distributions * Wrap any arbitrary expression/code behind a conditional 150*bbb1b6f9SApple OSS Distributions * on whether assertions are enabled. 151*bbb1b6f9SApple OSS Distributions */ 152*bbb1b6f9SApple OSS Distributions #define MACH_ASSERT_DO(...) ({ \ 153*bbb1b6f9SApple OSS Distributions if (mach_assert_enabled()) { \ 154*bbb1b6f9SApple OSS Distributions __VA_ARGS__; \ 155*bbb1b6f9SApple OSS Distributions } \ 156*bbb1b6f9SApple OSS Distributions }) 157*bbb1b6f9SApple OSS Distributions 158*bbb1b6f9SApple OSS Distributions #define mach_assert_abort(reason) ({ \ 159*bbb1b6f9SApple OSS Distributions __attribute__((used, section(MACH_ASSERT_SEGSECT))) \ 160*bbb1b6f9SApple OSS Distributions static const struct mach_assert_default __desc = { \ 161*bbb1b6f9SApple OSS Distributions { MACH_ASSERT_DEFAULT, __LINE__, __FILE_NAME__, }, \ 162*bbb1b6f9SApple OSS Distributions reason, \ 163*bbb1b6f9SApple OSS Distributions }; \ 164*bbb1b6f9SApple OSS Distributions \ 165*bbb1b6f9SApple OSS Distributions ml_fatal_trap_with_value(MACH_ASSERT_TRAP_CODE, &__desc); \ 166*bbb1b6f9SApple OSS Distributions }) 167*bbb1b6f9SApple OSS Distributions 168*bbb1b6f9SApple OSS Distributions #define mach_assert_abort3x(how, s_a, s_op, s_b, v_a, v_b) ({ \ 169*bbb1b6f9SApple OSS Distributions __attribute__((used, section(MACH_ASSERT_SEGSECT))) \ 170*bbb1b6f9SApple OSS Distributions static const struct mach_assert_3x __desc_ ## how = { \ 171*bbb1b6f9SApple OSS Distributions { MACH_ASSERT_ ## how, __LINE__, __FILE_NAME__, }, \ 172*bbb1b6f9SApple OSS Distributions s_a, s_op, s_b, \ 173*bbb1b6f9SApple OSS Distributions }; \ 174*bbb1b6f9SApple OSS Distributions \ 175*bbb1b6f9SApple OSS Distributions ml_fatal_trap_with_value3(MACH_ASSERT_TRAP_CODE, \ 176*bbb1b6f9SApple OSS Distributions &__desc_ ## how, v_a, v_b); \ 177*bbb1b6f9SApple OSS Distributions }) 178*bbb1b6f9SApple OSS Distributions 179*bbb1b6f9SApple OSS Distributions /*! 180*bbb1b6f9SApple OSS Distributions * @abstract 181*bbb1b6f9SApple OSS Distributions * assert() that is never elided or removed even in release builds. 182*bbb1b6f9SApple OSS Distributions */ 183*bbb1b6f9SApple OSS Distributions #define release_assert(ex) ({ \ 184*bbb1b6f9SApple OSS Distributions if (__builtin_expect(!(ex), 0L)) { \ 185*bbb1b6f9SApple OSS Distributions mach_assert_abort(#ex); \ 186*bbb1b6f9SApple OSS Distributions } \ 187*bbb1b6f9SApple OSS Distributions }) 188*bbb1b6f9SApple OSS Distributions 189*bbb1b6f9SApple OSS Distributions #if MACH_ASSERT || APPLE_KEXT_ASSERTIONS 190*bbb1b6f9SApple OSS Distributions 191*bbb1b6f9SApple OSS Distributions #define __assert_only 192*bbb1b6f9SApple OSS Distributions 193*bbb1b6f9SApple OSS Distributions #define mach_assert_enabled_expr(ex) \ 194*bbb1b6f9SApple OSS Distributions (mach_assert_enabled() || __builtin_constant_p(!(ex))) 195*bbb1b6f9SApple OSS Distributions 196*bbb1b6f9SApple OSS Distributions #define assert(ex) \ 197*bbb1b6f9SApple OSS Distributions (mach_assert_enabled_expr(ex) && !(ex) \ 198*bbb1b6f9SApple OSS Distributions ? (void)mach_assert_abort(#ex) : (void)0) 199*bbb1b6f9SApple OSS Distributions 200*bbb1b6f9SApple OSS Distributions #define assertf(ex, fmt, args...) ({ \ 201*bbb1b6f9SApple OSS Distributions if (mach_assert_enabled_expr(ex) && __builtin_expect(!(ex), 0L)) { \ 202*bbb1b6f9SApple OSS Distributions __Panic("%s:%d Assertion failed: %s : " fmt, \ 203*bbb1b6f9SApple OSS Distributions __FILE_NAME__, __LINE__, # ex, ##args); \ 204*bbb1b6f9SApple OSS Distributions } \ 205*bbb1b6f9SApple OSS Distributions }) 206*bbb1b6f9SApple OSS Distributions 207*bbb1b6f9SApple OSS Distributions /* 208*bbb1b6f9SApple OSS Distributions * Each of the following three macros takes three arguments instead of one for 209*bbb1b6f9SApple OSS Distributions * the assertion. The suffixes, 's', u' and 'p' indicate the type of arguments 210*bbb1b6f9SApple OSS Distributions * expected: 'signed', 'unsigned' or 'pointer' respectively. 211*bbb1b6f9SApple OSS Distributions * 212*bbb1b6f9SApple OSS Distributions * assert(a > b) -> file.c:123 Assertion failed: a > b 213*bbb1b6f9SApple OSS Distributions * assert3u(a, >, b) -> file.c:124 Assertion failed: a > b (1 >= 10) 214*bbb1b6f9SApple OSS Distributions * 215*bbb1b6f9SApple OSS Distributions * These macros define a local variable with name starting with __desc which 216*bbb1b6f9SApple OSS Distributions * contain the assert info and then call the brk instruction. The trap 217*bbb1b6f9SApple OSS Distributions * is then handled and panic_assert_format() is called to parse this struct. 218*bbb1b6f9SApple OSS Distributions */ 219*bbb1b6f9SApple OSS Distributions #define assert3u(a, op, b) ({ \ 220*bbb1b6f9SApple OSS Distributions if (mach_assert_enabled_expr((unsigned long long)(a) op \ 221*bbb1b6f9SApple OSS Distributions (unsigned long long)(b))) { \ 222*bbb1b6f9SApple OSS Distributions const unsigned long long a_ = (a); \ 223*bbb1b6f9SApple OSS Distributions const unsigned long long b_ = (b); \ 224*bbb1b6f9SApple OSS Distributions \ 225*bbb1b6f9SApple OSS Distributions if (__builtin_expect(!(a_ op b_), 0L)) { \ 226*bbb1b6f9SApple OSS Distributions mach_assert_abort3x(3U, #a, #op, #b, a_, b_); \ 227*bbb1b6f9SApple OSS Distributions } \ 228*bbb1b6f9SApple OSS Distributions } \ 229*bbb1b6f9SApple OSS Distributions }) 230*bbb1b6f9SApple OSS Distributions 231*bbb1b6f9SApple OSS Distributions #define assert3s(a, op, b) ({ \ 232*bbb1b6f9SApple OSS Distributions if (mach_assert_enabled_expr((long long)(a) op ((long long)b))) { \ 233*bbb1b6f9SApple OSS Distributions const signed long long a_ = (a); \ 234*bbb1b6f9SApple OSS Distributions const signed long long b_ = (b); \ 235*bbb1b6f9SApple OSS Distributions \ 236*bbb1b6f9SApple OSS Distributions if (__builtin_expect(!(a_ op b_), 0L)) { \ 237*bbb1b6f9SApple OSS Distributions mach_assert_abort3x(3S, #a, #op, #b, a_, b_); \ 238*bbb1b6f9SApple OSS Distributions } \ 239*bbb1b6f9SApple OSS Distributions } \ 240*bbb1b6f9SApple OSS Distributions }) 241*bbb1b6f9SApple OSS Distributions 242*bbb1b6f9SApple OSS Distributions #define assert3p(a, op, b) ({ \ 243*bbb1b6f9SApple OSS Distributions if (mach_assert_enabled_expr((const void *)(a) op (const void *)(b))) { \ 244*bbb1b6f9SApple OSS Distributions const void *a_ = (a); \ 245*bbb1b6f9SApple OSS Distributions const void *b_ = (b); \ 246*bbb1b6f9SApple OSS Distributions \ 247*bbb1b6f9SApple OSS Distributions if (__builtin_expect(!(a_ op b_), 0L)) { \ 248*bbb1b6f9SApple OSS Distributions mach_assert_abort3x(3P, #a, #op, #b, a_, b_); \ 249*bbb1b6f9SApple OSS Distributions } \ 250*bbb1b6f9SApple OSS Distributions } \ 251*bbb1b6f9SApple OSS Distributions }) 252*bbb1b6f9SApple OSS Distributions 253*bbb1b6f9SApple OSS Distributions #else /* !MACH_ASSERT && !XNU_KERNEL_PRIVATE */ 254*bbb1b6f9SApple OSS Distributions 255*bbb1b6f9SApple OSS Distributions #define __assert_only __unused 256*bbb1b6f9SApple OSS Distributions #define mach_assert_enabled_expr(ex) 0 257*bbb1b6f9SApple OSS Distributions 258*bbb1b6f9SApple OSS Distributions #define assert(ex) ((void)0) 259*bbb1b6f9SApple OSS Distributions #define assertf(ex, fmt, args...) ((void)0) 260*bbb1b6f9SApple OSS Distributions 261*bbb1b6f9SApple OSS Distributions #define assert3s(a, op, b) ((void)0) 262*bbb1b6f9SApple OSS Distributions #define assert3u(a, op, b) ((void)0) 263*bbb1b6f9SApple OSS Distributions #define assert3p(a, op, b) ((void)0) 264*bbb1b6f9SApple OSS Distributions 265*bbb1b6f9SApple OSS Distributions #endif /* !MACH_ASSERT && !XNU_KERNEL_PRIVATE */ 266*bbb1b6f9SApple OSS Distributions 267*bbb1b6f9SApple OSS Distributions /* 268*bbb1b6f9SApple OSS Distributions * static_assert is a C11 / C++0x / C++1z feature. 269*bbb1b6f9SApple OSS Distributions * 270*bbb1b6f9SApple OSS Distributions * Beginning with C++0x, it is a keyword and should not be #defined 271*bbb1b6f9SApple OSS Distributions * 272*bbb1b6f9SApple OSS Distributions * static_assert is not disabled by MACH_ASSERT or NDEBUG 273*bbb1b6f9SApple OSS Distributions */ 274*bbb1b6f9SApple OSS Distributions 275*bbb1b6f9SApple OSS Distributions #ifndef __cplusplus 276*bbb1b6f9SApple OSS Distributions #if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L 277*bbb1b6f9SApple OSS Distributions #define _STATIC_ASSERT_OVERLOADED_MACRO(_1, _2, NAME, ...) NAME 278*bbb1b6f9SApple OSS Distributions #define static_assert(...) _STATIC_ASSERT_OVERLOADED_MACRO(__VA_ARGS__, _static_assert_2_args, _static_assert_1_arg)(__VA_ARGS__) 279*bbb1b6f9SApple OSS Distributions 280*bbb1b6f9SApple OSS Distributions #define _static_assert_2_args(ex, str) _Static_assert((ex), str) 281*bbb1b6f9SApple OSS Distributions #define _static_assert_1_arg(ex) _Static_assert((ex), #ex) 282*bbb1b6f9SApple OSS Distributions #endif 283*bbb1b6f9SApple OSS Distributions #else 284*bbb1b6f9SApple OSS Distributions #if !defined(__cpp_static_assert) 285*bbb1b6f9SApple OSS Distributions /* pre C++11 support */ 286*bbb1b6f9SApple OSS Distributions #define _STATIC_ASSERT_OVERLOADED_MACRO(_1, _2, NAME, ...) NAME 287*bbb1b6f9SApple OSS Distributions #define static_assert(...) _STATIC_ASSERT_OVERLOADED_MACRO(__VA_ARGS__, _static_assert_2_args, _static_assert_1_arg)(__VA_ARGS__) 288*bbb1b6f9SApple OSS Distributions 289*bbb1b6f9SApple OSS Distributions #define _static_assert_2_args(ex, str) _Static_assert((ex), str) 290*bbb1b6f9SApple OSS Distributions #define _static_assert_1_arg(ex) _Static_assert((ex), #ex) 291*bbb1b6f9SApple OSS Distributions #else 292*bbb1b6f9SApple OSS Distributions /* 293*bbb1b6f9SApple OSS Distributions * C++11 only supports the 2 argument version of static_assert. 294*bbb1b6f9SApple OSS Distributions * C++1z has added support for the 1 argument version. 295*bbb1b6f9SApple OSS Distributions */ 296*bbb1b6f9SApple OSS Distributions #define _static_assert_1_arg(ex) static_assert((ex), #ex) 297*bbb1b6f9SApple OSS Distributions #endif 298*bbb1b6f9SApple OSS Distributions #endif 299*bbb1b6f9SApple OSS Distributions 300*bbb1b6f9SApple OSS Distributions #endif /* _KERN_ASSERT_H_ */ 301