-
Notifications
You must be signed in to change notification settings - Fork 255
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Discoverability of perf event types #689
Comments
Thanks for raising this topic, you are not wrong, but I do think this topic is way more complicated than you might assume ;-) I.e. we definitely don't want to do the naive sampling on multiple PMUs as that can lead to too much noise. Instead, leader sampling should be used, but that is somewhat flaky too in my testing (it sometimes breaks in kernel updates). Still, that's what should be done by default I think. https://www.man7.org/linux/man-pages/man1/perf-list.1.html#LEADER_SAMPLING Also hard coding an event in the way you suggest in your mockup will lead to failures in contexts where no PMU is available but the timer based fallback would still work. This is why not doing anything by default and letting the user write the more complex requests in the "event type(s)" edit is better imo. Maybe we should include some common examples as predefined values in the drop down instead? anyhow, patches welcome! |
I feared as much :)
Sorry I don't know if I'm understanding you 100% correctly, are you saying that: I was under the impression that at least a few hardware performance counters were available. Seems I was wrong as checking on my home PC
Certainly didn't want to suggest just hardcoding them. I was thinking about adding them to the dropdown as well. It's just that speaking from experience, I only discovered today that it was in fact a dropdown (after 6months of intensive usage of hotspot)
I'll try to create a PR with a small section added to the readme clarifying event usage and maybe add some defaults to the dropdown (and maybe hack a little on the UI in the meantime) . |
It's a combination of all this: The PMU has a limited slot of programmable PMUs (I think often just four?), and if you measure too many events then perf will start muxing which obviously deteriorates the accuracy. What's imo worse though is that a naive If you instead use leader sampling via
That sounds wrong to me, try something like this (I have a Ryzen 3900x here):
Intel CPUs give an exact number of available PMU counters, sadly not the case for AMD apparently. Also note how the NMI watchdog takes away one of them, so I probably only have 3 slots before muxing kicks in. |
Is your feature request related to a problem? Please describe.
Hotspot was my first introduction to using
perf
. It took a me an (embarrassingly) long time to figure out there's other events than just 'cycles' and how good this is all integrated in hotspot.Neither does the README contain any examples of using other events nor screenshots of the UI with multiple events enabled.
Describe the solution you'd like
An addition to the README's 'Using' section that demonstrates using multiple perf events, a list of some useful ones and a link to more information about perf events.
Maybe it could be integrated in the 'record' UI as well? I was thinking about adding some checkboxes next to the 'Event Type(s)' field containing the pre-defined events from
perf list
?Describe alternatives you've considered
Reading the perf manual sooner :)
Additional context
UI mock:
The text was updated successfully, but these errors were encountered: