2015-09-28 06:24:23 -03:00
|
|
|
OpenBSD build guide
|
|
|
|
======================
|
2021-06-24 08:58:42 -04:00
|
|
|
(updated for OpenBSD 6.9)
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2020-09-06 23:16:57 -03:00
|
|
|
This guide describes how to build bitcoind, bitcoin-qt, and command-line utilities on OpenBSD.
|
2015-09-28 06:24:23 -03:00
|
|
|
|
|
|
|
Preparation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Run the following as root to install the base dependencies for building:
|
|
|
|
|
|
|
|
```bash
|
2018-05-21 10:43:04 -04:00
|
|
|
pkg_add git gmake libevent libtool boost
|
2020-09-06 23:16:57 -03:00
|
|
|
pkg_add qt5 # (optional for enabling the GUI)
|
2015-09-28 06:24:23 -03:00
|
|
|
pkg_add autoconf # (select highest version, e.g. 2.69)
|
2018-10-19 01:15:25 -03:00
|
|
|
pkg_add automake # (select highest version, e.g. 1.16)
|
2020-07-28 04:29:47 -04:00
|
|
|
pkg_add python # (select highest version, e.g. 3.8)
|
2020-11-26 17:34:13 -03:00
|
|
|
pkg_add bash
|
2017-10-02 23:15:55 -03:00
|
|
|
|
|
|
|
git clone https://github.com/bitcoin/bitcoin.git
|
2015-09-28 06:24:23 -03:00
|
|
|
```
|
|
|
|
|
2017-07-09 07:15:45 -04:00
|
|
|
See [dependencies.md](dependencies.md) for a complete overview.
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2017-12-22 05:44:32 -03:00
|
|
|
**Important**: From OpenBSD 6.2 onwards a C++11-supporting clang compiler is
|
2020-07-28 04:29:47 -04:00
|
|
|
part of the base image, and while building it is necessary to make sure that
|
|
|
|
this compiler is used and not ancient g++ 4.2.1. This is done by appending
|
|
|
|
`CC=cc CC_FOR_BUILD=cc CXX=c++` to configuration commands. Mixing different
|
|
|
|
compilers within the same executable will result in errors.
|
2015-09-28 06:24:23 -03:00
|
|
|
|
|
|
|
### Building BerkeleyDB
|
|
|
|
|
2017-12-22 05:44:32 -03:00
|
|
|
BerkeleyDB is only necessary for the wallet functionality. To skip this, pass
|
|
|
|
`--disable-wallet` to `./configure` and skip to the next section.
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2017-11-16 01:26:02 -03:00
|
|
|
It is recommended to use Berkeley DB 4.8. You cannot use the BerkeleyDB library
|
|
|
|
from ports, for the same reason as boost above (g++/libstd++ incompatibility).
|
|
|
|
If you have to build it yourself, you can use [the installation script included
|
2018-10-25 16:58:08 -03:00
|
|
|
in contrib/](/contrib/install_db4.sh) like so:
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2020-02-12 15:16:39 -03:00
|
|
|
```bash
|
2017-12-22 05:44:32 -03:00
|
|
|
./contrib/install_db4.sh `pwd` CC=cc CXX=c++
|
2015-09-28 06:24:23 -03:00
|
|
|
```
|
|
|
|
|
2017-12-22 05:44:32 -03:00
|
|
|
from the root of the repository. Then set `BDB_PREFIX` for the next section:
|
2016-08-26 11:26:09 -03:00
|
|
|
|
2020-02-12 15:16:39 -03:00
|
|
|
```bash
|
2017-12-22 05:44:32 -03:00
|
|
|
export BDB_PREFIX="$PWD/db4"
|
|
|
|
```
|
2016-08-26 11:26:09 -03:00
|
|
|
|
2015-09-28 06:24:23 -03:00
|
|
|
### Building Bitcoin Core
|
|
|
|
|
2020-02-12 15:16:39 -03:00
|
|
|
**Important**: Use `gmake` (the non-GNU `make` will exit with an error).
|
2015-09-28 06:24:23 -03:00
|
|
|
|
|
|
|
Preparation:
|
|
|
|
```bash
|
2018-05-21 10:43:04 -04:00
|
|
|
|
|
|
|
# Replace this with the autoconf version that you installed. Include only
|
|
|
|
# the major and minor parts of the version: use "2.69" for "autoconf-2.69p2".
|
|
|
|
export AUTOCONF_VERSION=2.69
|
|
|
|
|
|
|
|
# Replace this with the automake version that you installed. Include only
|
2018-10-19 01:15:25 -03:00
|
|
|
# the major and minor parts of the version: use "1.16" for "automake-1.16.1".
|
|
|
|
export AUTOMAKE_VERSION=1.16
|
2018-05-21 10:43:04 -04:00
|
|
|
|
2015-09-28 06:24:23 -03:00
|
|
|
./autogen.sh
|
|
|
|
```
|
2017-10-02 23:15:55 -03:00
|
|
|
Make sure `BDB_PREFIX` is set to the appropriate path from the above steps.
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2021-06-24 08:58:42 -04:00
|
|
|
Note that building with external signer support currently fails on OpenBSD,
|
2021-07-23 11:29:54 -04:00
|
|
|
hence you have to explicitly disable it by passing the parameter
|
2021-06-24 08:58:42 -04:00
|
|
|
`--disable-external-signer` to the configure script.
|
|
|
|
(Background: the feature requires the header-only library boost::process, which
|
|
|
|
is available on OpenBSD 6.9 via Boost 1.72.0, but contains certain system calls
|
|
|
|
and preprocessor defines like `waitid()` and `WEXITED` that are not available.)
|
|
|
|
|
2015-09-28 06:24:23 -03:00
|
|
|
To configure with wallet:
|
|
|
|
```bash
|
2021-06-24 08:58:42 -04:00
|
|
|
./configure --with-gui=no --disable-external-signer CC=cc CXX=c++ \
|
2020-02-12 15:16:39 -03:00
|
|
|
BDB_LIBS="-L${BDB_PREFIX}/lib -ldb_cxx-4.8" \
|
|
|
|
BDB_CFLAGS="-I${BDB_PREFIX}/include" \
|
|
|
|
MAKE=gmake
|
2015-09-28 06:24:23 -03:00
|
|
|
```
|
|
|
|
|
|
|
|
To configure without wallet:
|
|
|
|
```bash
|
2021-06-24 08:58:42 -04:00
|
|
|
./configure --disable-wallet --with-gui=no --disable-external-signer CC=cc CC_FOR_BUILD=cc CXX=c++ MAKE=gmake
|
2015-09-28 06:24:23 -03:00
|
|
|
```
|
|
|
|
|
2020-09-06 23:16:57 -03:00
|
|
|
To configure with GUI:
|
|
|
|
```bash
|
2021-06-24 08:58:42 -04:00
|
|
|
./configure --with-gui=yes --disable-external-signer CC=cc CXX=c++ \
|
2020-09-06 23:16:57 -03:00
|
|
|
BDB_LIBS="-L${BDB_PREFIX}/lib -ldb_cxx-4.8" \
|
|
|
|
BDB_CFLAGS="-I${BDB_PREFIX}/include" \
|
|
|
|
MAKE=gmake
|
|
|
|
```
|
|
|
|
|
2015-09-28 06:24:23 -03:00
|
|
|
Build and run the tests:
|
|
|
|
```bash
|
2021-05-13 08:15:59 -04:00
|
|
|
gmake # use "-j N" here for N parallel jobs
|
2015-09-28 06:24:23 -03:00
|
|
|
gmake check
|
|
|
|
```
|
|
|
|
|
2017-12-22 05:44:32 -03:00
|
|
|
Resource limits
|
|
|
|
-------------------
|
2015-09-28 06:24:23 -03:00
|
|
|
|
2017-12-22 05:44:32 -03:00
|
|
|
If the build runs into out-of-memory errors, the instructions in this section
|
|
|
|
might help.
|
|
|
|
|
|
|
|
The standard ulimit restrictions in OpenBSD are very strict:
|
|
|
|
|
|
|
|
data(kbytes) 1572864
|
|
|
|
|
2018-10-25 16:58:08 -03:00
|
|
|
This is, unfortunately, in some cases not enough to compile some `.cpp` files in the project,
|
2017-12-22 05:44:32 -03:00
|
|
|
(see issue [#6658](https://github.com/bitcoin/bitcoin/issues/6658)).
|
|
|
|
If your user is in the `staff` group the limit can be raised with:
|
|
|
|
|
|
|
|
ulimit -d 3000000
|
|
|
|
|
|
|
|
The change will only affect the current shell and processes spawned by it. To
|
|
|
|
make the change system-wide, change `datasize-cur` and `datasize-max` in
|
|
|
|
`/etc/login.conf`, and reboot.
|
2015-09-28 06:24:23 -03:00
|
|
|
|