From: bernie Date: Mon, 13 Mar 2006 02:06:25 +0000 (+0000) Subject: containerof(): New macro. X-Git-Tag: 1.0.0~678 X-Git-Url: https://codewiz.org/gitweb?a=commitdiff_plain;h=a3dd3cda2928dea1e658fba91599aed201606f54;p=bertos.git containerof(): New macro. git-svn-id: https://src.develer.com/svnoss/bertos/trunk@563 38d2e660-2303-0410-9eaa-f027e97ec537 --- diff --git a/cfg/compiler.h b/cfg/compiler.h index e9d7567c..6eaf1482 100755 --- a/cfg/compiler.h +++ b/cfg/compiler.h @@ -14,6 +14,9 @@ /*#* *#* $Log$ + *#* Revision 1.15 2006/03/13 02:06:25 bernie + *#* containerof(): New macro. + *#* *#* Revision 1.14 2006/02/23 08:36:33 bernie *#* Emulate __func__ on MSVC. *#* @@ -500,6 +503,23 @@ typedef unsigned char page_t; /*!< Type for banked memory pages. */ #define countof(a) (sizeof(a) / sizeof(*(a))) #endif +/** + * Cast a member of a structure out to the containing structure. + * + * \param ptr the pointer to the member. + * \param type the type of the container struct this is embedded in. + * \param member the name of the member within the struct. + */ +#if COMPILER_TYPEOF && COMPILER_STATEMENT_EXPRESSIONS + #define containerof(ptr, type, member) ({ \ + const typeof( ((type *)0)->member ) *_mptr = (ptr); /* type check */ \ + (type *)((char *)_mptr - offsetof(type, member)); \ + }) +#else + #define containerof(ptr, type, member) \ + ( (type *)((char *)(ptr) - offsetof(type, member)) ) +#endif + /*! Issue a compilation error if the \a condition is false */ #define STATIC_ASSERT(condition) \ UNUSED_VAR(extern char, STATIC_ASSERTION_FAILED__[(condition) ? 1 : -1]) @@ -511,9 +531,9 @@ typedef unsigned char page_t; /*!< Type for banked memory pages. */ #endif #ifndef ASSERT_TYPE_IS -/*! Ensure variable is of specified type. */ +/** Ensure variable is of specified type. */ #define ASSERT_TYPE_IS(var, type) \ - do { (void)(&var == (type *)0); } while(0) + do { (void)(&(var) == (type *)0); } while(0) #endif #endif /* DEVLIB_COMPILER_H */