tracing/filter: Remove synchronize_sched() from __alloc_preds()
authorSteven Rostedt <srostedt@redhat.com>
Fri, 4 Feb 2011 04:29:06 +0000 (23:29 -0500)
committerSteven Rostedt <rostedt@goodmis.org>
Tue, 8 Feb 2011 01:56:20 +0000 (20:56 -0500)
Because the filters are processed first and then activated
(added to the call), we no longer need to worry about the preds
of the filter in __alloc_preds() being used. As the filter that
is allocating preds is not activated yet.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/trace_events_filter.c

index f5d335d28d0ba29441295f94e5d1e17462b2b1ec..3249b4f77ef083fdec2a5bba0a52c3f17a482b23 100644 (file)
@@ -795,33 +795,17 @@ static int __alloc_preds(struct event_filter *filter, int n_preds)
        struct filter_pred *pred;
        int i;
 
-       if (filter->preds) {
-               if (filter->a_preds < n_preds) {
-                       /*
-                        * We need to reallocate.
-                        * We should have already have zeroed out
-                        * the pred count and called synchronized_sched()
-                        * to make sure no one is using the preds.
-                        */
-                       if (WARN_ON_ONCE(filter->n_preds)) {
-                               /* We need to reset it now */
-                               filter->n_preds = 0;
-                               synchronize_sched();
-                       }
-                       __free_preds(filter);
-               }
-       }
+       if (filter->preds)
+               __free_preds(filter);
+
+       filter->preds =
+               kzalloc(sizeof(*filter->preds) * n_preds, GFP_KERNEL);
 
-       if (!filter->preds) {
-               filter->preds =
-                       kzalloc(sizeof(*filter->preds) * n_preds, GFP_KERNEL);
-               filter->a_preds = n_preds;
-       }
        if (!filter->preds)
                return -ENOMEM;
 
-       if (WARN_ON(filter->a_preds < n_preds))
-               return -EINVAL;
+       filter->a_preds = n_preds;
+       filter->n_preds = 0;
 
        for (i = 0; i < n_preds; i++) {
                pred = &filter->preds[i];