[ltt-dev] [PATCH] LTTNG: hold markers_mutex during marker section iteration
Mathieu Desnoyers
mathieu.desnoyers at polymtl.ca
Mon Mar 23 12:54:20 EDT 2009
* Gui Jianfeng (guijianfeng at cn.fujitsu.com) wrote:
> Hold the markers_mutex during marker section iteration.
>
Will merge, thanks !
Mathieu
> Signed-off-by: Gui Jianfeng <guijianfeng at cn.fujitsu.com>
> ---
> kernel/marker.c | 2 ++
> ltt/ltt-trace-control.c | 12 ++++++++++++
> 2 files changed, 14 insertions(+), 0 deletions(-)
>
> diff --git a/kernel/marker.c b/kernel/marker.c
> index 7d11393..93ffa8e 100644
> --- a/kernel/marker.c
> +++ b/kernel/marker.c
> @@ -44,11 +44,13 @@ void lock_markers(void)
> {
> mutex_lock(&markers_mutex);
> }
> +EXPORT_SYMBOL_GPL(lock_markers);
>
> void unlock_markers(void)
> {
> mutex_unlock(&markers_mutex);
> }
> +EXPORT_SYMBOL_GPL(unlock_markers);
>
> /*
> * Marker hash table, containing the active markers.
> diff --git a/ltt/ltt-trace-control.c b/ltt/ltt-trace-control.c
> index c1c44c6..63cbb29 100644
> --- a/ltt/ltt-trace-control.c
> +++ b/ltt/ltt-trace-control.c
> @@ -846,6 +846,8 @@ static ssize_t marker_info_read(struct file *filp, char __user *ubuf,
> len = 0;
> buf = (char *)__get_free_page(GFP_KERNEL);
>
> + lock_markers();
> +
> marker_iter_reset(&iter);
> marker_iter_start(&iter);
> for (; iter.marker != NULL; marker_iter_next(&iter)) {
> @@ -872,6 +874,8 @@ static ssize_t marker_info_read(struct file *filp, char __user *ubuf,
> }
> marker_iter_stop(&iter);
>
> + unlock_markers();
> +
> if (len >= PAGE_SIZE) {
> len = PAGE_SIZE;
> buf[PAGE_SIZE] = '\0';
> @@ -958,6 +962,8 @@ static int build_marker_control_files(void)
> if (!markers_control_dir)
> return -EEXIST;
>
> + lock_markers();
> +
> marker_iter_reset(&iter);
> marker_iter_start(&iter);
> for (; iter.marker != NULL; marker_iter_next(&iter)) {
> @@ -966,6 +972,9 @@ static int build_marker_control_files(void)
> goto err_build_fail;
> }
> marker_iter_stop(&iter);
> +
> + unlock_markers();
> +
> return 0;
>
> err_build_fail:
> @@ -991,6 +1000,8 @@ static int remove_marker_control_dir(struct module *mod, struct marker *marker)
> return -ENOENT;
> name = marker_d->d_name.name;
>
> + lock_markers();
> +
> marker_iter_reset(&iter);
> marker_iter_start(&iter);
> for (; iter.marker != NULL; marker_iter_next(&iter)) {
> @@ -1008,6 +1019,7 @@ static int remove_marker_control_dir(struct module *mod, struct marker *marker)
>
> end:
> marker_iter_stop(&iter);
> + unlock_markers();
> return 0;
> }
>
> --
> 1.5.4.rc3
>
>
>
--
Mathieu Desnoyers
OpenPGP key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68
More information about the lttng-dev
mailing list