diff options
| author | Elliott Hughes <enh@google.com> | 2017-07-10 20:40:53 +0000 |
|---|---|---|
| committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2017-07-10 20:40:53 +0000 |
| commit | e76ff925df7d0b9aef84fe230c7497ff6a8fbba4 (patch) | |
| tree | 9009caad2fd90f30494b915d367977b96867e0f8 /libc | |
| parent | 6aaa227f74031ee461c7ce5b7a2a262397e866b2 (diff) | |
| parent | 1449974d27473399a1fe25c2d28253908a57e382 (diff) | |
Merge "Make inline tcsetattr definition match constants."
Diffstat (limited to 'libc')
| -rw-r--r-- | libc/bionic/termios.cpp | 86 | ||||
| -rw-r--r-- | libc/include/android/legacy_termios_inlines.h | 72 | ||||
| -rw-r--r-- | libc/include/bits/termios_inlines.h | 119 |
3 files changed, 129 insertions, 148 deletions
diff --git a/libc/bionic/termios.cpp b/libc/bionic/termios.cpp index 44ae64354..5fe8eb0e7 100644 --- a/libc/bionic/termios.cpp +++ b/libc/bionic/termios.cpp @@ -26,93 +26,21 @@ * SUCH DAMAGE. */ -#include <errno.h> #include <termios.h> #include <unistd.h> -static speed_t cfgetspeed(const termios* s) { - return (s->c_cflag & CBAUD); -} - -speed_t cfgetispeed(const termios* s) { - return cfgetspeed(s); -} - -speed_t cfgetospeed(const termios* s) { - return cfgetspeed(s); -} - -void cfmakeraw(termios* s) { - s->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); - s->c_oflag &= ~OPOST; - s->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); - s->c_cflag &= ~(CSIZE|PARENB); - s->c_cflag |= CS8; -} - -int cfsetispeed(termios* s, speed_t speed) { - return cfsetspeed(s, speed); -} - -int cfsetospeed(termios* s, speed_t speed) { - return cfsetspeed(s, speed); -} - -int cfsetspeed(termios* s, speed_t speed) { - // TODO: check 'speed' is valid. - s->c_cflag = (s->c_cflag & ~CBAUD) | (speed & CBAUD); - return 0; -} - -int tcdrain(int fd) { - // A non-zero argument to TCSBRK means "don't send a break". - // The drain is a side-effect of the ioctl! - return ioctl(fd, TCSBRK, static_cast<unsigned long>(1)); -} - -int tcflow(int fd, int action) { - return ioctl(fd, TCXONC, static_cast<unsigned long>(action)); -} - -int tcflush(int fd, int queue) { - return ioctl(fd, TCFLSH, static_cast<unsigned long>(queue)); -} - -int tcgetattr(int fd, termios* s) { - return ioctl(fd, TCGETS, s); -} - -pid_t tcgetsid(int fd) { - pid_t sid; - if (ioctl(fd, TIOCGSID, &sid) == -1) { - return -1; - } - return sid; -} - -int tcsendbreak(int fd, int duration) { - return ioctl(fd, TCSBRKP, static_cast<unsigned long>(duration)); -} - -int tcsetattr(int fd, int optional_actions, const termios* s) { - int cmd; - switch (optional_actions) { - case TCSANOW: cmd = TCSETS; break; - case TCSADRAIN: cmd = TCSETSW; break; - case TCSAFLUSH: cmd = TCSETSF; break; - default: errno = EINVAL; return -1; - } - return ioctl(fd, cmd, s); -} +// Most of termios was missing in the platform until L, but available as inlines in the NDK. +// We share definitions with the NDK to avoid bugs (https://github.com/android-ndk/ndk/issues/441). +#define __BIONIC_TERMIOS_INLINE /* Out of line. */ +#include <bits/termios_inlines.h> +// Actually declared in <unistd.h>, present on all API levels. pid_t tcgetpgrp(int fd) { pid_t pid; - if (ioctl(fd, TIOCGPGRP, &pid) == -1) { - return -1; - } - return pid; + return (ioctl(fd, TIOCGPGRP, &pid) == -1) ? -1 : pid; } +// Actually declared in <unistd.h>, present on all API levels. int tcsetpgrp(int fd, pid_t pid) { return ioctl(fd, TIOCSPGRP, &pid); } diff --git a/libc/include/android/legacy_termios_inlines.h b/libc/include/android/legacy_termios_inlines.h index 02e942920..4ed56f049 100644 --- a/libc/include/android/legacy_termios_inlines.h +++ b/libc/include/android/legacy_termios_inlines.h @@ -36,74 +36,8 @@ #include <linux/termios.h> #if __ANDROID_API__ < __ANDROID_API_L__ - -__BEGIN_DECLS - -static __inline int tcgetattr(int fd, struct termios *s) { - return ioctl(fd, TCGETS, s); -} - -static __inline int tcsetattr(int fd, int __opt, const struct termios *s) { - return ioctl(fd, __opt, (void *)s); -} - -static __inline int tcflow(int fd, int action) { - return ioctl(fd, TCXONC, (void *)(intptr_t)action); -} - -static __inline int tcflush(int fd, int __queue) { - return ioctl(fd, TCFLSH, (void *)(intptr_t)__queue); -} - -static __inline pid_t tcgetsid(int fd) { - pid_t _pid; - return ioctl(fd, TIOCGSID, &_pid) ? (pid_t)-1 : _pid; -} - -static __inline int tcsendbreak(int fd, int __duration) { - return ioctl(fd, TCSBRKP, (void *)(uintptr_t)__duration); -} - -static __inline speed_t cfgetospeed(const struct termios *s) { - return (speed_t)(s->c_cflag & CBAUD); -} - -static __inline int cfsetospeed(struct termios *s, speed_t speed) { - s->c_cflag = (s->c_cflag & ~CBAUD) | (speed & CBAUD); - return 0; -} - -static __inline speed_t cfgetispeed(const struct termios *s) { - return (speed_t)(s->c_cflag & CBAUD); -} - -static __inline int cfsetispeed(struct termios *s, speed_t speed) { - s->c_cflag = (s->c_cflag & ~CBAUD) | (speed & CBAUD); - return 0; -} - -static __inline void cfmakeraw(struct termios *s) { - s->c_iflag &= - ~(IGNBRK | BRKINT | PARMRK | ISTRIP | INLCR | IGNCR | ICRNL | IXON); - s->c_oflag &= ~OPOST; - s->c_lflag &= ~(ECHO | ECHONL | ICANON | ISIG | IEXTEN); - s->c_cflag &= ~(CSIZE | PARENB); - s->c_cflag |= CS8; -} - -static __inline int cfsetspeed(struct termios* s, speed_t speed) { - // TODO: check 'speed' is valid. - s->c_cflag = (s->c_cflag & ~CBAUD) | (speed & CBAUD); - return 0; -} - -static __inline int tcdrain(int fd) { - // A non-zero argument to TCSBRK means "don't send a break". - // The drain is a side-effect of the ioctl! - return ioctl(fd, TCSBRK, __BIONIC_CAST(static_cast, unsigned long, 1)); -} - -__END_DECLS - +#define __BIONIC_TERMIOS_INLINE static __inline +#include <bits/termios_inlines.h> #endif + #endif /* _ANDROID_LEGACY_TERMIOS_INLINES_H_ */ diff --git a/libc/include/bits/termios_inlines.h b/libc/include/bits/termios_inlines.h new file mode 100644 index 000000000..d49167ed6 --- /dev/null +++ b/libc/include/bits/termios_inlines.h @@ -0,0 +1,119 @@ +/* + * 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 _BITS_TERMIOS_INLINES_H_ +#define _BITS_TERMIOS_INLINES_H_ + +#include <errno.h> +#include <sys/cdefs.h> +#include <sys/ioctl.h> +#include <sys/types.h> + +#include <linux/termios.h> + +#if !defined(__BIONIC_TERMIOS_INLINE) +#define __BIONIC_TERMIOS_INLINE static __inline +#endif + +__BEGIN_DECLS + +static __inline speed_t cfgetspeed(const struct termios* s) { + return __BIONIC_CAST(static_cast, speed_t, s->c_cflag & CBAUD); +} + +__BIONIC_TERMIOS_INLINE speed_t cfgetispeed(const struct termios* s) { + return cfgetspeed(s); +} + +__BIONIC_TERMIOS_INLINE speed_t cfgetospeed(const struct termios* s) { + return cfgetspeed(s); +} + +__BIONIC_TERMIOS_INLINE void cfmakeraw(struct termios* s) { + s->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON); + s->c_oflag &= ~OPOST; + s->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN); + s->c_cflag &= ~(CSIZE|PARENB); + s->c_cflag |= CS8; +} + +__BIONIC_TERMIOS_INLINE int cfsetspeed(struct termios* s, speed_t speed) { + // TODO: check 'speed' is valid. + s->c_cflag = (s->c_cflag & ~CBAUD) | (speed & CBAUD); + return 0; +} + +__BIONIC_TERMIOS_INLINE int cfsetispeed(struct termios* s, speed_t speed) { + return cfsetspeed(s, speed); +} + +__BIONIC_TERMIOS_INLINE int cfsetospeed(struct termios* s, speed_t speed) { + return cfsetspeed(s, speed); +} + +__BIONIC_TERMIOS_INLINE int tcdrain(int fd) { + // A non-zero argument to TCSBRK means "don't send a break". + // The drain is a side-effect of the ioctl! + return ioctl(fd, TCSBRK, __BIONIC_CAST(static_cast, unsigned long, 1)); +} + +__BIONIC_TERMIOS_INLINE int tcflow(int fd, int action) { + return ioctl(fd, TCXONC, __BIONIC_CAST(static_cast, unsigned long, action)); +} + +__BIONIC_TERMIOS_INLINE int tcflush(int fd, int queue) { + return ioctl(fd, TCFLSH, __BIONIC_CAST(static_cast, unsigned long, queue)); +} + +__BIONIC_TERMIOS_INLINE int tcgetattr(int fd, struct termios* s) { + return ioctl(fd, TCGETS, s); +} + +__BIONIC_TERMIOS_INLINE pid_t tcgetsid(int fd) { + pid_t sid; + return (ioctl(fd, TIOCGSID, &sid) == -1) ? -1 : sid; +} + +__BIONIC_TERMIOS_INLINE int tcsendbreak(int fd, int duration) { + return ioctl(fd, TCSBRKP, __BIONIC_CAST(static_cast, unsigned long, duration)); +} + +__BIONIC_TERMIOS_INLINE int tcsetattr(int fd, int optional_actions, const struct termios* s) { + int cmd; + switch (optional_actions) { + case TCSANOW: cmd = TCSETS; break; + case TCSADRAIN: cmd = TCSETSW; break; + case TCSAFLUSH: cmd = TCSETSF; break; + default: errno = EINVAL; return -1; + } + return ioctl(fd, cmd, s); +} + +__END_DECLS + +#endif |
