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 #[repr(align(...))] on function items (fn_align) #82232

Open
1 of 3 tasks
repnop opened this issue Feb 17, 2021 · 4 comments
Open
1 of 3 tasks

Tracking Issue for #[repr(align(...))] on function items (fn_align) #82232

repnop opened this issue Feb 17, 2021 · 4 comments
Labels
A-align Area: alignment control (`repr(align(N))` and so on) A-rust-for-linux Relevant for the Rust-for-Linux project C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC F-fn_align `#![feature(fn_align)]` T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-lang Relevant to the language team, which will review and decide on the PR/issue.

Comments

@repnop
Copy link
Contributor

repnop commented Feb 17, 2021

This feature allows specifying an alignment for function items by adding the #[repr(align(...))] attribute to them.
The feature gate for the issue is #![feature(fn_align)]

Example

#[repr(align(16))]
fn requires_alignment() {
    // ...
}

Steps

@repnop repnop added the C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC label Feb 17, 2021
@repnop repnop changed the title Tracking Issue for #[repr(align = ...)] on function items (fn_align) Tracking Issue for #[repr(align(...))] on function items (fn_align) Feb 17, 2021
@evanrichter
Copy link
Contributor

Is it be possible to apply this to methods as well?

#![feature(fn_align)]

#[repr(align(1))]
fn main() {
    Bar::foo();
}

struct Bar;

impl Bar {
    #[repr(align(1))]
    fn foo() {
        println!("bar");
    }
}
error[E0517]: attribute should be applied to a struct, enum, function, or union
  --> src/main.rs:11:12
   |
11 |       #[repr(align(1))]
   |              ^^^^^^^^
12 | /     fn foo() {
13 | |         println!("bar");
14 | |     }
   | |_____- not a struct, enum, function, or union

For more information about this error, try `rustc --explain E0517`.
error: could not compile `asdf` due to previous error

@repnop
Copy link
Contributor Author

repnop commented Aug 26, 2021

I don't see why not? (I'm surprised it doesn't work already honestly lol) I'll see if I can find some time to investigate that and make another PR to allow that 👍

winksaville added a commit to winksaville/exper-borrowed-vs-owned-parameters that referenced this issue Dec 3, 2022
MessageMf has "Many fields" making it able to see how borrowed and
owned scale differently.

Added benchmarking creating default instances of Message and
MessageMf.

Removed the xxx_loop() variants as they don't add information just more
noise. I would like to look at why xxx_idx_loop() is sometimes slower
than xxx_iter_loop().

NOTE: I believe some of the noise is caused by code alignment changes
as we tweak that where doing and change code.
See: https://www.google.com/search?q=benchmark+sensitive+to+code+alignment
and rust-lang/rust#82232
@bunnie
Copy link
Contributor

bunnie commented Dec 25, 2022

Thanks for opening this, I just bumped my head into this exact problem as well!

@workingjubilee
Copy link
Member

This should come with a command-line flag to address the request made in #128830 for global code alignment control.

@workingjubilee workingjubilee added the A-rust-for-linux Relevant for the Rust-for-Linux project label Aug 8, 2024
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this issue Aug 28, 2024
…tions, r=workingjubilee,compiler-errors

add repr to the allowlist for naked functions

Fixes rust-lang#129412 (combining unstable features rust-lang#90957 (`#![feature(naked_functions)]`) and rust-lang#82232 (`#![feature(fn_align)]`)
rust-timer added a commit to rust-lang-ci/rust that referenced this issue Aug 28, 2024
Rollup merge of rust-lang#129421 - jdonszelmann:naked-repr-align-functions, r=workingjubilee,compiler-errors

add repr to the allowlist for naked functions

Fixes rust-lang#129412 (combining unstable features rust-lang#90957 (`#![feature(naked_functions)]`) and rust-lang#82232 (`#![feature(fn_align)]`)
@jieyouxu jieyouxu added the F-fn_align `#![feature(fn_align)]` label Nov 1, 2024
@workingjubilee workingjubilee added A-align Area: alignment control (`repr(align(N))` and so on) F-fn_align `#![feature(fn_align)]` and removed F-fn_align `#![feature(fn_align)]` A-align Area: alignment control (`repr(align(N))` and so on) labels Nov 1, 2024
@workingjubilee workingjubilee added T-lang Relevant to the language team, which will review and decide on the PR/issue. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. labels Jan 10, 2025
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this issue Jan 11, 2025
…jubilee

add `-Zmin-function-alignment`

tracking issue: rust-lang#82232

This PR adds the `-Zmin-function-alignment=<align>` flag, that specifies a minimum alignment for all* functions.

### Motivation

This feature is requested by RfL [here](rust-lang#128830):

> i.e. the equivalents of `-fmin-function-alignment` ([GCC](https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#index-fmin-function-alignment_003dn), Clang does not support it) / `-falign-functions` ([GCC](https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#index-falign-functions), [Clang](https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang1-falign-functions)).
>
> For the Linux kernel, the behavior wanted is that of GCC's `-fmin-function-alignment` and Clang's `-falign-functions`, i.e. align all functions, including cold functions.
>
> There is [`feature(fn_align)`](rust-lang#82232), but we need to do it globally.

### Behavior

The `fn_align` feature does not have an RFC. It was decided at the time that it would not be necessary, but maybe we feel differently about that now? In any case, here are the semantics of this flag:

- `-Zmin-function-alignment=<align>` specifies the minimum alignment of all* functions
- the `#[repr(align(<align>))]` attribute can be used to override the function alignment on a per-function basis: when `-Zmin-function-alignment` is specified, the attribute's value is only used when it is higher than the value passed to `-Zmin-function-alignment`.
- the target may decide to use a higher value (e.g. on x86_64 the minimum that LLVM generates is 16)
- The highest supported alignment in rust is `2^29`: I checked a bunch of targets, and they all emit the `.p2align        29` directive for targets that align functions at all (some GPU stuff does not have function alignment).

*: Only with `build-std` would the minimum alignment also be applied to `std` functions.

---

cc `@ojeda`

r? `@workingjubilee` you were active on the tracking issue
rust-timer added a commit to rust-lang-ci/rust that referenced this issue Jan 11, 2025
Rollup merge of rust-lang#134030 - folkertdev:min-fn-align, r=workingjubilee

add `-Zmin-function-alignment`

tracking issue: rust-lang#82232

This PR adds the `-Zmin-function-alignment=<align>` flag, that specifies a minimum alignment for all* functions.

### Motivation

This feature is requested by RfL [here](rust-lang#128830):

> i.e. the equivalents of `-fmin-function-alignment` ([GCC](https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#index-fmin-function-alignment_003dn), Clang does not support it) / `-falign-functions` ([GCC](https://gcc.gnu.org/onlinedocs/gcc/Optimize-Options.html#index-falign-functions), [Clang](https://clang.llvm.org/docs/ClangCommandLineReference.html#cmdoption-clang1-falign-functions)).
>
> For the Linux kernel, the behavior wanted is that of GCC's `-fmin-function-alignment` and Clang's `-falign-functions`, i.e. align all functions, including cold functions.
>
> There is [`feature(fn_align)`](rust-lang#82232), but we need to do it globally.

### Behavior

The `fn_align` feature does not have an RFC. It was decided at the time that it would not be necessary, but maybe we feel differently about that now? In any case, here are the semantics of this flag:

- `-Zmin-function-alignment=<align>` specifies the minimum alignment of all* functions
- the `#[repr(align(<align>))]` attribute can be used to override the function alignment on a per-function basis: when `-Zmin-function-alignment` is specified, the attribute's value is only used when it is higher than the value passed to `-Zmin-function-alignment`.
- the target may decide to use a higher value (e.g. on x86_64 the minimum that LLVM generates is 16)
- The highest supported alignment in rust is `2^29`: I checked a bunch of targets, and they all emit the `.p2align        29` directive for targets that align functions at all (some GPU stuff does not have function alignment).

*: Only with `build-std` would the minimum alignment also be applied to `std` functions.

---

cc `@ojeda`

r? `@workingjubilee` you were active on the tracking issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-align Area: alignment control (`repr(align(N))` and so on) A-rust-for-linux Relevant for the Rust-for-Linux project C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC F-fn_align `#![feature(fn_align)]` T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-lang Relevant to the language team, which will review and decide on the PR/issue.
Projects
None yet
Development

No branches or pull requests

5 participants