2015-11-03 10:36:09 +00:00
|
|
|
WINDOWS BUILD NOTES
|
|
|
|
====================
|
|
|
|
|
2016-10-17 04:08:33 +00:00
|
|
|
Below are some notes on how to build Bitcoin Core for Windows.
|
2015-11-03 10:36:09 +00:00
|
|
|
|
|
|
|
Most developers use cross-compilation from Ubuntu to build executables for
|
2017-10-02 11:16:04 +00:00
|
|
|
Windows. Cross-compilation is also used to build the release binaries.
|
2015-11-03 10:36:09 +00:00
|
|
|
|
2017-10-02 11:16:04 +00:00
|
|
|
Currently only building on Ubuntu Trusty 14.04 or Ubuntu Zesty 17.04 or later is supported.
|
|
|
|
Building on Ubuntu Xenial 16.04 is known to be broken, see extensive discussion in issue [8732](https://github.com/bitcoin/bitcoin/issues/8732).
|
|
|
|
While it may be possible to do so with work arounds, it's potentially dangerous and not recommended.
|
2017-08-23 14:10:14 +00:00
|
|
|
|
2016-10-17 04:08:33 +00:00
|
|
|
While there are potentially a number of ways to build on Windows (for example using msys / mingw-w64),
|
2016-11-25 08:20:00 +00:00
|
|
|
using the Windows Subsystem For Linux is the most straightforward. If you are building with
|
|
|
|
another method, please contribute the instructions here for others who are running versions
|
2016-10-17 04:08:33 +00:00
|
|
|
of Windows that are not compatible with the Windows Subsystem for Linux.
|
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
Compiling with Windows Subsystem For Linux
|
|
|
|
-------------------------------------------
|
2016-10-17 04:08:33 +00:00
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
With Windows 10, Microsoft has released a new feature named the [Windows
|
|
|
|
Subsystem for Linux](https://msdn.microsoft.com/commandline/wsl/about). This
|
2016-12-26 23:59:17 +00:00
|
|
|
feature allows you to run a bash shell directly on Windows in an Ubuntu-based
|
2016-11-25 08:20:00 +00:00
|
|
|
environment. Within this environment you can cross compile for Windows without
|
2016-12-26 23:59:17 +00:00
|
|
|
the need for a separate Linux VM or server.
|
2016-10-17 04:08:33 +00:00
|
|
|
|
2016-12-26 23:59:17 +00:00
|
|
|
This feature is not supported in versions of Windows prior to Windows 10 or on
|
|
|
|
Windows Server SKUs. In addition, it is available [only for 64-bit versions of
|
|
|
|
Windows](https://msdn.microsoft.com/en-us/commandline/wsl/install_guide).
|
2016-10-17 04:08:33 +00:00
|
|
|
|
|
|
|
To get the bash shell, you must first activate the feature in Windows.
|
|
|
|
|
|
|
|
1. Turn on Developer Mode
|
|
|
|
* Open Settings -> Update and Security -> For developers
|
|
|
|
* Select the Developer Mode radio button
|
|
|
|
* Restart if necessary
|
|
|
|
2. Enable the Windows Subsystem for Linux feature
|
|
|
|
* From Start, search for "Turn Windows features on or off" (type 'turn')
|
|
|
|
* Select Windows Subsystem for Linux (beta)
|
|
|
|
* Click OK
|
|
|
|
* Restart if necessary
|
|
|
|
3. Complete Installation
|
|
|
|
* Open a cmd prompt and type "bash"
|
|
|
|
* Accept the license
|
|
|
|
* Create a new UNIX user account (this is a separate account from your Windows account)
|
|
|
|
|
2016-12-26 23:59:17 +00:00
|
|
|
After the bash shell is active, you can follow the instructions below, starting
|
|
|
|
with the "Cross-compilation" section. Compiling the 64-bit version is
|
|
|
|
recommended but it is possible to compile the 32-bit version.
|
2015-11-03 10:36:09 +00:00
|
|
|
|
|
|
|
Cross-compilation
|
|
|
|
-------------------
|
|
|
|
|
|
|
|
These steps can be performed on, for example, an Ubuntu VM. The depends system
|
|
|
|
will also work on other Linux distributions, however the commands for
|
|
|
|
installing the toolchain will be different.
|
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
First, install the general dependencies:
|
|
|
|
|
|
|
|
sudo apt-get install build-essential libtool autotools-dev automake pkg-config bsdmainutils curl
|
|
|
|
|
|
|
|
A host toolchain (`build-essential`) is necessary because some dependency
|
|
|
|
packages (such as `protobuf`) need to build host utilities that are used in the
|
|
|
|
build process.
|
|
|
|
|
2017-07-09 11:15:45 +00:00
|
|
|
See also: [dependencies.md](dependencies.md).
|
|
|
|
|
2017-10-02 11:16:04 +00:00
|
|
|
If you're building on Ubuntu 17.04 or later, run these two commands, selecting the 'posix' variant for both,
|
|
|
|
to work around issues with mingw-w64. See issue [8732](https://github.com/bitcoin/bitcoin/issues/8732) for more information.
|
|
|
|
```
|
|
|
|
sudo update-alternatives --config x86_64-w64-mingw32-g++
|
|
|
|
sudo update-alternatives --config x86_64-w64-mingw32-gcc
|
|
|
|
```
|
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
## Building for 64-bit Windows
|
|
|
|
|
|
|
|
To build executables for Windows 64-bit, install the following dependencies:
|
2015-11-03 10:36:09 +00:00
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
sudo apt-get install g++-mingw-w64-x86-64 mingw-w64-x86-64-dev
|
2015-11-03 10:36:09 +00:00
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
Then build using:
|
2015-11-03 10:36:09 +00:00
|
|
|
|
2017-09-05 20:26:20 +00:00
|
|
|
PATH=$(echo "$PATH" | sed -e 's/:\/mnt.*//g') # strip out problematic Windows %PATH% imported var
|
2015-11-03 10:36:09 +00:00
|
|
|
cd depends
|
2016-12-26 23:59:17 +00:00
|
|
|
make HOST=x86_64-w64-mingw32
|
2015-11-03 10:36:09 +00:00
|
|
|
cd ..
|
2016-09-22 03:10:59 +00:00
|
|
|
./autogen.sh # not required when building from tarball
|
2016-11-25 08:20:00 +00:00
|
|
|
CONFIG_SITE=$PWD/depends/x86_64-w64-mingw32/share/config.site ./configure --prefix=/
|
2015-11-03 10:36:09 +00:00
|
|
|
make
|
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
## Building for 32-bit Windows
|
|
|
|
|
|
|
|
To build executables for Windows 32-bit, install the following dependencies:
|
|
|
|
|
2017-10-02 11:16:04 +00:00
|
|
|
sudo apt-get install g++-mingw-w64-i686 mingw-w64-i686-dev
|
2016-11-25 08:20:00 +00:00
|
|
|
|
|
|
|
Then build using:
|
2015-11-03 10:36:09 +00:00
|
|
|
|
2017-09-05 20:26:20 +00:00
|
|
|
PATH=$(echo "$PATH" | sed -e 's/:\/mnt.*//g') # strip out problematic Windows %PATH% imported var
|
2015-11-03 10:36:09 +00:00
|
|
|
cd depends
|
2016-12-26 23:59:17 +00:00
|
|
|
make HOST=i686-w64-mingw32
|
2015-11-03 10:36:09 +00:00
|
|
|
cd ..
|
2016-09-22 03:10:59 +00:00
|
|
|
./autogen.sh # not required when building from tarball
|
2016-11-25 08:20:00 +00:00
|
|
|
CONFIG_SITE=$PWD/depends/i686-w64-mingw32/share/config.site ./configure --prefix=/
|
2015-11-03 10:36:09 +00:00
|
|
|
make
|
|
|
|
|
2016-11-25 08:20:00 +00:00
|
|
|
## Depends system
|
|
|
|
|
2015-11-03 10:36:09 +00:00
|
|
|
For further documentation on the depends system see [README.md](../depends/README.md) in the depends directory.
|
2016-11-25 08:20:00 +00:00
|
|
|
|
|
|
|
Installation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
After building using the Windows subsystem it can be useful to copy the compiled
|
|
|
|
executables to a directory on the windows drive in the same directory structure
|
|
|
|
as they appear in the release `.zip` archive. This can be done in the following
|
|
|
|
way. This will install to `c:\workspace\bitcoin`, for example:
|
|
|
|
|
|
|
|
make install DESTDIR=/mnt/c/workspace/bitcoin
|