Now unassigning CAMs from their devices when they are no longer used

This commit is contained in:
Klaus Schmidinger 2014-01-18 14:30:58 +01:00
parent 35d4ceaf37
commit 6f9929b1c0
2 changed files with 9 additions and 4 deletions

View File

@ -8132,7 +8132,7 @@ Video Disk Recorder Revision History
and also to use the correct directory with --edit (the latter reported by Marko and also to use the correct directory with --edit (the latter reported by Marko
Mäkelä). Mäkelä).
2014-01-17: Version 2.1.4 2014-01-18: Version 2.1.4
- Updated 'sources.conf' (thanks to Antti Hartikainen). - Updated 'sources.conf' (thanks to Antti Hartikainen).
- cFont::CreateFont() now returns a dummy font in case there are no fonts installed. - cFont::CreateFont() now returns a dummy font in case there are no fonts installed.
@ -8154,3 +8154,4 @@ Video Disk Recorder Revision History
in cDvbDevice have been removed to avoid redundancy. in cDvbDevice have been removed to avoid redundancy.
- Fixed detecting frame borders in MPEG-2 streams that have "bottom fields" or varying - Fixed detecting frame borders in MPEG-2 streams that have "bottom fields" or varying
GOP structures (reported by Christian Paulick, with help from Helmut Auer). GOP structures (reported by Christian Paulick, with help from Helmut Auer).
- Now unassigning CAMs from their devices when they are no longer used.

View File

@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and * See the main source file 'vdr.c' for copyright information and
* how to reach the author. * how to reach the author.
* *
* $Id: device.c 3.8 2014/01/14 11:58:49 kls Exp $ * $Id: device.c 3.9 2014/01/18 14:26:06 kls Exp $
*/ */
#include "device.h" #include "device.h"
@ -1697,8 +1697,12 @@ void cDevice::Detach(cReceiver *Receiver)
else if (receiver[i]) else if (receiver[i])
receiversLeft = true; receiversLeft = true;
} }
if (camSlot && Receiver->priority > MINPRIORITY) // priority check to avoid an infinite loop with the CAM slot's caPidReceiver if (camSlot) {
camSlot->StartDecrypting(); if (Receiver->priority > MINPRIORITY) // priority check to avoid an infinite loop with the CAM slot's caPidReceiver
camSlot->StartDecrypting();
if (!camSlot->IsDecrypting())
camSlot->Assign(NULL);
}
if (!receiversLeft) if (!receiversLeft)
Cancel(-1); Cancel(-1);
} }