| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 1 | ======================================== |
| 2 | Clang 10.0.0 (In-Progress) Release Notes |
| 3 | ======================================== |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 4 | |
| 5 | .. contents:: |
| 6 | :local: |
| 7 | :depth: 2 |
| 8 | |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 9 | Written by the `LLVM Team <https://llvm.org/>`_ |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 10 | |
| 11 | .. warning:: |
| 12 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 13 | These are in-progress notes for the upcoming Clang 10 release. |
| Hans Wennborg | 189f1f3 | 2017-02-09 23:26:34 +0000 | [diff] [blame] | 14 | Release notes for previous releases can be found on |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 15 | `the Download Page <https://releases.llvm.org/download.html>`_. |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 16 | |
| 17 | Introduction |
| 18 | ============ |
| 19 | |
| 20 | This document contains the release notes for the Clang C/C++/Objective-C |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 21 | frontend, part of the LLVM Compiler Infrastructure, release 10.0.0. Here we |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 22 | describe the status of Clang in some detail, including major |
| 23 | improvements from the previous release and new feature work. For the |
| 24 | general LLVM release notes, see `the LLVM |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 25 | documentation <https://llvm.org/docs/ReleaseNotes.html>`_. All LLVM |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 26 | releases may be downloaded from the `LLVM releases web |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 27 | site <https://llvm.org/releases/>`_. |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 28 | |
| Hans Wennborg | d878ca8 | 2017-08-30 18:35:44 +0000 | [diff] [blame] | 29 | For more information about Clang or LLVM, including information about the |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 30 | latest release, please see the `Clang Web Site <https://clang.llvm.org>`_ or the |
| 31 | `LLVM Web Site <https://llvm.org>`_. |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 32 | |
| 33 | Note that if you are reading this file from a Subversion checkout or the |
| 34 | main Clang web page, this document applies to the *next* release, not |
| 35 | the current one. To see the release notes for a specific release, please |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 36 | see the `releases page <https://llvm.org/releases/>`_. |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 37 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 38 | What's New in Clang 10.0.0? |
| 39 | =========================== |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 40 | |
| 41 | Some of the major new features and improvements to Clang are listed |
| 42 | here. Generic improvements to Clang as a whole or to its underlying |
| 43 | infrastructure are described first, followed by language-specific |
| 44 | sections with improvements to Clang's support for those languages. |
| 45 | |
| 46 | Major New Features |
| 47 | ------------------ |
| 48 | |
| Hans Wennborg | 1fe469a | 2019-01-16 10:57:02 +0000 | [diff] [blame] | 49 | - ... |
| Rafael Espindola | 3497069 | 2013-12-12 16:07:11 +0000 | [diff] [blame] | 50 | |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 51 | Improvements to Clang's diagnostics |
| 52 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 53 | |
| Richard Trieu | 6541c79 | 2019-09-21 02:37:10 +0000 | [diff] [blame] | 54 | - -Wtautological-overlap-compare will warn on negative numbers and non-int |
| 55 | types. |
| Richard Trieu | 4c05de8 | 2019-09-21 03:02:26 +0000 | [diff] [blame] | 56 | - -Wtautological-compare for self comparisons and |
| 57 | -Wtautological-overlap-compare will now look through member and array |
| 58 | access to determine if two operand expressions are the same. |
| Richard Trieu | 8b0d14a | 2019-10-19 00:57:23 +0000 | [diff] [blame] | 59 | - -Wtautological-bitwise-compare is a new warning group. This group has the |
| 60 | current warning which diagnoses the tautological comparison of a bitwise |
| 61 | operation and a constant. The group also has the new warning which diagnoses |
| 62 | when a bitwise-or with a non-negative value is converted to a bool, since |
| 63 | that bool will always be true. |
| Richard Trieu | 637af4c | 2019-10-19 01:47:49 +0000 | [diff] [blame] | 64 | - -Wbitwise-conditional-parentheses will warn on operator precedence issues |
| 65 | when mixing bitwise-and (&) and bitwise-or (|) operator with the |
| 66 | conditional operator (?:). |
| Roman Lebedev | 61061d6 | 2018-04-07 10:39:21 +0000 | [diff] [blame] | 67 | |
| Erich Keane | b0c7809 | 2017-07-26 18:04:45 +0000 | [diff] [blame] | 68 | Non-comprehensive list of changes in this release |
| 69 | ------------------------------------------------- |
| 70 | |
| Roman Lebedev | 536b0ee | 2019-10-10 09:25:02 +0000 | [diff] [blame] | 71 | * In both C and C++ (C17 ``6.5.6p8``, C++ ``[expr.add]``), pointer arithmetic is |
| 72 | only permitted within arrays. In particular, the behavior of a program is not |
| 73 | defined if it adds a non-zero offset (or in C, any offset) to a null pointer, |
| 74 | or if it forms a null pointer by subtracting an integer from a non-null |
| 75 | pointer, and the LLVM optimizer now uses those guarantees for transformations. |
| 76 | This may lead to unintended behavior in code that performs these operations. |
| 77 | The Undefined Behavior Sanitizer ``-fsanitize=pointer-overflow`` check has |
| 78 | been extended to detect these cases, so that code relying on them can be |
| 79 | detected and fixed. |
| 80 | |
| Craig Topper | 635d383 | 2019-09-11 23:54:36 +0000 | [diff] [blame] | 81 | - For X86 target, -march=skylake-avx512, -march=icelake-client, |
| 82 | -march=icelake-server, -march=cascadelake, -march=cooperlake will default to |
| 83 | not using 512-bit zmm registers in vectorized code unless 512-bit intrinsics |
| 84 | are used in the source code. 512-bit operations are known to cause the CPUs |
| 85 | to run at a lower frequency which can impact performance. This behavior can be |
| 86 | changed by passing -mprefer-vector-width=512 on the command line. |
| Ilya Biryukov | 88aef52 | 2018-12-05 18:32:05 +0000 | [diff] [blame] | 87 | |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 88 | New Compiler Flags |
| 89 | ------------------ |
| 90 | |
| Reid Kleckner | 5e866e4 | 2019-10-10 21:04:25 +0000 | [diff] [blame] | 91 | - The -fgnuc-version= flag now controls the value of ``__GNUC__`` and related |
| 92 | macros. This flag does not enable or disable any GCC extensions implemented in |
| 93 | Clang. Setting the version to zero causes Clang to leave ``__GNUC__`` and |
| 94 | other GNU-namespaced macros, such as ``__GXX_WEAK__``, undefined. |
| Aaron Ballman | 2b3bc4c | 2017-10-21 16:45:08 +0000 | [diff] [blame] | 95 | |
| Craig Topper | b2b6a54 | 2019-11-04 10:20:00 -0800 | [diff] [blame] | 96 | - vzeroupper insertion on X86 targets can now be disabled with -mno-vzeroupper. |
| 97 | You can also force vzeroupper insertion to be used on CPUs that normally |
| 98 | wouldn't with -mvzeroupper. |
| 99 | |
| Joerg Sonnenberger | c919968 | 2017-07-01 21:36:21 +0000 | [diff] [blame] | 100 | Deprecated Compiler Flags |
| 101 | ------------------------- |
| 102 | |
| 103 | The following options are deprecated and ignored. They will be removed in |
| 104 | future versions of Clang. |
| 105 | |
| Craig Topper | 5a43fdd | 2019-08-29 18:09:02 +0000 | [diff] [blame] | 106 | - -mmpx used to enable the __MPX__ preprocessor define for the Intel MPX |
| 107 | instructions. There were no MPX intrinsics. |
| 108 | - -mno-mpx used to disable -mmpx and is the default behavior. |
| 109 | |
| Hans Wennborg | fbb21e0 | 2017-07-19 14:14:07 +0000 | [diff] [blame] | 110 | - ... |
| Joerg Sonnenberger | c919968 | 2017-07-01 21:36:21 +0000 | [diff] [blame] | 111 | |
| Yuka Takahashi | ba900ab | 2018-03-07 11:34:02 +0000 | [diff] [blame] | 112 | Modified Compiler Flags |
| 113 | ----------------------- |
| 114 | |
| Eric Christopher | 030b17d | 2019-05-14 19:40:42 +0000 | [diff] [blame] | 115 | - ... |
| Yuka Takahashi | ba900ab | 2018-03-07 11:34:02 +0000 | [diff] [blame] | 116 | |
| Tyler Nowicki | db2668a | 2014-06-18 00:51:32 +0000 | [diff] [blame] | 117 | New Pragmas in Clang |
| Eugene Zelenko | ad5684a | 2018-05-15 21:45:01 +0000 | [diff] [blame] | 118 | -------------------- |
| Tyler Nowicki | db2668a | 2014-06-18 00:51:32 +0000 | [diff] [blame] | 119 | |
| Hans Wennborg | 1fe469a | 2019-01-16 10:57:02 +0000 | [diff] [blame] | 120 | - ... |
| Paul Robinson | f9ede1c | 2016-07-18 17:19:12 +0000 | [diff] [blame] | 121 | |
| 122 | Attribute Changes in Clang |
| 123 | -------------------------- |
| 124 | |
| Hans Wennborg | fbb21e0 | 2017-07-19 14:14:07 +0000 | [diff] [blame] | 125 | - ... |
| Paul Robinson | f9ede1c | 2016-07-18 17:19:12 +0000 | [diff] [blame] | 126 | |
| Hans Wennborg | 02dc000 | 2014-08-05 00:21:23 +0000 | [diff] [blame] | 127 | Windows Support |
| 128 | --------------- |
| 129 | |
| Hans Wennborg | 99c8651 | 2019-09-25 11:53:17 +0000 | [diff] [blame] | 130 | - Previous Clang versions contained a work-around to avoid an issue with the |
| 131 | standard library headers in Visual Studio 2019 versions prior to 16.3. This |
| 132 | work-around has now been removed, and users of Visual Studio 2019 are |
| 133 | encouraged to upgrade to 16.3 or later, otherwise they may see link errors as |
| 134 | below: |
| 135 | |
| 136 | .. code-block:: console |
| 137 | |
| 138 | error LNK2005: "bool const std::_Is_integral<int>" (??$_Is_integral@H@std@@3_NB) already defined |
| 139 | |
| 140 | |
| 141 | |
| Hans Wennborg | 02dc000 | 2014-08-05 00:21:23 +0000 | [diff] [blame] | 142 | |
| Renato Golin | f2fcddb | 2013-12-13 09:27:34 +0000 | [diff] [blame] | 143 | C Language Changes in Clang |
| 144 | --------------------------- |
| 145 | |
| Kristina Brooks | c0eb8a9 | 2019-06-05 03:47:02 +0000 | [diff] [blame] | 146 | - ... |
| Renato Golin | f2fcddb | 2013-12-13 09:27:34 +0000 | [diff] [blame] | 147 | |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 148 | C11 Feature Support |
| 149 | ^^^^^^^^^^^^^^^^^^^ |
| 150 | |
| 151 | ... |
| 152 | |
| 153 | C++ Language Changes in Clang |
| 154 | ----------------------------- |
| 155 | |
| Martin Storsjo | 71decf8 | 2019-09-27 12:25:19 +0000 | [diff] [blame] | 156 | - The behaviour of the `gnu_inline` attribute now matches GCC, for cases |
| 157 | where used without the `extern` keyword. As this is a change compared to |
| 158 | how it behaved in previous Clang versions, a warning is emitted for this |
| 159 | combination. |
| Richard Smith | 8eb53c8 | 2016-05-05 18:40:37 +0000 | [diff] [blame] | 160 | |
| 161 | C++1z Feature Support |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 162 | ^^^^^^^^^^^^^^^^^^^^^ |
| 163 | |
| 164 | ... |
| 165 | |
| 166 | Objective-C Language Changes in Clang |
| 167 | ------------------------------------- |
| 168 | |
| James Y Knight | d11a901 | 2019-11-04 12:44:31 -0500 | [diff] [blame] | 169 | - In both Objective-C and |
| 170 | Objective-C++, ``-Wcompare-distinct-pointer-types`` will now warn when |
| 171 | comparing ObjC ``Class`` with an ObjC instance type pointer. |
| 172 | |
| 173 | .. code-block:: objc |
| 174 | |
| 175 | Class clz = ...; |
| 176 | MyType *instance = ...; |
| 177 | bool eq = (clz == instance); // Previously undiagnosed, now warns. |
| 178 | |
| 179 | - Objective-C++ now diagnoses conversions between ``Class`` and ObjC |
| 180 | instance type pointers. Such conversions already emitted an |
| 181 | on-by-default ``-Wincompatible-pointer-types`` warning in Objective-C |
| 182 | mode, but had inadvertently been missed entirely in |
| 183 | Objective-C++. This has been fixed, and they are now diagnosed as |
| 184 | errors, consistent with the usual C++ treatment for conversions |
| 185 | between unrelated pointer types. |
| 186 | |
| 187 | .. code-block:: objc |
| 188 | |
| 189 | Class clz = ...; |
| 190 | MyType *instance = ...; |
| 191 | clz = instance; // Previously undiagnosed, now an error. |
| 192 | instance = clz; // Previously undiagnosed, now an error. |
| 193 | |
| 194 | One particular issue you may run into is attempting to use a class |
| 195 | as a key in a dictionary literal. This will now result in an error, |
| 196 | because ``Class`` is not convertable to ``id<NSCopying>``. (Note that |
| 197 | this was already a warning in Objective-C mode.) While an arbitrary |
| 198 | ``Class`` object is not guaranteed to implement ``NSCopying``, the |
| 199 | default metaclass implementation does. Therefore, the recommended |
| 200 | solution is to insert an explicit cast to ``id``, which disables the |
| 201 | type-checking here. |
| 202 | |
| 203 | .. code-block:: objc |
| 204 | |
| 205 | Class cls = ...; |
| 206 | |
| 207 | // Error: cannot convert from Class to id<NSCoding>. |
| 208 | NSDictionary* d = @{cls : @"Hello"}; |
| 209 | |
| 210 | // Fix: add an explicit cast to 'id'. |
| 211 | NSDictionary* d = @{(id)cls : @"Hello"}; |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 212 | |
| Erik Schnetter | 489700d | 2013-11-11 06:36:33 +0000 | [diff] [blame] | 213 | OpenCL C Language Changes in Clang |
| 214 | ---------------------------------- |
| 215 | |
| Bill Wendling | 0a794a4b | 2013-11-20 10:13:37 +0000 | [diff] [blame] | 216 | ... |
| Erik Schnetter | 489700d | 2013-11-11 06:36:33 +0000 | [diff] [blame] | 217 | |
| Richard Smith | 6822bd7 | 2018-10-26 19:26:45 +0000 | [diff] [blame] | 218 | ABI Changes in Clang |
| 219 | -------------------- |
| 220 | |
| Craig Topper | 6c8a34e | 2019-09-06 06:02:13 +0000 | [diff] [blame] | 221 | - gcc passes vectors of __int128 in memory on X86-64. Clang historically |
| 222 | broke the vectors into multiple scalars using two 64-bit values for each |
| 223 | element. Clang now matches the gcc behavior on Linux and NetBSD. You can |
| 224 | switch back to old API behavior with flag: -fclang-abi-compat=9.0. |
| Richard Smith | 6822bd7 | 2018-10-26 19:26:45 +0000 | [diff] [blame] | 225 | |
| Alexey Bataev | 44b6750 | 2016-05-31 11:17:08 +0000 | [diff] [blame] | 226 | OpenMP Support in Clang |
| Shoaib Meenai | 5be71fa | 2019-03-04 21:19:53 +0000 | [diff] [blame] | 227 | ----------------------- |
| Alexey Bataev | 44b6750 | 2016-05-31 11:17:08 +0000 | [diff] [blame] | 228 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 229 | - ... |
| Alexey Bataev | 44b6750 | 2016-05-31 11:17:08 +0000 | [diff] [blame] | 230 | |
| Jonas Hahnfeld | 8da9c2a | 2018-04-20 13:04:54 +0000 | [diff] [blame] | 231 | CUDA Support in Clang |
| 232 | --------------------- |
| 233 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 234 | - ... |
| Jonas Hahnfeld | 8da9c2a | 2018-04-20 13:04:54 +0000 | [diff] [blame] | 235 | |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 236 | Internal API Changes |
| 237 | -------------------- |
| 238 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 239 | These are major API changes that have happened since the 9.0.0 release of |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 240 | Clang. If upgrading an external codebase that uses Clang as a library, |
| 241 | this section should help get you past the largest hurdles of upgrading. |
| 242 | |
| Dmitri Gribenko | b22804b | 2019-08-30 09:29:34 +0000 | [diff] [blame] | 243 | - libTooling APIs that transfer ownership of `FrontendAction` objects now pass |
| 244 | them by `unique_ptr`, making the ownership transfer obvious in the type |
| 245 | system. `FrontendActionFactory::create()` now returns a |
| 246 | `unique_ptr<FrontendAction>`. `runToolOnCode`, `runToolOnCodeWithArgs`, |
| 247 | `ToolInvocation::ToolInvocation()` now take a `unique_ptr<FrontendAction>`. |
| 248 | |
| Shoaib Meenai | 5be71fa | 2019-03-04 21:19:53 +0000 | [diff] [blame] | 249 | Build System Changes |
| 250 | -------------------- |
| 251 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 252 | These are major changes to the build system that have happened since the 9.0.0 |
| Shoaib Meenai | 5be71fa | 2019-03-04 21:19:53 +0000 | [diff] [blame] | 253 | release of Clang. Users of the build system should adjust accordingly. |
| 254 | |
| 255 | - In 8.0.0 and below, the install-clang-headers target would install clang's |
| 256 | resource directory headers. This installation is now performed by the |
| 257 | install-clang-resource-headers target. Users of the old install-clang-headers |
| Shoaib Meenai | 20e7c0c | 2019-03-11 18:53:57 +0000 | [diff] [blame] | 258 | target should switch to the new install-clang-resource-headers target. The |
| 259 | install-clang-headers target now installs clang's API headers (corresponding |
| 260 | to its libraries), which is consistent with the install-llvm-headers target. |
| Shoaib Meenai | 5be71fa | 2019-03-04 21:19:53 +0000 | [diff] [blame] | 261 | |
| Chris Bieneman | a80a3a2b | 2019-08-14 16:49:52 +0000 | [diff] [blame] | 262 | - In 9.0.0 and later Clang added a new target, clang-cpp, which generates a |
| 263 | shared library comprised of all the clang component libraries and exporting |
| 264 | the clang C++ APIs. Additionally the build system gained the new |
| 265 | "CLANG_LINK_CLANG_DYLIB" option, which defaults Off, and when set to On, will |
| 266 | force clang (and clang-based tools) to link the clang-cpp library instead of |
| 267 | statically linking clang's components. This option will reduce the size of |
| 268 | binary distributions at the expense of compiler performance. |
| 269 | |
| 270 | - ... |
| Richard Smith | a0334a9 | 2015-05-14 00:22:12 +0000 | [diff] [blame] | 271 | |
| Aaron Ballman | cdc43af | 2015-09-17 13:47:22 +0000 | [diff] [blame] | 272 | AST Matchers |
| 273 | ------------ |
| Aaron Ballman | cdc43af | 2015-09-17 13:47:22 +0000 | [diff] [blame] | 274 | |
| Paul Hoad | ccc6f83 | 2019-03-22 22:47:34 +0000 | [diff] [blame] | 275 | - ... |
| Sylvestre Ledru | 72e3fa7 | 2017-03-14 09:43:55 +0000 | [diff] [blame] | 276 | |
| 277 | clang-format |
| 278 | ------------ |
| 279 | |
| Sam McCall | 08bfd9e | 2019-10-02 09:52:52 +0000 | [diff] [blame] | 280 | - The ``Standard`` style option specifies which version of C++ should be used |
| 281 | when parsing and formatting C++ code. The set of allowed values has changed: |
| Simon Pilgrim | 68f21b3 | 2019-10-05 16:08:17 +0000 | [diff] [blame] | 282 | |
| Sam McCall | 08bfd9e | 2019-10-02 09:52:52 +0000 | [diff] [blame] | 283 | - ``Latest`` will always enable new C++ language features. |
| 284 | - ``c++03``, ``c++11``, ``c++14``, ``c++17``, ``c++20`` will pin to exactly |
| 285 | that language version. |
| 286 | - ``Auto`` is the default and detects style from the code (this is unchanged). |
| Simon Pilgrim | 68f21b3 | 2019-10-05 16:08:17 +0000 | [diff] [blame] | 287 | |
| 288 | The previous values of ``Cpp03`` and ``Cpp11`` are deprecated. Note that |
| 289 | ``Cpp11`` is treated as ``Latest``, as this was always clang-format's behavior. |
| 290 | (One motivation for this change is the new name describes the behavior better). |
| Sylvestre Ledru | c941039 | 2017-12-05 09:23:47 +0000 | [diff] [blame] | 291 | |
| Sylvestre Ledru | 4c44fd3 | 2019-11-08 23:26:29 +0100 | [diff] [blame^] | 292 | - clang-format gets a new option called ``--dry-run`` or ``-n`` to emit a |
| 293 | warning. |
| 294 | |
| Ted Kremenek | 3a2291b | 2013-04-24 07:33:52 +0000 | [diff] [blame] | 295 | libclang |
| 296 | -------- |
| 297 | |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 298 | - ... |
| Ted Kremenek | 3a2291b | 2013-04-24 07:33:52 +0000 | [diff] [blame] | 299 | |
| Sylvestre Ledru | ea49d3a | 2016-08-06 20:23:54 +0000 | [diff] [blame] | 300 | |
| Anna Zaks | b6219a9 | 2013-04-25 23:14:38 +0000 | [diff] [blame] | 301 | Static Analyzer |
| Ted Kremenek | 004e823 | 2013-04-26 00:01:34 +0000 | [diff] [blame] | 302 | --------------- |
| Anna Zaks | b6219a9 | 2013-04-25 23:14:38 +0000 | [diff] [blame] | 303 | |
| Sylvestre Ledru | 9bea4ec | 2019-10-11 20:33:43 +0000 | [diff] [blame] | 304 | - The Clang analyzer checker ``DeadStores`` gets a new option called |
| 305 | ``WarnForDeadNestedAssignments`` to detect nested dead assignments |
| 306 | (enabled by default). |
| Hans Wennborg | 8f5b44a | 2019-07-18 11:51:05 +0000 | [diff] [blame] | 307 | - ... |
| Ted Kremenek | 004e823 | 2013-04-26 00:01:34 +0000 | [diff] [blame] | 308 | |
| Roman Lebedev | b69ba22 | 2018-07-30 18:58:30 +0000 | [diff] [blame] | 309 | .. _release-notes-ubsan: |
| 310 | |
| Vedant Kumar | 840c2c7 | 2017-06-13 02:52:31 +0000 | [diff] [blame] | 311 | Undefined Behavior Sanitizer (UBSan) |
| 312 | ------------------------------------ |
| 313 | |
| Roman Lebedev | 536b0ee | 2019-10-10 09:25:02 +0000 | [diff] [blame] | 314 | - * The ``pointer-overflow`` check was extended added to catch the cases where |
| 315 | a non-zero offset is applied to a null pointer, or the result of |
| 316 | applying the offset is a null pointer. |
| 317 | |
| 318 | .. code-block:: c++ |
| 319 | |
| 320 | #include <cstdint> // for intptr_t |
| 321 | |
| 322 | static char *getelementpointer_inbounds(char *base, unsigned long offset) { |
| 323 | // Potentially UB. |
| 324 | return base + offset; |
| 325 | } |
| 326 | |
| 327 | char *getelementpointer_unsafe(char *base, unsigned long offset) { |
| 328 | // Always apply offset. UB if base is ``nullptr`` and ``offset`` is not |
| 329 | // zero, or if ``base`` is non-``nullptr`` and ``offset`` is |
| 330 | // ``-reinterpret_cast<intptr_t>(base)``. |
| 331 | return getelementpointer_inbounds(base, offset); |
| 332 | } |
| 333 | |
| 334 | char *getelementpointer_safe(char *base, unsigned long offset) { |
| 335 | // Cast pointer to integer, perform usual arithmetic addition, |
| 336 | // and cast to pointer. This is legal. |
| 337 | char *computed = |
| 338 | reinterpret_cast<char *>(reinterpret_cast<intptr_t>(base) + offset); |
| 339 | // If either the pointer becomes non-``nullptr``, or becomes |
| 340 | // ``nullptr``, we must use ``computed`` result. |
| 341 | if (((base == nullptr) && (computed != nullptr)) || |
| 342 | ((base != nullptr) && (computed == nullptr))) |
| 343 | return computed; |
| 344 | // Else we can use ``getelementpointer_inbounds()``. |
| 345 | return getelementpointer_inbounds(base, offset); |
| 346 | } |
| 347 | |
| Roman Lebedev | bd1c087 | 2019-01-15 09:44:25 +0000 | [diff] [blame] | 348 | |
| Ted Kremenek | 004e823 | 2013-04-26 00:01:34 +0000 | [diff] [blame] | 349 | Core Analysis Improvements |
| 350 | ========================== |
| 351 | |
| Bill Wendling | 61f44cc | 2013-06-04 06:17:46 +0000 | [diff] [blame] | 352 | - ... |
| Ted Kremenek | 004e823 | 2013-04-26 00:01:34 +0000 | [diff] [blame] | 353 | |
| 354 | New Issues Found |
| 355 | ================ |
| 356 | |
| Bill Wendling | 61f44cc | 2013-06-04 06:17:46 +0000 | [diff] [blame] | 357 | - ... |
| Anna Zaks | b6219a9 | 2013-04-25 23:14:38 +0000 | [diff] [blame] | 358 | |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 359 | Python Binding Changes |
| 360 | ---------------------- |
| 361 | |
| 362 | The following methods have been added: |
| 363 | |
| 364 | - ... |
| 365 | |
| 366 | Significant Known Problems |
| 367 | ========================== |
| 368 | |
| 369 | Additional Information |
| 370 | ====================== |
| 371 | |
| 372 | A wide variety of additional information is available on the `Clang web |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 373 | page <https://clang.llvm.org/>`_. The web page contains versions of the |
| Sean Silva | fe25144 | 2012-12-23 01:19:35 +0000 | [diff] [blame] | 374 | API documentation which are up-to-date with the Subversion version of |
| 375 | the source code. You can access versions of these documents specific to |
| 376 | this release by going into the "``clang/docs/``" directory in the Clang |
| 377 | tree. |
| 378 | |
| 379 | If you have any questions or comments about Clang, please feel free to |
| 380 | contact us via the `mailing |
| Hans Wennborg | 0aa0d91 | 2018-09-10 08:51:25 +0000 | [diff] [blame] | 381 | list <https://lists.llvm.org/mailman/listinfo/cfe-dev>`_. |