1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-22 02:33:06 +01:00

[LangRef] Introduce noundef attribute for fully defined function params

LLVM currently does not require function parameters or return values
to be fully initialized, and does not care if they are poison. This can
be useful if the frontend ABI makes no such demands, but may prevent
helpful backend transformations in case they do. Specifically, the C
and C++ languages require all scalar function operands to be fully
determined.

Introducing this attribute is of particular use to MemorySanitizer
today, although other transformations may benefit from it as well.
We can modify MemorySanitizer instrumentation to provide modest (17%)
space savings where `frozen` is present.

This commit only adds the attribute to the Language Reference, and
the actual implementation of the attribute will follow in a separate
commit.

Differential Revision: https://reviews.llvm.org/D82316
This commit is contained in:
Gui Andrade 2020-06-22 16:49:41 +00:00
parent 5c273e628c
commit 905f645c80
2 changed files with 12 additions and 0 deletions

View File

@ -1067,6 +1067,7 @@ The integer codes are mapped to well-known attributes as follows.
* code 65: ``preallocated``
* code 66: ``no_merge``
* code 67: ``null_pointer_is_valid``
* code 68: ``noundef``
.. note::
The ``allocsize`` attribute has a special encoding for its arguments. Its two

View File

@ -1252,6 +1252,12 @@ Currently, only the following parameter attributes are defined:
only valid on intrinsic declarations and cannot be applied to a
call site or arbitrary function.
``noundef``
This attribute applies to parameters and return values. If the value
representation contains any undefined or poison bits, the behavior is
undefined. Note that this does not refer to padding introduced by the
type's storage representation.
.. _gc:
Garbage Collector Strategy Names
@ -3657,6 +3663,11 @@ behavior. Notably this includes (but is not limited to):
- The condition operand of a :ref:`br <i_br>` instruction.
- The callee operand of a :ref:`call <i_call>` or :ref:`invoke <i_invoke>`
instruction.
- The parameter operand of a :ref:`call <i_call>` or :ref:`invoke <i_invoke>`
instruction, when the function or invoking call site has a ``noundef``
attribute in the corresponding position.
- The operand of a :ref:`ret <i_ret>` instruction if the function or invoking
call site has a `noundef` attribute in the return value position.
Here are some examples: