mirror of https://gitee.com/openkylin/linux.git
tracing: Clean up alloc_synth_event()
alloc_synth_event() currently has the following code to initialize the event fields and dynamic_fields: for (i = 0, j = 0; i < n_fields; i++) { event->fields[i] = fields[i]; if (fields[i]->is_dynamic) { event->dynamic_fields[j] = fields[i]; event->dynamic_fields[j]->field_pos = i; event->dynamic_fields[j++] = fields[i]; event->n_dynamic_fields++; } } 1) It would make more sense to have all fields keep track of their field_pos. 2) event->dynmaic_fields[j] is assigned twice for no reason. 3) We can move updating event->n_dynamic_fields outside the loop, and just assign it to j. This combination makes the code much cleaner. Link: https://lkml.kernel.org/r/20210721195341.29bb0f77@oasis.local.home Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
This commit is contained in:
parent
1e3bac71c5
commit
9528c19507
|
@ -893,15 +893,13 @@ static struct synth_event *alloc_synth_event(const char *name, int n_fields,
|
||||||
dyn_event_init(&event->devent, &synth_event_ops);
|
dyn_event_init(&event->devent, &synth_event_ops);
|
||||||
|
|
||||||
for (i = 0, j = 0; i < n_fields; i++) {
|
for (i = 0, j = 0; i < n_fields; i++) {
|
||||||
|
fields[i]->field_pos = i;
|
||||||
event->fields[i] = fields[i];
|
event->fields[i] = fields[i];
|
||||||
|
|
||||||
if (fields[i]->is_dynamic) {
|
if (fields[i]->is_dynamic)
|
||||||
event->dynamic_fields[j] = fields[i];
|
|
||||||
event->dynamic_fields[j]->field_pos = i;
|
|
||||||
event->dynamic_fields[j++] = fields[i];
|
event->dynamic_fields[j++] = fields[i];
|
||||||
event->n_dynamic_fields++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
event->n_dynamic_fields = j;
|
||||||
event->n_fields = n_fields;
|
event->n_fields = n_fields;
|
||||||
out:
|
out:
|
||||||
return event;
|
return event;
|
||||||
|
|
Loading…
Reference in New Issue