Mercurial > hg > beaglert
changeset 288:771a0920c626 prerelease
merge
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Wed, 18 May 2016 01:50:01 +0100 |
parents | 4815ed0f21de (diff) bfe2e929304b (current diff) |
children | 156e6955ccf6 |
files | |
diffstat | 2 files changed, 31 insertions(+), 26 deletions(-) [+] |
line wrap: on
line diff
--- a/Makefile Tue May 17 18:31:43 2016 +0100 +++ b/Makefile Wed May 18 01:50:01 2016 +0100 @@ -11,10 +11,23 @@ # if the PROJECT variable is not set, throw an error and exit # otherwise, we could have unexpected data loss when calling clean without it ifndef PROJECT - $(error PROJECT is not set) + ifndef EXAMPLE + $(error PROJECT or EXAMPLE should be set) + endif endif -PROJECT_DIR := $(abspath projects/$(PROJECT)) +ifndef EXAMPLE + PROJECT_DIR := $(abspath projects/$(PROJECT)) +endif + +ifdef EXAMPLE + PROJECT?=exampleTempProject + PROJECT_DIR?=$(abspath projects/$(PROJECT)) + $(shell rm -rf $(PROJECT_DIR)) + $(shell cp -r examples/$(EXAMPLE) $(PROJECT_DIR)) + EXAMPLE:=that +endif + $(shell mkdir -p $(PROJECT_DIR)/build) RM := rm -rf STATIC_LIBS := ./libprussdrv.a ./libNE10.a @@ -112,7 +125,7 @@ $(PROJECT_DIR)/build/%.o: $(PROJECT_DIR)/%.c @echo 'Building $(notdir $<)...' # @echo 'Invoking: C Compiler' - @$(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 + $(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 @echo ' ...done' @echo ' ' @@ -129,27 +142,12 @@ # function, and conditionally call one of two recursive make targets depending on whether # we want to link in the default main file or not. The kludge is the mess of a shell script # line below. Surely there's a better way to do this? -BeagleRT: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - $(eval NEXT_TARGET := $(shell bash -c 'if [ `nm $(PROJECT_DIR)/build/*.o | grep -w T | grep -w main | wc -l` == '0' ]; then echo "BeagleRT_with_main"; else echo "BeagleRT_without_main"; fi')) - @$(MAKE) $(NEXT_TARGET) -# @echo 'Finished building target: $@' -# @echo ' ' -# $(MAKE) --no-print-directory post-build +BeagleRT: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(DEFAULT_MAIN_OBJS) + $(eval DEFAULT_MAIN_CONDITIONAL := $(shell bash -c 'if [ `nm $(PROJECT_DIR)/build/*.o | grep -w T | grep -w main | wc -l` == '0' ]; then echo "$(DEFAULT_MAIN_OBJS)"; else echo ""; fi')) + @echo 'Invoking: C++ linker' + @$(CXX) $(SYNTAX_FLAG) -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_OBJS) $(DEFAULT_MAIN_CONDITIONAL) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) + @echo 'Finished building target: $@' -# Rule for building BeagleRT including the default main file (no user-supplied main()) -BeagleRT_with_main: $(CORE_OBJS) $(DEFAULT_MAIN_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - @echo 'Linking default main.cpp...' -# @echo 'Invoking: C++ Linker' - @$(CXX) $(SYNTAX_FLAG) -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_OBJS) $(DEFAULT_MAIN_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) - @echo ' ...done' - -# Rule for building BeagleRT without the default main file (user-supplied main()) -BeagleRT_without_main: $(CORE_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) - @echo 'Linking main.cpp from project...' -# @echo 'Invoking: C++ Linker' - @$(CXX) $(SYNTAX_FLAG) -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_OBJS) $(ASM_OBJS) $(C_OBJS) $(CPP_OBJS) $(STATIC_LIBS) $(LIBS) - @echo ' ...done' - # Other Targets: # This rule compiles c and c++ source files without output or linking SYNTAX: $(C_OBJS) $(CPP_OBJS) @@ -163,7 +161,14 @@ distclean: -$(RM) build/source/* $(CORE_OBJS) $(CORE_CPP_DEPS) $(DEFAULT_MAIN_OBJS) $(DEFAULT_MAIN_CPP_DEPS) BeagleRT -@echo ' ' +OUTPUT_FILE="$(PROJECT_DIR)/$(PROJECT)" +$(OUTPUT_FILE): BeagleRT +run: $(OUTPUT_FILE) + @echo "Running $(OUTPUT_FILE)" + @$(OUTPUT_FILE) + + # Remove only the user-generated objects #clean: # -$(RM) build/source/* BeagleRT @@ -172,5 +177,5 @@ post-build: # Nothing to do here (for now) -.PHONY: all clean distclean projectclean dependents debug +.PHONY: all clean distclean projectclean dependents debug run .SECONDARY: post-build
--- a/scripts/stop_running.sh Tue May 17 18:31:43 2016 +0100 +++ b/scripts/stop_running.sh Wed May 18 01:50:01 2016 +0100 @@ -3,9 +3,9 @@ # This script stops the BeagleRT program running on the BeagleBone. BBB_ADDRESS="root@192.168.7.2" - +BBB_SCREEN_NAME="BeagleRT" # The first command should be sufficient to stop any BeagleRT run with # these scripts; the second will catch any leftovers run other ways BELA_AUDIO_THREAD_NAME=beaglert-audio -ssh $BBB_ADDRESS 'PID=`grep '"$BELA_AUDIO_THREAD_NAME"' /proc/xenomai/stat | cut -d " " -f 5 | sed s/\s//g`; if [ -z $PID ]; then printf ""; else echo "Killing old Bela process $PID"; kill -2 $PID; fi' +ssh $BBB_ADDRESS 'screen -X -S '"$BBB_SCREEN_NAME"' quit > /dev/null; PID=`grep '"$BELA_AUDIO_THREAD_NAME"' /proc/xenomai/stat | cut -d " " -f 5 | sed s/\s//g`; if [ -z $PID ]; then printf ""; else echo "Killing old Bela process $PID"; kill -2 $PID; fi'