= Release notes on the Microsoft Windows ports of OCaml = :toc: macro There are no fewer than three ports of OCaml for Microsoft Windows, each available in 32 and 64-bit versions: - native Windows, built with the Microsoft C/C++ Optimizing Compiler - native Windows, built using the Mingw-w64 version of GCC - Cygwin (http://www.cygwin.com[www.cygwin.com]) Here is a summary of the main differences between these ports: |===== | | Native Microsoft | Native Mingw-w64 | Cygwin 4+^| Third-party software required | for base bytecode system | none | none | none | for ocamlc -custom | Microsoft Visual C++ | Cygwin | Cygwin | for native-code generation | Microsoft Visual C++ | Cygwin | Cygwin 4+^| Features | Speed of bytecode interpreter | 70% | 100% | 100% | Replay debugger | yes <> | yes <> | yes | The Unix library | partial | partial | full | The Threads library | yes | yes | yes | The Graphics library | yes | yes | no | Restrictions on generated executables? | none | none | yes <> |===== [[tb1]] (*):: Cygwin-generated .exe files refer to a DLL that is distributed under the GPL. Thus, these .exe files can only be distributed under a license that is compatible with the GPL. Executables generated by Microsoft Visual C++ or Mingw-w64 have no such restrictions. [[tb2]] (**):: The debugger is supported but the "replay" functions are not enabled. Other functions are available (step, goto, run...). Cygwin aims to provide a Unix-like environment on Windows, and the build procedure for it is the same as for other flavours of Unix. See link:INSTALL.adoc[] for full instructions. The four native Windows ports have to be built differently, and the remainder of this document gives more information. toc::[] == The native Win32 port built with Microsoft Windows SDK === REQUIREMENTS This port runs under MS Windows 7 (32 and 64 bits), Vista, XP, and 2000. The base bytecode system (ocamlc, ocaml, ocamllex, ocamlyacc, ...) runs without any additional tools. The native-code compiler (ocamlopt) requires the Microsoft Windows SDK (item <>) and the flexdll tool (item <>). Statically linking OCaml bytecode with C code (ocamlc -custom) also requires items <> and <>. === INSTALLATION The binary distribution is a self-installing executable archive. Just run it and it should install OCaml automatically. === THIRD-PARTY SOFTWARE [[tps1]] [1]:: Microsoft Windows SDK for Windows 7 and .NET Framework 3.5 Service Pack 1. Can be downloaded for free from http://www.microsoft.com/downloads/en/default.aspx under the name "Microsoft Windows 7 SDK". [[tps2]] [2]:: flexdll version 0.31 or later. Can be downloaded from http://alain.frisch.fr/flexdll.html === RECOMPILATION FROM THE SOURCES The command-line tools can be recompiled from the Unix source distribution (ocaml-X.YY.Z.tar.gz), which also contains the files modified for Windows. You will need the following software components to perform the recompilation: - Windows NT, 2000, XP, Vista, or 7 (32 or 64 bits). - Items <> and <> from the list of recommended software above. - The Cygwin port of GNU tools, available from http://www.cygwin.com/ Install at least the following packages (and their dependencies): diffutils, dos2unix, gcc-core, make, ncurses. First, you need to set up your cygwin environment for using the MS tools. The following assumes that you have installed <>, <>, and [3] in their default directories. If this is not the case, you will need to adjust the paths accordingly. . Open a Windows Command Prompt and enter the following command: set PFPATH=C:\Program Files . If you are compiling on the 64-bit version of Windows 7, enter the following instead: set PFPATH=C:\Program Files (x86) . Then enter the following commands: cd "%PFPATH%\Microsoft Visual Studio 9.0\VC\bin" set FLEXDLLDIR=%PFPATH%\flexdll vcvars32 echo VCPATH="`cygpath -p '%Path%'`" >C:\cygwin\tmp\msenv echo LIB="%LIB%" >>C:\cygwin\tmp\msenv echo LIBPATH="%LIBPATH%" >>C:\cygwin\tmp\msenv echo INCLUDE="%INCLUDE%;%FLEXDLLDIR%" >>C:\cygwin\tmp\msenv echo FLPATH="`cygpath '%FLEXDLLDIR%'`" >>C:\cygwin\tmp\msenv echo PATH="$VCPATH:$FLPATH:$PATH" >>C:\cygwin\tmp\msenv echo export PATH LIB LIBPATH INCLUDE >>C:\cygwin\tmp\msenv echo export OCAMLBUILD_FIND=/usr/bin/find >>C:\cygwin\tmp\msenv . Open a Cygwin shell and enter the following commands: tr -d '\r' .msenv32 echo '. $HOME/.msenv32' >>.bashrc Now, close the Command Prompt and the shell and you're set up for using the MS tools under Cygwin. To recompile OCaml, start a new Cygwin shell and change to the top-level directory of the OCaml distribution. Then, do cp config/m-nt.h config/m.h cp config/s-nt.h config/s.h cp config/Makefile.msvc config/Makefile Then, edit config/Makefile as needed, following the comments in this file. Normally, the only variable that need to be changed is PREFIX where to install everything Finally, use `make -f Makefile.nt` to build the system, e.g. make -f Makefile.nt world make -f Makefile.nt bootstrap make -f Makefile.nt opt make -f Makefile.nt opt.opt make -f Makefile.nt install === NOTES * The VC++ compiler does not implement "computed gotos", and therefore generates inefficient code for 'byterun/interp.c'. Consequently, the performance of bytecode programs is about 2/3 of that obtained under Unix/GCC or Cygwin or Mingw on similar hardware. * Libraries available in this port: `num`, `str`, `threads`, `graphics`, and large parts of `unix`. * The replay debugger is partially supported (no reverse execution). === CREDITS The initial port of Caml Special Light (the ancestor of OCaml) to Windows NT was done by Kevin Gallo at Microsoft Research, who kindly contributed his changes to the OCaml project. == The native Win32 and Win64 ports built with Mingw === REQUIREMENTS Those ports run under MS Windows Seven, Vista, XP, and 2000. The base bytecode system (ocamlc, ocaml, ocamllex, ocamlyacc, ...) runs without any additional tools. The native-code compiler (ocamlopt), as well as static linking of OCaml bytecode with C code (ocamlc -custom), require the Cygwin development tools, available at http://www.cygwin.com/ and the flexdll tool, available at http://alain.frisch.fr/flexdll.html You will need to install at least the following Cygwin packages for the 32-bit flavor (use the Setup tool from Cygwin): mingw64-i686-binutils mingw64-i686-gcc-core mingw64-i686-runtime and the following packages for the 64-bit: mingw64-x86_64-binutils mingw64-x86_64-gcc-core mingw64-x86_64-runtime === NOTES - Do not use the Cygwin version of flexdll for this port. - There is another 32-bit gcc compiler, from the MinGW.org project, packaged in Cygwin under the name mingw-gcc. It is not currently supported by flexdll and OCaml. - The standard gcc compiler shipped with Cygwin used to support a `-mno-cygwin` option, which turned the compiler into a mingw compiler. This option was used by previous versions of flexdll and OCaml, but it is no longer available in recent version, hence the switch to another toolchain packaged in Cygwin. - The standalone mingw toolchain from the MinGW-w64 project (http://mingw-w64.org/) is not supported. Please use the version packaged in Cygwin instead. === INSTALLATION The binary distribution is a self-installing executable archive. Just run it and it should install OCaml automatically. === RECOMPILATION FROM THE SOURCES You will need the following software components to perform the recompilation: - Windows NT, 2000, XP, Vista, or Seven. - Cygwin: http://cygwin.com/ Install at least the following packages (and their dependencies, as computed by Cygwin's setup.exe): * For both flavor of OCaml (32-bit and 64-bit): diffutils make ncurses * For the 32 bit flavor of OCaml: mingw64-i686-binutils mingw64-i686-gcc-core mingw64-i686-runtime * For the 64 bit flavor of OCaml: mingw64-x86_64-binutils mingw64-x86_64-gcc-core mingw64-x86_64-runtime - The flexdll tool (see above). Do not forget to add the flexdll directory to your PATH The standalone mingw toolchain from the MinGW-w64 project (http://mingw-w64.org/) is not supported. Please use the version packaged in Cygwin instead. Start a new Cygwin shell and unpack the source distribution (ocaml-X.YY.Z.tar.gz) with `tar xzf`. Change to the top-level directory of the OCaml distribution. Then, do cp config/m-nt.h config/m.h cp config/s-nt.h config/s.h For a 32 bit OCaml: cp config/Makefile.mingw config/Makefile For a 64 bit OCaml: cp config/Makefile.mingw64 config/Makefile Then, edit config/Makefile as needed, following the comments in this file. Normally, the only variable that need to be changed is PREFIX where to install everything Finally, use `make -f Makefile.nt` to build the system, e.g. make -f Makefile.nt world make -f Makefile.nt bootstrap make -f Makefile.nt opt make -f Makefile.nt opt.opt make -f Makefile.nt install === NOTES * Libraries available in this port: `num`, `str`, `threads`, `graphics`, and large parts of `unix`. * The replay debugger is partially supported (no reverse execution). * The default Makefile.mingw and Makefile.mingw64 pass `-static-libgcc` to the linker. For more information on this topic: - http://gcc.gnu.org/onlinedocs/gcc-4.9.1/gcc/Link-Options.html#Link-Options - http://caml.inria.fr/mantis/view.php?id=6411 == The native Win64 port built with Microsoft Windows SDK === REQUIREMENTS This port runs under MS Windows XP 64, Windows Server 64, and Windows 7 64 on Intel64/AMD64 machines. The base bytecode system (ocamlc, ocaml, ocamllex, ocamlyacc, ...) runs without any additional tools. Statically linking OCaml bytecode with C code (ocamlc -custom) requires the Microsoft Platform SDK compiler (item <> in the section "third-party software" below) and the flexdll tool (item <>). The native-code compiler (ocamlopt) requires the Microsoft compiler and the Microsoft assembler MASM64 (item link:tps-native1[(1(]) and the flexdll tool (item <>). === INSTALLATION: There is no binary distribution yet. Please compile from sources as described below. === THIRD-PARTY SOFTWARE [[tps-native1]] [1]:: Microsoft Windows SDK for Windows 7 and .NET Framework 3.5 Service Pack 1. Can be downloaded for free from http://www.microsoft.com/downloads/en/default.aspx under the name "Microsoft Windows 7 SDK". [[tps-native2]] [2]:: flexdll version 0.31 or later. Can be downloaded from http://alain.frisch.fr/flexdll.html === RECOMPILATION FROM THE SOURCES The command-line tools can be recompiled from the Unix source distribution ('ocaml-X.YZ.tar.gz'), which also contains the files modified for Windows. You will need the following software components to perform the recompilation: - Windows XP 64, Windows Server 64, or Windows 7 64. - Items <> and <> from the list of recommended software above. - The Cygwin port of GNU tools, available from http://www.cygwin.com/ Install at least the following packages: diffutils, make, ncurses. First, you need to set up your cygwin environment for using the MS tools. The following assumes that you have installed <> and <> in their default directories. If this is not the case, you will need to adjust the paths accordingly. . Open a Windows Command Prompt and enter the following commands: set PFPATH=C:\Program Files (x86) cd "%PFPATH%\Microsoft Visual Studio 9.0\VC\bin" vcvars64 echo VCPATH="`cygpath -p '%Path%'`" >C:\cygwin\tmp\msenv echo LIB="%LIB%" >>C:\cygwin\tmp\msenv echo LIBPATH="%LIBPATH%" >>C:\cygwin\tmp\msenv echo INCLUDE="%INCLUDE%" >>C:\cygwin\tmp\msenv echo FLPATH="`cygpath '%PFPATH%\flexdll'`" >>C:\cygwin\tmp\msenv echo PATH="$VCPATH:$FLPATH:$PATH" >>C:\cygwin\tmp\msenv echo export PATH LIB LIBPATH INCLUDE >>C:\cygwin\tmp\msenv echo export OCAMLBUILD_FIND=/usr/bin/find >>C:\cygwin\tmp\msenv . Open a Cygwin shell and enter the following commands: tr -d '\r' .msenv64 echo '. $HOME/.msenv64' >>.bashrc Now, close the Command Prompt and the shell and you're set up for using the MS tools under Cygwin. To recompile OCaml, start a new Cygwin shell and change to the top-level directory of the OCaml distribution. Then, do cp config/m-nt.h config/m.h cp config/s-nt.h config/s.h cp config/Makefile.msvc64 config/Makefile Then, edit config/Makefile as needed, following the comments in this file. Normally, the only variable that need to be changed is PREFIX where to install everything Finally, use `make -f Makefile.nt` to build the system, e.g. make -f Makefile.nt world make -f Makefile.nt bootstrap make -f Makefile.nt opt make -f Makefile.nt opt.opt make -f Makefile.nt install === NOTES * Libraries available in this port: `num`, `str`, `threads`, `graphics`, and large parts of `unix`. * The replay debugger is partially supported (no reverse execution). * The graphical browser ocamlbrowser is not supported. == Trademarks Microsoft, Visual C++, Visual Studio and Windows are registered trademarks of Microsoft Corporation in the United States and/or other countries.