fsfw/src/fsfw/pus/Service9TimeManagement.cpp

100 lines
3.1 KiB
C++
Raw Normal View History

2021-07-13 20:58:45 +02:00
#include "fsfw/pus/Service9TimeManagement.h"
2020-09-16 19:11:50 +02:00
#include <cmath>
2021-07-13 20:58:45 +02:00
#include "fsfw/events/EventManagerIF.h"
2022-02-02 10:29:30 +01:00
#include "fsfw/pus/servicepackets/Service9Packets.h"
2024-04-03 16:15:07 +02:00
#include "fsfw/serialize/SerializeAdapter.h"
2021-07-13 20:58:45 +02:00
#include "fsfw/serviceinterface/ServiceInterface.h"
2022-02-02 10:29:30 +01:00
#include "fsfw/timemanager/CCSDSTime.h"
2020-09-16 19:11:50 +02:00
Service9TimeManagement::Service9TimeManagement(PsbParams params) : PusServiceBase(params) {
params.name = "PUS 9 Time MGMT";
}
2020-09-16 19:11:50 +02:00
2022-07-20 22:21:15 +02:00
Service9TimeManagement::~Service9TimeManagement() = default;
2020-09-16 19:11:50 +02:00
2022-08-16 01:08:26 +02:00
ReturnValue_t Service9TimeManagement::performService() { return returnvalue::OK; }
2020-09-16 19:11:50 +02:00
ReturnValue_t Service9TimeManagement::handleRequest(uint8_t subservice) {
2022-02-02 10:29:30 +01:00
switch (subservice) {
case Subservice::SET_TIME: {
2022-02-02 10:29:30 +01:00
return setTime();
}
case Subservice::DUMP_TIME: {
timeval newTime;
2024-04-03 16:19:40 +02:00
ReturnValue_t result = Clock::getClock_timeval(&newTime);
if (result != returnvalue::OK) {
return result;
}
2024-04-03 16:23:21 +02:00
triggerEvent(CLOCK_DUMP, newTime.tv_sec, newTime.tv_usec);
return returnvalue::OK;
}
2024-04-03 16:15:07 +02:00
case Subservice::RELATIVE_TIMESHIFT: {
timeval currentTime;
2024-04-03 16:19:40 +02:00
ReturnValue_t result = Clock::getClock_timeval(&currentTime);
if (result != returnvalue::OK) {
return result;
}
2024-04-03 16:15:07 +02:00
if (currentPacket.getUserDataLen() != 8) {
return AcceptsTelecommandsIF::ILLEGAL_APPLICATION_DATA;
}
size_t deserLen = 8;
int64_t timeshiftNanos = 0;
2024-04-03 16:19:40 +02:00
result = SerializeAdapter::deSerialize(&timeshiftNanos, currentPacket.getUserData(),
&deserLen, SerializeIF::Endianness::NETWORK);
if (result != returnvalue::OK) {
return result;
}
2024-04-03 16:15:07 +02:00
bool positiveShift = true;
if (timeshiftNanos < 0) {
positiveShift = false;
}
timeval offset{};
offset.tv_sec = std::abs(timeshiftNanos) / 1000000000;
offset.tv_usec = (std::abs(timeshiftNanos) % 1000000000) / 1000;
timeval newTime;
if (positiveShift) {
newTime = currentTime + offset;
} else {
newTime = currentTime - offset;
}
2024-04-03 16:23:21 +02:00
result = Clock::setClock(&newTime);
if (result == returnvalue::OK) {
// Report new time as event.
triggerEvent(CLOCK_DUMP, newTime.tv_sec, newTime.tv_usec);
}
return result;
2024-04-03 16:15:07 +02:00
}
2022-02-02 10:29:30 +01:00
default:
return AcceptsTelecommandsIF::INVALID_SUBSERVICE;
}
2020-09-16 19:11:50 +02:00
}
ReturnValue_t Service9TimeManagement::setTime() {
2022-02-02 10:29:30 +01:00
Clock::TimeOfDay_t timeToSet;
2022-07-21 11:34:11 +02:00
TimePacket timePacket(currentPacket.getUserData(), currentPacket.getUserDataLen());
2022-02-02 10:29:30 +01:00
ReturnValue_t result =
CCSDSTime::convertFromCcsds(&timeToSet, timePacket.getTime(), timePacket.getTimeSize());
2022-08-16 01:08:26 +02:00
if (result != returnvalue::OK) {
2022-02-02 10:29:30 +01:00
triggerEvent(CLOCK_SET_FAILURE, result, 0);
return result;
}
timeval time;
Clock::getClock_timeval(&time);
2022-02-02 10:29:30 +01:00
result = Clock::setClock(&timeToSet);
2022-08-16 01:08:26 +02:00
if (result == returnvalue::OK) {
timeval newTime;
Clock::getClock_timeval(&newTime);
triggerEvent(CLOCK_SET, time.tv_sec, newTime.tv_sec);
2022-08-16 01:08:26 +02:00
return returnvalue::OK;
2022-02-02 10:29:30 +01:00
} else {
triggerEvent(CLOCK_SET_FAILURE, result, 0);
2022-08-16 01:08:26 +02:00
return returnvalue::FAILED;
2022-02-02 10:29:30 +01:00
}
2020-09-16 19:11:50 +02:00
}