Add legacy inline for wait4.
This wasn't added to Android until android-18. Note that the reason I'm adding an inline here even though I just reverted a bunch of inlines in the previous commit is because this was an inline in the legacy NDK headers. If it was in the old headers, it needs to be in the unified headers. If it wasn't, it needs to be in libandroid_support. Test: ./tools/update_headers.py && make ndk && make native # Copied into working directory for unified headers NDK work. ndk/checkbuild.py ndk/run_tests.py --force-unified-headers Bug: None Change-Id: I751520a1df34b3edb5c59b4bd47170c4634a1883
This commit is contained in:
parent
a3ce418ca6
commit
e749abe9ab
2 changed files with 55 additions and 0 deletions
49
libc/include/android/legacy_sys_wait_inlines.h
Normal file
49
libc/include/android/legacy_sys_wait_inlines.h
Normal file
|
@ -0,0 +1,49 @@
|
|||
/*
|
||||
* Copyright (C) 2016 The Android Open Source Project
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#ifndef _ANDROID_LEGACY_SYS_WAIT_INLINES_H_
|
||||
#define _ANDROID_LEGACY_SYS_WAIT_INLINES_H_
|
||||
|
||||
#include <sys/cdefs.h>
|
||||
#include <sys/syscall.h>
|
||||
#include <sys/wait.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#if __ANDROID_API__ < 18
|
||||
|
||||
__BEGIN_DECLS
|
||||
|
||||
static __inline pid_t wait4(pid_t pid, int* status, int options, struct rusage* rusage) {
|
||||
return __BIONIC_CAST(static_cast, pid_t, syscall(__NR_wait4, pid, status, options, rusage));
|
||||
}
|
||||
|
||||
__END_DECLS
|
||||
|
||||
#endif /* __ANDROID_API__ < 18 */
|
||||
|
||||
#endif /* _ANDROID_LEGACY_SYS_WAIT_INLINES_H_ */
|
|
@ -51,7 +51,11 @@ __BEGIN_DECLS
|
|||
|
||||
pid_t wait(int*);
|
||||
pid_t waitpid(pid_t, int*, int);
|
||||
#if __ANDROID_API__ >= 18
|
||||
pid_t wait4(pid_t, int*, int, struct rusage*) __INTRODUCED_IN(18);
|
||||
#else
|
||||
// Implemented as a static inline before 18.
|
||||
#endif
|
||||
|
||||
/* Posix states that idtype_t should be an enumeration type, but
|
||||
* the kernel headers define P_ALL, P_PID and P_PGID as constant macros
|
||||
|
@ -63,4 +67,6 @@ int waitid(idtype_t which, id_t id, siginfo_t* info, int options);
|
|||
|
||||
__END_DECLS
|
||||
|
||||
#include <android/legacy_sys_wait_inlines.h>
|
||||
|
||||
#endif /* _SYS_WAIT_H_ */
|
||||
|
|
Loading…
Reference in a new issue