Last updated: 8-Apr-2008
This flags disclosure file describes the compiler flags associated with the following Intel compilers:
icc invokes the Intel C++ compiler . It is invoked as:
icc [ options ] file1 [ file2 ... ]
where,
Invoking the compiler using icc compiles .c and .i files as C. Using icc only links in C++ libraries if C++ source is provided on the command line.
The icpc command uses the same compiler options as the icc command. Invoking the compiler using icpc compiles .c, and .i files as C++. Using icpc always links in C++ libraries.
SPEC_CPU_MACOSX indicates that that OS has the malloc.h header file.
Portability changes for MacOS X
This flag can be set for SPEC compilation for MacOS X using default compiler.
This option causes the Intel-provided libraries to be linked in statically. It is the opposite of -shared-intel. Note that when this option is provided, libguide is also linked in statically.
The -fast option enhances execution speed across the entire program by including the following options that can improve run-time performance:
Options set by -fast cannot be overidden, list options separately to change behavior. The options set by -fast may change from release to release.
Enables the compiler to generate runtime control code for effective automatic parallelization
Tells the auto-parallelizer to generated multithreaded code for loops that can be safely executed in parallel. To use this option, you must also use option O2 or O3.
This option causes the Intel-provided libraries to be linked in statically. It is the opposite of -shared-intel. Note that when this option is provided, libguide is also linked in statically.
The -fast option enhances execution speed across the entire program by including the following options that can improve run-time performance:
Options set by -fast cannot be overidden, list options separately to change behavior. The options set by -fast may change from release to release.
Enables the compiler to generate runtime control code for effective automatic parallelization
This section contains descriptions of flags that were included implicitly by other flags, but which do not have a permanent home at SPEC.
The -xT option tells the compiler to generate optimized code for the Intel Core 2 Duo processor family. It can generate SSSE3, SSE3, SSE2, and SSE instructions for the Intel processors.
Enables O2 optimizations plus more aggressive optimizations, such as prefetching, scalar replacement, and loop and memory access transformations.
Enables optimizations for maximum speed, such as:
On IA-32 and Intel EM64T processors, when O3 is used with options -ax or -x (Linux/Mac OSX), the compiler performs more aggressive data dependency analysis than for O2, which may result in longer compilation times.
The O3 optimizations may not cause higher performance unless loop and memory access transformations take place. The optimizations may slow down code in some cases compared to O2 optimizations.
The O3 option is recommended for applications that have loops that heavily use floating-point calculations and process large data sets.
This option enables multi-file interprocedural optimizations that includes:
When you specify this option, the compiler performs inline function expansion for calls to functions defined in separate files.
This option improves precision of floating-point divides. It has a slight impact on speed.
With some optimizations, such as -xN and -xB (Linux) or /QxN and /QxB (Windows), the compiler may change floating-point division computations into multiplication by the reciprocal of the denominator. For example, A/B is computed as A * (1/B) to improve the speed of the computation.
However, sometimes the value produced by this transformation is not as accurate as full IEEE division. When it is important to have fully precise IEEE division, use this option to disable the floating-point division-to-multiplication optimization. The result is more accurate, with some loss of performance.
If you specify -no-prec-div (Linux and Mac OSX), it enables optimizations that give slightly less precise results than full IEEE division. The default is -prec-div.
Code is not relocatable, but external references are relocatable.
Platform settings
The system under test is deemed reasonably quiet by turning off the following from the System Preferences panel:
OMP_NUM_THREADS
Sets the maximum number of threads to use for OpenMP* parallel regions if no
other value is specified in the application. This environment variable applies to both
-openmp and -parallel (Linux and Mac OS X).
Example syntax on a Mac OS X system with 8 cores:
export OMP_NUM_THREADS=8
Flag description origin markings:
For questions about the meanings of these flags, please contact the tester.
For other inquiries, please contact webmaster@spec.org
Copyright 2006-2014 Standard Performance Evaluation Corporation
Tested with SPEC CPU2006 v1.0.1.
Report generated on Tue Jul 22 16:40:23 2014 by SPEC CPU2006 flags formatter v6906.