-
Notifications
You must be signed in to change notification settings - Fork 13k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #88321 - glaubitz:m68k-linux, r=wesleywiser
Add initial support for m68k This patch series adds initial support for m68k making use of the new M68k backend introduced with LLVM-13. Additional changes will be needed to be able to actually use the backend for this target.
- Loading branch information
Showing
18 changed files
with
196 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -76,6 +76,7 @@ fn main() { | |
"aarch64", | ||
"amdgpu", | ||
"avr", | ||
"m68k", | ||
"mips", | ||
"powerpc", | ||
"systemz", | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
use crate::abi::call::{ArgAbi, FnAbi}; | ||
|
||
fn classify_ret<Ty>(ret: &mut ArgAbi<'_, Ty>) { | ||
if ret.layout.is_aggregate() { | ||
ret.make_indirect(); | ||
} else { | ||
ret.extend_integer_width_to(32); | ||
} | ||
} | ||
|
||
fn classify_arg<Ty>(arg: &mut ArgAbi<'_, Ty>) { | ||
if arg.layout.is_aggregate() { | ||
arg.make_indirect_byval(); | ||
} else { | ||
arg.extend_integer_width_to(32); | ||
} | ||
} | ||
|
||
pub fn compute_abi_info<Ty>(fn_abi: &mut FnAbi<'_, Ty>) { | ||
if !fn_abi.ret.is_ignore() { | ||
classify_ret(&mut fn_abi.ret); | ||
} | ||
|
||
for arg in &mut fn_abi.args { | ||
if arg.is_ignore() { | ||
continue; | ||
} | ||
classify_arg(arg); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
use crate::abi::Endian; | ||
use crate::spec::{Target, TargetOptions}; | ||
|
||
pub fn target() -> Target { | ||
let mut base = super::linux_base::opts(); | ||
base.max_atomic_width = Some(32); | ||
|
||
Target { | ||
llvm_target: "m68k-unknown-linux-gnu".to_string(), | ||
pointer_width: 32, | ||
data_layout: "E-m:e-p:32:16:32-i8:8:8-i16:16:16-i32:16:32-n8:16:32-a:0:16-S16".to_string(), | ||
arch: "m68k".to_string(), | ||
options: TargetOptions { endian: Endian::Big, mcount: "_mcount".to_string(), ..base }, | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
26 changes: 26 additions & 0 deletions
26
src/ci/docker/host-x86_64/disabled/dist-m68k-linux/Dockerfile
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
FROM ubuntu:20.04 | ||
|
||
RUN apt-get update && apt-get install -y --no-install-recommends \ | ||
g++ \ | ||
make \ | ||
file \ | ||
curl \ | ||
ca-certificates \ | ||
python2.7 \ | ||
git \ | ||
cmake \ | ||
sudo \ | ||
gdb \ | ||
xz-utils \ | ||
g++-m68k-linux-gnu \ | ||
libssl-dev \ | ||
pkg-config | ||
|
||
|
||
COPY scripts/sccache.sh /scripts/ | ||
RUN sh /scripts/sccache.sh | ||
|
||
ENV HOSTS=m68k-unknown-linux-gnu | ||
|
||
ENV RUST_CONFIGURE_ARGS --host=$HOSTS --enable-extended | ||
ENV SCRIPT python3 ../x.py dist --host $HOSTS --target $HOSTS |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
97 changes: 97 additions & 0 deletions
97
src/doc/rustc/src/platform-support/m68k-unknown-linux-gnu.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
# m68k-unknown-linux-gnu | ||
|
||
**Tier: 3** | ||
|
||
Motorola 680x0 Linux | ||
|
||
## Designated Developers | ||
|
||
* [@glaubitz](https://github.com/glaubitz) | ||
* [@ricky26](https://github.com/ricky26) | ||
|
||
## Requirements | ||
|
||
This target requires a Linux/m68k build environment for cross-compilation which | ||
is available on Debian and Debian-based systems, openSUSE and other distributions. | ||
|
||
On Debian, it should be sufficient to install a g++ cross-compiler for the m68k | ||
architecture which will automatically pull in additional dependencies such as | ||
the glibc cross development package: | ||
|
||
```text | ||
# apt install g++-m68k-linux-gnu | ||
``` | ||
|
||
Binaries can be run using QEMU user emulation. On Debian-based systems, it should be | ||
sufficient to install the package `qemu-user-static` to be able to run simple static | ||
binaries: | ||
|
||
```text | ||
# apt install qemu-user-static | ||
``` | ||
|
||
To run more complex programs, it will be necessary to set up a Debian/m68k chroot with | ||
the help of the command `debootstrap`: | ||
|
||
```text | ||
# apt install debootstrap debian-ports-archive-keyring | ||
# debootstrap --keyring=/usr/share/keyrings/debian-ports-archive-keyring.gpg --arch=m68k unstable debian-68k http://ftp.ports.debian.org/debian-ports | ||
``` | ||
|
||
This chroot can then seamlessly entered using the normal `chroot` command thanks to | ||
QEMU user emulation: | ||
|
||
```text | ||
# chroot /path/to/debian-68k | ||
``` | ||
|
||
To get started with native builds, which are currently untested, a native Debian/m68k | ||
system can be installed either on real hardware such as 68k-based Commodore Amiga or | ||
Atari systems or emulated environments such as QEMU version 4.2 or newer or ARAnyM. | ||
|
||
ISO images for installation are provided by the Debian Ports team and can be obtained | ||
from the Debian CD image server available at: | ||
|
||
[https://cdimage.debian.org/cdimage/ports/current](https://cdimage.debian.org/cdimage/ports/current/) | ||
|
||
Documentation for Debian/m68k is available on the Debian Wiki at: | ||
|
||
[https://wiki.debian.org/M68k](https://wiki.debian.org/M68k) | ||
|
||
Support is available either through the `debian-68k` mailing list: | ||
|
||
[https://lists.debian.org/debian-68k/](https://lists.debian.org/debian-68k/) | ||
|
||
or the `#debian-68k` IRC channel on OFTC network. | ||
|
||
## Building | ||
|
||
The codegen for this target should be built by default. However, core and std | ||
are currently missing but are being worked on and should become available in | ||
the near future. | ||
|
||
## Cross-compilation | ||
|
||
This target can be cross-compiled from a standard Debian or Debian-based, openSUSE or any | ||
other distribution which has a basic m68k cross-toolchain available. | ||
|
||
## Testing | ||
|
||
Currently there is no support to run the rustc test suite for this target. | ||
|
||
## Building Rust programs | ||
|
||
Rust programs can be built for that target: | ||
|
||
```text | ||
rustc --target m68k-unknown-linux-gnu your-code.rs | ||
``` | ||
|
||
Very simple progams can be run using the `qemu-m68k-static` program: | ||
|
||
```text | ||
$ qemu-m68k-static your-code | ||
``` | ||
|
||
For more complex applications, a chroot or native (emulated) Debian/m68k system are required | ||
for testing. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters