2015-11-03 07:36:09 -03:00
|
|
|
WINDOWS BUILD NOTES
|
|
|
|
====================
|
|
|
|
|
2016-10-17 01:08:33 -03:00
|
|
|
Below are some notes on how to build Bitcoin Core for Windows.
|
2015-11-03 07:36:09 -03:00
|
|
|
|
2017-11-17 10:16:35 -03:00
|
|
|
The options known to work for building Bitcoin Core on Windows are:
|
|
|
|
|
2021-09-17 00:24:55 -03:00
|
|
|
* On Linux, using the [Mingw-w64](https://www.mingw-w64.org/) cross compiler tool chain.
|
2022-12-29 15:09:22 -03:00
|
|
|
* On Windows, using [Windows Subsystem for Linux (WSL)](https://learn.microsoft.com/en-us/windows/wsl/about) and Mingw-w64.
|
2024-07-24 06:55:19 -04:00
|
|
|
* On Windows, using [Microsoft Visual Studio](https://visualstudio.microsoft.com). See [`build-windows-msvc.md`](./build-windows-msvc.md).
|
2017-11-17 10:16:35 -03:00
|
|
|
|
2018-04-17 14:30:35 -03:00
|
|
|
Other options which may work, but which have not been extensively tested are (please contribute instructions):
|
2017-08-23 11:10:14 -03:00
|
|
|
|
2019-10-31 13:19:36 -03:00
|
|
|
* On Windows, using a POSIX compatibility layer application such as [cygwin](https://www.cygwin.com/) or [msys2](https://www.msys2.org/).
|
2016-10-17 01:08:33 -03:00
|
|
|
|
2024-08-03 06:19:30 -04:00
|
|
|
The instructions below work on Ubuntu and Debian. Make sure the distribution's `g++-mingw-w64-x86-64-posix`
|
|
|
|
package meets the minimum required `g++` version specified in [dependencies.md](dependencies.md).
|
|
|
|
|
2017-11-17 10:16:35 -03:00
|
|
|
Installing Windows Subsystem for Linux
|
|
|
|
---------------------------------------
|
2016-10-17 01:08:33 -03:00
|
|
|
|
2022-12-29 15:09:22 -03:00
|
|
|
Follow the upstream installation instructions, available [here](https://learn.microsoft.com/en-us/windows/wsl/install).
|
2015-11-03 07:36:09 -03:00
|
|
|
|
2017-11-17 10:16:35 -03:00
|
|
|
Cross-compilation for Ubuntu and Windows Subsystem for Linux
|
|
|
|
------------------------------------------------------------
|
2015-11-03 07:36:09 -03:00
|
|
|
|
2021-09-17 00:24:55 -03:00
|
|
|
The steps below can be performed on Ubuntu or WSL. The depends system
|
2015-11-03 07:36:09 -03:00
|
|
|
will also work on other Linux distributions, however the commands for
|
|
|
|
installing the toolchain will be different.
|
|
|
|
|
2024-10-16 10:30:55 -03:00
|
|
|
See [README.md](../depends/README.md) in the depends directory for which
|
|
|
|
dependencies to install and [dependencies.md](dependencies.md) for a complete overview.
|
2018-11-17 09:32:08 -03:00
|
|
|
|
2024-07-24 06:55:19 -04:00
|
|
|
If you want to build the Windows installer using the `deploy` build target, you will need [NSIS](https://nsis.sourceforge.io/Main_Page):
|
2018-11-17 09:32:08 -03:00
|
|
|
|
2024-10-16 10:30:55 -03:00
|
|
|
apt install nsis
|
2017-07-09 07:15:45 -04:00
|
|
|
|
2019-03-06 16:19:06 -03:00
|
|
|
Acquire the source in the usual way:
|
|
|
|
|
|
|
|
git clone https://github.com/bitcoin/bitcoin.git
|
|
|
|
cd bitcoin
|
|
|
|
|
2017-11-17 10:16:35 -03:00
|
|
|
Note that for WSL the Bitcoin Core source path MUST be somewhere in the default mount file system, for
|
|
|
|
example /usr/src/bitcoin, AND not under /mnt/d/. If this is not the case the dependency autoconf scripts will fail.
|
2018-10-25 16:58:08 -03:00
|
|
|
This means you cannot use a directory that is located directly on the host Windows file system to perform the build.
|
2017-11-17 10:16:35 -03:00
|
|
|
|
2019-03-06 16:19:06 -03:00
|
|
|
Build using:
|
2017-11-17 10:16:35 -03:00
|
|
|
|
2024-07-24 06:55:19 -04:00
|
|
|
gmake -C depends HOST=x86_64-w64-mingw32 # Use "-j N" for N parallel jobs.
|
|
|
|
cmake -B build --toolchain depends/x86_64-w64-mingw32/toolchain.cmake
|
|
|
|
cmake --build build # Use "-j N" for N parallel jobs.
|
2015-11-03 07:36:09 -03:00
|
|
|
|
2016-11-25 05:20:00 -03:00
|
|
|
## Depends system
|
|
|
|
|
2015-11-03 07:36:09 -03:00
|
|
|
For further documentation on the depends system see [README.md](../depends/README.md) in the depends directory.
|
2016-11-25 05:20:00 -03:00
|
|
|
|
|
|
|
Installation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
After building using the Windows subsystem it can be useful to copy the compiled
|
2018-10-04 15:58:24 -03:00
|
|
|
executables to a directory on the Windows drive in the same directory structure
|
2016-11-25 05:20:00 -03:00
|
|
|
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:
|
|
|
|
|
2024-07-24 06:55:19 -04:00
|
|
|
cmake --install build --prefix /mnt/c/workspace/bitcoin
|
2017-10-15 08:51:53 -03:00
|
|
|
|
2018-11-17 09:32:08 -03:00
|
|
|
You can also create an installer using:
|
|
|
|
|
2024-07-24 06:55:19 -04:00
|
|
|
cmake --build build --target deploy
|