* Stephane Eranian <eran...@google.com> wrote: > This patch removes a redundant store on regs->flags introduced > by commit: > > 71eb9ee9596d ("perf/x86/intel: Fix linear IP of PEBS real_ip on Haswell and > later CPUs") > > We were clearing the PERF_EFLAGS_EXACT but it was overwritten by > regs->flags = pebs->flags later on. > > The PERF_EFLAGS_EXACT is a software flag using bit 3 of regs->flags. > X86 marks this bit as Reserved. To make sure this bit is zero before > we do any IP processing, we clear it explicitly. > > Patch also removes the following assignment: > regs->flags = pebs->flags | (regs->flags & PERF_EFLAGS_VM); > > Because there is no regs->flags to preserve anymore because > set_linear_ip() is not called until later. > > Patch also clarifies comment for intel_pmu_pebs_fixup_ip(). > > Signed-off-by: Stephane Eranian <eran...@google.com> > --- > arch/x86/events/intel/ds.c | 23 ++++++++++++++--------- > 1 file changed, 14 insertions(+), 9 deletions(-) > > diff --git a/arch/x86/events/intel/ds.c b/arch/x86/events/intel/ds.c > index da6780122786..41b44a4fff51 100644 > --- a/arch/x86/events/intel/ds.c > +++ b/arch/x86/events/intel/ds.c > @@ -1153,7 +1153,6 @@ static void setup_pebs_sample_data(struct perf_event > *event, > if (pebs == NULL) > return; > > - regs->flags &= ~PERF_EFLAGS_EXACT; > sample_type = event->attr.sample_type; > dsrc = sample_type & PERF_SAMPLE_DATA_SRC; > > @@ -1197,7 +1196,13 @@ static void setup_pebs_sample_data(struct perf_event > *event, > * and PMI. > */ > *regs = *iregs; > - regs->flags = pebs->flags; > + > + /* > + * initialize regs_>flags from pebs > + * clear exact bit (which uses Reserved bit 3), > + * i.e, do not rely on it being zero. > + */ > + regs->flags = pebs->flags & ~PERF_EFLAGS_EXACT;
Please use consistent capitalization and spelling to make comments more readable: s/initialize /Initialize s/pebs /PEBS s/i.e /i.e. Also, please put a comma after 'PEBS', to make it more clear what the sentence says. > - /* Haswell and later have the eventing IP, so use it: */ > + /* Haswell and later have the eventing IP, so use it */ So that's a step backwards in readability ... > - /* Otherwise use PEBS off-by-1 IP: */ > + /* Otherwise use PEBS off-by-1 IP */ Ditto. > set_linear_ip(regs, pebs->ip); > > - /* ... and try to fix it up using the LBR entries: */ > + /* > + * ... and try to fix it up using the LBR entries > + * if successful, regs->ip modified and regs patch > + * via set_linear_ip() > + */ > if (intel_pmu_pebs_fixup_ip(regs)) > regs->flags |= PERF_EFLAGS_EXACT; And it's unclear to me what this tries to say: "try to fix it up using the LBR entries if successful", or: "try to fix it up using the LBR entries, and if successful, regs->ip modified and regs patch via set_linear_ip()", ? Please improve readability. Thanks, Ingo