- fix: close source/dst after pvr playback
authorFelix Domke <tmbinc@elitedvb.net>
Sat, 30 Jul 2005 02:03:06 +0000 (02:03 +0000)
committerFelix Domke <tmbinc@elitedvb.net>
Sat, 30 Jul 2005 02:03:06 +0000 (02:03 +0000)
lib/dvb/dvb.cpp
lib/dvb/dvb.h

index d98aa2a81e861245751ef9f8bbea2aac9f1c7094..4f5ecf2e022105156da238d96b76797c5ebb424a 100644 (file)
@@ -382,6 +382,8 @@ eDVBChannel::~eDVBChannel()
        if (m_pvr_thread)
        {
                m_pvr_thread->stop();
+               ::close(m_pvr_fd_src);
+               ::close(m_pvr_fd_dst);
                delete m_pvr_thread;
        }
 }
@@ -520,18 +522,18 @@ RESULT eDVBChannel::playFile(const char *file)
        
        
                /* (this codepath needs to be improved anyway.) */
-       int dest = open("/dev/misc/pvr", O_WRONLY);
-       if (dest < 0)
+       m_pvr_fd_dst = open("/dev/misc/pvr", O_WRONLY);
+       if (m_pvr_fd_dst < 0)
        {
                eDebug("can't open /dev/misc/pvr - you need to buy the new(!) $$$ box! (%m)");
                return -ENODEV;
        }
        
-       int source = open(file, O_RDONLY);
-       if (source < 0)
+       m_pvr_fd_src = open(file, O_RDONLY);
+       if (m_pvr_fd_src < 0)
        {
-               eDebug("can't open PVR source file %s (%m)", file);
-               close(dest);
+               eDebug("can't open PVR m_pvr_fd_src file %s (%m)", file);
+               close(m_pvr_fd_dst);
                return -ENOENT;
        }
 
@@ -539,5 +541,5 @@ RESULT eDVBChannel::playFile(const char *file)
        m_stateChanged(this);
        
        m_pvr_thread = new eFilePushThread();
-       m_pvr_thread->start(source, dest);
+       m_pvr_thread->start(m_pvr_fd_src, m_pvr_fd_dst);
 }
index 0e1c8af53a4729ccef59e0d2d523ab9887ee4055..d9f049eb9aebe0452e05b087d1f24370571d3814 100644 (file)
@@ -188,6 +188,7 @@ private:
        
                /* for PVR playback */
        eFilePushThread *m_pvr_thread;
+       int m_pvr_fd_src, m_pvr_fd_dst;
 
        friend class eUsePtr<eDVBChannel>;
                /* use count */