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

Broken LLVM module: inlinable function call in a function with debug info must have a !dbg location #135332

Open
DaniPopes opened this issue Jan 10, 2025 · 14 comments · Fixed by #135643
Assignees
Labels
A-debuginfo Area: Debugging information in compiled programs (DWARF, PDB, etc.) A-LLVM Area: Code generation parts specific to LLVM. Both correctness bugs and optimization-related issues. A-LTO Area: Link-time optimization (LTO) C-bug Category: This is a bug. E-needs-mcve Call for participation: This issue has a repro, but needs a Minimal Complete and Verifiable Example P-high High priority regression-from-stable-to-stable Performance or correctness regression from one stable version to another. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.

Comments

@DaniPopes
Copy link
Contributor

DaniPopes commented Jan 10, 2025

Code

I tried this code foundry-rs/foundry@0cc5355:

git clone https://github.com/foundry-rs/foundry.git
git checkout 0cc535504a909dcee74694fa86f7faafa4cbf4bc
cargo +stable build --bin forge --profile maxperf # takes a while (>5 min)

I expected to see this happen: compiles like with dev or release profile

Instead, this happened (see https://github.com/foundry-rs/foundry/actions/runs/12700786553/job/35404155023#step:7:3652):

inlinable function call in a function with debug info must have a !dbg location
  tail call fastcc void @_ZN5alloc5alloc18handle_alloc_error17ha0547c441587f574E(i64 noundef 8, i64 noundef 128) #324
... # the last line repeated thousands of times with different arguments
rustc-LLVM ERROR: Broken module found, compilation aborted!

This is caused by the following config combination, as changing any of these values makes it compile again:

debug = "line-tables-only" # any value that's not "none"
lto = "fat"

I've also verified that the strip value does not affect the outcome either.

We fixed this by setting debug = "none".

Maybe related to #129063, which modified the function mentioned in the error?


I could reproduce this locally only on 1.84, not on beta or nightly, so feel free to close this if it has already been fixed. Reproducible with RUSTFLAGS="-Zverify-llvm-ir", see #135332 (comment).

Unfortunately I wasn't able to minimize this.
Simpler repro in #135332 (comment).

Version it worked on

It most recently worked on: 1.83.0

Version with regression

rustc --version --verbose:

rustc 1.84.0 (9fc6b4312 2025-01-07)
binary: rustc
commit-hash: 9fc6b43126469e3858e2fe86cafb4f0fd5068869
commit-date: 2025-01-07
host: x86_64-unknown-linux-gnu
release: 1.84.0
LLVM version: 19.1.5
rustc 1.86.0-nightly (824759493 2025-01-09)
binary: rustc
commit-hash: 824759493246ee383beb9cd5ceffa0e15deb9fa4
commit-date: 2025-01-09
host: x86_64-unknown-linux-gnu
release: 1.86.0-nightly
LLVM version: 19.1.6

@rustbot modify labels: +regression-from-stable-to-stable -regression-untriaged

@DaniPopes DaniPopes added C-bug Category: This is a bug. regression-untriaged Untriaged performance or correctness regression. labels Jan 10, 2025
@rustbot rustbot added I-prioritize Issue: Indicates that prioritization has been requested for this issue. needs-triage This issue may need triage. Remove it if it has been sufficiently triaged. regression-from-stable-to-stable Performance or correctness regression from one stable version to another. and removed regression-untriaged Untriaged performance or correctness regression. labels Jan 10, 2025
@jieyouxu jieyouxu added E-needs-mcve Call for participation: This issue has a repro, but needs a Minimal Complete and Verifiable Example A-LTO Area: Link-time optimization (LTO) A-debuginfo Area: Debugging information in compiled programs (DWARF, PDB, etc.) E-needs-bisection Call for participation: This issue needs bisection: https://github.com/rust-lang/cargo-bisect-rustc labels Jan 10, 2025
@saethlin saethlin removed the needs-triage This issue may need triage. Remove it if it has been sufficiently triaged. label Jan 10, 2025
@lqd
Copy link
Member

lqd commented Jan 10, 2025

Maybe related to #129063, which modified the function mentioned in the error?

That landed in 1.83 so probably not. We can try to bisect, but 5 minutes per step does not sound like a fun time 😓.

@DaniPopes
Copy link
Contributor Author

DaniPopes commented Jan 10, 2025

That landed in 1.83 so probably not.

Ah sorry, misread the tag in the commit view.

We can try to bisect, but 5 minutes per step does not sound like a fun time

Took about 1 hour, not that bad.

searched nightlies: from nightly-2024-10-13 to nightly-2024-11-22
regressed nightly: nightly-2024-11-11
searched commit range: 59cec72...143ce09
regressed commit: b026d85

bisected with cargo-bisect-rustc v0.6.9

Host triple: x86_64-unknown-linux-gnu
Reproduce with:

cargo bisect-rustc --start 1.83.0 --end 1.84.0 -- build --profile maxperf --bin forge 

I then bisected b026d85 ... 1.84.0 with --regress no-error

searched toolchains nightly-2024-11-22 through nightly-2025-01-08


********************************************************************************
Regression in nightly-2024-12-02
********************************************************************************

ending github query because we found starting sha: 7442931d49b199ad0a1cc0f8ca54e327b5139b66
get_commits_between returning commits, len: 7
  commit[0] 2024-11-30: Auto merge of #133684 - RalfJung:rollup-j2tmrg7, r=RalfJung
  commit[1] 2024-12-01: Auto merge of #133365 - compiler-errors:compare-impl-item, r=lcnr
  commit[2] 2024-12-01: Auto merge of #133499 - nikic:no-backend-verify, r=Mark-Simulacrum
  commit[3] 2024-12-01: Auto merge of #133694 - matthiaskrgr:rollup-s6xj4rf, r=matthiaskrgr
  commit[4] 2024-12-01: Auto merge of #132390 - RalfJung:diagnostics-root-dir, r=albertlarsan68,weihanglo
  commit[5] 2024-12-01: Auto merge of #133532 - rami3l:ci/bump-ubuntu, r=Kobzol
  commit[6] 2024-12-01: Auto merge of #133703 - matthiaskrgr:rollup-fwlw0mc, r=matthiaskrgr

So:

And in fact building with RUSTFLAGS="-Zverify-llvm-ir" on the latest nightly fails compilation with the same LLVM error.

@lqd
Copy link
Member

lqd commented Jan 10, 2025

Yup, same, I was bisecting through 2024-11-11 myself.

Let's at least cc the authors of those PRs: @khuey and @nikic.

@lqd lqd removed the E-needs-bisection Call for participation: This issue needs bisection: https://github.com/rust-lang/cargo-bisect-rustc label Jan 10, 2025
@khuey
Copy link
Contributor

khuey commented Jan 10, 2025

If you run your -Zverify-llvm-ir stuff on tests/ui/debuginfo/debuginfo-inline-callsite-location-macro-1.rs and tests/ui/debuginfo/debuginfo-inline-callsite-location-macro-2.rs does it trigger on either test?

@nikic
Copy link
Contributor

nikic commented Jan 10, 2025

If you run your -Zverify-llvm-ir stuff on tests/ui/debuginfo/debuginfo-inline-callsite-location-macro-1.rs and tests/ui/debuginfo/debuginfo-inline-callsite-location-macro-2.rs does it trigger on either test?

Unless these tests are skipped in CI, the answer is no.

@nikic
Copy link
Contributor

nikic commented Jan 10, 2025

The usual way to fix this error (assuming that there genuinely no better location that can be attached) is to add a 0-line DILocation. https://reviews.llvm.org/D133095 is one case where I encountered this error before.

@khuey
Copy link
Contributor

khuey commented Jan 10, 2025

Yeah, that's what I plan to do, but I would like to understand the pattern that causes this error if the tests don't.

@DaniPopes
Copy link
Contributor Author

Managed to create a smaller reproducer here: https://github.com/DaniPopes/rust-bug-135332
Based on https://github.com/buaazp/rust-bug from #132900

@khuey
Copy link
Contributor

khuey commented Jan 15, 2025

khuey@zhadum:~/dev/scratch/rust-bug-135332$ python gen_code.py $N
  File "/home/khuey/dev/scratch/rust-bug-135332/gen_code.py", line 21
    """
       ^
SyntaxError: f-string expression part cannot include a backslash

@khuey
Copy link
Contributor

khuey commented Jan 15, 2025

diff --git a/gen_code.py b/gen_code.py
index f7b31f5..e44ab5c 100644
--- a/gen_code.py
+++ b/gen_code.py
@@ -10,12 +10,13 @@ def generate_code(num_lines):
         count += 1
         return f'"string{count}".to_owned()'

+    new_line = '\n'
     return f"""\
 pub type BigType = Vec<Vec<String>>;

 pub fn big_function() -> BigType {{
     vec![
-        {",\n        ".join(f"vec![{get_string()}]" for _ in range(num_lines))}
+        {f",{new_line}        ".join(f"vec![{get_string()}]" for _ in range(num_lines))}
     ]
 }}
 """

seems to wallpaper over it

@khuey
Copy link
Contributor

khuey commented Jan 15, 2025

I can reproduce with the linked repo and the above patch, thanks.

khuey added a commit to khuey/rust that referenced this issue Jan 17, 2025
… with dummy spans instead of not emitting locations at all when the correct location discriminator value exceeds LLVM's capacity.
@khuey
Copy link
Contributor

khuey commented Jan 17, 2025

@rustbot claim

@jieyouxu jieyouxu added A-LLVM Area: Code generation parts specific to LLVM. Both correctness bugs and optimization-related issues. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Jan 18, 2025
jieyouxu added a commit to jieyouxu/rust that referenced this issue Jan 18, 2025
jieyouxu added a commit to jieyouxu/rust that referenced this issue Jan 18, 2025
jieyouxu added a commit to jieyouxu/rust that referenced this issue Jan 18, 2025
khuey pushed a commit to khuey/rust that referenced this issue Jan 18, 2025
khuey added a commit to khuey/rust that referenced this issue Jan 18, 2025
… with dummy spans instead of not emitting locations at all when the correct location discriminator value exceeds LLVM's capacity.
@apiraino
Copy link
Contributor

WG-prioritization assigning priority (Zulip discussion).

@rustbot label -I-prioritize +P-high

@rustbot rustbot added P-high High priority and removed I-prioritize Issue: Indicates that prioritization has been requested for this issue. labels Jan 20, 2025
@bors bors closed this as completed in 6a64e3b Jan 20, 2025
@apiraino
Copy link
Contributor

reopening for tracking the backports of #135643

(we usually close fixed regressions only after t-compiler has decided to backport the patch fixing it)

@apiraino apiraino reopened this Jan 20, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-debuginfo Area: Debugging information in compiled programs (DWARF, PDB, etc.) A-LLVM Area: Code generation parts specific to LLVM. Both correctness bugs and optimization-related issues. A-LTO Area: Link-time optimization (LTO) C-bug Category: This is a bug. E-needs-mcve Call for participation: This issue has a repro, but needs a Minimal Complete and Verifiable Example P-high High priority regression-from-stable-to-stable Performance or correctness regression from one stable version to another. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.
Projects
None yet
8 participants