From 3e6da7e0dc7f264578203315272721919023a1b1 Mon Sep 17 00:00:00 2001 From: Nadav Rotem Date: Wed, 19 Dec 2012 18:02:36 +0000 Subject: [PATCH] DOC: document the use of O2, O3 and Os with -fvectorize. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170567 91177308-0d34-0410-b5e6-96231b3b80d8 --- docs/Vectorizers.rst | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/docs/Vectorizers.rst b/docs/Vectorizers.rst index 84fef67845a..9507fd6953b 100644 --- a/docs/Vectorizers.rst +++ b/docs/Vectorizers.rst @@ -18,7 +18,11 @@ command line flag: .. code-block:: console - $ clang -fvectorize file.c + $ clang -fvectorize -O3 file.c + +If the ``-fvectorize`` flag is used then the loop vectorizer will be enabled +when running with ``-O3``, ``-O2``. When ``-Os`` is used, the loop vectorizer +will only vectorize loops that do not require a major increase in code size. We plan to enable the Loop Vectorizer by default as part of the LLVM 3.3 release. @@ -194,7 +198,7 @@ Performance This section shows the the execution time of Clang on a simple benchmark: `gcc-loops `_. This benchmarks is a collection of loops from the GCC autovectorization -`page `_ by Dorit Nuzman._ +`page `_ by Dorit Nuzman. The chart below compares GCC-4.7, ICC-13, and Clang-SVN at -O3, running on a Sandybridge. The Y-axis shows time in msec. Lower is better.