------------------------------------------------------------------------ Intel(R) Threading Building Blocks - Release Notes Version 4.3 ------------------------------------------------------------------------ System Requirements ------------------- Intel(R) Threading Building Blocks (Intel(R) TBB) is available commercially (see http://software.intel.com/en-us/intel-tbb) as a binary distribution, and in open source, in both source and binary forms (see http://threadingbuildingblocks.org). When built from source, Intel(R) TBB is intended to be highly portable and so supports a wide variety of operating systems and platforms (see http://threadingbuildingblocks.org for more details). Binary distributions, including commercial distributions, are validated and officially supported for the hardware, software, operating systems and compilers listed here. Hardware - Recommended Microsoft* Windows* Systems Intel(R) Core(TM) 2 Duo processor or Intel(R) Xeon(R) processor or higher Linux* Systems Intel(R) Core(TM) 2 Duo processor or Intel(R) Xeon(R) processor or higher Intel(R) Xeon Phi(TM) coprocessor OS X* Systems Intel(R) Core(TM) 2 Duo processor or higher Hardware - Supported Intel(R) Pentium(R) 4 processor family and higher Intel(R) Xeon Phi(TM) coprocessor Non Intel(R) processors compatible with the above processors Software - Minimum Requirements Supported operating system (see below) Supported compiler (see below) Software - Recommended Intel(R) Parallel Studio XE 2013 SP1 Intel(R) Parallel Studio XE 2015 Professional Edition Software - Supported Operating Systems Systems with Microsoft* Windows* operating systems Microsoft* Windows* 8, 8.1 Microsoft* Windows* 7 SP1 Microsoft* Windows* Server 2012 Microsoft* Windows* Server 2008 SP2 (IA-32 only) Microsoft* Windows* Server 2008 R2 SP1 Microsoft* Windows* HPC Server 2008 Systems with Linux* operating systems Red Hat* Enterprise Linux* 5, 6, 7 Fedora* 20 Debian* 6.0, 7 Ubuntu* 12.04 LTS, 14.04 LTS Ubuntu* 13.10 SuSE* Linux* Enterprise Server 11 Intel(R) Cluster Ready Systems with OS X* operating systems OS X* 10.9 and higher Software - Supported Compilers Intel(R) C++ Compiler 13.1 (Intel(R) Parallel Studio XE 2013 SP1) and higher Microsoft* Visual C++ 10.0 (Microsoft* Visual Studio* 2010, Windows* OS only) and higher For each supported Linux* operating system, the standard gcc version provided with that operating system is supported, including gcc 4.1 through 4.8.2 Xcode* 5.0 and higher and command line tools (OS X* only) Known Issues ------------ Please note the following with respect to this particular release of Intel(R) Threading Building Blocks. Library Issues - If an application uses static version of MSVCRT libraries or uses Intel TBB DLL built with static MSVCRT (vc_mt variant), and throws an exception from a functor passed to task_group::run_and_wait(), the exception will not be intercepted by Intel TBB and will not result in cancellation of the task_group. For a workaround, catch the exception in the functor and explicitly cancel the task_group. - The debug version of Intel TBB DLL built with static MSVCRT (vc_mt/tbb_debug.dll) additionally requires Microsoft* Visual C++ 10.0 debug library (msvcp100d.dll) in order to run. - If you are using Intel(R) Threading Building Blocks and OpenMP* constructs mixed together in rapid succession in the same program, and you are using Intel(R) compilers for your OpenMP* code, set KMP_BLOCKTIME to a small value (e.g., 20 milliseconds) to improve performance. This setting can also be made within your OpenMP* code via the kmp_set_blocktime() library call. See the Intel(R) compiler OpenMP* documentation for more details on KMP_BLOCKTIME and kmp_set_blocktime(). - In general, non-debug ("release") builds of applications or examples should link against the non-debug versions of the Intel(R) Threading Building Blocks libraries, and debug builds should link against the debug versions of these libraries. On Windows* OS, compile with /MD and use Intel(R) Threading Building Blocks release libraries, or compile with /MDd and use debug libraries; not doing so may cause run-time failures. See the Tutorial in the product "doc" sub-directory for more details on debug vs. release libraries. - If an open source version installed to the system folders like /usr/lib64 on Linux OS, examples may fail to link because sometimes gcc searches for folders in unexpected order. To resolve this, use the -L command line linker option needs to be used to set the right location. This does not affect a program execution. - Running applications linked with Intel(R) Threading Building Blocks version 4.0 U5 or higher under Intel(R) Graphics Performance Analyzers is not supported. - If an application that uses dynamic memory allocator replacement via LD_PRELOAD is analyzed with Intel(R) VTune(TM) Amplifier XE for Linux, the analysis may fail to start. For a workaround, either specify the full path to both libtbbmalloc_proxy.so.2 and libtbbmalloc.so.2 in LD_PRELOAD, or set up a Intel(R) VTune(TM) Amplifier XE project to use a shell script that sets LD_PRELOAD and starts the application. - If your application includes tbb/enumerable_thread_specific.h (or tbb/tbb.h) for offload execution on an Intel(R) Xeon Phi(TM) coprocessor, you may see link issues related to libpthread. To resolve this issue, add the /Qoffload-option,mic,compiler,"-pthread" compiler switch to the command line on Windows* OS (or -qoffload-option,mic,compiler,"-pthread" on Linux* OS). ------------------------------------------------------------------------ Copyright (C) 2005-2015 Intel Corporation. All Rights Reserved. Intel, Xeon and Pentium are registered trademarks or trademarks of Intel Corporation or its subsidiaries in the United States and other countries. * Other names and brands may be claimed as the property of others. Third Party and Open Source Licenses Content of some examples or binaries may be covered by various open-source licenses. See the index.html file in each respective folder for details.