Skip to content

Commit 258ff09

Browse files
committed
Add documentation for target armv7-rtems-eabihf
1 parent 0bc52bd commit 258ff09

File tree

3 files changed

+52
-1
lines changed

3 files changed

+52
-1
lines changed

Cargo.toml

-1
Original file line numberDiff line numberDiff line change
@@ -105,7 +105,6 @@ debug = 0
105105
strip = true
106106

107107
[patch.crates-io]
108-
libc = { git = "https://github.com/thesummer/libc", rev = "2ada946801aec517051bb00cb83e890f9af5ad37" }
109108
# See comments in `library/rustc-std-workspace-core/README.md` for what's going on
110109
# here
111110
rustc-std-workspace-core = { path = 'library/rustc-std-workspace-core' }

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

+1
Original file line numberDiff line numberDiff line change
@@ -274,6 +274,7 @@ target | std | host | notes
274274
`armv6-unknown-freebsd` | ✓ | ✓ | Armv6 FreeBSD
275275
[`armv6-unknown-netbsd-eabihf`](platform-support/netbsd.md) | ✓ | ✓ | Armv6 NetBSD w/hard-float
276276
[`armv6k-nintendo-3ds`](platform-support/armv6k-nintendo-3ds.md) | ? | | Armv6k Nintendo 3DS, Horizon (Requires devkitARM toolchain)
277+
[`armv7-rtems-eabihf`](platform-support/armv7-rtems-eabihf.md) | ✓ | | RTEMS OS for ARM BSPs
277278
[`armv7-sony-vita-newlibeabihf`](platform-support/armv7-sony-vita-newlibeabihf.md) | ✓ | | Armv7-A Cortex-A9 Sony PlayStation Vita (requires VITASDK toolchain)
278279
[`armv7-unknown-linux-uclibceabi`](platform-support/armv7-unknown-linux-uclibceabi.md) | ✓ | ✓ | Armv7-A Linux with uClibc, softfloat
279280
[`armv7-unknown-linux-uclibceabihf`](platform-support/armv7-unknown-linux-uclibceabihf.md) | ✓ | ? | Armv7-A Linux with uClibc, hardfloat
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,51 @@
1+
# `armv7-rtems-eabihf`
2+
3+
**Tier: 3**
4+
5+
ARM targets for the [RTEMS realtime operating system](https://www.rtems.org) using the RTEMS gcc cross-compiler for linking against the libraries of a specified Board Support Package (BSP).
6+
7+
## Target maintainers
8+
9+
- [@thesummer](https://github.com/thesummer)
10+
11+
## Requirements
12+
13+
The target does not support host tools. Only cross-compilation is possible.
14+
The cross-compiler toolchain can be obtained by following the installation instructions
15+
of the [RTEMS Documentation](https://docs.rtems.org/branches/master/user/index.html). Additionally to the cross-compiler also a compiled BSP
16+
for a board fitting the architecture needs to be available on the host.
17+
Currently tested has been the BSP `xilinx_zynq_a9_qemu` of RTEMS 6.
18+
19+
`std` support is available, but not yet fully tested. Do NOT use in flight software!
20+
21+
The target follows the EABI calling convention for `extern "C"`.
22+
23+
The resulting binaries are in ELF format.
24+
25+
## Building the target
26+
27+
The target can be build by the standard compiler of Rust.
28+
## Building Rust programs
29+
30+
Rust does not yet ship pre-compiled artifacts for this target. To compile for
31+
this target, you will either need to build Rust with the target enabled (see
32+
"Building the target" above), or build your own copy of `core` by using
33+
`build-std` or similar.
34+
35+
In order to build an RTEMS executable it is also necessary to have a basic RTEMS configuration (in C) compiled to link against as this configures the operating system.
36+
An example can be found at this [`rtems-sys`](https://github.com/thesummer/rtems-sys) crate which could be added as an dependency to your application.
37+
38+
## Testing
39+
40+
The resulting binaries run fine on an emulated target (possibly also on a real Zedboard or similar).
41+
For example, on qemu the following command can execute the binary:
42+
```
43+
$ qemu-system-arm -no-reboot -serial null -serial mon:stdio -net none -nographic -M xilinx-zynq-a9 -m 512M -kernel <binary file>
44+
```
45+
46+
While basic execution of the unit test harness seems to work. However, running the Rust testsuite on the (emulated) hardware has not yet been tested.
47+
48+
## Cross-compilation toolchains and C code
49+
50+
Compatible C-code can be built with the RTEMS cross-compiler toolchain `arm-rtems6-gcc`.
51+
For more information how to build the toolchain, RTEMS itself and RTEMS applications please have a look at the [RTEMS Documentation](https://docs.rtems.org/branches/master/user/index.html).

0 commit comments

Comments
 (0)