Intel® Fortran Compiler 16.0 User and Reference Guide

ftrapuv, Qtrapuv

Initializes stack local variables to an unusual value to aid error detection.

Syntax

Linux and OS X:

-ftrapuv

Windows:

/Qtrapuv

Arguments

None

Default

OFF

The compiler does not initialize local variables.

Description

This option initializes stack local variables to an unusual value to aid error detection. Normally, these local variables should be initialized in the application. It also unmasks the floating-point invalid exception.

The option sets any uninitialized local variables that are allocated on the stack to a value that is typically interpreted as a very large integer or an invalid address. References to these variables are then likely to cause run-time errors that can help you detect coding errors.

This option sets option -g (Linux* OS and OS X*) and /Zi or /Z7 (Windows* OS), which changes the default optimization level from O2 to -O0 (Linux OS and OS X) or /Od (Windows OS). You can override this effect by explicitly specifying an O option setting.

This option sets option [Q]init snan.

If option O2 and option -ftrapuv (Linux OS and OS X) or /Qtrapuv (Windows OS) are used together, you should specify option -fp-speculation safe (Linux OS and OS X) or /Qfp-speculation:safe (Windows OS) to prevent exceptions resulting from speculated floating-point operations from being trapped.

For more details on using options -ftrapuv and /Qtrapuv with compiler option O, see the article in Intel® Developer Zone titled Don't optimize when using -ftrapuv for uninitialized variable detection.

Another way to detect uninitialized local scalar variables is by specifying keyword uninit for option check.

IDE Equivalent

Visual Studio: Data > Initialize stack variables to an unusual value

Eclipse: None

Xcode: Run-Time > Initialize Stack Variables to an Unusual Value

Alternate Options

None

See Also