X-Git-Url: http://git.efficios.com/?p=lttng-tools.git;a=blobdiff_plain;f=tests%2Fregression%2Ftools%2Fhealth%2Fhealth_exit.c;h=8a99326444e3687bed27ec997159f3dd1e76043a;hp=55cff4611726124c990a264a2cbc3d2cd5ff2742;hb=a33d2d4ae3b4bd640b5f535b4213e6606e7d0ddd;hpb=1fb2388876f2db46d5c253b9c00cda0990a5f762 diff --git a/tests/regression/tools/health/health_exit.c b/tests/regression/tools/health/health_exit.c index 55cff4611..8a9932644 100644 --- a/tests/regression/tools/health/health_exit.c +++ b/tests/regression/tools/health/health_exit.c @@ -1,5 +1,6 @@ /* * Copyright (C) 2012 - Christian Babeux + * Copyright (C) 2014 - Mathieu Desnoyers * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License, version 2 only, as @@ -24,6 +25,7 @@ * Check if the specified environment variable is set. * Return 1 if set, otherwise 0. */ +static int check_env_var(const char *env) { if (env) { @@ -36,6 +38,8 @@ int check_env_var(const char *env) return 0; } +/* Session daemon */ + int __testpoint_sessiond_thread_manage_clients(void) { const char *var = "LTTNG_SESSIOND_THREAD_MANAGE_CLIENTS_EXIT"; @@ -92,3 +96,169 @@ int __testpoint_sessiond_thread_manage_consumer(void) return 0; } + +int __testpoint_sessiond_thread_ht_cleanup(void) +{ + const char *var = "LTTNG_SESSIOND_THREAD_HT_CLEANUP_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_sessiond_thread_app_manage_notify(void) +{ + const char *var = "LTTNG_SESSIOND_THREAD_APP_MANAGE_NOTIFY_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_sessiond_thread_app_reg_dispatch(void) +{ + const char *var = "LTTNG_SESSIOND_THREAD_APP_REG_DISPATCH_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +} + +/* Consumer daemon */ + +int __testpoint_consumerd_thread_channel(void) +{ + const char *var = "LTTNG_CONSUMERD_THREAD_CHANNEL_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_consumerd_thread_metadata(void) +{ + const char *var = "LTTNG_CONSUMERD_THREAD_METADATA_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_consumerd_thread_data(void) +{ + const char *var = "LTTNG_CONSUMERD_THREAD_DATA_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_consumerd_thread_sessiond(void) +{ + const char *var = "LTTNG_CONSUMERD_THREAD_SESSIOND_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_consumerd_thread_metadata_timer(void) +{ + const char *var = "LTTNG_CONSUMERD_THREAD_METADATA_TIMER_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +} + +/* Relay daemon */ + +int __testpoint_relayd_thread_dispatcher(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_DISPATCHER_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_relayd_thread_worker(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_WORKER_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_relayd_thread_listener(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_LISTENER_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_relayd_thread_live_dispatcher(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_LIVE_DISPATCHER_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_relayd_thread_live_worker(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_LIVE_WORKER_EXIT"; + + if (check_env_var(var)) { + rcu_unregister_thread(); + pthread_exit(NULL); + } + + return 0; +} + +int __testpoint_relayd_thread_live_listener(void) +{ + const char *var = "LTTNG_RELAYD_THREAD_LIVE_LISTENER_EXIT"; + + if (check_env_var(var)) { + pthread_exit(NULL); + } + + return 0; +}