CCSDS time extra defined for avr lib

This commit is contained in:
Robin Müller 2020-01-28 23:19:19 +01:00
parent 8f17d5147e
commit 7dd4694d9d
2 changed files with 44 additions and 4 deletions

View File

@ -154,6 +154,7 @@ ReturnValue_t CCSDSTime::convertFromASCII(Clock::TimeOfDay_t* to, const uint8_t*
if (length < 19) { if (length < 19) {
return RETURN_FAILED; return RETURN_FAILED;
} }
#ifdef AVR_STDIO
// In the size optimized nano library used by ATMEL, floating point conversion // In the size optimized nano library used by ATMEL, floating point conversion
// is not allowed. There is a linker flag to allow it apparently, but I // is not allowed. There is a linker flag to allow it apparently, but I
// could not manage to make it run (removing -specs=nano.specs in linker flags works though, // could not manage to make it run (removing -specs=nano.specs in linker flags works though,
@ -167,11 +168,8 @@ ReturnValue_t CCSDSTime::convertFromASCII(Clock::TimeOfDay_t* to, const uint8_t*
int minute; int minute;
int second; int second;
int usecond; int usecond;
// try Code A (yyyy-mm-dd)
//int count = sscanf((char *) from, "%4hi-%2hi-%2hiT%2hi:%2hi:%fZ", &year,
// &month, &day, &hour, &minute, &second);
int count = sscanf((char *) from, "%4d-%2d-%2dT%2d:%2d:%2d.%dZ", &year, int count = sscanf((char *) from, "%4d-%2d-%2dT%2d:%2d:%2d.%dZ", &year,
&month, &day, &hour, &minute, &second, &usecond); &month, &day, &hour, &minute, &second, &usecond);
if (count == 7) { if (count == 7) {
to->year = year; to->year = year;
to->month = month; to->month = month;
@ -202,6 +200,47 @@ ReturnValue_t CCSDSTime::convertFromASCII(Clock::TimeOfDay_t* to, const uint8_t*
to->usecond = usecond; to->usecond = usecond;
return RETURN_OK; return RETURN_OK;
} }
#else
uint16_t year;
uint8_t month;
uint16_t day;
uint8_t hour;
uint8_t minute;
float second;
//try Code A (yyyy-mm-dd)
int count = sscanf((char *) from, "%4hi-%2hhi-%2hiT%2hhi:%2hhi:%fZ", &year,
&month, &day, &hour, &minute, &second);
if (count == 6) {
to->year = year;
to->month = month;
to->day = day;
to->hour = hour;
to->minute = minute;
to->second = second;
to->usecond = (second - floor(second)) * 1000000;
return RETURN_OK;
}
//try Code B (yyyy-ddd)
count = sscanf((char *) from, "%4hi-%3hiT%2hhi:%2hhi:%fZ", &year, &day,
&hour, &minute, &second);
if (count == 5) {
uint8_t tempDay;
ReturnValue_t result = CCSDSTime::convertDaysOfYear(day, year, &month,
&tempDay);
if (result != RETURN_OK) {
return RETURN_FAILED;
}
to->year = year;
to->month = month;
to->day = tempDay;
to->hour = hour;
to->minute = minute;
to->second = second;
to->usecond = (second - floor(second)) * 1000000;
return RETURN_OK;
}
#endif
return UNSUPPORTED_TIME_FORMAT; return UNSUPPORTED_TIME_FORMAT;
} }

View File

@ -7,6 +7,7 @@
#ifndef RECEIVESTIMEINFOIF_H_ #ifndef RECEIVESTIMEINFOIF_H_
#define RECEIVESTIMEINFOIF_H_ #define RECEIVESTIMEINFOIF_H_
#include <framework/ipc/MessageQueueSenderIF.h>
/** /**
* This is a Interface for classes that receive timing information * This is a Interface for classes that receive timing information