> So wie es ausschaut steckt der Fehler in vdr, nicht im Plugin.
in welcher der 9 neuen neuen Zeilen?
> So wie es ausschaut steckt der Fehler in vdr, nicht im Plugin.
in welcher der 9 neuen neuen Zeilen?
Weiß ich nicht, evtl poppt auch ein älterer Fehler in vdr auf.
Aber schau auf die Reihenfolge der letzten calls im backtrace, nicht im Plugin, sondern in VDR.
#5 0x00007ffff769c7c7 in malloc_printerr (str=str@entry=0x7ffff77b39f8 "malloc(): unaligned tcache chunk detected") at mall#6 0x00007ffff76a108c in tcache_get_n (ep=<optimized out>, tc_idx=<optimized out>) at malloc.c:3176
#7 tcache_get (tc_idx=<optimized out>) at malloc.c:3192
#8 __GI___libc_malloc (bytes=bytes@entry=10) at malloc.c:3313
#9 0x00007ffff7683648 in __vasprintf_internal
#10 0x000000000055ccab in cString::sprintf (fmt=fmt@entry=0x56d138 "%s (%s)") at tools.c:1178
#11 0x0000000000492b08 in cChannel::Name (this=this@entry=0x6fb1b0) at /usr/src/packages/BUILD/vdr-git-2.6.3/tools.h:189
#12 0x00007ffff7865e5f in cVNSIClient::processCHANNELS_GetChannels (this=0x7fffcc00a060, req=...) at vnsiclient.c:1181
Muss ja auch nicht an dem Patch liegen. Beim Durchlesen der Änderungen ist mir nur das free() ins Auge gesprungen. Dazu kam das zwei Plugins wegen der Änderung nicht mehr kompilieren wollten (was nicht an der Änderung sondern an den verwendeten Compiler-Parametern gelegen hat). Vielleicht ein Zufall, vielleicht bringt es irgendwen auf eine Idee. Und wenn nicht, dann halt Pech gehabt.
Baut das doch mal ein, und testet. Ich hätte jetzt nicht erwartet, dass jemand
a = a;
schreibt, aber man weiß ja nie ...
Könnte schon sein, dass es das ist.
~ Markus
Hier ist diese Absicherung auch drin: https://www.geeksforgeeks.org/…nment-operator-in-cpp-11/
Vielleicht gibt es auch irgendwelche "Sonderfälle" bei denen so eine Zuweisung stattfindet ohne das man so direkt "a = a" schreibt. Finde ich eh etwas bedenklich wie viel man über die interne Funktionsweise von C++ bescheid wissen muss um mit der Sprache keine Unfälle zu bauen.
Wenn man in diesen Edge-Case rennt, dann gibt man auf jeden Fall den internen Pointer frei. Ich hätte dann aber eher einen Crash wegen Zero-Pointer-Dereference erwartet.
Hier ist diese Absicherung auch drin: https://www.geeksforgeeks.org/…nment-operator-in-cpp-11/
Danke, das ist der eine Artikel, in dem ich es gesehen hatte.
Ich dachte, es war bei cppreference.com gewesen, da es dann natürlich nicht wieder finden...
Ich bin beim Suchen dann immer nur auf den Folgenden gestoßen :
learn.microsoft.com: Bewegungskonstruktoren und Bewegungszuweisungsoperatoren (C++)
Da wird sogar zwei mal explizit davor gewarnt.
Wann diese Selbstzuweisungen auftreten, würde mich auch mal interessieren.
Unter Umständen ist es aber gar nicht so selten.
Selbst was triviales wie a = a+x; könnte bei x == 0 ja theoretisch irgendwie dazu werden.
Ich mal den Patch #48 auf vdr-2.6.6 original angewandt, es crashed wie zuvor. Mit dem revert des Commit lt. #37
gibt es keinen crash.
Vielleicht ist folgende Beobachtung noch interessant:
Wenn nur 1 vnsi-client am vnsiserver connected ist crashed vdr selten
bei 2 vnsi-clienten erfolgt der crash häufig
bei 3 vnsi-cllenten efolgt der crash fast immer.
Die crashes gibt es beim umschalten eines Programms in den vnsi-clienten.
Je mehr Clients desto mehr parallel laufende Threads. Eventuell doch eine Race-Condition.
Ich werde dann wohl die Tage für Arch erstmal einen Patch einbauen der den Move-Operator wieder rausnimmt. Wenn ich damit wieder volle Plugin-Kompatibilität erhalte, ist es mir das erstmal wert. Ich will in Kürze für einen guten Freund einen neuen VDR-Server aufbauen und bei denen läuft praktisch alles mit (vielen) LibreElec-Clients. Stabile VNSI-Unterstützung ist da also absolute Voraussetzung.
Soll keine Kritik an der Änderung an sich sein. Egal wie viele Beispiele ich lese, mit dem letzten Vorschlag von SHF ist die Implementierung praktisch "wie aus dem Fachbuch". Aber ob das eine Race-Condition oder gar ein GCC-Bug ist, kann wohl auf die Schnelle auch keiner rausfinden. Bei Sprachen wie C++ ist man halt schnell auch an einem Punkt wo man Fehler im Assembly-Code suchen muss. Linus hat das wohl ein paarmal veranstaltet und den GCC-Entwicklern dann genau sagen können wo sie Bockmist gebaut haben.
Vielleicht nochmal ein unqualifizierter Einwurf aber nehmen wir an der Move Operator hat einen Einfluss (was ja wahrscheinlich ist). Kann man den mit wenig Aufwand so patchen das man geloggt bekommt in welcher Situation (Kontext) er aufgerufen wird?
Das gemeine daran ist, dass der dazu passende constructor genauso unvorhergesehen Effekte erzeugen kann.
Siehe das neue C++ keyword explizit.
Vielleicht nochmal ein unqualifizierter Einwurf aber nehmen wir an der Move Operator hat einen Einfluss (was ja wahrscheinlich ist). Kann man den mit wenig Aufwand so patchen das man geloggt bekommt in welcher Situation (Kontext) er aufgerufen wird?
Versuch doch mal:
cString &cString::operator=(cString &&String)
{
if (this == &String)
return *this;
esyslog("cString move, old string \"%s\", new string \"%s\"", s?s:"NULL", String.s?String.s:"NULL");
free(s);
s = String.s;
String.s = NULL;
return *this;
}
Möglicherweise reicht das ja
Ich habe das mal so eingebaut, leider passiert kein Crash mehr. Nur der Syslog wird mit den Meldungen vollgeschüttet.
was mich wundert sind solche Meldungen:
Feb 13 12:48:25 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:48:25 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Feb 13 12:48:35 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:48:36 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Feb 13 12:48:45 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:48:46 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Feb 13 12:48:55 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:48:56 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Feb 13 12:49:05 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:49:06 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Feb 13 12:49:16 vnas2.home.arpa vdr[9299]: [14337] cString move, old string "/dev/dvb/adapter0/frontend0", new string "/dev/dvb/adapter0/frontend0"
Feb 13 12:49:16 vnas2.home.arpa vdr[9299]: [14249] cString move, old string "/dev/dvb/adapter1/frontend0", new string "/dev/dvb/adapter1/frontend0"
Display More
Ich betreibe den vdr headless, es sind keine DVB Karten verbaut.
Ansonsten eine überwältigende Menge an Nachrichten des EPG Threads:
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "", new string "32,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,", new string "32,48,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,", new string "32,48,255,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,", new string "32,48,255,259,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,", new string "32,48,255,259,264,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,", new string "32,48,255,259,264,265,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,", new string "32,48,255,259,264,265,6604,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,", new string "32,48,255,259,264,265,6604,6860,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,", new string "32,48,255,259,264,265,6604,6860,7116,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,7116,", new string "32,48,255,259,264,265,6604,6860,7116,7372,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,7116,7372,", new string "32,48,255,259,264,265,6604,6860,7116,7372,7884,"
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,7116,7372,7884,", new string "32,48,255,259,264,265,6604,6860,7116,7372,7884,8>
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,7116,7372,7884,8140,", new string "32,48,255,259,264,265,6604,6860,7116,7372,7>
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "32,48,255,259,264,265,6604,6860,7116,7372,7884,8140,8141,", new string "32,48,255,259,264,265,6604,6860,7116,7>
Feb 13 12:49:53 vnas2.home.arpa vdr[9299]: [9307] cString move, old string "rtsp://192.168.20.245/stream=2", new string "rtsp://192.168.20.245/stream=2?delpids=32,48,255,259,264,265,6604>
Display More
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [13874] cString move, old string "TV Mainfranken HD (S19.2E)", new string "TV Mainfranken HD (S19.2E)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [13874] cString move, old string "TV Mainfranken HD (S19.2E)", new string "TV Mainfranken HD (S19.2E)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [13874] cString move, old string "Franken Fernsehen HD (S19.2E)", new string "Franken Fernsehen HD (S19.2E)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "caids:6200;2446;6224;", new string "caids:6200;2446;6224;6248;"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "caids:6200;2446;6224;6248;", new string "caids:6200;2446;6224;6248;6228;"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "caids:6200;2446;6224;6248;6228;", new string "caids:6200;2446;6224;6248;6228;6213;"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "ZDFinfo HD (C)", new string "ZDFinfo HD (C)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "ZDFinfo HD (C)", new string "ZDFinfo HD (C)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "zdf_neo HD (C)", new string "zdf_neo HD (C)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "zdf_neo HD (C)", new string "zdf_neo HD (C)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "ProSieben (C)", new string "ProSieben (C)"
Feb 13 12:47:38 vnas2.home.arpa vdr[9299]: [10766] cString move, old string "ProSieben (C)", new string "ProSieben (C)"
Display More
Es scheint durchaus eine Race Situation zu geben, da diese Flut von Meldungen das Timing so verändern, das der Chrash nicht auftritt.
Vielleicht macht es Sinn, nur dann eine Log-Meldung auszugeben, wenn this == &String ist, um zu sehen, ob der Fall überhaupt auftritt, und wenn ja, mit welchem String.
Don’t have an account yet? Register yourself now and be a part of our community!