Skip to content

Commit

Permalink
[simulation] log the exit code when the program exits
Browse files Browse the repository at this point in the history
  • Loading branch information
zhanglongxia committed Nov 18, 2024
1 parent 3702c88 commit 160a706
Show file tree
Hide file tree
Showing 10 changed files with 87 additions and 91 deletions.
8 changes: 4 additions & 4 deletions examples/platforms/simulation/alarm.c
Original file line number Diff line number Diff line change
Expand Up @@ -114,7 +114,7 @@ void platformAlarmInit(uint32_t aSpeedUpFactor)
if (sigaction(OPENTHREAD_CONFIG_MICRO_TIMER_SIGNAL, &sa, NULL) == -1)
{
perror("sigaction");
exit(EXIT_FAILURE);
DieNow(OT_EXIT_ERROR_ERRNO);
}

struct sigevent sev;
Expand All @@ -126,7 +126,7 @@ void platformAlarmInit(uint32_t aSpeedUpFactor)
if (-1 == timer_create(CLOCK_MONOTONIC, &sev, &sMicroTimer))
{
perror("timer_create");
exit(EXIT_FAILURE);
DieNow(OT_EXIT_ERROR_ERRNO);
}
}
#endif
Expand Down Expand Up @@ -198,7 +198,7 @@ void otPlatAlarmMicroStartAt(otInstance *aInstance, uint32_t aT0, uint32_t aDt)
if (-1 == timer_settime(sMicroTimer, 0, &its, NULL))
{
perror("otPlatAlarmMicroStartAt timer_settime()");
exit(EXIT_FAILURE);
DieNow(OT_EXIT_ERROR_ERRNO);
}
}
#endif // __linux__
Expand All @@ -217,7 +217,7 @@ void otPlatAlarmMicroStop(otInstance *aInstance)
if (-1 == timer_settime(sMicroTimer, 0, &its, NULL))
{
perror("otPlatAlarmMicroStop timer_settime()");
exit(EXIT_FAILURE);
DieNow(OT_EXIT_ERROR_ERRNO);
}
}
#endif // __linux__
Expand Down
5 changes: 3 additions & 2 deletions examples/platforms/simulation/ble.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
#include <openthread/tcat.h>
#include <openthread/platform/ble.h>

#include "lib/platform/exit_code.h"
#include "utils/code_utils.h"

#define PLAT_BLE_MSG_DATA_MAX 2048
Expand Down Expand Up @@ -76,7 +77,7 @@ static void initFds(void)
exit:
if (sFd == -1)
{
exit(EXIT_FAILURE);
DieNow(OT_EXIT_FAILURE);
}
}

Expand Down Expand Up @@ -207,7 +208,7 @@ void platformBleProcess(otInstance *aInstance, const fd_set *aReadFdSet, const f
else if (errno != EINTR && errno != EAGAIN)
{
perror("recvfrom BLE simulation failed");
exit(EXIT_FAILURE);
DieNow(OT_EXIT_FAILURE);
}
}
exit:
Expand Down
4 changes: 2 additions & 2 deletions examples/platforms/simulation/infra_if.c
Original file line number Diff line number Diff line change
Expand Up @@ -252,7 +252,7 @@ void platformInfraIfInit(void)
if (*endptr != '\0')
{
fprintf(stderr, "\r\nInvalid PORT_OFFSET: %s\r\n", str);
exit(EXIT_FAILURE);
DieNow(OT_EXIT_FAILURE);
}

sPortOffset *= (MAX_NETWORK_SIZE + 1);
Expand Down Expand Up @@ -332,7 +332,7 @@ OT_TOOL_WEAK void otPlatInfraIfRecvIcmp6Nd(otInstance *aInstance,
OT_UNUSED_VARIABLE(aBufferLength);

fprintf(stderr, "\n\r Weak otPlatInfraIfRecvIcmp6Nd is being used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);
}

#endif // OPENTHREAD_SIMULATION_IMPLEMENT_INFRA_IF && OPENTHREAD_CONFIG_BORDER_ROUTING_ENABLE
45 changes: 17 additions & 28 deletions examples/platforms/simulation/mdns_socket.c
Original file line number Diff line number Diff line change
Expand Up @@ -76,26 +76,16 @@ static int sMdnsFd6 = -1;
#endif
#endif

#define VerifyOrDie(aCondition, aErrMsg) \
do \
{ \
if (!(aCondition)) \
{ \
fprintf(stderr, "\n\r" aErrMsg ". errono:%s\n\r", strerror(errno)); \
exit(1); \
} \
} while (false)

static void SetReuseAddrPort(int aFd)
{
int ret;
int yes = 1;

ret = setsockopt(aFd, SOL_SOCKET, SO_REUSEADDR, (char *)&yes, sizeof(yes));
VerifyOrDie(ret >= 0, "setsocketopt(SO_REUSEADDR) failed");
VerifyOrDie(ret >= 0, OT_EXIT_FAILURE);

ret = setsockopt(aFd, SOL_SOCKET, SO_REUSEPORT, (char *)&yes, sizeof(yes));
VerifyOrDie(ret >= 0, "setsocketopt(SO_REUSEPORT) failed");
VerifyOrDie(ret >= 0, OT_EXIT_FAILURE);
}

static void OpenIp4Socket(uint32_t aInfraIfIndex)
Expand All @@ -109,18 +99,18 @@ static void OpenIp4Socket(uint32_t aInfraIfIndex)
int value;

fd = socket(AF_INET, SOCK_DGRAM, 0);
VerifyOrDie(fd >= 0, "socket() failed");
VerifyOrDie(fd >= 0, OT_EXIT_FAILURE);

#ifdef __linux__
{
char nameBuffer[IF_NAMESIZE];
const char *ifname;

ifname = if_indextoname(aInfraIfIndex, nameBuffer);
VerifyOrDie(ifname != NULL, "if_indextoname() failed");
VerifyOrDie(ifname != NULL, OT_EXIT_ERROR_ERRNO);

ret = setsockopt(fd, SOL_SOCKET, SO_BINDTODEVICE, ifname, strlen(ifname));
VerifyOrDie(ret >= 0, "setsocketopt(SO_BINDTODEVICE) failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);
}
#else
value = aInfraIfIndex;
Expand All @@ -129,15 +119,15 @@ static void OpenIp4Socket(uint32_t aInfraIfIndex)

u8 = 255;
ret = setsockopt(fd, IPPROTO_IP, IP_MULTICAST_TTL, &u8, sizeof(u8));
VerifyOrDie(ret >= 0, "setsocketopt(IP_MULTICAST_TTL) failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);

value = 255;
ret = setsockopt(fd, IPPROTO_IP, IP_TTL, &value, sizeof(value));
VerifyOrDie(ret >= 0, "setsocketopt(IP_TTL) failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);

u8 = 1;
ret = setsockopt(fd, IPPROTO_IP, IP_MULTICAST_LOOP, &u8, sizeof(u8));
VerifyOrDie(ret >= 0, "setsocketopt(IP_MULTICAST_LOOP) failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);

SetReuseAddrPort(fd);

Expand All @@ -149,7 +139,7 @@ static void OpenIp4Socket(uint32_t aInfraIfIndex)
mreqn.imr_ifindex = aInfraIfIndex;

ret = setsockopt(fd, IPPROTO_IP, IP_MULTICAST_IF, &mreqn, sizeof(mreqn));
VerifyOrDie(ret >= 0, "setsocketopt(IP_MULTICAST_IF) failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);
}

memset(&addr, 0, sizeof(addr));
Expand All @@ -158,7 +148,7 @@ static void OpenIp4Socket(uint32_t aInfraIfIndex)
addr.sin_port = htons(MDNS_PORT);

ret = bind(fd, (struct sockaddr *)&addr, sizeof(addr));
VerifyOrDie(ret >= 0, "bind() failed");
VerifyOrDie(ret >= 0, OT_EXIT_ERROR_ERRNO);

sMdnsFd4 = fd;
}
Expand Down Expand Up @@ -468,16 +458,15 @@ OT_TOOL_WEAK uint16_t otMessageRead(const otMessage *aMessage, uint16_t aOffset,
OT_UNUSED_VARIABLE(aLength);

fprintf(stderr, "\n\rWeak otMessageRead() is incorrectly used\n\r");
exit(1);

DieNow(OT_EXIT_FAILURE);
return 0;
}

OT_TOOL_WEAK void otMessageFree(otMessage *aMessage)
{
OT_UNUSED_VARIABLE(aMessage);
fprintf(stderr, "\n\rWeak otMessageFree() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);
}

OT_TOOL_WEAK otMessage *otIp6NewMessage(otInstance *aInstance, const otMessageSettings *aSettings)
Expand All @@ -486,7 +475,7 @@ OT_TOOL_WEAK otMessage *otIp6NewMessage(otInstance *aInstance, const otMessageSe
OT_UNUSED_VARIABLE(aSettings);

fprintf(stderr, "\n\rWeak otIp6NewMessage() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);

return NULL;
}
Expand All @@ -498,7 +487,7 @@ OT_TOOL_WEAK otError otMessageAppend(otMessage *aMessage, const void *aBuf, uint
OT_UNUSED_VARIABLE(aLength);

fprintf(stderr, "\n\rWeak otMessageFree() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);

return OT_ERROR_NOT_IMPLEMENTED;
}
Expand All @@ -509,7 +498,7 @@ OT_TOOL_WEAK void otIp4ToIp4MappedIp6Address(const otIp4Address *aIp4Address, ot
OT_UNUSED_VARIABLE(aIp6Address);

fprintf(stderr, "\n\rWeak otIp4ToIp4MappedIp6Address() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);
}

OT_TOOL_WEAK otError otIp4FromIp4MappedIp6Address(const otIp6Address *aIp6Address, otIp4Address *aIp4Address)
Expand All @@ -518,7 +507,7 @@ OT_TOOL_WEAK otError otIp4FromIp4MappedIp6Address(const otIp6Address *aIp6Addres
OT_UNUSED_VARIABLE(aIp4Address);

fprintf(stderr, "\n\rWeak otIp4FromIp4MappedIp6Address() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);

return OT_ERROR_NOT_IMPLEMENTED;
}
Expand All @@ -534,7 +523,7 @@ OT_TOOL_WEAK void otPlatMdnsHandleReceive(otInstance *aInstance
OT_UNUSED_VARIABLE(aAddress);

fprintf(stderr, "\n\rWeak otPlatMdnsHandleReceive() is incorrectly used\n\r");
exit(1);
DieNow(OT_EXIT_FAILURE);
}

//---------------------------------------------------------------------------------------------------------------------
Expand Down
3 changes: 2 additions & 1 deletion examples/platforms/simulation/radio.c
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
#include <openthread/platform/time.h>

#include "simul_utils.h"
#include "lib/platform/exit_code.h"
#include "utils/code_utils.h"
#include "utils/link_metrics.h"
#include "utils/mac_frame.h"
Expand Down Expand Up @@ -1231,7 +1232,7 @@ void parseFromEnvAsUint16(const char *aEnvName, uint16_t *aValue)
if (*endptr != '\0')
{
fprintf(stderr, "Invalid %s: %s\n", aEnvName, env);
exit(EXIT_FAILURE);
DieNow(OT_EXIT_FAILURE);
}
}
}
Loading

0 comments on commit 160a706

Please sign in to comment.