[LangRef] Update description of Constant Expressions

Summary:
When describing trunc/zext/sext/ptrtoint/inttoptr in the chapter
about Constant Expressions we now simply refer to the Instruction
Reference. As far as I know there are no difference when it comes
to the semantics and the argument constraints. The only difference
is that the syntax is slighly different for the constant expressions,
regarding the use of parenthesis in constant expressions.
Referring to the Instruction Reference is the same solution as
already used for several other operations, such as bitcast.

The main goal was to add information that vector types are allowed
also in trunc/zext/sext/ptrtoint/inttoptr constant expressions.
That was not explicitly mentioned earlier, and resulted in some
questions in the review of https://reviews.llvm.org/D38546

Reviewers: efriedma, majnemer

Reviewed By: efriedma

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D39165

llvm-svn: 316429
This commit is contained in:
Bjorn Pettersson 2017-10-24 11:59:20 +00:00
parent a17480d602
commit e1285e3cdf
1 changed files with 16 additions and 18 deletions

View File

@ -3162,14 +3162,11 @@ that does not have side effects (e.g. load and call are not supported).
The following is the syntax for constant expressions:
``trunc (CST to TYPE)``
Truncate a constant to another type. The bit size of CST must be
larger than the bit size of TYPE. Both types must be integers.
Perform the :ref:`trunc operation <i_trunc>` on constants.
``zext (CST to TYPE)``
Zero extend a constant to another type. The bit size of CST must be
smaller than the bit size of TYPE. Both types must be integers.
Perform the :ref:`zext operation <i_zext>` on constants.
``sext (CST to TYPE)``
Sign extend a constant to another type. The bit size of CST must be
smaller than the bit size of TYPE. Both types must be integers.
Perform the :ref:`sext operation <i_sext>` on constants.
``fptrunc (CST to TYPE)``
Truncate a floating point constant to another floating point type.
The size of CST must be larger than the size of TYPE. Both types
@ -3203,19 +3200,14 @@ The following is the syntax for constant expressions:
be scalars, or vectors of the same number of elements. If the value
won't fit in the floating point type, the results are undefined.
``ptrtoint (CST to TYPE)``
Convert a pointer typed constant to the corresponding integer
constant. ``TYPE`` must be an integer type. ``CST`` must be of
pointer type. The ``CST`` value is zero extended, truncated, or
unchanged to make it fit in ``TYPE``.
Perform the :ref:`ptrtoint operation <i_ptrtoint>` on constants.
``inttoptr (CST to TYPE)``
Convert an integer constant to a pointer constant. TYPE must be a
pointer type. CST must be of integer type. The CST value is zero
extended, truncated, or unchanged to make it fit in a pointer size.
Perform the :ref:`inttoptr operation <i_inttoptr>` on constants.
This one is *really* dangerous!
``bitcast (CST to TYPE)``
Convert a constant, CST, to another TYPE. The constraints of the
operands are the same as those for the :ref:`bitcast
instruction <i_bitcast>`.
Convert a constant, CST, to another TYPE.
The constraints of the operands are the same as those for the
:ref:`bitcast instruction <i_bitcast>`.
``addrspacecast (CST to TYPE)``
Convert a constant pointer or constant vector of pointer, CST, to another
TYPE in a different address space. The constraints of the operands are the
@ -3228,9 +3220,9 @@ The following is the syntax for constant expressions:
``select (COND, VAL1, VAL2)``
Perform the :ref:`select operation <i_select>` on constants.
``icmp COND (VAL1, VAL2)``
Performs the :ref:`icmp operation <i_icmp>` on constants.
Perform the :ref:`icmp operation <i_icmp>` on constants.
``fcmp COND (VAL1, VAL2)``
Performs the :ref:`fcmp operation <i_fcmp>` on constants.
Perform the :ref:`fcmp operation <i_fcmp>` on constants.
``extractelement (VAL, IDX)``
Perform the :ref:`extractelement operation <i_extractelement>` on
constants.
@ -8076,6 +8068,8 @@ The instructions in this category are the conversion instructions
(casting) which all take a single operand and a type. They perform
various bit conversions on the operand.
.. _i_trunc:
'``trunc .. to``' Instruction
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
@ -8118,6 +8112,8 @@ Example:
%Z = trunc i32 122 to i1 ; yields i1:false
%W = trunc <2 x i16> <i16 8, i16 7> to <2 x i8> ; yields <i8 8, i8 7>
.. _i_zext:
'``zext .. to``' Instruction
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
@ -8158,6 +8154,8 @@ Example:
%Y = zext i1 true to i32 ; yields i32:1
%Z = zext <2 x i16> <i16 8, i16 7> to <2 x i32> ; yields <i32 8, i32 7>
.. _i_sext:
'``sext .. to``' Instruction
^^^^^^^^^^^^^^^^^^^^^^^^^^^^