Skip to content

high memory requirement during monomorphization #125212

Open
@matthiaskrgr

Description

@matthiaskrgr

I noticed this while fuzzing because rustc would crash after hitting the memory limit inside the sandbox
We need around 1.5 gb of memory during monomorphization here it seems.
Next solver does not help.

I tried this code:
rustc file.rs -Ztime-passes -Clink-dead-code

struct Foo {
    bar: dyn for<'r> Fn(usize, &'r dyn Fn(
            &dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(&dyn Fn(u32))))))))),
        ))
}

fn main() {
}

Meta

rustc --version --verbose:

rustc 1.80.0-nightly (8c127df75 2024-05-16)
binary: rustc
commit-hash: 8c127df75fde3d5ad8ef9af664962a7676288b52
commit-date: 2024-05-16
host: x86_64-unknown-linux-gnu
release: 1.80.0-nightly
LLVM version: 18.1.4
Backtrace

 rustc ice.rs -Ztime-passes -Clink-dead-code
time:   0.000; rss:   46MB ->   47MB (   +2MB)	parse_crate
time:   0.000; rss:   48MB ->   49MB (   +1MB)	setup_global_ctxt
time:   0.000; rss:   50MB ->   50MB (   +1MB)	crate_injection
time:   0.002; rss:   50MB ->   63MB (  +12MB)	expand_crate
time:   0.002; rss:   50MB ->   63MB (  +12MB)	macro_expand_crate
time:   0.000; rss:   63MB ->   63MB (   +0MB)	AST_validation
time:   0.000; rss:   63MB ->   63MB (   +0MB)	finalize_imports
time:   0.000; rss:   63MB ->   67MB (   +4MB)	finalize_macro_resolutions
time:   0.000; rss:   67MB ->   67MB (   +0MB)	late_resolve_crate
time:   0.000; rss:   67MB ->   67MB (   +0MB)	resolve_check_unused
time:   0.000; rss:   67MB ->   67MB (   +0MB)	resolve_postprocess
time:   0.001; rss:   63MB ->   67MB (   +5MB)	resolve_crate
time:   0.000; rss:   68MB ->   68MB (   +0MB)	complete_gated_feature_checking
time:   0.000; rss:   68MB ->   69MB (   +2MB)	looking_for_entry_point
time:   0.000; rss:   70MB ->   71MB (   +0MB)	unused_lib_feature_checking
time:   0.000; rss:   68MB ->   71MB (   +3MB)	misc_checking_1
time:   0.001; rss:   71MB ->   78MB (   +7MB)	coherence_checking
time:   0.001; rss:   71MB ->   79MB (   +8MB)	type_check_crate
time:   0.000; rss:   79MB ->   81MB (   +2MB)	MIR_borrow_checking
time:   0.000; rss:   81MB ->   82MB (   +1MB)	MIR_effect_checking
warning: struct `Foo` is never constructed
 --> ice.rs:1:8
  |
1 | struct Foo {
  |        ^^^
  |
  = note: `#[warn(dead_code)]` on by default

time:   0.000; rss:   86MB ->   86MB (   +0MB)	module_lints
time:   0.000; rss:   86MB ->   86MB (   +0MB)	lint_checking
time:   0.002; rss:   82MB ->   86MB (   +4MB)	misc_checking_3
time:   0.000; rss:   86MB ->   87MB (   +1MB)	monomorphization_collector_root_collections
time:   5.850; rss:   87MB -> 1537MB (+1450MB)	monomorphization_collector_graph_walk
time:   0.000; rss: 1537MB -> 1538MB (   +1MB)	partition_and_assert_distinct_symbols
time:   0.000; rss: 1538MB -> 1541MB (   +3MB)	write_allocator_module
time:   0.001; rss: 1547MB -> 1557MB (   +9MB)	codegen_to_LLVM_IR
time:   5.853; rss:   86MB -> 1557MB (+1471MB)	codegen_crate
time:   0.000; rss: 1557MB -> 1557MB (   +0MB)	serialize_dep_graph
time:   0.023; rss: 1557MB -> 1279MB ( -277MB)	LLVM_passes
time:   0.078; rss: 1557MB ->  209MB (-1349MB)	free_global_ctxt
time:   0.051; rss:  209MB ->  209MB (   +0MB)	run_linker
time:   0.052; rss:  209MB ->  209MB (   +0MB)	link_binary
time:   0.052; rss:  209MB ->  209MB (   +0MB)	link_crate
time:   0.052; rss:  209MB ->  209MB (   +0MB)	link
warning: 1 warning emitted

time:   5.999; rss:   32MB ->  102MB (  +70MB)	total

Metadata

Metadata

Assignees

No one assigned

    Labels

    A-monomorphizationArea: MonomorphizationC-optimizationCategory: An issue highlighting optimization opportunities or PRs implementing suchI-compilememIssue: Problems and improvements with respect to memory usage during compilation.T-compilerRelevant to the compiler team, which will review and decide on the PR/issue.

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions