Daniel McKenna
6acbf873db
Fixed issues in test and struct names.
...
Fixed the issues that prevented the libc_tests that are generated from passing. Also, fixed struct names and types to be representative of the linux source files.
2017-05-29 18:27:27 +01:00
bors
fda4049c11
Auto merge of #596 - Susurrus:master, r=alexcrichton
...
Use NOCANCEL variants for close on Mac
The default `close()` on OS X does not provide clear errors, instead the `$NOCANCEL` variants should be used. These are available as of OS X 10.6 onwards.
Fixes #595 .
2017-05-19 14:10:33 +00:00
Bryant Mairs
9b9f36aefc
Use NOCANCEL variants for close on Mac
...
The default on OS X does not provide clear errors,
instead the NOCANCEL variants should be used. These are available
as of OS X 10.6 onwards.
2017-05-18 12:04:28 -07:00
Lee Bousfield
98889cf243
Add ENOATTR for Linux
2017-05-18 09:02:25 -06:00
bors
19f3be3638
Auto merge of #578 - cactorium:master, r=alexcrichton
...
Steps towards support for musl-unknown-linux-uclibc
Hello! I've been working towards resolving https://github.com/rust-lang/libc/issues/361 , this PR compiles successfully with a newish compiler (with some minor fixes in `gcc`, `ctest`), and all the tests pass for `libc-ctest`. Basically most of the undefined functions, constants, and structs were just removed from the ctest, and then any constants that weren't correct were fixed. Would it make more sense to conditionally remove them from libc? I wasn't sure when it was appropriate to skip the test for it instead of removing the function/constants, so I just removed all the tests for now because that was a little easier than hunting them down. I'm also guessing the way some of the constants were conditionally set wasn't the correct style, would you guys have any advice on how to do it more correctly? Lemme know how it looks!
2017-05-08 14:49:12 +00:00
Lee Bousfield
fdbfe8fc91
Add xattr functions for OSX
2017-05-07 17:05:51 -06:00
Kelvin Ly
c0bec43234
Remove MAP_HUGETLB from mips-unknown-linux-uclibc
2017-05-06 02:49:54 -04:00
Kelvin Ly
96a830648d
Merge branch 'master' into master
2017-05-04 22:08:48 -04:00
bors
03562b0cb2
Auto merge of #585 - jonhoo:res_init, r=alexcrichton
...
Add res_init
The `res_init` function, while deprecated, is critical for making networked applications work correctly when switching between networks, or between being offline and online. By default, `getaddrinfo` and friends use a cached version of `/etc/resolv.conf`, which means that network changes are not picked up by applications after they first start up. This has bitten [Firefox](https://bugzilla.mozilla.org/show_bug.cgi?id=214538 ), [Pidgin](https://developer.pidgin.im/ticket/2825 ), [MongoDB](https://jira.mongodb.org/browse/DOCS-5700 ), and more in the past.
The logic behind exposing only `res_init` is that it is the only `res_*` function that is frequently called directly by user applications. The other `res_*` functions provide low-level access to domain lookups, whereas `res_init` is useful even if the application itself is not concerned with doing lookups.
Behind the scenes, `getaddrinfo` in glibc [ultimately calls](a2f34833b1/resolv/nss_dns/dns-host.c (L196)
) `res_nsearch` with `&_res`. `res_init` operates directly on this global reference, and is thus more useful to expose for most applications than the non-deprecated `res_ninit` function (which operators on an arbitrary `res_state`).
As far as I can tell, `res_init` is available in [FreeBSD](https://www.freebsd.org/cgi/man.cgi?query=res_init&manpath=SuSE+Linux/i386+11.3 ), [NetBSD](http://netbsd.gw.com/cgi-bin/man-cgi?res_init+3+NetBSD-6.1 ), [OpenBSD](http://man.openbsd.org/resolver.3 ), [Solaris](http://www.polarhome.com/service/man/?qf=res_init&tf=2&of=Solaris&sf= ), [Linux](https://linux.die.net/man/3/res_init ), and [macOS](https://developer.apple.com/legacy/library/documentation/Darwin/Reference/ManPages/man3/res_init.3.html ).
2017-05-03 22:30:49 +00:00
Jon Gjengset
be7e45f6f5
Skip res_init test on macOS/iOS
2017-05-03 15:57:39 -04:00
NODA, Kai
61c23fb927
Add Linux-specific recvmmsg(2) and sendmmsg(2)
...
There is a compatibility issue regarding the type of a flag parameter:
int vs uint. Linux does declare the syscall to use uint and musl
followed it, but it is incompatible with other POSIX recv*/send*
syscalls. So it seems to be wise to follow the glibc version of
prototypes with int.
Signed-off-by: NODA, Kai <nodakai@gmail.com>
2017-05-02 07:46:52 -04:00
Jon Gjengset
afebd98131
Android doesn't expose res_init in header file
2017-04-28 22:23:33 -04:00
Jon Gjengset
ef20ddbc57
Add binding for res_init.
...
Some notes about the particularities of the changes:
res_init has been deprecated in favor of res_ninit, and many (but not
all) targets have therefore renamed the link name to __res_init. For
example, this happened in glibc in version 2.2:
https://bugzilla.redhat.com/show_bug.cgi?id=43822#c6
In these systems, res_init is #defined to __res_init in resolv.h, which
lets existing C programs continue to be compiled.
Unfortunately, this define doesn't automatically apply to our Rust code.
We therefore need to manually map the link name of res_init as
appropriate for each target:
macOS and iOS use res_9_init: 3908694d63/src/libresolv/resolv.h (L316)
Solaris uses res_init: https://java.net/projects/solaris/sources/on-src/content/usr/src/head/resolv.h
OpenBSD uses __res_init: f3b3b7c7ca/include/resolv.h (L268)
FreeBSD uses __res_init: 6911f4a88c/include/resolv.h (L290)
NetBSD uses __res_init: http://ftp.netbsd.org/pub/NetBSD/NetBSD-current/src/include/resolv.h
glibc uses __res_init: a2f34833b1/resolv/resolv.h (L259)
eglibc uses __res_init: 7f0bcce417/resolv/resolv.h (L259)
musl uses res_init: 0a11d7cb13/include/resolv.h (L128)
Android uses res_init: 306ea55952/libc/include/resolv.h (L57)
One caveat here is that NetBSD doesn't seem to use the symbol name
__res_init yet, despite the redefine being present in resolv.h. At least
Travis fails for the netbsd target if __res_init is used. This may
change in the future.
iOS and macOS both unfortunately require linking with libresolv, despite
the symbols technically being available without libresolv:
resolv: http://blog.achernya.com/2013/03/os-x-has-silly-libsystem.html
Android and OpenBSD fall in the same category.
2017-04-28 10:58:25 -04:00
Kelvin Ly
c14178c305
Fix indentation, remove more constants that don't work for uclibc
2017-04-26 23:01:05 -04:00
Kelvin Ly
2a9b6470d6
Remove extra comment
2017-04-21 18:34:12 -04:00
Kelvin Ly
26670c77b7
Fix build errors for mips-unknown-linux-uclibc
2017-04-21 18:20:08 -04:00
Kelvin Ly
2d6c7dad20
Fix more stuff after updating libc
2017-04-20 18:42:59 -04:00
bors
c34a802d1e
Auto merge of #572 - malbarbo:android-x86_64, r=alexcrichton
...
Add x86_64-linux-android support
When rust add support for x86_64-linux-android, the tests may be run with:
`rustup target add x86_64-linux-android && bash ci/run-docker.sh x86_64-linux-android`.
Android x86_64 emulator does not work without hardware acceleration, so we are not able to run tests on travis.
2017-04-20 14:46:39 +00:00
Kelvin Ly
9a835580a6
Add changes to allow uclibc to build
2017-04-20 02:37:31 -04:00
Marco A L Barbosa
3ca6ad9a3f
Fix x86_64-linux-android failing tests
2017-04-19 12:24:45 -03:00
superriva
2122616185
Add IPC,SHM,MSG for Freebsd
...
INFO for the patch:
FREEBSD [https://github.com/freebsd/freebsd ]
/sys/sys/_types.h
typedef long __key_t;
/sys/sys/types.h
typedef __key_t key_t;
/sys/sys/ipc.h
struct ipc_perm {
uid_t cuid;
gid_t cgid;
uid_t uid;
gid_t gid;
mode_t mode;
unsigned short seq;
key_t key;
};
key_t ftok(const char *, int);
/sys/sys/msg.h
typedef unsigned long msglen_t;
typedef unsigned long msgqnum_t;
struct msqid_ds {
struct ipc_perm msg_perm;
struct msg *msg_first;
struct msg *msg_last;
msglen_t msg_cbytes;
msgqnum_t msg_qnum;
msglen_t msg_qbytes;
pid_t msg_lspid;
pid_t msg_lrpid;
time_t msg_stime;
time_t msg_rtime;
time_t msg_ctime;
};
struct msg {
struct msg *msg_next;
long msg_type;
u_short msg_ts;
short msg_spot;
struct label *label;
};
struct msginfo {
int msgmax,
msgmni,
msgmnb,
msgtql,
msgssz,
msgseg;
};
int msgctl(int, int, struct msqid_ds *);
int msgget(key_t, int);
ssize_t msgrcv(int, void *, size_t, long, int);
int msgsnd(int, const void *, size_t, int);
/sys/sys/shm.h
typedef unsigned int shmatt_t;
struct shmid_ds {
struct ipc_perm shm_perm;
size_t shm_segsz;
pid_t shm_lpid;
pid_t shm_cpid;
shmatt_t shm_nattch;
time_t shm_atime;
time_t shm_dtime;
time_t shm_ctime;
};
void *shmat(int, const void *, int);
int shmget(key_t, size_t, int);
int shmctl(int, int, struct shmid_ds *);
int shmdt(const void *);
/sys/security/mac/mac_internal.h
struct label {
int l_flags;
intptr_t l_perpolicy[MAC_MAX_SLOTS];
};
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update build.rs
Update mod.rs
Update mod.rs
Update build.rs
Update mod.rs
Update build.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update mod.rs
Update build.rs
Update build.rs
Update mod.rs
Update mod.rs
2017-04-04 10:13:43 +03:00
Marco A L Barbosa
bfeb3606f2
Merge branch 'master' into ci-android
2017-02-27 17:25:43 -03:00
bors
dc1aa0e2c0
Auto merge of #530 - berkowski:baud_constants, r=alexcrichton
...
Added baudrate constants.
Addresses #528 , adding baudrate constants for `bsd` and `notbsd` flavors of `unix`.
Passes `libc-test` locally on ubuntu 14.04 LTS with the additional (uncommitted) entries into in `build.rs`:
```
cfg.skip_const( move |name| {
match name {
# ... snip ...
"PTRACE_O_SUSPEND_SECCOMP" |
"CLONE_NEWCGROUP" |
"NETLINK_LIST_MEMBERSHIPS" |
"NETLINK_LISTEN_ALL_NSID" |
"NETLINK_CAP_ACK" |
"PR_CAP_AMBIENT_CLEAR_ALL" |
"PR_CAP_AMBIENT_LOWER" |
"PR_CAP_AMBIENT_RAISE" |
"PR_CAP_AMBIENT_IS_SET" |
"PR_CAP_AMBIENT" |
"PR_FP_MODE_FRE" |
"PR_FP_MODE_FR" |
"PR_GET_FP_MODE" |
"PR_SET_FP_MODE" |
"PR_MPX_DISABLE_MANAGEMENT" |
"PR_MPX_ENABLE_MANAGEMENT" |
"PR_GET_THP_DISABLE" |
"PR_SET_THP_DISABLE" |
"PR_SET_MM_MAP_SIZE" |
"PR_GET_MM_MAP_SIZE" |
"PR_SET_MM_MAP" |
"NLM_F_DUMP_FILTERED" |
"EPOLLEXCLUSIVE" => true,
_ => false,
}
});
```
I'm assuming this is because I'm stuck using `linux-libc-dev:3.13.0-24.46` for the moment and those constants are defined in newer versions.
2017-02-24 20:25:55 +00:00
Marco A L Barbosa
92ce51823c
Make libc-tests compile for aarch64-linux-android
...
- some tests are failing
- remove readlink, timegm and sig* functions in favor of the
unix/mod.rs definitions
- remove time64_t (it is not defined for aarch64)
- move some definitions to android/b32.rs and create appropriated
definitions in android/b64.rs
2017-02-24 16:24:49 -03:00
Zac Berkowitz
004814849d
Removed "rpcsvc/rex.h" from build.rs
for OpenBSD
...
```
export TARGET=x86_64-unknown-openbsd
export QEMU=openbsd.qcow2
sh ci/run-docker.sh $TARGET
```
Passes when run localy.
2017-02-24 18:51:51 +00:00
Zac Berkowitz
e8fc9928cd
Removed "termios.h" from build.rs
openbsd case.
...
Adding `termios.h` behind `rpcsvc/rex.h` does not solve the #define
clash since `rex.h` also defines the `_SYS_TERMIOS_H_` include guard.
2017-02-24 17:20:34 +00:00
bors
16832447b4
Auto merge of #532 - malbarbo:fs2-android, r=alexcrichton
...
Add definitions to Android to allow fs2 crate compile
This is the only missing part to allow cargo to compile on android.
2017-02-22 17:41:08 +00:00
Marco A L Barbosa
bad80ba4d7
Add definitions to Android to allow fs2 crate compile
2017-02-21 17:17:46 -03:00
Ryan Moeller
7c03711d45
Add jail functions and constants for FreeBSD
2017-02-21 00:41:12 +00:00
Zac Berkowitz
e393a2d4a0
Adding termios.h to openbsd headers.
...
Attempting to correct for conflicting defines from `rpcsvc/rex.h`
2017-02-20 20:49:19 +00:00
Kevin Brothaler
7fbff3a443
Fix for removed OS X constants.
...
https://developer.apple.com/library/content/releasenotes/General/APIDiffsMacOS10_12/Swift/Darwin.html
Fixes https://github.com/rust-lang/libc/issues/480
2017-01-16 12:49:49 -04:00
Michael Neumann
7134822dd2
Skip signedness test for sem_t on DragonFly
2016-12-04 13:05:01 +01:00
Michael Neumann
09bff052a9
Include aio.h on DragonFly as well
2016-12-04 12:46:17 +01:00
Alex Crichton
8726270a8e
Merge pull request #456 from alexcrichton/cache-things
...
Share the host's `target` directory for tests
2016-11-18 09:00:09 -06:00
Alex Crichton
c2842463e5
Share the host's target
directory for tests
...
This helps caching between runs and can help speed up turnaround time for
various operations. The old android container didn't work out for some reason
due to permissions so the definition has now been vendored locally to just
rebuild it each time.
2016-11-17 11:30:17 -08:00
Alan Somers
9860c2935a
Fix tests on FreeBSD 11
...
FreeBSD svn r262489 removed some *_MAXID definitions in sys/sysctl.h. They never
should've been used outside of the FreeBSD base system anyway. Mark them as
deprecated, hide them from the API docs, and disable their tests.
r273250 removed MAP_RENAME and MAP_NORESERVE, flags used by mmap(2), but old
binaries that use them will still work. Suppress their test errors.
r294930 changed stack_t.ss_sp from a char* to a void*. Suppress its test error.
2016-11-15 20:54:43 -07:00
Alan Somers
e0ff0d6185
Fix more CI errors in PR #449
2016-11-13 14:35:17 -07:00
Alan Somers
9245e0727b
Fix various CI errors in PR #449
2016-11-13 13:52:34 -07:00
Alan Somers
4ec884ac6d
Fix undefined symbol errors in CI
2016-11-13 08:07:45 -07:00
Alex Crichton
852db737b3
Merge pull request #441 from billiob/setfsuid
...
Add setfsgid()/setfsuid() on linux
2016-11-06 00:37:48 -07:00
Boris Faure
28d0afa657
Add setfsgid()/setfsuid() on linux
2016-11-05 21:19:53 +01:00
Boris Faure
da445b99f2
Fix typo in comment
2016-11-05 20:16:50 +01:00
Alex Crichton
78070bdf28
Try to fix powerpc64 and update to crates.io ctest
2016-10-20 17:23:23 -07:00
Alex Crichton
739edbc468
Use workspaces in this repo
...
Also cache on appveyor to speed up builds.
2016-10-08 17:26:56 -07:00
Alex Crichton
10142aa24a
Add checksums to cargo lock files
2016-09-29 19:20:58 -07:00
Philipp Keller
04d0b71d2c
Add missing header shadow.h
2016-09-27 07:19:17 +02:00
Alexander Schlarb
7590565993
Add System V message queue bindings for Linux (glibc/musl)
2016-09-18 13:14:28 +02:00
Jorge Aparicio
bcc44dfee8
libc-test: cargo update
2016-09-11 17:52:45 -05:00
Alex Crichton
351df2ddef
Bump to 0.2.16
2016-09-08 15:01:24 -07:00
bors
af23c1e5f1
Auto merge of #365 - alexcrichton:more-arch, r=alexcrichton
...
Add more architectures to libc-test
* `i686-unknown-linux-musl`
* `powerpc-unknown-linux-gnu`
* `powerpc64-unknown-linux-gnu`
cc @japaric
cc https://github.com/rust-lang/rust/issues/36006
2016-08-27 11:26:39 -07:00