Mercurial > hg > beaglert
changeset 68:59edd5780fef
Changed d-box code to run cleanly when built on board. Updated Makefile to add ne10 include path on board. Some extra docs in Utilities.h
author | andrewm |
---|---|
date | Fri, 17 Jul 2015 16:57:08 +0100 (2015-07-17) |
parents | 472e892c6e41 |
children | 272154649c46 |
files | Makefile include/Utilities.h projects/d-box/DboxSensors.h projects/d-box/I2c_TouchKey.h projects/d-box/StatusLED.cpp projects/d-box/how_to_build_dbox.txt projects/d-box/main.cpp projects/tank_wars/game.cpp |
diffstat | 8 files changed, 102 insertions(+), 14 deletions(-) [+] |
line wrap: on
line diff
--- a/Makefile Fri Jul 17 15:28:18 2015 +0100 +++ b/Makefile Fri Jul 17 16:57:08 2015 +0100 @@ -10,6 +10,9 @@ STATIC_LIBS := ./libprussdrv.a ./libNE10.a LIBS := -lrt -lnative -lxenomai +INCLUDES := -I/usr/include/ne10 -I/usr/xenomai/include -I/usr/arm-linux-gnueabihf/include/xenomai/include -I/usr/arm-linux-gnueabihf/include/ne10 + + ASM_SRCS := $(wildcard source/*.S) ASM_OBJS := $(addprefix build/source/,$(notdir $(ASM_SRCS:.S=.o))) ASM_DEPS := $(addprefix build/source/,$(notdir $(ASM_SRCS:.S=.d))) @@ -55,34 +58,34 @@ DEFAULT_MAIN_CPP_SRCS := ./core/default_main.cpp DEFAULT_MAIN_OBJS := ./build/core/default_main.o DEFAULT_MAIN_CPP_DEPS := ./build/core/default_main.d - + # All = build BeagleRT all: BeagleRT - + # Rule for BeagleRT core C++ files build/core/%.o: ./core/%.cpp @echo 'Building file: $<' @echo 'Invoking: GCC C++ Compiler' - g++ -I/usr/xenomai/include -I/usr/arm-linux-gnueabihf/include/xenomai/include -I/usr/arm-linux-gnueabihf/include/ne10 -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" + g++ $(INCLUDES) -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" @echo 'Finished building: $<' @echo ' ' - + # Rule for user-supplied C++ files build/source/%.o: ./source/%.cpp @echo 'Building file: $<' @echo 'Invoking: GCC C++ Compiler' - g++ -I./include -I/usr/xenomai/include -I/usr/arm-linux-gnueabihf/include/xenomai/include -I/usr/arm-linux-gnueabihf/include/ne10 -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" + g++ -I./include $(INCLUDES) -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" @echo 'Finished building: $<' @echo ' ' - + # Rule for user-supplied C files build/source/%.o: ./source/%.c @echo 'Building file: $<' @echo 'Invoking: GCC C Compiler' - gcc -I./include -I/usr/xenomai/include -I/usr/arm-linux-gnueabihf/include/xenomai/include -I/usr/arm-linux-gnueabihf/include/ne10 -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" + gcc -I./include $(INCLUDES) -O2 -Wall -c -fmessage-length=0 -U_FORTIFY_SOURCE -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o "$@" "$<" @echo 'Finished building: $<' @echo ' ' - + # Rule for user-supplied assembly files build/source/%.o: ./source/%.S @echo 'Building file: $<' @@ -102,7 +105,7 @@ @echo 'Finished building target: $@' @echo ' ' # $(MAKE) --no-print-directory post-build - + # 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 'Building target: $@'
--- a/include/Utilities.h Fri Jul 17 15:28:18 2015 +0100 +++ b/include/Utilities.h Fri Jul 17 16:57:08 2015 +0100 @@ -32,8 +32,58 @@ // Likewise, thread launch should be able to be called from setup() // Also, make volume change functions callable from render() thread -- as an aux task? +/** + * \brief Read an analog input, specifying the frame number (when to read) and the channel. + * + * This function returns the value of an analog input, at the time indicated by \c frame. + * The returned value ranges from 0 to 1, corresponding to a voltage range of 0 to 4.096V. + * + * \param context The I/O data structure which is passed by BeagleRT to render(). + * \param frame Which frame (i.e. what time) to read the analog input. Valid values range + * from 0 to (context->analogFrames - 1). + * \param channel Which analog input to read. Valid values are between 0 and + * (context->analogChannels - 1), typically 0 to 7 by default. + * \return Value of the analog input, range 0 to 1. + */ float analogReadFrame(BeagleRTContext *context, int frame, int channel); + +/** + * \brief Write an analog output, specifying the frame number (when to write) and the channel. + * + * This function sets the value of an analog output, at the time indicated by \c frame. Valid + * values are between 0 and 1, corresponding to the range 0 to 5V. + * + * The value written will persist for all future frames if BEAGLERT_FLAG_ANALOG_OUTPUTS_PERSIST + * is set in context->flags. This is the default behaviour. + * + * \param context The I/O data structure which is passed by BeagleRT to render(). + * \param frame Which frame (i.e. what time) to write the analog output. Valid values range + * from 0 to (context->analogFrames - 1). + * \param channel Which analog output to write. Valid values are between 0 and + * (context->analogChannels - 1), typically 0 to 7 by default. + * \param value Value to write to the output, range 0 to 1. + */ void analogWriteFrame(BeagleRTContext *context, int frame, int channel, float value); + +/** + * \brief Write an analog output, specifying the frame number (when to write) and the channel. + * + * This function sets the value of an analog output, at the time indicated by \c frame. Valid + * values are between 0 and 1, corresponding to the range 0 to 5V. + * + * Unlike analogWriteFrame(), the value written will affect \b only the frame specified, with + * future values unchanged. This is more efficient than analogWriteFrame() so is better suited + * to applications where every frame will be written to a different value. If + * BEAGLERT_FLAG_ANALOG_OUTPUTS_PERSIST is not set within context->flags, then + * analogWriteFrameOnce() and analogWriteFrame() are equivalent. + * + * \param context The I/O data structure which is passed by BeagleRT to render(). + * \param frame Which frame (i.e. what time) to write the analog output. Valid values range + * from 0 to (context->analogFrames - 1). + * \param channel Which analog output to write. Valid values are between 0 and + * (context->analogChannels - 1), typically 0 to 7 by default. + * \param value Value to write to the output, range 0 to 1. + */ void analogWriteFrameOnce(BeagleRTContext *context, int frame, int channel, float value); int digitalReadFrame(BeagleRTContext *context, int frame, int channel);
--- a/projects/d-box/DboxSensors.h Fri Jul 17 15:28:18 2015 +0100 +++ b/projects/d-box/DboxSensors.h Fri Jul 17 16:57:08 2015 +0100 @@ -21,7 +21,7 @@ #include "I2c_TouchKey.h" #include "AnalogInput.h" -#include "../../include/GPIOcontrol.h" // TODO wrap this into a class +#include <GPIOcontrol.h> // TODO wrap this into a class /*--------------------------------------------------------------------------------------------------------------------------------------------------- * This class retrieves data from all the connected sensors,
--- a/projects/d-box/I2c_TouchKey.h Fri Jul 17 15:28:18 2015 +0100 +++ b/projects/d-box/I2c_TouchKey.h Fri Jul 17 16:57:08 2015 +0100 @@ -8,7 +8,7 @@ #ifndef I2CTK_H_ #define I2CTK_H_ -#include "../../include/I2c.h" +#include <I2c.h> // #define NUM_BYTES_OLD 9 // #define NUM_BYTES_NEW 13
--- a/projects/d-box/StatusLED.cpp Fri Jul 17 15:28:18 2015 +0100 +++ b/projects/d-box/StatusLED.cpp Fri Jul 17 16:57:08 2015 +0100 @@ -9,7 +9,7 @@ #include <iostream> #include "StatusLED.h" -#include "../../include/GPIOcontrol.h" +#include <GPIOcontrol.h> extern int gShouldStop; extern int gVerbose;
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/projects/d-box/how_to_build_dbox.txt Fri Jul 17 16:57:08 2015 +0100 @@ -0,0 +1,35 @@ +The D-Box code can be built on the board using the scripts included with +BeagleRT. To build the code, do the following from the scripts/ directory: + +./setup_board.sh # Only if BeagleRT is not already copied to the board +./build_project.sh -n ../projects/d-box # -n means don't run yet + +You will now need to copy the .dbx sound files to the box. These need to +be in a directory: /root/d-box/sounds + +Log into the board via ssh to create the d-box directory, or run: + +ssh root@192.168.7.2 "mkdir /root/d-box" + +Now copy the .dbx files from a source of your choice to the board. Assuming +they are in a directory called "sounds": + +scp -r sounds root@192.168.7.2:/root/d-box/ + +Now you can run the D-Box program to make sure it plays. You will need the +sensors and matrix connected to the box (i.e. a complete hardware D-Box). +From the scripts/ directory: + +./run_project.sh -f -c "-q 24 -r 25 -t 2 -s -p 2 -l 0 -u 0 -i 1 -n f -g 3 -v" + +If this plays properly, the D-Box can then be set to run automatically on boot: + +./set_startup.sh -l -c "-q 24 -r 25 -t 2 -s -p 2 -l 0 -u 0 -i 1 -n f -g 3 -v" + +If at any time you want to stop the D-Box program running, you can run: + +./stop_running.sh + +To turn off further autoboot, run: + +./set_startup.sh -n
--- a/projects/d-box/main.cpp Fri Jul 17 15:28:18 2015 +0100 +++ b/projects/d-box/main.cpp Fri Jul 17 16:57:08 2015 +0100 @@ -76,7 +76,7 @@ char sdPath[256] = "/dev/mmcblk0p2"; // system path of the SD, partition 2 char mountPath[256] = "/root/d-box/usersounds"; // mount point of SD partition 2 [where user files are] char gUserDirName[256] = "usersounds"; // Directory in which user analysis files can be found [dir of mountPath] -char gDefaultDirName[256] = "sounds"; // Directory in which built in analysis files can be found +char gDefaultDirName[256] = "/root/d-box/sounds"; // Directory in which built in analysis files can be found char *gDirName; bool gIsLoading = false; int fileCnt = 0;
--- a/projects/tank_wars/game.cpp Fri Jul 17 15:28:18 2015 +0100 +++ b/projects/tank_wars/game.cpp Fri Jul 17 16:57:08 2015 +0100 @@ -8,7 +8,7 @@ #include <cmath> #include <cstdlib> #include "vector_graphics.h" -#include "../../include/Utilities.h" +#include <Utilities.h> // Virtual screen size int screenWidth, screenHeight;