use 'id3demux'/'mad' for decoding mp3files instead of decodebin
[enigma2.git] / main / bsod.cpp
index 2248d01c4e9caf32bfa4e80fd4a40010db405f7c..b273eacf61729593b844e4dc465adbf438027e2b 100644 (file)
@@ -86,6 +86,10 @@ void bsodFatal()
                std::string buffer = getLogBuffer();
                fwrite(buffer.c_str(), buffer.size(), 1, f);
                fclose(f);
+               
+               char cmd[256];
+               sprintf(cmd, "find /usr/lib/enigma2/python/ -name \"*.py\" | xargs md5sum >> %s", logfile);
+               system(cmd);
        }
        
        ePtr<gFBDC> my_dc;
@@ -143,14 +147,20 @@ void bsodFatal()
 void oops(const mcontext_t &context, int dumpcode)
 {
        eDebug("PC: %08lx, vaddr: %08lx", (unsigned long)context.pc, (unsigned long)context.badvaddr);
-       
+       int i;
+       for (i=0; i<32; ++i)
+       {
+               eDebugNoNewLine(" %08x", (int)context.gregs[i]);
+               if ((i&3) == 3)
+                       eDebug("");
+       }
                /* this is temporary debug stuff. */
        if (dumpcode && ((unsigned long)context.pc) > 0x10000) /* not a zero pointer */
        {
                eDebug("As a final action, i will try to dump a bit of code.");
                eDebug("I just hope that this won't crash.");
                int i;
-               eDebugNoNewLine("%08x:", (unsigned long)context.pc);
+               eDebugNoNewLine("%08lx:", (unsigned long)context.pc);
                for (i=0; i<0x20; ++i)
                        eDebugNoNewLine(" %02x", ((unsigned char*)context.pc)[i]);
                eDebug(" (end)");
@@ -158,7 +168,6 @@ void oops(const mcontext_t &context, int dumpcode)
 }
 #else
 #warning "no oops support!"
-#error bla
 #define NO_OOPS_SUPPORT
 #endif
 
@@ -167,7 +176,7 @@ void handleFatalSignal(int signum, siginfo_t *si, void *ctx)
        ucontext_t *uc = (ucontext_t*)ctx;
        eDebug("KILLED BY signal %d", signum);
 #ifndef NO_OOPS_SUPPORT
-       oops(uc->uc_mcontext, signum == SIGSEGV);
+       oops(uc->uc_mcontext, signum == SIGSEGV || signum == SIGABRT);
 #endif
        eDebug("-------");
        bsodFatal();
@@ -186,6 +195,7 @@ void bsodCatchSignals()
        sigaction(SIGSEGV, &act, 0);
        sigaction(SIGILL, &act, 0);
        sigaction(SIGBUS, &act, 0);
+       sigaction(SIGABRT, &act, 0);
 }
 
 void bsodLogInit()