Skip to content

Commit 5f160f5

Browse files
committed
Add new {x86_64,i686}-win7-windows-gnu targets
These are in symmetry with `{x86_64,i686}-win7-windows-msvc`.
1 parent 04e0134 commit 5f160f5

File tree

8 files changed

+125
-3
lines changed

8 files changed

+125
-3
lines changed

compiler/rustc_target/src/spec/mod.rs

+3-1
Original file line numberDiff line numberDiff line change
@@ -1782,9 +1782,11 @@ supported_targets! {
17821782
("aarch64-unknown-illumos", aarch64_unknown_illumos),
17831783

17841784
("x86_64-pc-windows-gnu", x86_64_pc_windows_gnu),
1785+
("x86_64-uwp-windows-gnu", x86_64_uwp_windows_gnu),
1786+
("x86_64-win7-windows-gnu", x86_64_win7_windows_gnu),
17851787
("i686-pc-windows-gnu", i686_pc_windows_gnu),
17861788
("i686-uwp-windows-gnu", i686_uwp_windows_gnu),
1787-
("x86_64-uwp-windows-gnu", x86_64_uwp_windows_gnu),
1789+
("i686-win7-windows-gnu", i686_win7_windows_gnu),
17881790

17891791
("aarch64-pc-windows-gnullvm", aarch64_pc_windows_gnullvm),
17901792
("i686-pc-windows-gnullvm", i686_pc_windows_gnullvm),
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
use crate::spec::{Cc, FramePointer, LinkerFlavor, Lld, Target, base};
2+
3+
pub(crate) fn target() -> Target {
4+
let mut base = base::windows_gnu::opts();
5+
base.vendor = "win7".into();
6+
base.cpu = "pentium4".into();
7+
base.max_atomic_width = Some(64);
8+
base.frame_pointer = FramePointer::Always; // Required for backtraces
9+
base.linker = Some("i686-w64-mingw32-gcc".into());
10+
11+
// Mark all dynamic libraries and executables as compatible with the larger 4GiB address
12+
// space available to x86 Windows binaries on x86_64.
13+
base.add_pre_link_args(LinkerFlavor::Gnu(Cc::No, Lld::No), &[
14+
"-m",
15+
"i386pe",
16+
"--large-address-aware",
17+
]);
18+
base.add_pre_link_args(LinkerFlavor::Gnu(Cc::Yes, Lld::No), &["-Wl,--large-address-aware"]);
19+
20+
Target {
21+
llvm_target: "i686-pc-windows-gnu".into(),
22+
metadata: crate::spec::TargetMetadata {
23+
description: Some("32-bit MinGW (Windows 7+)".into()),
24+
tier: Some(3),
25+
host_tools: Some(false),
26+
std: Some(true),
27+
},
28+
pointer_width: 32,
29+
data_layout: "e-m:x-p:32:32-p270:32:32-p271:32:32-p272:64:64-\
30+
i64:64-i128:128-f80:32-n8:16:32-a:0:32-S32"
31+
.into(),
32+
arch: "x86".into(),
33+
options: base,
34+
}
35+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
use crate::spec::{Cc, LinkerFlavor, Lld, Target, base};
2+
3+
pub(crate) fn target() -> Target {
4+
let mut base = base::windows_gnu::opts();
5+
base.vendor = "win7".into();
6+
base.cpu = "x86-64".into();
7+
base.plt_by_default = false;
8+
// Use high-entropy 64 bit address space for ASLR
9+
base.add_pre_link_args(LinkerFlavor::Gnu(Cc::No, Lld::No), &[
10+
"-m",
11+
"i386pep",
12+
"--high-entropy-va",
13+
]);
14+
base.add_pre_link_args(LinkerFlavor::Gnu(Cc::Yes, Lld::No), &["-m64", "-Wl,--high-entropy-va"]);
15+
base.max_atomic_width = Some(64);
16+
base.linker = Some("x86_64-w64-mingw32-gcc".into());
17+
18+
Target {
19+
llvm_target: "x86_64-pc-windows-gnu".into(),
20+
metadata: crate::spec::TargetMetadata {
21+
description: Some("64-bit MinGW (Windows 7+)".into()),
22+
tier: Some(3),
23+
host_tools: Some(false),
24+
std: Some(true),
25+
},
26+
pointer_width: 64,
27+
data_layout:
28+
"e-m:w-p270:32:32-p271:32:32-p272:64:64-i64:64-i128:128-f80:128-n8:16:32:64-S128".into(),
29+
arch: "x86_64".into(),
30+
options: base,
31+
}
32+
}

src/doc/rustc/src/SUMMARY.md

+1
Original file line numberDiff line numberDiff line change
@@ -93,6 +93,7 @@
9393
- [wasm32-unknown-unknown](platform-support/wasm32-unknown-unknown.md)
9494
- [wasm32v1-none](platform-support/wasm32v1-none.md)
9595
- [wasm64-unknown-unknown](platform-support/wasm64-unknown-unknown.md)
96+
- [\*-win7-windows-gnu](platform-support/win7-windows-gnu.md)
9697
- [\*-win7-windows-msvc](platform-support/win7-windows-msvc.md)
9798
- [x86_64-fortanix-unknown-sgx](platform-support/x86_64-fortanix-unknown-sgx.md)
9899
- [x86_64-pc-solaris](platform-support/solaris.md)

src/doc/rustc/src/platform-support.md

+2
Original file line numberDiff line numberDiff line change
@@ -313,6 +313,7 @@ target | std | host | notes
313313
[`i686-unknown-redox`](platform-support/redox.md) | ✓ | | i686 Redox OS
314314
`i686-uwp-windows-gnu` | ✓ | | [^x86_32-floats-return-ABI]
315315
`i686-uwp-windows-msvc` | ✓ | | [^x86_32-floats-return-ABI]
316+
[`i686-win7-windows-gnu`](platform-support/win7-windows-gnu.md) | ✓ | | 32-bit Windows 7 support [^x86_32-floats-return-ABI]
316317
[`i686-win7-windows-msvc`](platform-support/win7-windows-msvc.md) | ✓ | | 32-bit Windows 7 support [^x86_32-floats-return-ABI]
317318
[`i686-wrs-vxworks`](platform-support/vxworks.md) | ✓ | | [^x86_32-floats-return-ABI]
318319
[`loongarch64-unknown-linux-ohos`](platform-support/openharmony.md) | ✓ | | LoongArch64 OpenHarmony
@@ -391,6 +392,7 @@ target | std | host | notes
391392
[`x86_64-unknown-trusty`](platform-support/trusty.md) | ? | |
392393
`x86_64-uwp-windows-gnu` | ✓ | |
393394
`x86_64-uwp-windows-msvc` | ✓ | |
395+
[`x86_64-win7-windows-gnu`](platform-support/win7-windows-gnu.md) | ✓ | | 64-bit Windows 7 support
394396
[`x86_64-win7-windows-msvc`](platform-support/win7-windows-msvc.md) | ✓ | | 64-bit Windows 7 support
395397
[`x86_64-wrs-vxworks`](platform-support/vxworks.md) | ✓ | |
396398
[`x86_64h-apple-darwin`](platform-support/x86_64h-apple-darwin.md) | ✓ | ✓ | macOS with late-gen Intel (at least Haswell)
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
# \*-win7-windows-gnu
2+
3+
**Tier: 3**
4+
5+
Windows targets continuing support of Windows 7.
6+
7+
## Target maintainers
8+
9+
- @tbu-
10+
11+
## Requirements
12+
13+
This target supports all of core, alloc, std and test. Host
14+
tools may also work, though those are not currently tested.
15+
16+
Those targets follow Windows calling convention for extern "C".
17+
18+
Like any other Windows target, the created binaries are in PE format.
19+
20+
## Building the target
21+
22+
You can build Rust with support for the targets by adding it to the target list in config.toml:
23+
24+
```toml
25+
[build]
26+
build-stage = 1
27+
target = ["x86_64-win7-windows-gnu"]
28+
```
29+
30+
## Building Rust programs
31+
32+
Rust does not ship pre-compiled artifacts for this target. To compile for this
33+
target, you will either need to build Rust with the target enabled (see
34+
"Building the target" above), or build your own copy by using `build-std` or
35+
similar.
36+
37+
## Testing
38+
39+
Created binaries work fine on Windows or Wine using native hardware. Remote
40+
testing is possible using the `remote-test-server` described [here](https://rustc-dev-guide.rust-lang.org/tests/running.html#running-tests-on-a-remote-machine).
41+
42+
## Cross-compilation toolchains and C code
43+
44+
Compatible C code can be built with gcc's `{i686,x86_64}-w64-mingw32-gcc`.

src/doc/rustc/src/platform-support/win7-windows-msvc.md

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
1-
# *-win7-windows-msvc
1+
# \*-win7-windows-msvc
22

33
**Tier: 3**
44

5-
Windows targets continuing support of windows7.
5+
Windows targets continuing support of Windows 7.
66

77
## Target maintainers
88

tests/assembly/targets/targets-pe.rs

+6
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,9 @@
3939
//@ revisions: i686_uwp_windows_gnu
4040
//@ [i686_uwp_windows_gnu] compile-flags: --target i686-uwp-windows-gnu
4141
//@ [i686_uwp_windows_gnu] needs-llvm-components: x86
42+
//@ revisions: i686_win7_windows_gnu
43+
//@ [i686_win7_windows_gnu] compile-flags: --target i686-win7-windows-gnu
44+
//@ [i686_win7_windows_gnu] needs-llvm-components: x86
4245
//@ revisions: i686_unknown_uefi
4346
//@ [i686_unknown_uefi] compile-flags: --target i686-unknown-uefi
4447
//@ [i686_unknown_uefi] needs-llvm-components: x86
@@ -72,6 +75,9 @@
7275
//@ revisions: x86_64_uwp_windows_gnu
7376
//@ [x86_64_uwp_windows_gnu] compile-flags: --target x86_64-uwp-windows-gnu
7477
//@ [x86_64_uwp_windows_gnu] needs-llvm-components: x86
78+
//@ revisions: x86_64_win7_windows_gnu
79+
//@ [x86_64_win7_windows_gnu] compile-flags: --target x86_64-win7-windows-gnu
80+
//@ [x86_64_win7_windows_gnu] needs-llvm-components: x86
7581
//@ revisions: x86_64_uwp_windows_msvc
7682
//@ [x86_64_uwp_windows_msvc] compile-flags: --target x86_64-uwp-windows-msvc
7783
//@ [x86_64_uwp_windows_msvc] needs-llvm-components: x86

0 commit comments

Comments
 (0)