Skip to content
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

Use profiling crate to support more profiler backends #5150

Merged
merged 33 commits into from
Dec 16, 2024

Conversation

teddemunnik
Copy link
Contributor

@teddemunnik teddemunnik commented Sep 23, 2024

Hey! I am not sure if this is something that's been considered before and decided against (I couldn't find any PR's or issues).

This change removes the internal profiling macros in library crates and the puffin feature and replaces it with similar functions in the profiling crate. This crate provides a layer of abstraction over various profiler instrumentation crates and allows library users to pick their favorite (supported) profiler.

An additional benefit for puffin users is that dependencies of egui are included in the instrumentation output too (mainly wgpu which uses the profiling crate), so more details might be available when profiling.

A breaking change is that instead of using the puffin feature on egui, users that want to profile the crate with puffin instead have to enable the profile-with-puffin feature on the profiling crate. Similarly they could instead choose to use profile-with-tracy etc.

I tried to add a 'tracy' feature to egui_demo_app in order to showcase , however the /scripts/check.sh currently breaks on mutually exclusive features (which this introduces), so I decided against including it for the initial PR. I'm happy to iterate more on this if there is interest in taking this PR though.

Screenshot showing the additional info for wgpu now available when using puffin
image

@teddemunnik teddemunnik requested a review from Wumpf as a code owner September 23, 2024 16:30
Copy link

github-actions bot commented Sep 24, 2024

Preview available at https://egui-pr-preview.github.io/pr/5150-prprofiling-crate
Note that it might take a couple seconds for the update to show up after the preview_build workflow has completed.

Copy link
Owner

@emilk emilk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good overall, but I would prefer not to have the costs of proc-macros for every egui user, if possible.

We should also document the use of profiling somewhere, with at least a line or two in the crate-level docs for egui eframe.

Btw, you can already combine the profiling output of wgpu with the puffin output of eframe/egui if you enable the right features on both :)

@@ -58,9 58,8 @@ enum AppIconStatus {
///
/// Since window creation can be lazy, call this every frame until it's either successfully or gave up.
/// (See [`AppIconStatus`])
#[profiling::function]
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Proc-macros like these have a tendency to increase build-times. Luckily we can opt-out of them by disabling the default features of the profiling crate

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's a fair point. I don't think the profiling crates currently implements another abstraction that would call puffin::profile_function! under the hood though. So I think we have 3 options here:

  1. Add profiling::function!() macro upstream which would call puffin::profile_function!()
  2. Create our own egui::profile_function!() macro which calls profiling::scope!() with similar internal code to figure out the calling function name as puffin does internally in it's macro.
  3. Use profiling::scope!() and manually type the function name.

Let me know if you have any thoughts on this. I'll have a look and see how feasible option 1 would be tonight

Cargo.toml Outdated Show resolved Hide resolved
@teddemunnik
Copy link
Contributor Author

Thank you for the feedback @emilk! I've added crate level docs as suggested for both egui and eframe (let me know if this is what you meant).

Also opened a pull request for the profiling crate about adding a declarative macro so that we can instrument functions without the procmacro feature enabled, let's see if that is something there is interest for.

@teddemunnik
Copy link
Contributor Author

profiling 1.0.16 was released a couple of weeks ago with a new declarative macro profiling::function_scope!() which works very similar to the crate::profile_function!() found in egui currently, which allows us to easily replace existing call sites and not make use or the procedural macros feature.

I've merged this PR with upstream and replaced usages of procedural macros with the new declarative macro. @emilk would you mind having another look at this, and seeing if this resolves your concerns?

Copy link
Owner

@emilk emilk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice, looks good!

@emilk emilk added eframe Relates to epi and eframe egui labels Dec 16, 2024
@emilk emilk changed the title Switch internal instrumentation macros to use profiling crate instead, allowing instrumentation with different profilers Use profiling crate to support more profiler backends Dec 16, 2024
@emilk emilk merged commit 3af9079 into emilk:master Dec 16, 2024
26 of 27 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
eframe Relates to epi and eframe egui
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants