blob: 15442f172fc03897659f58c99c254b9759f56582 [file] [log] [blame]
James Kuszmaulb13e13f2023-11-22 20:44:04 -08001From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
James Kuszmaulcf324122023-01-14 14:07:17 -08002From: PJ Reiniger <pj.reiniger@gmail.com>
3Date: Sun, 8 May 2022 13:34:07 -0400
James Kuszmaulb13e13f2023-11-22 20:44:04 -08004Subject: [PATCH 08/31] Add compiler warning pragmas
James Kuszmaulcf324122023-01-14 14:07:17 -08005
6---
7 llvm/include/llvm/ADT/FunctionExtras.h | 11 +++++++++++
8 llvm/include/llvm/ADT/Hashing.h | 9 +++++++++
9 llvm/include/llvm/ADT/SmallVector.h | 8 ++++++++
10 llvm/include/llvm/Support/MathExtras.h | 9 +++++++++
11 llvm/include/llvm/Support/MemAlloc.h | 13 +++++++++++++
12 llvm/lib/Support/raw_ostream.cpp | 4 ++++
13 llvm/unittests/ADT/DenseMapTest.cpp | 4 ++++
14 llvm/unittests/ADT/MapVectorTest.cpp | 7 +++++++
15 llvm/unittests/ADT/SmallVectorTest.cpp | 4 ++++
16 llvm/unittests/Support/AlignOfTest.cpp | 7 +++----
17 10 files changed, 72 insertions(+), 4 deletions(-)
18
19diff --git a/llvm/include/llvm/ADT/FunctionExtras.h b/llvm/include/llvm/ADT/FunctionExtras.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080020index 9d10b16e3cbe9c0df818a3254fcd3a6032d54b39..1daeae915eb506b32a2d1296d2f0fe4e6dab606e 100644
James Kuszmaulcf324122023-01-14 14:07:17 -080021--- a/llvm/include/llvm/ADT/FunctionExtras.h
22+++ b/llvm/include/llvm/ADT/FunctionExtras.h
23@@ -55,6 +55,13 @@ namespace llvm {
24 /// It can hold functions with a non-const operator(), like mutable lambdas.
25 template <typename FunctionT> class unique_function;
26
27+// GCC warns on OutOfLineStorage
28+#if defined(__GNUC__) && !defined(__clang__)
29+#pragma GCC diagnostic push
30+#pragma GCC diagnostic ignored "-Warray-bounds"
31+#pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
32+#endif
33+
34 namespace detail {
35
36 template <typename T>
James Kuszmaulb13e13f2023-11-22 20:44:04 -080037@@ -409,6 +416,10 @@ public:
James Kuszmaulcf324122023-01-14 14:07:17 -080038 }
39 };
40
41+#if defined(__GNUC__) && !defined(__clang__)
42+#pragma GCC diagnostic pop
43+#endif
44+
45 } // end namespace llvm
46
47 #endif // LLVM_ADT_FUNCTIONEXTRAS_H
48diff --git a/llvm/include/llvm/ADT/Hashing.h b/llvm/include/llvm/ADT/Hashing.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080049index ef983105c7bae67bb2ef832e4473939a0406e0df..781bdb7416392e3f60a1ac3a38fbcf5324b5395f 100644
James Kuszmaulcf324122023-01-14 14:07:17 -080050--- a/llvm/include/llvm/ADT/Hashing.h
51+++ b/llvm/include/llvm/ADT/Hashing.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080052@@ -56,6 +56,11 @@
James Kuszmaulcf324122023-01-14 14:07:17 -080053 #include <tuple>
54 #include <utility>
55
56+#ifdef _WIN32
57+#pragma warning(push)
58+#pragma warning(disable : 26495)
59+#endif
60+
61 namespace llvm {
62 template <typename T, typename Enable> struct DenseMapInfo;
63
James Kuszmaulb13e13f2023-11-22 20:44:04 -080064@@ -683,4 +688,8 @@ template <> struct DenseMapInfo<hash_code, void> {
James Kuszmaulcf324122023-01-14 14:07:17 -080065
66 } // namespace llvm
67
68+#ifdef _WIN32
69+#pragma warning(pop)
70+#endif
71+
72 #endif
73diff --git a/llvm/include/llvm/ADT/SmallVector.h b/llvm/include/llvm/ADT/SmallVector.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080074index 84f4d0931a30f4be29549354c85cb4c0489e14c9..b42438a9b16c273f9ef5b5cce6192873c78cb964 100644
James Kuszmaulcf324122023-01-14 14:07:17 -080075--- a/llvm/include/llvm/ADT/SmallVector.h
76+++ b/llvm/include/llvm/ADT/SmallVector.h
77@@ -14,6 +14,14 @@
78 #ifndef LLVM_ADT_SMALLVECTOR_H
79 #define LLVM_ADT_SMALLVECTOR_H
80
81+// This file uses std::memcpy() to copy std::pair<unsigned int, unsigned int>.
82+// That type is POD, but the standard doesn't guarantee that. GCC doesn't treat
83+// the type as POD so it throws a warning. We want to consider this a warning
84+// instead of an error.
85+#if __GNUC__ >= 8
86+#pragma GCC diagnostic warning "-Wclass-memaccess"
87+#endif
88+
89 #include "llvm/Support/Compiler.h"
90 #include "llvm/Support/type_traits.h"
91 #include <algorithm>
92diff --git a/llvm/include/llvm/Support/MathExtras.h b/llvm/include/llvm/Support/MathExtras.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080093index 0bd572d07fcbf2ff56998dbf366215068b62f527..cd5a64a746b2eb7491e9b6cf8570bdf436d94a6d 100644
James Kuszmaulcf324122023-01-14 14:07:17 -080094--- a/llvm/include/llvm/Support/MathExtras.h
95+++ b/llvm/include/llvm/Support/MathExtras.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -080096@@ -208,6 +208,11 @@ inline uint64_t maxUIntN(uint64_t N) {
James Kuszmaulcf324122023-01-14 14:07:17 -080097 return UINT64_MAX >> (64 - N);
98 }
99
100+#ifdef _WIN32
101+#pragma warning(push)
102+#pragma warning(disable : 4146)
103+#endif
104+
105 /// Gets the minimum value for a N-bit signed integer.
106 inline int64_t minIntN(int64_t N) {
107 assert(N > 0 && N <= 64 && "integer width out of range");
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800108@@ -215,6 +220,10 @@ inline int64_t minIntN(int64_t N) {
James Kuszmaulcf324122023-01-14 14:07:17 -0800109 return UINT64_C(1) + ~(UINT64_C(1) << (N - 1));
110 }
111
112+#ifdef _WIN32
113+#pragma warning(pop)
114+#endif
115+
116 /// Gets the maximum value for a N-bit signed integer.
117 inline int64_t maxIntN(int64_t N) {
118 assert(N > 0 && N <= 64 && "integer width out of range");
119diff --git a/llvm/include/llvm/Support/MemAlloc.h b/llvm/include/llvm/Support/MemAlloc.h
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800120index d6012bd5a6985d8405136039aa85931605cd8a40..01007deb89bba625b1b3ad3e703d0c16ed6f757b 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800121--- a/llvm/include/llvm/Support/MemAlloc.h
122+++ b/llvm/include/llvm/Support/MemAlloc.h
123@@ -22,6 +22,14 @@
124
125 namespace llvm {
126
127+#ifdef _WIN32
128+#pragma warning(push)
129+// Warning on NONNULL, report is not known to abort
130+#pragma warning(disable : 6387)
131+#pragma warning(disable : 28196)
132+#pragma warning(disable : 28183)
133+#endif
134+
135 LLVM_ATTRIBUTE_RETURNS_NONNULL inline void *safe_malloc(size_t Sz) {
136 void *Result = std::malloc(Sz);
137 if (Result == nullptr) {
138@@ -84,4 +92,9 @@ allocate_buffer(size_t Size, size_t Alignment);
139 void deallocate_buffer(void *Ptr, size_t Size, size_t Alignment);
140
141 } // namespace llvm
142+
143+#ifdef _WIN32
144+#pragma warning(pop)
145+#endif
146+
147 #endif
148diff --git a/llvm/lib/Support/raw_ostream.cpp b/llvm/lib/Support/raw_ostream.cpp
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800149index 9966a0056ae4f24a7a38346ee1c2f5d83ac20248..a23f567a37abdc199363607446f33f29e021d7ad 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800150--- a/llvm/lib/Support/raw_ostream.cpp
151+++ b/llvm/lib/Support/raw_ostream.cpp
152@@ -10,6 +10,10 @@
153 //
154 //===----------------------------------------------------------------------===//
155
156+#ifdef _WIN32
157+#define _CRT_NONSTDC_NO_WARNINGS
158+#endif
159+
160 #include "llvm/Support/raw_ostream.h"
James Kuszmaulcf324122023-01-14 14:07:17 -0800161 #include "llvm/ADT/StringExtras.h"
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800162 #include "llvm/Config/config.h"
James Kuszmaulcf324122023-01-14 14:07:17 -0800163diff --git a/llvm/unittests/ADT/DenseMapTest.cpp b/llvm/unittests/ADT/DenseMapTest.cpp
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800164index b710ac07461ba58faa99cedeae7f209dc0f5902b..1f232d3046292c0da940ba4bef7d50604556e4c2 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800165--- a/llvm/unittests/ADT/DenseMapTest.cpp
166+++ b/llvm/unittests/ADT/DenseMapTest.cpp
167@@ -6,6 +6,10 @@
168 //
169 //===----------------------------------------------------------------------===//
170
171+#if defined(__GNUC__) && !defined(__clang__)
172+#pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
173+#endif
174+
175 #include "llvm/ADT/DenseMap.h"
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800176 #include "llvm/ADT/DenseMapInfo.h"
177 #include "llvm/ADT/DenseMapInfoVariant.h"
James Kuszmaulcf324122023-01-14 14:07:17 -0800178diff --git a/llvm/unittests/ADT/MapVectorTest.cpp b/llvm/unittests/ADT/MapVectorTest.cpp
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800179index 1a371cbfba81e8ea4b57c4077ca94c86c3db8991..62fafcaf04a67d4c67b98b8f42d837ccca245fe9 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800180--- a/llvm/unittests/ADT/MapVectorTest.cpp
181+++ b/llvm/unittests/ADT/MapVectorTest.cpp
182@@ -6,6 +6,13 @@
183 //
184 //===----------------------------------------------------------------------===//
185
186+#if defined(__GNUC__)
187+#pragma GCC diagnostic ignored "-Wpedantic"
188+#if !defined(__clang__)
189+#pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
190+#endif
191+#endif
192+
193 #include "llvm/ADT/MapVector.h"
194 #include "llvm/ADT/iterator_range.h"
195 #include "gtest/gtest.h"
196diff --git a/llvm/unittests/ADT/SmallVectorTest.cpp b/llvm/unittests/ADT/SmallVectorTest.cpp
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800197index 7029038d18d433cef987bedbfa4fda269b24fb8f..f8c37820ef9fdfe0af067f5aa8d2297ed15e73bc 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800198--- a/llvm/unittests/ADT/SmallVectorTest.cpp
199+++ b/llvm/unittests/ADT/SmallVectorTest.cpp
200@@ -17,6 +17,10 @@
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800201 #include <span>
James Kuszmaulcf324122023-01-14 14:07:17 -0800202 #include <stdarg.h>
203
204+#if defined(__GNUC__)
205+#pragma GCC diagnostic ignored "-Wpedantic"
206+#endif
207+
208 using namespace llvm;
209
210 namespace {
211diff --git a/llvm/unittests/Support/AlignOfTest.cpp b/llvm/unittests/Support/AlignOfTest.cpp
James Kuszmaulb13e13f2023-11-22 20:44:04 -0800212index f84895c18602d3936d623ed79c5d9689cd57cc91..6a50205b143b7ff553066f048a45bf4e1ecc475b 100644
James Kuszmaulcf324122023-01-14 14:07:17 -0800213--- a/llvm/unittests/Support/AlignOfTest.cpp
214+++ b/llvm/unittests/Support/AlignOfTest.cpp
215@@ -31,10 +31,9 @@ namespace {
216 #pragma clang diagnostic ignored "-Wunknown-pragmas"
217 #pragma clang diagnostic ignored "-Winaccessible-base"
218 #elif ((__GNUC__ * 100) + __GNUC_MINOR__) >= 402
219-// Pragma based warning suppression was introduced in GGC 4.2. Additionally
220-// this warning is "enabled by default". The warning still appears if -Wall is
221-// suppressed. Apparently GCC suppresses it when -w is specifed, which is odd.
222-#pragma GCC diagnostic warning "-w"
223+#pragma GCC diagnostic warning "-Wunknown-pragmas"
224+#pragma GCC diagnostic warning "-Winaccessible-base"
225+#pragma GCC diagnostic warning "-Wunused-function"
226 #endif
227
228 // Define some fixed alignment types to use in these tests.