diff --git a/Source/Core/Common/Crypto/AES.cpp b/Source/Core/Common/Crypto/AES.cpp index 3fc9a80a56..272341ecca 100644 --- a/Source/Core/Common/Crypto/AES.cpp +++ b/Source/Core/Common/Crypto/AES.cpp @@ -250,7 +250,19 @@ public: } private: - std::array<__m128i, NUM_ROUND_KEYS> round_keys; + // Ensures alignment specifiers are respected. + struct XmmReg + { + __m128i data; + + XmmReg& operator=(const __m128i& m) + { + data = m; + return *this; + } + operator __m128i() const { return data; } + }; + std::array round_keys; }; #endif diff --git a/Source/Core/Common/Crypto/SHA1.cpp b/Source/Core/Common/Crypto/SHA1.cpp index 57c45b09f3..f87bbd2c6d 100644 --- a/Source/Core/Common/Crypto/SHA1.cpp +++ b/Source/Core/Common/Crypto/SHA1.cpp @@ -166,7 +166,20 @@ public: } private: - using WorkBlock = CyclicArray<__m128i, 4>; + struct XmmReg + { + // Allows aliasing attributes to be respected in the + // face of templates. + __m128i data; + + XmmReg& operator=(const __m128i& d) + { + data = d; + return *this; + } + operator __m128i() const { return data; } + }; + using WorkBlock = CyclicArray; ATTRIBUTE_TARGET("ssse3") static inline __m128i byterev_16B(__m128i x) @@ -244,7 +257,7 @@ private: virtual bool HwAccelerated() const override { return true; } - std::array<__m128i, 2> state{}; + std::array state{}; }; #endif