Skip to content

Commit

Permalink
common: utils: array_copy: remove specific diagnostics from the function
Browse files Browse the repository at this point in the history
Change-Id: Id2e03f385fbade13ca0fbc2408a26b45058ea59e
  • Loading branch information
dzarukin authored and Radu2k committed Dec 2, 2024
1 parent 1c40ad0 commit ea7f648
Showing 1 changed file with 16 additions and 2 deletions.
18 changes: 16 additions & 2 deletions src/common/utils.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -209,13 +209,27 @@ constexpr bool any_null(Args... ptrs) {
return one_of(nullptr, ptrs...);
}

// For some unknown reason, GCC 11.x and beyond can't compile specific places
// of the library that involve this routine. It's connected to the fact that
// this function is inline and defined in a header.
#if defined(__GNUC__) && __GNUC__ > 8 && !defined(__clang__)
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wrestrict"
// /usr/include/bits/string_fortified.h:29:33: warning: ‘void* __builtin_memcpy(
// void*, const void*, long unsigned int)’ accessing 18446744056529682432 or
// more bytes at offsets 320 and 0 overlaps 9223372002495037441 bytes at
// offset -9223372019674906625 [-Wrestrict]
#pragma GCC diagnostic ignored "-Wstringop-overflow"
// warning: ‘void* __builtin_memcpy(void*, const void*, long unsigned int)’
// specified bound between 18446744056529682432 and 18446744073709551608
// exceeds maximum object size 9223372036854775807 [-Wstringop-overflow=]
#endif
template <typename T>
inline void array_copy(T *dst, const T *src, size_t size) {
for (size_t i = 0; i < size; ++i)
dst[i] = src[i];
}

#if defined(__GNUC__) && __GNUC__ > 8 && !defined(__clang__)
#if defined(__GNUC__) && !defined(__clang__)
#pragma GCC diagnostic pop
#endif

Expand Down

0 comments on commit ea7f648

Please sign in to comment.