X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=rts%2FTrace.c;h=fb8e9226afb4473b5dfe1d44ca10bcbe19b046ac;hp=f2f9e815498b66d3422047366b31307a93e810c0;hb=58532eb46041aec8d4cbb48b054cb5b001edb43c;hpb=58339b06aff704834e8553faaa2db00d746b26f3 diff --git a/rts/Trace.c b/rts/Trace.c index f2f9e81..fb8e922 100644 --- a/rts/Trace.c +++ b/rts/Trace.c @@ -20,6 +20,10 @@ #include "Threads.h" #include "Printer.h" +#ifdef HAVE_UNISTD_H +#include +#endif + #ifdef DEBUG // debugging flags, set with +RTS -D int DEBUG_sched; @@ -251,6 +255,69 @@ void traceSchedEvent_ (Capability *cap, EventTypeNum tag, } } +void traceCapsetModify_ (EventTypeNum tag, + CapsetID capset, + StgWord32 other, + StgWord32 other2) +{ +#ifdef DEBUG + if (RtsFlags.TraceFlags.tracing == TRACE_STDERR) { + ACQUIRE_LOCK(&trace_utx); + + tracePreface(); + switch (tag) { + case EVENT_CAPSET_CREATE: // (capset, capset_type) + debugBelch("created capset %d of type %d\n", capset, other); + break; + case EVENT_CAPSET_DELETE: // (capset) + debugBelch("deleted capset %d\n", capset); + break; + case EVENT_CAPSET_ASSIGN_CAP: // (capset, capno) + debugBelch("assigned cap %d to capset %d\n", other, capset); + break; + case EVENT_CAPSET_REMOVE_CAP: // (capset, capno) + debugBelch("removed cap %d from capset %d\n", other, capset); + break; + } + RELEASE_LOCK(&trace_utx); + } else +#endif + { + if(eventlog_enabled) postCapsetModifyEvent(tag, capset, other, other2); + } +} + +extern char **environ; + +void traceCapsetDetails_(int *argc, char **argv[]){ + if(eventlog_enabled){ + postCapsetModifyEvent(EVENT_OSPROCESS_PID, + CAPSET_OSPROCESS_DEFAULT, + getpid(), + getppid()); + + char buf[256]; + snprintf(buf, sizeof(buf), "GHC-%s %s", ProjectVersion, RtsWay); + postCapsetStrEvent(EVENT_RTS_IDENTIFIER, + CAPSET_OSPROCESS_DEFAULT, + buf); + + if(argc != NULL && argv != NULL){ + postCapsetVecEvent(EVENT_PROGRAM_ARGS, + CAPSET_OSPROCESS_DEFAULT, + *argc, + *argv); + } + + int env_len; + for( env_len = 0; environ[env_len] != NULL; env_len++); + postCapsetVecEvent(EVENT_PROGRAM_ENV, + CAPSET_OSPROCESS_DEFAULT, + env_len, + environ); + } +} + void traceEvent_ (Capability *cap, EventTypeNum tag) { #ifdef DEBUG