diff options
| author | Martin Sustrik <sustrik@250bpm.com> | 2010-02-03 13:06:34 +0100 | 
|---|---|---|
| committer | Martin Sustrik <sustrik@250bpm.com> | 2010-02-03 13:06:34 +0100 | 
| commit | 7c25feb51bdbc9563cc65ff4829f761ef7231483 (patch) | |
| tree | 6e1075e91d6a039c2cc93bf29e170765ad22eb72 /src/pgm_socket.cpp | |
| parent | 9cee8f9c3e22f1e880988271ab1c31c92827efde (diff) | |
ZMQII-55: At most one PGM/UDP transport can be opened
Diffstat (limited to 'src/pgm_socket.cpp')
| -rw-r--r-- | src/pgm_socket.cpp | 38 | 
1 files changed, 20 insertions, 18 deletions
| diff --git a/src/pgm_socket.cpp b/src/pgm_socket.cpp index 4d713e3..8160ca6 100644 --- a/src/pgm_socket.cpp +++ b/src/pgm_socket.cpp @@ -78,33 +78,35 @@ int zmq::pgm_socket_t::init (bool udp_encapsulation_, const char *network_)      nbytes_processed = 0;      pgm_msgv_processed = 0; +    int rc;      GError *pgm_error = NULL; -    //  Init PGM transport. +    //  Init PGM transport if not already done.      //  Ensure threading enabled, ensure timer enabled and find PGM protocol id.      //      //  Note that if you want to use gettimeofday and sleep for openPGM timing,      //  set environment variables PGM_TIMER to "GTOD"       //  and PGM_SLEEP to "USLEEP". -    int rc = pgm_init (&pgm_error); -    if (rc != TRUE) { +    if (!pgm_supported ()) { +        rc = pgm_init (&pgm_error); +        if (rc != TRUE) { +            if (pgm_error->domain == PGM_IF_ERROR && ( +                  pgm_error->code == PGM_IF_ERROR_INVAL || +                  pgm_error->code == PGM_IF_ERROR_XDEV || +                  pgm_error->code == PGM_IF_ERROR_NODEV || +                  pgm_error->code == PGM_IF_ERROR_NOTUNIQ || +                  pgm_error->code == PGM_IF_ERROR_ADDRFAMILY || +                  pgm_error->code == PGM_IF_ERROR_FAMILY || +                  pgm_error->code == PGM_IF_ERROR_NODATA || +                  pgm_error->code == PGM_IF_ERROR_NONAME || +                  pgm_error->code == PGM_IF_ERROR_SERVICE)) { +                errno = EINVAL; +	            g_error_free (pgm_error); +                return -1; +            } -        if (pgm_error->domain == PGM_IF_ERROR && ( -              pgm_error->code == PGM_IF_ERROR_INVAL || -              pgm_error->code == PGM_IF_ERROR_XDEV || -              pgm_error->code == PGM_IF_ERROR_NODEV || -              pgm_error->code == PGM_IF_ERROR_NOTUNIQ || -              pgm_error->code == PGM_IF_ERROR_ADDRFAMILY || -              pgm_error->code == PGM_IF_ERROR_FAMILY || -              pgm_error->code == PGM_IF_ERROR_NODATA || -              pgm_error->code == PGM_IF_ERROR_NONAME || -              pgm_error->code == PGM_IF_ERROR_SERVICE)) { -            errno = EINVAL; -	        g_error_free (pgm_error); -            return -1; +            zmq_assert (false);          } - -        zmq_assert (false);      }      //  PGM transport GSI. | 
