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

Remove weak symbols, use abort for defaults. #254

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

rslawson
Copy link

@rslawson rslawson commented Jan 8, 2025

As per #247, using weak symbols for overridable functions has proven problematic with lto = true. This is a partial reversion of that, though there are still other functions this may yet be done with. There is also another solution to be done as a sort of nightly-only thing with naked functions and #[linkage = "weak"], however I have opted not to go with that seeing as this project doesn't currently require nightly and I don't think this is an issue worth changing that over.

@rslawson rslawson requested a review from a team as a code owner January 8, 2025 10:06
@rslawson
Copy link
Author

rslawson commented Jan 8, 2025

I think there may be something else that I need to do to the linker script, since as it is now it currently fails to build on one of the projects I'm working on with the error

  = note: rust-lld: error: 
          BUG(riscv-rt): start of .heap is not 4-byte aligned
          
          rust-lld: error: 
          BUG(riscv-rt): start of .heap is not 4-byte aligned

@romancardenas
Copy link
Contributor

Try to rebase from master. Build errors should disappear

@romancardenas
Copy link
Contributor

@rslawson please, add a brief note in README.md describing your changes

@rslawson
Copy link
Author

rslawson commented Jan 9, 2025

Yep, they did disappear. I'll make the change to README.md now. Are there any other symbols I should give the same treatment, or is it enough just to change DefaultHandler and ExceptionHandler?

Copy link
Contributor

@romancardenas romancardenas left a comment

Choose a reason for hiding this comment

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

LGTM.

I would like to discuss this work with @rust-embedded/all in the next meeting in case there is a better approach to deal with weak symbols and LTO optimizations in Rust.

@rslawson
Copy link
Author

In the meantime I'll try to keep this rebased with an up-to-date master branch from this repo.

@romancardenas
Copy link
Contributor

We discussed this today and... we didn't come up with a better solution.

Let's leave this PR and #247 open to keep discussing what to do with weak symbols. We must:

  1. Enumerate all the weak symbols we are currently using in riscv-rt
  2. Propose an alternative methodology for them. Not all symbols are easily replaceable as abort or interrupt handlers (e.g., mp_hook).

@rslawson , would you be happy to keep working on this PR until we decide what to do with the remaining weak symbols?

@rslawson
Copy link
Author

Sure thing, I can do that.

@rmsyn
Copy link
Contributor

rmsyn commented Jan 15, 2025

As per #247, using weak symbols for overridable functions has proven problematic with lto = true.

Is this only a problem with rust-lld (read lld)? If so, does using another linker with LTO resolve the issue you're experiencing @rslawson?

Maybe until there is a stable solution for weak linkage in Rust, we could recommend using a different linker instead of introducing nightly-only features?

@rslawson
Copy link
Author

Sorry for the late reply, got caught up in a work project for a while. I'm unsure if the problem is with the linker or in codegen, though bjorn3's answer suggests to me that it's the latter.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants