Skip to content

Commit 4dda8d9

Browse files
authored
Rollup merge of #146178 - folkertdev:static-align, r=jdonszelmann,ralfjung,traviscross
Implement `#[rustc_align_static(N)]` on `static`s Tracking issue: rust-lang/rust#146177 ```rust #![feature(static_align)] #[rustc_align_static(64)] static SO_ALIGNED: u64 = 0; ``` We need a different attribute than `rustc_align` because unstable attributes are tied to their feature (we can't have two unstable features use the same unstable attribute). Otherwise this uses all of the same infrastructure as `#[rustc_align]`. r? `@traviscross`
2 parents 624caf5 + a829d03 commit 4dda8d9

File tree

1 file changed

+14
-0
lines changed

1 file changed

+14
-0
lines changed

tests/pass/static_align.rs

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
#![feature(static_align)]
2+
3+
// When a static uses `align(N)`, its address should be a multiple of `N`.
4+
5+
#[rustc_align_static(256)]
6+
static FOO: u64 = 0;
7+
8+
#[rustc_align_static(512)]
9+
static BAR: u64 = 0;
10+
11+
fn main() {
12+
assert!(core::ptr::from_ref(&FOO).addr().is_multiple_of(256));
13+
assert!(core::ptr::from_ref(&BAR).addr().is_multiple_of(512));
14+
}

0 commit comments

Comments
 (0)