utils: Provide aligning variants of INIT/INIT_EXTRA macros
authorMartin Willi <martin@revosec.ch>
Tue, 31 Mar 2015 15:27:30 +0000 (17:27 +0200)
committerMartin Willi <martin@revosec.ch>
Wed, 15 Apr 2015 11:44:40 +0000 (13:44 +0200)
src/libstrongswan/utils/utils.h

index a9791ed..c42f881 100644 (file)
@@ -274,6 +274,19 @@ static inline void *memset_noop(void *s, int c, size_t n)
                                                   *(this) = (typeof(*(this))){ __VA_ARGS__ }; }
 
 /**
+ * Aligning version of INIT().
+ *
+ * The returned pointer must be freed using free_align(), not free().
+ *
+ * @param this         object to allocate/initialize
+ * @param align                alignment for allocation, in bytes
+ * @param ...          initializer
+ */
+#define INIT_ALIGN(this, align, ...) { \
+                                               (this) = malloc_align(sizeof(*(this)), align); \
+                                               *(this) = (typeof(*(this))){ __VA_ARGS__ }; }
+
+/**
  * Object allocation/initialization macro, with extra allocated bytes at tail.
  *
  * The extra space gets zero-initialized.
@@ -289,6 +302,22 @@ static inline void *memset_noop(void *s, int c, size_t n)
                                                memset((this) + 1, 0, _extra); }
 
 /**
+ * Aligning version of INIT_EXTRA().
+ *
+ * The returned pointer must be freed using free_align(), not free().
+ *
+ * @param this         object to allocate/initialize
+ * @param extra                number of bytes to allocate at end of this
+ * @param align                alignment for allocation, in bytes
+ * @param ...          initializer
+ */
+#define INIT_EXTRA_ALIGN(this, extra, align, ...) { \
+                                               typeof(extra) _extra = (extra); \
+                                               (this) = malloc_align(sizeof(*(this)) + _extra, align); \
+                                               *(this) = (typeof(*(this))){ __VA_ARGS__ }; \
+                                               memset((this) + 1, 0, _extra); }
+
+/**
  * Method declaration/definition macro, providing private and public interface.
  *
  * Defines a method name with this as first parameter and a return value ret,