monero/contrib/depends
luigi1111 aa1369993d
Merge pull request #9589
085d3ed build: fix tar extract cmd for systems with 16 bit uid_t (Ishan Arora)
2024-12-23 11:01:09 -05:00
..
builders
hosts Bootstrappable Builds 2024-12-08 18:00:32 +01:00
packages Merge pull request #9518 2024-12-23 10:43:09 -05:00
patches Bootstrappable Builds 2024-12-08 18:00:32 +01:00
.gitignore
config.guess
config.sub
description.md
funcs.mk Merge pull request #9589 2024-12-23 11:01:09 -05:00
Makefile Merge pull request #9457 2024-12-23 10:36:44 -05:00
packages.md
README.md
toolchain.cmake.in Merge pull request #9502 2024-12-23 10:39:16 -05:00

Usage

To build dependencies for the current arch+OS, from this working directory:

make

To build for another arch/OS:

make HOST=host-platform-triplet

For example:

make HOST=x86_64-w64-mingw32 -j4

A toolchain will be generated that's suitable for plugging into Monero's cmake. In the above example, a dir named x86_64-w64-mingw32 will be created. To use it for Monero, from the top of the Monero source tree:

mkdir build
cd build
cmake -DCMAKE_TOOLCHAIN_FILE=$PWD/../contrib/depends/x86_64-w64-mingw32/share/toolchain.cmake ..

Common host-platform-triplets for cross compilation are:

  • i686-w64-mingw32 for Win32
  • x86_64-w64-mingw32 for Win64
  • x86_64-apple-darwin for MacOSX x86_64
  • arm-linux-gnueabihf for Linux ARM 32 bit
  • aarch64-linux-gnu for Linux ARM 64 bit
  • riscv64-linux-gnu for Linux RISCV 64 bit

No other options are needed, the paths are automatically configured.

Dependency Options: The following can be set when running make: make FOO=bar

SOURCES_PATH: downloaded sources will be placed here
BASE_CACHE: built packages will be placed here
FALLBACK_DOWNLOAD_PATH: If a source file can't be fetched, try here before giving up
DEBUG: disable some optimizations and enable more runtime checking
HOST_ID_SALT: Optional salt to use when generating host package ids
BUILD_ID_SALT: Optional salt to use when generating build package ids

Additional targets:

download: run 'make download' to fetch all sources without building them
download-osx: run 'make download-osx' to fetch all sources needed for osx builds
download-win: run 'make download-win' to fetch all sources needed for win builds
download-linux: run 'make download-linux' to fetch all sources needed for linux builds

#Mingw builds

Building for 32/64bit mingw requires switching alternatives to a posix mode

update-alternatives --set x86_64-w64-mingw32-g++ x86_64-w64-mingw32-g++-posix
update-alternatives --set x86_64-w64-mingw32-gcc x86_64-w64-mingw32-gcc-posix

Other documentation