Coding style fixed for pgm_socket

Signed-off-by: Martin Sustrik <sustrik@250bpm.com>
This commit is contained in:
Martin Sustrik 2010-10-30 16:17:08 +02:00
parent b358df9fff
commit 3d8eb071a2
2 changed files with 132 additions and 84 deletions

View File

@ -107,59 +107,71 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
memset (&hints, 0, sizeof (hints)); memset (&hints, 0, sizeof (hints));
hints.ai_family = AF_UNSPEC; hints.ai_family = AF_UNSPEC;
if (!pgm_getaddrinfo (network, NULL, &res, &pgm_error)) { if (!pgm_getaddrinfo (network, NULL, &res, &pgm_error)) {
// Invalid parameters don't set pgm_error_t
// Invalid parameters don't set pgm_error_t.
zmq_assert (pgm_error != NULL); zmq_assert (pgm_error != NULL);
if (pgm_error->domain == PGM_ERROR_DOMAIN_IF && ( if (pgm_error->domain == PGM_ERROR_DOMAIN_IF && (
// NB: cannot catch EAI_BADFLAGS
// NB: cannot catch EAI_BADFLAGS.
pgm_error->code != PGM_ERROR_SERVICE && pgm_error->code != PGM_ERROR_SERVICE &&
pgm_error->code != PGM_ERROR_SOCKTNOSUPPORT)) pgm_error->code != PGM_ERROR_SOCKTNOSUPPORT))
// User, host, or network configuration or transient error
// User, host, or network configuration or transient error.
goto err_abort; goto err_abort;
// Fatal OpenPGM internal error // Fatal OpenPGM internal error.
zmq_assert (false); zmq_assert (false);
} }
zmq_assert (res != NULL); zmq_assert (res != NULL);
// Pick up detected IP family // Pick up detected IP family.
sa_family = res->ai_send_addrs[0].gsr_group.ss_family; sa_family = res->ai_send_addrs[0].gsr_group.ss_family;
// Create IP/PGM or UDP/PGM socket // Create IP/PGM or UDP/PGM socket.
if (udp_encapsulation_) { if (udp_encapsulation_) {
if (!pgm_socket (&sock, sa_family, SOCK_SEQPACKET, IPPROTO_UDP, &pgm_error)) { if (!pgm_socket (&sock, sa_family, SOCK_SEQPACKET, IPPROTO_UDP,
// Invalid parameters don't set pgm_error_t &pgm_error)) {
// Invalid parameters don't set pgm_error_t.
zmq_assert (pgm_error != NULL); zmq_assert (pgm_error != NULL);
if (pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET && ( if (pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET && (
pgm_error->code != PGM_ERROR_BADF && pgm_error->code != PGM_ERROR_BADF &&
pgm_error->code != PGM_ERROR_FAULT && pgm_error->code != PGM_ERROR_FAULT &&
pgm_error->code != PGM_ERROR_NOPROTOOPT && pgm_error->code != PGM_ERROR_NOPROTOOPT &&
pgm_error->code != PGM_ERROR_FAILED)) pgm_error->code != PGM_ERROR_FAILED))
// User, host, or network configuration or transient error
// User, host, or network configuration or transient error.
goto err_abort; goto err_abort;
// Fatal OpenPGM internal error // Fatal OpenPGM internal error.
zmq_assert (false); zmq_assert (false);
} }
// All options are of data type int // All options are of data type int
const int encapsulation_port = port_number; const int encapsulation_port = port_number;
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_UDP_ENCAP_UCAST_PORT, &encapsulation_port, sizeof (encapsulation_port)) || if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_UDP_ENCAP_UCAST_PORT,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_UDP_ENCAP_MCAST_PORT, &encapsulation_port, sizeof (encapsulation_port))) &encapsulation_port, sizeof (encapsulation_port)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_UDP_ENCAP_MCAST_PORT,
&encapsulation_port, sizeof (encapsulation_port)))
goto err_abort; goto err_abort;
} else { }
if (!pgm_socket (&sock, sa_family, SOCK_SEQPACKET, IPPROTO_PGM, &pgm_error)) { else {
// Invalid parameters don't set pgm_error_t if (!pgm_socket (&sock, sa_family, SOCK_SEQPACKET, IPPROTO_PGM,
&pgm_error)) {
// Invalid parameters don't set pgm_error_t.
zmq_assert (pgm_error != NULL); zmq_assert (pgm_error != NULL);
if (pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET && ( if (pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET && (
pgm_error->code != PGM_ERROR_BADF && pgm_error->code != PGM_ERROR_BADF &&
pgm_error->code != PGM_ERROR_FAULT && pgm_error->code != PGM_ERROR_FAULT &&
pgm_error->code != PGM_ERROR_NOPROTOOPT && pgm_error->code != PGM_ERROR_NOPROTOOPT &&
pgm_error->code != PGM_ERROR_FAILED)) pgm_error->code != PGM_ERROR_FAILED))
// User, host, or network configuration or transient error
// User, host, or network configuration or transient error.
goto err_abort; goto err_abort;
// Fatal OpenPGM internal error // Fatal OpenPGM internal error.
zmq_assert (false); zmq_assert (false);
} }
} }
@ -169,16 +181,19 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
sndbuf = (int) options.sndbuf, sndbuf = (int) options.sndbuf,
max_tpdu = (int) pgm_max_tpdu; max_tpdu = (int) pgm_max_tpdu;
if (rcvbuf) { if (rcvbuf) {
if (!pgm_setsockopt (sock, SOL_SOCKET, SO_RCVBUF, &rcvbuf, sizeof (rcvbuf))) if (!pgm_setsockopt (sock, SOL_SOCKET, SO_RCVBUF, &rcvbuf,
goto err_abort; sizeof (rcvbuf)))
goto err_abort;
} }
if (sndbuf) { if (sndbuf) {
if (!pgm_setsockopt (sock, SOL_SOCKET, SO_SNDBUF, &sndbuf, sizeof (sndbuf))) if (!pgm_setsockopt (sock, SOL_SOCKET, SO_SNDBUF, &sndbuf,
goto err_abort; sizeof (sndbuf)))
goto err_abort;
} }
// Set maximum transport protocol data unit size (TPDU). // Set maximum transport protocol data unit size (TPDU).
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MTU, &max_tpdu, sizeof (max_tpdu))) if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MTU, &max_tpdu,
sizeof (max_tpdu)))
goto err_abort; goto err_abort;
} }
@ -194,16 +209,26 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
nak_data_retries = 50, nak_data_retries = 50,
nak_ncf_retries = 50; nak_ncf_retries = 50;
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_RECV_ONLY, &recv_only, sizeof (recv_only)) || if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_RECV_ONLY, &recv_only,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_RXW_MAX_RTE, &rxw_max_rte, sizeof (rxw_max_rte)) || sizeof (recv_only)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_RXW_SECS, &rxw_secs, sizeof (rxw_secs)) || !pgm_setsockopt (sock, IPPROTO_PGM, PGM_RXW_MAX_RTE, &rxw_max_rte,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_PEER_EXPIRY, &peer_expiry, sizeof (peer_expiry)) || sizeof (rxw_max_rte)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_SPMR_EXPIRY, &spmr_expiry, sizeof (spmr_expiry)) || !pgm_setsockopt (sock, IPPROTO_PGM, PGM_RXW_SECS, &rxw_secs,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_BO_IVL, &nak_bo_ivl, sizeof (nak_bo_ivl)) || sizeof (rxw_secs)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_RPT_IVL, &nak_rpt_ivl, sizeof (nak_rpt_ivl)) || !pgm_setsockopt (sock, IPPROTO_PGM, PGM_PEER_EXPIRY, &peer_expiry,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_RDATA_IVL, &nak_rdata_ivl, sizeof (nak_rdata_ivl)) || sizeof (peer_expiry)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_DATA_RETRIES, &nak_data_retries, sizeof (nak_data_retries)) || !pgm_setsockopt (sock, IPPROTO_PGM, PGM_SPMR_EXPIRY, &spmr_expiry,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_NCF_RETRIES, &nak_ncf_retries, sizeof (nak_ncf_retries))) sizeof (spmr_expiry)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_BO_IVL, &nak_bo_ivl,
sizeof (nak_bo_ivl)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_RPT_IVL, &nak_rpt_ivl,
sizeof (nak_rpt_ivl)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_RDATA_IVL,
&nak_rdata_ivl, sizeof (nak_rdata_ivl)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_DATA_RETRIES,
&nak_data_retries, sizeof (nak_data_retries)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NAK_NCF_RETRIES,
&nak_ncf_retries, sizeof (nak_ncf_retries)))
goto err_abort; goto err_abort;
} else { } else {
const int send_only = 1, const int send_only = 1,
@ -220,11 +245,16 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
pgm_secs (25), pgm_secs (25),
pgm_secs (30) }; pgm_secs (30) };
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_SEND_ONLY, &send_only, sizeof (send_only)) || if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_SEND_ONLY,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_TXW_MAX_RTE, &txw_max_rte, sizeof (txw_max_rte)) || &send_only, sizeof (send_only)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_TXW_SECS, &txw_secs, sizeof (txw_secs)) || !pgm_setsockopt (sock, IPPROTO_PGM, PGM_TXW_MAX_RTE,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_AMBIENT_SPM, &ambient_spm, sizeof (ambient_spm)) || &txw_max_rte, sizeof (txw_max_rte)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_HEARTBEAT_SPM, &heartbeat_spm, sizeof (heartbeat_spm))) !pgm_setsockopt (sock, IPPROTO_PGM, PGM_TXW_SECS,
&txw_secs, sizeof (txw_secs)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_AMBIENT_SPM,
&ambient_spm, sizeof (ambient_spm)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_HEARTBEAT_SPM,
&heartbeat_spm, sizeof (heartbeat_spm)))
goto err_abort; goto err_abort;
} }
@ -238,13 +268,15 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
if (options.identity.size () > 0) { if (options.identity.size () > 0) {
// Create gsi from identity. // Create gsi from identity.
if (!pgm_gsi_create_from_data (&addr.sa_addr.gsi, options.identity.data (), options.identity.size ())) if (!pgm_gsi_create_from_data (&addr.sa_addr.gsi,
options.identity.data (), options.identity.size ()))
goto err_abort; goto err_abort;
} else { } else {
// Generate random gsi. // Generate random gsi.
std::string gsi_base = uuid_t ().to_string (); std::string gsi_base = uuid_t ().to_string ();
if (!pgm_gsi_create_from_string (&addr.sa_addr.gsi, gsi_base.c_str (), -1)) if (!pgm_gsi_create_from_string (&addr.sa_addr.gsi,
gsi_base.c_str (), -1))
goto err_abort; goto err_abort;
} }
@ -258,53 +290,63 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)
memcpy (&sa6, &res->ai_recv_addrs[0].gsr_group, sizeof (sa6)); memcpy (&sa6, &res->ai_recv_addrs[0].gsr_group, sizeof (sa6));
if_req.ir_scope_id = sa6.sin6_scope_id; if_req.ir_scope_id = sa6.sin6_scope_id;
} }
if (!pgm_bind3 (sock, &addr, sizeof (addr), &if_req, sizeof (if_req), &if_req, sizeof (if_req), &pgm_error)) { if (!pgm_bind3 (sock, &addr, sizeof (addr), &if_req, sizeof (if_req),
// Invalid parameters don't set pgm_error_t &if_req, sizeof (if_req), &pgm_error)) {
// Invalid parameters don't set pgm_error_t.
zmq_assert (pgm_error != NULL); zmq_assert (pgm_error != NULL);
if ((pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET || if ((pgm_error->domain == PGM_ERROR_DOMAIN_SOCKET ||
pgm_error->domain == PGM_ERROR_DOMAIN_IF) && ( pgm_error->domain == PGM_ERROR_DOMAIN_IF) && (
pgm_error->code != PGM_ERROR_INVAL && pgm_error->code != PGM_ERROR_INVAL &&
pgm_error->code != PGM_ERROR_BADF && pgm_error->code != PGM_ERROR_BADF &&
pgm_error->code != PGM_ERROR_FAULT)) pgm_error->code != PGM_ERROR_FAULT))
// User, host, or network configuration or transient error
// User, host, or network configuration or transient error.
goto err_abort; goto err_abort;
// Fatal OpenPGM internal error // Fatal OpenPGM internal error.
zmq_assert (false); zmq_assert (false);
} }
// Join IP multicast groups // Join IP multicast groups.
for (unsigned i = 0; i < res->ai_recv_addrs_len; i++) for (unsigned i = 0; i < res->ai_recv_addrs_len; i++) {
{ if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_JOIN_GROUP,
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_JOIN_GROUP, &res->ai_recv_addrs[i], sizeof (struct group_req))) &res->ai_recv_addrs [i], sizeof (struct group_req)))
goto err_abort; goto err_abort;
} }
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_SEND_GROUP, &res->ai_send_addrs[0], sizeof (struct group_req))) if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_SEND_GROUP,
&res->ai_send_addrs [0], sizeof (struct group_req)))
goto err_abort; goto err_abort;
pgm_freeaddrinfo (res); pgm_freeaddrinfo (res);
res = NULL; res = NULL;
// Set IP level parameters // Set IP level parameters.
{ {
const int nonblocking = 1, const int nonblocking = 1,
multicast_loop = options.use_multicast_loop ? 1 : 0, multicast_loop = options.use_multicast_loop ? 1 : 0,
multicast_hops = 16, multicast_hops = 16,
dscp = 0x2e << 2; /* Expedited Forwarding PHB for network elements, no ECN. */
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MULTICAST_LOOP, &multicast_loop, sizeof (multicast_loop)) || // Expedited Forwarding PHB for network elements, no ECN.
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MULTICAST_HOPS, &multicast_hops, sizeof (multicast_hops))) dscp = 0x2e << 2;
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MULTICAST_LOOP,
&multicast_loop, sizeof (multicast_loop)) ||
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_MULTICAST_HOPS,
&multicast_hops, sizeof (multicast_hops)))
goto err_abort; goto err_abort;
if (AF_INET6 != sa_family && if (AF_INET6 != sa_family && !pgm_setsockopt (sock,
!pgm_setsockopt (sock, IPPROTO_PGM, PGM_TOS, &dscp, sizeof (dscp))) IPPROTO_PGM, PGM_TOS, &dscp, sizeof (dscp)))
goto err_abort; goto err_abort;
if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NOBLOCK, &nonblocking, sizeof (nonblocking))) if (!pgm_setsockopt (sock, IPPROTO_PGM, PGM_NOBLOCK,
&nonblocking, sizeof (nonblocking)))
goto err_abort; goto err_abort;
} }
// Connect PGM transport to start state machine. // Connect PGM transport to start state machine.
if (!pgm_connect (sock, &pgm_error)) { if (!pgm_connect (sock, &pgm_error)) {
// Invalid parameters don't set pgm_error_t
// Invalid parameters don't set pgm_error_t.
zmq_assert (pgm_error != NULL); zmq_assert (pgm_error != NULL);
goto err_abort; goto err_abort;
} }
@ -348,9 +390,8 @@ zmq::pgm_socket_t::~pgm_socket_t ()
pgm_close (sock, TRUE); pgm_close (sock, TRUE);
} }
// Get receiver fds. receive_fd_ is signaled for incoming // Get receiver fds. receive_fd_ is signaled for incoming packets,
// packets, waiting_pipe_fd_ is signaled for state driven // waiting_pipe_fd_ is signaled for state driven events and data.
// events and data.
void zmq::pgm_socket_t::get_receiver_fds (int *receive_fd_, void zmq::pgm_socket_t::get_receiver_fds (int *receive_fd_,
int *waiting_pipe_fd_) int *waiting_pipe_fd_)
{ {
@ -361,12 +402,14 @@ void zmq::pgm_socket_t::get_receiver_fds (int *receive_fd_,
zmq_assert (waiting_pipe_fd_); zmq_assert (waiting_pipe_fd_);
socklen = sizeof (*receive_fd_); socklen = sizeof (*receive_fd_);
rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RECV_SOCK, receive_fd_, &socklen); rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RECV_SOCK, receive_fd_,
&socklen);
zmq_assert (rc); zmq_assert (rc);
zmq_assert (socklen == sizeof (*receive_fd_)); zmq_assert (socklen == sizeof (*receive_fd_));
socklen = sizeof (*waiting_pipe_fd_); socklen = sizeof (*waiting_pipe_fd_);
rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_PENDING_SOCK, waiting_pipe_fd_, &socklen); rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_PENDING_SOCK, waiting_pipe_fd_,
&socklen);
zmq_assert (rc); zmq_assert (rc);
zmq_assert (socklen == sizeof (*waiting_pipe_fd_)); zmq_assert (socklen == sizeof (*waiting_pipe_fd_));
} }
@ -393,17 +436,20 @@ void zmq::pgm_socket_t::get_sender_fds (int *send_fd_, int *receive_fd_,
zmq_assert (socklen == sizeof (*receive_fd_)); zmq_assert (socklen == sizeof (*receive_fd_));
socklen = sizeof (*receive_fd_); socklen = sizeof (*receive_fd_);
rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RECV_SOCK, receive_fd_, &socklen); rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RECV_SOCK, receive_fd_,
&socklen);
zmq_assert (rc); zmq_assert (rc);
zmq_assert (socklen == sizeof (*receive_fd_)); zmq_assert (socklen == sizeof (*receive_fd_));
socklen = sizeof (*rdata_notify_fd_); socklen = sizeof (*rdata_notify_fd_);
rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_REPAIR_SOCK, rdata_notify_fd_, &socklen); rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_REPAIR_SOCK, rdata_notify_fd_,
&socklen);
zmq_assert (rc); zmq_assert (rc);
zmq_assert (socklen == sizeof (*rdata_notify_fd_)); zmq_assert (socklen == sizeof (*rdata_notify_fd_));
socklen = sizeof (*pending_notify_fd_); socklen = sizeof (*pending_notify_fd_);
rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_PENDING_SOCK, pending_notify_fd_, &socklen); rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_PENDING_SOCK,
pending_notify_fd_, &socklen);
zmq_assert (rc); zmq_assert (rc);
zmq_assert (socklen == sizeof (*pending_notify_fd_)); zmq_assert (socklen == sizeof (*pending_notify_fd_));
} }
@ -416,12 +462,13 @@ size_t zmq::pgm_socket_t::send (unsigned char *data_, size_t data_len_)
const int status = pgm_send (sock, data_, data_len_, &nbytes); const int status = pgm_send (sock, data_, data_len_, &nbytes);
// We have to write all data as one packet. // We have to write all data as one packet.
if (nbytes > 0) { if (nbytes > 0) {
zmq_assert (status == PGM_IO_STATUS_NORMAL); zmq_assert (status == PGM_IO_STATUS_NORMAL);
zmq_assert ((ssize_t) nbytes == (ssize_t) data_len_); zmq_assert ((ssize_t) nbytes == (ssize_t) data_len_);
} else { } else {
zmq_assert (status == PGM_IO_STATUS_RATE_LIMITED || status == PGM_IO_STATUS_WOULD_BLOCK); zmq_assert (status == PGM_IO_STATUS_RATE_LIMITED ||
status == PGM_IO_STATUS_WOULD_BLOCK);
if (status == PGM_IO_STATUS_RATE_LIMITED) if (status == PGM_IO_STATUS_RATE_LIMITED)
errno = ENOMEM; errno = ENOMEM;
@ -429,7 +476,7 @@ size_t zmq::pgm_socket_t::send (unsigned char *data_, size_t data_len_)
errno = EBUSY; errno = EBUSY;
} }
// Save return value. // Save return value.
last_tx_status = status; last_tx_status = status;
return nbytes; return nbytes;
@ -437,12 +484,15 @@ size_t zmq::pgm_socket_t::send (unsigned char *data_, size_t data_len_)
long zmq::pgm_socket_t::get_rx_timeout () long zmq::pgm_socket_t::get_rx_timeout ()
{ {
if (last_rx_status != PGM_IO_STATUS_RATE_LIMITED && last_rx_status != PGM_IO_STATUS_TIMER_PENDING) if (last_rx_status != PGM_IO_STATUS_RATE_LIMITED &&
last_rx_status != PGM_IO_STATUS_TIMER_PENDING)
return -1; return -1;
struct timeval tv; struct timeval tv;
socklen_t optlen = sizeof (tv); socklen_t optlen = sizeof (tv);
const bool rc = pgm_getsockopt (sock, IPPROTO_PGM, last_rx_status == PGM_IO_STATUS_RATE_LIMITED ? PGM_RATE_REMAIN : PGM_TIME_REMAIN, &tv, &optlen); const bool rc = pgm_getsockopt (sock, IPPROTO_PGM,
last_rx_status == PGM_IO_STATUS_RATE_LIMITED ? PGM_RATE_REMAIN :
PGM_TIME_REMAIN, &tv, &optlen);
zmq_assert (rc); zmq_assert (rc);
const long timeout = (tv.tv_sec * 1000) + (tv.tv_usec / 1000); const long timeout = (tv.tv_sec * 1000) + (tv.tv_usec / 1000);
@ -457,7 +507,8 @@ long zmq::pgm_socket_t::get_tx_timeout ()
struct timeval tv; struct timeval tv;
socklen_t optlen = sizeof (tv); socklen_t optlen = sizeof (tv);
const bool rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RATE_REMAIN, &tv, &optlen); const bool rc = pgm_getsockopt (sock, IPPROTO_PGM, PGM_RATE_REMAIN, &tv,
&optlen);
zmq_assert (rc); zmq_assert (rc);
const long timeout = (tv.tv_sec * 1000) + (tv.tv_usec / 1000); const long timeout = (tv.tv_sec * 1000) + (tv.tv_usec / 1000);
@ -477,9 +528,8 @@ size_t zmq::pgm_socket_t::get_max_tsdu_size ()
return (size_t) max_tsdu; return (size_t) max_tsdu;
} }
// pgm_recvmsgv is called to fill the pgm_msgv array up to // pgm_recvmsgv is called to fill the pgm_msgv array up to pgm_msgv_len.
// pgm_msgv_len. In subsequent calls data from pgm_msgv structure are // In subsequent calls data from pgm_msgv structure are returned.
// returned.
ssize_t zmq::pgm_socket_t::receive (void **raw_data_, const pgm_tsi_t **tsi_) ssize_t zmq::pgm_socket_t::receive (void **raw_data_, const pgm_tsi_t **tsi_)
{ {
size_t raw_data_len = 0; size_t raw_data_len = 0;
@ -512,7 +562,7 @@ ssize_t zmq::pgm_socket_t::receive (void **raw_data_, const pgm_tsi_t **tsi_)
const int status = pgm_recvmsgv (sock, pgm_msgv, const int status = pgm_recvmsgv (sock, pgm_msgv,
pgm_msgv_len, MSG_ERRQUEUE, &nbytes_rec, &pgm_error); pgm_msgv_len, MSG_ERRQUEUE, &nbytes_rec, &pgm_error);
// Invalid parameters // Invalid parameters.
zmq_assert (status != PGM_IO_STATUS_ERROR); zmq_assert (status != PGM_IO_STATUS_ERROR);
last_rx_status = status; last_rx_status = status;
@ -535,8 +585,7 @@ ssize_t zmq::pgm_socket_t::receive (void **raw_data_, const pgm_tsi_t **tsi_)
zmq_assert (nbytes_rec == 0); zmq_assert (nbytes_rec == 0);
// In case if no RDATA/ODATA caused POLLIN 0 is // In case if no RDATA/ODATA caused POLLIN 0 is returned.
// returned.
nbytes_rec = 0; nbytes_rec = 0;
errno = ENOMEM; errno = ENOMEM;
return 0; return 0;
@ -547,8 +596,7 @@ ssize_t zmq::pgm_socket_t::receive (void **raw_data_, const pgm_tsi_t **tsi_)
zmq_assert (nbytes_rec == 0); zmq_assert (nbytes_rec == 0);
// In case if no RDATA/ODATA caused POLLIN 0 is // In case if no RDATA/ODATA caused POLLIN 0 is returned.
// returned.
nbytes_rec = 0; nbytes_rec = 0;
errno = EAGAIN; errno = EAGAIN;
return 0; return 0;
@ -610,12 +658,13 @@ void zmq::pgm_socket_t::process_upstream ()
const int status = pgm_recvmsgv (sock, &dummy_msg, const int status = pgm_recvmsgv (sock, &dummy_msg,
1, MSG_ERRQUEUE, &dummy_bytes, &pgm_error); 1, MSG_ERRQUEUE, &dummy_bytes, &pgm_error);
// Invalid parameters // Invalid parameters.
zmq_assert (status != PGM_IO_STATUS_ERROR); zmq_assert (status != PGM_IO_STATUS_ERROR);
// No data should be returned. // No data should be returned.
zmq_assert (dummy_bytes == 0 && (status == PGM_IO_STATUS_TIMER_PENDING || zmq_assert (dummy_bytes == 0 && (status == PGM_IO_STATUS_TIMER_PENDING ||
status == PGM_IO_STATUS_RATE_LIMITED || status == PGM_IO_STATUS_WOULD_BLOCK)); status == PGM_IO_STATUS_RATE_LIMITED ||
status == PGM_IO_STATUS_WOULD_BLOCK));
last_rx_status = status; last_rx_status = status;

View File

@ -40,9 +40,8 @@ namespace zmq
{ {
public: public:
// If receiver_ is true PGM transport is not generating SPM packets. // If receiver_ is true PGM transport is not generating SPM packets.
// interface format: iface;mcast_group:port for raw PGM socket
// udp:iface;mcast_goup:port for UDP encapsulacion
pgm_socket_t (bool receiver_, const options_t &options_); pgm_socket_t (bool receiver_, const options_t &options_);
// Closes the transport. // Closes the transport.
@ -77,7 +76,7 @@ namespace zmq
private: private:
// OpenPGM transport // OpenPGM transport.
pgm_sock_t* sock; pgm_sock_t* sock;
int last_rx_status, last_tx_status; int last_rx_status, last_tx_status;