2009-06-10 20 views
5

Necesito obtener la información de pila de mi aplicación C en ciertos puntos. He leído la documentación y buscado en la red, pero todavía no puedo entender cómo puedo hacerlo. ¿Puedes señalar una explicación simple del proceso? O, mejor aún, a un ejemplo de desenrollado de la pila. Lo necesito para HP-UX (Itanium) y Linux.Desenrollado de pila en HP-UX y Linux

Respuesta

4

Salida Linux/stacktrace.h

Aquí es una referencia de la API:

http://www.cs.cmu.edu/afs/cs/Web/People/tekkotsu/dox/StackTrace_8h.html

debería funcionar en todos los núcleos de Linux

Aquí es un ejemplo alternativo en C de

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)); 

} 
+0

No sabía que existía API; ¡Qué util! – Jamie

+0

No lo ayuda con HP-UX;) – DaveR

+0

@dave, nit-picker: P –

3

Usted quiere mirar libunwind - esto es una biblioteca multiplataforma desarrollada originalmente por HP para desenrollar seguimientos de pila Itanium (que son particularmente complejas); pero posteriormente se ha expandido a muchas otras plataformas; incluyendo tanto x86-Linux como Itanium-HPUX.

De la página de comando man libunwind (3); aquí es un ejemplo del uso libunwind escribir una función típica 'espectáculo traza inversa': trabajo

#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); 
    } 
} 
Cuestiones relacionadas