From 088db0103f8fba9c54928ce1fdab61ce44c3bcd1 Mon Sep 17 00:00:00 2001 From: Shauren Date: Wed, 11 May 2022 13:59:41 +0200 Subject: [PATCH] Core/Misc: Remove uses of std::aligned_storage (deprecated in future c++ standard) --- src/common/Threading/MPSCQueue.h | 20 ++++++++++++------- .../Server/Packets/AuctionHousePackets.cpp | 1 + 2 files changed, 14 insertions(+), 7 deletions(-) diff --git a/src/common/Threading/MPSCQueue.h b/src/common/Threading/MPSCQueue.h index 91654546298..ee58eb96b29 100644 --- a/src/common/Threading/MPSCQueue.h +++ b/src/common/Threading/MPSCQueue.h @@ -18,8 +18,9 @@ #ifndef MPSCQueue_h__ #define MPSCQueue_h__ +#include #include -#include +#include namespace Trinity { @@ -92,12 +93,14 @@ private: template T::* IntrusiveLink> class MPSCQueueIntrusive { + using Atomic = std::atomic; + public: - MPSCQueueIntrusive() : _dummyPtr(reinterpret_cast(std::addressof(_dummy))), _head(_dummyPtr), _tail(_dummyPtr) + MPSCQueueIntrusive() : _dummyPtr(reinterpret_cast(_dummy.data())), _head(_dummyPtr), _tail(_dummyPtr) { - // _dummy is constructed from aligned_storage and is intentionally left uninitialized (it might not be default constructible) + // _dummy is constructed from raw byte array and is intentionally left uninitialized (it might not be default constructible) // so we init only its IntrusiveLink here - std::atomic* dummyNext = new (&(_dummyPtr->*IntrusiveLink)) std::atomic(); + Atomic* dummyNext = new (&(_dummyPtr->*IntrusiveLink)) Atomic(); dummyNext->store(nullptr, std::memory_order_relaxed); } @@ -106,6 +109,9 @@ public: T* output; while (Dequeue(output)) delete output; + + // destruct our dummy atomic + (_dummyPtr->*IntrusiveLink).~Atomic(); } void Enqueue(T* input) @@ -152,10 +158,10 @@ public: } private: - std::aligned_storage_t _dummy; + alignas(T) std::array _dummy; T* _dummyPtr; - std::atomic _head; - std::atomic _tail; + Atomic _head; + Atomic _tail; MPSCQueueIntrusive(MPSCQueueIntrusive const&) = delete; MPSCQueueIntrusive& operator=(MPSCQueueIntrusive const&) = delete; diff --git a/src/server/game/Server/Packets/AuctionHousePackets.cpp b/src/server/game/Server/Packets/AuctionHousePackets.cpp index 4610c0a0111..cc8bdade761 100644 --- a/src/server/game/Server/Packets/AuctionHousePackets.cpp +++ b/src/server/game/Server/Packets/AuctionHousePackets.cpp @@ -17,6 +17,7 @@ #include "AuctionHousePackets.h" #include "AuctionHouseMgr.h" +#include "DB2Stores.h" #include "ObjectGuid.h" #include "Util.h"