Skip to content

Commit e2c1816

Browse files
committed
libperf: Remove BUG_ON() from library code in get_group_fd()
We shouldn't just panic, return a value that doesn't clash with what perf_evsel__open() was already returning in case of error, i.e. errno when sys_perf_event_open() fails. Acked-by: Jiri Olsa <[email protected]> Cc: Alexander Shishkin <[email protected]> Cc: Ian Rogers <[email protected]> Cc: Mark Rutland <[email protected]> Cc: Michael Petlan <[email protected]> Cc: Namhyung Kim <[email protected]> Cc: Peter Zijlstra <[email protected]> Cc: Shunsuke Nakamura <[email protected]> Link: http://lore.kernel.org/lkml/[email protected] Signed-off-by: Arnaldo Carvalho de Melo <[email protected]>
1 parent 3fd35de commit e2c1816

File tree

1 file changed

+16
-7
lines changed

1 file changed

+16
-7
lines changed

tools/lib/perf/evsel.c

Lines changed: 16 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -77,23 +77,30 @@ sys_perf_event_open(struct perf_event_attr *attr,
7777
return syscall(__NR_perf_event_open, attr, pid, cpu, group_fd, flags);
7878
}
7979

80-
static int get_group_fd(struct perf_evsel *evsel, int cpu, int thread)
80+
static int get_group_fd(struct perf_evsel *evsel, int cpu, int thread, int *group_fd)
8181
{
8282
struct perf_evsel *leader = evsel->leader;
8383
int fd;
8484

85-
if (evsel == leader)
86-
return -1;
85+
if (evsel == leader) {
86+
*group_fd = -1;
87+
return 0;
88+
}
8789

8890
/*
8991
* Leader must be already processed/open,
9092
* if not it's a bug.
9193
*/
92-
BUG_ON(!leader->fd);
94+
if (!leader->fd)
95+
return -ENOTCONN;
9396

9497
fd = FD(leader, cpu, thread);
95-
BUG_ON(fd == -1);
96-
return fd;
98+
if (fd == -1)
99+
return -EBADF;
100+
101+
*group_fd = fd;
102+
103+
return 0;
97104
}
98105

99106
int perf_evsel__open(struct perf_evsel *evsel, struct perf_cpu_map *cpus,
@@ -133,7 +140,9 @@ int perf_evsel__open(struct perf_evsel *evsel, struct perf_cpu_map *cpus,
133140
for (thread = 0; thread < threads->nr; thread++) {
134141
int fd, group_fd;
135142

136-
group_fd = get_group_fd(evsel, cpu, thread);
143+
err = get_group_fd(evsel, cpu, thread, &group_fd);
144+
if (err < 0)
145+
return err;
137146

138147
fd = sys_perf_event_open(&evsel->attr,
139148
threads->map[thread].pid,

0 commit comments

Comments
 (0)