Skip to content

Commit

Permalink
Add support for arm-unknown-linux-musleabi{,hf} targets.
Browse files Browse the repository at this point in the history
These targets will be similar to the x86_64-unknown-linux-musl
target, in that they'll use MUSL libc to allow fully static binaries
to be generated. To remain consistent with the naming of existing
ARM targets, as well as with the standard naming of MUSL toolchains,
we'll use `musleabi` and `musleabihf` as the target environment
names (analogous to `gnueabi` and `gnueabihf`).

Most of these changes just extend the special casing for x86_64 MUSL
targets to the ARM ones as well.
  • Loading branch information
timonvo committed Apr 16, 2016
1 parent bab6a37 commit ad72859
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 9 deletions.
9 changes: 6 additions & 3 deletions src/unix/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,9 @@ s! {
pub ru_nvcsw: c_long,
pub ru_nivcsw: c_long,

#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
__reserved: [c_long; 16],
}

Expand Down Expand Up @@ -149,8 +151,9 @@ cfg_if! {
} else if #[cfg(all(not(stdbuild), feature = "use_std"))] {
// cargo build, don't pull in anything extra as the libstd dep
// already pulls in all libs.
} else if #[cfg(all(target_env = "musl", not(any(target_arch = "mips",
target_arch = "arm"))))] {
} else if #[cfg(any(all(target_env = "musl", not(target_arch = "mips")),
target_env = "musleabi",
target_env = "musleabihf"))] {
#[link(name = "c", kind = "static")]
extern {}
} else if #[cfg(target_os = "emscripten")] {
Expand Down
10 changes: 8 additions & 2 deletions src/unix/notbsd/linux/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -93,9 +93,13 @@ s! {
}

pub struct pthread_cond_t {
#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
__align: [*const ::c_void; 0],
#[cfg(not(target_env = "musl"))]
#[cfg(not(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf")))]
__align: [::c_longlong; 0],
size: [u8; __SIZEOF_PTHREAD_COND_T],
}
Expand Down Expand Up @@ -615,6 +619,8 @@ extern {

cfg_if! {
if #[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf",
target_os = "emscripten"))] {
mod musl;
pub use self::musl::*;
Expand Down
16 changes: 12 additions & 4 deletions src/unix/notbsd/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,13 +99,21 @@ s! {

pub struct sched_param {
pub sched_priority: ::c_int,
#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
pub sched_ss_low_priority: ::c_int,
#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
pub sched_ss_repl_period: ::timespec,
#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
pub sched_ss_init_budget: ::timespec,
#[cfg(target_env = "musl")]
#[cfg(any(target_env = "musl",
target_env = "musleabi",
target_env = "musleabihf"))]
pub sched_ss_max_repl: ::c_int,
}

Expand Down

0 comments on commit ad72859

Please sign in to comment.