mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
Various memory measurement improvements (#36834)
The two significant changes here are 1) a commit that frees memory used to perform memory reporting once the reporting is complete, 2) memory reporting for the system font service. There are various other commits that remove `#[ignore_malloc_size_of]` attributes for data that we are now able to measure, but they do not significantly change our measurements when testing servo.org. Testing: Comparing the output of about:memory on servo.org. --------- Signed-off-by: Josh Matthews <josh@joshmatthews.net>
This commit is contained in:
parent
e9f364ef51
commit
ba8f923201
19 changed files with 135 additions and 49 deletions
|
@ -97,6 +97,7 @@ enum ParseState {
|
|||
AfterDescriptor,
|
||||
}
|
||||
|
||||
#[derive(MallocSizeOf)]
|
||||
pub(crate) struct SourceSet {
|
||||
image_sources: Vec<ImageSource>,
|
||||
source_size: SourceSizeList,
|
||||
|
@ -111,13 +112,13 @@ impl SourceSet {
|
|||
}
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq)]
|
||||
#[derive(Clone, Debug, MallocSizeOf, PartialEq)]
|
||||
pub struct ImageSource {
|
||||
pub url: String,
|
||||
pub descriptor: Descriptor,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq)]
|
||||
#[derive(Clone, Debug, MallocSizeOf, PartialEq)]
|
||||
pub struct Descriptor {
|
||||
pub width: Option<u32>,
|
||||
pub density: Option<f64>,
|
||||
|
@ -145,7 +146,7 @@ struct ImageRequest {
|
|||
parsed_url: Option<ServoUrl>,
|
||||
source_url: Option<USVString>,
|
||||
blocker: DomRefCell<Option<LoadBlocker>>,
|
||||
#[ignore_malloc_size_of = "Arc"]
|
||||
#[conditional_malloc_size_of]
|
||||
#[no_trace]
|
||||
image: Option<Arc<Image>>,
|
||||
#[no_trace]
|
||||
|
@ -162,7 +163,6 @@ pub(crate) struct HTMLImageElement {
|
|||
pending_request: DomRefCell<ImageRequest>,
|
||||
form_owner: MutNullableDom<HTMLFormElement>,
|
||||
generation: Cell<u32>,
|
||||
#[ignore_malloc_size_of = "SourceSet"]
|
||||
source_set: DomRefCell<SourceSet>,
|
||||
last_selected_source: DomRefCell<Option<USVString>>,
|
||||
#[ignore_malloc_size_of = "promises are hard"]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue