Update clang-tidy configuration and fix some warnings (#1474)
Don't enable coding conventions from unrelated projects. Only enable generic checks.
This commit is contained in:
parent
bfedf47d1a
commit
afea7ca0d1
33
.clang-tidy
33
.clang-tidy
|
@ -1,14 +1,15 @@
|
||||||
Checks: '*,
|
Checks: 'bugprone-*,
|
||||||
-altera-unroll-loops,
|
cert-*,
|
||||||
-llvmlibc-callee-namespace,
|
cppcoreguidelines-*,
|
||||||
-llvmlibc-implementation-in-namespace,
|
hicpp-*,
|
||||||
-llvmlibc-restrict-system-libc-headers,
|
misc-*,
|
||||||
-llvm-header-guard,
|
modernize-*,
|
||||||
-llvm-namespace-comment,
|
performance-*,
|
||||||
-google-build-using-namespace,
|
portability-*,
|
||||||
-google-runtime-int,
|
readability-*,
|
||||||
-google-readability-namespace-comments,
|
fuchsia-trailing-return,
|
||||||
-fuchsia-statically-constructed-objects,
|
-cert-err58-cpp,
|
||||||
|
-cert-err60-cpp,
|
||||||
-cppcoreguidelines-prefer-member-initializer,
|
-cppcoreguidelines-prefer-member-initializer,
|
||||||
-cppcoreguidelines-pro-bounds-array-to-pointer-decay,
|
-cppcoreguidelines-pro-bounds-array-to-pointer-decay,
|
||||||
-cppcoreguidelines-pro-bounds-constant-array-index,
|
-cppcoreguidelines-pro-bounds-constant-array-index,
|
||||||
|
@ -20,10 +21,6 @@ Checks: '*,
|
||||||
-cppcoreguidelines-avoid-non-const-global-variables,
|
-cppcoreguidelines-avoid-non-const-global-variables,
|
||||||
-cppcoreguidelines-avoid-c-arrays,
|
-cppcoreguidelines-avoid-c-arrays,
|
||||||
-cppcoreguidelines-special-member-functions,
|
-cppcoreguidelines-special-member-functions,
|
||||||
-readability-magic-numbers,
|
|
||||||
-readability-uppercase-literal-suffix,
|
|
||||||
-modernize-use-trailing-return-type,
|
|
||||||
-modernize-avoid-c-arrays,
|
|
||||||
-hicpp-avoid-c-arrays,
|
-hicpp-avoid-c-arrays,
|
||||||
-hicpp-uppercase-literal-suffix,
|
-hicpp-uppercase-literal-suffix,
|
||||||
-hicpp-vararg,
|
-hicpp-vararg,
|
||||||
|
@ -31,8 +28,10 @@ Checks: '*,
|
||||||
-hicpp-no-array-decay,
|
-hicpp-no-array-decay,
|
||||||
-hicpp-signed-bitwise,
|
-hicpp-signed-bitwise,
|
||||||
-hicpp-special-member-functions,
|
-hicpp-special-member-functions,
|
||||||
-cert-err58-cpp,
|
-modernize-use-trailing-return-type,
|
||||||
-cert-err60-cpp'
|
-modernize-avoid-c-arrays,
|
||||||
|
-readability-magic-numbers,
|
||||||
|
-readability-uppercase-literal-suffix'
|
||||||
CheckOptions:
|
CheckOptions:
|
||||||
- key: readability-function-cognitive-complexity.Threshold
|
- key: readability-function-cognitive-complexity.Threshold
|
||||||
value: 100
|
value: 100
|
||||||
|
|
|
@ -778,7 +778,7 @@ link_directories(
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
set(COMMON_FLAGS -MP -MD -mthumb -mabi=aapcs -Wall -Wextra -Warray-bounds=2 -Wformat=2 -Wformat-overflow=2 -Wformat-truncation=2 -Wformat-nonliteral -ftree-vrp -Wno-unused-parameter -Wno-missing-field-initializers -Wno-unknown-pragmas -Wno-expansion-to-defined -g3 -ffunction-sections -fdata-sections -fno-strict-aliasing -fno-builtin --short-enums -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16 -Wreturn-type -Werror=return-type -fstack-usage -fno-exceptions -fno-non-call-exceptions)
|
set(COMMON_FLAGS -MP -MD -mthumb -mabi=aapcs -Wall -Wextra -Warray-bounds=2 -Wformat=2 -Wformat-overflow=2 -Wformat-truncation=2 -Wformat-nonliteral -ftree-vrp -Wno-unused-parameter -Wno-missing-field-initializers -Wno-unknown-pragmas -Wno-expansion-to-defined -g3 -ffunction-sections -fdata-sections -fno-strict-aliasing -fno-builtin -fshort-enums -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16 -Wreturn-type -Werror=return-type -fstack-usage -fno-exceptions -fno-non-call-exceptions)
|
||||||
add_definitions(-DCONFIG_GPIO_AS_PINRESET)
|
add_definitions(-DCONFIG_GPIO_AS_PINRESET)
|
||||||
add_definitions(-DNIMBLE_CFG_CONTROLLER)
|
add_definitions(-DNIMBLE_CFG_CONTROLLER)
|
||||||
add_definitions(-DOS_CPUTIME_FREQ)
|
add_definitions(-DOS_CPUTIME_FREQ)
|
||||||
|
|
|
@ -28,7 +28,7 @@ AlarmController::AlarmController(Controllers::DateTime& dateTimeController) : da
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
void SetOffAlarm(TimerHandle_t xTimer) {
|
void SetOffAlarm(TimerHandle_t xTimer) {
|
||||||
auto controller = static_cast<Pinetime::Controllers::AlarmController*>(pvTimerGetTimerID(xTimer));
|
auto* controller = static_cast<Pinetime::Controllers::AlarmController*>(pvTimerGetTimerID(xTimer));
|
||||||
controller->SetOffAlarmNow();
|
controller->SetOffAlarmNow();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,8 +16,8 @@ Battery::Battery() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Battery::ReadPowerState() {
|
void Battery::ReadPowerState() {
|
||||||
isCharging = !nrf_gpio_pin_read(PinMap::Charging);
|
isCharging = (nrf_gpio_pin_read(PinMap::Charging) == 0);
|
||||||
isPowerPresent = !nrf_gpio_pin_read(PinMap::PowerPresent);
|
isPowerPresent = (nrf_gpio_pin_read(PinMap::PowerPresent) == 0);
|
||||||
|
|
||||||
if (isPowerPresent && !isCharging) {
|
if (isPowerPresent && !isCharging) {
|
||||||
isFull = true;
|
isFull = true;
|
||||||
|
@ -81,10 +81,8 @@ void Battery::SaadcEventHandler(nrfx_saadc_evt_t const* p_event) {
|
||||||
// p_event->data.done.p_buffer[0] = (adc_voltage / reference_voltage) * 1024
|
// p_event->data.done.p_buffer[0] = (adc_voltage / reference_voltage) * 1024
|
||||||
voltage = p_event->data.done.p_buffer[0] * (8 * 600) / 1024;
|
voltage = p_event->data.done.p_buffer[0] * (8 * 600) / 1024;
|
||||||
|
|
||||||
uint8_t newPercent;
|
uint8_t newPercent = 100;
|
||||||
if (isFull) {
|
if (!isFull) {
|
||||||
newPercent = 100;
|
|
||||||
} else {
|
|
||||||
newPercent = std::min(aprox.GetValue(voltage), isCharging ? uint8_t {99} : uint8_t {100});
|
newPercent = std::min(aprox.GetValue(voltage), isCharging ? uint8_t {99} : uint8_t {100});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ namespace {
|
||||||
constexpr ble_uuid128_t navProgressCharUuid {CharUuid(0x04, 0x00)};
|
constexpr ble_uuid128_t navProgressCharUuid {CharUuid(0x04, 0x00)};
|
||||||
|
|
||||||
int NAVCallback(uint16_t conn_handle, uint16_t attr_handle, struct ble_gatt_access_ctxt* ctxt, void* arg) {
|
int NAVCallback(uint16_t conn_handle, uint16_t attr_handle, struct ble_gatt_access_ctxt* ctxt, void* arg) {
|
||||||
auto navService = static_cast<Pinetime::Controllers::NavigationService*>(arg);
|
auto* navService = static_cast<Pinetime::Controllers::NavigationService*>(arg);
|
||||||
return navService->OnCommand(conn_handle, attr_handle, ctxt);
|
return navService->OnCommand(conn_handle, attr_handle, ctxt);
|
||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
|
@ -29,8 +29,9 @@ namespace {
|
||||||
auto z1 = CompareShift(d, mn - 1, size);
|
auto z1 = CompareShift(d, mn - 1, size);
|
||||||
for (int i = mn; i < mx + 1; i++) {
|
for (int i = mn; i < mx + 1; i++) {
|
||||||
auto z = CompareShift(d, i, size);
|
auto z = CompareShift(d, i, size);
|
||||||
if (z2 > z1 && z1 < z)
|
if (z2 > z1 && z1 < z) {
|
||||||
return i;
|
return i;
|
||||||
|
}
|
||||||
z2 = z1;
|
z2 = z1;
|
||||||
z1 = z;
|
z1 = z;
|
||||||
}
|
}
|
||||||
|
@ -52,41 +53,48 @@ int8_t Ppg::Preprocess(float spl) {
|
||||||
|
|
||||||
auto spl_int = static_cast<int8_t>(spl);
|
auto spl_int = static_cast<int8_t>(spl);
|
||||||
|
|
||||||
if (dataIndex < 200)
|
if (dataIndex < 200) {
|
||||||
data[dataIndex++] = spl_int;
|
data[dataIndex++] = spl_int;
|
||||||
|
}
|
||||||
return spl_int;
|
return spl_int;
|
||||||
}
|
}
|
||||||
|
|
||||||
float Ppg::HeartRate() {
|
int Ppg::HeartRate() {
|
||||||
if (dataIndex < 200)
|
if (dataIndex < 200) {
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
NRF_LOG_INFO("PREPROCESS, offset = %d", offset);
|
NRF_LOG_INFO("PREPROCESS, offset = %d", offset);
|
||||||
auto hr = ProcessHeartRate();
|
auto hr = ProcessHeartRate();
|
||||||
dataIndex = 0;
|
dataIndex = 0;
|
||||||
return hr;
|
return hr;
|
||||||
}
|
}
|
||||||
float Ppg::ProcessHeartRate() {
|
|
||||||
auto t0 = Trough(data.data(), dataIndex, 7, 48);
|
|
||||||
if (t0 < 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
float t1 = t0 * 2;
|
int Ppg::ProcessHeartRate() {
|
||||||
|
int t0 = Trough(data.data(), dataIndex, 7, 48);
|
||||||
|
if (t0 < 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int t1 = t0 * 2;
|
||||||
t1 = Trough(data.data(), dataIndex, t1 - 5, t1 + 5);
|
t1 = Trough(data.data(), dataIndex, t1 - 5, t1 + 5);
|
||||||
if (t1 < 0)
|
if (t1 < 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
float t2 = static_cast<int>(t1 * 3) / 2;
|
int t2 = (t1 * 3) / 2;
|
||||||
t2 = Trough(data.data(), dataIndex, t2 - 5, t2 + 5);
|
t2 = Trough(data.data(), dataIndex, t2 - 5, t2 + 5);
|
||||||
if (t2 < 0)
|
if (t2 < 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
float t3 = static_cast<int>(t2 * 4) / 3;
|
int t3 = (t2 * 4) / 3;
|
||||||
t3 = Trough(data.data(), dataIndex, t3 - 4, t3 + 4);
|
t3 = Trough(data.data(), dataIndex, t3 - 4, t3 + 4);
|
||||||
if (t3 < 0)
|
if (t3 < 0) {
|
||||||
return static_cast<int>(60 * 24 * 3) / static_cast<int>(t2);
|
return (60 * 24 * 3) / t2;
|
||||||
|
}
|
||||||
|
|
||||||
return static_cast<int>(60 * 24 * 4) / static_cast<int>(t3);
|
return (60 * 24 * 4) / t3;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ppg::SetOffset(uint16_t offset) {
|
void Ppg::SetOffset(uint16_t offset) {
|
||||||
|
|
|
@ -12,9 +12,9 @@ namespace Pinetime {
|
||||||
public:
|
public:
|
||||||
Ppg();
|
Ppg();
|
||||||
int8_t Preprocess(float spl);
|
int8_t Preprocess(float spl);
|
||||||
float HeartRate();
|
int HeartRate();
|
||||||
|
|
||||||
void SetOffset(uint16_t i);
|
void SetOffset(uint16_t offset);
|
||||||
void Reset();
|
void Reset();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -25,7 +25,7 @@ namespace Pinetime {
|
||||||
Ptagc agc;
|
Ptagc agc;
|
||||||
Biquad lpf;
|
Biquad lpf;
|
||||||
|
|
||||||
float ProcessHeartRate();
|
int ProcessHeartRate();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,13 +14,15 @@ Ptagc::Ptagc(float start, float decay, float threshold) : peak {start}, decay {d
|
||||||
}
|
}
|
||||||
|
|
||||||
float Ptagc::Step(float spl) {
|
float Ptagc::Step(float spl) {
|
||||||
if (std::abs(spl) > peak)
|
if (std::abs(spl) > peak) {
|
||||||
peak *= boost;
|
peak *= boost;
|
||||||
else
|
} else {
|
||||||
peak *= decay;
|
peak *= decay;
|
||||||
|
}
|
||||||
|
|
||||||
if ((spl > (peak * threshold)) || (spl < (peak * -threshold)))
|
if ((spl > (peak * threshold)) || (spl < (peak * -threshold))) {
|
||||||
return 0.0f;
|
return 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
spl = 100.0f * spl / (2.0f * peak);
|
spl = 100.0f * spl / (2.0f * peak);
|
||||||
return spl;
|
return spl;
|
||||||
|
|
|
@ -26,11 +26,10 @@ bool MotionController::Should_RaiseWake(bool isSleeping) {
|
||||||
if (not isSleeping) {
|
if (not isSleeping) {
|
||||||
if (y <= 0) {
|
if (y <= 0) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
}
|
||||||
lastYForWakeUp = 0;
|
lastYForWakeUp = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (y >= 0) {
|
if (y >= 0) {
|
||||||
lastYForWakeUp = 0;
|
lastYForWakeUp = 0;
|
||||||
|
|
|
@ -152,7 +152,7 @@ void DisplayApp::Refresh() {
|
||||||
}
|
}
|
||||||
|
|
||||||
Messages msg;
|
Messages msg;
|
||||||
if (xQueueReceive(msgQueue, &msg, queueTimeout)) {
|
if (xQueueReceive(msgQueue, &msg, queueTimeout) == pdTRUE) {
|
||||||
switch (msg) {
|
switch (msg) {
|
||||||
case Messages::DimScreen:
|
case Messages::DimScreen:
|
||||||
brightnessController.Set(Controllers::BrightnessController::Levels::Low);
|
brightnessController.Set(Controllers::BrightnessController::Levels::Low);
|
||||||
|
@ -485,10 +485,9 @@ void DisplayApp::LoadApp(Apps app, DisplayApp::FullRefreshDirections direction)
|
||||||
|
|
||||||
void DisplayApp::PushMessage(Messages msg) {
|
void DisplayApp::PushMessage(Messages msg) {
|
||||||
if (in_isr()) {
|
if (in_isr()) {
|
||||||
BaseType_t xHigherPriorityTaskWoken;
|
BaseType_t xHigherPriorityTaskWoken = pdFALSE;
|
||||||
xHigherPriorityTaskWoken = pdFALSE;
|
|
||||||
xQueueSendFromISR(msgQueue, &msg, &xHigherPriorityTaskWoken);
|
xQueueSendFromISR(msgQueue, &msg, &xHigherPriorityTaskWoken);
|
||||||
if (xHigherPriorityTaskWoken) {
|
if (xHigherPriorityTaskWoken == pdTRUE) {
|
||||||
portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
|
portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -532,8 +531,7 @@ void DisplayApp::Register(Pinetime::System::SystemTask* systemTask) {
|
||||||
}
|
}
|
||||||
void DisplayApp::ApplyBrightness() {
|
void DisplayApp::ApplyBrightness() {
|
||||||
auto brightness = settingsController.GetBrightness();
|
auto brightness = settingsController.GetBrightness();
|
||||||
if(brightness != Controllers::BrightnessController::Levels::Low &&
|
if (brightness != Controllers::BrightnessController::Levels::Low && brightness != Controllers::BrightnessController::Levels::Medium &&
|
||||||
brightness != Controllers::BrightnessController::Levels::Medium &&
|
|
||||||
brightness != Controllers::BrightnessController::Levels::High) {
|
brightness != Controllers::BrightnessController::Levels::High) {
|
||||||
brightness = Controllers::BrightnessController::Levels::High;
|
brightness = Controllers::BrightnessController::Levels::High;
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,16 +32,16 @@ FirmwareValidation::FirmwareValidation(Pinetime::Applications::DisplayApp* app,
|
||||||
lv_label_set_long_mode(labelIsValidated, LV_LABEL_LONG_BREAK);
|
lv_label_set_long_mode(labelIsValidated, LV_LABEL_LONG_BREAK);
|
||||||
lv_obj_set_width(labelIsValidated, 240);
|
lv_obj_set_width(labelIsValidated, 240);
|
||||||
|
|
||||||
if (validator.IsValidated())
|
if (validator.IsValidated()) {
|
||||||
lv_label_set_text_static(labelIsValidated, "You have already\n#00ff00 validated# this firmware#");
|
lv_label_set_text_static(labelIsValidated, "You have already\n#00ff00 validated# this firmware#");
|
||||||
else {
|
} else {
|
||||||
lv_label_set_text_static(labelIsValidated,
|
lv_label_set_text_static(labelIsValidated,
|
||||||
"Please #00ff00 Validate# this version or\n#ff0000 Reset# to rollback to the previous version.");
|
"Please #00ff00 Validate# this version or\n#ff0000 Reset# to rollback to the previous version.");
|
||||||
|
|
||||||
buttonValidate = lv_btn_create(lv_scr_act(), nullptr);
|
buttonValidate = lv_btn_create(lv_scr_act(), nullptr);
|
||||||
buttonValidate->user_data = this;
|
buttonValidate->user_data = this;
|
||||||
lv_obj_set_size(buttonValidate, 115, 50);
|
lv_obj_set_size(buttonValidate, 115, 50);
|
||||||
lv_obj_align(buttonValidate, NULL, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
lv_obj_align(buttonValidate, nullptr, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
||||||
lv_obj_set_event_cb(buttonValidate, ButtonEventHandler);
|
lv_obj_set_event_cb(buttonValidate, ButtonEventHandler);
|
||||||
lv_obj_set_style_local_bg_color(buttonValidate, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::highlight);
|
lv_obj_set_style_local_bg_color(buttonValidate, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::highlight);
|
||||||
|
|
||||||
|
|
|
@ -64,8 +64,9 @@ HeartRate::HeartRate(Pinetime::Applications::DisplayApp* app,
|
||||||
|
|
||||||
label_startStop = lv_label_create(btn_startStop, nullptr);
|
label_startStop = lv_label_create(btn_startStop, nullptr);
|
||||||
UpdateStartStopButton(isHrRunning);
|
UpdateStartStopButton(isHrRunning);
|
||||||
if (isHrRunning)
|
if (isHrRunning) {
|
||||||
systemTask.PushMessage(Pinetime::System::Messages::DisableSleeping);
|
systemTask.PushMessage(Pinetime::System::Messages::DisableSleeping);
|
||||||
|
}
|
||||||
|
|
||||||
taskRefresh = lv_task_create(RefreshTaskCallback, 100, LV_TASK_PRIO_MID, this);
|
taskRefresh = lv_task_create(RefreshTaskCallback, 100, LV_TASK_PRIO_MID, this);
|
||||||
}
|
}
|
||||||
|
@ -110,8 +111,9 @@ void HeartRate::OnStartStopEvent(lv_event_t event) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void HeartRate::UpdateStartStopButton(bool isRunning) {
|
void HeartRate::UpdateStartStopButton(bool isRunning) {
|
||||||
if (isRunning)
|
if (isRunning) {
|
||||||
lv_label_set_text_static(label_startStop, "Stop");
|
lv_label_set_text_static(label_startStop, "Stop");
|
||||||
else
|
} else {
|
||||||
lv_label_set_text_static(label_startStop, "Start");
|
lv_label_set_text_static(label_startStop, "Start");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -7,9 +7,9 @@ using namespace Pinetime::Applications::Screens;
|
||||||
|
|
||||||
Motion::Motion(Pinetime::Applications::DisplayApp* app, Controllers::MotionController& motionController)
|
Motion::Motion(Pinetime::Applications::DisplayApp* app, Controllers::MotionController& motionController)
|
||||||
: Screen(app), motionController {motionController} {
|
: Screen(app), motionController {motionController} {
|
||||||
chart = lv_chart_create(lv_scr_act(), NULL);
|
chart = lv_chart_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_size(chart, 240, 240);
|
lv_obj_set_size(chart, 240, 240);
|
||||||
lv_obj_align(chart, NULL, LV_ALIGN_IN_TOP_MID, 0, 0);
|
lv_obj_align(chart, nullptr, LV_ALIGN_IN_TOP_MID, 0, 0);
|
||||||
lv_chart_set_type(chart, LV_CHART_TYPE_LINE); /*Show lines and points too*/
|
lv_chart_set_type(chart, LV_CHART_TYPE_LINE); /*Show lines and points too*/
|
||||||
// lv_chart_set_series_opa(chart, LV_OPA_70); /*Opacity of the data series*/
|
// lv_chart_set_series_opa(chart, LV_OPA_70); /*Opacity of the data series*/
|
||||||
// lv_chart_set_series_width(chart, 4); /*Line width and point radious*/
|
// lv_chart_set_series_width(chart, 4); /*Line width and point radious*/
|
||||||
|
@ -28,13 +28,13 @@ Motion::Motion(Pinetime::Applications::DisplayApp* app, Controllers::MotionContr
|
||||||
lv_chart_init_points(chart, ser3, 0);
|
lv_chart_init_points(chart, ser3, 0);
|
||||||
lv_chart_refresh(chart); /*Required after direct set*/
|
lv_chart_refresh(chart); /*Required after direct set*/
|
||||||
|
|
||||||
label = lv_label_create(lv_scr_act(), NULL);
|
label = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_label_set_text_fmt(label, "X #FF0000 %d# Y #00B000 %d# Z #FFFF00 %d#", 0, 0, 0);
|
lv_label_set_text_fmt(label, "X #FF0000 %d# Y #00B000 %d# Z #FFFF00 %d#", 0, 0, 0);
|
||||||
lv_label_set_align(label, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(label, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(label, NULL, LV_ALIGN_IN_TOP_MID, 0, 10);
|
lv_obj_align(label, nullptr, LV_ALIGN_IN_TOP_MID, 0, 10);
|
||||||
lv_label_set_recolor(label, true);
|
lv_label_set_recolor(label, true);
|
||||||
|
|
||||||
labelStep = lv_label_create(lv_scr_act(), NULL);
|
labelStep = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_align(labelStep, chart, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
lv_obj_align(labelStep, chart, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
||||||
lv_label_set_text_static(labelStep, "Steps ---");
|
lv_label_set_text_static(labelStep, "Steps ---");
|
||||||
|
|
||||||
|
@ -58,5 +58,5 @@ void Motion::Refresh() {
|
||||||
motionController.X() / 0x10,
|
motionController.X() / 0x10,
|
||||||
motionController.Y() / 0x10,
|
motionController.Y() / 0x10,
|
||||||
motionController.Z() / 0x10);
|
motionController.Z() / 0x10);
|
||||||
lv_obj_align(label, NULL, LV_ALIGN_IN_TOP_MID, 0, 10);
|
lv_obj_align(label, nullptr, LV_ALIGN_IN_TOP_MID, 0, 10);
|
||||||
}
|
}
|
||||||
|
|
|
@ -139,15 +139,9 @@ bool Notifications::OnTouchEvent(Pinetime::Applications::TouchEvents event) {
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case Pinetime::Applications::TouchEvents::SwipeRight:
|
case Pinetime::Applications::TouchEvents::SwipeRight:
|
||||||
if (validDisplay) {
|
if (validDisplay) {
|
||||||
Controllers::NotificationManager::Notification previousNotification;
|
|
||||||
auto previousMessage = notificationManager.GetPrevious(currentId);
|
auto previousMessage = notificationManager.GetPrevious(currentId);
|
||||||
auto nextMessage = notificationManager.GetNext(currentId);
|
auto nextMessage = notificationManager.GetNext(currentId);
|
||||||
if (!previousMessage.valid) {
|
afterDismissNextMessageFromAbove = previousMessage.valid;
|
||||||
// dismissed last message (like 5/5), need to go one message down (like 4/4)
|
|
||||||
afterDismissNextMessageFromAbove = false; // show next message coming from below
|
|
||||||
} else {
|
|
||||||
afterDismissNextMessageFromAbove = true; // show next message coming from above
|
|
||||||
}
|
|
||||||
notificationManager.Dismiss(currentId);
|
notificationManager.Dismiss(currentId);
|
||||||
if (previousMessage.valid) {
|
if (previousMessage.valid) {
|
||||||
currentId = previousMessage.id;
|
currentId = previousMessage.id;
|
||||||
|
@ -270,7 +264,7 @@ Notifications::NotificationItem::NotificationItem(const char* title,
|
||||||
|
|
||||||
lv_obj_t* alert_count = lv_label_create(container, nullptr);
|
lv_obj_t* alert_count = lv_label_create(container, nullptr);
|
||||||
lv_label_set_text_fmt(alert_count, "%i/%i", notifNr, notifNb);
|
lv_label_set_text_fmt(alert_count, "%i/%i", notifNr, notifNb);
|
||||||
lv_obj_align(alert_count, NULL, LV_ALIGN_IN_TOP_RIGHT, 0, 16);
|
lv_obj_align(alert_count, nullptr, LV_ALIGN_IN_TOP_RIGHT, 0, 16);
|
||||||
|
|
||||||
lv_obj_t* alert_type = lv_label_create(container, nullptr);
|
lv_obj_t* alert_type = lv_label_create(container, nullptr);
|
||||||
lv_obj_set_style_local_text_color(alert_type, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::orange);
|
lv_obj_set_style_local_text_color(alert_type, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::orange);
|
||||||
|
@ -288,7 +282,7 @@ Notifications::NotificationItem::NotificationItem(const char* title,
|
||||||
}
|
}
|
||||||
lv_label_set_long_mode(alert_type, LV_LABEL_LONG_SROLL_CIRC);
|
lv_label_set_long_mode(alert_type, LV_LABEL_LONG_SROLL_CIRC);
|
||||||
lv_obj_set_width(alert_type, 180);
|
lv_obj_set_width(alert_type, 180);
|
||||||
lv_obj_align(alert_type, NULL, LV_ALIGN_IN_TOP_LEFT, 0, 16);
|
lv_obj_align(alert_type, nullptr, LV_ALIGN_IN_TOP_LEFT, 0, 16);
|
||||||
|
|
||||||
lv_obj_t* alert_subject = lv_label_create(subject_container, nullptr);
|
lv_obj_t* alert_subject = lv_label_create(subject_container, nullptr);
|
||||||
lv_label_set_long_mode(alert_subject, LV_LABEL_LONG_BREAK);
|
lv_label_set_long_mode(alert_subject, LV_LABEL_LONG_BREAK);
|
||||||
|
@ -312,7 +306,7 @@ Notifications::NotificationItem::NotificationItem(const char* title,
|
||||||
bt_accept->user_data = this;
|
bt_accept->user_data = this;
|
||||||
lv_obj_set_event_cb(bt_accept, CallEventHandler);
|
lv_obj_set_event_cb(bt_accept, CallEventHandler);
|
||||||
lv_obj_set_size(bt_accept, 76, 76);
|
lv_obj_set_size(bt_accept, 76, 76);
|
||||||
lv_obj_align(bt_accept, NULL, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
lv_obj_align(bt_accept, nullptr, LV_ALIGN_IN_BOTTOM_LEFT, 0, 0);
|
||||||
label_accept = lv_label_create(bt_accept, nullptr);
|
label_accept = lv_label_create(bt_accept, nullptr);
|
||||||
lv_label_set_text_static(label_accept, Symbols::phone);
|
lv_label_set_text_static(label_accept, Symbols::phone);
|
||||||
lv_obj_set_style_local_bg_color(bt_accept, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::highlight);
|
lv_obj_set_style_local_bg_color(bt_accept, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::highlight);
|
||||||
|
@ -321,7 +315,7 @@ Notifications::NotificationItem::NotificationItem(const char* title,
|
||||||
bt_reject->user_data = this;
|
bt_reject->user_data = this;
|
||||||
lv_obj_set_event_cb(bt_reject, CallEventHandler);
|
lv_obj_set_event_cb(bt_reject, CallEventHandler);
|
||||||
lv_obj_set_size(bt_reject, 76, 76);
|
lv_obj_set_size(bt_reject, 76, 76);
|
||||||
lv_obj_align(bt_reject, NULL, LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
lv_obj_align(bt_reject, nullptr, LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
||||||
label_reject = lv_label_create(bt_reject, nullptr);
|
label_reject = lv_label_create(bt_reject, nullptr);
|
||||||
lv_label_set_text_static(label_reject, Symbols::phoneSlash);
|
lv_label_set_text_static(label_reject, Symbols::phoneSlash);
|
||||||
lv_obj_set_style_local_bg_color(bt_reject, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_RED);
|
lv_obj_set_style_local_bg_color(bt_reject, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_RED);
|
||||||
|
@ -330,7 +324,7 @@ Notifications::NotificationItem::NotificationItem(const char* title,
|
||||||
bt_mute->user_data = this;
|
bt_mute->user_data = this;
|
||||||
lv_obj_set_event_cb(bt_mute, CallEventHandler);
|
lv_obj_set_event_cb(bt_mute, CallEventHandler);
|
||||||
lv_obj_set_size(bt_mute, 76, 76);
|
lv_obj_set_size(bt_mute, 76, 76);
|
||||||
lv_obj_align(bt_mute, NULL, LV_ALIGN_IN_BOTTOM_RIGHT, 0, 0);
|
lv_obj_align(bt_mute, nullptr, LV_ALIGN_IN_BOTTOM_RIGHT, 0, 0);
|
||||||
label_mute = lv_label_create(bt_mute, nullptr);
|
label_mute = lv_label_create(bt_mute, nullptr);
|
||||||
lv_label_set_text_static(label_mute, Symbols::volumMute);
|
lv_label_set_text_static(label_mute, Symbols::volumMute);
|
||||||
lv_obj_set_style_local_bg_color(bt_mute, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::lightGray);
|
lv_obj_set_style_local_bg_color(bt_mute, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::lightGray);
|
||||||
|
|
|
@ -29,7 +29,6 @@ namespace Pinetime {
|
||||||
uint32_t currentTripSteps = 0;
|
uint32_t currentTripSteps = 0;
|
||||||
|
|
||||||
lv_obj_t* lSteps;
|
lv_obj_t* lSteps;
|
||||||
lv_obj_t* lStepsIcon;
|
|
||||||
lv_obj_t* stepsArc;
|
lv_obj_t* stepsArc;
|
||||||
lv_obj_t* resetBtn;
|
lv_obj_t* resetBtn;
|
||||||
lv_obj_t* resetButtonLabel;
|
lv_obj_t* resetButtonLabel;
|
||||||
|
|
|
@ -99,7 +99,7 @@ std::unique_ptr<Screen> SystemInfo::CreateScreen1() {
|
||||||
|
|
||||||
std::unique_ptr<Screen> SystemInfo::CreateScreen2() {
|
std::unique_ptr<Screen> SystemInfo::CreateScreen2() {
|
||||||
auto batteryPercent = batteryController.PercentRemaining();
|
auto batteryPercent = batteryController.PercentRemaining();
|
||||||
auto resetReason = [this]() {
|
const auto* resetReason = [this]() {
|
||||||
switch (watchdog.ResetReason()) {
|
switch (watchdog.ResetReason()) {
|
||||||
case Drivers::Watchdog::ResetReasons::Watchdog:
|
case Drivers::Watchdog::ResetReasons::Watchdog:
|
||||||
return "wtdg";
|
return "wtdg";
|
||||||
|
@ -182,7 +182,7 @@ std::unique_ptr<Screen> SystemInfo::CreateScreen3() {
|
||||||
|
|
||||||
lv_obj_t* label = lv_label_create(lv_scr_act(), nullptr);
|
lv_obj_t* label = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_label_set_recolor(label, true);
|
lv_label_set_recolor(label, true);
|
||||||
auto& bleAddr = bleController.Address();
|
const auto& bleAddr = bleController.Address();
|
||||||
lv_label_set_text_fmt(label,
|
lv_label_set_text_fmt(label,
|
||||||
"#808080 BLE MAC#\n"
|
"#808080 BLE MAC#\n"
|
||||||
" %02x:%02x:%02x:%02x:%02x:%02x"
|
" %02x:%02x:%02x:%02x:%02x:%02x"
|
||||||
|
|
|
@ -51,8 +51,9 @@ Tile::Tile(uint8_t screenID,
|
||||||
|
|
||||||
uint8_t btIndex = 0;
|
uint8_t btIndex = 0;
|
||||||
for (uint8_t i = 0; i < 6; i++) {
|
for (uint8_t i = 0; i < 6; i++) {
|
||||||
if (i == 3)
|
if (i == 3) {
|
||||||
btnmMap[btIndex++] = "\n";
|
btnmMap[btIndex++] = "\n";
|
||||||
|
}
|
||||||
if (applications[i].application == Apps::None) {
|
if (applications[i].application == Apps::None) {
|
||||||
btnmMap[btIndex] = " ";
|
btnmMap[btIndex] = " ";
|
||||||
} else {
|
} else {
|
||||||
|
@ -66,7 +67,7 @@ Tile::Tile(uint8_t screenID,
|
||||||
btnm1 = lv_btnmatrix_create(lv_scr_act(), nullptr);
|
btnm1 = lv_btnmatrix_create(lv_scr_act(), nullptr);
|
||||||
lv_btnmatrix_set_map(btnm1, btnmMap);
|
lv_btnmatrix_set_map(btnm1, btnmMap);
|
||||||
lv_obj_set_size(btnm1, LV_HOR_RES - 16, LV_VER_RES - 60);
|
lv_obj_set_size(btnm1, LV_HOR_RES - 16, LV_VER_RES - 60);
|
||||||
lv_obj_align(btnm1, NULL, LV_ALIGN_CENTER, 0, 10);
|
lv_obj_align(btnm1, nullptr, LV_ALIGN_CENTER, 0, 10);
|
||||||
|
|
||||||
lv_obj_set_style_local_radius(btnm1, LV_BTNMATRIX_PART_BTN, LV_STATE_DEFAULT, 20);
|
lv_obj_set_style_local_radius(btnm1, LV_BTNMATRIX_PART_BTN, LV_STATE_DEFAULT, 20);
|
||||||
lv_obj_set_style_local_bg_opa(btnm1, LV_BTNMATRIX_PART_BTN, LV_STATE_DEFAULT, LV_OPA_50);
|
lv_obj_set_style_local_bg_opa(btnm1, LV_BTNMATRIX_PART_BTN, LV_STATE_DEFAULT, LV_OPA_50);
|
||||||
|
@ -102,8 +103,9 @@ void Tile::UpdateScreen() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Tile::OnValueChangedEvent(lv_obj_t* obj, uint32_t buttonId) {
|
void Tile::OnValueChangedEvent(lv_obj_t* obj, uint32_t buttonId) {
|
||||||
if (obj != btnm1)
|
if (obj != btnm1) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
app->StartApp(apps[buttonId], DisplayApp::FullRefreshDirections::Up);
|
app->StartApp(apps[buttonId], DisplayApp::FullRefreshDirections::Up);
|
||||||
running = false;
|
running = false;
|
||||||
|
|
|
@ -26,7 +26,6 @@ namespace Pinetime::Applications::Screens {
|
||||||
void UpdateMask();
|
void UpdateMask();
|
||||||
Controllers::TimerController& timerController;
|
Controllers::TimerController& timerController;
|
||||||
|
|
||||||
lv_obj_t* msecTime;
|
|
||||||
lv_obj_t* btnPlayPause;
|
lv_obj_t* btnPlayPause;
|
||||||
lv_obj_t* txtPlayPause;
|
lv_obj_t* txtPlayPause;
|
||||||
|
|
||||||
|
@ -40,7 +39,7 @@ namespace Pinetime::Applications::Screens {
|
||||||
Widgets::Counter secondCounter = Widgets::Counter(0, 59, jetbrains_mono_76);
|
Widgets::Counter secondCounter = Widgets::Counter(0, 59, jetbrains_mono_76);
|
||||||
|
|
||||||
bool buttonPressing = false;
|
bool buttonPressing = false;
|
||||||
int maskPosition = 0;
|
lv_coord_t maskPosition = 0;
|
||||||
TickType_t pressTime;
|
TickType_t pressTime = 0;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,9 +61,9 @@ WatchFaceAnalog::WatchFaceAnalog(Pinetime::Applications::DisplayApp* app,
|
||||||
sMinute = 99;
|
sMinute = 99;
|
||||||
sSecond = 99;
|
sSecond = 99;
|
||||||
|
|
||||||
lv_obj_t* bg_clock_img = lv_img_create(lv_scr_act(), NULL);
|
lv_obj_t* bg_clock_img = lv_img_create(lv_scr_act(), nullptr);
|
||||||
lv_img_set_src(bg_clock_img, &bg_clock);
|
lv_img_set_src(bg_clock_img, &bg_clock);
|
||||||
lv_obj_align(bg_clock_img, NULL, LV_ALIGN_CENTER, 0, 0);
|
lv_obj_align(bg_clock_img, nullptr, LV_ALIGN_CENTER, 0, 0);
|
||||||
|
|
||||||
batteryIcon.Create(lv_scr_act());
|
batteryIcon.Create(lv_scr_act());
|
||||||
lv_obj_align(batteryIcon.GetObject(), nullptr, LV_ALIGN_IN_TOP_RIGHT, 0, 0);
|
lv_obj_align(batteryIcon.GetObject(), nullptr, LV_ALIGN_IN_TOP_RIGHT, 0, 0);
|
||||||
|
@ -72,24 +72,24 @@ WatchFaceAnalog::WatchFaceAnalog(Pinetime::Applications::DisplayApp* app,
|
||||||
lv_label_set_text_static(plugIcon, Symbols::plug);
|
lv_label_set_text_static(plugIcon, Symbols::plug);
|
||||||
lv_obj_align(plugIcon, nullptr, LV_ALIGN_IN_TOP_RIGHT, 0, 0);
|
lv_obj_align(plugIcon, nullptr, LV_ALIGN_IN_TOP_RIGHT, 0, 0);
|
||||||
|
|
||||||
notificationIcon = lv_label_create(lv_scr_act(), NULL);
|
notificationIcon = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_color(notificationIcon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_LIME);
|
lv_obj_set_style_local_text_color(notificationIcon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_LIME);
|
||||||
lv_label_set_text_static(notificationIcon, NotificationIcon::GetIcon(false));
|
lv_label_set_text_static(notificationIcon, NotificationIcon::GetIcon(false));
|
||||||
lv_obj_align(notificationIcon, NULL, LV_ALIGN_IN_TOP_LEFT, 0, 0);
|
lv_obj_align(notificationIcon, nullptr, LV_ALIGN_IN_TOP_LEFT, 0, 0);
|
||||||
|
|
||||||
// Date - Day / Week day
|
// Date - Day / Week day
|
||||||
|
|
||||||
label_date_day = lv_label_create(lv_scr_act(), NULL);
|
label_date_day = lv_label_create(lv_scr_act(), nullptr);
|
||||||
lv_obj_set_style_local_text_color(label_date_day, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::orange);
|
lv_obj_set_style_local_text_color(label_date_day, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, Colors::orange);
|
||||||
lv_label_set_text_fmt(label_date_day, "%s\n%02i", dateTimeController.DayOfWeekShortToString(), dateTimeController.Day());
|
lv_label_set_text_fmt(label_date_day, "%s\n%02i", dateTimeController.DayOfWeekShortToString(), dateTimeController.Day());
|
||||||
lv_label_set_align(label_date_day, LV_LABEL_ALIGN_CENTER);
|
lv_label_set_align(label_date_day, LV_LABEL_ALIGN_CENTER);
|
||||||
lv_obj_align(label_date_day, NULL, LV_ALIGN_CENTER, 50, 0);
|
lv_obj_align(label_date_day, nullptr, LV_ALIGN_CENTER, 50, 0);
|
||||||
|
|
||||||
minute_body = lv_line_create(lv_scr_act(), NULL);
|
minute_body = lv_line_create(lv_scr_act(), nullptr);
|
||||||
minute_body_trace = lv_line_create(lv_scr_act(), NULL);
|
minute_body_trace = lv_line_create(lv_scr_act(), nullptr);
|
||||||
hour_body = lv_line_create(lv_scr_act(), NULL);
|
hour_body = lv_line_create(lv_scr_act(), nullptr);
|
||||||
hour_body_trace = lv_line_create(lv_scr_act(), NULL);
|
hour_body_trace = lv_line_create(lv_scr_act(), nullptr);
|
||||||
second_body = lv_line_create(lv_scr_act(), NULL);
|
second_body = lv_line_create(lv_scr_act(), nullptr);
|
||||||
|
|
||||||
lv_style_init(&second_line_style);
|
lv_style_init(&second_line_style);
|
||||||
lv_style_set_line_width(&second_line_style, LV_STATE_DEFAULT, 3);
|
lv_style_set_line_width(&second_line_style, LV_STATE_DEFAULT, 3);
|
||||||
|
|
|
@ -57,7 +57,7 @@ SettingShakeThreshold::SettingShakeThreshold(DisplayApp* app,
|
||||||
lv_obj_set_width(calButton, 200);
|
lv_obj_set_width(calButton, 200);
|
||||||
lv_obj_align(calButton, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
lv_obj_align(calButton, lv_scr_act(), LV_ALIGN_IN_BOTTOM_MID, 0, 0);
|
||||||
lv_btn_set_checkable(calButton, true);
|
lv_btn_set_checkable(calButton, true);
|
||||||
calLabel = lv_label_create(calButton, NULL);
|
calLabel = lv_label_create(calButton, nullptr);
|
||||||
lv_label_set_text_static(calLabel, "Calibrate");
|
lv_label_set_text_static(calLabel, "Calibrate");
|
||||||
|
|
||||||
lv_arc_set_value(positionArc, settingsController.GetShakeThreshold());
|
lv_arc_set_value(positionArc, settingsController.GetShakeThreshold());
|
||||||
|
@ -102,7 +102,7 @@ void SettingShakeThreshold::Refresh() {
|
||||||
}
|
}
|
||||||
if (xTaskGetTickCount() - vCalTime > pdMS_TO_TICKS(7500)) {
|
if (xTaskGetTickCount() - vCalTime > pdMS_TO_TICKS(7500)) {
|
||||||
lv_btn_set_state(calButton, LV_STATE_DEFAULT);
|
lv_btn_set_state(calButton, LV_STATE_DEFAULT);
|
||||||
lv_event_send(calButton, LV_EVENT_VALUE_CHANGED, NULL);
|
lv_event_send(calButton, LV_EVENT_VALUE_CHANGED, nullptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (motionController.currentShakeSpeed() - 300 > lv_arc_get_value(animArc)) {
|
if (motionController.currentShakeSpeed() - 300 > lv_arc_get_value(animArc)) {
|
||||||
|
|
|
@ -6,16 +6,17 @@
|
||||||
using namespace Pinetime::Applications;
|
using namespace Pinetime::Applications;
|
||||||
|
|
||||||
HeartRateTask::HeartRateTask(Drivers::Hrs3300& heartRateSensor, Controllers::HeartRateController& controller)
|
HeartRateTask::HeartRateTask(Drivers::Hrs3300& heartRateSensor, Controllers::HeartRateController& controller)
|
||||||
: heartRateSensor {heartRateSensor}, controller {controller}, ppg {} {
|
: heartRateSensor {heartRateSensor}, controller {controller} {
|
||||||
}
|
}
|
||||||
|
|
||||||
void HeartRateTask::Start() {
|
void HeartRateTask::Start() {
|
||||||
messageQueue = xQueueCreate(10, 1);
|
messageQueue = xQueueCreate(10, 1);
|
||||||
controller.SetHeartRateTask(this);
|
controller.SetHeartRateTask(this);
|
||||||
|
|
||||||
if (pdPASS != xTaskCreate(HeartRateTask::Process, "Heartrate", 500, this, 0, &taskHandle))
|
if (pdPASS != xTaskCreate(HeartRateTask::Process, "Heartrate", 500, this, 0, &taskHandle)) {
|
||||||
APP_ERROR_HANDLER(NRF_ERROR_NO_MEM);
|
APP_ERROR_HANDLER(NRF_ERROR_NO_MEM);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void HeartRateTask::Process(void* instance) {
|
void HeartRateTask::Process(void* instance) {
|
||||||
auto* app = static_cast<HeartRateTask*>(instance);
|
auto* app = static_cast<HeartRateTask*>(instance);
|
||||||
|
@ -25,17 +26,19 @@ void HeartRateTask::Process(void* instance) {
|
||||||
void HeartRateTask::Work() {
|
void HeartRateTask::Work() {
|
||||||
int lastBpm = 0;
|
int lastBpm = 0;
|
||||||
while (true) {
|
while (true) {
|
||||||
Messages msg;
|
auto delay = portMAX_DELAY;
|
||||||
uint32_t delay;
|
|
||||||
if (state == States::Running) {
|
if (state == States::Running) {
|
||||||
if (measurementStarted)
|
if (measurementStarted) {
|
||||||
delay = 40;
|
delay = 40;
|
||||||
else
|
} else {
|
||||||
delay = 100;
|
delay = 100;
|
||||||
} else
|
}
|
||||||
|
} else {
|
||||||
delay = portMAX_DELAY;
|
delay = portMAX_DELAY;
|
||||||
|
}
|
||||||
|
|
||||||
if (xQueueReceive(messageQueue, &msg, delay)) {
|
Messages msg;
|
||||||
|
if (xQueueReceive(messageQueue, &msg, delay) == pdTRUE) {
|
||||||
switch (msg) {
|
switch (msg) {
|
||||||
case Messages::GoToSleep:
|
case Messages::GoToSleep:
|
||||||
StopMeasurement();
|
StopMeasurement();
|
||||||
|
@ -49,15 +52,17 @@ void HeartRateTask::Work() {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case Messages::StartMeasurement:
|
case Messages::StartMeasurement:
|
||||||
if (measurementStarted)
|
if (measurementStarted) {
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
lastBpm = 0;
|
lastBpm = 0;
|
||||||
StartMeasurement();
|
StartMeasurement();
|
||||||
measurementStarted = true;
|
measurementStarted = true;
|
||||||
break;
|
break;
|
||||||
case Messages::StopMeasurement:
|
case Messages::StopMeasurement:
|
||||||
if (!measurementStarted)
|
if (!measurementStarted) {
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
StopMeasurement();
|
StopMeasurement();
|
||||||
measurementStarted = false;
|
measurementStarted = false;
|
||||||
break;
|
break;
|
||||||
|
@ -68,8 +73,9 @@ void HeartRateTask::Work() {
|
||||||
ppg.Preprocess(static_cast<float>(heartRateSensor.ReadHrs()));
|
ppg.Preprocess(static_cast<float>(heartRateSensor.ReadHrs()));
|
||||||
auto bpm = ppg.HeartRate();
|
auto bpm = ppg.HeartRate();
|
||||||
|
|
||||||
if (lastBpm == 0 && bpm == 0)
|
if (lastBpm == 0 && bpm == 0) {
|
||||||
controller.Update(Controllers::HeartRateController::States::NotEnoughData, 0);
|
controller.Update(Controllers::HeartRateController::States::NotEnoughData, 0);
|
||||||
|
}
|
||||||
if (bpm != 0) {
|
if (bpm != 0) {
|
||||||
lastBpm = bpm;
|
lastBpm = bpm;
|
||||||
controller.Update(Controllers::HeartRateController::States::Running, lastBpm);
|
controller.Update(Controllers::HeartRateController::States::Running, lastBpm);
|
||||||
|
@ -79,10 +85,9 @@ void HeartRateTask::Work() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void HeartRateTask::PushMessage(HeartRateTask::Messages msg) {
|
void HeartRateTask::PushMessage(HeartRateTask::Messages msg) {
|
||||||
BaseType_t xHigherPriorityTaskWoken;
|
BaseType_t xHigherPriorityTaskWoken = pdFALSE;
|
||||||
xHigherPriorityTaskWoken = pdFALSE;
|
|
||||||
xQueueSendFromISR(messageQueue, &msg, &xHigherPriorityTaskWoken);
|
xQueueSendFromISR(messageQueue, &msg, &xHigherPriorityTaskWoken);
|
||||||
if (xHigherPriorityTaskWoken) {
|
if (xHigherPriorityTaskWoken == pdTRUE) {
|
||||||
/* Actual macro used here is port specific. */
|
/* Actual macro used here is port specific. */
|
||||||
// TODO : should I do something here?
|
// TODO : should I do something here?
|
||||||
}
|
}
|
||||||
|
@ -91,7 +96,7 @@ void HeartRateTask::PushMessage(HeartRateTask::Messages msg) {
|
||||||
void HeartRateTask::StartMeasurement() {
|
void HeartRateTask::StartMeasurement() {
|
||||||
heartRateSensor.Enable();
|
heartRateSensor.Enable();
|
||||||
vTaskDelay(100);
|
vTaskDelay(100);
|
||||||
ppg.SetOffset(static_cast<float>(heartRateSensor.ReadHrs()));
|
ppg.SetOffset(heartRateSensor.ReadHrs());
|
||||||
}
|
}
|
||||||
|
|
||||||
void HeartRateTask::StopMeasurement() {
|
void HeartRateTask::StopMeasurement() {
|
||||||
|
|
39
src/main.cpp
39
src/main.cpp
|
@ -45,7 +45,6 @@
|
||||||
#include "drivers/Cst816s.h"
|
#include "drivers/Cst816s.h"
|
||||||
#include "drivers/PinMap.h"
|
#include "drivers/PinMap.h"
|
||||||
#include "systemtask/SystemTask.h"
|
#include "systemtask/SystemTask.h"
|
||||||
#include "drivers/PinMap.h"
|
|
||||||
#include "touchhandler/TouchHandler.h"
|
#include "touchhandler/TouchHandler.h"
|
||||||
#include "buttonhandler/ButtonHandler.h"
|
#include "buttonhandler/ButtonHandler.h"
|
||||||
|
|
||||||
|
@ -210,29 +209,29 @@ void SPIM0_SPIS0_TWIM0_TWIS0_SPI0_TWI0_IRQHandler(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void (*radio_isr_addr)(void);
|
static void (*radio_isr_addr)();
|
||||||
static void (*rng_isr_addr)(void);
|
static void (*rng_isr_addr)();
|
||||||
static void (*rtc0_isr_addr)(void);
|
static void (*rtc0_isr_addr)();
|
||||||
|
|
||||||
/* Some interrupt handlers required for NimBLE radio driver */
|
/* Some interrupt handlers required for NimBLE radio driver */
|
||||||
extern "C" {
|
extern "C" {
|
||||||
void RADIO_IRQHandler(void) {
|
void RADIO_IRQHandler(void) {
|
||||||
((void (*)(void)) radio_isr_addr)();
|
((void (*)()) radio_isr_addr)();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RNG_IRQHandler(void) {
|
void RNG_IRQHandler(void) {
|
||||||
((void (*)(void)) rng_isr_addr)();
|
((void (*)()) rng_isr_addr)();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RTC0_IRQHandler(void) {
|
void RTC0_IRQHandler(void) {
|
||||||
((void (*)(void)) rtc0_isr_addr)();
|
((void (*)()) rtc0_isr_addr)();
|
||||||
}
|
}
|
||||||
|
|
||||||
void WDT_IRQHandler(void) {
|
void WDT_IRQHandler(void) {
|
||||||
nrf_wdt_event_clear(NRF_WDT_EVENT_TIMEOUT);
|
nrf_wdt_event_clear(NRF_WDT_EVENT_TIMEOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void npl_freertos_hw_set_isr(int irqn, void (*addr)(void)) {
|
void npl_freertos_hw_set_isr(int irqn, void (*addr)()) {
|
||||||
switch (irqn) {
|
switch (irqn) {
|
||||||
case RADIO_IRQn:
|
case RADIO_IRQn:
|
||||||
radio_isr_addr = addr;
|
radio_isr_addr = addr;
|
||||||
|
@ -243,6 +242,8 @@ void npl_freertos_hw_set_isr(int irqn, void (*addr)(void)) {
|
||||||
case RTC0_IRQn:
|
case RTC0_IRQn:
|
||||||
rtc0_isr_addr = addr;
|
rtc0_isr_addr = addr;
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,7 +254,7 @@ uint32_t npl_freertos_hw_enter_critical(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void npl_freertos_hw_exit_critical(uint32_t ctx) {
|
void npl_freertos_hw_exit_critical(uint32_t ctx) {
|
||||||
if (!ctx) {
|
if (ctx == 0) {
|
||||||
__enable_irq();
|
__enable_irq();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -265,15 +266,14 @@ struct ble_npl_eventq* nimble_port_get_dflt_eventq(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void nimble_port_run(void) {
|
void nimble_port_run(void) {
|
||||||
struct ble_npl_event* ev;
|
struct ble_npl_event* event;
|
||||||
|
while (true) {
|
||||||
while (1) {
|
event = ble_npl_eventq_get(&g_eventq_dflt, BLE_NPL_TIME_FOREVER);
|
||||||
ev = ble_npl_eventq_get(&g_eventq_dflt, BLE_NPL_TIME_FOREVER);
|
ble_npl_event_run(event);
|
||||||
ble_npl_event_run(ev);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void BleHost(void*) {
|
void BleHost(void* /*unused*/) {
|
||||||
nimble_port_run();
|
nimble_port_run();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -285,8 +285,7 @@ void nimble_port_init(void) {
|
||||||
ble_hs_init();
|
ble_hs_init();
|
||||||
ble_store_ram_init();
|
ble_store_ram_init();
|
||||||
|
|
||||||
int res;
|
int res = hal_timer_init(5, nullptr);
|
||||||
res = hal_timer_init(5, NULL);
|
|
||||||
ASSERT(res == 0);
|
ASSERT(res == 0);
|
||||||
res = os_cputime_init(32768);
|
res = os_cputime_init(32768);
|
||||||
ASSERT(res == 0);
|
ASSERT(res == 0);
|
||||||
|
@ -301,17 +300,17 @@ void nimble_port_ll_task_func(void* args) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void calibrate_lf_clock_rc(nrf_drv_clock_evt_type_t event) {
|
void calibrate_lf_clock_rc(nrf_drv_clock_evt_type_t /*event*/) {
|
||||||
// 16 * 0.25s = 4s calibration cycle
|
// 16 * 0.25s = 4s calibration cycle
|
||||||
// Not recursive, call is deferred via internal calibration timer
|
// Not recursive, call is deferred via internal calibration timer
|
||||||
nrf_drv_clock_calibration_start(16, calibrate_lf_clock_rc);
|
nrf_drv_clock_calibration_start(16, calibrate_lf_clock_rc);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void) {
|
int main() {
|
||||||
logger.Init();
|
logger.Init();
|
||||||
|
|
||||||
nrf_drv_clock_init();
|
nrf_drv_clock_init();
|
||||||
nrf_drv_clock_lfclk_request(NULL);
|
nrf_drv_clock_lfclk_request(nullptr);
|
||||||
|
|
||||||
// When loading the firmware via the Wasp-OS reloader-factory, which uses the used internal LF RC oscillator,
|
// When loading the firmware via the Wasp-OS reloader-factory, which uses the used internal LF RC oscillator,
|
||||||
// the LF clock has to be explicitly restarted because InfiniTime uses the external crystal oscillator if available.
|
// the LF clock has to be explicitly restarted because InfiniTime uses the external crystal oscillator if available.
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include <cstdint>
|
||||||
namespace Pinetime {
|
namespace Pinetime {
|
||||||
namespace System {
|
namespace System {
|
||||||
enum class Messages {
|
enum class Messages : uint8_t {
|
||||||
GoToSleep,
|
GoToSleep,
|
||||||
GoToRunning,
|
GoToRunning,
|
||||||
TouchWakeUp,
|
TouchWakeUp,
|
||||||
|
|
|
@ -30,14 +30,14 @@ namespace {
|
||||||
void DimTimerCallback(TimerHandle_t xTimer) {
|
void DimTimerCallback(TimerHandle_t xTimer) {
|
||||||
|
|
||||||
NRF_LOG_INFO("DimTimerCallback");
|
NRF_LOG_INFO("DimTimerCallback");
|
||||||
auto sysTask = static_cast<SystemTask*>(pvTimerGetTimerID(xTimer));
|
auto* sysTask = static_cast<SystemTask*>(pvTimerGetTimerID(xTimer));
|
||||||
sysTask->OnDim();
|
sysTask->OnDim();
|
||||||
}
|
}
|
||||||
|
|
||||||
void IdleTimerCallback(TimerHandle_t xTimer) {
|
void IdleTimerCallback(TimerHandle_t xTimer) {
|
||||||
|
|
||||||
NRF_LOG_INFO("IdleTimerCallback");
|
NRF_LOG_INFO("IdleTimerCallback");
|
||||||
auto sysTask = static_cast<SystemTask*>(pvTimerGetTimerID(xTimer));
|
auto* sysTask = static_cast<SystemTask*>(pvTimerGetTimerID(xTimer));
|
||||||
sysTask->OnIdle();
|
sysTask->OnIdle();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,10 +208,9 @@ void SystemTask::Work() {
|
||||||
while (true) {
|
while (true) {
|
||||||
UpdateMotion();
|
UpdateMotion();
|
||||||
|
|
||||||
uint8_t msg;
|
Messages msg;
|
||||||
if (xQueueReceive(systemTasksMsgQueue, &msg, 100)) {
|
if (xQueueReceive(systemTasksMsgQueue, &msg, 100) == pdTRUE) {
|
||||||
Messages message = static_cast<Messages>(msg);
|
switch (msg) {
|
||||||
switch (message) {
|
|
||||||
case Messages::EnableSleeping:
|
case Messages::EnableSleeping:
|
||||||
// Make sure that exiting an app doesn't enable sleeping,
|
// Make sure that exiting an app doesn't enable sleeping,
|
||||||
// if the exiting was caused by a firmware update
|
// if the exiting was caused by a firmware update
|
||||||
|
@ -348,7 +347,7 @@ void SystemTask::Work() {
|
||||||
displayApp.PushMessage(Pinetime::Applications::Display::Messages::TouchEvent);
|
displayApp.PushMessage(Pinetime::Applications::Display::Messages::TouchEvent);
|
||||||
break;
|
break;
|
||||||
case Messages::HandleButtonEvent: {
|
case Messages::HandleButtonEvent: {
|
||||||
Controllers::ButtonActions action;
|
Controllers::ButtonActions action = Controllers::ButtonActions::None;
|
||||||
if (nrf_gpio_pin_read(Pinetime::PinMap::Button) == 0) {
|
if (nrf_gpio_pin_read(Pinetime::PinMap::Button) == 0) {
|
||||||
action = buttonHandler.HandleEvent(Controllers::ButtonHandler::Events::Release);
|
action = buttonHandler.HandleEvent(Controllers::ButtonHandler::Events::Release);
|
||||||
} else {
|
} else {
|
||||||
|
@ -459,7 +458,7 @@ void SystemTask::Work() {
|
||||||
uint32_t systick_counter = nrf_rtc_counter_get(portNRF_RTC_REG);
|
uint32_t systick_counter = nrf_rtc_counter_get(portNRF_RTC_REG);
|
||||||
dateTimeController.UpdateTime(systick_counter);
|
dateTimeController.UpdateTime(systick_counter);
|
||||||
NoInit_BackUpTime = dateTimeController.CurrentDateTime();
|
NoInit_BackUpTime = dateTimeController.CurrentDateTime();
|
||||||
if (!nrf_gpio_pin_read(PinMap::Button)) {
|
if (nrf_gpio_pin_read(PinMap::Button) == 0) {
|
||||||
watchdog.Kick();
|
watchdog.Kick();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -552,10 +551,9 @@ void SystemTask::PushMessage(System::Messages msg) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in_isr()) {
|
if (in_isr()) {
|
||||||
BaseType_t xHigherPriorityTaskWoken;
|
BaseType_t xHigherPriorityTaskWoken = pdFALSE;
|
||||||
xHigherPriorityTaskWoken = pdFALSE;
|
|
||||||
xQueueSendFromISR(systemTasksMsgQueue, &msg, &xHigherPriorityTaskWoken);
|
xQueueSendFromISR(systemTasksMsgQueue, &msg, &xHigherPriorityTaskWoken);
|
||||||
if (xHigherPriorityTaskWoken) {
|
if (xHigherPriorityTaskWoken == pdTRUE) {
|
||||||
/* Actual macro used here is port specific. */
|
/* Actual macro used here is port specific. */
|
||||||
portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
|
portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user