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

Tracking Issue for -Z codegen-backend #77933

Open
XAMPPRocky opened this issue Oct 14, 2020 · 2 comments
Open

Tracking Issue for -Z codegen-backend #77933

XAMPPRocky opened this issue Oct 14, 2020 · 2 comments
Labels
A-CLI Area: Command-line interface (CLI) to the compiler A-codegen Area: Code generation B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC S-tracking-impl-incomplete Status: The implementation is incomplete. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.

Comments

@XAMPPRocky
Copy link
Member

XAMPPRocky commented Oct 14, 2020

This is a tracking issue for the -Zcodegen-backend compiler flag.

rustc today only supports one stable backend ("llvm"), but it has many unstable backends.

In the future, it will support multiple stable backends.

Our plan is that the stable backends will all be allowlisted in the compiler. The general pattern will be that every stable backend will be denoted by an identifier with no . in its name (e.g. "cranelift", "gcc", "llvm"). When we start reaching a point where one of the alternative backends is getting close to being ready to stabilize, we will then discuss how to offer a stable form of this flag (i.e. -C codegen-backend flag).

Meanwhile, the -Z codegen-backend flag will always unstably support an interface for connecting to an arbitrary backend loaded as a dynamic library, as described below.


This flag unstably allows you specify a path to a dynamic library containing a function named __rustc_codegen_backend with a signature of fn() -> Box<dyn rustc_codegen_ssa::traits::CodegenBackend> to use as code generation backend at runtime. (CodegenBackend trait)

Example

use rustc_codegen_ssa::traits::CodegenBackend;

struct MyBackend;

impl CodegenBackend for MyBackend {
   // Implement codegen methods
}

#[no_mangle]
pub fn __rustc_codegen_backend() -> Box<dyn CodegenBackend> {
    Box::new(MyBackend)
}

About tracking issues

Tracking issues are used to record the overall progress of implementation.
They are also used as hubs connecting to other relevant issues, e.g., bugs or open design questions.
A tracking issue is however not meant for large scale discussion, questions, or bug reports about a feature.
Instead, open a dedicated issue for the specific matter and add the relevant feature gate label.

Implementation history

@XAMPPRocky XAMPPRocky added T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC labels Oct 14, 2020
@jonas-schievink jonas-schievink added the A-codegen Area: Code generation label Oct 14, 2020
JohnTitor added a commit to JohnTitor/rust that referenced this issue Oct 14, 2020
@pnkfelix
Copy link
Member

pnkfelix commented Oct 21, 2022

Discussed at backlog bonanza

https://rust-lang.zulipchat.com/#narrow/stream/238009-t-compiler.2Fmeetings/topic/.5Bplanning.20meeting.5D.202022-10-21/near/305370223

We won't need a stable form of this flag until we have a alternative backend that is far enough along to be a candidate to be stabilized (i.e., its "blocked" on that issue, and thus impl-incomplete). Once we do, then we'll figure out whether we need two tracking issues (one for the stable parts of this, and another for the perma-unstable parts), or if we'll just have the one perma-unstable tracking issue.

@pnkfelix
Copy link
Member

@rustbot label: S-tracking-impl-incomplete

@rustbot rustbot added the S-tracking-impl-incomplete Status: The implementation is incomplete. label Oct 21, 2022
@workingjubilee workingjubilee added the A-CLI Area: Command-line interface (CLI) to the compiler label Mar 5, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-CLI Area: Command-line interface (CLI) to the compiler A-codegen Area: Code generation B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC S-tracking-impl-incomplete Status: The implementation is incomplete. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue.
Projects
None yet
Development

No branches or pull requests

5 participants