Commit 71ae6305 authored by Naveen N. Rao's avatar Naveen N. Rao Committed by Michael Ellerman

selftests/powerpc: Move perror closer to its use

Right now, if perf_event_open() fails for the systemwide tests, error
report is printed too late, sometimes after subsequent system calls.
Move use of perror() to the main function, just after the syscall.
Signed-off-by: default avatarNaveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/372ac78c27899f1f612fbd6ac796604a4a9310aa.1669096083.git.naveen.n.rao@linux.vnet.ibm.com
parent dea681c9
...@@ -146,6 +146,7 @@ static int perf_systemwide_event_open(int *fd, __u32 type, __u64 addr, __u64 len ...@@ -146,6 +146,7 @@ static int perf_systemwide_event_open(int *fd, __u32 type, __u64 addr, __u64 len
for (i = 0; i < nprocs; i++) { for (i = 0; i < nprocs; i++) {
fd[i] = perf_cpu_event_open(i, type, addr, len); fd[i] = perf_cpu_event_open(i, type, addr, len);
if (fd[i] < 0) { if (fd[i] < 0) {
perror("perf_systemwide_event_open");
close_fds(fd, i); close_fds(fd, i);
return fd[i]; return fd[i];
} }
...@@ -543,15 +544,12 @@ static int test_syswide_multi_diff_addr(void) ...@@ -543,15 +544,12 @@ static int test_syswide_multi_diff_addr(void)
int ret; int ret;
ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret)
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
}
ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_RW, (__u64)&b, (__u64)sizeof(b)); ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_RW, (__u64)&b, (__u64)sizeof(b));
if (ret) { if (ret) {
close_fds(fd1, nprocs); close_fds(fd1, nprocs);
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
...@@ -590,15 +588,12 @@ static int test_syswide_multi_same_addr(void) ...@@ -590,15 +588,12 @@ static int test_syswide_multi_same_addr(void)
int ret; int ret;
ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret)
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
}
ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_RW, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret) {
close_fds(fd1, nprocs); close_fds(fd1, nprocs);
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
...@@ -637,15 +632,12 @@ static int test_syswide_multi_diff_addr_ro_wo(void) ...@@ -637,15 +632,12 @@ static int test_syswide_multi_diff_addr_ro_wo(void)
int ret; int ret;
ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_W, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_W, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret)
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
}
ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_R, (__u64)&b, (__u64)sizeof(b)); ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_R, (__u64)&b, (__u64)sizeof(b));
if (ret) { if (ret) {
close_fds(fd1, nprocs); close_fds(fd1, nprocs);
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
...@@ -684,15 +676,12 @@ static int test_syswide_multi_same_addr_ro_wo(void) ...@@ -684,15 +676,12 @@ static int test_syswide_multi_same_addr_ro_wo(void)
int ret; int ret;
ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_W, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd1, HW_BREAKPOINT_W, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret)
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
}
ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_R, (__u64)&a, (__u64)sizeof(a)); ret = perf_systemwide_event_open(fd2, HW_BREAKPOINT_R, (__u64)&a, (__u64)sizeof(a));
if (ret) { if (ret) {
close_fds(fd1, nprocs); close_fds(fd1, nprocs);
perror("perf_systemwide_event_open");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment