diff options
Diffstat (limited to 'libs')
-rw-r--r-- | libs/utils/Trace.cpp | 22 | ||||
-rw-r--r-- | libs/utils/misc.cpp | 60 |
2 files changed, 77 insertions, 5 deletions
diff --git a/libs/utils/Trace.cpp b/libs/utils/Trace.cpp index f3ec485..5cd5731 100644 --- a/libs/utils/Trace.cpp +++ b/libs/utils/Trace.cpp @@ -19,6 +19,7 @@ #include <cutils/properties.h> #include <utils/Log.h> #include <utils/Trace.h> +#include <utils/misc.h> namespace android { @@ -27,10 +28,19 @@ int Tracer::sTraceFD = -1; uint64_t Tracer::sEnabledTags = 0; Mutex Tracer::sMutex; +void Tracer::changeCallback() { + Mutex::Autolock lock(sMutex); + if (sIsReady && sTraceFD >= 0) { + loadSystemProperty(); + } +} + void Tracer::init() { Mutex::Autolock lock(sMutex); if (!sIsReady) { + add_sysprop_change_callback(changeCallback, 0); + const char* const traceFileName = "/sys/kernel/debug/tracing/trace_marker"; sTraceFD = open(traceFileName, O_WRONLY); @@ -38,14 +48,18 @@ void Tracer::init() { ALOGE("error opening trace file: %s (%d)", strerror(errno), errno); // sEnabledTags remains zero indicating that no tracing can occur } else { - char value[PROPERTY_VALUE_MAX]; - property_get("debug.atrace.tags.enableflags", value, "0"); - sEnabledTags = (strtoll(value, NULL, 0) & ATRACE_TAG_VALID_MASK) - | ATRACE_TAG_ALWAYS; + loadSystemProperty(); } android_atomic_release_store(1, &sIsReady); } } +void Tracer::loadSystemProperty() { + char value[PROPERTY_VALUE_MAX]; + property_get("debug.atrace.tags.enableflags", value, "0"); + sEnabledTags = (strtoll(value, NULL, 0) & ATRACE_TAG_VALID_MASK) + | ATRACE_TAG_ALWAYS; +} + } // namespace andoid diff --git a/libs/utils/misc.cpp b/libs/utils/misc.cpp index dc89d15..b3c99e6 100644 --- a/libs/utils/misc.cpp +++ b/libs/utils/misc.cpp @@ -14,10 +14,13 @@ * limitations under the License. */ +#define LOG_TAG "misc" + // // Miscellaneous utility functions. // #include <utils/misc.h> +#include <utils/Log.h> #include <sys/stat.h> #include <string.h> @@ -25,6 +28,12 @@ #include <assert.h> #include <stdio.h> +#if defined(HAVE_PTHREADS) +# include <pthread.h> +#endif + +#include <utils/Vector.h> + using namespace android; namespace android { @@ -181,5 +190,54 @@ unsigned int roundUpPower2(unsigned int val) return val; } -}; // namespace android +struct sysprop_change_callback_info { + sysprop_change_callback callback; + int priority; +}; + +#if defined(HAVE_PTHREADS) +static pthread_mutex_t gSyspropMutex = PTHREAD_MUTEX_INITIALIZER; +static Vector<sysprop_change_callback_info>* gSyspropList = NULL; +#endif + +void add_sysprop_change_callback(sysprop_change_callback cb, int priority) { +#if defined(HAVE_PTHREADS) + pthread_mutex_lock(&gSyspropMutex); + if (gSyspropList == NULL) { + gSyspropList = new Vector<sysprop_change_callback_info>(); + } + sysprop_change_callback_info info; + info.callback = cb; + info.priority = priority; + bool added = false; + for (size_t i=0; i<gSyspropList->size(); i++) { + if (priority >= gSyspropList->itemAt(i).priority) { + gSyspropList->insertAt(info, i); + added = true; + break; + } + } + if (!added) { + gSyspropList->add(info); + } + pthread_mutex_unlock(&gSyspropMutex); +#endif +} + +void report_sysprop_change() { +#if defined(HAVE_PTHREADS) + pthread_mutex_lock(&gSyspropMutex); + Vector<sysprop_change_callback_info> listeners; + if (gSyspropList != NULL) { + listeners = *gSyspropList; + } + pthread_mutex_unlock(&gSyspropMutex); + //ALOGI("Reporting sysprop change to %d listeners", listeners.size()); + for (size_t i=0; i<listeners.size(); i++) { + listeners[i].callback(); + } +#endif +} + +}; // namespace android |