mirror of
https://github.com/tobast/libunwind-eh_elf.git
synced 2025-01-25 17:50:29 +01:00
(Debug): New macro. This one automates some of usual stuff that
gets printed during debugging and is supposed to produce a nicer format. Eventually, we'll switch everything over from debug() to Debug(). (extract_dynamic_proc_info): We need both generic and local-only. (dyn_remote_find_proc_info): Likewise. (dyn_remote_put_unwind_info): Likewise. (Logical change 1.142)
This commit is contained in:
parent
dcd705f1a4
commit
7d3de049e6
1 changed files with 33 additions and 20 deletions
|
@ -90,8 +90,21 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||||
|
|
||||||
#if UNW_DEBUG
|
#if UNW_DEBUG
|
||||||
# include <stdio.h>
|
# include <stdio.h>
|
||||||
# define debug(level,format...) \
|
# define debug(level,format...) \
|
||||||
do { if (tdep_debug_level > level) fprintf (stderr, format); } while (0)
|
do { \
|
||||||
|
if (tdep_debug_level > level) fprintf (stderr, format); \
|
||||||
|
} while (0)
|
||||||
|
# define Debug(level,format...) \
|
||||||
|
do { \
|
||||||
|
if (tdep_debug_level > level) \
|
||||||
|
{ \
|
||||||
|
int _n = level; \
|
||||||
|
if (_n > 16) \
|
||||||
|
_n = 16; \
|
||||||
|
fprintf (stderr, "%*c>%s: ", _n, ' ', __FUNCTION__); \
|
||||||
|
fprintf (stderr, format); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
# define dprintf(format...) \
|
# define dprintf(format...) \
|
||||||
fprintf (stderr, format)
|
fprintf (stderr, format)
|
||||||
# ifdef __GNUC__
|
# ifdef __GNUC__
|
||||||
|
@ -152,23 +165,23 @@ extern int UNWI_OBJ(find_dynamic_proc_info) (unw_addr_space_t as,
|
||||||
unw_word_t ip,
|
unw_word_t ip,
|
||||||
unw_proc_info_t *pi,
|
unw_proc_info_t *pi,
|
||||||
int need_unwind_info, void *arg);
|
int need_unwind_info, void *arg);
|
||||||
extern int UNWI_ARCH_OBJ(extract_dynamic_proc_info) (unw_addr_space_t as,
|
extern int UNWI_OBJ(extract_dynamic_proc_info) (unw_addr_space_t as,
|
||||||
unw_word_t ip,
|
unw_word_t ip,
|
||||||
unw_proc_info_t *pi,
|
unw_proc_info_t *pi,
|
||||||
unw_dyn_info_t *di,
|
unw_dyn_info_t *di,
|
||||||
int need_unwind_info,
|
int need_unwind_info,
|
||||||
void *arg);
|
void *arg);
|
||||||
extern void UNWI_OBJ(put_dynamic_unwind_info) (unw_addr_space_t as,
|
extern void UNWI_OBJ(put_dynamic_unwind_info) (unw_addr_space_t as,
|
||||||
unw_proc_info_t *pi, void *arg);
|
unw_proc_info_t *pi, void *arg);
|
||||||
extern int UNWI_ARCH_OBJ(dyn_remote_find_proc_info) (unw_addr_space_t as,
|
extern int UNWI_OBJ(dyn_remote_find_proc_info) (unw_addr_space_t as,
|
||||||
unw_word_t ip,
|
unw_word_t ip,
|
||||||
unw_proc_info_t *pi,
|
unw_proc_info_t *pi,
|
||||||
unw_word_t *generation,
|
unw_word_t *generation,
|
||||||
int need_unwind_info,
|
int need_unwind_info,
|
||||||
void *arg);
|
void *arg);
|
||||||
extern void UNWI_ARCH_OBJ(dyn_remote_put_unwind_info) (unw_addr_space_t as,
|
extern void UNWI_OBJ(dyn_remote_put_unwind_info) (unw_addr_space_t as,
|
||||||
unw_proc_info_t *pi,
|
unw_proc_info_t *pi,
|
||||||
void *arg);
|
void *arg);
|
||||||
extern int UNWI_OBJ(get_proc_name) (unw_addr_space_t as, unw_word_t ip,
|
extern int UNWI_OBJ(get_proc_name) (unw_addr_space_t as, unw_word_t ip,
|
||||||
char *buf, size_t buf_len,
|
char *buf, size_t buf_len,
|
||||||
unw_word_t *offp, void *arg);
|
unw_word_t *offp, void *arg);
|
||||||
|
@ -177,7 +190,7 @@ extern int UNWI_OBJ(get_proc_name) (unw_addr_space_t as, unw_word_t ip,
|
||||||
UNWI_OBJ(find_dynamic_proc_info)(as, ip, pi, n, arg)
|
UNWI_OBJ(find_dynamic_proc_info)(as, ip, pi, n, arg)
|
||||||
|
|
||||||
#define unwi_extract_dynamic_proc_info(as,ip,pi,di,n,arg) \
|
#define unwi_extract_dynamic_proc_info(as,ip,pi,di,n,arg) \
|
||||||
UNWI_ARCH_OBJ(extract_dynamic_proc_info)(as, ip, pi, di, n, arg)
|
UNWI_OBJ(extract_dynamic_proc_info)(as, ip, pi, di, n, arg)
|
||||||
|
|
||||||
#define unwi_put_dynamic_unwind_info(as,pi,arg) \
|
#define unwi_put_dynamic_unwind_info(as,pi,arg) \
|
||||||
UNWI_OBJ(put_dynamic_unwind_info)(as, pi, arg)
|
UNWI_OBJ(put_dynamic_unwind_info)(as, pi, arg)
|
||||||
|
@ -186,10 +199,10 @@ extern int UNWI_OBJ(get_proc_name) (unw_addr_space_t as, unw_word_t ip,
|
||||||
dynamic unwind info. */
|
dynamic unwind info. */
|
||||||
|
|
||||||
#define unwi_dyn_remote_find_proc_info(as,i,p,g,n,arg) \
|
#define unwi_dyn_remote_find_proc_info(as,i,p,g,n,arg) \
|
||||||
UNWI_ARCH_OBJ(dyn_remote_find_proc_info)(as, i, p, g, n, arg)
|
UNWI_OBJ(dyn_remote_find_proc_info)(as, i, p, g, n, arg)
|
||||||
|
|
||||||
#define unwi_dyn_remote_put_unwind_info(as,p,arg) \
|
#define unwi_dyn_remote_put_unwind_info(as,p,arg) \
|
||||||
UNWI_ARCH_OBJ(dyn_remote_put_unwind_info)(as, p, arg)
|
UNWI_OBJ(dyn_remote_put_unwind_info)(as, p, arg)
|
||||||
|
|
||||||
#define unwi_get_proc_name(as,ip,b,s,o,arg) \
|
#define unwi_get_proc_name(as,ip,b,s,o,arg) \
|
||||||
UNWI_OBJ(get_proc_name)(as, ip, b, s, o, arg)
|
UNWI_OBJ(get_proc_name)(as, ip, b, s, o, arg)
|
||||||
|
|
Loading…
Reference in a new issue