@ -12,10 +12,14 @@ SRC_DIR ?= ./src
|
|||||||
TEST_DIR ?= ./test
|
TEST_DIR ?= ./test
|
||||||
OUT_DIR ?= ./out
|
OUT_DIR ?= ./out
|
||||||
|
|
||||||
|
ifeq ($(DOCKER),1)
|
||||||
|
LLVM_DIR = $(LOCAL_PATH)llvm/llvm-docker
|
||||||
|
else
|
||||||
OS=$(shell uname)
|
OS=$(shell uname)
|
||||||
ifeq ($(OS),Darwin)
|
ifeq ($(OS),Darwin)
|
||||||
LLVM_DIR ?= $(shell brew --prefix llvm)
|
LLVM_DIR ?= $(shell brew --prefix llvm)
|
||||||
endif
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
ifdef LLVM_DIR
|
ifdef LLVM_DIR
|
||||||
CC := $(LLVM_DIR)/bin/clang
|
CC := $(LLVM_DIR)/bin/clang
|
||||||
@ -29,14 +33,14 @@ LLC := llc-7
|
|||||||
OBJ_DUMP := llvm-objdump-7
|
OBJ_DUMP := llvm-objdump-7
|
||||||
endif
|
endif
|
||||||
|
|
||||||
SYSTEM_INC_DIRS := -isystem $(LOCAL_PATH)inc
|
SYSTEM_INC_DIRS := $(LOCAL_PATH)inc
|
||||||
|
|
||||||
C_FLAGS := \
|
C_FLAGS := \
|
||||||
-Werror \
|
-Werror \
|
||||||
-O2 \
|
-O2 \
|
||||||
-fno-builtin \
|
-fno-builtin \
|
||||||
-std=c17 \
|
-std=c17 \
|
||||||
$(SYSTEM_INC_DIRS) \
|
$(addprefix -isystem,$(SYSTEM_INC_DIRS)) \
|
||||||
$(addprefix -I,$(INC_DIRS))
|
$(addprefix -I,$(INC_DIRS))
|
||||||
|
|
||||||
CXX_FLAGS := \
|
CXX_FLAGS := \
|
||||||
@ -88,6 +92,7 @@ TEST_CXX_FLAGS := \
|
|||||||
$(TESTFRAMEWORK_FLAGS) \
|
$(TESTFRAMEWORK_FLAGS) \
|
||||||
|
|
||||||
help:
|
help:
|
||||||
|
@echo ''
|
||||||
@echo 'BPF Program makefile'
|
@echo 'BPF Program makefile'
|
||||||
@echo ''
|
@echo ''
|
||||||
@echo 'This makefile will build BPF Programs from C or C++ source files into ELFs'
|
@echo 'This makefile will build BPF Programs from C or C++ source files into ELFs'
|
||||||
@ -102,8 +107,11 @@ help:
|
|||||||
@echo ''
|
@echo ''
|
||||||
@echo 'User settings'
|
@echo 'User settings'
|
||||||
@echo ' - The following setting are overridable on the command line, default values shown:'
|
@echo ' - The following setting are overridable on the command line, default values shown:'
|
||||||
@echo ' - Show commands while building:'
|
@echo ' - Show commands while building: V=1'
|
||||||
@echo ' V=1'
|
@echo ' V=$(V)'
|
||||||
|
@echo ' - Use LLVM from docker: DOCKER=1'
|
||||||
|
@echo ' Docker image must be pulled first: docker pull solanalabs/llvm'
|
||||||
|
@echo ' DOCKER=$(DOCKER)'
|
||||||
@echo ' - List of include directories:'
|
@echo ' - List of include directories:'
|
||||||
@echo ' INC_DIRS=$(INC_DIRS)'
|
@echo ' INC_DIRS=$(INC_DIRS)'
|
||||||
@echo ' - List of system include directories:'
|
@echo ' - List of system include directories:'
|
||||||
@ -119,7 +127,7 @@ help:
|
|||||||
@echo ''
|
@echo ''
|
||||||
@echo 'Usage:'
|
@echo 'Usage:'
|
||||||
@echo ' - make help - This help message'
|
@echo ' - make help - This help message'
|
||||||
@echo ' - make all - Builds all the programs'
|
@echo ' - make all - Build all the programs'
|
||||||
@echo ' - make test - Build and run all tests'
|
@echo ' - make test - Build and run all tests'
|
||||||
@echo ' - make dump_<program name> - Dumps the contents of the program to stdout'
|
@echo ' - make dump_<program name> - Dumps the contents of the program to stdout'
|
||||||
@echo ' - make <program name> - Build a single program by name'
|
@echo ' - make <program name> - Build a single program by name'
|
||||||
@ -133,6 +141,7 @@ help:
|
|||||||
@echo ' - Assuming a programed named foo (src/foo.c)'
|
@echo ' - Assuming a programed named foo (src/foo.c)'
|
||||||
@echo ' - make foo'
|
@echo ' - make foo'
|
||||||
@echo ' - make dump_foo'
|
@echo ' - make dump_foo'
|
||||||
|
@echo ''
|
||||||
|
|
||||||
.PRECIOUS: $(OUT_DIR)/%.bc
|
.PRECIOUS: $(OUT_DIR)/%.bc
|
||||||
$(OUT_DIR)/%.bc: $(SRC_DIR)/%.c
|
$(OUT_DIR)/%.bc: $(SRC_DIR)/%.c
|
||||||
|
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/clang
Executable file
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/clang
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
SDKPATH="$( cd "$(dirname "$0")" ; pwd -P )"/../../../..
|
||||||
|
docker run --workdir /solana_sdk --volume $SDKPATH:/solana_sdk --rm solanalabs/llvm `basename "$0"` "$@"
|
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/clang++
Executable file
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/clang++
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
SDKPATH="$( cd "$(dirname "$0")" ; pwd -P )"/../../../..
|
||||||
|
docker run --workdir /solana_sdk --volume $SDKPATH:/solana_sdk --rm solanalabs/llvm `basename "$0"` "$@"
|
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/llc
Executable file
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/llc
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
SDKPATH="$( cd "$(dirname "$0")" ; pwd -P )"/../../../..
|
||||||
|
docker run --workdir /solana_sdk --volume $SDKPATH:/solana_sdk --rm solanalabs/llvm `basename "$0"` "$@"
|
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/llvm-objdump
Executable file
4
programs/bpf/c/sdk/llvm/llvm-docker/bin/llvm-objdump
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
SDKPATH="$( cd "$(dirname "$0")" ; pwd -P )"/../../../..
|
||||||
|
docker run --workdir /solana_sdk --volume $SDKPATH:/solana_sdk --rm solanalabs/llvm `basename "$0"` "$@"
|
13
programs/bpf/c/sdk/llvm/llvm-docker/generate.sh
Executable file
13
programs/bpf/c/sdk/llvm/llvm-docker/generate.sh
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
read -r -d '' SCRIPT << 'EOM'
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
SDKPATH="$( cd "$(dirname "$0")" ; pwd -P )"/../../../..
|
||||||
|
docker run --workdir /solana_sdk --volume $SDKPATH:/solana_sdk --rm solanalabs/llvm `basename "$0"` "$@"
|
||||||
|
EOM
|
||||||
|
|
||||||
|
echo "$SCRIPT" > bin/clang
|
||||||
|
echo "$SCRIPT" > bin/clang++
|
||||||
|
echo "$SCRIPT" > bin/llc
|
||||||
|
echo "$SCRIPT" > bin/llvm-objdump
|
68
sdk/docker-llvm/Dockerfile
Normal file
68
sdk/docker-llvm/Dockerfile
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
# This docker file is based on the llvm docker file example located here:
|
||||||
|
# https://github.com/llvm-mirror/llvm/blob/master/utils/docker/debian8/Dockerfile
|
||||||
|
|
||||||
|
FROM launcher.gcr.io/google/debian8:latest as builder
|
||||||
|
LABEL maintainer "Solana Maintainers"
|
||||||
|
|
||||||
|
# Install build dependencies of llvm.
|
||||||
|
# First, Update the apt's source list and include the sources of the packages.
|
||||||
|
RUN grep deb /etc/apt/sources.list | \
|
||||||
|
sed 's/^deb/deb-src /g' >> /etc/apt/sources.list
|
||||||
|
|
||||||
|
# Install compiler, python and subversion.
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y \
|
||||||
|
--no-install-recommends \
|
||||||
|
ca-certificates gnupg \
|
||||||
|
build-essential \
|
||||||
|
python \
|
||||||
|
wget \
|
||||||
|
unzip \
|
||||||
|
git \
|
||||||
|
ssh && \
|
||||||
|
rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# Install a newer ninja release. It seems the older version in the debian repos
|
||||||
|
# randomly crashes when compiling llvm.
|
||||||
|
RUN wget "https://github.com/ninja-build/ninja/releases/download/v1.8.2/ninja-linux.zip" && \
|
||||||
|
echo "d2fea9ff33b3ef353161ed906f260d565ca55b8ca0568fa07b1d2cab90a84a07 ninja-linux.zip" \
|
||||||
|
| sha256sum -c && \
|
||||||
|
unzip ninja-linux.zip -d /usr/local/bin && \
|
||||||
|
rm ninja-linux.zip
|
||||||
|
|
||||||
|
# Import public key required for verifying signature of cmake download.
|
||||||
|
RUN gpg --no-tty --keyserver hkp://pgp.mit.edu --recv 0x2D2CEF1034921684
|
||||||
|
|
||||||
|
# Download, verify and install cmake version that can compile clang into /usr/local.
|
||||||
|
# (Version in debian8 repos is too old)
|
||||||
|
RUN mkdir /tmp/cmake-install && cd /tmp/cmake-install && \
|
||||||
|
wget "https://cmake.org/files/v3.7/cmake-3.7.2-SHA-256.txt.asc" && \
|
||||||
|
wget "https://cmake.org/files/v3.7/cmake-3.7.2-SHA-256.txt" && \
|
||||||
|
gpg --verify cmake-3.7.2-SHA-256.txt.asc cmake-3.7.2-SHA-256.txt && \
|
||||||
|
wget "https://cmake.org/files/v3.7/cmake-3.7.2-Linux-x86_64.tar.gz" && \
|
||||||
|
( grep "cmake-3.7.2-Linux-x86_64.tar.gz" cmake-3.7.2-SHA-256.txt | \
|
||||||
|
sha256sum -c - ) && \
|
||||||
|
tar xzf cmake-3.7.2-Linux-x86_64.tar.gz -C /usr/local --strip-components=1 && \
|
||||||
|
cd / && \
|
||||||
|
rm -rf /tmp/cmake-install
|
||||||
|
|
||||||
|
# ADD checksums /tmp/checksums
|
||||||
|
# ADD scripts /tmp/scripts
|
||||||
|
|
||||||
|
# Checkout the source code
|
||||||
|
RUN git clone https://github.com/solana-labs/llvm.git && \
|
||||||
|
git clone https://github.com/solana-labs/clang.git llvm/tools/clang && \
|
||||||
|
git clone https://github.com/solana-labs/clang-tools-extra.git llvm/tools/clang/tools/extra && \
|
||||||
|
git clone https://github.com/solana-labs/lld.git llvm/tools/lld && \
|
||||||
|
git clone https://github.com/solana-labs/compiler-rt.git llvm/projects/compiler-rt
|
||||||
|
|
||||||
|
RUN mkdir /llvm/build && \
|
||||||
|
cd /llvm/build && \
|
||||||
|
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_EXPORT_COMPILE_COMMANDS=ON -DCMAKE_INSTALL_PREFIX=$HOME/local -G "Ninja" .. && \
|
||||||
|
ninja -j6 && \
|
||||||
|
ninja install
|
||||||
|
|
||||||
|
# Produce stage 2 docker with just the peices needed
|
||||||
|
FROM launcher.gcr.io/google/debian8:latest
|
||||||
|
LABEL maintainer "Solana Maintainers"
|
||||||
|
COPY --from=builder root/local/bin /usr/local/bin
|
16
sdk/docker-llvm/README.md
Normal file
16
sdk/docker-llvm/README.md
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
## Solana Customized LLVM
|
||||||
|
|
||||||
|
This Docker contains LLVM binaries that incorporate customizations and fixes required
|
||||||
|
by Solana but not yet upstreamed into the LLVM mainline.
|
||||||
|
|
||||||
|
https://hub.docker.com/r/solanalabs/llvm/
|
||||||
|
|
||||||
|
### Usage:
|
||||||
|
|
||||||
|
This Docker is optionally used by the SDK BPF build system.
|
||||||
|
|
||||||
|
For more information:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ make help
|
||||||
|
```
|
7
sdk/docker-llvm/build.sh
Executable file
7
sdk/docker-llvm/build.sh
Executable file
@ -0,0 +1,7 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -ex
|
||||||
|
|
||||||
|
cd "$(dirname "$0")"
|
||||||
|
|
||||||
|
docker build -t solanalabs/llvm .
|
||||||
|
docker push solanalabs/llvm
|
@ -18,10 +18,10 @@ if [[ -z $CHANNEL ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
rm -rf usr/
|
rm -rf usr/
|
||||||
../docker-run.sh solanalabs/rust:1.30.1 bash -c "
|
../../ci/docker-run.sh solanalabs/rust:1.30.1 bash -c "
|
||||||
set -ex
|
set -ex
|
||||||
cargo install --path drone --root ci/docker-solana/usr
|
cargo install --path drone --root sdk/docker-solana/usr
|
||||||
cargo install --path . --root ci/docker-solana/usr
|
cargo install --path . --root sdk/docker-solana/usr
|
||||||
"
|
"
|
||||||
cp -f entrypoint.sh usr/bin/solana-entrypoint.sh
|
cp -f entrypoint.sh usr/bin/solana-entrypoint.sh
|
||||||
../../scripts/install-native-programs.sh usr/bin/
|
../../scripts/install-native-programs.sh usr/bin/
|
Reference in New Issue
Block a user