summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKlaus Schmidinger <vdr@tvdr.de>2018-04-28 12:17:22 +0200
committerKlaus Schmidinger <vdr@tvdr.de>2018-04-28 12:17:22 +0200
commit820a0ddb8a046c04833c667ecaf0148babe837bc (patch)
tree26833126c8523e7f19035fe50d3dded3f434510b
parentd84ec07ff67f259c17462f7aa7a5c489e5f05713 (diff)
downloadvdr-820a0ddb8a046c04833c667ecaf0148babe837bc.tar.gz
vdr-820a0ddb8a046c04833c667ecaf0148babe837bc.tar.bz2
Fixed a possible invalid locking sequence in case a remote timer handling error message is displayed on the OSD and the skin tries to lock the Recordings or DeletedRecordings list in its Flush() function
-rw-r--r--HISTORY9
-rw-r--r--menu.c4
-rw-r--r--skins.c10
-rw-r--r--vdr.c5
4 files changed, 21 insertions, 7 deletions
diff --git a/HISTORY b/HISTORY
index 4010cefc..06500b8e 100644
--- a/HISTORY
+++ b/HISTORY
@@ -9348,7 +9348,14 @@ Video Disk Recorder Revision History
Senzel).
- Official release.
-2018-04-19: Version 2.4.1
+2018-04-28: Version 2.4.1
- Fixed handling the tfRecording flag in the SVDRP commands MODT and UPDT (reported
by Johann Friedrichs).
+- Fixed a possible invalid locking sequence in case a remote timer handling error message
+ is displayed on the OSD and the skin tries to lock the Recordings or DeletedRecordings
+ list in its Flush() function (for instance by calling cVideoDiskUsage::HasChanged()).
+ To do this, the call to Skins.Message() in menu.c's HandleRemoteModifications() has
+ been changed to Skins.QueueMessage(), and cSkins::ProcessQueuedMessages() is now called
+ unconditionally in the main loop, and checks whether the current cSkinDisplay object
+ (if any) implements SetMessage().
diff --git a/menu.c b/menu.c
index c8a557c1..686806a0 100644
--- a/menu.c
+++ b/menu.c
@@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and
* how to reach the author.
*
- * $Id: menu.c 4.74 2018/04/14 10:24:41 kls Exp $
+ * $Id: menu.c 4.75 2018/04/28 12:09:45 kls Exp $
*/
#include "menu.h"
@@ -1075,7 +1075,7 @@ static bool HandleRemoteModifications(cTimer *NewTimer, cTimer *OldTimer = NULL)
{
cString ErrorMessage;
if (!HandleRemoteTimerModifications(NewTimer, OldTimer, &ErrorMessage)) {
- Skins.Message(mtError, ErrorMessage);
+ Skins.QueueMessage(mtError, ErrorMessage);
return false;
}
return true;
diff --git a/skins.c b/skins.c
index 8d00e8d4..b5c447b0 100644
--- a/skins.c
+++ b/skins.c
@@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and
* how to reach the author.
*
- * $Id: skins.c 3.1 2013/08/18 12:07:22 kls Exp $
+ * $Id: skins.c 4.1 2018/04/28 12:13:01 kls Exp $
*/
#include "skins.h"
@@ -352,6 +352,14 @@ void cSkins::ProcessQueuedMessages(void)
dsyslog("cSkins::ProcessQueuedMessages() called from background thread - ignored!");
return;
}
+ // Check whether there is a cSkinDisplay object (if any) that implements SetMessage():
+ if (cSkinDisplay *sd = cSkinDisplay::Current()) {
+ if (!(dynamic_cast<cSkinDisplayChannel *>(sd) ||
+ dynamic_cast<cSkinDisplayMenu *>(sd) ||
+ dynamic_cast<cSkinDisplayReplay *>(sd) ||
+ dynamic_cast<cSkinDisplayMessage *>(sd)))
+ return;
+ }
cSkinQueuedMessage *msg = NULL;
// Get the first waiting message:
queueMessageMutex.Lock();
diff --git a/vdr.c b/vdr.c
index 00f59c2a..502fd96b 100644
--- a/vdr.c
+++ b/vdr.c
@@ -22,7 +22,7 @@
*
* The project's page is at http://www.tvdr.de
*
- * $Id: vdr.c 4.25 2018/04/10 13:24:43 kls Exp $
+ * $Id: vdr.c 4.26 2018/04/28 11:27:48 kls Exp $
*/
#include <getopt.h>
@@ -1176,8 +1176,7 @@ int main(int argc, char *argv[])
if (!Menu && !cOsd::IsOpen())
Menu = CamControl();
// Queued messages:
- if (!Skins.IsOpen())
- Skins.ProcessQueuedMessages();
+ Skins.ProcessQueuedMessages();
// User Input:
cOsdObject *Interact = Menu ? Menu : cControl::Control();
eKeys key = Interface->GetKey(!Interact || !Interact->NeedsFastResponse());