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

Additions and modifications for the x86_64-unknown-none target #1

Merged
merged 6 commits into from
Sep 19, 2021

Conversation

joshtriplett
Copy link

@joshtriplett joshtriplett commented Sep 19, 2021

Here are all my additions and modifications for the x86_64-unknown-none target, based on the PR branch.

In addition to addressing all the structured suggestions I'd made, I also added target documentation explaining the properties and assumptions of the target, and how to work with it.

Work sponsored by Profian.

Most Rust freestanding/bare-metal targets use just `-unknown-none` here,
including aarch64-unknown-none, mipsel-unknown-none, and the BPF
targets. The *only* target using `-unknown-none-elf` is RISC-V.

The underlying toolchain doesn't care; LLVM accepts both `x86_64-unknown-none`
and `x86_64-unknown-none-elf`.

In addition, there's a long history of embedded x86 targets with varying
definitions for the `elf` suffix; on some of those embedded targets,
`elf` implied the inclusion of a C library based on newlib or similar.
Using `x86_64-unknown-none` avoids any potential ambiguity there.

(Work on this target sponsored by Profian.)
(Work on this target sponsored by Profian.)
(Work on this target sponsored by Profian.)
Based on the list used for x86_64-unknown-none-linuxkernel.

(Work on this target sponsored by Profian.)
Specify the `cpu` and the `max_atomic_width` (64).

Set `stack_probes` similarly to other targets to work around known
issues, and copy the corresponding comment from those targets.

Build position-independent code that doesn't require relocations.

(Work on this target sponsored by Profian.)
In particular, document the default properties and assumptions of code
built for the target.

(Work on this target sponsored by Profian.)
@mikeleany mikeleany merged this pull request into mikeleany:new-target Sep 19, 2021
@joshtriplett joshtriplett deleted the new-target-mods branch September 20, 2021 04:35
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants