parent
fa6793df1b
commit
bfba3a30a5
|
@ -1,167 +0,0 @@
|
|||
---
|
||||
title: Cross-Compiling Geth
|
||||
sort_key: C
|
||||
---
|
||||
|
||||
**Note: All of these and much more have been merged into the project Makefile. You can
|
||||
cross build via `make geth-<os>-<platform>` without needing to know any of these details
|
||||
from below.**
|
||||
|
||||
Developers usually have a preferred platform that they feel most comfortable working in,
|
||||
with all the necessary tools, libraries and environments set up for an optimal workflow.
|
||||
However, there's often need to build for either a different CPU architecture, or an
|
||||
entirely different operating system; but maintaining a development environment for each
|
||||
and switching between the them quickly becomes unwieldy.
|
||||
|
||||
Here we present a very simple way to cross compile Ethereum to various operating systems
|
||||
and architectures using a minimal set of prerequisites and a completely containerized
|
||||
approach, guaranteeing that your development environment remains clean even after the
|
||||
complex requirements and mechanisms of a cross compilation.
|
||||
|
||||
The currently supported target platforms are:
|
||||
|
||||
- ARMv7 Android and iOS
|
||||
- 32 bit, 64 bit and ARMv5 Linux
|
||||
- 32 bit and 64 bit Mac OSX
|
||||
- 32 bit and 64 bit Windows
|
||||
|
||||
Please note, that cross compilation does not replace a release build. Although resulting
|
||||
binaries can usually run perfectly on the desired platform, compiling on a native system
|
||||
with the specialized tools provided by the official vendor can often result in more a
|
||||
finely optimized code.
|
||||
|
||||
## Cross compilation environment
|
||||
|
||||
Although the `go-ethereum` project is written in Go, it does include a bit of C code
|
||||
shared between all implementations to ensure that all perform equally well, including a
|
||||
dependency to the GNU Multiple Precision Arithmetic Library. Because of these, Go cannot
|
||||
by itself compile to a different platform than the host. To overcome this limitation, we
|
||||
will use [`xgo`](https://github.com/karalabe/xgo), a Go cross compiler package based on
|
||||
Docker containers that has been architected specifically to allow both embedded C snippets
|
||||
as well as simpler external C dependencies during compilation.
|
||||
|
||||
The `xgo` project has two simple dependencies: Docker (to ensure that the build
|
||||
environment is completely contained) and Go. On most platforms these should be available
|
||||
from the official package repositories. For manually installing them, please consult their
|
||||
install guides at [Docker](https://docs.docker.com/installation/) and
|
||||
[Go](https://golang.org/doc/install) respectively. This guide assumes that these two
|
||||
dependencies are met.
|
||||
|
||||
To install and/or update xgo, simply type:
|
||||
|
||||
$ go get -u github.com/karalabe/xgo
|
||||
|
||||
You can test whether `xgo` is functioning correctly by requesting it to cross
|
||||
compile itself and verifying that all cross compilations succeeded or not.
|
||||
|
||||
$ xgo github.com/karalabe/xgo
|
||||
...
|
||||
|
||||
$ ls -al
|
||||
-rwxr-xr-x 1 root root 2792436 Sep 14 16:45 xgo-android-21-arm
|
||||
-rwxr-xr-x 1 root root 2353212 Sep 14 16:45 xgo-darwin-386
|
||||
-rwxr-xr-x 1 root root 2906128 Sep 14 16:45 xgo-darwin-amd64
|
||||
-rwxr-xr-x 1 root root 2388288 Sep 14 16:45 xgo-linux-386
|
||||
-rwxr-xr-x 1 root root 2960560 Sep 14 16:45 xgo-linux-amd64
|
||||
-rwxr-xr-x 1 root root 2437864 Sep 14 16:45 xgo-linux-arm
|
||||
-rwxr-xr-x 1 root root 2551808 Sep 14 16:45 xgo-windows-386.exe
|
||||
-rwxr-xr-x 1 root root 3130368 Sep 14 16:45 xgo-windows-amd64.exe
|
||||
|
||||
|
||||
## Building Ethereum
|
||||
|
||||
Cross compiling Ethereum is analogous to the above example, but an additional flags is
|
||||
required to satisfy the dependencies:
|
||||
|
||||
- `--deps` is used to inject arbitrary C dependency packages and pre-build them
|
||||
|
||||
Injecting the GNU Arithmetic Library dependency and selecting `geth` would be:
|
||||
|
||||
$ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \
|
||||
github.com/ethereum/go-ethereum/cmd/geth
|
||||
...
|
||||
|
||||
$ ls -al
|
||||
-rwxr-xr-x 1 root root 23213372 Sep 14 17:59 geth-android-21-arm
|
||||
-rwxr-xr-x 1 root root 14373980 Sep 14 17:59 geth-darwin-386
|
||||
-rwxr-xr-x 1 root root 17373676 Sep 14 17:59 geth-darwin-amd64
|
||||
-rwxr-xr-x 1 root root 21098910 Sep 14 17:59 geth-linux-386
|
||||
-rwxr-xr-x 1 root root 25049693 Sep 14 17:59 geth-linux-amd64
|
||||
-rwxr-xr-x 1 root root 20578535 Sep 14 17:59 geth-linux-arm
|
||||
-rwxr-xr-x 1 root root 16351260 Sep 14 17:59 geth-windows-386.exe
|
||||
-rwxr-xr-x 1 root root 19418071 Sep 14 17:59 geth-windows-amd64.exe
|
||||
|
||||
|
||||
As the cross compiler needs to build all the dependencies as well as the main project
|
||||
itself for each platform, it may take a while for the build to complete (approximately 3-4
|
||||
minutes on a Core i7 3770K machine).
|
||||
|
||||
### Fine tuning the build
|
||||
|
||||
By default Go, and inherently `xgo`, checks out and tries to build the master branch of a
|
||||
source repository. However, more often than not, you'll probably want to build a different
|
||||
branch from possibly an entirely different remote repository. These can be controlled via
|
||||
the `--remote` and `--branch` flags.
|
||||
|
||||
To build the `develop` branch of the official `go-ethereum` repository instead of the
|
||||
default `master` branch, you just need to specify it as an additional command line flag
|
||||
(`--branch`):
|
||||
|
||||
$ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \
|
||||
--branch=develop \
|
||||
github.com/ethereum/go-ethereum/cmd/geth
|
||||
|
||||
Additionally, during development you will most probably want to not only build a custom
|
||||
branch, but also one originating from your own fork of the repository instead of the
|
||||
upstream one. This can be done via the `--remote` flag:
|
||||
|
||||
$ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \
|
||||
--remote=https://github.com/karalabe/go-ethereum \
|
||||
--branch=rpi-staging \
|
||||
github.com/ethereum/go-ethereum/cmd/geth
|
||||
|
||||
By default `xgo` builds binaries for all supported platforms and architectures, with
|
||||
Android binaries defaulting to the highest released Android NDK platform. To limit the
|
||||
build targets or compile to a different Android platform, use the `--targets` CLI
|
||||
parameter.
|
||||
|
||||
$ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \
|
||||
--targets=android-16/arm,windows/* \
|
||||
github.com/ethereum/go-ethereum/cmd/geth
|
||||
|
||||
### Building locally
|
||||
|
||||
If you would like to cross compile your local development version, simply specify a local
|
||||
path (starting with `.` or `/`), and `xgo` will use all local code from `GOPATH`, only
|
||||
downloading missing dependencies. In such a case of course, the `--branch`, `--remote` and
|
||||
`--pkg` arguments are no-op:
|
||||
|
||||
$ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \
|
||||
./cmd/geth
|
||||
|
||||
## Using the Makefile
|
||||
|
||||
Having understood the gist of `xgo` based cross compilation, you do not need to actually
|
||||
memorize and maintain these commands, as they have been incorporated into the official
|
||||
[Makefile](https://github.com/ethereum/go-ethereum/blob/master/Makefile) and can be
|
||||
invoked with a trivial `make` request:
|
||||
|
||||
* `make geth-cross`: Cross compiles to every supported OS and architecture
|
||||
* `make geth-<os>`: Cross compiles supported architectures of a particular OS (e.g. `linux`)
|
||||
* `make geth-<os>-<arch>`: Cross compiles to a specific OS/architecture (e.g. `linux`, `arm`)
|
||||
|
||||
We advise using the `make` based commands opposed to manually invoking `xgo` as we do
|
||||
maintain the Makefile actively whereas we cannot guarantee that this document will be
|
||||
always readily updated to latest advancements.
|
||||
|
||||
### Tuning the cross builds
|
||||
|
||||
A few of the `xgo` build options have also been surfaced directly into the Makefile to
|
||||
allow fine tuning builds to work around either upstream Go issues, or to enable some
|
||||
fancier mechanics.
|
||||
|
||||
- `make ... GO=<go>`: Use a specific Go runtime (e.g. `1.5.1`, `1.5-develop`, `develop`)
|
||||
- `make ... MODE=<mode>`: Build a specific target type (e.g. `exe`, `c-archive`).
|
||||
|
||||
Please note that these are not yet fully finalized, so they may or may not change in the
|
||||
future as our code and the Go runtime features change.
|
Loading…
Reference in New Issue