Domanda

Ho bisogno di ottenere le informazioni pila di mia applicazione C in alcuni punti. Ho letto la documentazione e cercato la rete, ma ancora non riesco a capire come posso farlo. Si può puntare a una semplice spiegazione processo? O, meglio ancora, ad un esempio di stack di svolgimento. Ne ho bisogno per HP-UX (Itanium) e Linux.

È stato utile?

Soluzione

Scopri linux / stacktrace.h

Ecco un riferimento API:

http: //www.cs .cmu.edu / AFS / cs / Web / Persone / tekkotsu / DOX / StackTrace_8h.html

dovrebbe funzionare su tutti i kernel Linux

Ecco un esempio alternativo in C da

http://www.linuxjournal.com/article/6391

#include <stdio.h>
#include <signal.h>
#include <execinfo.h>

void show_stackframe() {
  void *trace[16];
  char **messages = (char **)NULL;
  int i, trace_size = 0;

  trace_size = backtrace(trace, 16);
  messages = backtrace_symbols(trace, trace_size);
  printf("[bt] Execution path:\n");
  for (i=0; i<trace_size; ++i)
    printf("[bt] %s\n", messages[i]);
}


int func_low(int p1, int p2) {

  p1 = p1 - p2;
  show_stackframe();

  return 2*p1;
}

int func_high(int p1, int p2) {

  p1 = p1 + p2;
  show_stackframe();

  return 2*p1;
}


int test(int p1) {
  int res;

  if (p1<10)
    res = 5+func_low(p1, 2*p1);
  else
    res = 5+func_high(p1, 2*p1);
  return res;
}



int main() {

  printf("First call: %d\n\n", test(27));
  printf("Second call: %d\n", test(4));

}

Altri suggerimenti

Si desidera guardare libunwind - questa è una libreria multipiattaforma sviluppato originariamente da HP per tracce di svolgimento pila Itanium (che sono particolarmente complessi); ma è stato successivamente esteso a molte altre piattaforme; includendo sia x86 Linux e Itanium-HPUX.

Dalla (3) pagina man libunwind; ecco un esempio di utilizzo libunwind per scrivere un tipica funzione 'mostra backtrace':

#define UNW_LOCAL_ONLY
#include <libunwind.h>

void show_backtrace (void) {
  unw_cursor_t cursor; unw_context_t uc;
  unw_word_t ip, sp;

  unw_getcontext(&uc);
  unw_init_local(&cursor, &uc);
  while (unw_step(&cursor) > 0) {
    unw_get_reg(&cursor, UNW_REG_IP, &ip);
    unw_get_reg(&cursor, UNW_REG_SP, &sp);
    printf ("ip = %lx, sp = %lx\n", (long) ip, (long) sp);
  }
}

Questo lavoro shoulw per HPUX Itanium: http://docs.hp.com/en/B9106-90012/ unwind.5.html

Per la semplice analisi dello stack, provare U_STACK_TRACE ().

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top