Compare commits
16 Commits
| Author | SHA1 | Date |
|---|---|---|
|
|
e94208880e | |
|
|
5b17aa3e34 | |
|
|
e58e235256 | |
|
|
aac41aa882 | |
|
|
bf6eec8c26 | |
|
|
33d0b44f98 | |
|
|
34e9ba4405 | |
|
|
e29cc12ab4 | |
|
|
eb18a05c51 | |
|
|
d2e0bebc4e | |
|
|
46adafd5f0 | |
|
|
b51d570b73 | |
|
|
0e96eb27ae | |
|
|
218baed2ed | |
|
|
c44af52ad5 | |
|
|
084babb919 |
33
README.md
33
README.md
|
|
@ -29,7 +29,7 @@ Cross Platform device manager for driving and flight simulators, for use with co
|
||||||
- argtable2
|
- argtable2
|
||||||
- libconfig
|
- libconfig
|
||||||
- [slog](https://github.com/kala13x/slog) (static)
|
- [slog](https://github.com/kala13x/slog) (static)
|
||||||
- [wine-linux-shm-adapter](https://github.com/spacefreak18/simshmbridge) - for sims that need shared memory mapping like AC.
|
- [simshmbridge](https://github.com/spacefreak18/simshmbridge) - for sims that need shared memory mapping like AC and Project Cars related.
|
||||||
- [simapi](https://github.com/spacefreak18/simapi)
|
- [simapi](https://github.com/spacefreak18/simapi)
|
||||||
|
|
||||||
## Building
|
## Building
|
||||||
|
|
@ -51,9 +51,36 @@ to use the pulseaudio backend use this cmake command
|
||||||
cmake -DUSE_PULSEAUDIO=YES ..
|
cmake -DUSE_PULSEAUDIO=YES ..
|
||||||
```
|
```
|
||||||
|
|
||||||
## Testing
|
## Using Arduino Devices
|
||||||
|
|
||||||
### Setting up Your Arduino Device
|
Currently Monocoque supports simwind and shiftlights through the included arduino sketches which have been tested on Uno boards. The simwind controller requires a Motor shield.
|
||||||
|
|
||||||
|
There are included Makefiles for each controller. For now, the makefiles expect the device to be attached at /dev/ttyACM0. So unplug both controllers, and then plug in just the
|
||||||
|
controller you're updating to ensure the correct controller is at /dev/ttyACM0.
|
||||||
|
|
||||||
|
To compile and upload these sketches, the Makefiles use arduino-cli. Unfortunately it seems some distributions such as debian do not include this in the repositories. If this is
|
||||||
|
the case follow the install instructions here:
|
||||||
|
```
|
||||||
|
https://arduino.github.io/arduino-cli/0.35/installation/
|
||||||
|
```
|
||||||
|
You may have to download the core libraries, it will prompt you to do so if you do not have them and you go further
|
||||||
|
```
|
||||||
|
arduino-cli core install arduino:avr
|
||||||
|
```
|
||||||
|
Then for shiftlights navigate to included shiftlight directory ( be sure only the shiftlight controller is plugged into the machine and is available at /dev/ttyACM0 ) and
|
||||||
|
|
||||||
|
```
|
||||||
|
arduino-cli lib install FastLED
|
||||||
|
make
|
||||||
|
```
|
||||||
|
Then for simwind navigate to the included simwind directory ( be sure only the simwind controller is plugged into the machine and is available at /dev/ttyACM0 ) and
|
||||||
|
```
|
||||||
|
ARDUINO_LIBRARY_ENABLE_UNSAFE_INSTALL=true arduino-cli lib install --git-url https://github.com/adafruit/Adafruit_Motor_Shield_V2_Library.git
|
||||||
|
ARDUINO_LIBRARY_ENABLE_UNSAFE_INSTALL=true arduino-cli lib install --git-url https://github.com/adafruit/Adafruit_BusIO.git
|
||||||
|
make
|
||||||
|
```
|
||||||
|
|
||||||
|
## Testing
|
||||||
|
|
||||||
### Static Analysis
|
### Static Analysis
|
||||||
```
|
```
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,166 @@
|
||||||
|
# Makefile for Arduino based scketches
|
||||||
|
#
|
||||||
|
# Copyright 2020 Valerio Di Giampietro http://va.ler.io v@ler.io
|
||||||
|
# MIT License - see License.txt file
|
||||||
|
#
|
||||||
|
# This Makefile uses the arduino-cli, the Arduino command line interface
|
||||||
|
# and has been designed and tested to run on Linux, not on Windows.
|
||||||
|
# Probably it will run on a Mac, but it has not been tested.
|
||||||
|
#
|
||||||
|
# Please note that:
|
||||||
|
#
|
||||||
|
# 1. each sketch must reside in his own folder with this Makefile
|
||||||
|
#
|
||||||
|
# 2. the main make targets are:
|
||||||
|
# - all compiles and upload
|
||||||
|
# - compile compiles only
|
||||||
|
# - upload upload via serial port, compile if the binary file is
|
||||||
|
# not available
|
||||||
|
# - ota upload Over The Air, automatically find the device
|
||||||
|
# IP address using the IOT_NAME (device hostname)
|
||||||
|
# - clean clean the build directory
|
||||||
|
# - find find OTA updatable devices on the local subnet
|
||||||
|
# - requirements it the file "requirements.txt" exists it will
|
||||||
|
# install the libraries listed in this file
|
||||||
|
#
|
||||||
|
# default is "all"
|
||||||
|
#
|
||||||
|
# 3. it gets the name of the sketch using the wildcard make command;
|
||||||
|
# the name is *.ino; this means that you must have ONLY a file
|
||||||
|
# with .ino extension, otherwise this makefile will break. This
|
||||||
|
# also means that you can use this Makefile, almost unmodified,
|
||||||
|
# for any sketch as long as you keep a single .ino file in each
|
||||||
|
# folder
|
||||||
|
#
|
||||||
|
# 4. you can split your project in multiple files, if you wish,
|
||||||
|
# using a single .ino file and multiple .h files, that you can
|
||||||
|
# include in the .ino file with an '#include "myfile.h"'
|
||||||
|
# directive
|
||||||
|
#
|
||||||
|
# Optionally some environment variables can be set:
|
||||||
|
#
|
||||||
|
# FQBN Fully Qualified Board Name; if not set in the environment
|
||||||
|
# it will be assigned a value in this makefile
|
||||||
|
#
|
||||||
|
# SERIAL_DEV Serial device to upload the sketch; if not set in the
|
||||||
|
# environment it will be assigned:
|
||||||
|
# /dev/ttyUSB0 if it exists, or
|
||||||
|
# /dev/ttyACM0 if it exists, or
|
||||||
|
# unknown
|
||||||
|
#
|
||||||
|
# IOT_NAME Name of the IOT device; if not set in the environment
|
||||||
|
# it will be assigned a value in this makefile. This is
|
||||||
|
# very useful for OTA update, the device will be searched
|
||||||
|
# on the local subnet using this name
|
||||||
|
#
|
||||||
|
# OTA_PORT Port used by OTA update; if not set in the environment
|
||||||
|
# it will be assigned the default value of 8266 in this
|
||||||
|
# makefile
|
||||||
|
#
|
||||||
|
# OTA_PASS Password used for OTA update; if not set in the environment
|
||||||
|
# it will be assigned the default value of an empty string
|
||||||
|
#
|
||||||
|
# V verbose flag; can be 0 (quiet) or 1 (verbose); if not set
|
||||||
|
# in the environment it will be assigned a default value
|
||||||
|
# in this makefile
|
||||||
|
|
||||||
|
|
||||||
|
MAKE_DIR := $(PWD)
|
||||||
|
#
|
||||||
|
# ----- setup wor Wemos D1 mini -----
|
||||||
|
#FQBN ?= esp8266:esp8266:d1_mini
|
||||||
|
#IOT_NAME ?= esp8266-meteo
|
||||||
|
#OTA_PORT ?= 8266
|
||||||
|
#OTA_PASS ?=
|
||||||
|
# ----- setup for Arduino Uno
|
||||||
|
FQBN ?= arduino:avr:uno
|
||||||
|
# ----- ---------------------
|
||||||
|
V ?= 0
|
||||||
|
VFLAG =
|
||||||
|
|
||||||
|
ifeq "$(V)" "1"
|
||||||
|
VFLAG =-v
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef SERIAL_DEV
|
||||||
|
ifneq (,$(wildcard /dev/ttyUSB0))
|
||||||
|
SERIAL_DEV = /dev/ttyUSB0
|
||||||
|
else ifneq (,$(wildcard /dev/ttyACM0))
|
||||||
|
SERIAL_DEV = /dev/ttyACM0
|
||||||
|
else
|
||||||
|
SERIAL_DEV = unknown
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
BUILD_DIR := $(subst :,.,build/$(FQBN))
|
||||||
|
|
||||||
|
SRC := $(wildcard *.ino)
|
||||||
|
HDRS := $(wildcard *.h)
|
||||||
|
BIN := $(BUILD_DIR)/$(SRC).bin
|
||||||
|
ELF := $(BUILD_DIR)/$(SRC).elf
|
||||||
|
|
||||||
|
$(info FQBN is [${FQBN}])
|
||||||
|
$(info IOT_NAME is [${IOT_NAME}])
|
||||||
|
$(info OTA_PORT is [${OTA_PORT}])
|
||||||
|
$(info OTA_PASS is [${OTA_PASS}])
|
||||||
|
$(info V is [${V}])
|
||||||
|
$(info VFLAG is [${VFLAG}])
|
||||||
|
$(info MAKE_DIR is [${MAKE_DIR}])
|
||||||
|
$(info BUILD_DIR is [${BUILD_DIR}])
|
||||||
|
$(info SRC is [${SRC}])
|
||||||
|
$(info HDRS is [${HDRS}])
|
||||||
|
$(info BIN is [${BIN}])
|
||||||
|
$(info SERIAL_DEV is [${SERIAL_DEV}])
|
||||||
|
|
||||||
|
all: $(ELF) upload
|
||||||
|
.PHONY: all
|
||||||
|
|
||||||
|
compile: $(ELF)
|
||||||
|
.PHONY: compile
|
||||||
|
|
||||||
|
$(ELF): $(SRC) $(HDRS)
|
||||||
|
arduino-cli compile -b $(FQBN) $(VFLAG)
|
||||||
|
@if which arduino-manifest.pl; \
|
||||||
|
then echo "---> Generating manifest.txt"; \
|
||||||
|
arduino-manifest.pl -b $(FQBN) $(SRC) $(HDRS) > manifest.txt; \
|
||||||
|
else echo "---> If you want to generate manifest.txt, listing used libraries and their versions,"; \
|
||||||
|
echo "---> please install arduino-manifest, see https://github.com/digiampietro/arduino-manifest"; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
upload:
|
||||||
|
@if [ ! -c $(SERIAL_DEV) ] ; \
|
||||||
|
then echo "---> ERROR: Serial Device not available, please set the SERIAL_DEV environment variable" ; \
|
||||||
|
else echo "---> Uploading sketch\n"; \
|
||||||
|
arduino-cli upload -b $(FQBN) -p $(SERIAL_DEV) $(VFLAG); \
|
||||||
|
fi
|
||||||
|
|
||||||
|
ota:
|
||||||
|
@PLAT_PATH=`arduino-cli compile -b $(FQBN) --show-properties | grep '^runtime.platform.path' | awk -F= '{print $$2}'` ; \
|
||||||
|
PY_PATH=`arduino-cli compile -b $(FQBN) --show-properties | grep '^runtime.tools.python3.path' | awk -F= '{print $$2}'` ; \
|
||||||
|
IOT_IP=`avahi-browse _arduino._tcp --resolve --parsable --terminate|grep -i ';$(IOT_NAME);'|grep ';$(OTA_PORT);'| awk -F\; '{print $$8}'|head -1`; \
|
||||||
|
BINFILE=$(wildcard $(BUILD_DIR)/$(SRC)*bin); \
|
||||||
|
echo "PLAT_PATH is [$$PLAT_PATH]" ; \
|
||||||
|
echo "PY_PATH: is [$$PY_PATH]" ; \
|
||||||
|
echo "IOT_IP: is [$$IOT_IP]" ; \
|
||||||
|
echo "BINFILE: is [$$BINFILE]" ; \
|
||||||
|
if [ "$$IOT_IP" = "" ] ; \
|
||||||
|
then echo "Unable to find device IP. Check that the IOT_NAME environment variable is correctly set. Use 'make find' to search devices"; \
|
||||||
|
else echo "---> Uploading Over The Air"; \
|
||||||
|
$$PY_PATH/python3 $$PLAT_PATH/tools/espota.py -i $$IOT_IP -p $(OTA_PORT) --auth=$(OTA_PASS) -f $$BINFILE ;\
|
||||||
|
fi
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@echo "---> Cleaning the build directory"
|
||||||
|
rm -rf build
|
||||||
|
|
||||||
|
find:
|
||||||
|
avahi-browse _arduino._tcp --resolve --parsable --terminate
|
||||||
|
|
||||||
|
requirements:
|
||||||
|
@if [ -e requirements.txt ]; \
|
||||||
|
then while read -r i ; do echo ; \
|
||||||
|
echo "---> Installing " '"'$$i'"' ; \
|
||||||
|
arduino-cli lib install "$$i" ; \
|
||||||
|
done < requirements.txt ; \
|
||||||
|
else echo "---> MISSING requirements.txt file"; \
|
||||||
|
fi
|
||||||
|
|
@ -0,0 +1,27 @@
|
||||||
|
#ifndef _SHIFTLIGHTSDATA_H
|
||||||
|
#define _SHIFTLIGHTSDATA_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
unsigned char color_1_red;
|
||||||
|
unsigned char color_1_green;
|
||||||
|
unsigned char color_1_blue;
|
||||||
|
unsigned char color_2_red;
|
||||||
|
unsigned char color_2_green;
|
||||||
|
unsigned char color_2_blue;
|
||||||
|
unsigned char color_3_red;
|
||||||
|
unsigned char color_3_green;
|
||||||
|
unsigned char color_3_blue;
|
||||||
|
unsigned char space_1;
|
||||||
|
unsigned char space_2;
|
||||||
|
unsigned char space_3;
|
||||||
|
uint32_t maxrpm;
|
||||||
|
uint32_t rpm;
|
||||||
|
}
|
||||||
|
ShiftLightsData;
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -1,14 +1,24 @@
|
||||||
#include <FastLED.h>
|
#include <FastLED.h>
|
||||||
#include "simdata.h"
|
#include "shiftlights.h"
|
||||||
|
|
||||||
#define SIMDATA_SIZE sizeof(SimData)
|
#define SIMDATA_SIZE sizeof(ShiftLightsData)
|
||||||
|
|
||||||
#define LED_PIN 7
|
#define LED_PIN 7
|
||||||
#define NUM_LEDS 6
|
#define NUM_LEDS 6
|
||||||
#define BRIGHTNESS 40
|
#define BRIGHTNESS 40
|
||||||
|
|
||||||
|
#define COLOR1A 0
|
||||||
|
#define COLOR1B 0
|
||||||
|
#define COLOR1C 255
|
||||||
|
#define COLOR2A 0
|
||||||
|
#define COLOR2B 255
|
||||||
|
#define COLOR2C 0
|
||||||
|
#define COLOR3A 255
|
||||||
|
#define COLOR3B 0
|
||||||
|
#define COLOR3C 0
|
||||||
|
|
||||||
CRGB leds[NUM_LEDS];
|
CRGB leds[NUM_LEDS];
|
||||||
SimData sd;
|
ShiftLightsData sd;
|
||||||
int maxrpm = 0;
|
int maxrpm = 0;
|
||||||
int rpm = 0;
|
int rpm = 0;
|
||||||
int numlights = NUM_LEDS;
|
int numlights = NUM_LEDS;
|
||||||
|
|
@ -29,11 +39,8 @@ void setup()
|
||||||
}
|
}
|
||||||
FastLED.clear();
|
FastLED.clear();
|
||||||
|
|
||||||
sd.rpms = 0;
|
sd.rpm = 0;
|
||||||
sd.maxrpm = 6500;
|
sd.maxrpm = 6500;
|
||||||
sd.altitude = 10;
|
|
||||||
sd.pulses = 40000;
|
|
||||||
sd.velocity = 10;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop()
|
void loop()
|
||||||
|
|
@ -45,12 +52,10 @@ void loop()
|
||||||
{
|
{
|
||||||
Serial.readBytes(buff, SIMDATA_SIZE);
|
Serial.readBytes(buff, SIMDATA_SIZE);
|
||||||
memcpy(&sd, &buff, SIMDATA_SIZE);
|
memcpy(&sd, &buff, SIMDATA_SIZE);
|
||||||
rpm = sd.rpms;
|
rpm = sd.rpm;
|
||||||
maxrpm = sd.maxrpm;
|
maxrpm = sd.maxrpm;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
while (l < numlights)
|
while (l < numlights)
|
||||||
{
|
{
|
||||||
lights[l] = 0;
|
lights[l] = 0;
|
||||||
|
|
@ -75,15 +80,15 @@ void loop()
|
||||||
|
|
||||||
if (l >= numlights / 2)
|
if (l >= numlights / 2)
|
||||||
{
|
{
|
||||||
leds[l] = CRGB ( 0, 0, 255);
|
leds[l] = CRGB ( COLOR1A, COLOR1B, COLOR1C);
|
||||||
}
|
}
|
||||||
if (l < numlights / 2)
|
if (l < numlights / 2)
|
||||||
{
|
{
|
||||||
leds[l] = CRGB ( 0, 255, 0);
|
leds[l] = CRGB ( COLOR2A, COLOR2B, COLOR2C);
|
||||||
}
|
}
|
||||||
if (l == numlights - 1)
|
if (l == numlights - 1)
|
||||||
{
|
{
|
||||||
leds[l] = CRGB ( 255, 0, 0);
|
leds[l] = CRGB ( COLOR3A, COLOR3B, COLOR3C);
|
||||||
}
|
}
|
||||||
if (lights[l] <= 0)
|
if (lights[l] <= 0)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,166 @@
|
||||||
|
# Makefile for Arduino based scketches
|
||||||
|
#
|
||||||
|
# Copyright 2020 Valerio Di Giampietro http://va.ler.io v@ler.io
|
||||||
|
# MIT License - see License.txt file
|
||||||
|
#
|
||||||
|
# This Makefile uses the arduino-cli, the Arduino command line interface
|
||||||
|
# and has been designed and tested to run on Linux, not on Windows.
|
||||||
|
# Probably it will run on a Mac, but it has not been tested.
|
||||||
|
#
|
||||||
|
# Please note that:
|
||||||
|
#
|
||||||
|
# 1. each sketch must reside in his own folder with this Makefile
|
||||||
|
#
|
||||||
|
# 2. the main make targets are:
|
||||||
|
# - all compiles and upload
|
||||||
|
# - compile compiles only
|
||||||
|
# - upload upload via serial port, compile if the binary file is
|
||||||
|
# not available
|
||||||
|
# - ota upload Over The Air, automatically find the device
|
||||||
|
# IP address using the IOT_NAME (device hostname)
|
||||||
|
# - clean clean the build directory
|
||||||
|
# - find find OTA updatable devices on the local subnet
|
||||||
|
# - requirements it the file "requirements.txt" exists it will
|
||||||
|
# install the libraries listed in this file
|
||||||
|
#
|
||||||
|
# default is "all"
|
||||||
|
#
|
||||||
|
# 3. it gets the name of the sketch using the wildcard make command;
|
||||||
|
# the name is *.ino; this means that you must have ONLY a file
|
||||||
|
# with .ino extension, otherwise this makefile will break. This
|
||||||
|
# also means that you can use this Makefile, almost unmodified,
|
||||||
|
# for any sketch as long as you keep a single .ino file in each
|
||||||
|
# folder
|
||||||
|
#
|
||||||
|
# 4. you can split your project in multiple files, if you wish,
|
||||||
|
# using a single .ino file and multiple .h files, that you can
|
||||||
|
# include in the .ino file with an '#include "myfile.h"'
|
||||||
|
# directive
|
||||||
|
#
|
||||||
|
# Optionally some environment variables can be set:
|
||||||
|
#
|
||||||
|
# FQBN Fully Qualified Board Name; if not set in the environment
|
||||||
|
# it will be assigned a value in this makefile
|
||||||
|
#
|
||||||
|
# SERIAL_DEV Serial device to upload the sketch; if not set in the
|
||||||
|
# environment it will be assigned:
|
||||||
|
# /dev/ttyUSB0 if it exists, or
|
||||||
|
# /dev/ttyACM0 if it exists, or
|
||||||
|
# unknown
|
||||||
|
#
|
||||||
|
# IOT_NAME Name of the IOT device; if not set in the environment
|
||||||
|
# it will be assigned a value in this makefile. This is
|
||||||
|
# very useful for OTA update, the device will be searched
|
||||||
|
# on the local subnet using this name
|
||||||
|
#
|
||||||
|
# OTA_PORT Port used by OTA update; if not set in the environment
|
||||||
|
# it will be assigned the default value of 8266 in this
|
||||||
|
# makefile
|
||||||
|
#
|
||||||
|
# OTA_PASS Password used for OTA update; if not set in the environment
|
||||||
|
# it will be assigned the default value of an empty string
|
||||||
|
#
|
||||||
|
# V verbose flag; can be 0 (quiet) or 1 (verbose); if not set
|
||||||
|
# in the environment it will be assigned a default value
|
||||||
|
# in this makefile
|
||||||
|
|
||||||
|
|
||||||
|
MAKE_DIR := $(PWD)
|
||||||
|
#
|
||||||
|
# ----- setup wor Wemos D1 mini -----
|
||||||
|
#FQBN ?= esp8266:esp8266:d1_mini
|
||||||
|
#IOT_NAME ?= esp8266-meteo
|
||||||
|
#OTA_PORT ?= 8266
|
||||||
|
#OTA_PASS ?=
|
||||||
|
# ----- setup for Arduino Uno
|
||||||
|
FQBN ?= arduino:avr:uno
|
||||||
|
# ----- ---------------------
|
||||||
|
V ?= 0
|
||||||
|
VFLAG =
|
||||||
|
|
||||||
|
ifeq "$(V)" "1"
|
||||||
|
VFLAG =-v
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifndef SERIAL_DEV
|
||||||
|
ifneq (,$(wildcard /dev/ttyUSB0))
|
||||||
|
SERIAL_DEV = /dev/ttyUSB0
|
||||||
|
else ifneq (,$(wildcard /dev/ttyACM0))
|
||||||
|
SERIAL_DEV = /dev/ttyACM0
|
||||||
|
else
|
||||||
|
SERIAL_DEV = unknown
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
BUILD_DIR := $(subst :,.,build/$(FQBN))
|
||||||
|
|
||||||
|
SRC := $(wildcard *.ino)
|
||||||
|
HDRS := $(wildcard *.h)
|
||||||
|
BIN := $(BUILD_DIR)/$(SRC).bin
|
||||||
|
ELF := $(BUILD_DIR)/$(SRC).elf
|
||||||
|
|
||||||
|
$(info FQBN is [${FQBN}])
|
||||||
|
$(info IOT_NAME is [${IOT_NAME}])
|
||||||
|
$(info OTA_PORT is [${OTA_PORT}])
|
||||||
|
$(info OTA_PASS is [${OTA_PASS}])
|
||||||
|
$(info V is [${V}])
|
||||||
|
$(info VFLAG is [${VFLAG}])
|
||||||
|
$(info MAKE_DIR is [${MAKE_DIR}])
|
||||||
|
$(info BUILD_DIR is [${BUILD_DIR}])
|
||||||
|
$(info SRC is [${SRC}])
|
||||||
|
$(info HDRS is [${HDRS}])
|
||||||
|
$(info BIN is [${BIN}])
|
||||||
|
$(info SERIAL_DEV is [${SERIAL_DEV}])
|
||||||
|
|
||||||
|
all: $(ELF) upload
|
||||||
|
.PHONY: all
|
||||||
|
|
||||||
|
compile: $(ELF)
|
||||||
|
.PHONY: compile
|
||||||
|
|
||||||
|
$(ELF): $(SRC) $(HDRS)
|
||||||
|
arduino-cli compile -b $(FQBN) $(VFLAG)
|
||||||
|
@if which arduino-manifest.pl; \
|
||||||
|
then echo "---> Generating manifest.txt"; \
|
||||||
|
arduino-manifest.pl -b $(FQBN) $(SRC) $(HDRS) > manifest.txt; \
|
||||||
|
else echo "---> If you want to generate manifest.txt, listing used libraries and their versions,"; \
|
||||||
|
echo "---> please install arduino-manifest, see https://github.com/digiampietro/arduino-manifest"; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
upload:
|
||||||
|
@if [ ! -c $(SERIAL_DEV) ] ; \
|
||||||
|
then echo "---> ERROR: Serial Device not available, please set the SERIAL_DEV environment variable" ; \
|
||||||
|
else echo "---> Uploading sketch\n"; \
|
||||||
|
arduino-cli upload -b $(FQBN) -p $(SERIAL_DEV) $(VFLAG); \
|
||||||
|
fi
|
||||||
|
|
||||||
|
ota:
|
||||||
|
@PLAT_PATH=`arduino-cli compile -b $(FQBN) --show-properties | grep '^runtime.platform.path' | awk -F= '{print $$2}'` ; \
|
||||||
|
PY_PATH=`arduino-cli compile -b $(FQBN) --show-properties | grep '^runtime.tools.python3.path' | awk -F= '{print $$2}'` ; \
|
||||||
|
IOT_IP=`avahi-browse _arduino._tcp --resolve --parsable --terminate|grep -i ';$(IOT_NAME);'|grep ';$(OTA_PORT);'| awk -F\; '{print $$8}'|head -1`; \
|
||||||
|
BINFILE=$(wildcard $(BUILD_DIR)/$(SRC)*bin); \
|
||||||
|
echo "PLAT_PATH is [$$PLAT_PATH]" ; \
|
||||||
|
echo "PY_PATH: is [$$PY_PATH]" ; \
|
||||||
|
echo "IOT_IP: is [$$IOT_IP]" ; \
|
||||||
|
echo "BINFILE: is [$$BINFILE]" ; \
|
||||||
|
if [ "$$IOT_IP" = "" ] ; \
|
||||||
|
then echo "Unable to find device IP. Check that the IOT_NAME environment variable is correctly set. Use 'make find' to search devices"; \
|
||||||
|
else echo "---> Uploading Over The Air"; \
|
||||||
|
$$PY_PATH/python3 $$PLAT_PATH/tools/espota.py -i $$IOT_IP -p $(OTA_PORT) --auth=$(OTA_PASS) -f $$BINFILE ;\
|
||||||
|
fi
|
||||||
|
|
||||||
|
clean:
|
||||||
|
@echo "---> Cleaning the build directory"
|
||||||
|
rm -rf build
|
||||||
|
|
||||||
|
find:
|
||||||
|
avahi-browse _arduino._tcp --resolve --parsable --terminate
|
||||||
|
|
||||||
|
requirements:
|
||||||
|
@if [ -e requirements.txt ]; \
|
||||||
|
then while read -r i ; do echo ; \
|
||||||
|
echo "---> Installing " '"'$$i'"' ; \
|
||||||
|
arduino-cli lib install "$$i" ; \
|
||||||
|
done < requirements.txt ; \
|
||||||
|
else echo "---> MISSING requirements.txt file"; \
|
||||||
|
fi
|
||||||
|
|
@ -0,0 +1,15 @@
|
||||||
|
#ifndef _SIMWINDDATA_H
|
||||||
|
#define _SIMWINDDATA_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
uint32_t velocity;
|
||||||
|
float fanpower;
|
||||||
|
}
|
||||||
|
SimWindData;
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -1,16 +1,16 @@
|
||||||
#include <Adafruit_MotorShield.h>
|
#include <Adafruit_MotorShield.h>
|
||||||
#include "simdata.h"
|
#include "simwind.h"
|
||||||
|
|
||||||
#define BYTE_SIZE sizeof(SimData)
|
#define BYTE_SIZE sizeof(SimWindData)
|
||||||
#define KPHTOMPH .621317
|
#define KPHTOMPH .621317
|
||||||
|
#define FANPOWER .6
|
||||||
|
|
||||||
Adafruit_MotorShield AFMS = Adafruit_MotorShield();
|
Adafruit_MotorShield AFMS = Adafruit_MotorShield();
|
||||||
|
|
||||||
Adafruit_DCMotor *myMotor1 = AFMS.getMotor(1);
|
Adafruit_DCMotor *myMotor1 = AFMS.getMotor(1);
|
||||||
Adafruit_DCMotor *myMotor2 = AFMS.getMotor(3);
|
Adafruit_DCMotor *myMotor2 = AFMS.getMotor(3);
|
||||||
|
|
||||||
SimData sd;
|
SimWindData sd;
|
||||||
int velocity = 0;
|
int velocity = 0;
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
|
@ -19,10 +19,6 @@ void setup() {
|
||||||
Serial.println("Could not find Motor Shield. Check wiring.");
|
Serial.println("Could not find Motor Shield. Check wiring.");
|
||||||
while (1);
|
while (1);
|
||||||
}
|
}
|
||||||
sd.rpms = 0;
|
|
||||||
sd.maxrpm = 6500;
|
|
||||||
sd.altitude = 10;
|
|
||||||
sd.pulses = 40000;
|
|
||||||
sd.velocity = 10;
|
sd.velocity = 10;
|
||||||
|
|
||||||
myMotor1->setSpeed(0);
|
myMotor1->setSpeed(0);
|
||||||
|
|
@ -46,6 +42,6 @@ void loop() {
|
||||||
{
|
{
|
||||||
v = 255;
|
v = 255;
|
||||||
}
|
}
|
||||||
myMotor1->setSpeed(v);
|
myMotor1->setSpeed(v*FANPOWER);
|
||||||
myMotor2->setSpeed(v);
|
myMotor2->setSpeed(v*FANPOWER);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,8 @@ set(devices_source_files
|
||||||
serialdevice.c
|
serialdevice.c
|
||||||
tachdevice.h
|
tachdevice.h
|
||||||
tachdevice.c
|
tachdevice.c
|
||||||
|
usbhapticdevice.h
|
||||||
|
usbhapticdevice.c
|
||||||
sound.h
|
sound.h
|
||||||
sound.c
|
sound.c
|
||||||
usb/revburner.h
|
usb/revburner.h
|
||||||
|
|
|
||||||
|
|
@ -6,19 +6,42 @@
|
||||||
#include "arduino.h"
|
#include "arduino.h"
|
||||||
#include "../../slog/slog.h"
|
#include "../../slog/slog.h"
|
||||||
|
|
||||||
#define arduino_timeout 2000
|
#define arduino_timeout 5000
|
||||||
|
|
||||||
int arduino_update(SerialDevice* serialdevice, SimData* simdata)
|
int arduino_update(SerialDevice* serialdevice, void* data, size_t size)
|
||||||
{
|
{
|
||||||
int result = 1;
|
int result = 1;
|
||||||
if (serialdevice->port)
|
if (serialdevice->port)
|
||||||
{
|
{
|
||||||
result = check(sp_blocking_write(serialdevice->port, simdata, sizeof(SimData), arduino_timeout));
|
slogt("copying %i bytes to arduino device", size);
|
||||||
|
result = check(sp_blocking_write(serialdevice->port, data, size, arduino_timeout));
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//int arduino_shiftlights_update(SerialDevice* serialdevice, SimData* simdata)
|
||||||
|
//{
|
||||||
|
// int result = 1;
|
||||||
|
// if (serialdevice->port)
|
||||||
|
// {
|
||||||
|
// result = check(sp_blocking_write(serialdevice->port, simdata, sizeof(SimData), arduino_timeout));
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// return result;
|
||||||
|
//}
|
||||||
|
//
|
||||||
|
//int arduino_simwind_update(SerialDevice* serialdevice, SimData* simdata)
|
||||||
|
//{
|
||||||
|
// int result = 1;
|
||||||
|
// if (serialdevice->port)
|
||||||
|
// {
|
||||||
|
// result = check(sp_blocking_write(serialdevice->port, simdata, sizeof(SimData), arduino_timeout));
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// return result;
|
||||||
|
//}
|
||||||
|
|
||||||
int arduino_init(SerialDevice* serialdevice, const char* portdev)
|
int arduino_init(SerialDevice* serialdevice, const char* portdev)
|
||||||
{
|
{
|
||||||
slogi("initializing arduino serial device...");
|
slogi("initializing arduino serial device...");
|
||||||
|
|
@ -80,3 +103,4 @@ int check(enum sp_return result)
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,8 +4,9 @@
|
||||||
#include "../simdevice.h"
|
#include "../simdevice.h"
|
||||||
#include "../serialdevice.h"
|
#include "../serialdevice.h"
|
||||||
|
|
||||||
int arduino_update(SerialDevice* serialdevice, SimData* simdata);
|
|
||||||
int arduino_init(SerialDevice* serialdevice, const char* portdev);
|
int arduino_update(SerialDevice* serialdevice, void* data, size_t size);
|
||||||
|
int arduino_init(SerialDevice* serialdevice, const char* portdev);
|
||||||
int arduino_free(SerialDevice* serialdevice);
|
int arduino_free(SerialDevice* serialdevice);
|
||||||
int check(enum sp_return result);
|
int check(enum sp_return result);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -15,10 +15,45 @@ int serialdev_update(SimDevice* this, SimData* simdata)
|
||||||
{
|
{
|
||||||
SerialDevice* serialdevice = (void *) this->derived;
|
SerialDevice* serialdevice = (void *) this->derived;
|
||||||
|
|
||||||
arduino_update(serialdevice, simdata);
|
|
||||||
|
|
||||||
|
arduino_update(serialdevice, simdata, sizeof(SimData));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int arduino_shiftlights_update(SimDevice* this, SimData* simdata)
|
||||||
|
{
|
||||||
|
SerialDevice* serialdevice = (void *) this->derived;
|
||||||
|
int result = 1;
|
||||||
|
|
||||||
|
|
||||||
|
serialdevice->u.shiftlightsdata.maxrpm = simdata->maxrpm;
|
||||||
|
serialdevice->u.shiftlightsdata.rpm = simdata->rpms;
|
||||||
|
slogt("Updating arduino device rpms to %i", serialdevice->u.shiftlightsdata.rpm);
|
||||||
|
// we can add configs to set all the colors
|
||||||
|
// i can move the size to the initialization since it should not change
|
||||||
|
size_t size = sizeof(ShiftLightsData);
|
||||||
|
|
||||||
|
arduino_update(serialdevice, &serialdevice->u.shiftlightsdata, size);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
int arduino_simwind_update(SimDevice* this, SimData* simdata)
|
||||||
|
{
|
||||||
|
SerialDevice* serialdevice = (void *) this->derived;
|
||||||
|
int result = 1;
|
||||||
|
|
||||||
|
serialdevice->u.simwinddata.velocity = simdata->velocity;
|
||||||
|
slogt("Updating arduino device speed to %i", serialdevice->u.simwinddata.velocity);
|
||||||
|
// this can be added to the config, all config dependent can be added to init
|
||||||
|
serialdevice->u.simwinddata.fanpower = 0.6;
|
||||||
|
size_t size = sizeof(SimWindData);
|
||||||
|
|
||||||
|
arduino_update(serialdevice, &serialdevice->u.simwinddata, size);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
int serialdev_free(SimDevice* this)
|
int serialdev_free(SimDevice* this)
|
||||||
{
|
{
|
||||||
SerialDevice* serialdevice = (void *) this->derived;
|
SerialDevice* serialdevice = (void *) this->derived;
|
||||||
|
|
@ -43,6 +78,8 @@ int serialdev_init(SerialDevice* serialdevice, const char* portdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
static const vtable serial_simdevice_vtable = { &serialdev_update, &serialdev_free };
|
static const vtable serial_simdevice_vtable = { &serialdev_update, &serialdev_free };
|
||||||
|
static const vtable arduino_shiftlights_vtable = { &arduino_shiftlights_update, &serialdev_free };
|
||||||
|
static const vtable arduino_simwind_vtable = { &arduino_simwind_update, &serialdev_free };
|
||||||
|
|
||||||
SerialDevice* new_serial_device(DeviceSettings* ds) {
|
SerialDevice* new_serial_device(DeviceSettings* ds) {
|
||||||
|
|
||||||
|
|
@ -53,6 +90,20 @@ SerialDevice* new_serial_device(DeviceSettings* ds) {
|
||||||
this->m.derived = this;
|
this->m.derived = this;
|
||||||
this->m.vtable = &serial_simdevice_vtable;
|
this->m.vtable = &serial_simdevice_vtable;
|
||||||
|
|
||||||
|
slogt("Attempting to configure arduino device with subtype: %i", ds->dev_subtype);
|
||||||
|
switch (ds->dev_subtype) {
|
||||||
|
case (SIMDEVTYPE_SHIFTLIGHTS):
|
||||||
|
this->devicetype = ARDUINODEV__SHIFTLIGHTS;
|
||||||
|
this->m.vtable = &arduino_shiftlights_vtable;
|
||||||
|
slogi("Initializing arduino device for shiftlights.");
|
||||||
|
break;
|
||||||
|
case (SIMDEVTYPE_SIMWIND):
|
||||||
|
this->devicetype = ARDUINODEV__SIMWIND;
|
||||||
|
this->m.vtable = &arduino_simwind_vtable;
|
||||||
|
slogi("Initializing arduino devices for sim wind.");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
int error = serialdev_init(this, ds->serialdevsettings.portdev);
|
int error = serialdev_init(this, ds->serialdevsettings.portdev);
|
||||||
|
|
||||||
if (error != 0)
|
if (error != 0)
|
||||||
|
|
|
||||||
|
|
@ -3,5 +3,11 @@
|
||||||
|
|
||||||
#include <libserialport.h>
|
#include <libserialport.h>
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
ARDUINODEV__SHIFTLIGHTS = 0,
|
||||||
|
ARDUINODEV__SIMWIND = 1,
|
||||||
|
}
|
||||||
|
SerialDeviceType;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -61,6 +61,7 @@ int devinit(SimDevice* simdevices, int numdevices, DeviceSettings* ds)
|
||||||
simdevices[j] = sim->m;
|
simdevices[j] = sim->m;
|
||||||
simdevices[j].initialized = true;
|
simdevices[j].initialized = true;
|
||||||
simdevices[j].type = SIMDEV_USB;
|
simdevices[j].type = SIMDEV_USB;
|
||||||
|
simdevices[j].tyre = ds[j].tyre;
|
||||||
devices++;
|
devices++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -78,6 +79,7 @@ int devinit(SimDevice* simdevices, int numdevices, DeviceSettings* ds)
|
||||||
simdevices[j] = sim->m;
|
simdevices[j] = sim->m;
|
||||||
simdevices[j].initialized = true;
|
simdevices[j].initialized = true;
|
||||||
simdevices[j].type = SIMDEV_SOUND;
|
simdevices[j].type = SIMDEV_SOUND;
|
||||||
|
simdevices[j].tyre = ds[j].tyre;
|
||||||
devices++;
|
devices++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,8 @@
|
||||||
#include "../helper/confighelper.h"
|
#include "../helper/confighelper.h"
|
||||||
#include "../simulatorapi/simapi/simapi/simdata.h"
|
#include "../simulatorapi/simapi/simapi/simdata.h"
|
||||||
|
|
||||||
|
#include "../../arduino/simwind/simwind.h"
|
||||||
|
#include "../../arduino/shiftlights/shiftlights.h"
|
||||||
|
|
||||||
typedef struct SimDevice SimDevice;
|
typedef struct SimDevice SimDevice;
|
||||||
|
|
||||||
|
|
@ -21,7 +23,7 @@ struct SimDevice
|
||||||
int id;
|
int id;
|
||||||
bool initialized;
|
bool initialized;
|
||||||
DeviceType type;
|
DeviceType type;
|
||||||
|
MonocoqueTyreIdentifier tyre;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
@ -43,10 +45,17 @@ typedef struct
|
||||||
int id;
|
int id;
|
||||||
SerialType type;
|
SerialType type;
|
||||||
struct sp_port* port;
|
struct sp_port* port;
|
||||||
|
SerialDeviceType devicetype;
|
||||||
|
union
|
||||||
|
{
|
||||||
|
SimWindData simwinddata;
|
||||||
|
ShiftLightsData shiftlightsdata;
|
||||||
|
} u;
|
||||||
}
|
}
|
||||||
SerialDevice;
|
SerialDevice;
|
||||||
|
|
||||||
int serialdev_update(SimDevice* this, SimData* simdata);
|
int arduino_shiftlights_update(SimDevice* this, SimData* simdata);
|
||||||
|
int arduino_simwind_update(SimDevice* this, SimData* simdata);
|
||||||
int serialdev_free(SimDevice* this);
|
int serialdev_free(SimDevice* this);
|
||||||
|
|
||||||
SerialDevice* new_serial_device(DeviceSettings* ds);
|
SerialDevice* new_serial_device(DeviceSettings* ds);
|
||||||
|
|
@ -55,7 +64,8 @@ SerialDevice* new_serial_device(DeviceSettings* ds);
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
USBDEV_UNKNOWN = 0,
|
USBDEV_UNKNOWN = 0,
|
||||||
USBDEV_TACHOMETER = 1
|
USBDEV_TACHOMETER = 1,
|
||||||
|
USBDEV_GENERICHAPTIC = 2
|
||||||
}
|
}
|
||||||
USBType;
|
USBType;
|
||||||
|
|
||||||
|
|
@ -67,6 +77,7 @@ typedef struct
|
||||||
union
|
union
|
||||||
{
|
{
|
||||||
TachDevice tachdevice;
|
TachDevice tachdevice;
|
||||||
|
USBGenericHapticDevice hapticdevice;
|
||||||
} u;
|
} u;
|
||||||
}
|
}
|
||||||
USBDevice;
|
USBDevice;
|
||||||
|
|
@ -96,6 +107,7 @@ SoundDevice;
|
||||||
|
|
||||||
int sounddev_engine_update(SimDevice* this, SimData* simdata);
|
int sounddev_engine_update(SimDevice* this, SimData* simdata);
|
||||||
int sounddev_gearshift_update(SimDevice* this, SimData* simdata);
|
int sounddev_gearshift_update(SimDevice* this, SimData* simdata);
|
||||||
|
int sounddev_tyreslip_update(SimDevice* this, SimData* simdata);
|
||||||
int sounddev_free(SimDevice* this);
|
int sounddev_free(SimDevice* this);
|
||||||
|
|
||||||
SoundDevice* new_sound_device(DeviceSettings* ds);
|
SoundDevice* new_sound_device(DeviceSettings* ds);
|
||||||
|
|
|
||||||
|
|
@ -112,7 +112,7 @@ int usb_generic_shaker_init(SoundDevice* sounddevice, pa_threaded_mainloop* main
|
||||||
pa_stream_set_state_callback(stream, stream_state_cb, mainloop);
|
pa_stream_set_state_callback(stream, stream_state_cb, mainloop);
|
||||||
|
|
||||||
|
|
||||||
if (sounddevice->effecttype == SOUNDEFFECT_GEARSHIFT)
|
if (sounddevice->effecttype == EFFECT_GEARSHIFT)
|
||||||
{
|
{
|
||||||
pa_stream_set_write_callback(stream, gear_sound_stream, &sounddevice->sounddata);
|
pa_stream_set_write_callback(stream, gear_sound_stream, &sounddevice->sounddata);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -38,6 +38,55 @@ int sounddev_engine_update(SimDevice* this, SimData* simdata)
|
||||||
slogt("set engine frequency to %i", sounddevice->sounddata.frequency);
|
slogt("set engine frequency to %i", sounddevice->sounddata.frequency);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int sounddev_tyreslip_update(SimDevice* this, SimData* simdata)
|
||||||
|
{
|
||||||
|
SoundDevice* sounddevice = (void *) this->derived;
|
||||||
|
|
||||||
|
double play = 0;
|
||||||
|
if (this->tyre == FRONTLEFT || this->tyre == FRONTS || this->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[0];
|
||||||
|
}
|
||||||
|
if (this->tyre == FRONTRIGHT || this->tyre == FRONTS || this->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[1];
|
||||||
|
}
|
||||||
|
if (this->tyre == REARLEFT || this->tyre == REARS || this->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[2];
|
||||||
|
}
|
||||||
|
if (this->tyre == REARRIGHT || this->tyre == REARS || this->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[3];
|
||||||
|
}
|
||||||
|
if (play > 0)
|
||||||
|
{
|
||||||
|
sounddevice->sounddata.curr_frequency = sounddevice->sounddata.frequency * play;
|
||||||
|
sounddevice->sounddata.curr_duration = sounddevice->sounddata.duration;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sounddevice->sounddata.curr_frequency = 0;
|
||||||
|
sounddevice->sounddata.curr_duration = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int sounddev_absbrakes_update(SimDevice* this, SimData* simdata)
|
||||||
|
{
|
||||||
|
SoundDevice* sounddevice = (void *) this->derived;
|
||||||
|
|
||||||
|
if (simdata->abs > 0)
|
||||||
|
{
|
||||||
|
sounddevice->sounddata.curr_frequency = sounddevice->sounddata.frequency;
|
||||||
|
sounddevice->sounddata.curr_duration = sounddevice->sounddata.duration;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sounddevice->sounddata.curr_frequency = 0;
|
||||||
|
sounddevice->sounddata.curr_duration = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int sounddev_gearshift_update(SimDevice* this, SimData* simdata)
|
int sounddev_gearshift_update(SimDevice* this, SimData* simdata)
|
||||||
{
|
{
|
||||||
SoundDevice* sounddevice = (void *) this->derived;
|
SoundDevice* sounddevice = (void *) this->derived;
|
||||||
|
|
@ -79,7 +128,7 @@ int sounddev_init(SoundDevice* sounddevice, const char* devname, int volume, int
|
||||||
|
|
||||||
const char* streamname= "Engine";
|
const char* streamname= "Engine";
|
||||||
switch (sounddevice->effecttype) {
|
switch (sounddevice->effecttype) {
|
||||||
case (SOUNDEFFECT_GEARSHIFT):
|
case (EFFECT_GEARSHIFT):
|
||||||
|
|
||||||
sounddevice->sounddata.last_gear = 0;
|
sounddevice->sounddata.last_gear = 0;
|
||||||
//sounddevice->sounddata.pitch = 500;
|
//sounddevice->sounddata.pitch = 500;
|
||||||
|
|
@ -90,6 +139,16 @@ int sounddev_init(SoundDevice* sounddevice, const char* devname, int volume, int
|
||||||
sounddevice->sounddata.curr_duration = duration;
|
sounddevice->sounddata.curr_duration = duration;
|
||||||
streamname = "Gear";
|
streamname = "Gear";
|
||||||
break;
|
break;
|
||||||
|
case (EFFECT_TYRESLIP):
|
||||||
|
sounddevice->sounddata.duration = duration;
|
||||||
|
sounddevice->sounddata.curr_duration = duration;
|
||||||
|
streamname = "TyreSlip";
|
||||||
|
break;
|
||||||
|
case (EFFECT_ABSBRAKES):
|
||||||
|
sounddevice->sounddata.duration = duration;
|
||||||
|
sounddevice->sounddata.curr_duration = duration;
|
||||||
|
streamname = "ABS";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_PULSEAUDIO
|
#ifdef USE_PULSEAUDIO
|
||||||
|
|
@ -105,6 +164,8 @@ int sounddev_init(SoundDevice* sounddevice, const char* devname, int volume, int
|
||||||
|
|
||||||
static const vtable engine_sound_simdevice_vtable = { &sounddev_engine_update, &sounddev_free };
|
static const vtable engine_sound_simdevice_vtable = { &sounddev_engine_update, &sounddev_free };
|
||||||
static const vtable gear_sound_simdevice_vtable = { &sounddev_gearshift_update, &sounddev_free };
|
static const vtable gear_sound_simdevice_vtable = { &sounddev_gearshift_update, &sounddev_free };
|
||||||
|
static const vtable tyreslip_sound_simdevice_vtable = { &sounddev_tyreslip_update, &sounddev_free };
|
||||||
|
static const vtable absbrakes_sound_simdevice_vtable = { &sounddev_absbrakes_update, &sounddev_free };
|
||||||
|
|
||||||
SoundDevice* new_sound_device(DeviceSettings* ds) {
|
SoundDevice* new_sound_device(DeviceSettings* ds) {
|
||||||
|
|
||||||
|
|
@ -114,18 +175,28 @@ SoundDevice* new_sound_device(DeviceSettings* ds) {
|
||||||
this->m.free = &simdevfree;
|
this->m.free = &simdevfree;
|
||||||
this->m.derived = this;
|
this->m.derived = this;
|
||||||
|
|
||||||
slogt("Attempting to configure sound device with subtype: %i", ds->dev_subtype);
|
slogt("Attempting to configure sound device with subtype: %i", ds->effect_type);
|
||||||
switch (ds->dev_subtype) {
|
switch (ds->effect_type) {
|
||||||
case (SIMDEVTYPE_ENGINESOUND):
|
case (EFFECT_ENGINERPM):
|
||||||
this->effecttype = SOUNDEFFECT_ENGINERPM;
|
this->effecttype = EFFECT_ENGINERPM;
|
||||||
this->m.vtable = &engine_sound_simdevice_vtable;
|
this->m.vtable = &engine_sound_simdevice_vtable;
|
||||||
slogi("Initializing sound device for engine vibrations.");
|
slogi("Initializing sound device for engine vibrations.");
|
||||||
break;
|
break;
|
||||||
case (SIMDEVTYPE_GEARSOUND):
|
case (EFFECT_GEARSHIFT):
|
||||||
this->effecttype = SOUNDEFFECT_GEARSHIFT;
|
this->effecttype = EFFECT_GEARSHIFT;
|
||||||
this->m.vtable = &gear_sound_simdevice_vtable;
|
this->m.vtable = &gear_sound_simdevice_vtable;
|
||||||
slogi("Initializing sound device for gear shift vibrations.");
|
slogi("Initializing sound device for gear shift vibrations.");
|
||||||
break;
|
break;
|
||||||
|
case (EFFECT_TYRESLIP):
|
||||||
|
this->effecttype = EFFECT_TYRESLIP;
|
||||||
|
this->m.vtable = &tyreslip_sound_simdevice_vtable;
|
||||||
|
slogi("Initializing sound device for tyre slip vibrations.");
|
||||||
|
break;
|
||||||
|
case (EFFECT_ABSBRAKES):
|
||||||
|
this->effecttype = EFFECT_ABSBRAKES;
|
||||||
|
this->m.vtable = &absbrakes_sound_simdevice_vtable;
|
||||||
|
slogi("Initializing sound device for abs vibrations.");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
slogt("Attempting to use device %s", ds->sounddevsettings.dev);
|
slogt("Attempting to use device %s", ds->sounddevsettings.dev);
|
||||||
|
|
|
||||||
|
|
@ -14,13 +14,6 @@ typedef enum
|
||||||
}
|
}
|
||||||
SoundType;
|
SoundType;
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
SOUNDEFFECT_ENGINERPM = 0,
|
|
||||||
SOUNDEFFECT_GEARSHIFT = 1
|
|
||||||
}
|
|
||||||
VibrationEffectType;
|
|
||||||
|
|
||||||
#define MAX_TABLE_SIZE (6000)
|
#define MAX_TABLE_SIZE (6000)
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,9 @@ int usbdev_update(SimDevice* this, SimData* simdata)
|
||||||
case USBDEV_TACHOMETER :
|
case USBDEV_TACHOMETER :
|
||||||
tachdev_update(&usbdevice->u.tachdevice, simdata);
|
tachdev_update(&usbdevice->u.tachdevice, simdata);
|
||||||
break;
|
break;
|
||||||
|
case USBDEV_GENERICHAPTIC :
|
||||||
|
usbhapticdev_update(&usbdevice->u.hapticdevice, simdata);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -28,12 +31,16 @@ int usbdev_free(SimDevice* this)
|
||||||
{
|
{
|
||||||
USBDevice* usbdevice = (void *) this->derived;
|
USBDevice* usbdevice = (void *) this->derived;
|
||||||
|
|
||||||
|
slogt("Usb device free");
|
||||||
switch ( usbdevice->type )
|
switch ( usbdevice->type )
|
||||||
{
|
{
|
||||||
case USBDEV_UNKNOWN :
|
case USBDEV_UNKNOWN :
|
||||||
case USBDEV_TACHOMETER :
|
case USBDEV_TACHOMETER :
|
||||||
tachdev_free(&usbdevice->u.tachdevice);
|
tachdev_free(&usbdevice->u.tachdevice);
|
||||||
break;
|
break;
|
||||||
|
case USBDEV_GENERICHAPTIC :
|
||||||
|
usbhapticdev_free(&usbdevice->u.hapticdevice);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
free(usbdevice);
|
free(usbdevice);
|
||||||
|
|
@ -46,13 +53,16 @@ int usbdev_init(USBDevice* usbdevice, DeviceSettings* ds)
|
||||||
slogi("initializing usb device...");
|
slogi("initializing usb device...");
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
|
||||||
usbdevice->type = USBDEV_TACHOMETER;
|
//usbdevice->type = USBDEV_TACHOMETER;
|
||||||
switch ( usbdevice->type )
|
switch ( usbdevice->type )
|
||||||
{
|
{
|
||||||
case USBDEV_UNKNOWN :
|
case USBDEV_UNKNOWN :
|
||||||
case USBDEV_TACHOMETER :
|
case USBDEV_TACHOMETER :
|
||||||
error = tachdev_init(&usbdevice->u.tachdevice, ds);
|
error = tachdev_init(&usbdevice->u.tachdevice, ds);
|
||||||
break;
|
break;
|
||||||
|
case USBDEV_GENERICHAPTIC :
|
||||||
|
error = usbhapticdev_init(&usbdevice->u.hapticdevice, ds);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return error;
|
return error;
|
||||||
|
|
@ -69,6 +79,12 @@ USBDevice* new_usb_device(DeviceSettings* ds) {
|
||||||
this->m.derived = this;
|
this->m.derived = this;
|
||||||
this->m.vtable = &usb_simdevice_vtable;
|
this->m.vtable = &usb_simdevice_vtable;
|
||||||
|
|
||||||
|
this->type = USBDEV_TACHOMETER;
|
||||||
|
if (ds->dev_subtype == SIMDEVTYPE_USBHAPTIC)
|
||||||
|
{
|
||||||
|
this->type = USBDEV_GENERICHAPTIC;
|
||||||
|
}
|
||||||
|
|
||||||
int error = usbdev_init(this, ds);
|
int error = usbdev_init(this, ds);
|
||||||
|
|
||||||
if (error != 0)
|
if (error != 0)
|
||||||
|
|
|
||||||
|
|
@ -2,5 +2,6 @@
|
||||||
#define _USBDEVICE_H
|
#define _USBDEVICE_H
|
||||||
|
|
||||||
#include "tachdevice.h"
|
#include "tachdevice.h"
|
||||||
|
#include "usbhapticdevice.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,99 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
|
#include "usbhapticdevice.h"
|
||||||
|
#include "../../helper/confighelper.h"
|
||||||
|
#include "../../simulatorapi/simapi/simapi/simdata.h"
|
||||||
|
#include "../../slog/slog.h"
|
||||||
|
|
||||||
|
int usbhapticdev_update(USBGenericHapticDevice* usbhapticdevice, SimData* simdata)
|
||||||
|
{
|
||||||
|
double play = 0;
|
||||||
|
switch (usbhapticdevice->effecttype)
|
||||||
|
{
|
||||||
|
case (EFFECT_TYRESLIP):
|
||||||
|
|
||||||
|
if (usbhapticdevice->effecttype == EFFECT_TYRESLIP)
|
||||||
|
{
|
||||||
|
if (usbhapticdevice->tyre == FRONTLEFT || usbhapticdevice->tyre == FRONTS || usbhapticdevice->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[0];
|
||||||
|
}
|
||||||
|
if (usbhapticdevice->tyre == FRONTRIGHT || usbhapticdevice->tyre == FRONTS || usbhapticdevice->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[1];
|
||||||
|
}
|
||||||
|
if (usbhapticdevice->tyre == REARLEFT || usbhapticdevice->tyre == REARS || usbhapticdevice->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[2];
|
||||||
|
}
|
||||||
|
if (usbhapticdevice->tyre == REARRIGHT || usbhapticdevice->tyre == REARS || usbhapticdevice->tyre == ALLFOUR)
|
||||||
|
{
|
||||||
|
play += simdata->wheelslip[3];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case (EFFECT_ABSBRAKES):
|
||||||
|
play += simdata->abs;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (play != usbhapticdevice->state)
|
||||||
|
{
|
||||||
|
if(play > 0)
|
||||||
|
{
|
||||||
|
fprintf(usbhapticdevice->handle, "%i\n", usbhapticdevice->value1);
|
||||||
|
fflush(usbhapticdevice->handle);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fprintf(usbhapticdevice->handle, "%i\n", usbhapticdevice->value0);
|
||||||
|
fflush(usbhapticdevice->handle);
|
||||||
|
|
||||||
|
}
|
||||||
|
usbhapticdevice->state = play;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int usbhapticdev_free(USBGenericHapticDevice* usbhapticdevice)
|
||||||
|
{
|
||||||
|
slogt("closing usb haptic device");
|
||||||
|
fflush(usbhapticdevice->handle);
|
||||||
|
fclose(usbhapticdevice->handle);
|
||||||
|
free(usbhapticdevice->dev);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int usbhapticdev_init(USBGenericHapticDevice* usbhapticdevice, DeviceSettings* ds)
|
||||||
|
{
|
||||||
|
int error = 0;
|
||||||
|
usbhapticdevice->state = 0;
|
||||||
|
usbhapticdevice->dev = strdup(ds->usbdevsettings.dev);
|
||||||
|
usbhapticdevice->value0 = ds->usbdevsettings.value0;
|
||||||
|
usbhapticdevice->value1 = ds->usbdevsettings.value1;
|
||||||
|
usbhapticdevice->state = usbhapticdevice->value0;
|
||||||
|
usbhapticdevice->tyre = ds->tyre;
|
||||||
|
usbhapticdevice->effecttype = ds->effect_type;
|
||||||
|
|
||||||
|
usbhapticdevice->handle = fopen(usbhapticdevice->dev, "w");
|
||||||
|
if(usbhapticdevice->handle == 0)
|
||||||
|
{
|
||||||
|
error = MONOCOQUE_ERROR_INVALID_DEV;
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
slogt("Initializing standalone usb haptic device");
|
||||||
|
if(ds->effect_type == EFFECT_TYRESLIP)
|
||||||
|
{
|
||||||
|
usbhapticdevice->effecttype = EFFECT_TYRESLIP;
|
||||||
|
}
|
||||||
|
if(ds->effect_type == EFFECT_WHEELLOCK)
|
||||||
|
{
|
||||||
|
usbhapticdevice->effecttype = EFFECT_WHEELLOCK;
|
||||||
|
}
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
#ifndef _USBHAPTICDEVICE_H
|
||||||
|
#define _USBHAPTICDEVICE_H
|
||||||
|
|
||||||
|
#include <hidapi/hidapi.h>
|
||||||
|
#include "../helper/confighelper.h"
|
||||||
|
#include "../simulatorapi/simapi/simapi/simdata.h"
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
HAPTIC_UNKNOWN = 0,
|
||||||
|
HAPTIC_GENERIC = 1
|
||||||
|
}
|
||||||
|
HapticType;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
int id;
|
||||||
|
HapticType type;
|
||||||
|
double state;
|
||||||
|
int value0;
|
||||||
|
int value1;
|
||||||
|
VibrationEffectType effecttype;
|
||||||
|
MonocoqueTyreIdentifier tyre;
|
||||||
|
FILE* handle;
|
||||||
|
char* dev;
|
||||||
|
}
|
||||||
|
USBGenericHapticDevice;
|
||||||
|
|
||||||
|
|
||||||
|
int usbhapticdev_update(USBGenericHapticDevice* hapticdevice, SimData* simdata);
|
||||||
|
int usbhapticdev_init(USBGenericHapticDevice* hapticdevice, DeviceSettings* ds);
|
||||||
|
int usbhapticdev_free(USBGenericHapticDevice* hapticdevice);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <poll.h>
|
#include <poll.h>
|
||||||
#include <termios.h>
|
#include <termios.h>
|
||||||
|
#include <signal.h>
|
||||||
|
|
||||||
#include "gameloop.h"
|
#include "gameloop.h"
|
||||||
#include "../helper/parameters.h"
|
#include "../helper/parameters.h"
|
||||||
|
|
@ -17,6 +18,19 @@
|
||||||
|
|
||||||
#define DEFAULT_UPDATE_RATE 240.0
|
#define DEFAULT_UPDATE_RATE 240.0
|
||||||
#define SIM_CHECK_RATE 1.0
|
#define SIM_CHECK_RATE 1.0
|
||||||
|
bool go = false;
|
||||||
|
bool go2 = false;
|
||||||
|
struct sigaction act;
|
||||||
|
|
||||||
|
void sighandler(int signum, siginfo_t* info, void* ptr)
|
||||||
|
{
|
||||||
|
sloge("caught signal");
|
||||||
|
go = false;
|
||||||
|
go2 = false;
|
||||||
|
//gfx_clear(pixels, pixels_len);
|
||||||
|
//gfx_swapbuffers();
|
||||||
|
//gfx_close();
|
||||||
|
}
|
||||||
|
|
||||||
int showstats(SimData* simdata)
|
int showstats(SimData* simdata)
|
||||||
{
|
{
|
||||||
|
|
@ -170,27 +184,13 @@ int showstats(SimData* simdata)
|
||||||
|
|
||||||
int clilooper(SimDevice* devices, int numdevices, Parameters* p, SimData* simdata, SimMap* simmap)
|
int clilooper(SimDevice* devices, int numdevices, Parameters* p, SimData* simdata, SimMap* simmap)
|
||||||
{
|
{
|
||||||
|
|
||||||
slogi("preparing game loop with %i devices...", numdevices);
|
|
||||||
|
|
||||||
|
|
||||||
slogi("sending initial data to devices");
|
|
||||||
simdata->velocity = 16;
|
|
||||||
simdata->rpms = 100;
|
|
||||||
for (int x = 0; x < numdevices; x++)
|
|
||||||
{
|
|
||||||
devices[x].update(&devices[x], simdata);
|
|
||||||
}
|
|
||||||
sleep(3);
|
|
||||||
|
|
||||||
|
|
||||||
struct pollfd mypoll = { STDIN_FILENO, POLLIN|POLLPRI };
|
struct pollfd mypoll = { STDIN_FILENO, POLLIN|POLLPRI };
|
||||||
double update_rate = DEFAULT_UPDATE_RATE;
|
double update_rate = DEFAULT_UPDATE_RATE;
|
||||||
char ch;
|
char ch;
|
||||||
int t=0;
|
int t=0;
|
||||||
int s=0;
|
int s=0;
|
||||||
bool go = true;
|
go2 = true;
|
||||||
while (go == true && simdata->simstatus > 1)
|
while (go2 == true && simdata->simstatus > 1)
|
||||||
{
|
{
|
||||||
simdatamap(simdata, simmap, p->sim);
|
simdatamap(simdata, simmap, p->sim);
|
||||||
showstats(simdata);
|
showstats(simdata);
|
||||||
|
|
@ -210,7 +210,7 @@ int clilooper(SimDevice* devices, int numdevices, Parameters* p, SimData* simdat
|
||||||
scanf("%c", &ch);
|
scanf("%c", &ch);
|
||||||
if(ch == 'q')
|
if(ch == 'q')
|
||||||
{
|
{
|
||||||
go = false;
|
go2 = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -229,6 +229,12 @@ int clilooper(SimDevice* devices, int numdevices, Parameters* p, SimData* simdat
|
||||||
|
|
||||||
int looper(SimDevice* devices, int numdevices, Parameters* p)
|
int looper(SimDevice* devices, int numdevices, Parameters* p)
|
||||||
{
|
{
|
||||||
|
memset(&act, 0, sizeof(act));
|
||||||
|
act.sa_sigaction = sighandler;
|
||||||
|
act.sa_flags = SA_SIGINFO;
|
||||||
|
sigaction(SIGTERM, &act, NULL);
|
||||||
|
sigaction(SIGINT, &act, NULL);
|
||||||
|
sigaction(SIGTSTP, &act, NULL);
|
||||||
|
|
||||||
SimData* simdata = malloc(sizeof(SimData));
|
SimData* simdata = malloc(sizeof(SimData));
|
||||||
SimMap* simmap = malloc(sizeof(SimMap));
|
SimMap* simmap = malloc(sizeof(SimMap));
|
||||||
|
|
@ -244,23 +250,28 @@ int looper(SimDevice* devices, int numdevices, Parameters* p)
|
||||||
struct pollfd mypoll = { STDIN_FILENO, POLLIN|POLLPRI };
|
struct pollfd mypoll = { STDIN_FILENO, POLLIN|POLLPRI };
|
||||||
|
|
||||||
fprintf(stdout, "Searching for sim data... Press q to quit...\n");
|
fprintf(stdout, "Searching for sim data... Press q to quit...\n");
|
||||||
|
|
||||||
p->simon = false;
|
p->simon = false;
|
||||||
double update_rate = SIM_CHECK_RATE;
|
double update_rate = SIM_CHECK_RATE;
|
||||||
int go = true;
|
go = true;
|
||||||
while (go == true)
|
while (go == true)
|
||||||
{
|
{
|
||||||
|
p->simon = false;
|
||||||
|
getSim(simdata, simmap, &p->simon, &p->sim);
|
||||||
|
|
||||||
|
if (p->simon == true && simdata->simstatus > 1)
|
||||||
|
|
||||||
|
|
||||||
if (p->simon == false)
|
|
||||||
{
|
{
|
||||||
getSim(simdata, simmap, &p->simon, &p->sim);
|
slogi("preparing game loop with %i devices...", numdevices);
|
||||||
}
|
|
||||||
|
|
||||||
|
slogi("sending initial data to devices");
|
||||||
|
simdata->velocity = 16;
|
||||||
|
simdata->rpms = 100;
|
||||||
|
for (int x = 0; x < numdevices; x++)
|
||||||
|
{
|
||||||
|
devices[x].update(&devices[x], simdata);
|
||||||
|
}
|
||||||
|
sleep(3);
|
||||||
|
|
||||||
if (p->simon == true)
|
|
||||||
{
|
|
||||||
clilooper(devices, numdevices, p, simdata, simmap);
|
clilooper(devices, numdevices, p, simdata, simmap);
|
||||||
}
|
}
|
||||||
if (p->simon == true)
|
if (p->simon == true)
|
||||||
|
|
@ -270,12 +281,15 @@ int looper(SimDevice* devices, int numdevices, Parameters* p)
|
||||||
sleep(2);
|
sleep(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( poll(&mypoll, 1, 1000.0/update_rate) )
|
if (poll(&mypoll, 1, 1000.0/update_rate) )
|
||||||
{
|
{
|
||||||
scanf("%c", &ch);
|
if (go != false )
|
||||||
if(ch == 'q')
|
|
||||||
{
|
{
|
||||||
go = false;
|
scanf("%c", &ch);
|
||||||
|
if(ch == 'q')
|
||||||
|
{
|
||||||
|
go = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -309,6 +323,11 @@ int tester(SimDevice* devices, int numdevices)
|
||||||
simdata->velocity = 16;
|
simdata->velocity = 16;
|
||||||
simdata->rpms = 100;
|
simdata->rpms = 100;
|
||||||
simdata->maxrpm = 8000;
|
simdata->maxrpm = 8000;
|
||||||
|
simdata->abs = 0;
|
||||||
|
simdata->wheelslip[0] = 0;
|
||||||
|
simdata->wheelslip[1] = 0;
|
||||||
|
simdata->wheelslip[2] = 0;
|
||||||
|
simdata->wheelslip[3] = 0;
|
||||||
sleep(3);
|
sleep(3);
|
||||||
|
|
||||||
fprintf(stdout, "Setting rpms to 1000\n");
|
fprintf(stdout, "Setting rpms to 1000\n");
|
||||||
|
|
@ -319,6 +338,30 @@ int tester(SimDevice* devices, int numdevices)
|
||||||
}
|
}
|
||||||
sleep(3);
|
sleep(3);
|
||||||
|
|
||||||
|
fprintf(stdout, "Setting ABS to 1\n");
|
||||||
|
simdata->abs = 1;
|
||||||
|
for (int x = 0; x < numdevices; x++)
|
||||||
|
{
|
||||||
|
devices[x].update(&devices[x], simdata);
|
||||||
|
}
|
||||||
|
sleep(3);
|
||||||
|
simdata->abs = 0;
|
||||||
|
|
||||||
|
fprintf(stdout, "Setting Wheelslip to 1\n");
|
||||||
|
simdata->wheelslip[0] = 1;
|
||||||
|
simdata->wheelslip[1] = 1;
|
||||||
|
simdata->wheelslip[2] = 1;
|
||||||
|
simdata->wheelslip[3] = 1;
|
||||||
|
for (int x = 0; x < numdevices; x++)
|
||||||
|
{
|
||||||
|
devices[x].update(&devices[x], simdata);
|
||||||
|
}
|
||||||
|
sleep(3);
|
||||||
|
simdata->wheelslip[0] = 0;
|
||||||
|
simdata->wheelslip[1] = 0;
|
||||||
|
simdata->wheelslip[2] = 0;
|
||||||
|
simdata->wheelslip[3] = 0;
|
||||||
|
|
||||||
fprintf(stdout, "Shifting into first gear\n");
|
fprintf(stdout, "Shifting into first gear\n");
|
||||||
simdata->gear = 2;
|
simdata->gear = 2;
|
||||||
for (int x = 0; x < numdevices; x++)
|
for (int x = 0; x < numdevices; x++)
|
||||||
|
|
|
||||||
|
|
@ -52,6 +52,31 @@ int strtogame(const char* game, MonocoqueSettings* ms)
|
||||||
return MONOCOQUE_ERROR_NONE;
|
return MONOCOQUE_ERROR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int strtoeffecttype(const char* effect, DeviceSettings* ds)
|
||||||
|
{
|
||||||
|
ds->is_valid = false;
|
||||||
|
|
||||||
|
if (strcicmp(effect, "Engine") == 0)
|
||||||
|
{
|
||||||
|
ds->effect_type = EFFECT_ENGINERPM;
|
||||||
|
}
|
||||||
|
if (strcicmp(effect, "Gear") == 0)
|
||||||
|
{
|
||||||
|
ds->effect_type = EFFECT_GEARSHIFT;
|
||||||
|
}
|
||||||
|
if (strcicmp(effect, "ABS") == 0)
|
||||||
|
{
|
||||||
|
ds->effect_type = EFFECT_ABSBRAKES;
|
||||||
|
}
|
||||||
|
if ((strcicmp(effect, "SLIP") == 0) || (strcicmp(effect, "TYRESLIP") == 0) || (strcicmp(effect, "TIRESLIP") == 0))
|
||||||
|
{
|
||||||
|
ds->effect_type = EFFECT_TYRESLIP;
|
||||||
|
}
|
||||||
|
|
||||||
|
ds->is_valid = true;
|
||||||
|
return MONOCOQUE_ERROR_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
int strtodevsubtype(const char* device_subtype, DeviceSettings* ds, int simdev)
|
int strtodevsubtype(const char* device_subtype, DeviceSettings* ds, int simdev)
|
||||||
{
|
{
|
||||||
ds->is_valid = false;
|
ds->is_valid = false;
|
||||||
|
|
@ -64,6 +89,11 @@ int strtodevsubtype(const char* device_subtype, DeviceSettings* ds, int simdev)
|
||||||
ds->dev_subtype = SIMDEVTYPE_TACHOMETER;
|
ds->dev_subtype = SIMDEVTYPE_TACHOMETER;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (strcicmp(device_subtype, "UsbHaptic") == 0 || strcicmp(device_subtype, "Haptic") == 0)
|
||||||
|
{
|
||||||
|
ds->dev_subtype = SIMDEVTYPE_USBHAPTIC;
|
||||||
|
break;
|
||||||
|
}
|
||||||
case SIMDEV_SERIAL:
|
case SIMDEV_SERIAL:
|
||||||
if (strcicmp(device_subtype, "ShiftLights") == 0)
|
if (strcicmp(device_subtype, "ShiftLights") == 0)
|
||||||
{
|
{
|
||||||
|
|
@ -76,21 +106,8 @@ int strtodevsubtype(const char* device_subtype, DeviceSettings* ds, int simdev)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SIMDEV_SOUND:
|
case SIMDEV_SOUND:
|
||||||
if (strcicmp(device_subtype, "Engine") == 0)
|
ds->is_valid = true;
|
||||||
{
|
break;
|
||||||
ds->dev_subtype = SIMDEVTYPE_ENGINESOUND;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (strcicmp(device_subtype, "Gear") == 0)
|
|
||||||
{
|
|
||||||
ds->dev_subtype = SIMDEVTYPE_GEARSOUND;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (strcicmp(device_subtype, "ABS") == 0)
|
|
||||||
{
|
|
||||||
ds->dev_subtype = SIMDEVTYPE_ABSBRAKES;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
ds->is_valid = false;
|
ds->is_valid = false;
|
||||||
slogw("%s does not appear to be a valid device sub type, but attempting to continue with other devices", device_subtype);
|
slogw("%s does not appear to be a valid device sub type, but attempting to continue with other devices", device_subtype);
|
||||||
|
|
@ -223,6 +240,40 @@ int loadtachconfig(const char* config_file, DeviceSettings* ds)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int gettyre(config_setting_t* device_settings, DeviceSettings* ds) {
|
||||||
|
|
||||||
|
const char* temp;
|
||||||
|
int found = config_setting_lookup_string(device_settings, "tyre", &temp);
|
||||||
|
|
||||||
|
ds->tyre = ALLFOUR;
|
||||||
|
|
||||||
|
if (strcicmp(temp, "FRONTS") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = FRONTS;
|
||||||
|
}
|
||||||
|
if (strcicmp(temp, "REARS") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = REARS;
|
||||||
|
}
|
||||||
|
if (strcicmp(temp, "FRONTLEFT") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = FRONTLEFT;
|
||||||
|
}
|
||||||
|
if (strcicmp(temp, "FRONTRIGHT") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = FRONTRIGHT;
|
||||||
|
}
|
||||||
|
if (strcicmp(temp, "REARLEFT") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = REARLEFT;
|
||||||
|
}
|
||||||
|
if (strcicmp(temp, "REARRIGHT") == 0)
|
||||||
|
{
|
||||||
|
ds->tyre = REARRIGHT;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
int loadconfig(const char* config_file, DeviceSettings* ds)
|
int loadconfig(const char* config_file, DeviceSettings* ds)
|
||||||
{
|
{
|
||||||
if (ds->dev_subtype == SIMDEVTYPE_TACHOMETER)
|
if (ds->dev_subtype == SIMDEVTYPE_TACHOMETER)
|
||||||
|
|
@ -239,6 +290,7 @@ int devsetup(const char* device_type, const char* device_subtype, const char* co
|
||||||
ds->dev_type = SIMDEV_UNKNOWN;
|
ds->dev_type = SIMDEV_UNKNOWN;
|
||||||
|
|
||||||
error = strtodev(device_type, device_subtype, ds);
|
error = strtodev(device_type, device_subtype, ds);
|
||||||
|
|
||||||
if (error != MONOCOQUE_ERROR_NONE)
|
if (error != MONOCOQUE_ERROR_NONE)
|
||||||
{
|
{
|
||||||
return error;
|
return error;
|
||||||
|
|
@ -253,40 +305,7 @@ int devsetup(const char* device_type, const char* device_subtype, const char* co
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ds->dev_type == SIMDEV_SOUND)
|
|
||||||
{
|
|
||||||
slogi("reading configured sound device settings");
|
|
||||||
ds->sounddevsettings.frequency = -1;
|
|
||||||
ds->sounddevsettings.volume = -1;
|
|
||||||
ds->sounddevsettings.lowbound_frequency = -1;
|
|
||||||
ds->sounddevsettings.upperbound_frequency = -1;
|
|
||||||
ds->sounddevsettings.pan = 0;
|
|
||||||
ds->sounddevsettings.duration = 2.0;
|
|
||||||
if (ds->dev_subtype == SIMDEVTYPE_GEARSOUND)
|
|
||||||
{
|
|
||||||
ds->sounddevsettings.duration = .125;
|
|
||||||
}
|
|
||||||
if (device_settings != NULL)
|
|
||||||
{
|
|
||||||
|
|
||||||
config_setting_lookup_int(device_settings, "volume", &ds->sounddevsettings.volume);
|
|
||||||
config_setting_lookup_int(device_settings, "frequency", &ds->sounddevsettings.frequency);
|
|
||||||
config_setting_lookup_int(device_settings, "pan", &ds->sounddevsettings.pan);
|
|
||||||
config_setting_lookup_float(device_settings, "duration", &ds->sounddevsettings.duration);
|
|
||||||
|
|
||||||
const char* temp;
|
|
||||||
int found = 0;
|
|
||||||
found = config_setting_lookup_string(device_settings, "devid", &temp);
|
|
||||||
if (found == 0)
|
|
||||||
{
|
|
||||||
ds->sounddevsettings.dev = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ds->sounddevsettings.dev = strdup(temp);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ds->dev_subtype == SIMDEVTYPE_TACHOMETER)
|
if (ds->dev_subtype == SIMDEVTYPE_TACHOMETER)
|
||||||
{
|
{
|
||||||
|
|
@ -307,6 +326,73 @@ int devsetup(const char* device_type, const char* device_subtype, const char* co
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ds->dev_subtype == SIMDEVTYPE_USBHAPTIC)
|
||||||
|
{
|
||||||
|
if (device_settings != NULL)
|
||||||
|
{
|
||||||
|
ds->usbdevsettings.value0 = 0;
|
||||||
|
ds->usbdevsettings.value1 = 1;
|
||||||
|
|
||||||
|
const char* temp;
|
||||||
|
int found = config_setting_lookup_string(device_settings, "devpath", &temp);
|
||||||
|
if (found == 0)
|
||||||
|
{
|
||||||
|
ds->usbdevsettings.dev = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ds->usbdevsettings.dev = strdup(temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
config_setting_lookup_int(device_settings, "value0", &ds->usbdevsettings.value0);
|
||||||
|
config_setting_lookup_int(device_settings, "value1", &ds->usbdevsettings.value1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ds->dev_subtype == SIMDEVTYPE_USBHAPTIC || ds->dev_type == SIMDEV_SOUND) {
|
||||||
|
const char* effect;
|
||||||
|
config_setting_lookup_string(device_settings, "effect", &effect);
|
||||||
|
strtoeffecttype(effect, ds);
|
||||||
|
if (ds->effect_type == EFFECT_TYRESLIP || ds->effect_type == EFFECT_WHEELLOCK)
|
||||||
|
{
|
||||||
|
gettyre(device_settings, ds);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ds->dev_type == SIMDEV_SOUND)
|
||||||
|
{
|
||||||
|
slogi("reading configured sound device settings");
|
||||||
|
ds->sounddevsettings.frequency = -1;
|
||||||
|
ds->sounddevsettings.volume = -1;
|
||||||
|
ds->sounddevsettings.lowbound_frequency = -1;
|
||||||
|
ds->sounddevsettings.upperbound_frequency = -1;
|
||||||
|
ds->sounddevsettings.pan = 0;
|
||||||
|
ds->sounddevsettings.duration = 2.0;
|
||||||
|
if (ds->effect_type == EFFECT_GEARSHIFT)
|
||||||
|
{
|
||||||
|
ds->sounddevsettings.duration = .125;
|
||||||
|
}
|
||||||
|
if (device_settings != NULL)
|
||||||
|
{
|
||||||
|
|
||||||
|
config_setting_lookup_int(device_settings, "volume", &ds->sounddevsettings.volume);
|
||||||
|
config_setting_lookup_int(device_settings, "frequency", &ds->sounddevsettings.frequency);
|
||||||
|
config_setting_lookup_int(device_settings, "pan", &ds->sounddevsettings.pan);
|
||||||
|
config_setting_lookup_float(device_settings, "duration", &ds->sounddevsettings.duration);
|
||||||
|
|
||||||
|
const char* temp;
|
||||||
|
int found = 0;
|
||||||
|
found = config_setting_lookup_string(device_settings, "devid", &temp);
|
||||||
|
if (found == 0)
|
||||||
|
{
|
||||||
|
ds->sounddevsettings.dev = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ds->sounddevsettings.dev = strdup(temp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (ds->dev_subtype == SIMDEVTYPE_SIMWIND || ds->dev_subtype == SIMDEVTYPE_SHIFTLIGHTS)
|
if (ds->dev_subtype == SIMDEVTYPE_SIMWIND || ds->dev_subtype == SIMDEVTYPE_SHIFTLIGHTS)
|
||||||
{
|
{
|
||||||
|
|
@ -339,5 +425,13 @@ int settingsfree(DeviceSettings ds)
|
||||||
free(ds.sounddevsettings.dev);
|
free(ds.sounddevsettings.dev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ds.dev_type == SIMDEV_USB)
|
||||||
|
{
|
||||||
|
if (ds.usbdevsettings.dev != NULL )
|
||||||
|
{
|
||||||
|
free(ds.usbdevsettings.dev);
|
||||||
|
}
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef _CONFIGHELPER_H
|
#ifndef _CONFIGHELPER_H
|
||||||
#define _CONFIGHELPER_H
|
#define _CONFIGHELPER_H
|
||||||
|
|
||||||
|
#include <pulse/channelmap.h>
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
|
@ -21,11 +22,9 @@ typedef enum
|
||||||
{
|
{
|
||||||
SIMDEVTYPE_UNKNOWN = 0,
|
SIMDEVTYPE_UNKNOWN = 0,
|
||||||
SIMDEVTYPE_TACHOMETER = 1,
|
SIMDEVTYPE_TACHOMETER = 1,
|
||||||
SIMDEVTYPE_SHIFTLIGHTS = 2,
|
SIMDEVTYPE_USBHAPTIC = 2,
|
||||||
SIMDEVTYPE_SIMWIND = 3,
|
SIMDEVTYPE_SHIFTLIGHTS = 3,
|
||||||
SIMDEVTYPE_ENGINESOUND = 4,
|
SIMDEVTYPE_SIMWIND = 4
|
||||||
SIMDEVTYPE_GEARSOUND = 5,
|
|
||||||
SIMDEVTYPE_ABSBRAKES = 6
|
|
||||||
}
|
}
|
||||||
DeviceSubType;
|
DeviceSubType;
|
||||||
|
|
||||||
|
|
@ -41,6 +40,16 @@ typedef enum
|
||||||
}
|
}
|
||||||
SimulatorUpdate;
|
SimulatorUpdate;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
EFFECT_ENGINERPM = 0,
|
||||||
|
EFFECT_GEARSHIFT = 1,
|
||||||
|
EFFECT_ABSBRAKES = 2,
|
||||||
|
EFFECT_TYRESLIP = 3,
|
||||||
|
EFFECT_WHEELLOCK = 4
|
||||||
|
}
|
||||||
|
VibrationEffectType;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
MONOCOQUE_ERROR_NONE = 0,
|
MONOCOQUE_ERROR_NONE = 0,
|
||||||
|
|
@ -52,6 +61,18 @@ typedef enum
|
||||||
}
|
}
|
||||||
MonocoqueError;
|
MonocoqueError;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
FRONTLEFT = 0,
|
||||||
|
FRONTRIGHT = 1,
|
||||||
|
REARLEFT = 2,
|
||||||
|
REARRIGHT = 3,
|
||||||
|
FRONTS = 4,
|
||||||
|
REARS = 5,
|
||||||
|
ALLFOUR = 6
|
||||||
|
}
|
||||||
|
MonocoqueTyreIdentifier;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
ProgramAction program_action;
|
ProgramAction program_action;
|
||||||
|
|
@ -87,14 +108,26 @@ typedef struct
|
||||||
}
|
}
|
||||||
SoundDeviceSettings;
|
SoundDeviceSettings;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
int value0;
|
||||||
|
int value1;
|
||||||
|
char* dev;
|
||||||
|
}
|
||||||
|
USBDeviceSettings;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
bool is_valid;
|
bool is_valid;
|
||||||
DeviceType dev_type;
|
DeviceType dev_type;
|
||||||
DeviceSubType dev_subtype;
|
DeviceSubType dev_subtype;
|
||||||
|
VibrationEffectType effect_type;
|
||||||
|
// union?
|
||||||
TachometerSettings tachsettings;
|
TachometerSettings tachsettings;
|
||||||
SerialDeviceSettings serialdevsettings;
|
SerialDeviceSettings serialdevsettings;
|
||||||
SoundDeviceSettings sounddevsettings;
|
SoundDeviceSettings sounddevsettings;
|
||||||
|
USBDeviceSettings usbdevsettings;
|
||||||
|
MonocoqueTyreIdentifier tyre;
|
||||||
}
|
}
|
||||||
DeviceSettings;
|
DeviceSettings;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1 +1 @@
|
||||||
Subproject commit c77e96339caf1eb79479d89ce342161ad83ca70e
|
Subproject commit 231e64e1190686dad77fcaf2e9e5e9bc8d831274
|
||||||
Loading…
Reference in New Issue