Namhyung Kim
38ab04186f
perf tools: Allow build-id with trailing zeros
...
commit 4a86d41404005a3c7e7b6065e8169ac6202887a9 upstream.
Currently perf saves a build-id with size but old versions assumes the
size of 20. In case the build-id is less than 20 (like for MD5), it'd
fill the rest with 0s.
I saw a problem when old version of perf record saved a binary in the
build-id cache and new version of perf reads the data. The symbols
should be read from the build-id cache (as the path no longer has the
same binary) but it failed due to mismatch in the build-id.
symsrc__init: build id mismatch for /home/namhyung/.debug/.build-id/53/e4c2f42a4c61a2d632d92a72afa08f00000000/elf.
The build-id event in the data has 20 byte build-ids, but it saw a
different size (16) when it reads the build-id of the elf file in the
build-id cache.
$ readelf -n ~/.debug/.build-id/53/e4c2f42a4c61a2d632d92a72afa08f00000000/elf
Displaying notes found in: .note.gnu.build-id
Owner Data size Description
GNU 0x00000010 NT_GNU_BUILD_ID (unique build ID bitstring)
Build ID: 53e4c2f42a4c61a2d632d92a72afa08f
Let's fix this by allowing trailing zeros if the size is different.
Fixes: 39be8d0115b321ed ("perf tools: Pass build_id object to dso__build_id_equal()")
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Acked-by: Jiri Olsa <jolsa@redhat.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Ian Rogers <irogers@google.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lore.kernel.org/lkml/20210910224630.1084877-1-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2021-09-26 14:08:57 +02:00
..
2020-08-21 10:22:23 -03:00
2020-01-14 12:02:19 -03:00
2020-05-05 16:35:32 -03:00
2020-11-12 17:55:41 -03:00
2021-06-03 09:00:28 +02:00
2019-09-20 09:19:20 -03:00
2021-07-14 16:56:38 +02:00
2019-11-28 08:08:38 -03:00
2019-11-28 08:08:38 -03:00
2021-09-03 10:09:29 +02:00
2021-09-03 10:09:29 +02:00
2019-03-11 11:56:02 -03:00
2020-06-01 12:24:23 -03:00
2021-04-28 13:40:00 +02:00
2020-08-06 08:24:03 -03:00
2021-04-14 08:42:11 +02:00
2020-03-09 21:43:25 -03:00
2019-01-25 15:12:09 +01:00
2019-01-25 15:12:09 +01:00
2019-02-19 16:11:56 -03:00
2019-02-19 16:11:56 -03:00
2020-05-05 16:35:29 -03:00
2020-05-05 16:35:29 -03:00
2020-09-09 11:28:28 -07:00
2019-07-29 18:34:42 -03:00
2020-06-09 12:40:04 -03:00
2019-09-20 09:19:20 -03:00
2020-05-28 10:03:27 -03:00
2021-05-19 10:13:13 +02:00
2020-11-03 09:14:45 -03:00
2020-10-14 08:46:22 -03:00
2019-08-29 17:38:32 -03:00
2019-08-26 11:58:29 -03:00
2019-07-09 10:13:27 -03:00
2019-06-05 17:36:37 +02:00
2020-10-14 13:34:26 -03:00
2020-10-14 13:34:26 -03:00
2019-08-14 10:48:39 -03:00
2020-04-16 12:19:08 -03:00
2020-09-28 09:18:06 -03:00
2020-09-28 09:18:06 -03:00
2020-08-06 09:33:57 -03:00
2020-08-06 09:33:57 -03:00
2020-05-28 10:03:26 -03:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2019-01-25 15:12:08 +01:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:09 +01:00
2019-05-15 16:36:49 -03:00
2020-10-13 17:03:19 -03:00
2020-10-13 17:03:19 -03:00
2019-10-15 12:05:18 -03:00
2019-09-25 09:51:49 -03:00
2020-05-28 10:03:27 -03:00
2020-05-28 10:03:27 -03:00
2019-02-06 10:00:39 -03:00
2020-03-24 10:36:00 -03:00
2019-11-29 12:20:45 -03:00
2019-08-22 17:16:57 -03:00
2020-05-28 10:03:27 -03:00
2020-09-01 12:15:52 -03:00
2020-05-05 16:35:32 -03:00
2020-08-06 09:43:37 -03:00
2020-08-06 09:43:37 -03:00
2021-07-28 14:35:36 +02:00
2019-11-06 15:43:05 -03:00
2019-11-26 11:07:46 -03:00
2019-07-29 18:34:42 -03:00
2020-08-14 09:15:47 -03:00
2019-11-12 08:32:27 -03:00
2020-05-28 10:03:28 -03:00
2019-09-20 09:19:20 -03:00
2021-09-26 14:08:57 +02:00
2020-10-14 11:28:52 -03:00
2020-10-14 11:28:52 -03:00
2019-11-19 19:12:26 -03:00
2018-12-28 16:33:02 -03:00
2018-12-28 16:33:02 -03:00
2021-06-10 13:39:17 +02:00
2019-11-06 15:43:06 -03:00
2019-09-20 09:19:20 -03:00
2021-09-03 10:09:29 +02:00
2020-08-06 09:42:20 -03:00
2021-03-04 11:38:03 +01:00
2020-07-10 08:39:14 -03:00
2019-08-31 22:24:10 -03:00
2021-03-04 11:38:09 +01:00
2021-03-04 11:38:09 +01:00
2020-05-28 10:03:24 -03:00
2020-05-28 10:03:24 -03:00
2020-05-28 10:03:24 -03:00
2020-09-28 08:55:48 -03:00
2020-09-28 08:55:48 -03:00
2019-08-15 12:26:13 -03:00
2019-08-15 12:25:55 -03:00
2020-07-30 07:01:49 -03:00
2020-07-30 07:01:49 -03:00
2020-06-22 16:28:09 -03:00
2020-07-30 07:01:49 -03:00
2019-01-08 13:28:13 -03:00
2019-11-28 08:08:38 -03:00
2019-11-28 08:08:38 -03:00
2020-05-29 16:51:38 -03:00
2019-11-29 12:20:45 -03:00
2019-09-25 16:26:41 -03:00
2019-08-26 11:58:29 -03:00
2019-07-09 10:13:26 -03:00
2020-11-03 08:26:55 -03:00
2020-11-27 14:19:33 -03:00
2020-10-14 11:28:12 -03:00
2020-08-06 09:35:06 -03:00
2019-07-09 10:13:26 -03:00
2020-05-28 10:03:24 -03:00
2020-05-28 10:03:24 -03:00
2020-05-05 16:35:30 -03:00
2019-06-05 17:36:37 +02:00
2021-06-03 09:00:27 +02:00
2019-06-05 17:36:37 +02:00
2019-06-05 17:37:04 +02:00
2019-01-25 15:12:10 +01:00
2021-05-14 09:50:44 +02:00
2020-05-28 10:03:27 -03:00
2019-09-20 10:28:26 -03:00
2021-07-14 16:56:52 +02:00
2019-08-29 17:38:32 -03:00
2021-07-28 14:35:35 +02:00
2021-09-22 12:27:57 +02:00
2020-09-17 15:47:12 -03:00
2019-11-26 11:07:46 -03:00
2021-08-04 12:46:45 +02:00
2020-10-13 11:01:37 -03:00
2019-11-26 11:07:46 -03:00
2020-05-05 16:35:30 -03:00
2019-08-31 19:10:40 -03:00
2020-05-28 10:03:25 -03:00
2020-05-28 10:03:25 -03:00
2019-09-20 09:19:22 -03:00
2020-10-13 13:02:20 -03:00
2020-09-28 09:16:21 -03:00
2020-03-12 11:32:46 -03:00
2020-01-06 11:46:09 -03:00
2019-09-20 10:28:21 -03:00
2019-09-20 10:28:21 -03:00
2020-04-30 10:48:32 -03:00
2020-05-28 10:03:27 -03:00
2019-08-31 19:10:19 -03:00
2020-10-14 12:24:28 -03:00
2020-09-28 09:22:39 -03:00
2020-10-14 12:24:28 -03:00
2020-09-28 09:22:39 -03:00
2020-12-30 11:53:59 +01:00
2019-05-15 16:36:49 -03:00
2020-08-14 09:15:47 -03:00
2020-08-14 09:15:47 -03:00
2019-08-31 22:24:10 -03:00
2019-08-31 22:24:10 -03:00
2020-07-10 08:20:01 -03:00
2020-07-10 08:20:01 -03:00
2020-07-10 08:20:01 -03:00
2019-10-10 09:29:33 -03:00
2021-09-03 10:09:29 +02:00
2019-09-20 09:19:20 -03:00
2019-05-28 18:37:44 -03:00
2020-05-29 16:51:38 -03:00
2020-05-29 16:51:38 -03:00
2020-09-15 09:22:42 -03:00
2020-09-15 09:22:42 -03:00
2020-10-01 12:10:56 -03:00
2021-07-28 14:35:35 +02:00
2019-11-18 19:09:23 -03:00
2021-07-28 14:35:36 +02:00
2019-11-18 19:08:02 -03:00
2021-06-10 13:39:17 +02:00
2020-09-18 09:20:47 -03:00
2020-05-28 10:03:27 -03:00
2020-04-03 09:37:55 -03:00
2020-09-28 09:16:21 -03:00
2019-01-25 15:12:10 +01:00
2019-06-05 17:37:04 +02:00
2019-01-25 15:12:10 +01:00
2020-09-17 15:47:58 -03:00
2020-09-04 14:38:15 -03:00
2019-07-09 14:59:11 -03:00
2019-07-09 14:59:11 -03:00
2019-09-20 09:19:20 -03:00
2020-04-16 12:19:15 -03:00
2020-05-05 16:35:29 -03:00
2019-09-20 09:19:20 -03:00
2019-07-29 18:34:42 -03:00
2019-07-29 18:34:42 -03:00
2021-06-16 12:01:46 +02:00
2019-11-22 10:48:13 -03:00
2019-07-09 10:13:26 -03:00
2020-04-14 08:43:18 -03:00
2020-05-28 10:03:24 -03:00
2020-05-05 16:35:29 -03:00
2021-07-28 14:35:35 +02:00
2021-07-28 14:35:35 +02:00
2019-10-11 10:57:00 -03:00
2019-10-11 10:57:00 -03:00
2019-11-28 08:08:38 -03:00
2019-02-06 10:00:38 -03:00
2020-01-30 11:55:26 +01:00
2019-01-25 15:12:09 +01:00
2020-11-27 14:31:37 -03:00
2020-09-17 15:48:08 -03:00
2020-09-17 15:48:08 -03:00
2020-09-28 09:07:08 -03:00
2019-08-31 19:10:19 -03:00
2020-10-14 13:34:26 -03:00
2020-10-14 13:34:26 -03:00
2019-07-09 10:13:26 -03:00
2019-10-15 13:03:57 -03:00
2019-07-01 22:50:40 -03:00
2019-07-09 10:13:26 -03:00
2019-01-25 15:12:10 +01:00
2019-09-20 09:19:21 -03:00
2019-08-29 17:38:31 -03:00
2020-03-24 09:37:27 -03:00
2021-05-14 09:50:28 +02:00
2021-09-03 10:09:29 +02:00
2020-10-14 08:46:42 -03:00
2021-03-04 11:38:07 +01:00
2020-11-03 08:30:34 -03:00
2019-08-31 22:24:05 -03:00
2021-03-30 14:32:06 +02:00
2020-04-03 09:37:55 -03:00
2020-05-29 16:50:29 -03:00
2020-05-29 16:50:26 -03:00
2019-09-20 09:19:20 -03:00
2019-08-29 08:36:12 -03:00
2019-08-29 08:36:12 -03:00
2020-05-05 16:35:29 -03:00
2020-05-05 16:35:29 -03:00
2020-04-18 09:05:01 -03:00
2020-04-18 09:05:01 -03:00
2019-10-15 08:36:22 -03:00
2019-10-15 08:36:22 -03:00
2020-07-10 08:20:01 -03:00
2020-05-05 16:35:30 -03:00
2020-05-05 16:35:29 -03:00
2020-09-17 15:47:58 -03:00
2020-09-17 15:47:58 -03:00
2020-05-28 10:03:27 -03:00
2019-11-05 08:39:27 -03:00
2021-03-17 17:06:17 +01:00
2019-08-29 17:38:32 -03:00
2019-09-20 09:19:20 -03:00
2019-11-05 08:39:27 -03:00
2019-08-29 17:38:32 -03:00
2020-09-22 13:46:40 -03:00
2020-09-22 13:45:21 -03:00
2021-05-28 13:17:43 +02:00
2020-05-28 10:03:27 -03:00
2019-11-26 11:07:46 -03:00
2019-11-26 11:07:46 -03:00
2019-09-20 09:19:20 -03:00
2020-04-16 12:19:08 -03:00
2020-09-10 11:55:37 -03:00
2019-08-31 19:10:19 -03:00
2021-09-03 10:09:29 +02:00
2019-07-09 10:13:26 -03:00
2019-09-20 09:19:20 -03:00
2020-09-01 12:15:21 -03:00