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-15 16:06:01 +08:00
|
|
|
- Clang now supports the ``-fzero-call-used-regs`` feature for x86. The purpose
|
|
|
|
of this feature is to limit Return-Oriented Programming (ROP) exploits and
|
|
|
|
information leakage. It works by zeroing out a selected class of registers
|
|
|
|
before function return --- e.g., all GPRs that are used within the function.
|
|
|
|
There is an analogous ``zero_call_used_regs`` attribute to allow for finer
|
|
|
|
control of this feature.
|
2020-02-14 05:46:33 +08:00
|
|
|
|
2022-02-11 15:27:33 +08:00
|
|
|
Bug Fixes
|
|
|
|
------------------
|
|
|
|
- ``CXXNewExpr::getArraySize()`` previously returned a ``llvm::Optional``
|
|
|
|
wrapping a ``nullptr`` when the ``CXXNewExpr`` did not have an array
|
|
|
|
size expression. This was fixed and ``::getArraySize()`` will now always
|
|
|
|
either return ``None`` or a ``llvm::Optional`` wrapping a valid ``Expr*``.
|
2022-02-23 01:50:39 +08:00
|
|
|
This fixes `Issue 53742 <https://github.com/llvm/llvm-project/issues/53742>`_.
|
2022-03-22 03:09:02 +08:00
|
|
|
- We now ignore full expressions when traversing cast subexpressions. This
|
|
|
|
fixes `Issue 53044 <https://github.com/llvm/llvm-project/issues/53044>`_.
|
2022-03-23 01:14:16 +08:00
|
|
|
- Allow `-Wno-gnu` to silence GNU extension diagnostics for pointer arithmetic
|
|
|
|
diagnostics. Fixes `Issue 54444 <https://github.com/llvm/llvm-project/issues/54444>`_.
|
2022-03-20 01:26:02 +08:00
|
|
|
- Placeholder constraints, as in `Concept auto x = f();`, were not checked when modifiers
|
|
|
|
like ``auto&`` or ``auto**`` were added. These constraints are now checked.
|
|
|
|
This fixes `Issue 53911 <https://github.com/llvm/llvm-project/issues/53911>`_
|
|
|
|
and `Issue 54443 <https://github.com/llvm/llvm-project/issues/54443>`_.
|
2022-03-23 09:12:05 +08:00
|
|
|
- Previously invalid member variables with template parameters would crash clang.
|
|
|
|
Now fixed by setting identifiers for them.
|
|
|
|
This fixes `Issue 28475 (PR28101) <https://github.com/llvm/llvm-project/issues/28475>`_.
|
2022-03-24 01:24:53 +08:00
|
|
|
- Now allow the `restrict` and `_Atomic` qualifiers to be used in conjunction
|
|
|
|
with `__auto_type` to match the behavior in GCC. This fixes
|
|
|
|
`Issue 53652 <https://github.com/llvm/llvm-project/issues/53652>`_.
|
2022-03-24 22:38:37 +08:00
|
|
|
- No longer crash when specifying a variably-modified parameter type in a
|
|
|
|
function with the ``naked`` attribute. This fixes
|
|
|
|
`Issue 50541 <https://github.com/llvm/llvm-project/issues/50541>`_.
|
2022-03-25 08:11:54 +08:00
|
|
|
- Allow multiple ``#pragma weak`` directives to name the same undeclared (if an
|
|
|
|
alias, target) identifier instead of only processing one such ``#pragma weak``
|
|
|
|
per identifier.
|
|
|
|
Fixes `Issue 28985 <https://github.com/llvm/llvm-project/issues/28985>`_.
|
2022-03-26 20:01:47 +08:00
|
|
|
- Assignment expressions in C11 and later mode now properly strip the _Atomic
|
|
|
|
qualifier when determining the type of the assignment expression. Fixes
|
|
|
|
`Issue 48742 <https://github.com/llvm/llvm-project/issues/48742>`_.
|
2022-03-13 03:49:01 +08:00
|
|
|
- Unevaluated lambdas in dependant contexts no longer result in clang crashing.
|
2022-03-26 02:34:16 +08:00
|
|
|
This fixes Issues `50376 <https://github.com/llvm/llvm-project/issues/50376>`_,
|
|
|
|
`51414 <https://github.com/llvm/llvm-project/issues/51414>`_,
|
|
|
|
`51416 <https://github.com/llvm/llvm-project/issues/51416>`_,
|
|
|
|
and `51641 <https://github.com/llvm/llvm-project/issues/51641>`_.
|
2022-03-13 03:49:01 +08:00
|
|
|
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Improvements to Clang's diagnostics
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
2022-03-17 19:40:03 +08:00
|
|
|
- ``-Wliteral-range`` will warn on floating-point equality comparisons with
|
|
|
|
constants that are not representable in a casted value. For example,
|
|
|
|
``(float) f == 0.1`` is always false.
|
2022-03-24 05:27:35 +08:00
|
|
|
- ``-Winline-namespace-reopened-noninline`` now takes into account that the
|
|
|
|
``inline`` keyword must appear on the original but not necessarily all
|
|
|
|
extension definitions of an inline namespace and therefore points its note
|
|
|
|
at the original definition. This fixes `Issue 50794 (PR51452)
|
|
|
|
<https://github.com/llvm/llvm-project/issues/50794>`_.
|
2022-03-25 17:45:08 +08:00
|
|
|
- ``-Wunused-but-set-variable`` now also warns if the variable is only used
|
|
|
|
by unary operators.
|
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-03-25 03:09:10 +08:00
|
|
|
- The builtin function __builtin_dump_struct would crash clang when the target
|
|
|
|
struct have bitfield. Now it fixed, and __builtin_dump_struct support dump
|
|
|
|
the bitwidth of bitfields.
|
|
|
|
This fixes `Issue 54462 <https://github.com/llvm/llvm-project/issues/54462>`_.
|
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
|
|
|
|
--------------------------
|
|
|
|
|
2022-02-09 02:27:52 +08:00
|
|
|
- Added support for parameter pack expansion in `clang::annotate`.
|
|
|
|
|
2022-02-14 21:53:36 +08:00
|
|
|
- The ``overloadable`` attribute can now be written in all of the syntactic
|
2022-02-11 15:27:33 +08:00
|
|
|
locations a declaration attribute may appear.
|
2022-02-23 01:50:39 +08:00
|
|
|
This fixes `Issue 53805 <https://github.com/llvm/llvm-project/issues/53805>`_.
|
2022-02-14 21:53:36 +08:00
|
|
|
|
2022-03-16 02:46:54 +08:00
|
|
|
- Improved namespace attributes handling:
|
2022-03-16 05:08:54 +08:00
|
|
|
|
2022-03-16 02:46:54 +08:00
|
|
|
- Handle GNU attributes before a namespace identifier and subsequent
|
|
|
|
attributes of different kinds.
|
|
|
|
- Emit error on GNU attributes for a nested namespace definition.
|
|
|
|
|
2022-03-17 23:28:37 +08:00
|
|
|
- Statement attributes ``[[clang::noinline]]`` and ``[[clang::always_inline]]``
|
|
|
|
can be used to control inlining decisions at callsites.
|
|
|
|
|
2022-03-09 06:45:28 +08:00
|
|
|
- ``#pragma clang attribute push`` now supports multiple attributes within a single directive.
|
|
|
|
|
2022-03-24 23:51:31 +08:00
|
|
|
- The ``__declspec(naked)`` attribute can no longer be written on a member
|
|
|
|
function in Microsoft compatibility mode, matching the behavior of cl.exe.
|
|
|
|
|
2022-03-25 03:09:10 +08:00
|
|
|
- Improve __builtin_dump_struct:
|
|
|
|
|
|
|
|
- Support bitfields in struct and union.
|
|
|
|
|
|
|
|
- Improve the dump format, dump both bitwidth(if its a bitfield) and field value.
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Windows Support
|
|
|
|
---------------
|
|
|
|
|
2022-02-11 07:10:48 +08:00
|
|
|
- Add support for MSVC-compatible ``/JMC``/``/JMC-`` flag in clang-cl (supports
|
|
|
|
X86/X64/ARM/ARM64). ``/JMC`` could only be used when ``/Zi`` or ``/Z7`` is
|
|
|
|
turned on. With this addition, clang-cl can be used in Visual Studio for the
|
|
|
|
JustMyCode feature. Note, you may need to manually add ``/JMC`` as additional
|
|
|
|
compile options in the Visual Studio since it currently assumes clang-cl does not support ``/JMC``.
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
C Language Changes in Clang
|
|
|
|
---------------------------
|
|
|
|
|
2022-02-14 22:33:48 +08:00
|
|
|
C2x Feature Support
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
- Implemented `WG14 N2674 The noreturn attribute <http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2764.pdf>`_.
|
2022-02-21 20:25:04 +08:00
|
|
|
- Implemented `WG14 N2935 Make false and true first-class language features <http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2935.pdf>`_.
|
2022-03-14 21:22:37 +08:00
|
|
|
- Implemented `WG14 N2763 Adding a fundamental type for N-bit integers <http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2763.pdf>`_.
|
|
|
|
- Implemented `WG14 N2775 Literal suffixes for bit-precise integers <http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2775.pdf>`_.
|
2022-03-23 19:39:53 +08:00
|
|
|
- Implemented the `*_WIDTH` macros to complete support for
|
|
|
|
`WG14 N2412 Two's complement sign representation for C2x <https://www9.open-std.org/jtc1/sc22/wg14/www/docs/n2412.pdf>`_.
|
2022-02-14 22:33:48 +08:00
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
C++ Language Changes in Clang
|
|
|
|
-----------------------------
|
|
|
|
|
2020-07-15 17:40:53 +08:00
|
|
|
- ...
|
2020-02-14 05:46:33 +08:00
|
|
|
|
2021-04-14 19:18:23 +08:00
|
|
|
C++20 Feature Support
|
|
|
|
^^^^^^^^^^^^^^^^^^^^^
|
2022-03-08 23:09:16 +08:00
|
|
|
- Diagnose consteval and constexpr issues that happen at namespace scope. This
|
|
|
|
partially addresses `Issue 51593 <https://github.com/llvm/llvm-project/issues/51593>`_.
|
2022-03-29 02:46:14 +08:00
|
|
|
- No longer attempt to evaluate a consteval UDL function call at runtime when
|
|
|
|
it is called through a template instantiation. This fixes
|
|
|
|
`Issue 54578 <https://github.com/llvm/llvm-project/issues/54578>`_.
|
2022-01-19 02:40:47 +08:00
|
|
|
|
[Clang] Implement __builtin_source_location.
This builtin returns the address of a global instance of the
`std::source_location::__impl` type, which must be defined (with an
appropriate shape) before calling the builtin.
It will be used to implement std::source_location in libc++ in a
future change. The builtin is compatible with GCC's implementation,
and libstdc++'s usage. An intentional divergence is that GCC declares
the builtin's return type to be `const void*` (for
ease-of-implementation reasons), while Clang uses the actual type,
`const std::source_location::__impl*`.
In order to support this new functionality, I've also added a new
'UnnamedGlobalConstantDecl'. This artificial Decl is modeled after
MSGuidDecl, and is used to represent a generic concept of an lvalue
constant with global scope, deduplicated by its value. It's possible
that MSGuidDecl itself, or some of the other similar sorts of things
in Clang might be able to be refactored onto this more-generic
concept, but there's enough special-case weirdness in MSGuidDecl that
I gave up attempting to share code there, at least for now.
Finally, for compatibility with libstdc++'s <source_location> header,
I've added a second exception to the "cannot cast from void* to T* in
constant evaluation" rule. This seems a bit distasteful, but feels
like the best available option.
Reviewers: aaron.ballman, erichkeane
Differential Revision: https://reviews.llvm.org/D120159
2022-03-29 06:27:18 +08:00
|
|
|
- Implemented `__builtin_source_location()` which enables library support for std::source_location.
|
|
|
|
|
2021-04-14 19:18:23 +08:00
|
|
|
C++2b Feature Support
|
2020-02-14 05:46:33 +08:00
|
|
|
^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
|
2022-02-09 01:09:03 +08:00
|
|
|
- Implemented `P2128R6: Multidimensional subscript operator <https://wg21.link/P2128R6>`_.
|
2022-03-01 09:17:49 +08:00
|
|
|
- Implemented `P0849R8: auto(x): decay-copy in the language <https://wg21.link/P0849R8>`_.
|
2021-10-06 05:33:31 +08:00
|
|
|
- Implemented `P2242R3: Non-literal variables (and labels and gotos) in constexpr functions <https://wg21.link/P2242R3>`_.
|
2022-02-09 01:09:03 +08:00
|
|
|
|
2021-08-18 05:39:58 +08:00
|
|
|
CUDA Language Changes in Clang
|
2021-08-24 04:45:13 +08:00
|
|
|
------------------------------
|
2021-08-18 05:39:58 +08:00
|
|
|
|
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-02-03 02:06:55 +08:00
|
|
|
- ``clang-nvlink-wrapper`` tool introduced to support linking of cubin files
|
|
|
|
archived in an archive. See :doc:`ClangNvlinkWrapper`.
|
|
|
|
- ``clang-linker-wrapper`` tool introduced to support linking using a new OpenMP
|
|
|
|
target offloading method. See :doc:`ClangLinkerWrapper`.
|
|
|
|
- Support for a new driver for OpenMP target offloading has been added as an
|
|
|
|
opt-in feature. The new driver can be selected using ``-fopenmp-new-driver``
|
|
|
|
with clang. Device-side LTO can also be enabled using the new driver by
|
|
|
|
passing ``-foffload-lto=`` as well. The new driver supports the following
|
|
|
|
features:
|
|
|
|
- Linking AMDGPU and NVPTX offloading targets.
|
|
|
|
- Static linking using archive files.
|
|
|
|
- Device-side LTO.
|
|
|
|
|
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-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
|
|
|
|
--------------------------------
|
|
|
|
|
2022-03-23 18:51:08 +08:00
|
|
|
- When using ``-mbranch-protection=bti`` with AArch64, calls to setjmp will
|
|
|
|
now be followed by a BTI instruction. This is done to be compatible with
|
|
|
|
setjmp implementations that return with a br instead of a ret. You can
|
|
|
|
disable this behaviour using the ``-mno-bti-at-return-twice`` option.
|
|
|
|
|
2021-11-09 22:35:25 +08:00
|
|
|
Floating Point Support in Clang
|
|
|
|
-------------------------------
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Internal API Changes
|
|
|
|
--------------------
|
|
|
|
|
2022-02-09 02:27:52 +08:00
|
|
|
- Added a new attribute flag `AcceptsExprPack` that when set allows expression
|
|
|
|
pack expansions in the parsed arguments of the corresponding attribute.
|
|
|
|
Additionally it introduces delaying of attribute arguments, adding common
|
|
|
|
handling for creating attributes that cannot be fully initialized prior to
|
|
|
|
template instantiation.
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
Build System Changes
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
AST Matchers
|
|
|
|
------------
|
|
|
|
|
2022-02-23 16:33:58 +08:00
|
|
|
- Expanded ``isInline`` narrowing matcher to support c++17 inline variables.
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
clang-format
|
|
|
|
------------
|
|
|
|
|
2021-11-06 04:10:09 +08:00
|
|
|
- **Important change**: Renamed ``IndentRequires`` to ``IndentRequiresClause``
|
|
|
|
and changed the default for all styles from ``false`` to ``true``.
|
|
|
|
|
|
|
|
- Reworked and improved handling of concepts and requires. Added the
|
|
|
|
``RequiresClausePosition`` option as part of that.
|
|
|
|
|
|
|
|
- Changed ``BreakBeforeConceptDeclarations`` from ``Boolean`` to an enum.
|
|
|
|
|
2022-02-08 14:58:50 +08:00
|
|
|
- Option ``InsertBraces`` has been added to insert optional braces after control
|
|
|
|
statements.
|
|
|
|
|
2020-02-14 05:46:33 +08:00
|
|
|
libclang
|
|
|
|
--------
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
|
|
|
Static Analyzer
|
|
|
|
---------------
|
|
|
|
|
|
|
|
- ...
|
|
|
|
|
|
|
|
.. _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
|
|
|
|
contact us via the `mailing
|
|
|
|
list <https://lists.llvm.org/mailman/listinfo/cfe-dev>`_.
|