diff options
| author | Matthias P. Braendli <matthias.braendli@mpb.li> | 2022-08-19 17:19:16 +0200 | 
|---|---|---|
| committer | Matthias P. Braendli <matthias.braendli@mpb.li> | 2022-08-19 17:19:16 +0200 | 
| commit | 8007dffae5fee4fcc81fcb5f888e0ee138db6e1e (patch) | |
| tree | f0ef8f06c046ce7242736078367000769b1fff4a /lib/edioutput/Transport.cpp | |
| parent | fe2c5e875e6410376f4dc2e9257b3beaf52d33e0 (diff) | |
| download | ODR-SourceCompanion-8007dffae5fee4fcc81fcb5f888e0ee138db6e1e.tar.gz ODR-SourceCompanion-8007dffae5fee4fcc81fcb5f888e0ee138db6e1e.tar.bz2 ODR-SourceCompanion-8007dffae5fee4fcc81fcb5f888e0ee138db6e1e.zip | |
Common c23bfcb, fe2a905, 036201c with socket changes
Diffstat (limited to 'lib/edioutput/Transport.cpp')
| -rw-r--r-- | lib/edioutput/Transport.cpp | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/lib/edioutput/Transport.cpp b/lib/edioutput/Transport.cpp index 5d34814..a870aa0 100644 --- a/lib/edioutput/Transport.cpp +++ b/lib/edioutput/Transport.cpp @@ -1,5 +1,5 @@  /* -   Copyright (C) 2020 +   Copyright (C) 2022     Matthias P. Braendli, matthias.braendli@mpb.li      http://www.opendigitalradio.org @@ -66,7 +66,7 @@ Sender::Sender(const configuration_t& conf) :      edi_pft(m_conf)  {      if (m_conf.verbose) { -        etiLog.log(info, "Setup EDI Output"); +        etiLog.level(info) << "Setup EDI Output, TCP output preroll " << m_conf.tcp_server_preroll_buffers;      }      for (const auto& edi_dest : m_conf.destinations) { @@ -81,7 +81,9 @@ Sender::Sender(const configuration_t& conf) :              udp_sockets.emplace(udp_dest.get(), udp_socket);          }          else if (auto tcp_dest = dynamic_pointer_cast<edi::tcp_server_t>(edi_dest)) { -            auto dispatcher = make_shared<Socket::TCPDataDispatcher>(tcp_dest->max_frames_queued); +            auto dispatcher = make_shared<Socket::TCPDataDispatcher>( +                    tcp_dest->max_frames_queued, m_conf.tcp_server_preroll_buffers); +              dispatcher->start(tcp_dest->listen_port, "0.0.0.0");              tcp_dispatchers.emplace(tcp_dest.get(), dispatcher);          } @@ -135,9 +137,10 @@ void Sender::write(const AFPacket& af_packet)          // Apply PFT layer to AF Packet (Reed Solomon FEC and Fragmentation)          vector<edi::PFTFragment> edi_fragments = edi_pft.Assemble(af_packet); -        if (m_conf.verbose) { -            fprintf(stderr, "EDI Output: Number of PFT fragments %zu\n", +        if (m_conf.verbose and m_last_num_pft_fragments != edi_fragments.size()) { +            etiLog.log(debug, "EDI Output: Number of PFT fragments %zu\n",                      edi_fragments.size()); +            m_last_num_pft_fragments = edi_fragments.size();          }          /* Spread out the transmission of all fragments over part of the 24ms AF packet duration | 
