Hallo zusammen, in einem Embedded-Linux Projekt verwende ich die Listen-Implementierung aus der STL/C++-Standard-Library. Bis jetzt hatte ich das Projekt jedoch immer nur für den PC kompiliert und hatte keinerlei Probleme. Nun habe ich das Projekt für den ARM kompiliert, was noch problemlos ging. Nun entsteht jedoch eine "Segmentation-Violation", wenn auf eine Liste zugegiffen wird. Die Liste ist als Klassen-Member im protected-Bereich folgendermaßen deklariert "std::list<void *> foo;" Greife ich nun z.B. mit "i32Size = foo.size();" auf die Liste zu, "kracht" es. Wenn ich mit dem Debugger in die Listenimplementierung "hineinsteppe" sehe ich, dass der Fehler an folgendem Punkt auftritt: "_M_node = _M_node->_M_next;". Das Problem ist, dass _M_node 0 ist, somit ist es klar, dass es hier beim Dereferenzieren schiefgehen muss... Wie gesagt, auf dem PC unter Suse 10.1 läuft derselbe Code einwandfrei. Es scheint, dass bei der Initialisierung der Liste etwas schiefgeht, das ist aber leider gar nich so leicht zu debuggen.. Kleinere Testprogramme, die auch die Liste verwenden, funktionieren übrigens auf dem PC und dem ARM einwandfrei. Es scheint also nicht an der Liste selbst zu liegen, sondern evtl. an einer Kombination, oder muss ich spezielle Compiler-Switches verwenden? Hat jemand schon Erfahrungen mit C++ und Embedded-Linux auf dem ARM gesammelt und weiß Rat? gcc-Version (sowohl PC, als auch ARM): 4.1.0
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.