diff options
| -rw-r--r-- | tools/lib/traceevent/event-parse.c | 23 | ||||
| -rw-r--r-- | tools/perf/util/session.c | 5 |
2 files changed, 24 insertions, 4 deletions
diff --git a/tools/lib/traceevent/event-parse.c b/tools/lib/traceevent/event-parse.c index 4d885934b919..cf42b090477b 100644 --- a/tools/lib/traceevent/event-parse.c +++ b/tools/lib/traceevent/event-parse.c | |||
| @@ -3795,7 +3795,7 @@ static void print_str_arg(struct trace_seq *s, void *data, int size, | |||
| 3795 | struct format_field *field; | 3795 | struct format_field *field; |
| 3796 | struct printk_map *printk; | 3796 | struct printk_map *printk; |
| 3797 | long long val, fval; | 3797 | long long val, fval; |
| 3798 | unsigned long addr; | 3798 | unsigned long long addr; |
| 3799 | char *str; | 3799 | char *str; |
| 3800 | unsigned char *hex; | 3800 | unsigned char *hex; |
| 3801 | int print; | 3801 | int print; |
| @@ -3828,13 +3828,30 @@ static void print_str_arg(struct trace_seq *s, void *data, int size, | |||
| 3828 | */ | 3828 | */ |
| 3829 | if (!(field->flags & FIELD_IS_ARRAY) && | 3829 | if (!(field->flags & FIELD_IS_ARRAY) && |
| 3830 | field->size == pevent->long_size) { | 3830 | field->size == pevent->long_size) { |
| 3831 | addr = *(unsigned long *)(data + field->offset); | 3831 | |
| 3832 | /* Handle heterogeneous recording and processing | ||
| 3833 | * architectures | ||
| 3834 | * | ||
| 3835 | * CASE I: | ||
| 3836 | * Traces recorded on 32-bit devices (32-bit | ||
| 3837 | * addressing) and processed on 64-bit devices: | ||
| 3838 | * In this case, only 32 bits should be read. | ||
| 3839 | * | ||
| 3840 | * CASE II: | ||
| 3841 | * Traces recorded on 64 bit devices and processed | ||
| 3842 | * on 32-bit devices: | ||
| 3843 | * In this case, 64 bits must be read. | ||
| 3844 | */ | ||
| 3845 | addr = (pevent->long_size == 8) ? | ||
| 3846 | *(unsigned long long *)(data + field->offset) : | ||
| 3847 | (unsigned long long)*(unsigned int *)(data + field->offset); | ||
| 3848 | |||
| 3832 | /* Check if it matches a print format */ | 3849 | /* Check if it matches a print format */ |
| 3833 | printk = find_printk(pevent, addr); | 3850 | printk = find_printk(pevent, addr); |
| 3834 | if (printk) | 3851 | if (printk) |
| 3835 | trace_seq_puts(s, printk->printk); | 3852 | trace_seq_puts(s, printk->printk); |
| 3836 | else | 3853 | else |
| 3837 | trace_seq_printf(s, "%lx", addr); | 3854 | trace_seq_printf(s, "%llx", addr); |
| 3838 | break; | 3855 | break; |
| 3839 | } | 3856 | } |
| 3840 | str = malloc(len + 1); | 3857 | str = malloc(len + 1); |
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 8a4537ee9bc3..fc3f7c922f99 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
| @@ -1580,7 +1580,10 @@ static int __perf_session__process_events(struct perf_session *session, | |||
| 1580 | file_offset = page_offset; | 1580 | file_offset = page_offset; |
| 1581 | head = data_offset - page_offset; | 1581 | head = data_offset - page_offset; |
| 1582 | 1582 | ||
| 1583 | if (data_size && (data_offset + data_size < file_size)) | 1583 | if (data_size == 0) |
| 1584 | goto out; | ||
| 1585 | |||
| 1586 | if (data_offset + data_size < file_size) | ||
| 1584 | file_size = data_offset + data_size; | 1587 | file_size = data_offset + data_size; |
| 1585 | 1588 | ||
| 1586 | ui_progress__init(&prog, file_size, "Processing events..."); | 1589 | ui_progress__init(&prog, file_size, "Processing events..."); |
