r372185 - Revert "Create UsersManual section entitled 'Controlling Floating Point"

Richard Smith via cfe-commits cfe-commits at lists.llvm.org
Tue Sep 17 20:09:35 PDT 2019


On Tue, 17 Sep 2019, 15:25 Erich Keane via cfe-commits, <
cfe-commits at lists.llvm.org> wrote:

> Author: erichkeane
> Date: Tue Sep 17 14:27:07 2019
> New Revision: 372185
>
> URL: http://llvm.org/viewvc/llvm-project?rev=372185&view=rev
> Log:
> Revert "Create UsersManual section entitled 'Controlling Floating Point"
>

When reverting a change, please include a reason for the revert in your
commit message.

This reverts commit a08d5a4b0ebd44dc64f41049ed4e97a3c6d31498.
>
> Modified:
>     cfe/trunk/docs/UsersManual.rst
>
> Modified: cfe/trunk/docs/UsersManual.rst
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/docs/UsersManual.rst?rev=372185&r1=372184&r2=372185&view=diff
>
> ==============================================================================
> --- cfe/trunk/docs/UsersManual.rst (original)
> +++ cfe/trunk/docs/UsersManual.rst Tue Sep 17 14:27:07 2019
> @@ -1128,165 +1128,6 @@ number of cases where the compilation en
>  and the precompiled header cannot be generated after headers have been
>  installed.
>
> -.. _controlling-fp-behavior:
> -
> -Controlling Floating Point Behavior
> ------------------------------------
> -
> -Clang provides a number of ways to control floating point behavior. The
> options
> -are listed below.
> -
> -.. option:: -ffast-math
> -
> -   Enable fast-math mode.  This option lets the
> -   compiler make aggressive, potentially-lossy assumptions about
> -   floating-point math.  These include:
> -
> -   * Floating-point math obeys regular algebraic rules for real numbers
> (e.g.
> -     ``+`` and ``*`` are associative, ``x/y == x * (1/y)``, and
> -     ``(a + b) * c == a * c + b * c``),
> -   * Operands to floating-point operations are not equal to ``NaN`` and
> -     ``Inf``, and
> -   * ``+0`` and ``-0`` are interchangeable.
> -
> -   ``-ffast-math`` also defines the ``__FAST_MATH__`` preprocessor
> -   macro. Some math libraries recognize this macro and change their
> behavior.
> -   With the exception of ``-ffp-contract=fast``, using any of the options
> -   below to disable any of the individual optimizations in ``-ffast-math``
> -   will cause ``__FAST_MATH__`` to no longer be set.
> -
> -  This option implies:
> -
> -   * ``-fno-honor-infinities``
> -
> -   * ``-fno-honor-nans``
> -
> -   * ``-fno-math-errno``
> -
> -   * ``-ffinite-math``
> -
> -   * ``-fassociative-math``
> -
> -   * ``-freciprocal-math``
> -
> -   * ``-fno-signed-zeros``
> -
> -   * ``-fno-trapping-math``
> -
> -   * ``-ffp-contract=fast``
> -
> -.. option:: -fdenormal-fp-math=<value>
> -
> -   Select which denormal numbers the code is permitted to require.
> -
> -   Valid values are:
> -
> -   * ``ieee`` - IEEE 754 denormal numbers
> -   * ``preserve-sign`` - the sign of a flushed-to-zero number is
> preserved in the sign of 0
> -   * ``positive-zero`` - denormals are flushed to positive zero
> -
> -   Defaults to ``ieee``.
> -
> -.. option:: -f[no-]strict-float-cast-overflow
> -
> -   When a floating-point value is not representable in a destination
> integer
> -   type, the code has undefined behavior according to the language
> standard.
> -   By default, Clang will not guarantee any particular result in that
> case.
> -   With the 'no-strict' option, Clang attempts to match the overflowing
> behavior
> -   of the target's native float-to-int conversion instructions.
> -
> -.. option:: -f[no-]math-errno
> -
> -   Require math functions to indicate errors by setting errno.
> -   The default varies by ToolChain.  ``-fno-math-errno`` allows
> optimizations
> -   that might cause standard C math functions to not set ``errno``.
> -   For example, on some systems, the math function ``sqrt`` is specified
> -   as setting ``errno`` to ``EDOM`` when the input is negative. On these
> -   systems, the compiler cannot normally optimize a call to ``sqrt`` to
> use
> -   inline code (e.g. the x86 ``sqrtsd`` instruction) without additional
> -   checking to ensure that ``errno`` is set appropriately.
> -   ``-fno-math-errno`` permits these transformations.
> -
> -   On some targets, math library functions never set ``errno``, and so
> -   ``-fno-math-errno`` is the default. This includes most BSD-derived
> -   systems, including Darwin.
> -
> -.. option:: -f[no-]trapping-math
> -
> -   ``-fno-trapping-math`` allows optimizations that assume that
> -   floating point operations cannot generate traps such as divide-by-zero,
> -   overflow and underflow. Defaults to ``-ftrapping-math``.
> -   Currently this option has no effect.
> -
> -.. option:: -ffp-contract=<value>
> -
> -   Specify when the compiler is permitted to form fused floating-point
> -   operations, such as fused multiply-add (FMA). Fused operations are
> -   permitted to produce more precise results than performing the same
> -   operations separately.
> -
> -   The C standard permits intermediate floating-point results within an
> -   expression to be computed with more precision than their type would
> -   normally allow. This permits operation fusing, and Clang takes
> advantage
> -   of this by default. This behavior can be controlled with the
> -   ``FP_CONTRACT`` pragma. Please refer to the pragma documentation for a
> -   description of how the pragma interacts with this option.
> -
> -   Valid values are:
> -
> -   * ``fast`` (everywhere)
> -   * ``on`` (according to FP_CONTRACT pragma, default)
> -   * ``off`` (never fuse)
> -
> -.. option:: -f[no-]honor-infinities
> -
> -   If both ``-fno-honor-infinities`` and ``-fno-honor-nans`` are used,
> -   has the same effect as specifying ``-ffinite-math``.
> -
> -.. option:: -f[no-]honor-nans
> -
> -   If both ``-fno-honor-infinities`` and ``-fno-honor-nans`` are used,
> -   has the same effect as specifying ``-ffinite-math``.
> -
> -.. option:: -f[no-]signed-zeros
> -
> -   Allow optimizations that ignore the sign of floating point zeros.
> -   Defaults to ``-fno-signed-zeros``.
> -
> -.. option:: -f[no-]associative-math
> -
> -  Allow floating point operations to be reassociated.
> -  Defaults to ``-fno-associative-math``.
> -
> -.. option:: -f[no-]reciprocal-math
> -
> -  Allow division operations to be transformed into multiplication by a
> -  reciprocal. This can be significantly faster than an ordinary division
> -  but can also have significantly less precision. Defaults to
> -  ``-fno-reciprocal-math``.
> -
> -.. option:: -f[no-]unsafe-math-optimizations
> -
> -   Allow unsafe floating-point optimizations. Also implies:
> -
> -   * ``-fassociative-math``
> -   * ``-freciprocal-math``
> -   * ``-fno-signed-zeroes``
> -   * ``-fno-trapping-math``.
> -
> -   Defaults to ``-fno-unsafe-math-optimizations``.
> -
> -.. option:: -f[no-]finite-math
> -
> -   Allow floating-point optimizations that assume arguments and results
> are
> -   not NaNs or +-Inf.  This defines the ``__FINITE_MATH_ONLY__``
> preprocessor macro.
> -   Also implies:
> -
> -   * ``-fno-honor-infinities``
> -   * ``-fno-honor-nans``
> -
> -   Defaults to ``-fno-finite-math``.
> -
>  .. _controlling-code-generation:
>
>  Controlling Code Generation
> @@ -1425,6 +1266,36 @@ are listed below.
>     This enables better devirtualization. Turned off by default, because
> it is
>     still experimental.
>
> +.. option:: -ffast-math
> +
> +   Enable fast-math mode. This defines the ``__FAST_MATH__`` preprocessor
> +   macro, and lets the compiler make aggressive, potentially-lossy
> assumptions
> +   about floating-point math.  These include:
> +
> +   * Floating-point math obeys regular algebraic rules for real numbers
> (e.g.
> +     ``+`` and ``*`` are associative, ``x/y == x * (1/y)``, and
> +     ``(a + b) * c == a * c + b * c``),
> +   * operands to floating-point operations are not equal to ``NaN`` and
> +     ``Inf``, and
> +   * ``+0`` and ``-0`` are interchangeable.
> +
> +.. option:: -fdenormal-fp-math=[values]
> +
> +   Select which denormal numbers the code is permitted to require.
> +
> +   Valid values are: ``ieee``, ``preserve-sign``, and ``positive-zero``,
> +   which correspond to IEEE 754 denormal numbers, the sign of a
> +   flushed-to-zero number is preserved in the sign of 0, denormals are
> +   flushed to positive zero, respectively.
> +
> +.. option:: -f[no-]strict-float-cast-overflow
> +
> +   When a floating-point value is not representable in a destination
> integer
> +   type, the code has undefined behavior according to the language
> standard.
> +   By default, Clang will not guarantee any particular result in that
> case.
> +   With the 'no-strict' option, Clang attempts to match the overflowing
> behavior
> +   of the target's native float-to-int conversion instructions.
> +
>  .. option:: -fwhole-program-vtables
>
>     Enable whole-program vtable optimizations, such as
> single-implementation
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at lists.llvm.org
> https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20190917/902291a5/attachment-0001.html>


More information about the cfe-commits mailing list