Skip to content

Commit

Permalink
#161 fix ASAN errors
Browse files Browse the repository at this point in the history
  • Loading branch information
Jakub Strzebonski committed Jun 23, 2021
1 parent 1ea3f1f commit fa59359
Showing 1 changed file with 22 additions and 9 deletions.
31 changes: 22 additions & 9 deletions src/checkpoint/container/vector_serialize.h
Original file line number Diff line number Diff line change
Expand Up @@ -98,14 +98,22 @@ void constructVectorDataWithResize(
);
}

template <typename T>
struct Allocated {
Allocated() : buf{dispatch::Standard::template allocate<T>()} { }
~Allocated() { std::allocator<T>{}.deallocate(reinterpret_cast<T*>(buf), 1); }

SerialByteType* buf;
};

template <typename T, typename VectorAllocator>
void constructVectorDataReconstruct(
SerialSizeType const vec_size, std::vector<T, VectorAllocator>& vec,
typename dispatch::Reconstructor<T>::template isReconstructibleType<T>* = nullptr
) {
auto buf = dispatch::Standard::template allocate<T>();
Allocated<T> const allocated;
for (SerialSizeType i = 0; i < vec_size; ++i) {
auto& t = T::reconstruct(buf);
auto& t = T::reconstruct(allocated.buf);
vec.emplace_back(std::move(t));
}
}
Expand All @@ -115,10 +123,10 @@ void constructVectorDataReconstruct(
SerialSizeType const vec_size, std::vector<T, VectorAllocator>& vec,
typename dispatch::Reconstructor<T>::template isNonIntReconstructibleType<T>* = nullptr
) {
auto buf = dispatch::Standard::allocate<T>();
Allocated<T> const allocated;
for (SerialSizeType i = 0; i < vec_size; ++i) {
T* t = nullptr;
reconstruct(t, buf);
reconstruct(t, allocated.buf);
vec.emplace_back(std::move(*t));
}
}
Expand All @@ -136,9 +144,7 @@ void constructVectorData(
SerialSizeType const vec_size, std::vector<T, VectorAllocator>& vec,
typename dispatch::Reconstructor<T>::template isTaggedConstructibleType<T>* = nullptr
) {
for (SerialSizeType i = 0; i < vec_size; ++i) {
vec.emplace_back(SERIALIZE_CONSTRUCT_TAG{});
}
vec.resize(vec_size, T{SERIALIZE_CONSTRUCT_TAG{}});
}

template <typename T, typename VectorAllocator>
Expand All @@ -152,7 +158,11 @@ void constructVectorData(
template <typename Serializer, typename T, typename VectorAllocator>
void serialize(Serializer& s, std::vector<T, VectorAllocator>& vec) {
auto const vec_size = serializeVectorMeta(s, vec);
constructVectorData(vec_size, vec);

if (s.isUnpacking()) {
constructVectorData(vec_size, vec);
}

dispatch::serializeArray(s, vec.data(), vec.size());

// make sure to account for reserved space when footprinting
Expand All @@ -167,7 +177,10 @@ void serialize(Serializer& s, std::vector<bool, VectorAllocator>& vec) {
}

auto const vec_size = serializeVectorMeta(s, vec);
constructVectorData(vec_size, vec);

if (s.isUnpacking()) {
constructVectorData(vec_size, vec);
}

if (!s.isUnpacking()) {
for (bool elt : vec) {
Expand Down

0 comments on commit fa59359

Please sign in to comment.