gentoo-ebuilds/media-plugins/vdr-vcd/files/vdr-vcd-0.9_Control.patch
Martin Dummer f10a6dcb44
media-plugins/vdr-vcd: fix usage of cControl::Control()
introduce subslot dependency on media-video/vdr

Closes: https://bugs.gentoo.org/963496
Signed-off-by: Martin Dummer <martin.dummer@gmx.net>
Part-of: https://github.com/gentoo/gentoo/pull/43960
Signed-off-by: Sam James <sam@gentoo.org>
2025-10-03 01:42:30 +01:00

56 lines
2.1 KiB
Diff

diff '--color=auto' -Naur vcd-0.9.orig/menucontrol.c vcd-0.9/menucontrol.c
--- vcd-0.9.orig/menucontrol.c 2025-09-27 15:32:52.262205083 +0200
+++ vcd-0.9/menucontrol.c 2025-09-27 15:39:34.901524119 +0200
@@ -56,7 +56,8 @@
void cMenuSpiControl::SetItem(int Spi, cVcd *Vcd)
{
- cControl *control = cControl::Control();
+ cMutexLock MutexLock;
+ cControl *control = cControl::Control(MutexLock);
if (control && typeid(*control)==typeid(cMenuVcdControl))
static_cast<cMenuVcdControl*>(control)->Stop();
if (control && typeid(*control)==typeid(cMenuSpiControl)
@@ -146,7 +147,8 @@
void cMenuVcdControl::SetTrack(int Track, cVcd *Vcd)
{
- cControl *control = cControl::Control();
+ cMutexLock MutexLock;
+ cControl *control = cControl::Control(MutexLock);
if (control && typeid(*control)==typeid(cMenuSpiControl))
static_cast<cMenuSpiControl*>(control)->Stop();
if (control && typeid(*control)==typeid(cMenuVcdControl) &&
diff '--color=auto' -Naur vcd-0.9.orig/psdcontrol.c vcd-0.9/psdcontrol.c
--- vcd-0.9.orig/psdcontrol.c 2025-09-27 15:43:52.708831004 +0200
+++ vcd-0.9/psdcontrol.c 2025-09-27 15:47:19.216149801 +0200
@@ -100,7 +100,8 @@
void cPsdSpiControl::SetItem(int Spi, cVcd *Vcd, union psd_vcd *PsdVcd)
{
- cControl *control = cControl::Control();
+ cMutexLock MutexLock;
+ cControl *control = cControl::Control(MutexLock);
if (control && typeid(*control)==typeid(cPsdVcdControl))
static_cast<cPsdVcdControl*>(control)->Stop();
@@ -262,7 +263,8 @@
void cPsdVcdControl::SetTrack(int Track, cVcd *Vcd, union psd_vcd *PsdVcd)
{
- cControl *control = cControl::Control();
+ cMutexLock MutexLock;
+ cControl *control = cControl::Control(MutexLock);
if (control && typeid(*control)==typeid(cPsdSpiControl))
static_cast<cPsdSpiControl*>(control)->Stop();
@@ -298,7 +300,8 @@
void cPsdVcdControl::SetEntry(int Entry, cVcd *Vcd, union psd_vcd *PsdVcd)
{
- cControl *control = cControl::Control();
+ cMutexLock MutexLock;
+ cControl *control = cControl::Control(MutexLock);
if (control && typeid(*control)==typeid(cPsdSpiControl))
static_cast<cPsdSpiControl*>(control)->Stop();