diff options
Diffstat (limited to 'kernel/trace/trace_functions_graph.c')
| -rw-r--r-- | kernel/trace/trace_functions_graph.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/kernel/trace/trace_functions_graph.c b/kernel/trace/trace_functions_graph.c index 79f4bac99a94..6f233698518e 100644 --- a/kernel/trace/trace_functions_graph.c +++ b/kernel/trace/trace_functions_graph.c | |||
| @@ -507,7 +507,15 @@ get_return_for_leaf(struct trace_iterator *iter, | |||
| 507 | * if the output fails. | 507 | * if the output fails. |
| 508 | */ | 508 | */ |
| 509 | data->ent = *curr; | 509 | data->ent = *curr; |
| 510 | data->ret = *next; | 510 | /* |
| 511 | * If the next event is not a return type, then | ||
| 512 | * we only care about what type it is. Otherwise we can | ||
| 513 | * safely copy the entire event. | ||
| 514 | */ | ||
| 515 | if (next->ent.type == TRACE_GRAPH_RET) | ||
| 516 | data->ret = *next; | ||
| 517 | else | ||
| 518 | data->ret.ent.type = next->ent.type; | ||
| 511 | } | 519 | } |
| 512 | } | 520 | } |
| 513 | 521 | ||
| @@ -641,7 +649,8 @@ trace_print_graph_duration(unsigned long long duration, struct trace_seq *s) | |||
| 641 | 649 | ||
| 642 | /* Print nsecs (we don't want to exceed 7 numbers) */ | 650 | /* Print nsecs (we don't want to exceed 7 numbers) */ |
| 643 | if (len < 7) { | 651 | if (len < 7) { |
| 644 | snprintf(nsecs_str, 8 - len, "%03lu", nsecs_rem); | 652 | snprintf(nsecs_str, min(sizeof(nsecs_str), 8UL - len), "%03lu", |
| 653 | nsecs_rem); | ||
| 645 | ret = trace_seq_printf(s, ".%s", nsecs_str); | 654 | ret = trace_seq_printf(s, ".%s", nsecs_str); |
| 646 | if (!ret) | 655 | if (!ret) |
| 647 | return TRACE_TYPE_PARTIAL_LINE; | 656 | return TRACE_TYPE_PARTIAL_LINE; |
