1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// Copyright (c) 2017-2021, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "ModemResetHandler.hpp"
#include <module-utils/log/Logger.hpp>
namespace cellular::service
{
auto ModemResetHandler::performSoftReset() -> bool
{
if (procedureInProgress != ProcedureInProgress::None) {
LOG_ERROR("Modem reset procedure is already in progress! Skip request.");
return false;
}
procedureInProgress = ProcedureInProgress::SoftReset;
onAnyReset();
onCellularStateSet(State::ST::PowerDownWaiting);
return onSoftReset();
}
auto ModemResetHandler::performHardReset() -> bool
{
if (procedureInProgress != ProcedureInProgress::None) {
LOG_ERROR("Modem reset procedure is already in progress! Skip request.");
return false;
}
procedureInProgress = ProcedureInProgress::HardReset;
onAnyReset();
onCellularStateSet(State::ST::PowerDownWaiting);
onHardReset();
return false;
}
auto ModemResetHandler::performReboot() -> bool
{
if (procedureInProgress != ProcedureInProgress::None) {
LOG_ERROR("Modem reset procedure is already in progress! Skip request.");
return false;
}
procedureInProgress = ProcedureInProgress::Reboot;
onAnyReset();
onCellularStateSet(State::ST::PowerDownWaiting);
onTurnModemOff();
return false;
}
auto ModemResetHandler::handleStatusPinEvent(bool isActive) -> bool
{
if (isActive) {
return handleSwitchToActive();
}
return handleSwitchToInactive();
}
auto ModemResetHandler::isResetInProgress() -> bool
{
return procedureInProgress != ProcedureInProgress::None;
}
auto ModemResetHandler::handleSwitchToInactive() -> bool
{
switch (procedureInProgress) {
case ProcedureInProgress::None:
return false;
case ProcedureInProgress::SoftReset:
case ProcedureInProgress::HardReset:
onCellularStateSet(State::ST::PowerDown);
return true;
case ProcedureInProgress::Reboot:
auto constexpr delay50ms = 50;
vTaskDelay(delay50ms);
onTurnModemOn();
onCellularStateSet(State::ST::PowerDown);
return true;
}
return false;
}
auto ModemResetHandler::handleSwitchToActive() -> bool
{
if (procedureInProgress == ProcedureInProgress::None) {
return false;
}
procedureInProgress = ProcedureInProgress::None;
onCellularStateSet(State::ST::StatusCheck);
return true;
}
auto ModemResetHandler::performFunctionalityReset() -> bool
{
onAnyReset();
if (onFunctionalityReset) {
return onFunctionalityReset();
}
return false;
}
} // namespace cellular::service