summaryrefslogtreecommitdiff
path: root/src/system_fsm/booting.cpp
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2024-04-19 16:52:33 +1000
committerjacqueline <me@jacqueline.id.au>2024-04-19 16:52:33 +1000
commit5b99267cb9f0344e519956096867aea5468ecf9f (patch)
tree9a6fd47602c4a4971434b1ed30142fd383ca8cdb /src/system_fsm/booting.cpp
parent8e113ea9ae595b1bc37e7a567b0bc6b90ec81c05 (diff)
parent7c075cf5b776feaed2065f936dff0c176635b89d (diff)
downloadtangara-fw-5b99267cb9f0344e519956096867aea5468ecf9f.tar.gz
Merge branch 'main' of codeberg.org:cool-tech-zone/tangara-fw
Diffstat (limited to 'src/system_fsm/booting.cpp')
-rw-r--r--src/system_fsm/booting.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/system_fsm/booting.cpp b/src/system_fsm/booting.cpp
index bd394428..a89f35d9 100644
--- a/src/system_fsm/booting.cpp
+++ b/src/system_fsm/booting.cpp
@@ -62,6 +62,10 @@ auto Booting::entry() -> void {
sServices->nvs(
std::unique_ptr<drivers::NvsStorage>(drivers::NvsStorage::OpenSync()));
+ // HACK: tell the unit that it has an ERM motor (we will likely default to
+ // LRAs in future, but all the current units in the field use ERMs.)
+ sServices->nvs().HapticMotorIsErm(true);
+
// HACK: fix up the switch polarity on newer dev units
// sServices->nvs().LockPolarity(false);
@@ -85,7 +89,11 @@ auto Booting::entry() -> void {
sServices->samd(std::unique_ptr<drivers::Samd>(drivers::Samd::Create()));
sServices->touchwheel(
std::unique_ptr<drivers::TouchWheel>{drivers::TouchWheel::Create()});
- sServices->haptics(std::make_unique<drivers::Haptics>());
+ sServices->haptics(std::make_unique<drivers::Haptics>(
+ sServices->nvs().HapticMotorIsErm()
+ ? std::variant<drivers::ErmMotor, drivers::LraMotor>(
+ drivers::ErmMotor())
+ : drivers::LraMotor()));
auto adc = drivers::AdcBattery::Create();
sServices->battery(std::make_unique<battery::Battery>(