diff options
author | Frank Schmirler <vdr@schmirler.de> | 2010-12-02 09:43:13 +0100 |
---|---|---|
committer | Frank Schmirler <vdr@schmirler.de> | 2010-12-02 09:43:13 +0100 |
commit | 7254a6752808830d5fc133e5362da6c47f3f84ff (patch) | |
tree | 673cc17f88ba80f8a67debb54f85ea100cde9ae5 /server/streamer.c | |
parent | 31df0eaf8e49bc1cfea755bd88f3dd795c8f1ace (diff) | |
download | vdr-plugin-streamdev-7254a6752808830d5fc133e5362da6c47f3f84ff.tar.gz vdr-plugin-streamdev-7254a6752808830d5fc133e5362da6c47f3f84ff.tar.bz2 |
Snapshot 2009-06-11
Diffstat (limited to 'server/streamer.c')
-rw-r--r-- | server/streamer.c | 45 |
1 files changed, 28 insertions, 17 deletions
diff --git a/server/streamer.c b/server/streamer.c index 979032a..9795cc6 100644 --- a/server/streamer.c +++ b/server/streamer.c @@ -1,5 +1,5 @@ /* - * $Id: streamer.c,v 1.16 2007/09/21 11:45:53 schmirl Exp $ + * $Id: streamer.c,v 1.18 2009/02/13 10:39:22 schmirl Exp $ */ #include <vdr/ringbuffer.h> @@ -20,16 +20,15 @@ cStreamdevWriter::cStreamdevWriter(cTBSocket *Socket, cStreamdevStreamer *Streamer): cThread("streamdev-writer"), m_Streamer(Streamer), - m_Socket(Socket), - m_Active(false) + m_Socket(Socket) { } cStreamdevWriter::~cStreamdevWriter() { Dprintf("destructing writer\n"); - m_Active = false; - Cancel(3); + if (Running()) + Cancel(3); } void cStreamdevWriter::Action(void) @@ -39,11 +38,10 @@ void cStreamdevWriter::Action(void) int max = 0; uchar *block = NULL; int count, offset = 0; - m_Active = true; sel.Clear(); sel.Add(*m_Socket, true); - while (m_Active) { + while (Running()) { if (block == NULL) { block = m_Streamer->Get(count); offset = 0; @@ -57,23 +55,39 @@ void cStreamdevWriter::Action(void) if (sel.CanWrite(*m_Socket)) { int written; - if ((written = m_Socket->Write(block + offset, count)) == -1) { - esyslog("ERROR: streamdev-server: couldn't send data: %m"); + int pkgsize = count; + // SOCK_DGRAM indicates multicast + if (m_Socket->Type() == SOCK_DGRAM) { + // don't fragment multicast packets + // max. payload on standard local ethernet is 1416 to 1456 bytes + // and some STBs expect complete TS packets + // so let's always limit to 7 * TS_SIZE = 1316 + if (pkgsize > 7 * TS_SIZE) + pkgsize = 7 * TS_SIZE; + else + pkgsize -= pkgsize % TS_SIZE; + } + if ((written = m_Socket->Write(block + offset, pkgsize)) == -1) { + esyslog("ERROR: streamdev-server: couldn't send %d bytes: %m", pkgsize); break; } + + // statistics if (count > max) max = count; offset += written; count -= written; - if (count == 0) { + + // less than one TS packet left: + // delete what we've written so far and get next chunk + if (count < TS_SIZE) { m_Streamer->Del(offset); block = NULL; } } } } - m_Active = false; Dprintf("Max. Transmit Blocksize was: %d\n", max); } @@ -81,7 +95,6 @@ void cStreamdevWriter::Action(void) cStreamdevStreamer::cStreamdevStreamer(const char *Name): cThread(Name), - m_Active(false), m_Running(false), m_Writer(NULL), m_RingBuffer(new cRingBufferLinear(STREAMERBUFSIZE, TS_SIZE * 2, @@ -109,7 +122,7 @@ void cStreamdevStreamer::Start(cTBSocket *Socket) void cStreamdevStreamer::Activate(bool On) { - if (On && !m_Active) { + if (On && !Active()) { Dprintf("activate streamer\n"); m_Writer->Start(); cThread::Start(); @@ -118,9 +131,8 @@ void cStreamdevStreamer::Activate(bool On) void cStreamdevStreamer::Stop(void) { - if (m_Active) { + if (Running()) { Dprintf("stopping streamer\n"); - m_Active = false; Cancel(3); } if (m_Running) { @@ -132,8 +144,7 @@ void cStreamdevStreamer::Stop(void) void cStreamdevStreamer::Action(void) { - m_Active = true; - while (m_Active) { + while (Running()) { int got; uchar *block = m_RingBuffer->Get(got); |