libosmocore / logging from within libraries
Konrad Meier
meierk at informatik.uni-freiburg.de
Mon Jun 27 13:32:58 CEST 2011
27.06.2011 11:00, schrieb Harald Welte:
> Hi!
>
> As more and more code is moving into libraries (like I just did with the
> LAPDm code, and like pablo is working on with libosmo-abis), we needed a
> solution how to allocate and use the LOGP subsystem constants like DRSL,
> DRR, ... from within libraries.
>
> The existing logging code wasn't really prepared for that. I've now
> come um with a hack to extend it while preserving compatibility to
> applications:
>
> * we use negative numbers starting from -1 for library-internal
> subsystems
> * those numbers get converted to a positive index into the various
> arrays at run-time. So -1 ends up one entry higher in the array
> than the last application-providede log category/subsystem.
>
> As part of this change, the array allocations are now dynamic, i.e there
> is no maximum limit for the number of log categories that an application
> can register with the core.
>
> Only for libraries (even outside libosmocore), we have compile-time
> registration, i.e. the 'struct log_info_cat' and the D* constant need to
> be defined inside libosmocore. I think this is an acceptable
> compromise.
>
> Furthermore, if LOGP()/DEBUGP() ever see a subsystem number that it
> doesn't know, it will assign it to the new 'DLGLOBAL' (Debug Library
> GLOBAL) category, i.e. there cna be no array overflows.
>
> This ensures that even an external library using a 'newer' D* constant
> will not crash or otherwise fail, it will simply log in a slightly
> different way.
>
> Regards,
> Harald
Hi Harald,
Quick fix for openbsc:
index 6800021..fb5ce7a 100644
--- a/openbsc/tests/debug/debug_test.c
+++ b/openbsc/tests/debug/debug_test.c
@@ -25,7 +25,7 @@ int main(int argc, char **argv)
{
struct log_target *stderr_target;
- log_init(&log_info);
+ log_init(&log_info, NULL);
stderr_target = log_target_create_stderr();
log_add_target(stderr_target);
log_set_all_filter(stderr_target, 1);
Regards Konrad
More information about the baseband-devel
mailing list