From: Ian Jackson <ian.jackson@eu.citrix.com>
To: xen-devel@lists.xensource.com
Cc: Ian Jackson <ian.jackson@eu.citrix.com>
Subject: [PATCH 12/10] libxl: New convenience macro CONTAINING_STRUCT
Date: Mon, 9 Jan 2012 17:34:35 +0000 [thread overview]
Message-ID: <1326130477-18085-3-git-send-email-ian.jackson@eu.citrix.com> (raw)
In-Reply-To: <1325882107-5794-1-git-send-email-ian.jackson@eu.citrix.com>
Provide a convenient and type-safe wrapper which does the correct
dance to subtract offsetof.
Signed-off-by: Ian Jackson <ian.jackson@eu.citrix.com>
---
tools/libxl/libxl_internal.h | 35 +++++++++++++++++++++++++++++++++++
1 files changed, 35 insertions(+), 0 deletions(-)
diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h
index e0ff15c..e0c2ad6 100644
--- a/tools/libxl/libxl_internal.h
+++ b/tools/libxl/libxl_internal.h
@@ -1224,6 +1224,41 @@ _hidden void libxl__ao__destroy(libxl_ctx*, libxl__ao *ao);
* Convenience macros.
*/
+/*
+ * [GET_]CONTAINING_STRUCT work like this. Given:
+ * typedef struct {
+ * ...
+ * member_type member_name;
+ * ...
+ * } outer_type;
+ * Then:
+ * void GET_CONTAINING_STRUCT(outer_type *outer_var [NB:UPDATED],
+ * some_type *inner_ptr,
+ * member_name);
+ * outer_type *CONTAINING_STRUCT(outer_type,
+ * some_type *inner_ptr,
+ * member_name);
+ * The semantics are that after:
+ * outer_type outer, *outer_var;
+ * member_type *inner_ptr = &outer->member_name;
+ * GET_CONTAINING_STRUCT(outer_var, &outer_ptr->member_name, member_name)
+ * The following hold:
+ * CONTAINING_STRUCT(inner_ptr, outer_type, member_name) == outer_ptr
+ * outer_var == &outer
+ */
+#define GET_CONTAINING_STRUCT(outer_var, inner_ptr, member_name) \
+ ((outer_var) = (void*)((char*)(inner_ptr) - \
+ offsetof(typeof(*(outer_var)), member_name)), \
+ (void)(&(outer_var)->member_name == \
+ (typeof(inner_ptr))0) /* type check */, \
+ (void)0)
+#define CONTAINING_STRUCT(outer_type, inner_ptr, member_name) \
+ ({ \
+ typeof(outer_type) *containing_struct; \
+ GET_CONTAINING_STRUCT(containing_struct, inner_ptr, member_name); \
+ containing_struct; \
+ })
+
/*
* All of these assume (or define)
--
1.7.2.5
next prev parent reply other threads:[~2012-01-09 17:34 UTC|newest]
Thread overview: 43+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-01-06 20:34 [PATCH v6 00/10] libxl: event API Ian Jackson
2012-01-06 20:34 ` [PATCH 01/10] libxl: make LIBXL_INIT_GC a statement, not an initialiser Ian Jackson
2012-01-06 20:34 ` [PATCH 02/10] xenstore: New function xs_path_is_subpath Ian Jackson
2012-01-13 10:39 ` Ian Campbell
2012-01-06 20:35 ` [PATCH 03/10] libxl: move a lot more includes into libxl_internal.h Ian Jackson
2012-01-13 10:41 ` Ian Campbell
2012-01-13 13:37 ` Ian Jackson
2012-01-13 13:39 ` Ian Campbell
2012-01-13 16:23 ` Ian Jackson
2012-01-06 20:35 ` [PATCH 04/10] libxl: Provide more formal libxl__ctx_lock and _unlock Ian Jackson
2012-01-13 10:42 ` Ian Campbell
2012-01-06 20:35 ` [PATCH 05/10] libxl: Fix leaks on context init failure Ian Jackson
2012-01-13 10:43 ` Ian Campbell
2012-01-13 15:58 ` Ian Jackson
2012-01-06 20:35 ` [PATCH 06/10] DROP: libxl: rename libxl__free_all Ian Jackson
2012-01-06 20:35 ` [PATCH 07/10] libxl: New API for providing OS events to libxl Ian Jackson
2012-01-11 17:32 ` Stefano Stabellini
2012-01-12 11:28 ` Ian Campbell
2012-01-12 13:49 ` Stefano Stabellini
2012-01-12 15:49 ` Ian Jackson
2012-01-12 15:56 ` Ian Jackson
2012-01-13 15:07 ` Ian Campbell
2012-01-13 15:47 ` Ian Jackson
2012-01-13 15:56 ` Ian Campbell
2012-01-13 16:34 ` Ian Jackson
2012-01-06 20:35 ` [PATCH 08/10] libxl: New event generation API Ian Jackson
2012-01-13 15:22 ` Ian Campbell
2012-01-13 15:49 ` Ian Jackson
2012-01-06 20:35 ` [PATCH 09/10] libxl: introduce libxl_fd_set_nonblock, rationalise _cloexec Ian Jackson
2012-01-13 10:45 ` Ian Campbell
2012-01-13 15:54 ` Ian Jackson
2012-01-06 20:35 ` [PATCH 10/10] libxl: Permit multithreaded event waiting Ian Jackson
2012-01-09 17:34 ` [PATCH RFC v6.1 11-14/10] libxl: asynchronous operations Ian Jackson
2012-01-09 17:34 ` [PATCH 11/10] libxl: Asynchronous/long-running operation infrastructure Ian Jackson
2012-01-09 17:34 ` Ian Jackson [this message]
2012-01-13 10:49 ` [PATCH 12/10] libxl: New convenience macro CONTAINING_STRUCT Ian Campbell
2012-01-13 13:53 ` Ian Jackson
2012-01-13 15:06 ` Ian Campbell
2012-01-09 17:34 ` [PATCH 13/10] libxl: Introduce libxl__ev_devstate Ian Jackson
2012-01-09 17:34 ` [PATCH 14/10] libxl: Convert to asynchronous: device removal Ian Jackson
2012-01-13 14:50 ` [PATCH v6 00/10] libxl: event API Ian Campbell
2012-01-13 15:03 ` Ian Jackson
2012-01-13 17:43 ` Ian Jackson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1326130477-18085-3-git-send-email-ian.jackson@eu.citrix.com \
--to=ian.jackson@eu.citrix.com \
--cc=xen-devel@lists.xensource.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).