diff options
| author | Lennart <lekaiser@uos.de> | 2020-07-25 20:50:23 +0200 | 
|---|---|---|
| committer | Lennart <lekaiser@uos.de> | 2020-07-25 20:50:23 +0200 | 
| commit | 714e5788be7b89f937fe8dbf270b8035c4f7d436 (patch) | |
| tree | e05ae1a2b421840847ae28d053a26d8538fe89c1 /src | |
| parent | 5c4045862bf55be0b8dc755ac3d5c5bd24b5fedf (diff) | |
| parent | d0ea0a521a582549dfd9a98b47e7c12d8bcd0de6 (diff) | |
Merge branch 'master' into state-duration-timers
Diffstat (limited to 'src')
| -rw-r--r-- | src/arch/msp430fr5994lp/Makefile.inc | 16 | ||||
| -rw-r--r-- | src/arch/msp430fr5994lp/driver/timed_resistive_load.cc | 85 | ||||
| -rw-r--r-- | src/driver/mmsubstate.cc | 41 | 
3 files changed, 141 insertions, 1 deletions
| diff --git a/src/arch/msp430fr5994lp/Makefile.inc b/src/arch/msp430fr5994lp/Makefile.inc index 8348d8e..e9d666f 100644 --- a/src/arch/msp430fr5994lp/Makefile.inc +++ b/src/arch/msp430fr5994lp/Makefile.inc @@ -72,6 +72,19 @@ ifneq ($(findstring counter,${arch_drivers}), )  	CXX_TARGETS += src/arch/msp430fr5994lp/driver/counter.cc  endif +ifneq ($(findstring timed_resistive_load,${arch_drivers}), ) +	CXX_TARGETS += src/arch/msp430fr5994lp/driver/timed_resistive_load.cc +	resistor1_pin ?= p3_0 +	resistor2_pin ?= p3_1 +	resistor3_pin ?= p3_2 +	resistor4_pin ?= p3_3 +	COMMON_FLAGS += -DDRIVER_TIMED_RESISTIVE_LOAD +	COMMON_FLAGS += -DTIMED_RESISTIVE_LOAD_PIN1=GPIO::${resistor1_pin} +	COMMON_FLAGS += -DTIMED_RESISTIVE_LOAD_PIN2=GPIO::${resistor2_pin} +	COMMON_FLAGS += -DTIMED_RESISTIVE_LOAD_PIN3=GPIO::${resistor3_pin} +	COMMON_FLAGS += -DTIMED_RESISTIVE_LOAD_PIN4=GPIO::${resistor4_pin} +endif +  ifneq (${cpu_freq}, )  	COMMON_FLAGS += -DF_CPU=${cpu_freq}UL  else @@ -127,7 +140,8 @@ arch_info:  	@echo "CPU   Freq: ${cpu_freq} Hz"  	@echo "Timer Freq: ${timer_freq} Hz -> $(shell src/arch/msp430fr5994lp/model.py f_timer "${cpu_freq}" "${timer_freq}")"  	@echo "I2C   Freq: ${i2c_freq} Hz" -	@echo "Counter Overflow: 65536/255" +	@echo "Counter Overflow: 65536/65535" +	@echo "sleep_ms Overflow: 250 500"  	@echo "Monitor: /dev/${SERIAL_PORT} 115200"  .PHONY: arch_clean arch_help arch_info monitor program diff --git a/src/arch/msp430fr5994lp/driver/timed_resistive_load.cc b/src/arch/msp430fr5994lp/driver/timed_resistive_load.cc new file mode 100644 index 0000000..2c46be2 --- /dev/null +++ b/src/arch/msp430fr5994lp/driver/timed_resistive_load.cc @@ -0,0 +1,85 @@ +#include "driver/timed_resistive_load.h" +#include "driver/gpio.h" +#include "arch.h" + +#ifndef TIMED_RESISTIVE_LOAD_PIN1 +#error TIMED_RESISTIVE_LOAD_PIN1 must be set +#endif + +#ifndef TIMED_RESISTIVE_LOAD_PIN2 +#error TIMED_RESISTIVE_LOAD_PIN2 must be set +#endif + +#ifndef TIMED_RESISTIVE_LOAD_PIN3 +#error TIMED_RESISTIVE_LOAD_PIN3 must be set +#endif + +#ifndef TIMED_RESISTIVE_LOAD_PIN4 +#error TIMED_RESISTIVE_LOAD_PIN4 must be set +#endif + +void TimedResistiveLoad::setup() +{ +	gpio.output(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.output(TIMED_RESISTIVE_LOAD_PIN2, 0); +	gpio.output(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.output(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +void TimedResistiveLoad::switchToNone() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +void TimedResistiveLoad::switchTo750() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +void TimedResistiveLoad::switchTo1K0() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +void TimedResistiveLoad::switchTo2K4() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 1); +} + +void TimedResistiveLoad::switchTo3K3() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +void TimedResistiveLoad::switchTo10K() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 1); +} + +void TimedResistiveLoad::switchTo47K() +{ +	gpio.write(TIMED_RESISTIVE_LOAD_PIN1, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN2, 0); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN3, 1); +	gpio.write(TIMED_RESISTIVE_LOAD_PIN4, 0); +} + +TimedResistiveLoad timedResistiveLoad; diff --git a/src/driver/mmsubstate.cc b/src/driver/mmsubstate.cc new file mode 100644 index 0000000..b701f0b --- /dev/null +++ b/src/driver/mmsubstate.cc @@ -0,0 +1,41 @@ +#include "driver/mmsubstate.h" +#if defined(MULTIPASS_ARCH_HAS_I2C) && !defined(DRIVER_SOFTI2C) +#include "driver/i2c.h" +#else +#include "driver/soft_i2c.h" +#endif + +void MicroMoodySubstate::setSubstates(unsigned char substateCount, unsigned char switchDuration, unsigned char power) +{ +	txbuf[0] = substateCount; +	txbuf[1] = power; +	txbuf[2] = switchDuration; +	i2c.xmit(address, 3, txbuf, 0, txbuf); +} + +void MicroMoodySubstate::sleep() +{ +	setSubstates(1, 0, 0); +} + +void MicroMoodySubstate::noSubstates(unsigned char power1, unsigned char power2) +{ +	setSubstates(1, power1, power2); +} + +void MicroMoodySubstate::twoSubstates(unsigned char switchDuration, unsigned char power) +{ +	setSubstates(2, switchDuration, power); +} + +void MicroMoodySubstate::fourSubstates(unsigned char switchDuration, unsigned char power) +{ +	setSubstates(4, switchDuration, power); +} + +void MicroMoodySubstate::eightSubstates(unsigned char switchDuration, unsigned char power) +{ +	setSubstates(8, switchDuration, power); +} + +MicroMoodySubstate moody(0x11); | 
