annotate Makefile @ 548:3980b707634d prerelease

Added makefile command line options
author Giulio Moro <giuliomoro@yahoo.it>
date Fri, 24 Jun 2016 04:49:40 +0100
parents d0414ec15f63
children e545ce04cf2c
rev   line source
giuliomoro@301 1 # Bela
giuliomoro@64 2 # Low-latency, real-time audio and sensor processing on BeagleBone Black
l@260 3 # (c) 2016 Andrew McPherson, Victor Zappi, Giulio Moro, Liam Donovan
giuliomoro@64 4 # Centre for Digital Music, Queen Mary University of London
giuliomoro@64 5
giuliomoro@548 6 ## This Makefile is intended for use on the BeagleBone Black itself #
giuliomoro@548 7 ## and not for cross-compiling #
giuliomoro@548 8 ## available command line options: #
giuliomoro@548 9 ## EXAMPLE= -- name of the folder in examples/ to be copied to projects/ and built
giuliomoro@548 10 ## PROJECT= -- name of the folder in projects/ to be built
giuliomoro@548 11 ## CL= -- list of command line options to pass to the program when running
giuliomoro@548 12 ## INCLUDES= -- list of additional include paths to pass to the compiler
giuliomoro@548 13 ## CPP_FLAGS= -- list of additional flags passed to the C++ compiler
giuliomoro@548 14 ## C_FLAGS= -- list of additional flags passed to the C compiler
giuliomoro@548 15 ## COMPILER= -- compiler to use (clang or gcc)
giuliomoro@548 16 ## LIBS= -- libs to link in
giuliomoro@548 17 ## AT= -- used instead of @ to silence the output. Defaults AT=@, use AT= for a very verbose output
giuliomoro@548 18 ###
giuliomoro@548 19 ##available targets: #
giuliomoro@386 20 .DEFAULT_GOAL := Bela
giuliomoro@386 21
giuliomoro@548 22 AT?=@
giuliomoro@459 23 NO_PROJECT_TARGETS=help coreclean distclean stop nostartup idestart idestop idestartup idenostartup connect ideconnect update checkupdate updateunsafe
giuliomoro@385 24 NO_PROJECT_TARGETS_MESSAGE=PROJECT or EXAMPLE should be set for all targets except: $(NO_PROJECT_TARGETS)
giuliomoro@424 25 # list of targets that automatically activate the QUIET=true flag
giuliomoro@424 26 QUIET_TARGETS=runide
giuliomoro@424 27
giuliomoro@385 28 # Type `$ make help` to get a description of the functionalities of this Makefile.
giuliomoro@385 29 help: ## Show this help
giuliomoro@548 30 $(AT) echo 'Usage: make [target] CL=[command line options] [PROJECT=[projectName] | EXAMPLE=[exampleName]]'
giuliomoro@548 31 $(AT) printf "\n$(NO_PROJECT_TARGETS_MESSAGE)\n\n"
giuliomoro@548 32 $(AT) echo 'Targets: (default: $(.DEFAULT_GOAL))'
giuliomoro@548 33 $(AT) echo list: $(MAKEFILE_LIST)
giuliomoro@548 34 $(AT) fgrep -h "##" $(MAKEFILE_LIST) | fgrep -v fgrep | sed -e 's/^\(.*\): .*##\(.*\)/\1:#\2/' | sed -e 's/^\(.*\)= .* -- \(.*\)/\1=#\2/' | sed 's/^##//' | awk -F"#" '{ printf "%-18s %-1s\n", $$1, $$2}'
l@260 35
giuliomoro@385 36 # PROJECT or EXAMPLE must be set for targets that are not included in NO_PROJECT_TARGETS
giuliomoro@374 37 ifeq (,$(filter $(NO_PROJECT_TARGETS),$(MAKECMDGOALS)))
giuliomoro@374 38 ifndef PROJECT
giuliomoro@374 39 ifndef EXAMPLE
giuliomoro@385 40 $(error $(NO_PROJECT_TARGETS_MESSAGE))
giuliomoro@374 41 endif
giuliomoro@287 42 endif
l@260 43 endif
l@260 44
giuliomoro@374 45 # if we are building an example, just copy it to the projects/ folder
giuliomoro@386 46 # and then treat it as a project
giuliomoro@374 47 ifdef EXAMPLE
giuliomoro@394 48 #you can alternatively specify PROJECT= along with EXAMPLE=
giuliomoro@374 49 PROJECT?=exampleTempProject
giuliomoro@374 50 PROJECT_DIR?=$(abspath projects/$(PROJECT))
andrewm@380 51 $(shell mkdir -p $(abspath projects))
giuliomoro@374 52 $(shell rm -rf $(PROJECT_DIR))
giuliomoro@374 53 $(shell cp -r examples/$(EXAMPLE) $(PROJECT_DIR))
giuliomoro@374 54 else
giuliomoro@287 55 PROJECT_DIR := $(abspath projects/$(PROJECT))
giuliomoro@287 56 endif
giuliomoro@287 57
giuliomoro@374 58 ifdef PROJECT
giuliomoro@393 59 $(shell mkdir -p $(PROJECT_DIR)/build build/core)
giuliomoro@287 60 endif
giuliomoro@374 61
giuliomoro@331 62 OUTPUT_FILE?=$(PROJECT_DIR)/$(PROJECT)
giuliomoro@331 63 COMMAND_LINE_OPTIONS?=$(CL)
giuliomoro@446 64 RUN_FROM?=$(PROJECT_DIR)
giuliomoro@331 65 RUN_COMMAND?=$(OUTPUT_FILE) $(COMMAND_LINE_OPTIONS)
giuliomoro@396 66 RUN_IDE_COMMAND?=stdbuf -i0 -o0 -e0 $(RUN_COMMAND)
giuliomoro@401 67 BELA_STARTUP_SCRIPT?=/root/Bela_startup.sh
giuliomoro@359 68 BELA_AUDIO_THREAD_NAME?=bela-audio
giuliomoro@377 69 SCREEN_NAME?=Bela
giuliomoro@399 70 BELA_IDE_STARTUP_SCRIPT?=/root/Bela_node.sh
giuliomoro@393 71 BELA_IDE_HOME?=/root/Bela/IDE
giuliomoro@400 72 # A bug in this version of screen forces us to use two screen names which beginning substrings do not match (Bela, Bela-IDE would cause problems)
giuliomoro@400 73 BELA_IDE_SCREEN_NAME?=IDE-Bela
giuliomoro@440 74 BELA_IDE_RUN_COMMAND?=cd $(BELA_IDE_HOME) && screen -S $(BELA_IDE_SCREEN_NAME) -d -m bash -c "while true; do /usr/local/bin/node index.js; sleep 0.5; done"
giuliomoro@393 75 BELA_IDE_STOP_COMMAND?=screen -X -S $(BELA_IDE_SCREEN_NAME) quit > /dev/null
giuliomoro@374 76
giuliomoro@424 77 ifneq (,$(filter $(QUIET_TARGETS),$(MAKECMDGOALS)))
giuliomoro@424 78 QUIET=true
giuliomoro@424 79 endif
giuliomoro@424 80 QUIET?=false
giuliomoro@424 81
giuliomoro@64 82 RM := rm -rf
giuliomoro@64 83 STATIC_LIBS := ./libprussdrv.a ./libNE10.a
giuliomoro@548 84 override LIBS += -lrt -lnative -lxenomai -lsndfile
l@260 85
giuliomoro@244 86 # refresh library cache and check if libpd is there
giuliomoro@326 87 #TEST_LIBPD := $(shell ldconfig; ldconfig -p | grep "libpd\.so") # safest but slower way of checking
giuliomoro@326 88 LIBPD_PATH = /usr/lib/libpd.so
giuliomoro@326 89 TEST_LIBPD := $(shell which $(LIBPD_PATH))
giuliomoro@326 90 ifneq ($(strip $(TEST_LIBPD)), )
giuliomoro@244 91 # if libpd is there, link it in
giuliomoro@244 92 LIBS += -lpd -lpthread_rt
giuliomoro@244 93 endif
giuliomoro@548 94 DEFAULT_CPP_FLAGS := -O3 -march=armv7-a -mtune=cortex-a8 -mfloat-abi=hard -mfpu=neon -ftree-vectorize
giuliomoro@548 95 override CPP_FLAGS := $(DEFAULT_CPP_FLAGS) $(CPP_FLAGS)
giuliomoro@548 96 override C_FLAGS := $(DEFAULT_CPP_FLAGS) $(C_FLAGS)
giuliomoro@64 97
giuliomoro@241 98
giuliomoro@241 99 ifndef COMPILER
giuliomoro@241 100 # check whether clang is installed
giuliomoro@385 101 TEST_COMPILER := $(shell which clang)
giuliomoro@302 102 ifneq ($(strip $(TEST_COMPILER)), )
giuliomoro@385 103 #if it is installed, use it
giuliomoro@302 104 COMPILER := clang
giuliomoro@302 105 else
giuliomoro@241 106 COMPILER := gcc
giuliomoro@302 107 endif
giuliomoro@241 108 endif
giuliomoro@241 109
giuliomoro@241 110 ifeq ($(COMPILER), clang)
giuliomoro@306 111 CC=clang
giuliomoro@306 112 CXX=clang++
giuliomoro@302 113 CPP_FLAGS += -DNDEBUG
giuliomoro@302 114 C_FLAGS += -DNDEBUG
giuliomoro@548 115 else
giuliomoro@548 116 ifeq ($(COMPILER), gcc)
giuliomoro@548 117 CC=gcc
giuliomoro@548 118 CXX=g++
giuliomoro@548 119 CPP_FLAGS += --fast-math
giuliomoro@548 120 C_FLAGS += --fast-math
giuliomoro@548 121 endif
giuliomoro@241 122 endif
giuliomoro@241 123
giuliomoro@548 124 DEFAULT_INCLUDES := -I$(PROJECT_DIR) -I./include -I/usr/include/ne10 -I/usr/xenomai/include -I/usr/arm-linux-gnueabihf/include/xenomai/include -I/usr/arm-linux-gnueabihf/include/ne10
giuliomoro@548 125 override INCLUDES += $(DEFAULT_INCLUDES)
andrewm@68 126
l@260 127 ASM_SRCS := $(wildcard $(PROJECT_DIR)/*.S)
l@260 128 ASM_OBJS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(ASM_SRCS:.S=.o)))
l@260 129 ASM_DEPS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(ASM_SRCS:.S=.d)))
giuliomoro@64 130
l@260 131 C_SRCS := $(wildcard $(PROJECT_DIR)/*.c)
l@260 132 C_OBJS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(C_SRCS:.c=.o)))
l@260 133 C_DEPS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(C_SRCS:.c=.d)))
giuliomoro@64 134
l@260 135 CPP_SRCS := $(wildcard $(PROJECT_DIR)/*.cpp)
l@260 136 CPP_OBJS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(CPP_SRCS:.cpp=.o)))
l@260 137 CPP_DEPS := $(addprefix $(PROJECT_DIR)/build/,$(notdir $(CPP_SRCS:.cpp=.d)))
giuliomoro@64 138
giuliomoro@383 139 PROJECT_OBJS = $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS)
giuliomoro@383 140
giuliomoro@301 141 # Core Bela sources
giuliomoro@463 142 CORE_CPP_SRCS = $(filter-out core/default_main.cpp core/default_libpd_render.cpp, $(wildcard core/*.cpp))
giuliomoro@186 143 CORE_OBJS := $(addprefix build/core/,$(notdir $(CORE_CPP_SRCS:.cpp=.o)))
giuliomoro@186 144 CORE_CPP_DEPS := $(addprefix build/core/,$(notdir $(CORE_CPP_SRCS:.cpp=.d)))
giuliomoro@64 145
andrewm@318 146 CORE_ASM_SRCS := $(wildcard core/*.S)
andrewm@318 147 CORE_ASM_OBJS := $(addprefix build/core/,$(notdir $(CORE_ASM_SRCS:.S=.o)))
andrewm@318 148 CORE_ASM_DEPS := $(addprefix build/core/,$(notdir $(CORE_ASM_SRCS:.S=.d)))
andrewm@318 149
andrewm@318 150
giuliomoro@64 151 # Objects for a system-supplied default main() file, if the user
giuliomoro@64 152 # only wants to provide the render functions.
giuliomoro@64 153 DEFAULT_MAIN_CPP_SRCS := ./core/default_main.cpp
giuliomoro@64 154 DEFAULT_MAIN_OBJS := ./build/core/default_main.o
giuliomoro@64 155 DEFAULT_MAIN_CPP_DEPS := ./build/core/default_main.d
andrewm@68 156
giuliomoro@463 157 # Objects for a system-supplied default render() file for libpd projects,
giuliomoro@463 158 # if the user only wants to provide the Pd files.
giuliomoro@463 159 DEFAULT_PD_CPP_SRCS := ./core/default_libpd_render.cpp
giuliomoro@463 160 DEFAULT_PD_OBJS := ./build/core/default_libpd_render.o
giuliomoro@463 161 DEFAULT_PD_CPP_DEPS := ./build/core/default_libpd_render.d
giuliomoro@463 162
giuliomoro@463 163 Bela: ## Builds the Bela program with all the optimizations
giuliomoro@334 164 Bela: $(OUTPUT_FILE)
giuliomoro@334 165
giuliomoro@301 166 # all = build Bela
giuliomoro@334 167 all: ## Same as Bela
andrewm@69 168 all: SYNTAX_FLAG :=
giuliomoro@301 169 all: Bela
andrewm@68 170
giuliomoro@301 171 # debug = buildBela debug
giuliomoro@334 172 debug: ## Same as Bela but with debug flags and no optimizations
giuliomoro@209 173 debug: CPP_FLAGS=-g
giuliomoro@209 174 debug: C_FLAGS=-g
giuliomoro@209 175 debug: all
giuliomoro@209 176
andrewm@69 177 # syntax = check syntax
giuliomoro@334 178 syntax: ## Only checks syntax
andrewm@69 179 syntax: SYNTAX_FLAG := -fsyntax-only
giuliomoro@478 180 syntax: $(PROJECT_OBJS)
andrewm@69 181
giuliomoro@301 182 # Rule for Bela core C++ files
giuliomoro@64 183 build/core/%.o: ./core/%.cpp
giuliomoro@548 184 $(AT) echo 'Building $(notdir $<)...'
giuliomoro@548 185 # $(AT) echo 'Invoking: C++ Compiler $(CXX)'
giuliomoro@548 186 $(AT) $(CXX) $(SYNTAX_FLAG) $(INCLUDES) $(CPP_FLAGS) -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
giuliomoro@548 187 $(AT) echo ' ...done'
giuliomoro@548 188 $(AT) echo ' '
andrewm@68 189
andrewm@318 190 # Rule for Bela core ASM files
andrewm@318 191 build/core/%.o: ./core/%.S
giuliomoro@548 192 $(AT) echo 'Building $(notdir $<)...'
giuliomoro@548 193 # $(AT) echo 'Invoking: GCC Assembler'
giuliomoro@548 194 $(AT) as -o "$@" "$<"
giuliomoro@548 195 $(AT) echo ' ...done'
giuliomoro@548 196 $(AT) echo ' '
andrewm@318 197
giuliomoro@64 198 # Rule for user-supplied C++ files
l@260 199 $(PROJECT_DIR)/build/%.o: $(PROJECT_DIR)/%.cpp
giuliomoro@548 200 $(AT) echo 'Building $(notdir $<)...'
giuliomoro@548 201 # $(AT) echo 'Invoking: C++ Compiler $(CXX)'
giuliomoro@548 202 $(AT) $(CXX) $(SYNTAX_FLAG) $(INCLUDES) $(CPP_FLAGS) -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<"
giuliomoro@548 203 $(AT) echo ' ...done'
giuliomoro@548 204 $(AT) echo ' '
andrewm@68 205
giuliomoro@64 206 # Rule for user-supplied C files
l@260 207 $(PROJECT_DIR)/build/%.o: $(PROJECT_DIR)/%.c
giuliomoro@548 208 $(AT) echo 'Building $(notdir $<)...'
giuliomoro@548 209 # $(AT) echo 'Invoking: C Compiler $(CC)'
giuliomoro@548 210 $(AT) $(CC) $(SYNTAX_FLAG) $(INCLUDES) $(C_FLAGS) -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" -std=c99
giuliomoro@548 211 $(AT) echo ' ...done'
giuliomoro@548 212 $(AT) echo ' '
andrewm@68 213
giuliomoro@64 214 # Rule for user-supplied assembly files
l@260 215 $(PROJECT_DIR)/build/%.o: $(PROJECT_DIR)/%.S
giuliomoro@548 216 $(AT) echo 'Building $(notdir $<)...'
giuliomoro@548 217 # $(AT) echo 'Invoking: GCC Assembler'
giuliomoro@548 218 $(AT) as -o "$@" "$<"
giuliomoro@548 219 $(AT) echo ' ...done'
giuliomoro@548 220 $(AT) echo ' '
giuliomoro@64 221
giuliomoro@64 222 # This is a nasty kludge: we want to be able to optionally link in a default
giuliomoro@64 223 # main file if the user hasn't supplied one. We check for the presence of the main()
giuliomoro@64 224 # function, and conditionally call one of two recursive make targets depending on whether
giuliomoro@64 225 # we want to link in the default main file or not. The kludge is the mess of a shell script
giuliomoro@64 226 # line below. Surely there's a better way to do this?
giuliomoro@467 227 $(OUTPUT_FILE): $(CORE_ASM_OBJS) $(CORE_OBJS) $(PROJECT_OBJS) $(STATIC_LIBS) $(DEFAULT_MAIN_OBJS) $(DEFAULT_PD_OBJS)
giuliomoro@463 228 $(eval DEFAULT_MAIN_CONDITIONAL :=\
giuliomoro@463 229 $(shell bash -c '[ `nm $(PROJECT_OBJS) 2>/dev/null | grep -w T | grep -w main | wc -l` == '0' ] && echo "$(DEFAULT_MAIN_OBJS)" || : '))
giuliomoro@548 230 $(AT) #If there is a .pd file AND there is no "render" symbol then link in the $(DEFAULT_PD_OBJS)
giuliomoro@463 231 $(eval DEFAULT_PD_CONDITIONAL :=\
giuliomoro@470 232 $(shell bash -c '{ ls $(PROJECT_DIR)/*.pd &>/dev/null && [ `nm $(PROJECT_OBJS) 2>/dev/null | grep -w T | grep "render.*BelaContext" | wc -l` -eq 0 ]; } && echo '$(DEFAULT_PD_OBJS)' || : ' ))
giuliomoro@548 233 $(AT) echo 'Linking...'
giuliomoro@548 234 $(AT) $(CXX) $(SYNTAX_FLAG) $(LDFLAGS) -L/usr/xenomai/lib -L/usr/arm-linux-gnueabihf/lib -L/usr/arm-linux-gnueabihf/lib/xenomai -L/usr/lib/arm-linux-gnueabihf -pthread -Wpointer-arith -o "$(PROJECT_DIR)/$(PROJECT)" $(CORE_ASM_OBJS) $(CORE_OBJS) $(DEFAULT_MAIN_CONDITIONAL) $(DEFAULT_PD_CONDITIONAL) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS)
giuliomoro@548 235 $(AT) echo ' ...done'
l@387 236
l@260 237 # Other Targets:
giuliomoro@548 238 projectclean: ## Remove the PROJECT's build objects & binary
giuliomoro@326 239 -$(RM) $(PROJECT_DIR)/build/* $(OUTPUT_FILE)
giuliomoro@64 240 -@echo ' '
giuliomoro@64 241
giuliomoro@386 242 clean: ## Same as projectclean
giuliomoro@386 243 clean: projectclean
giuliomoro@386 244
giuliomoro@386 245 coreclean: ## Remove the core's build objects
giuliomoro@394 246 -$(RM) build/core/*
giuliomoro@386 247
giuliomoro@386 248 prompt:
giuliomoro@548 249 $(AT) printf "Warning: you are about to DELETE the projects/ folder and its content. This operation cannot be undone. Continue? (y/N) "
giuliomoro@548 250 $(AT) read REPLY; if [ $$REPLY != y ] && [ $$REPLY != Y ]; then echo "Aborting..."; exit 1; fi
giuliomoro@386 251
giuliomoro@386 252 distclean: ## Restores the Bela folder to a pristine state: remove all the projects source and the built objects, including the core Bela objects.
giuliomoro@386 253 distclean: prompt distcleannoprompt
giuliomoro@386 254
giuliomoro@386 255 distcleannoprompt: ## Same as distclean, but does not prompt for confirmation. Use with care.
giuliomoro@326 256 -$(RM) build/source/* $(CORE_OBJS) $(CORE_CPP_DEPS) $(DEFAULT_MAIN_OBJS) $(DEFAULT_MAIN_CPP_DEPS) $(OUTPUT_FILE)
giuliomoro@64 257 -@echo ' '
giuliomoro@64 258
giuliomoro@548 259 $(warning C_FLAGS $(C_FLAGS))
giuliomoro@548 260 $(warning CPP_FLAGS $(CPP_FLAGS))
giuliomoro@548 261 $(warning LIBS $(LIBS))
giuliomoro@548 262 $(warning INCLUDES $(INCLUDES))
giuliomoro@302 263 runfg: run
giuliomoro@334 264 run: ## Run PROJECT in the foreground
giuliomoro@326 265 run: stop Bela
giuliomoro@548 266 $(AT) echo "Running $(RUN_COMMAND)"
giuliomoro@548 267 $(AT) sync& cd $(RUN_FROM) && $(RUN_COMMAND)
giuliomoro@424 268 runide: ## Run PROJECT for IDE (foreground, no buffering)
giuliomoro@424 269 runide: stop Bela
giuliomoro@548 270 $(AT) sync& cd $(RUN_FROM) && $(RUN_IDE_COMMAND)
giuliomoro@334 271 runscreen: ## Run PROJECT in the background (detached screen)
giuliomoro@302 272 runscreen: stop $(OUTPUT_FILE)
giuliomoro@548 273 $(AT) echo "Running $(RUN_COMMAND) in a screen"
giuliomoro@548 274 $(AT) cd $(RUN_FROM) && screen -S $(SCREEN_NAME) -d -m $(RUN_COMMAND)
giuliomoro@334 275 runscreenfg: ## Run PROJECT in a screen in the foreground (can detach with ctrl-a ctrl-d)
giuliomoro@313 276 runscreenfg: stop $(OUTPUT_FILE)
giuliomoro@548 277 $(AT) echo "Running $(RUN_COMMAND) in a screen"
giuliomoro@548 278 $(AT) cd $(RUN_FROM) && screen -S $(SCREEN_NAME) -m $(RUN_COMMAND)
giuliomoro@302 279
giuliomoro@331 280 STARTUP_COMMAND=printf "\#!/bin/sh\n\#\n\# This file is autogenerated by Bela. Do not edit!\n\necho Running Bela...\nscreen -S $(SCREEN_NAME) -d -m %s $(RUN_COMMAND) %s\n"
giuliomoro@334 281 nostartup: ## No Bela project runs at startup
giuliomoro@331 282 nostartup:
giuliomoro@548 283 $(AT) echo "Disabling Bela at startup..."
giuliomoro@548 284 $(AT) printf "#!/bin/sh\n#\n\n# This file is autogenerated by Bela. Do not edit!\n\n# Run on startup disabled -- nothing to do here\n" > $(BELA_STARTUP_SCRIPT)
giuliomoro@331 285
giuliomoro@334 286 startuploop: ## Makes PROJECT run at startup and restarts it if it crashes
giuliomoro@331 287 startuploop: Bela
giuliomoro@548 288 $(AT) echo "Enabling Bela at startup in a loop..."
giuliomoro@548 289 $(AT) $(STARTUP_COMMAND) 'bash -c "while sleep 0.5 ; do echo Running Bela...;' '; done"' > $(BELA_STARTUP_SCRIPT)
giuliomoro@331 290
giuliomoro@334 291 startup: ## Makes PROJECT run at startup
giuliomoro@331 292 startup: Bela
giuliomoro@548 293 $(AT) echo "Enabling Bela at startup..."
giuliomoro@548 294 $(AT) $(STARTUP_COMMAND) > $(BELA_STARTUP_SCRIPT)
giuliomoro@548 295 $(AT) chmod +x $(BELA_STARTUP_SCRIPT)
giuliomoro@334 296 stop: ## Stops any Bela program that is currently running
giuliomoro@302 297 stop:
giuliomoro@548 298 $(AT) PID=`grep $(BELA_AUDIO_THREAD_NAME) /proc/xenomai/stat | cut -d " " -f 5 | sed s/\s//g`; if [ -z $$PID ]; then [ $(QUIET) = true ] || echo "No process to kill"; else [ $(QUIET) = true ] || echo "Killing old Bela process $$PID"; kill -2 $$PID; fi; screen -X -S $(SCREEN_NAME) quit > /dev/null; exit 0;
giuliomoro@64 299
giuliomoro@417 300 connect: ## Connects to the running Bela program (if any), can detach with ctrl-a ctrl-d.
giuliomoro@548 301 $(AT) screen -r -S $(SCREEN_NAME)
giuliomoro@417 302
giuliomoro@409 303 idestart: ## Starts the on-board IDE
giuliomoro@410 304 idestart: idestop
giuliomoro@548 305 $(AT) printf "Starting IDE..."
giuliomoro@548 306 $(AT) $(BELA_IDE_RUN_COMMAND)
giuliomoro@548 307 $(AT) printf "done\n"
giuliomoro@393 308
giuliomoro@393 309 idestop: ## Stops the on-board IDE
giuliomoro@548 310 $(AT) printf "Stopping currently running IDE..."
giuliomoro@548 311 $(AT) screen -X -S $(BELA_IDE_SCREEN_NAME) quit > /dev/null; exit 0;
giuliomoro@548 312 $(AT) printf "done\n"
giuliomoro@393 313
giuliomoro@440 314 BELA_IDE_STARTUP_COMMAND=printf '\#!/bin/sh\n\#\n\# This file is autogenerated by Bela. Do not edit!\n\necho Running the Bela IDE...\n$(BELA_IDE_RUN_COMMAND)\n' > $(BELA_IDE_STARTUP_SCRIPT)
giuliomoro@393 315
giuliomoro@399 316 idestartup: ## Enables the IDE at startup
giuliomoro@548 317 $(AT) echo "Enabling the IDE at startup"
giuliomoro@548 318 $(AT) $(BELA_IDE_STARTUP_COMMAND)
giuliomoro@548 319 $(AT) chmod +x $(BELA_IDE_STARTUP_SCRIPT)
giuliomoro@393 320
giuliomoro@393 321 idenostartup: ## Disables the IDE at startup
giuliomoro@548 322 $(AT) echo "Disabling the IDE at startup"
giuliomoro@548 323 $(AT) printf "#!/bin/sh\n#\n\n# This file is autogenerated by Bela. Do not edit!\n\n# The Bela IDE is disabled on startup.\n" > $(BELA_IDE_STARTUP_SCRIPT)
giuliomoro@417 324
giuliomoro@417 325 ideconnect: ## Brings in the foreground the IDE that currently is running in a screen (if any), can detach with ctrl-a ctrl-d.
giuliomoro@548 326 $(AT) screen -r -S $(BELA_IDE_SCREEN_NAME)
giuliomoro@417 327
giuliomoro@448 328 BELA_DIR:=$(shell dirname $(realpath $(lastword $(MAKEFILE_LIST))))
giuliomoro@448 329 UPDATES_DIR?=/root/Bela/updates
giuliomoro@453 330 UPDATE_SOURCE_DIR_BASE?=/tmp/belaUpdate
giuliomoro@453 331 UPDATE_SOURCE_DIR=$(UPDATE_SOURCE_DIR_BASE)/Bela
giuliomoro@448 332 UPDATE_REQUIRED_PATHS?=scripts include core scripts/update_board
giuliomoro@453 333 UPDATE_BELA_PATCH?=/tmp/belaPatch
giuliomoro@448 334 UPDATE_BELA_BACKUP?=/tmp/belaBak
giuliomoro@448 335 UPDATE_BELA_MV_BACKUP?=/tmp/belaMvBak
giuliomoro@448 336
giuliomoro@448 337 updateclean: ## Cleans the $(UPDATES_DIR) folder
giuliomoro@548 338 $(AT) [ -n $(UPDATE_DIR) ] && rm -rf $(UPDATE_DIR) && mkdir -p $(UPDATE_DIR)
giuliomoro@448 339
giuliomoro@448 340 checkupdate: ## Unzips the zip file in $(UPDATES_DIR) and checks that it contains a valid
giuliomoro@548 341 $(AT) echo Validating archive...
giuliomoro@548 342 $(AT) cd $(UPDATES_DIR) && COUNT=`ls -l *.zip | wc -l` && [ $$COUNT -eq 1 ] && rm -rf `ls | grep -v "\.zip$$"`
giuliomoro@548 343 $(AT) #TODO: heuristics on available space. Use unzip -l and df
giuliomoro@548 344 $(AT) echo uncompressed size: `unzip -l \`ls $(UPDATES_DIR)/*.zip\` | tail -n1 | awk '{print $$1}'`
giuliomoro@548 345 $(AT) # Delete and re-create the temp directory (first, make sure it is not an empty string!)
giuliomoro@548 346 $(AT) [ -n $(UPDATE_SOURCE_DIR_BASE) ] && rm -rf $(UPDATE_SOURCE_DIR_BASE) && mkdir -p $(UPDATE_SOURCE_DIR_BASE)
giuliomoro@548 347 $(AT) echo Unzipping archive...
giuliomoro@548 348 $(AT) cd $(UPDATE_SOURCE_DIR_BASE) && unzip -qq $(UPDATES_DIR)/*zip
giuliomoro@458 349 #TODO: this should not be needed. Remove comments. Strip the top-level folder ( if there is only one )
giuliomoro@453 350 #@DIR=`ls -d $(UPDATE_SOURCE_DIR)` && COUNT=`echo $$DIR | wc -l` &&\
giuliomoro@448 351 [ $$COUNT -eq 1 ] && mv $(UPDATE_SOURCE_DIR)/* /tmp/supertemp && rm -rf $(UPDATE_SOURCE_DIR) && mv /tmp/supertemp $(UPDATE_SOURCE_DIR)
giuliomoro@458 352
giuliomoro@548 353 $(AT) echo Validating unzipped archive...
giuliomoro@548 354 $(AT) cd $(UPDATE_SOURCE_DIR) && FAIL=0 && for path in $(UPDATE_REQUIRED_PATHS); do `ls $$path >/dev/null 2>&1` || { FAIL=1; break; }; done;\
giuliomoro@448 355 [ $$FAIL -eq 0 ] || { echo "$$path was not found in the zip archive. Maybe it is corrupted?"; exit 1; }
giuliomoro@548 356 $(AT) echo ...done
giuliomoro@448 357 UPDATE_LOG?=~/update.log
giuliomoro@448 358 LOG=>> $(UPDATE_LOG) 2>&1
giuliomoro@459 359 updateunsafe: ## Installs the update from $(UPDATES_DIR) in a more brick-friendly way
giuliomoro@548 360 $(AT) echo > $(UPDATE_LOG)
giuliomoro@459 361 # Re-perform the check, just in case ...
giuliomoro@548 362 $(AT) cd $(UPDATE_SOURCE_DIR) && FAIL=0 && for path in $(UPDATE_REQUIRED_PATHS); do `ls $$path >/dev/null 2>&1` || { FAIL=1; break; }; done;\
giuliomoro@459 363 [ $$FAIL -eq 0 ] || { echo "$$path was not found in the zip archive. Maybe it is corrupted?"; exit 1; }
giuliomoro@548 364 $(AT) cd $(UPDATE_SOURCE_DIR)/scripts && BBB_ADDRESS=root@127.0.0.1 BBB_BELA_HOME=$(BELA_DIR) ./update_board -y --no-frills
giuliomoro@548 365 $(AT) screen -S update-Bela -d -m bash -c "echo Restart the IDE $(LOG) &&\
giuliomoro@459 366 $(MAKE) --no-print-directory idestart $(LOG) && echo Update succesful $(LOG);" $(LOG)
giuliomoro@448 367 update: ## Installs the update from $(UPDATES_DIR)
giuliomoro@448 368 update: stop
giuliomoro@548 369 $(AT) # Truncate the log file
giuliomoro@548 370 $(AT) echo > $(UPDATE_LOG)
giuliomoro@548 371 $(AT) echo Re-perform the check, just in case ... >> $(UPDATE_LOG)
giuliomoro@548 372 $(AT) cd $(UPDATE_SOURCE_DIR) && FAIL=0 && for path in $(UPDATE_REQUIRED_PATHS); do `ls $$path >/dev/null 2>&1` || { FAIL=1; break; }; done;\
giuliomoro@448 373 [ $$FAIL -eq 0 ] || { echo "$$path was not found in the zip archive. Maybe it is corrupted?"; exit 1; }
giuliomoro@548 374 $(AT) [ -n $(UPDATE_BELA_PATCH) ] && mkdir -p $(UPDATE_BELA_PATCH)
giuliomoro@548 375 $(AT) #TODO: this would allow to trim trailing slashes in case we want to be safer: a="`pwd`/" ; target=${a%/} ; echo $target
giuliomoro@548 376 $(AT) $(MAKE) --no-print-directory coreclean
giuliomoro@548 377 $(AT) echo Backing up $(BELA_DIR) to $(UPDATE_BELA_PATCH) ... | tee -a $(UPDATE_LOG)
giuliomoro@548 378 $(AT) rsync -a --delete-during --exclude Documentation $(BELA_DIR)/ $(UPDATE_BELA_PATCH)
giuliomoro@548 379 $(AT) echo Backing up $(BELA_DIR) to $(UPDATE_BELA_BACKUP) ... | tee -a $(UPDATE_LOG)
giuliomoro@548 380 $(AT) [ -n $(UPDATE_BELA_BACKUP) ] && mkdir -p $(UPDATE_BELA_BACKUP)
giuliomoro@548 381 $(AT) rsync -a --delete-during $(BELA_DIR)/ $(UPDATE_BELA_BACKUP)
giuliomoro@548 382 $(AT) echo Running update script... | tee -a $(UPDATE_LOG)
giuliomoro@548 383 $(AT) cd $(UPDATE_SOURCE_DIR)/scripts && BBB_ADDRESS=root@127.0.0.1 BBB_BELA_HOME=$(UPDATE_BELA_PATCH) ./update_board -y --no-frills
giuliomoro@548 384 $(AT) # If everything went ok, we now have the updated version of $(BELA_DIR) in $(UPDATE_BELA_PATCH) and a backup of $(BELA_DIR) in $(UPDATE_BELA_BACKUP)
giuliomoro@548 385 $(AT) # So let's operate the magic swap. $(BELA_DIR) is moved to $(UPDATE_BELA_MV_BACKUP) and $(UPDATE_BELA_PATCH) is moved to $(BELA_DIR).
giuliomoro@548 386 $(AT) # If something goes wrong at thie stage, you can always find your old $(BELA_DIR) folder at $(UPDATE_BELA_BACKUP)
giuliomoro@548 387 $(AT) # The fun part is that this Makefile is moved as well...
giuliomoro@548 388 $(AT) # We are about to kill the IDE, so just in case you are running this from within the IDE, we run the remainder of this update in a screen.
giuliomoro@548 389 $(AT) # Output will be logged to $(UPDATE_LOG)
giuliomoro@548 390 $(AT) echo Restoring directory structure... | tee -a $(UPDATE_LOG)
giuliomoro@548 391 $(AT) screen -S update-Bela -d -m bash -c '\
giuliomoro@448 392 [ -n $(UPDATE_BELA_MV_BACKUP) ] $(LOG) && rm -rf $(UPDATE_BELA_MV_BACKUP) $(LOG) &&\
giuliomoro@448 393 echo Kill the IDE $(LOG) && \
giuliomoro@448 394 $(MAKE) --no-print-directory idestop $(LOG) &&\
giuliomoro@453 395 mv $(BELA_DIR) $(UPDATE_BELA_MV_BACKUP) $(LOG) && mv $(UPDATE_BELA_PATCH) $(BELA_DIR) $(LOG) &&\
giuliomoro@448 396 echo Hope we are still alive here $(LOG) &&\
giuliomoro@448 397 echo Restart the IDE $(LOG) &&\
giuliomoro@448 398 make --no-print-directory -C $(BELA_DIR) idestart $(LOG) &&\
giuliomoro@448 399 echo Update succesful $(LOG); \
giuliomoro@448 400 ' $(LOG)
giuliomoro@448 401
giuliomoro@526 402 .PHONY: all clean distclean help projectclean nostartup startup startuploop debug run runfg runscreen runscreenfg stop idestart idestop idestartup idenostartup ideconnect connect update checkupdate updateunsafe