diff options
| author | Ingo Molnar <mingo@kernel.org> | 2015-09-23 03:42:11 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2015-09-23 03:42:11 -0400 |
| commit | b5727270ecd807f75a8d5d1450cec39495fc794a (patch) | |
| tree | b40753b713a39f41179bd0b48668f363814664fd /tools/lib/traceevent | |
| parent | 96f3eda67fcf2598e9d2794398e0e7ab35138ea6 (diff) | |
| parent | d0d0313c2ae4bc220c4ed96ce340860a4e74a2e9 (diff) | |
Merge branch 'perf/urgent' into perf/core to pick up fixes before pulling new changes
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/lib/traceevent')
| -rw-r--r-- | tools/lib/traceevent/event-parse.c | 23 |
1 files changed, 20 insertions, 3 deletions
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c index 12447978a921..9aa107a0ce8c 100644 --- a/tools/lib/traceevent/event-parse.c +++ b/tools/lib/traceevent/event-parse.c | |||
| @@ -3847,7 +3847,7 @@ static void print_str_arg(struct trace_seq *s, void *data, int size, | |||
| 3847 | struct format_field *field; | 3847 | struct format_field *field; |
| 3848 | struct printk_map *printk; | 3848 | struct printk_map *printk; |
| 3849 | long long val, fval; | 3849 | long long val, fval; |
| 3850 | unsigned long addr; | 3850 | unsigned long long addr; |
| 3851 | char *str; | 3851 | char *str; |
| 3852 | unsigned char *hex; | 3852 | unsigned char *hex; |
| 3853 | int print; | 3853 | int print; |
| @@ -3880,13 +3880,30 @@ static void print_str_arg(struct trace_seq *s, void *data, int size, | |||
| 3880 | */ | 3880 | */ |
| 3881 | if (!(field->flags & FIELD_IS_ARRAY) && | 3881 | if (!(field->flags & FIELD_IS_ARRAY) && |
| 3882 | field->size == pevent->long_size) { | 3882 | field->size == pevent->long_size) { |
| 3883 | addr = *(unsigned long *)(data + field->offset); | 3883 | |
| 3884 | /* Handle heterogeneous recording and processing | ||
| 3885 | * architectures | ||
| 3886 | * | ||
| 3887 | * CASE I: | ||
| 3888 | * Traces recorded on 32-bit devices (32-bit | ||
| 3889 | * addressing) and processed on 64-bit devices: | ||
| 3890 | * In this case, only 32 bits should be read. | ||
| 3891 | * | ||
| 3892 | * CASE II: | ||
| 3893 | * Traces recorded on 64 bit devices and processed | ||
| 3894 | * on 32-bit devices: | ||
| 3895 | * In this case, 64 bits must be read. | ||
| 3896 | */ | ||
| 3897 | addr = (pevent->long_size == 8) ? | ||
| 3898 | *(unsigned long long *)(data + field->offset) : | ||
| 3899 | (unsigned long long)*(unsigned int *)(data + field->offset); | ||
| 3900 | |||
| 3884 | /* Check if it matches a print format */ | 3901 | /* Check if it matches a print format */ |
| 3885 | printk = find_printk(pevent, addr); | 3902 | printk = find_printk(pevent, addr); |
| 3886 | if (printk) | 3903 | if (printk) |
| 3887 | trace_seq_puts(s, printk->printk); | 3904 | trace_seq_puts(s, printk->printk); |
| 3888 | else | 3905 | else |
| 3889 | trace_seq_printf(s, "%lx", addr); | 3906 | trace_seq_printf(s, "%llx", addr); |
| 3890 | break; | 3907 | break; |
| 3891 | } | 3908 | } |
| 3892 | str = malloc(len + 1); | 3909 | str = malloc(len + 1); |
