2022-02-02 15:13:01 +08:00
|
|
|
===========================================
|
|
|
|
Clang |release| |ReleaseNotesTitle|
|
|
|
|
===========================================
|
2020-02-14 05:46:33 +08:00
|
|
|
|
|
|
|
.. contents::
|
|
|
|
:local:
|
|
|
|
:depth: 2
|
|
|
|
|
|
|
|
Written by the `LLVM Team <https://llvm.org/>`_
|
|
|
|
|
2022-02-02 15:13:01 +08:00
|
|
|
.. only:: PreRelease
|
2020-02-14 05:46:33 +08:00
|
|
|
|
2022-02-02 15:13:01 +08:00
|
|
|
.. warning::
|
|
|
|
These are in-progress notes for the upcoming Clang |version| release.
|
|
|
|
Release notes for previous releases can be found on
|
|
|
|
`the Download Page <https://releases.llvm.org/download.html>`_.
|
2020-02-14 05:46:33 +08:00
|
|
|
|
|
|
|
Introduction
|
|
|
|
============
|
|
|
|
|
|
|
|
This document contains the release notes for the Clang C/C++/Objective-C
|
2022-02-02 15:13:01 +08:00
|
|
|
frontend, part of the LLVM Compiler Infrastructure, release |release|. Here we
|
2020-02-14 05:46:33 +08:00
|
|
|
describe the status of Clang in some detail, including major
|
|
|
|
improvements from the previous release and new feature work. For the
|
|
|
|
general LLVM release notes, see `the LLVM
|
|
|
|
documentation <https://llvm.org/docs/ReleaseNotes.html>`_. All LLVM
|
|
|
|
releases may be downloaded from the `LLVM releases web
|
|
|
|
site <https://llvm.org/releases/>`_.
|
|
|
|
|
|
|
|
For more information about Clang or LLVM, including information about the
|
|
|
|
latest release, please see the `Clang Web Site <https://clang.llvm.org>`_ or the
|
|
|
|
`LLVM Web Site <https://llvm.org>`_.
|
|
|
|
|
|
|
|
Note that if you are reading this file from a Git checkout or the
|
|
|
|
main Clang web page, this document applies to the *next* release, not
|
|
|
|
the current one. To see the release notes for a specific release, please
|
|
|
|
see the `releases page <https://llvm.org/releases/>`_.
|
|
|
|
|
2022-02-02 15:13:01 +08:00
|
|
|
What's New in Clang |release|?
|
|
|
|
==============================
|
2020-02-14 05:46:33 +08:00
|
|
|
|
|
|
|
Some of the major new features and improvements to Clang are listed
|
|
|
|
here. Generic improvements to Clang as a whole or to its underlying
|
|
|
|
infrastructure are described first, followed by language-specific
|
|
|
|
sections with improvements to Clang's support for those languages.
|
|
|
|
|
|
|
|
Major New Features
|
|
|
|
------------------
|
|
|
|
|
2022-02-11 15:27:33 +08:00
|
|
|
Bug Fixes
|
2022-05-06 20:47:19 +08:00
|
|
|
---------
|
2022-07-30 01:16:10 +08:00
|
|
|
- Fixes an accepts-invalid bug in C when using a ``_Noreturn`` function
|
|
|
|
specifier on something other than a function declaration. This fixes
|
|
|
|
`Issue 56800 <https://github.com/llvm/llvm-project/issues/56800>`_.
|
2022-08-02 04:47:30 +08:00
|
|
|
- Fix `#56772 <https://github.com/llvm/llvm-project/issues/56772>`_ - invalid
|
|
|
|
destructor names were incorrectly accepted on template classes.
|
2022-07-29 22:12:49 +08:00
|
|
|
- Improve compile-times with large dynamic array allocations with trivial
|
|
|
|
constructors. This fixes
|
2022-08-03 16:51:34 +08:00
|
|
|
`Issue 56774 <https://github.com/llvm/llvm-project/issues/56774>`_.
|
2022-08-04 02:05:09 +08:00
|
|
|
- No longer assert/miscompile when trying to make a vectorized ``_BitInt`` type
|
|
|
|
using the ``ext_vector_type`` attribute (the ``vector_size`` attribute was
|
|
|
|
already properly diagnosing this case).
|
2022-08-03 23:05:07 +08:00
|
|
|
- Fix clang not properly diagnosing the failing subexpression when chained
|
|
|
|
binary operators are used in a ``static_assert`` expression.
|
2022-08-04 18:53:06 +08:00
|
|
|
- Fix a crash when evaluating a multi-dimensional array's array filler
|
|
|
|
expression is element-dependent. This fixes
|
|
|
|
`Issue 50601 <https://github.com/llvm/llvm-project/issues/56016>`_.
|
|
|
|
|
2022-03-13 03:49:01 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Improvements to Clang's diagnostics
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2022-07-29 06:26:15 +08:00
|
|
|
- Clang will now correctly diagnose as ill-formed a constant expression where an
|
|
|
|
enum without a fixed underlying type is set to a value outside the range of
|
2022-08-09 06:17:34 +08:00
|
|
|
the enumeration's values. Due to the extended period of time this bug was
|
|
|
|
present in major C++ implementations (including Clang), this error has the
|
|
|
|
ability to be downgraded into a warning (via: -Wno-error=enum-constexpr-conversion)
|
|
|
|
to provide a transition period for users. This diagnostic is expected to turn
|
|
|
|
into an error-only diagnostic in the next Clang release. Fixes
|
2022-07-29 06:26:15 +08:00
|
|
|
`Issue 50055: <https://github.com/llvm/llvm-project/issues/50055>`_.
|
2022-08-03 10:07:31 +08:00
|
|
|
- Clang will now check compile-time determinable string literals as format strings.
|
2022-08-07 12:42:15 +08:00
|
|
|
Fixes `Issue 55805: <https://github.com/llvm/llvm-project/issues/55805>`_.
|
2022-08-05 01:26:31 +08:00
|
|
|
- ``-Wformat`` now recognizes ``%b`` for the ``printf``/``scanf`` family of
|
|
|
|
functions and ``%B`` for the ``printf`` family of functions. Fixes
|
|
|
|
`Issue 56885: <https://github.com/llvm/llvm-project/issues/56885>`_.
|
2022-08-09 23:42:39 +08:00
|
|
|
- ``-Wbitfield-constant-conversion`` now diagnoses implicit truncation when 1 is
|
|
|
|
assigned to a 1-bit signed integer bitfield. This fixes
|
|
|
|
`Issue 53253 <https://github.com/llvm/llvm-project/issues/53253>`_.
|
2022-08-11 01:52:33 +08:00
|
|
|
- ``-Wincompatible-function-pointer-types`` now defaults to an error in all C
|
|
|
|
language modes. It may be downgraded to a warning with
|
|
|
|
``-Wno-error=incompatible-function-pointer-types`` or disabled entirely with
|
|
|
|
``-Wno-implicit-function-pointer-types``.
|
[clang] Require strict matches for defines for PCH in GCC style directories
When clang includes a PCH, it tolerates some amount of differences
between the defines used when creating and when including the PCH
- this seems to be intentionally allowed in
c379c072405f39bca1d3552408fc0427328e8b6d (and later extended in
b63687519610a73dd565be1fec28332211b4df5b).
When using a PCH (or when picking a PCH out of a directory containing
multiple candidates) Clang used to accept the header if there were
defines on the command line when creating the PCH that are missing
when using the PCH, or vice versa, defines only set when using the
PCH.
The only cases where Clang explicitly rejected the use of a PCH
is if there was an explicit conflict between the options, e.g.
-DFOO=1 vs -DFOO=2, or -DFOO vs -UFOO.
The latter commit added a FIXME that we really should check whether
mismatched defines actually were used somewhere in the PCH, so that
the define would affect the outcome. This FIXME has stood unaddressed
since 2012.
This differs from GCC, which rejects PCH files if the defines differ
at all.
When explicitly including a single PCH file, the relaxed policy
of allowing minor differences is harmless for correct use cases
(but may fail to diagnose mismtaches), and potentially allow using
PCHs in wider cases (where the user intentionally know that the
differences in defines are harmless for the PCH).
However, for GCC style PCH directories, with a directory containing
multiple PCH variants and the compiler should pick the correct match
out of them, Clang's relaxed logic was problematic. The directory
could contain two otherwise identical PCHs, but one built with -DFOO
and one without. When attempting to include a PCH and iterating over
the candidates in the directory, Clang would essentially pick the
first one out of the two, even if there existed a better, exact
match in the directory.
Keep the relaxed checking when specificlly including one named
PCH file, but require strict matches when trying to pick the right
candidate out of a GCC style directory with alternatives.
This fixes https://github.com/lhmouse/mcfgthread/issues/63.
Differential Revision: https://reviews.llvm.org/D126676
2022-05-25 20:07:18 +08:00
|
|
|
- When including a PCH from a GCC style directory with multiple alternative PCH
|
|
|
|
files, Clang now requires all defines set on the command line while generating
|
|
|
|
the PCH and when including it to match. This matches GCC's behaviour.
|
|
|
|
Previously Clang would tolerate defines to be set when creating the PCH but
|
|
|
|
missing when used, or vice versa. This makes sure that Clang picks the
|
|
|
|
correct one, where it previously would consider multiple ones as potentially
|
|
|
|
acceptable (and erroneously use whichever one is tried first).
|
2022-08-01 20:12:32 +08:00
|
|
|
- Clang will now print more information about failed static assertions. In
|
|
|
|
particular, simple static assertion expressions are evaluated to their
|
|
|
|
compile-time value and printed out if the assertion fails.
|
2022-04-02 06:03:48 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Non-comprehensive list of changes in this release
|
2022-03-25 19:13:26 +08:00
|
|
|
-------------------------------------------------
|
2022-05-06 06:57:17 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
New Compiler Flags
|
|
|
|
------------------
|
|
|
|
|
|
|
|
Deprecated Compiler Flags
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
Modified Compiler Flags
|
|
|
|
-----------------------
|
|
|
|
|
2020-12-17 22:23:02 +08:00
|
|
|
Removed Compiler Flags
|
|
|
|
-------------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
New Pragmas in Clang
|
|
|
|
--------------------
|
|
|
|
- ...
|
|
|
|
|
|
|
|
Attribute Changes in Clang
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
Windows Support
|
|
|
|
---------------
|
|
|
|
|
2022-05-03 05:06:04 +08:00
|
|
|
AIX Support
|
|
|
|
-----------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
C Language Changes in Clang
|
|
|
|
---------------------------
|
|
|
|
|
2022-02-14 22:33:48 +08:00
|
|
|
C2x Feature Support
|
|
|
|
-------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
C++ Language Changes in Clang
|
|
|
|
-----------------------------
|
|
|
|
|
2021-04-14 19:18:23 +08:00
|
|
|
C++20 Feature Support
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^
|
2022-06-17 01:52:12 +08:00
|
|
|
|
2022-03-30 20:27:44 +08:00
|
|
|
- Support capturing structured bindings in lambdas
|
|
|
|
(`P1091R3 <https://wg21.link/p1091r3>`_ and `P1381R1 <https://wg21.link/P1381R1>`).
|
|
|
|
This fixes issues `GH52720 <https://github.com/llvm/llvm-project/issues/52720>`_,
|
|
|
|
`GH54300 <https://github.com/llvm/llvm-project/issues/54300>`_,
|
|
|
|
`GH54301 <https://github.com/llvm/llvm-project/issues/54301>`_,
|
|
|
|
and `GH49430 <https://github.com/llvm/llvm-project/issues/49430>`_.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-04-14 19:18:23 +08:00
|
|
|
C++2b Feature Support
|
2020-02-14 05:46:33 +08:00
|
|
|
^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
2022-05-04 02:13:56 +08:00
|
|
|
CUDA/HIP Language Changes in Clang
|
|
|
|
----------------------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Objective-C Language Changes in Clang
|
|
|
|
-------------------------------------
|
|
|
|
|
|
|
|
OpenCL C Language Changes in Clang
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
ABI Changes in Clang
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
OpenMP Support in Clang
|
|
|
|
-----------------------
|
|
|
|
|
2022-04-19 20:45:51 +08:00
|
|
|
...
|
2022-02-03 02:06:55 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
CUDA Support in Clang
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
2020-08-21 04:37:51 +08:00
|
|
|
X86 Support in Clang
|
|
|
|
--------------------
|
|
|
|
|
2022-07-29 17:47:49 +08:00
|
|
|
- Support ``-mindirect-branch-cs-prefix`` for call and jmp to indirect thunk.
|
|
|
|
|
2022-01-24 12:45:25 +08:00
|
|
|
DWARF Support in Clang
|
|
|
|
----------------------
|
|
|
|
|
2021-10-15 21:29:57 +08:00
|
|
|
Arm and AArch64 Support in Clang
|
|
|
|
--------------------------------
|
|
|
|
|
2021-11-09 22:35:25 +08:00
|
|
|
Floating Point Support in Clang
|
|
|
|
-------------------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Internal API Changes
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
Build System Changes
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
AST Matchers
|
|
|
|
------------
|
|
|
|
|
|
|
|
clang-format
|
|
|
|
------------
|
|
|
|
|
2022-07-05 19:45:32 +08:00
|
|
|
clang-extdef-mapping
|
|
|
|
--------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
libclang
|
|
|
|
--------
|
|
|
|
|
|
|
|
Static Analyzer
|
|
|
|
---------------
|
2022-06-14 15:20:41 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
.. _release-notes-ubsan:
|
|
|
|
|
|
|
|
Undefined Behavior Sanitizer (UBSan)
|
|
|
|
------------------------------------
|
|
|
|
|
|
|
|
Core Analysis Improvements
|
|
|
|
==========================
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
|
|
|
New Issues Found
|
|
|
|
================
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
|
|
|
Python Binding Changes
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
The following methods have been added:
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
|
|
|
Significant Known Problems
|
|
|
|
==========================
|
|
|
|
|
|
|
|
Additional Information
|
|
|
|
======================
|
|
|
|
|
|
|
|
A wide variety of additional information is available on the `Clang web
|
|
|
|
page <https://clang.llvm.org/>`_. The web page contains versions of the
|
2020-03-23 05:18:40 +08:00
|
|
|
API documentation which are up-to-date with the Git version of
|
2020-02-14 05:46:33 +08:00
|
|
|
the source code. You can access versions of these documents specific to
|
|
|
|
this release by going into the "``clang/docs/``" directory in the Clang
|
|
|
|
tree.
|
|
|
|
|
|
|
|
If you have any questions or comments about Clang, please feel free to
|
2022-07-02 05:07:48 +08:00
|
|
|
contact us on the Discourse forums (Clang Frontend category)
|
|
|
|
<https://discourse.llvm.org/c/clang/6>`_.
|