about summary refs log tree commit diff
path: root/sysdeps/unix
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-05-05 20:48:16 +0000
committerUlrich Drepper <drepper@redhat.com>2000-05-05 20:48:16 +0000
commitfda4deac4361d47c60df663f7c1c997322d10b5e (patch)
treed5a5255b4d19bc3ea5b93a055a085e8c4fb9db46 /sysdeps/unix
parent3c38e028f36115cb4b5621380dc95b0d247ca011 (diff)
downloadglibc-fda4deac4361d47c60df663f7c1c997322d10b5e.tar.gz
glibc-fda4deac4361d47c60df663f7c1c997322d10b5e.tar.xz
glibc-fda4deac4361d47c60df663f7c1c997322d10b5e.zip
Update.
	* sysdeps/unix/sysv/linux/powerpc/aix/tcgetattr.c: New file.
Diffstat (limited to 'sysdeps/unix')
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/aix/Dist7
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/aix/tcgetattr.c156
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/aix/tcsetattr.c4
3 files changed, 165 insertions, 2 deletions
diff --git a/sysdeps/unix/sysv/linux/powerpc/aix/Dist b/sysdeps/unix/sysv/linux/powerpc/aix/Dist
new file mode 100644
index 0000000000..64de6ace3e
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/aix/Dist
@@ -0,0 +1,7 @@
+aix-dirent.h
+aix-errno.h
+aix-stat.h
+aix-termios.h
+direntconv.c
+errnoconv.c
+statconv.c
diff --git a/sysdeps/unix/sysv/linux/powerpc/aix/tcgetattr.c b/sysdeps/unix/sysv/linux/powerpc/aix/tcgetattr.c
new file mode 100644
index 0000000000..27223fe0d7
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/aix/tcgetattr.c
@@ -0,0 +1,156 @@
+/* Copyright (C) 2000 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Library General Public License as
+   published by the Free Software Foundation; either version 2 of the
+   License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Library General Public License for more details.
+
+   You should have received a copy of the GNU Library General Public
+   License along with the GNU C Library; see the file COPYING.LIB.  If not,
+   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+   Boston, MA 02111-1307, USA.  */
+
+#include <errno.h>
+#include <termios.h>
+#include "aix-termios.h"
+
+int
+tcgetattr (fd, linuxtermios_p)
+     int fd;
+     struct termios *linuxtermios_p;
+{
+  struct aixtermios aixtermios;
+  int result;
+
+  result = /* make syscall */;
+
+  if (result != -1)
+    {
+      /* Convert the result.  */
+
+      linuxtermios_p->c_cc[VINTR] = aixtermios.c_cc[AIX_VINTR];
+      linuxtermios_p->c_cc[VQUIT] = aixtermios.c_cc[AIX_VQUIT];
+      linuxtermios_p->c_cc[VERASE] = aixtermios.c_cc[AIX_VERASE];
+      linuxtermios_p->c_cc[VKILL] = aixtermios.c_cc[AIX_VKILL];
+      linuxtermios_p->c_cc[VEOF] = aixtermios.c_cc[AIX_VEOF];
+      // XXX VMIN has the same value as VEOF !?
+      linuxtermios_p->c_cc[VEOL] = aixtermios.c_cc[AIX_VEOL];
+      // XXX VTIME has the same value as VEOL !?
+      linuxtermios_p->c_cc[VEOL2] = aixtermios.c_cc[AIX_VEOL2];
+      linuxtermios_p->c_cc[VSTART] = aixtermios.c_cc[AIX_VSTART];
+      linuxtermios_p->c_cc[VSTOP] = aixtermios.c_cc[AIX_VSTOP];
+      linuxtermios_p->c_cc[VSUSP] = aixtermios.c_cc[AIX_VSUSP];
+      // XXX No Linux equivalent for VDSUSP !?
+      linuxtermios_p->c_cc[VREPRINT] = aixtermios.c_cc[AIX_VREPRINT];
+      linuxtermios_p->c_cc[VDISCARD] = aixtermios.c_cc[AIX_VDISCARD];
+      linuxtermios_p->c_cc[VWERASE] = aixtermios.c_cc[AIX_VWERASE];
+      linuxtermios_p->c_cc[VLNEXT] = aixtermios.c_cc[AIX_VLNEXT];
+
+      linuxtermios_p->c_cflag = aixtermios.c_c_flag & AIX_CBAUD;
+
+      /* Only the IUCLC, IXANY, and IMAXBEL values are different in the
+	 c_iflag member.  */
+      linuxtermios_p->c_iflag = aixtermios.c_iflag & 0x7ff;
+      if (aixtermios.c_iflag & AIX_IXANY)
+	linuxtermios_p->c_iflag |= IXANY;
+      if (aixtermios.c_iflag & AIX_IUCLC)
+	linuxtermios_p->c_iflag |= IUCLC;
+      if (aixtermios.c_iflag & AIX_IMAXBEL)
+	linuxtermios_p->c_iflag |= IMAXBEL;
+
+      /* Many of the c_oflag files differ.  Bummer.  */
+      linuxtermios_p->c_oflag = (aixtermios.c_oflag
+				 & (OPOST | OCRNL | ONOCR | ONLRET | OFILL
+				    | OFDEL | TABDLY));
+      if (aixtermios.c_oflag & AIX_OLCUC)
+	linuxtermios_p->c_oflag |= OLCUC;
+      if (aixtermios.c_oflag & AIX_ONLCR)
+	linuxtermios_p->c_oflag |= ONLCR;
+      if (aixtermiosc_oflag & AIX_NLDLY)
+	linuxtermios_p->c_oflag |= NL1;
+
+      if (aixtermiosc_oflag.c_oflag & AIX_TABDLY)
+	{
+#define offset 2
+#if AIX_TAB1 << offset != TAB1 || AIX_TAB3 << offset != TAB3
+# error "Check the offset"
+#endif
+	  linuxtermios_p->c_oflag |= (aixtermios.c_oflag >> offset) & TABDLY;
+#undef offset
+	}
+      if (aixtermios.c_oflag & AIX_FFDLY)
+	linuxtermios_p->c_oflag |= FF1;
+      if (aixtermios.c_oflag & AIX_BSDLY)
+	linuxtermios_p->c_oflag |= BS1;
+      if (aixtermios.c_oflag & AIX_VTDLY)
+	linuxtermios_p->c_oflag |= VT1;
+
+      /* A lot of the c_cflag member is also different.  */
+      if (aixtermios.c_cflag & AIX_CSIZE)
+	{
+#define offset 4
+#if CSIZE >> offset != AIX_CSIZE
+# error "Check the offset"
+#endif
+	  linuxtermios_p->c_cflag |= (aixtermios.c_cflag >> offset) & CSIZE;
+#undef offset
+	}
+
+      if (aixtermios.c_cflag & AIX_STOPB)
+	linuxtermios_p->c_cflag |= STOPB;
+      if (aixtermios.c_cflag & AIX_CREAD)
+	linuxtermios_p->c_cflag |= CREAD;
+      if (aixtermios.cflag & AIX_PARENB)
+	linuxtermios_p->c_cflag |= PARENB;
+      if (aixtermios.cflag & AIX_PARODD)
+	linuxtermios_p->c_cflag |= PARODD;
+      if (aixtermios.c_cflag & AIX_HUPCL)
+	linuxtermios_p->c_cflag |= HUPCL;
+      if (aixtermios.c_cflag & AIX_CLOCAL)
+	linuxtermios_p->c_cflag |= CLOCAL;
+
+      /* The c_lflag is information is also different.  */
+      aixtermios.c_lflag = 0;
+      if (aixtermios.c_lflag & AIX_ISIG)
+	linuxtermios_p->c_lflag |= ISIG;
+      if (aixtermios.c_lflag & AIX_ICANON)
+	linuxtermios_p->c_lflag |= ICANON;
+      if (aixtermios.c_lflag & AIX_XCASE)
+	linuxtermios_p->c_lflag |= XCASE;
+      if (aixtermios.c_lflag & AIX_ECHO)
+	linuxtermios_p->c_lflag |= ECHO;
+      if (aixtermios.c_lflag & AIX_ECHOE)
+	linuxtermios_p->c_lflag |= ECHOE;
+      if (aixtermios.c_lflag & AIX_ECHOK)
+	linuxtermios_p->c_lflag |= ECHOK;
+      if (aixtermios.c_lflag & AIX_ECHONL)
+	linuxtermios_p->c_lflag |= ECHONL;
+      if (aixtermios.c_lflag & AIX_NOFLSH)
+	linuxtermios_p->c_lflag |= NOFLSH;
+      if (aixtermios.c_lflag & AIX_TOSTOP)
+	linuxtermios_p->c_lflag |= TOSTOP;
+      if (aixtermios.c_lflag & AIX_ECHOCTL)
+	linuxtermios_p->c_lflag |= ECHOCTL;
+      if (aixtermios.c_lflag & AIX_ECHOPRT)
+	linuxtermios_p->c_lflag |= ECHOPRT;
+      if (aixtermios.c_lflag & AIX_ECHOKE)
+	linuxtermios_p->c_lflag |= ECHOKE;
+      if (aixtermios.c_lflag & AIX_FLUSHO)
+	linuxtermios_p->c_lflag |= FLUSHO;
+      if (aixtermios.c_lflag & AIX_PENDIN)
+	linuxtermios_p->c_lflag |= PENDIN;
+      if (aixtermios->c_lflag & AIX_IEXTEN)
+	linuxtermios_p->c_lflag |= IEXTEN;
+    }
+  else
+    // Convert error here or in syscall.
+    ;
+
+  return result;
+}
diff --git a/sysdeps/unix/sysv/linux/powerpc/aix/tcsetattr.c b/sysdeps/unix/sysv/linux/powerpc/aix/tcsetattr.c
index bf3b2d638c..5736b4fe3d 100644
--- a/sysdeps/unix/sysv/linux/powerpc/aix/tcsetattr.c
+++ b/sysdeps/unix/sysv/linux/powerpc/aix/tcsetattr.c
@@ -93,7 +93,7 @@ tcsetattr (fd, optional_actions, linuxtermios_p)
   if (linuxtermios_p->c_oflag & TABDLY)
     {
 #define offset 2
-#if TAB0 >> offset != AIX_TAB1 || TAB1 >> offset != AIX_TAB3
+#if TAB1 >> offset != AIX_TAB1 || TAB3 >> offset != AIX_TAB3
 # error "Check the offset"
 #endif
       aixtermios.c_oflag |= (linuxtermios_p->c_oflag >> offset) & AIX_TABDLY;
@@ -110,7 +110,7 @@ tcsetattr (fd, optional_actions, linuxtermios_p)
   if (linuxtermios_p->c_cflag & CSIZE)
     {
 #define offset 4
-#if LINUX_CSIZE >> offset != AIX_CSIZE
+#if CSIZE >> offset != AIX_CSIZE
 # error "Check the offset"
 #endif
       aixtermios.c_cflag |= (linuxtermios_p->c_cflag >> offset) & AIX_CSIZE;