mirror of
				https://github.com/vdr-projects/vdr.git
				synced 2025-03-01 10:50:46 +00:00 
			
		
		
		
	Improved handling present/following data for VPS timers
This commit is contained in:
		| @@ -2567,6 +2567,7 @@ Markus Ehrnsperger <markus.ehrnsperger@googlemail.com> | ||||
|  for adding a 15 second grace period before actually stopping a VPS timer | ||||
|  for making the primary device no longer start unnecessary threads if it doesn't have | ||||
|  a decoder | ||||
|  for improving handling present/following data for VPS timers | ||||
|  | ||||
| Werner F<>rber <w.faerber@gmx.de> | ||||
|  for reporting a bug in handling the cPluginManager::Active() result when pressing | ||||
|   | ||||
							
								
								
									
										3
									
								
								HISTORY
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								HISTORY
									
									
									
									
									
								
							| @@ -9887,7 +9887,7 @@ Video Disk Recorder Revision History | ||||
| - Fixed possible duplicate component entries in the info of an ongoing recording | ||||
|   (reported by Christoph Haubrich). | ||||
|  | ||||
| 2024-03-04: | ||||
| 2024-03-06: | ||||
|  | ||||
| - Fixed the move assignment operator to check for self-assignment (suggested by | ||||
|   Stefan Herdler). | ||||
| @@ -9905,3 +9905,4 @@ Video Disk Recorder Revision History | ||||
| - Updated the Hungarian OSD texts (thanks to Istv<74>n F<>ley). | ||||
| - The new setup parameters "EPG scan max. channel number" and "EPG pause after scan" | ||||
|   can be used to tune the behavior of the EPG scan (see MANUAL for details). | ||||
| - Improved handling present/following data for VPS timers (thanks to Markus Ehrnsperger). | ||||
|   | ||||
							
								
								
									
										23
									
								
								timers.c
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								timers.c
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ | ||||
|  * See the main source file 'vdr.c' for copyright information and | ||||
|  * how to reach the author. | ||||
|  * | ||||
|  * $Id: timers.c 5.19 2024/03/03 15:47:09 kls Exp $ | ||||
|  * $Id: timers.c 5.20 2024/03/06 14:37:15 kls Exp $ | ||||
|  */ | ||||
|  | ||||
| #include "timers.h" | ||||
| @@ -50,6 +50,7 @@ cTimer::cTimer(bool Instant, bool Pause, const cChannel *Channel) | ||||
|   start = now->tm_hour * 100 + now->tm_min; | ||||
|   stop = 0; | ||||
|   vpsNotRunning = 0; | ||||
|   vpsActive = false; | ||||
|   if (!Setup.InstantRecordTime && channel && (Instant || Pause)) { | ||||
|      LOCK_SCHEDULES_READ; | ||||
|      if (const cSchedule *Schedule = Schedules->GetSchedule(channel)) { | ||||
| @@ -190,6 +191,7 @@ cTimer::cTimer(const cEvent *Event, const char *FileName, const cTimer *PatternT | ||||
|   remote = NULL; | ||||
|   event = NULL; | ||||
|   vpsNotRunning = 0; | ||||
|   vpsActive = false; | ||||
|   if (!PatternTimer || PatternTimer->HasFlags(tfVps)) { | ||||
|      if (Event->Vps() && (PatternTimer || Setup.UseVps)) | ||||
|         SetFlags(tfVps); | ||||
| @@ -260,6 +262,7 @@ cTimer& cTimer::operator= (const cTimer &Timer) | ||||
|      priority     = Timer.priority; | ||||
|      lifetime     = Timer.lifetime; | ||||
|      vpsNotRunning = 0; | ||||
|      vpsActive    = false; | ||||
|      strncpy(pattern, Timer.pattern, sizeof(pattern)); | ||||
|      strncpy(file, Timer.file, sizeof(file)); | ||||
|      free(aux); | ||||
| @@ -561,6 +564,7 @@ void cTimer::SetFile(const char *File) | ||||
| } | ||||
|  | ||||
| #define EITPRESENTFOLLOWINGRATE 10 // max. seconds between two occurrences of the "EIT present/following table for the actual multiplex" (2s by the standard, using some more for safety) | ||||
| #define EITPRESENTFOLLOWINGGRACE 60 // max. seconds before reporting a loss of VPS control of an ongoing recording | ||||
|  | ||||
| bool cTimer::Matches(time_t t, bool Directly, int Margin) const | ||||
| { | ||||
| @@ -617,6 +621,11 @@ bool cTimer::Matches(time_t t, bool Directly, int Margin) const | ||||
|                  stopTime = event->EndTime(); | ||||
|                  if (!Margin) { // this is an actual check | ||||
|                     if (event->Schedule()->PresentSeenWithin(EITPRESENTFOLLOWINGRATE)) { // VPS control can only work with up-to-date events... | ||||
|                        if (!vpsActive) { | ||||
|                           vpsActive = true; | ||||
|                           if (Recording()) | ||||
|                              dsyslog("timer %s regained VPS control", *ToDescr()); | ||||
|                           } | ||||
|                        bool running = event->IsRunning(true); | ||||
|                        if (!running) { | ||||
|                           if (Recording() && vpsNotRunning == 0) | ||||
| @@ -626,7 +635,17 @@ bool cTimer::Matches(time_t t, bool Directly, int Margin) const | ||||
|                           vpsNotRunning = 0; | ||||
|                        return running || time(NULL) < vpsNotRunning + VPSGRACE; | ||||
|                        } | ||||
|                     // ...otherwise we fall back to normal timer handling below (note: Margin == 0!) | ||||
|                     if (Recording()) { | ||||
|                        if (event->Schedule()->PresentSeenWithin(EITPRESENTFOLLOWINGGRACE)) | ||||
|                           return event->IsRunning(true); // give it a chance to recover - worst case: the recording will be 60 seconds too long | ||||
|                        if (vpsActive) { | ||||
|                           vpsActive = false; | ||||
|                           esyslog("ERROR: timer %s lost VPS control", *ToDescr()); | ||||
|                           } | ||||
|                        // ...otherwise we fall back to normal timer handling below (note: Margin == 0!) | ||||
|                        } | ||||
|                     else | ||||
|                        return false; // relying on vdr.c to ensure that a transponder is tuned to this channel | ||||
|                     } | ||||
|                  } | ||||
|               } | ||||
|   | ||||
							
								
								
									
										3
									
								
								timers.h
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								timers.h
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ | ||||
|  * See the main source file 'vdr.c' for copyright information and | ||||
|  * how to reach the author. | ||||
|  * | ||||
|  * $Id: timers.h 5.10 2024/03/03 15:47:09 kls Exp $ | ||||
|  * $Id: timers.h 5.11 2024/03/06 14:37:15 kls Exp $ | ||||
|  */ | ||||
|  | ||||
| #ifndef __TIMERS_H | ||||
| @@ -38,6 +38,7 @@ private: | ||||
|   int scheduleStateAdjust; | ||||
|   mutable time_t deferred; ///< Matches(time_t, ...) will return false if the current time is before this value | ||||
|   mutable time_t vpsNotRunning; ///< the time when a VPS event's running status changed to "not running" | ||||
|   mutable bool vpsActive; ///< true if this is a VPS timer and the event is current | ||||
|   bool pending, inVpsMargin; | ||||
|   uint flags; | ||||
|   const cChannel *channel; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user