2025-07-13 18:53:58 +01:00
- i n c l u d e $( HOME ) / . R O C K N I X / o p t i o n s
all : world
2009-03-18 13:51:08 +01:00
2009-04-05 23:10:05 +02:00
system :
2010-11-11 17:38:57 +01:00
./scripts/image
2009-04-05 23:10:05 +02:00
2010-01-19 16:07:31 +01:00
release :
2011-08-14 17:11:16 +02:00
./scripts/image release
2009-03-18 13:51:08 +01:00
2013-09-16 18:13:09 +03:00
image :
2013-12-27 21:39:15 +01:00
./scripts/image mkimage
2013-09-16 18:13:09 +03:00
2013-08-25 16:32:37 +02:00
noobs :
./scripts/image noobs
2009-03-18 13:51:08 +01:00
clean :
2022-04-09 02:33:43 +00:00
./scripts/makefile_helper --clean
2009-03-18 13:51:08 +01:00
2016-06-08 21:37:11 +00:00
distclean :
2022-04-09 02:33:43 +00:00
./scripts/makefile_helper --distclean
2016-06-08 21:37:11 +00:00
2009-03-18 13:51:08 +01:00
src-pkg :
2019-12-03 11:10:19 +01:00
tar cvJf sources.tar.xz sources
2025-07-13 18:53:58 +01:00
docs :
./tools/foreach './scripts/clean emulators && ./scripts/build emulators'
world : RK 3588 RK 3566 RK 3326 RK 3399 S 922X SM 8250 SM 8550 H 700
kconfig-olddefconfig-% :
DEVICE = $* ./tools/adjust_kernel_config olddefconfig
kconfig-menuconfig-% :
DEVICE = $* ./tools/adjust_kernel_config menuconfig
AMD64 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = AMD64 ARCH = i686 ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = AMD64 ARCH = x86_64 ./scripts/build_distro
RK3588 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = RK3588 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = RK3588 ARCH = aarch64 ./scripts/build_distro
S922X :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = S922X ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = S922X ARCH = aarch64 ./scripts/build_distro
RK3566 :
unset DEVICE_ROOT
DEVICE_ROOT = RK3566 PROJECT = ROCKNIX DEVICE = RK3566 ARCH = arm ./scripts/build_distro
DEVICE_ROOT = RK3566 PROJECT = ROCKNIX DEVICE = RK3566 ARCH = aarch64 ./scripts/build_distro
RK3326 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = RK3326 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = RK3326 ARCH = aarch64 ./scripts/build_distro
RK3399 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = RK3399 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = RK3399 ARCH = aarch64 ./scripts/build_distro
H700 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = H700 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = H700 ARCH = aarch64 ./scripts/build_distro
2025-07-22 05:33:45 +00:00
SDM845 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = SDM845 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = SDM845 ARCH = aarch64 ./scripts/build_distro
2025-07-13 18:53:58 +01:00
SM8250 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = SM8250 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = SM8250 ARCH = aarch64 ./scripts/build_distro
SM8550 :
unset DEVICE_ROOT
PROJECT = ROCKNIX DEVICE = SM8550 ARCH = arm ./scripts/build_distro
PROJECT = ROCKNIX DEVICE = SM8550 ARCH = aarch64 ./scripts/build_distro
update :
PROJECT = ROCKNIX DEVICE = RK3588 ARCH = aarch64 ./scripts/update_packages
package :
./scripts/build ${ PACKAGE }
package-clean :
./scripts/clean ${ PACKAGE }
## Docker builds - overview
# docker-* commands just wire up docker to call the normal make command via docker
# For example: make docker-AMD64 will use docker to call: make AMD64
# All variables are scoped to docker-* commands to prevent weird collisions/behavior with non-docker commands
docker-% : DOCKER_IMAGE := "ghcr .io /rocknix /rocknix -build :latest "
# DOCKER_WORK_DIR is the directory in the Docker image - it is set to /work by default
# Anytime this directory changes, you must run `make clean` similarly to moving the distribution directory
docker-% : DOCKER_WORK_DIR := $( shell if [ -n "$ {DOCKER_WORK_DIR }" ]; then echo $ {DOCKER_WORK_DIR }; else echo "$ $ ( pwd ) " ; fi )
# ${HOME}/.ROCKNIX/options is a global options file containing developer and build settings.
docker-% : GLOBAL_SETTINGS := $( shell if [ -f "$ {HOME }/.ROCKNIX /options " ]; then echo "-v \"$ {HOME }/.ROCKNIX /options :$ {HOME }/.ROCKNIX /options \""; else echo ""; fi )
# LOCAL_SSH_KEYS_FILE is a variable that contains the location of the authorized keys file for development build use. It will be mounted into the container if it exists.
docker-% : LOCAL_SSH_KEYS_FILE := $( shell if [ -n "$ {LOCAL_SSH_KEYS_FILE }" ]; then echo "-v \"$ {LOCAL_SSH_KEYS_FILE }:$ {LOCAL_SSH_KEYS_FILE }\""; else echo ""; fi )
# EMULATIONSTATION_SRC is a variable that contains the location of local emulationstation source code. It will be mounted into the container if it exists.
docker-% : EMULATIONSTATION_SRC := $( shell if [ -n "$ {EMULATIONSTATION_SRC }" ]; then echo "-v \"$ {EMULATIONSTATION_SRC }:$ {EMULATIONSTATION_SRC }\""; else echo ""; fi )
# UID is the user ID of current user - ensures docker sets file permissions properly
docker-% : UID := $( shell id -u )
# GID is the main user group of current user - ensures docker sets file permissions properly
docker-% : GID := $( shell id -g )
# PWD is 'present working directory' and passes through the full path to current dir to docker (becomes 'work')
docker-% : PWD := $( shell pwd )
# Command to use (either `docker` or `podman`)
docker-% : DOCKER_CMD := $( shell if which docker 2>/dev /null 1>/dev /null ; then echo "docker "; elif which podman 2>/dev /null 1>/dev /null ; then echo "podman "; fi )
# Podman requires some extra args (`--userns=keep-id` and `--security-opt=label=disable`). Set those args if using podman
# Make sure that docker isn't just an alias for podman
docker-% : PODMAN_ARGS := $( shell if echo "$ $ ( docker --version 2>/dev /null || podman --version 2>/dev /null ) " | grep podman 1>/dev /null ; then echo "--userns =keep -id --security -opt =label =disable -v /proc /mounts :/etc /mtab "; fi )
# Launch docker as interactive if this is an interactive shell (allows ctrl-c for manual and running non-interactive - aka: build server)
docker-% : INTERACTIVE =$( shell [ -t 0 ] && echo "-it ")
# By default pass through anything after `docker-` back into `make`
docker-% : COMMAND =make $*
# Get .env file ready
docker-% : $( shell ./scripts /get_env > .env )
# If the user issues a `make docker-shell` just start up bash as the shell to run commands
docker-shell : COMMAND =bash
# Command: builds and saves a docker builder image locally.
# The build user must also be a member of the "docker" group.
docker-image-build :
$( DOCKER_CMD) buildx create --use
$( DOCKER_CMD) buildx build --tag $( DOCKER_IMAGE) --platform $( shell if [ " $( uname -m) " = "aarch64" ] ; then echo "linux/arm64" ; else echo "linux/amd64" ; fi ) --load .
# Command: pulls latest docker image from dockerhub. This will *replace* locally built version.
docker-image-pull :
$( DOCKER_CMD) pull $( DOCKER_IMAGE)
# Wire up docker to call equivalent make files using % to match and $* to pass the value matched by %
docker-% :
BUILD_DIR = $( DOCKER_WORK_DIR) $( DOCKER_CMD) run $( PODMAN_ARGS) $( INTERACTIVE) --init --env-file .env --rm --user $( UID) :$( GID) $( GLOBAL_SETTINGS) $( LOCAL_SSH_KEYS_FILE) $( EMULATIONSTATION_SRC) -v $( PWD) :$( DOCKER_WORK_DIR) -w $( DOCKER_WORK_DIR) $( DOCKER_EXTRA_OPTS) $( DOCKER_IMAGE) $( COMMAND)