Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add intial steps to transfer transitions to the MC
[simgrid.git] / src / mc / remote / Channel.cpp
1 /* Copyright (c) 2015-2023. The SimGrid Team.
2  * All rights reserved.                                                     */
3
4 /* This program is free software; you can redistribute it and/or modify it
5  * under the terms of the license (GNU LGPL) which comes with this package. */
6
7 #include "src/mc/remote/Channel.hpp"
8 #include <xbt/log.h>
9
10 #include <cerrno>
11 #include <cstring>
12 #include <sys/socket.h>
13 #include <sys/types.h>
14 #include <unistd.h>
15
16 XBT_LOG_NEW_DEFAULT_SUBCATEGORY(mc_Channel, mc, "MC interprocess communication");
17
18 namespace simgrid::mc {
19
20 Channel::~Channel()
21 {
22   if (this->socket_ >= 0)
23     close(this->socket_);
24 }
25
26 /** @brief Send a message; returns 0 on success or errno on failure */
27 int Channel::send(const void* message, size_t size) const
28 {
29   XBT_DEBUG("Send %s", to_c_str(*(MessageType*)message));
30   while (::send(this->socket_, message, size, 0) == -1) {
31     if (errno != EINTR) {
32       XBT_ERROR("Channel::send failure: %s", strerror(errno));
33       return errno;
34     }
35   }
36   return 0;
37 }
38
39 ssize_t Channel::receive(void* message, size_t size, bool block) const
40 {
41   ssize_t res = recv(this->socket_, message, size, block ? 0 : MSG_DONTWAIT);
42   if (res != -1)
43     XBT_DEBUG("Receive %s (requested %lu bytes to be sent; received %lu)", to_c_str(*(MessageType*)message), size, res);
44   else
45     XBT_ERROR("Channel::receive failure: %s", strerror(errno));
46   return res;
47 }
48 } // namespace simgrid::mc