- Building OpenCL ICD Loader documented; Acknowledgments section of Overview updated to mention also OpenGL and OpenCL - Reference to OpenCL updated in Overview: use general statement instead of direct link to AMD SDK. - GeForce 610, 6600, and Radeon HD 7870 added to list of tested graphic cards - Minor syntax corrections in DRAW UG to avoid interferences - Update 3rdparty products up to current state - Redesign of pages - Building OpenCL ICD Loader was documented for Linux platform - Lists reformatted, documentation manual updated to better describe use of lists. - Updating picture of structure of installed OCCT - Updating description of Automake procedure - Updating description of CMake building procedure
14 KiB
Building 3rd-party libraries on Windows
@tableofcontents
@section dev_guides__building_3rdparty_win_1 Introduction
This document presents guidelines for building third-party products used by Open CASCADE Technology (OCCT) and samples on Windows platform.
This guide assumfamiliar with MS Visual Studio / Visual C++.
You need to use the same version of MS Visual Studio for building all third-party products and OCCT itself, in order to receive a consistent set of run-time binaries.
The links for downloading the third-party products are available on the web site of OPEN CASCADE SAS at http://www.opencascade.org/getocc/require/. There are two types of third-party products which are used by OCCT:
- Mandatory products: Tcl/Tk 8.5 - 8.6 and FreeType 2.4.10 - 2.4.11
- Optional products: TBB 3.x - 4.x, gl2ps 1.3.5 - 1.3.8, FreeImage 3.14.1 -3.15.4
It is recommended to create a separate new folder on your workstation where you will unpack the downloaded archives of the third-party products, and where you will build these products (for example, c:\occ3rdparty).
Further in this document, this folder is referred to as 3rdparty.
@section dev_guides__building_3rdparty_win_2 Building Mandatory Third-party Products
@subsection dev_guides__building_3rdparty_win_2_1 Tcl/Tk
Tcl/Tk is required for DRAW test harness.We recommend installing a binary distribution that could be downloaded from http://www.activestate.com/activetcl.
Go to "Free Downloads" and pick the version of the Install Wizard that matches your target platform – 32 bit (x86) or 64 bit (x64). The version of Visual Studio you use is irrelevant when choosing the Install Wizard.
Run the Install Wizard you downloaded, and install Tcl/Tk products
- to 3rdparty\tcltk-win32 folder (for 32-bit platform) or
- to 3rdparty\tcltk-win64 folder (for 64-bit platform).
Further in this document, this folder is referred to as tcltk.
@subsection dev_guides__building_3rdparty_win_2_2 FreeType
FreeType is required for display of text in 3D viewer. You can download its sources from http://sourceforge.net/projects/freetype/files/
The building process is the following:
-
Unpack the downloaded archive of FreeType product into the 3rdparty folder.
As a result, you should have a folder named for example, 3rdparty\freetype-2.4.10. Further in this document, this folder is referred to as freetype.
-
Open the solution file freetype\builds\win32\vc20xx\freetype.sln in Visual Studio, where vc20xx stands for the version of Visual Studio you are using.
-
Select a configuration to build: either Debug or Release.
-
Build the freetype project.
As a result, you will get a freetype import library (.lib) in the freetype\obj\win32\vc20xx folder.
-
If you are building for 64 bit platform, start the Configuration Manager (Build - Configuration Manager), and add x64 platform to the solution configuration by copying the settings from Win32 platform:
@image html /dev_guides/building/3rdparty/images/3rdparty_image001.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image001.png
Update the value of the Output File for x64 configuration:
@image html /dev_guides/building/3rdparty/images/3rdparty_image003.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image003.png
Build the freetype project.
As a result, you should obtain a 64 bit import library (.lib) file in the freetype\x64\vc20xx folder.
If you want to build freetype as a dynamic library (.dll) follow items 6, 7 and 8 of this list.
-
Open Project-Properties-Configuration Properties-General and change option 'Configuration Type' to "Dynamic Library (.dll)".
-
Edit file freetype\include\freetype\config\ftoption.h:
in line 255, uncomment the definition of macro FT_EXPORT and change it as follows:
#define FT_EXPORT(x) __declspec(dllexport) x
-
Build the freetype project.
As a result, you should obtain import library (.lib) and dynamic library (.dll) files in freetype \objs\release or \objs\debug folders. If you are building for a 64 bit platform, follow item 5 of this list.
In order to facilitate use of the FreeType libraries in OCCT with minimal adjustment of its build procedures, it is recommended to copy the include files and libraries of FreeType to a separate folder, named according to the pattern: freetype-compiler-bitness-building mode
where- compiler is vc8 or vc9 or vc10 or vc11;
- bitness is 32 or 64;
- building mode is opt (for Release) or deb (for Debug)
The include subfolder should be copied as is, while libraries should be renamed to freetype.lib and freetype.dll (suffixes removed) and placed to subdirectories *lib *and bin, respectively. If Debug configuration is built, the Debug libraries should be put in subdirectories libd and bind.
@section dev_guides__building_3rdparty_win_3 Building Optional Third-party Products
@subsection dev_guides__building_3rdparty_win_3_1 TBB
This third-party product is installed with binaries from the archive that can be downloaded from http://threadingbuildingblocks.org/. Go to "Downloads page", find the release version you need (e.g. tbb30_018oss) and pick the archive for Windows platform. Unpack the downloaded archive of TBB product into the 3rdparty folder. Further in this document, this folder is referred to as tbb.
@subsection dev_guides__building_3rdparty_win_3_2 gl2ps
This third-party product should be built as a dynamically loadable library (dll file). You can download its sources from http://geuz.org/gl2ps/src/
The building process is the following:
-
Unpack the downloaded archive of gl2ps product (e.g. gl2ps-1.3.5.tgz) into the 3rdparty folder.
As a result, you should have a folder named for example, 3rdparty\gl2ps-1.3.5-source.
Rename it according to the rule: gl2ps-platform-compiler-building mode, where
- platform is win32 or win64;
- compiler is vc8 or vc9 or vc10;
- building mode - opt (for release) or deb (for debug)
Further in this document, this folder is referred to as gl2ps.
-
Download (from http://www.cmake.org/cmake/resources/software.html) and install the CMake build system.
-
Edit the file gl2ps\CMakeLists.txt.
After line 113 in CMakeLists.txt:
set_target_properties(shared PROPERTIES COMPILE_FLAGS \"-DGL2PSDLL -DGL2PSDLL_EXPORTS\")
add the following line:
add_definitions(-D_USE_MATH_DEFINES)
Attention: If cygwin was installed on your computer make sure that there is no path to the latter in the PATH variable in order to avoid possible conflicts during the configuration.
-
Launch CMake (cmake-gui.exe) using the Program menu.
In CMake:
-
Define where the source code is. This path must point to gl2ps folder.
-
Define where to build the binaries. This path must point to the folder where generated gl2ps project binaries will be placed (for example, gl2ps\bin). Further in this document, this folder is referred to as gl2ps_bin.
-
Press the "Configure" button. @image html /dev_guides/building/3rdparty/images/3rdparty_image004.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image004.png
-
Select the generator (the compiler and the target platform - 32 or 64 bit) in the pop-up window. @image html /dev_guides/building/3rdparty/images/3rdparty_image005.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image005.png
-
Then press the "Finish" button to return to the main CMake window. Expand the ENABLE group and uncheck ENABLE_PNG and ENABLE_ZLIB check boxes. @image html /dev_guides/building/3rdparty/images/3rdparty_image006.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image006.png
-
Expand the CMAKE group and define CMAKE_INSTALL_PREFIX (path where you want to install the build results, for example, c:\occ3rdparty\gl2ps-1.3.5). @image html /dev_guides/building/3rdparty/images/3rdparty_image007.png @image latex /dev_guides/building/3rdparty/images/3rdparty_image007.png
-
Press the "Configure" button again, and then the "Generate" button in order to generate Visual Studio projects. After completion, close CMake application.
-
-
Open the solution file gl2ps_bin\gl2ps.sln in Visual Studio.
- Select a configuration to build
- Choose "Release" if you are building Release binaries.
- Choose "Debug" if you are building Debug binaries.
- Select a platform to build.
- Choose "Win32" if you are building for a 32 bit platform.
- Choose "x64" if you are building for a 64 bit platform.
- Build the solution.
- Build the INSTALL project.
- Select a configuration to build
As a result, you should have the installed gl2ps product in the CMAKE_INSTALL_PREFIX path.
@subsection dev_guides__building_3rdparty_win_3_3 FreeImage
This third-party product should be built as a dynamically loadable library (.dll file). You can download its sources from http://sourceforge.net/projects/freeimage/files/Source%20Distribution/
The building process is the following:
-
Unpack the downloaded archive of FreeImage product into 3rdparty folder.
As a result, you should have a folder named 3rdparty\FreeImage.
Rename it according to the rule: freeimage-platform-compiler-building mode, where
- platform is win32 or win64;
- compiler is vc8 or vc9 or vc10 or vc11;
- building mode is opt (for release) or deb (for debug)
Further in this document, this folder is referred to as freeimage.
-
Open the solution file freeimage\FreeImage..sln* in Visual Studio that corresponds to the version of Visual Studio you use.
Since the version of Visual Studio you use is higher than VC++ 2008, apply conversion of the workspace. Such conversion should be suggested automatically by Visual Studio.
-
Select a configuration to build.
- Choose " Release " if you are building Release binaries.
- Choose " Debug " if you are building Debug binaries.
Note:
If you want to build a debug version of FreeImage binaries then you must rename the following files for projects FreeImage and FreeimagePlus:
Project-Properties-Configuration Properties-Linker-General-Output File
from FreeImage*d*.dll to FreeImage.dll from FreeImagePlus*d*.dll to FreeImagePlus.dll
Project-Properties-Configuration Properties-Linker-Debugging-Generate Program Database File
from FreeImage*d*.pdb to FreeImage.pdb from FreeImagePlus*d*.pdb to FreeImagePlus.pdb
Project-Properties-Configuration Properties-Linker-Advanced-Import Library
from FreeImage*d*.lib to FreeImage.lib from FreeImagePlus*d*.lib to FreeImagePlus.lib
Project-Properties-Configuration Properties-Build Events-Post-Build Event-Comand Line
from FreeImage*d*.dll to FreeImage.dll from FreeImage*d*.lib to FreeImage.lib from FreeImagePlus*d*.dll to FreeImagePlus.dll from FreeImagePlus*d*.lib to FreeImagePlus.lib
Additionally, for project FreeImagePlus rename: Project-Properties-Configuration Properties-Linker-Input-Additional Dependencies
from FreeImage*d*.lib to FreeImage.lib
-
Select a platform to build.
- Choose " Win32 " if you are building for a 32 bit platform.
- Choose " x64 " if you are building for a 64 bit platform.
-
Start the building process.
As a result, you should have the library files of FreeImage product in the freeimage\Dist folder (FreeImage.dll and FreeImage.lib files) and in the freeimage\Wrapper\FreeImagePlus\dist folder (FreeImagePlus.dll and FreeImagePlus.lib files).
@subsection dev_guides__building_3rdparty_win_opencl OpenCL ICD Loader
If you have OpenCL SDK (one provided by Apple, AMD, NVIDIA, Intel, or other vendor) installed on your system, you should find OpenCL headers and libraries required for building OCCT inside that SDK.
Alternatively, you can use OpenCL ICD (Installable Client Driver) Loader provided by Khronos group. The following describes steps used to build OpenCL ICD Loader version 1.2.11.0.
-
Download OpenCL ICD Loader sources archive and OpenCL header files from Khronos OpenCL Registry http://www.khronos.org/registry/cl/
-
Unpack the archive and put headers in inc/CL sub-folder
-
Use CMake to generate VS projects for building the library:
- Start CMake-GUI and select OpenCL ICD Loader folder as source path, and the folder of your choice for VS project and intermediate build data
- Click Generate
- Select VS version to be used (among the one you have installed; we recommend using VS 2010), and architecture (32- or 64-bit)
-
Open solution OPENCL_ICD_LOADER.sln generated in the build folder. Though not strictly necessary, we recommend making two changes in generated projects:
- Add file OpenCL.rc to project OpenCL, to have version and Khronos copyright correctly embedded in DLL
- In properties of OpenCL project, on "C/C++ / Code Generation" page, for Release configuration, change "Runtime library" to "Multi-threaded (/MT)", to avoid dependency on run-time DLL.
-
Build project OpenCL in Release mode
-
Create installation folder for OpenCL IDL Loader package and put there:
- OpenCL header files in include/CL subfolder
- OpenCL.dll (generated in bin/Release subfolder of source package) in bin subfolder
- OpenCL.lib (generated in Release subfolder of build directory) in lib subfolder