2021-07-13 20:58:45 +02:00
|
|
|
#include "fsfw/osal/common/tcpipHelpers.h"
|
2021-03-12 16:47:55 +01:00
|
|
|
|
2021-03-12 18:06:24 +01:00
|
|
|
#include <errno.h>
|
2022-02-02 10:29:30 +01:00
|
|
|
|
2021-03-12 18:06:24 +01:00
|
|
|
#include <string>
|
|
|
|
|
2022-02-02 10:29:30 +01:00
|
|
|
#include "fsfw/serviceinterface/ServiceInterface.h"
|
|
|
|
#include "fsfw/tasks/TaskFactory.h"
|
|
|
|
|
2021-03-12 18:06:24 +01:00
|
|
|
void tcpip::handleError(Protocol protocol, ErrorSources errorSrc, dur_millis_t sleepDuration) {
|
2022-02-02 10:29:30 +01:00
|
|
|
int errCode = errno;
|
|
|
|
std::string protocolString;
|
|
|
|
std::string errorSrcString;
|
|
|
|
determineErrorStrings(protocol, errorSrc, protocolString, errorSrcString);
|
|
|
|
std::string infoString;
|
|
|
|
switch (errCode) {
|
|
|
|
case (EACCES): {
|
|
|
|
infoString = "EACCES";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EINVAL): {
|
|
|
|
infoString = "EINVAL";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EAGAIN): {
|
|
|
|
infoString = "EAGAIN";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EMFILE): {
|
|
|
|
infoString = "EMFILE";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENFILE): {
|
|
|
|
infoString = "ENFILE";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EAFNOSUPPORT): {
|
|
|
|
infoString = "EAFNOSUPPORT";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENOBUFS): {
|
|
|
|
infoString = "ENOBUFS";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENOMEM): {
|
|
|
|
infoString = "ENOMEM";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EPROTONOSUPPORT): {
|
|
|
|
infoString = "EPROTONOSUPPORT";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EADDRINUSE): {
|
|
|
|
infoString = "EADDRINUSE";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EBADF): {
|
|
|
|
infoString = "EBADF";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENOTSOCK): {
|
|
|
|
infoString = "ENOTSOCK";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EADDRNOTAVAIL): {
|
|
|
|
infoString = "EADDRNOTAVAIL";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EFAULT): {
|
|
|
|
infoString = "EFAULT";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ELOOP): {
|
|
|
|
infoString = "ELOOP";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENAMETOOLONG): {
|
|
|
|
infoString = "ENAMETOOLONG";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENOENT): {
|
|
|
|
infoString = "ENOENT";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (ENOTDIR): {
|
|
|
|
infoString = "ENOTDIR";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case (EROFS): {
|
|
|
|
infoString = "EROFS";
|
|
|
|
break;
|
2021-03-12 18:06:24 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
default: {
|
2022-02-02 10:29:30 +01:00
|
|
|
infoString = "Error code: " + std::to_string(errCode);
|
2021-03-12 18:06:24 +01:00
|
|
|
}
|
2022-02-02 10:29:30 +01:00
|
|
|
}
|
2021-03-12 18:06:24 +01:00
|
|
|
|
|
|
|
#if FSFW_CPP_OSTREAM_ENABLED == 1
|
2022-02-02 10:29:30 +01:00
|
|
|
sif::warning << "tcpip::handleError: " << protocolString << " | " << errorSrcString << " | "
|
|
|
|
<< infoString << std::endl;
|
2021-03-12 18:06:24 +01:00
|
|
|
#else
|
2022-02-02 10:29:30 +01:00
|
|
|
sif::printWarning("tcpip::handleError: %s | %s | %s\n", protocolString.c_str(),
|
|
|
|
errorSrcString.c_str(), infoString.c_str());
|
2021-03-12 18:06:24 +01:00
|
|
|
#endif /* FSFW_CPP_OSTREAM_ENABLED == 1 */
|
|
|
|
|
2022-02-02 10:29:30 +01:00
|
|
|
if (sleepDuration > 0) {
|
|
|
|
TaskFactory::instance()->delayTask(sleepDuration);
|
|
|
|
}
|
2021-03-12 16:47:55 +01:00
|
|
|
}
|