On Wed, Mar 24, 2021 at 02:21:37PM +0100, Peter Zijlstra wrote:
--- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -5652,13 +5652,17 @@ static long _perf_ioctl(struct perf_even return perf_event_query_prog_array(event, (void __user *)arg); case PERF_EVENT_IOC_MODIFY_ATTRIBUTES: {
struct perf_event_attr new_attr;struct perf_event_attr __user *uattr;
int err = perf_copy_attr((struct perf_event_attr __user *)arg,
&new_attr);
int err;
uattr = (struct perf_event_attr __user *)arg;
if (err) return err;err = perf_copy_attr(uattr, &new_attr);
event->siginfo.si_perf = (unsigned long)uattr;
Oh bugger; that wants updating for all children too..
- return perf_event_modify_attr(event, &new_attr); } default:
@@ -12011,6 +12010,11 @@ SYSCALL_DEFINE5(perf_event_open, goto err_task; }
- clear_siginfo(&event->siginfo);
- event->siginfo.si_signo = SIGTRAP;
- event->siginfo.si_code = TRAP_PERF;
- event->siginfo.si_perf = (unsigned long)attr_uptr;
And inherit_event() / perf_event_alloc() want to copy/propagate that.
if (is_sampling_event(event)) { if (event->pmu->capabilities & PERF_PMU_CAP_NO_INTERRUPT) { err = -EOPNOTSUPP;