X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fbacktrace.c;h=c6829d77c19bda1feef4cec6ad8f58ae40266145;hb=d978fa4832bbc5176e05edd05bcdf2452a8dded2;hp=0999a081ecb351e9e0c530b43010cadc7c4dcf10;hpb=34e63086edddcae06d7c1a4fa84fec0861e50758;p=sliver-openvswitch.git diff --git a/lib/backtrace.c b/lib/backtrace.c index 0999a081e..c6829d77c 100644 --- a/lib/backtrace.c +++ b/lib/backtrace.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2010, 2011 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -15,17 +15,34 @@ */ #include + #include "backtrace.h" + #include #include #include #include -#include "compiler.h" -#define THIS_MODULE VLM_backtrace +#include "compiler.h" #include "vlog.h" -static uintptr_t UNUSED +VLOG_DEFINE_THIS_MODULE(backtrace); + +#ifdef HAVE_BACKTRACE +#include +void +backtrace_capture(struct backtrace *b) +{ + void *frames[BACKTRACE_MAX_FRAMES]; + int i; + + b->n_frames = backtrace(frames, BACKTRACE_MAX_FRAMES); + for (i = 0; i < b->n_frames; i++) { + b->frames[i] = (uintptr_t) frames[i]; + } +} +#elif __GNUC__ +static uintptr_t get_max_stack(void) { static const char file_name[] = "/proc/self/maps"; @@ -42,7 +59,7 @@ get_max_stack(void) for (line_number = 1; fgets(line, sizeof line, f); line_number++) { if (strstr(line, "[stack]")) { uintptr_t end; - if (sscanf(line, "%*"SCNxPTR"-%"SCNxPTR, &end) != 1) { + if (sscanf(line, "%*x-%"SCNxPTR, &end) != 1) { VLOG_WARN("%s:%d: parse error", file_name, line_number); continue; } @@ -69,16 +86,8 @@ stack_high(void) static uintptr_t stack_low(void) { -#ifdef __i386__ - uintptr_t low; - asm("movl %%esp,%0" : "=g" (low)); + uintptr_t low = (uintptr_t) &low; return low; -#else - /* This causes a warning in GCC that cannot be disabled, so use it only on - * non-x86. */ - int dummy; - return (uintptr_t) &dummy; -#endif } static bool @@ -104,3 +113,10 @@ backtrace_capture(struct backtrace *backtrace) } backtrace->n_frames = n; } +#else /* !HAVE_BACKTRACE && !__GNUC__ */ +void +backtrace_capture(struct backtrace *backtrace) +{ + backtrace->n_frames = 0; +} +#endif