diff options
author | Klaus Schmidinger <vdr@tvdr.de> | 2007-04-30 09:40:34 +0200 |
---|---|---|
committer | Klaus Schmidinger <vdr@tvdr.de> | 2007-04-30 09:40:34 +0200 |
commit | fcbb206fdf4d0c5bda73cfd6c12a421c426ee428 (patch) | |
tree | 80a6d373c93a745c5193e043a59d28b936adb9ca | |
parent | f935c03c792ddf5f2aac6522bfa1597ac5507ca6 (diff) | |
download | vdr-fcbb206fdf4d0c5bda73cfd6c12a421c426ee428.tar.gz vdr-fcbb206fdf4d0c5bda73cfd6c12a421c426ee428.tar.bz2 |
Non-primary devices in Transfer mode are now also used for recording
-rw-r--r-- | CONTRIBUTORS | 1 | ||||
-rw-r--r-- | HISTORY | 2 | ||||
-rw-r--r-- | device.c | 4 |
3 files changed, 5 insertions, 2 deletions
diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 1f9c1420..a232f790 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -2018,6 +2018,7 @@ Anssi Hannula <anssi.hannula@gmail.com> receiving and doesn't require detatching receivers for improving handling Transfer Mode devices when selecting a device to receive for fixing handling frequencies in NitFilter::Process() + for making non-primary devices in Transfer mode be also used for recording Antti Hartikainen <ami+vdr@ah.fi> for updating 'S13E' in 'sources.conf' @@ -5180,3 +5180,5 @@ Video Disk Recorder Revision History - Fixed handling frequencies in NitFilter::Process() (thanks to Anssi Hannula). - Fixed a race condition with signal handlers at program exit (thanks to Udo Richter). +- Non-primary devices in Transfer mode are now also used for recording (thanks + to Anssi Hannula). @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: device.c 1.139 2007/01/13 12:05:00 kls Exp $ + * $Id: device.c 1.140 2007/04/30 09:34:00 kls Exp $ */ #include "device.h" @@ -327,7 +327,7 @@ cDevice *cDevice::GetDevice(const cChannel *Channel, int Priority, bool LiveView // difference, because it results in the most significant bit of the result. uint32_t imp = 0; imp <<= 1; imp |= LiveView ? !device[i]->IsPrimaryDevice() || ndr : 0; // prefer the primary device for live viewing if we don't need to detach existing receivers - imp <<= 1; imp |= !device[i]->Receiving() || ndr; // use receiving devices if we don't need to detach existing receivers + imp <<= 1; imp |= !device[i]->Receiving() && (device[i] != cTransferControl::ReceiverDevice() || device[i]->IsPrimaryDevice()) || ndr; // use receiving devices if we don't need to detach existing receivers, but avoid primary device in local transfer mode imp <<= 1; imp |= device[i]->Receiving(); // avoid devices that are receiving imp <<= 1; imp |= device[i] == cTransferControl::ReceiverDevice(); // avoid the Transfer Mode receiver device imp <<= 8; imp |= min(max(device[i]->Priority() + MAXPRIORITY, 0), 0xFF); // use the device with the lowest priority (+MAXPRIORITY to assure that values -99..99 can be used) |