|
|
|
@ -19,13 +19,15 @@
|
|
|
|
|
|
|
|
|
|
/// Helper macros to insert unused bytes or words to properly align structs. These values will be
|
|
|
|
|
/// zero-initialized.
|
|
|
|
|
#define INSERT_PADDING_BYTES(num_bytes) std::array<u8, num_bytes> CONCAT2(pad, __LINE__){};
|
|
|
|
|
#define INSERT_PADDING_WORDS(num_words) std::array<u32, num_words> CONCAT2(pad, __LINE__){};
|
|
|
|
|
#define INSERT_PADDING_BYTES(num_bytes) \
|
|
|
|
|
std::array<u8, num_bytes> CONCAT2(pad, __LINE__) {}
|
|
|
|
|
#define INSERT_PADDING_WORDS(num_words) \
|
|
|
|
|
std::array<u32, num_words> CONCAT2(pad, __LINE__) {}
|
|
|
|
|
|
|
|
|
|
/// These are similar to the INSERT_PADDING_* macros, but are needed for padding unions. This is
|
|
|
|
|
/// because unions can only be initialized by one member.
|
|
|
|
|
#define INSERT_UNION_PADDING_BYTES(num_bytes) std::array<u8, num_bytes> CONCAT2(pad, __LINE__);
|
|
|
|
|
#define INSERT_UNION_PADDING_WORDS(num_words) std::array<u32, num_words> CONCAT2(pad, __LINE__);
|
|
|
|
|
#define INSERT_UNION_PADDING_BYTES(num_bytes) std::array<u8, num_bytes> CONCAT2(pad, __LINE__)
|
|
|
|
|
#define INSERT_UNION_PADDING_WORDS(num_words) std::array<u32, num_words> CONCAT2(pad, __LINE__)
|
|
|
|
|
|
|
|
|
|
#ifndef _MSC_VER
|
|
|
|
|
|
|
|
|
|