Compare commits
2 commits
c7d40b828b
...
4d9c9e2ac4
Author | SHA1 | Date | |
---|---|---|---|
![]() |
4d9c9e2ac4 | ||
![]() |
a4699b9bc8 |
10
.github/workflows/rust.yml
vendored
10
.github/workflows/rust.yml
vendored
|
@ -36,9 +36,9 @@ jobs:
|
||||||
run: output=$(git status --porcelain) && [ -z "$output" ]
|
run: output=$(git status --porcelain) && [ -z "$output" ]
|
||||||
|
|
||||||
- name: build example -- glibc release
|
- name: build example -- glibc release
|
||||||
run: cd example && make clean && make LIBC=gnu LINK=dynamic PROFILE=release
|
run: cd example && make -r clean-all && make -r LIBC=gnu LINK=dynamic PROFILE=release
|
||||||
- name: build example -- glibc debug
|
- name: build example -- glibc debug
|
||||||
run: cd example && make clean && make LIBC=gnu LINK=dynamic PROFILE=debug
|
run: cd example && make -r clean-all && make -r LIBC=gnu LINK=dynamic PROFILE=debug
|
||||||
|
|
||||||
build-size-gnu-unstable:
|
build-size-gnu-unstable:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
@ -52,6 +52,6 @@ jobs:
|
||||||
- name: install rust targets
|
- name: install rust targets
|
||||||
run: rustup toolchain install nightly -t aarch64-unknown-linux-gnu -c rust-src --no-self-update
|
run: rustup toolchain install nightly -t aarch64-unknown-linux-gnu -c rust-src --no-self-update
|
||||||
|
|
||||||
- name: build example -- glibc size-optimized
|
- name: build example -- glibc size_optimized
|
||||||
run: cd example && make clean
|
run: cd example && make clean-all -r
|
||||||
&& make LIBC=gnu LINK=dynamic PROFILE=size-optimized CARGO="rustup run nightly cargo" LTO=1
|
&& make -r LIBC=gnu LINK=dynamic PROFILE=size_optimized CARGO="rustup run nightly cargo" LTO=1
|
||||||
|
|
|
@ -40,7 +40,7 @@ missing_safety_doc = "allow"
|
||||||
[package.metadata.docs.rs]
|
[package.metadata.docs.rs]
|
||||||
all-features = true
|
all-features = true
|
||||||
|
|
||||||
[profile.size-optimized]
|
[profile.size_optimized]
|
||||||
inherits = "release"
|
inherits = "release"
|
||||||
opt-level = 'z' # Optimize for size
|
opt-level = 'z' # Optimize for size
|
||||||
lto = true # Enable link-time optimization
|
lto = true # Enable link-time optimization
|
||||||
|
|
|
@ -11,8 +11,8 @@ ifeq (,$(filter dynamic static,$(_link_type)))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
_profile := $(if $(PROFILE),$(PROFILE),release)
|
_profile := $(if $(PROFILE),$(PROFILE),release)
|
||||||
ifeq (,$(filter release debug size-optimized,$(_profile)))
|
ifeq (,$(filter release debug size_optimized,$(_profile)))
|
||||||
_profile := $(error "PROFILE has to be set to one of: debug, release, size-optimized")
|
_profile := $(error "PROFILE has to be set to one of: debug, release, size_optimized")
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ARCH ?= $(shell uname -m)
|
ARCH ?= $(shell uname -m)
|
||||||
|
@ -34,6 +34,7 @@ FEATURES := ""#"env_logger"
|
||||||
|
|
||||||
THIS_DIR := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
|
THIS_DIR := $(dir $(realpath $(lastword $(MAKEFILE_LIST))))
|
||||||
REPO_ROOT := $(realpath $(THIS_DIR)/..)
|
REPO_ROOT := $(realpath $(THIS_DIR)/..)
|
||||||
|
CARGO_OBJDIR := cargo/$(RUST_TARGET)/$(_profile)
|
||||||
|
|
||||||
# TODO: check if override is needed
|
# TODO: check if override is needed
|
||||||
_rust_cli_profile := $(if $(filter $(_profile),debug),dev,$(_profile))
|
_rust_cli_profile := $(if $(filter $(_profile),debug),dev,$(_profile))
|
||||||
|
@ -43,7 +44,7 @@ _rust_cli_profile := $(if $(filter $(_profile),debug),dev,$(_profile))
|
||||||
STRIPFLAGS += -s --strip-unneeded -R .comment -R .gnu.version -R .note -R .note.gnu.build-id -R .note.ABI-tag
|
STRIPFLAGS += -s --strip-unneeded -R .comment -R .gnu.version -R .note -R .note.gnu.build-id -R .note.ABI-tag
|
||||||
STATIC_LINK_LIBS += -lservicepoint_binding_c
|
STATIC_LINK_LIBS += -lservicepoint_binding_c
|
||||||
|
|
||||||
size-optimized_CARGOFLAGS += -Zbuild-std="core,std,alloc,proc_macro,panic_abort" \
|
size_optimized_CARGOFLAGS += -Zbuild-std="core,std,alloc,proc_macro,panic_abort" \
|
||||||
-Zbuild-std-features="panic_immediate_abort"
|
-Zbuild-std-features="panic_immediate_abort"
|
||||||
CARGOFLAGS += --manifest-path=$(REPO_ROOT)/Cargo.toml \
|
CARGOFLAGS += --manifest-path=$(REPO_ROOT)/Cargo.toml \
|
||||||
--profile=$(_rust_cli_profile) \
|
--profile=$(_rust_cli_profile) \
|
||||||
|
@ -55,7 +56,7 @@ CARGOFLAGS += --manifest-path=$(REPO_ROOT)/Cargo.toml \
|
||||||
|
|
||||||
CFLAGS += -Wall -Wextra -pedantic -fwhole-program -fPIE -pie
|
CFLAGS += -Wall -Wextra -pedantic -fwhole-program -fPIE -pie
|
||||||
_no_debug_cflags := -ffunction-sections -fdata-sections -Wl,--gc-sections
|
_no_debug_cflags := -ffunction-sections -fdata-sections -Wl,--gc-sections
|
||||||
size-optimized_CFLAGS += -Oz \
|
size_optimized_CFLAGS += -Oz \
|
||||||
-fwrapv -fomit-frame-pointer -fno-stack-protector\
|
-fwrapv -fomit-frame-pointer -fno-stack-protector\
|
||||||
-fno-unroll-loops \
|
-fno-unroll-loops \
|
||||||
-fno-unwind-tables -fno-asynchronous-unwind-tables \
|
-fno-unwind-tables -fno-asynchronous-unwind-tables \
|
||||||
|
@ -68,13 +69,20 @@ size-optimized_CFLAGS += -Oz \
|
||||||
-fno-ident \
|
-fno-ident \
|
||||||
-fno-exceptions \
|
-fno-exceptions \
|
||||||
$(_no_debug_cflags)
|
$(_no_debug_cflags)
|
||||||
|
|
||||||
release_CFLAGS += -O2 \
|
release_CFLAGS += -O2 \
|
||||||
$(_no_debug_cflags)
|
$(_no_debug_cflags)
|
||||||
debug_CFLAGS += -Og
|
debug_CFLAGS += -Og
|
||||||
static_CFLAGS += -static $(STATIC_LINK_LIBS)
|
static_CFLAGS += -static $(STATIC_LINK_LIBS)
|
||||||
dynamic_CFLAGS += -Wl,-Bstatic $(STATIC_LINK_LIBS) -Wl,-Bdynamic
|
dynamic_CFLAGS += -Wl,-Bstatic $(STATIC_LINK_LIBS) -Wl,-Bdynamic
|
||||||
|
|
||||||
size-optimized_RUSTFLAGS += -Zlocation-detail=none \
|
_servicepoint_cflags := -I $(REPO_ROOT)/include -L $(CARGO_OBJDIR)
|
||||||
|
CFLAGS += $($(_libc)_CFLAGS) $($(_profile)_CFLAGS) $($(_link_type)_CFLAGS) $(_servicepoint_cflags)
|
||||||
|
ifeq ($(LTO), 1)
|
||||||
|
CFLAGS += -flto
|
||||||
|
endif
|
||||||
|
|
||||||
|
size_optimized_RUSTFLAGS += -Zlocation-detail=none \
|
||||||
-Zfmt-debug=none \
|
-Zfmt-debug=none \
|
||||||
-C link-arg=-z,norelro \
|
-C link-arg=-z,norelro \
|
||||||
-C panic=abort
|
-C panic=abort
|
||||||
|
@ -86,39 +94,28 @@ ifneq ($(_profile), debug)
|
||||||
RUSTFLAGS += -C link-arg=-s -C link-arg=-Wl,--gc-sections
|
RUSTFLAGS += -C link-arg=-s -C link-arg=-Wl,--gc-sections
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CARGO_OBJDIR := cargo/$(RUST_TARGET)/$(_profile)
|
|
||||||
_servicepoint_cflags := -I $(REPO_ROOT)/include -L $(CARGO_OBJDIR)
|
|
||||||
|
|
||||||
CFLAGS += $($(_libc)_CFLAGS) $($(_profile)_CFLAGS) $($(_link_type)_CFLAGS) $(_servicepoint_cflags)
|
|
||||||
ifeq ($(LTO), 1)
|
|
||||||
CFLAGS += -flto
|
|
||||||
endif
|
|
||||||
|
|
||||||
# TODO: wildcard does not work with VPATH
|
# TODO: wildcard does not work with VPATH
|
||||||
_c_src := src/announce.c src/brightness_tester.c src/header_logger.c \
|
_c_src := src/announce.c src/brightness_tester.c src/header_logger.c \
|
||||||
src/moving_line.c src/random_stuff.c src/wiping_clear.c
|
src/moving_line.c src/random_stuff.c src/wiping_clear.c
|
||||||
_programs := $(basename $(notdir $(_c_src)))
|
_programs := $(basename $(notdir $(_c_src)))
|
||||||
_bins := $(_programs)
|
_bins := $(_programs)
|
||||||
_unstripped_bins := $(addsuffix _unstripped, $(_bins))
|
_unstripped_bins := $(addsuffix _unstripped, $(_bins))
|
||||||
_run_programs := $(addprefix run_, $(_programs))
|
|
||||||
|
|
||||||
# TODO: use cargo --target-dir to put rust binaries into same dir
|
.SUFFIXES:
|
||||||
|
|
||||||
|
.PHONY: all build-rust
|
||||||
|
|
||||||
all: $(_bins)
|
all: $(_bins)
|
||||||
|
|
||||||
.PHONY: all clean sizes $(_run_programs) clean-c clean-rust build-rust help FORCE
|
|
||||||
|
|
||||||
$(_unstripped_bins): %_unstripped: src/%.c src/helpers.h build-rust
|
$(_unstripped_bins): %_unstripped: src/%.c src/helpers.h build-rust
|
||||||
$(CC) $< $(CFLAGS) -o $@
|
$(CC) $< $(CFLAGS) -o $@
|
||||||
|
|
||||||
$(_bins): %: %_unstripped
|
$(_bins): %: %_unstripped
|
||||||
$(STRIP) $(STRIPFLAGS) $^ -o $@
|
$(STRIP) $(STRIPFLAGS) $^ -o $@
|
||||||
|
|
||||||
build-rust: FORCE
|
build-rust:
|
||||||
# generate servicepoint header and library to link against
|
# generate servicepoint header and library to link against
|
||||||
$(CARGO) rustc $(CARGOFLAGS) -- $(RUSTFLAGS)
|
$(CARGO) rustc $(CARGOFLAGS) -- $(RUSTFLAGS)
|
||||||
|
|
||||||
FORCE: ;
|
|
||||||
|
|
||||||
#----- Begin Boilerplate
|
#----- Begin Boilerplate
|
||||||
endif
|
endif
|
|
@ -33,7 +33,7 @@ Makefile : ;
|
||||||
# and the source directory containing only source files, `clean' is as trivial
|
# and the source directory containing only source files, `clean' is as trivial
|
||||||
# as removing the target directories!
|
# as removing the target directories!
|
||||||
#
|
#
|
||||||
.PHONY: clean clean-all
|
.PHONY: clean clean-all help
|
||||||
clean:
|
clean:
|
||||||
rm -rf $(OBJDIR)
|
rm -rf $(OBJDIR)
|
||||||
clean-all:
|
clean-all:
|
||||||
|
@ -45,8 +45,12 @@ help:
|
||||||
@echo "Variable | Description | Default | Values"
|
@echo "Variable | Description | Default | Values"
|
||||||
@echo "---------+----------------------+-----------+---------------------------"
|
@echo "---------+----------------------+-----------+---------------------------"
|
||||||
@echo "LIBC | libc to link against | 'gnu' | 'gnu' or 'musl'"
|
@echo "LIBC | libc to link against | 'gnu' | 'gnu' or 'musl'"
|
||||||
@echo "PROFILE | Optimization profile | 'release' | 'debug' or 'size-optimized'"
|
@echo "PROFILE | Optimization profile | 'release' | 'debug' or 'size_optimized'"
|
||||||
@echo "LINK | | 'dynamic' | 'dynamic' or 'static'"
|
@echo "LINK | | 'dynamic' | 'dynamic' or 'static'"
|
||||||
@echo "CARGO | cargo binary to use | 'cargo' | 'rustup run nightly cargo'"
|
@echo "CARGO | cargo binary to use | 'cargo' | 'rustup run nightly cargo'"
|
||||||
@echo "CC | C compiler to use | 'gcc' | 'musl-gcc'"
|
@echo "CC | C compiler to use | 'gcc' | 'musl-gcc'"
|
||||||
@echo "STRIP | strip command to use | 'strip' | -"
|
@echo "STRIP | strip command to use | 'strip' | -"
|
||||||
|
@echo ""
|
||||||
|
@echo "When building this project, each configuration will result in a separate output directory."
|
||||||
|
@echo "The target clean only removes the output directory of the specified configuration."
|
||||||
|
@echo "The target clean-all can be used to remove the builds of all configurations."
|
||||||
|
|
Loading…
Reference in a new issue