|
|
|
@ -18,14 +18,16 @@
|
|
|
|
|
/// 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__) {}
|
|
|
|
|
[[maybe_unused]] std::array<u8, num_bytes> CONCAT2(pad, __LINE__) {}
|
|
|
|
|
#define INSERT_PADDING_WORDS(num_words) \
|
|
|
|
|
std::array<u32, num_words> CONCAT2(pad, __LINE__) {}
|
|
|
|
|
[[maybe_unused]] std::array<u32, num_words> CONCAT2(pad, __LINE__) {}
|
|
|
|
|
|
|
|
|
|
/// These are similar to the INSERT_PADDING_* macros but do not zero-initialize the contents.
|
|
|
|
|
/// This keeps the structure trivial to construct.
|
|
|
|
|
#define INSERT_PADDING_BYTES_NOINIT(num_bytes) std::array<u8, num_bytes> CONCAT2(pad, __LINE__)
|
|
|
|
|
#define INSERT_PADDING_WORDS_NOINIT(num_words) std::array<u32, num_words> CONCAT2(pad, __LINE__)
|
|
|
|
|
#define INSERT_PADDING_BYTES_NOINIT(num_bytes) \
|
|
|
|
|
[[maybe_unused]] std::array<u8, num_bytes> CONCAT2(pad, __LINE__)
|
|
|
|
|
#define INSERT_PADDING_WORDS_NOINIT(num_words) \
|
|
|
|
|
[[maybe_unused]] std::array<u32, num_words> CONCAT2(pad, __LINE__)
|
|
|
|
|
|
|
|
|
|
#ifndef _MSC_VER
|
|
|
|
|
|
|
|
|
|