diff options
author | David 'Digit' Turner <digit@google.com> | 2010-01-20 12:36:51 -0800 |
---|---|---|
committer | David 'Digit' Turner <digit@google.com> | 2010-02-11 10:46:48 -0800 |
commit | 5c734644eebf8d01be1e86cbe20a111a5c5a2738 (patch) | |
tree | 5e442dc0157ec487f51a65f85f87fe2bd66fd0cf /linker/linker_debug.h | |
parent | e100f52f4ad1b70762bbcc5ad9828bd258917ee5 (diff) | |
download | bionic-5c734644eebf8d01be1e86cbe20a111a5c5a2738.zip bionic-5c734644eebf8d01be1e86cbe20a111a5c5a2738.tar.gz bionic-5c734644eebf8d01be1e86cbe20a111a5c5a2738.tar.bz2 |
Fix debug output in the dynamic linker.
This provides a mini-printf implementation that reduces the
size of the dynamic linker by 25 KB, by preventing the drag of
formatting-related routines from the C library.
Also allow traces to be sent to the log, instead of stdout.
NOTE: You now need to modify Android.mk to enable/disable debug
output.
Diffstat (limited to 'linker/linker_debug.h')
-rw-r--r-- | linker/linker_debug.h | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/linker/linker_debug.h b/linker/linker_debug.h index 3f4fc4c..3f08303 100644 --- a/linker/linker_debug.h +++ b/linker/linker_debug.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2008 The Android Open Source Project + * Copyright (C) 2008-2010 The Android Open Source Project * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -31,12 +31,17 @@ #include <stdio.h> -/* WARNING: For linker debugging only.. Be careful not to leave any of - * this on when submitting back to repository */ -#define LINKER_DEBUG 0 -#define TRACE_DEBUG 0 -#define DO_TRACE_LOOKUP 0 -#define DO_TRACE_RELO 0 +#ifndef LINKER_DEBUG +#error LINKER_DEBUG should be defined to either 1 or 0 in Android.mk +#endif + +/* set LINKER_DEBUG_TO_LOG to 1 to send the logs to logcat, + * or 0 to use stdout instead. + */ +#define LINKER_DEBUG_TO_LOG 1 +#define TRACE_DEBUG 1 +#define DO_TRACE_LOOKUP 1 +#define DO_TRACE_RELO 1 #define TIMING 0 #define STATS 0 #define COUNT_PAGES 0 @@ -59,12 +64,21 @@ * corruption when the linker uses printf(). */ #if LINKER_DEBUG +#include "linker_format.h" extern int debug_verbosity; -#warning "*** LINKER IS USING printf(); DO NOT CHECK THIS IN ***" -#define _PRINTVF(v,f,x...) \ - do { \ - (debug_verbosity > (v)) && (printf(x), ((f) && fflush(stdout))); \ +#if LINKER_DEBUG_TO_LOG +extern int format_log(int, const char *, const char *, ...); +#define _PRINTVF(v,f,x...) \ + do { \ + if (debug_verbosity > (v)) format_log(5-(v),"linker",x); \ + } while (0) +#else /* !LINKER_DEBUG_TO_LOG */ +extern int format_fd(int, const char *, ...); +#define _PRINTVF(v,f,x...) \ + do { \ + if (debug_verbosity > (v)) format_fd(1, x); \ } while (0) +#endif /* !LINKER_DEBUG_TO_LOG */ #else /* !LINKER_DEBUG */ #define _PRINTVF(v,f,x...) do {} while(0) #endif /* LINKER_DEBUG */ |