summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVadim Kochan <vadim4j@gmail.com>2019-08-21 03:30:59 +0300
committerWaldemar Brodkorb <wbx@openadk.org>2019-09-06 12:07:32 +0200
commit14c36638c1a125b1c2d06857c7e7c44f266d0e8e (patch)
tree1e498849b8fc7944aefd4e9e0882bf767cbe5124
parente94e6f4bd91c92c7e1cc21d82ed9320dd722add2 (diff)
package/uclibc: fix termios redefinition issue for PowerPC
Fix redefinition of 'struct termios' by syncing termios powerpc headers from glibc, the commit which fixed the same issue in glibc: d4795e4a43e6f0c221bc5dc64c612206a21a177b PowerPC: Fix termios definitions https://sourceware.org/git/?p=glibc.git;a=commit;h=d4795e4a43e6f0c221bc5dc64c612206a21a177b it fixed the following bug request: https://bugzilla.redhat.com/show_bug.cgi?id=1122714 In case of Buildroot it fixes flashrom build for PowerPC. Fixes: http://autobuild.buildroot.net/results/797dde5cbf0e94162c7cc7b557841605c78ac2f3/ Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
-rw-r--r--package/uclibc/0005-PowerPC-sync-with-termios-fix-from-glibc.patch434
1 files changed, 434 insertions, 0 deletions
diff --git a/package/uclibc/0005-PowerPC-sync-with-termios-fix-from-glibc.patch b/package/uclibc/0005-PowerPC-sync-with-termios-fix-from-glibc.patch
new file mode 100644
index 000000000..7f676fba3
--- /dev/null
+++ b/package/uclibc/0005-PowerPC-sync-with-termios-fix-from-glibc.patch
@@ -0,0 +1,434 @@
+From 11d50ce9f44e5d2224ec6a3d8a9225d9164c7c64 Mon Sep 17 00:00:00 2001
+From: Vadim Kochan <vadim4j@gmail.com>
+Date: Tue, 20 Aug 2019 23:16:18 +0300
+Subject: [PATCH] PowerPC: sync with termios fix from glibc
+
+It fixes the following bug:
+
+ https://bugzilla.redhat.com/show_bug.cgi?id=1122714
+
+with original glibc's fix:
+
+ d4795e4a43e6f0c221bc5 (PowerPC: Fix termios definitions)
+
+https://sourceware.org/git/?p=glibc.git;a=commit;h=d4795e4a43e6f0c221bc5dc64c612206a21a177b
+
+Signed-off-by: Vadim Kochan <vadim4j@gmail.com>
+---
+ libc/sysdeps/linux/powerpc/bits/ioctl-types.h | 74 +++-
+ libc/sysdeps/linux/powerpc/bits/termios.h | 320 ------------------
+ 2 files changed, 73 insertions(+), 321 deletions(-)
+ delete mode 100644 libc/sysdeps/linux/powerpc/bits/termios.h
+
+diff --git a/libc/sysdeps/linux/powerpc/bits/ioctl-types.h b/libc/sysdeps/linux/powerpc/bits/ioctl-types.h
+index 87b8265af..926061fa8 100644
+--- a/libc/sysdeps/linux/powerpc/bits/ioctl-types.h
++++ b/libc/sysdeps/linux/powerpc/bits/ioctl-types.h
+@@ -1,5 +1,77 @@
++/* Structure types for pre-termios terminal ioctls. Linux/powerpc version.
++ Copyright (C) 2014-2019 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 Lesser General Public
++ License as published by the Free Software Foundation; either
++ version 2.1 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
++ Lesser General Public License for more details.
++
++ You should have received a copy of the GNU Lesser General Public
++ License along with the GNU C Library; if not, see
++ <http://www.gnu.org/licenses/>. */
++
+ #ifndef _SYS_IOCTL_H
+ # error "Never use <bits/ioctl-types.h> directly; include <sys/ioctl.h> instead."
+ #endif
+
+-#include <termios.h>
++/* Get definition of constants for use with `ioctl'. */
++#include <asm/ioctls.h>
++
++
++struct winsize
++ {
++ unsigned short int ws_row;
++ unsigned short int ws_col;
++ unsigned short int ws_xpixel;
++ unsigned short int ws_ypixel;
++ };
++
++#define NCC 10
++struct termio
++ {
++ unsigned short int c_iflag; /* input mode flags */
++ unsigned short int c_oflag; /* output mode flags */
++ unsigned short int c_cflag; /* control mode flags */
++ unsigned short int c_lflag; /* local mode flags */
++ unsigned char c_line; /* line discipline */
++ unsigned char c_cc[NCC]; /* control characters */
++};
++
++/* modem lines */
++#define TIOCM_LE 0x001
++#define TIOCM_DTR 0x002
++#define TIOCM_RTS 0x004
++#define TIOCM_ST 0x008
++#define TIOCM_SR 0x010
++#define TIOCM_CTS 0x020
++#define TIOCM_CAR 0x040
++#define TIOCM_RNG 0x080
++#define TIOCM_DSR 0x100
++#define TIOCM_CD TIOCM_CAR
++#define TIOCM_RI TIOCM_RNG
++
++/* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
++
++/* line disciplines */
++#define N_TTY 0
++#define N_SLIP 1
++#define N_MOUSE 2
++#define N_PPP 3
++#define N_STRIP 4
++#define N_AX25 5
++#define N_X25 6 /* X.25 async */
++#define N_6PACK 7
++#define N_MASC 8 /* Mobitex module */
++#define N_R3964 9 /* Simatic R3964 module */
++#define N_PROFIBUS_FDL 10 /* Profibus */
++#define N_IRDA 11 /* Linux IR */
++#define N_SMSBLOCK 12 /* SMS block mode */
++#define N_HDLC 13 /* synchronous HDLC */
++#define N_SYNC_PPP 14 /* synchronous PPP */
++#define N_HCI 15 /* Bluetooth HCI UART */
+diff --git a/libc/sysdeps/linux/powerpc/bits/termios.h b/libc/sysdeps/linux/powerpc/bits/termios.h
+deleted file mode 100644
+index ffd99a5e2..000000000
+--- a/libc/sysdeps/linux/powerpc/bits/termios.h
++++ /dev/null
+@@ -1,320 +0,0 @@
+-/* Copyright (C) 1997,1999,2001,2003,2004,2005 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 Lesser General Public
+- License as published by the Free Software Foundation; either
+- version 2.1 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
+- Lesser General Public License for more details.
+-
+- You should have received a copy of the GNU Lesser General Public
+- License along with the GNU C Library; if not, see
+- <http://www.gnu.org/licenses/>. */
+-
+-#ifndef _TERMIOS_H
+-# error "Never include <bits/termios.h> directly; use <termios.h> instead."
+-#endif
+-
+-typedef unsigned char cc_t;
+-typedef unsigned int speed_t;
+-typedef unsigned int tcflag_t;
+-
+-/*
+- * termios type and macro definitions. Be careful about adding stuff
+- * to this file since it's used in GNU libc and there are strict rules
+- * concerning namespace pollution.
+- */
+-
+-#define NCCS 32
+-struct termios {
+- tcflag_t c_iflag; /* input mode flags */
+- tcflag_t c_oflag; /* output mode flags */
+- tcflag_t c_cflag; /* control mode flags */
+- tcflag_t c_lflag; /* local mode flags */
+- cc_t c_line; /* line discipline (== c_cc[19]) */
+- cc_t c_cc[NCCS]; /* control characters */
+- speed_t c_ispeed; /* input speed */
+- speed_t c_ospeed; /* output speed */
+-#define _HAVE_STRUCT_TERMIOS_C_ISPEED 1
+-#define _HAVE_STRUCT_TERMIOS_C_OSPEED 1
+-};
+-
+-/* c_cc characters */
+-#define VINTR 0
+-#define VQUIT 1
+-#define VERASE 2
+-#define VKILL 3
+-#define VEOF 4
+-#define VMIN 5
+-#define VEOL 6
+-#define VTIME 7
+-#define VEOL2 8
+-#define VSWTC 9
+-
+-#define VWERASE 10
+-#define VREPRINT 11
+-#define VSUSP 12
+-#define VSTART 13
+-#define VSTOP 14
+-#define VLNEXT 15
+-#define VDISCARD 16
+-
+-/* c_iflag bits */
+-#define IGNBRK 0000001
+-#define BRKINT 0000002
+-#define IGNPAR 0000004
+-#define PARMRK 0000010
+-#define INPCK 0000020
+-#define ISTRIP 0000040
+-#define INLCR 0000100
+-#define IGNCR 0000200
+-#define ICRNL 0000400
+-#define IXON 0001000
+-#define IXOFF 0002000
+-#define IXANY 0004000
+-#define IUCLC 0010000
+-#define IMAXBEL 0020000
+-#define IUTF8 0040000
+-
+-/* c_oflag bits */
+-#define OPOST 0000001
+-#define ONLCR 0000002
+-#define OLCUC 0000004
+-
+-#define OCRNL 0000010
+-#define ONOCR 0000020
+-#define ONLRET 0000040
+-
+-#define OFILL 00000100
+-#define OFDEL 00000200
+-#if defined __USE_MISC || defined __USE_XOPEN
+-# define NLDLY 00001400
+-# define NL0 00000000
+-# define NL1 00000400
+-# define NL2 00001000
+-# define NL3 00001400
+-# define TABDLY 00006000
+-# define TAB0 00000000
+-# define TAB1 00002000
+-# define TAB2 00004000
+-# define TAB3 00006000
+-# define CRDLY 00030000
+-# define CR0 00000000
+-# define CR1 00010000
+-# define CR2 00020000
+-# define CR3 00030000
+-# define FFDLY 00040000
+-# define FF0 00000000
+-# define FF1 00040000
+-# define BSDLY 00100000
+-# define BS0 00000000
+-# define BS1 00100000
+-#endif
+-#define VTDLY 00200000
+-#define VT0 00000000
+-#define VT1 00200000
+-
+-#ifdef __USE_MISC
+-# define XTABS 00006000
+-#endif
+-
+-/* c_cflag bit meaning */
+-#ifdef __USE_MISC
+-# define CBAUD 0000377
+-#endif
+-#define B0 0000000 /* hang up */
+-#define B50 0000001
+-#define B75 0000002
+-#define B110 0000003
+-#define B134 0000004
+-#define B150 0000005
+-#define B200 0000006
+-#define B300 0000007
+-#define B600 0000010
+-#define B1200 0000011
+-#define B1800 0000012
+-#define B2400 0000013
+-#define B4800 0000014
+-#define B9600 0000015
+-#define B19200 0000016
+-#define B38400 0000017
+-#ifdef __USE_MISC
+-# define EXTA B19200
+-# define EXTB B38400
+-# define CBAUDEX 0000020
+-#endif
+-#define B57600 00020
+-#define B115200 00021
+-#define B230400 00022
+-#define B460800 00023
+-#define B500000 00024
+-#define B576000 00025
+-#define B921600 00026
+-#define B1000000 00027
+-#define B1152000 00030
+-#define B1500000 00031
+-#define B2000000 00032
+-#define B2500000 00033
+-#define B3000000 00034
+-#define B3500000 00035
+-#define B4000000 00036
+-#define __MAX_BAUD B4000000
+-
+-#define CSIZE 00001400
+-#define CS5 00000000
+-#define CS6 00000400
+-#define CS7 00001000
+-#define CS8 00001400
+-
+-#define CSTOPB 00002000
+-#define CREAD 00004000
+-#define PARENB 00010000
+-#define PARODD 00020000
+-#define HUPCL 00040000
+-
+-#define CLOCAL 00100000
+-#ifdef __USE_MISC
+-# define CMSPAR 010000000000 /* mark or space (stick) parity */
+-# define CRTSCTS 020000000000 /* flow control */
+-#endif
+-
+-/* c_lflag bits */
+-#define ISIG 0x00000080
+-#define ICANON 0x00000100
+-#if defined __USE_MISC || defined __USE_XOPEN
+-# define XCASE 0x00004000
+-#endif
+-#define ECHO 0x00000008
+-#define ECHOE 0x00000002
+-#define ECHOK 0x00000004
+-#define ECHONL 0x00000010
+-#define NOFLSH 0x80000000
+-#define TOSTOP 0x00400000
+-#ifdef __USE_MISC
+-# define ECHOCTL 0x00000040
+-# define ECHOPRT 0x00000020
+-# define ECHOKE 0x00000001
+-# define FLUSHO 0x00800000
+-# define PENDIN 0x20000000
+-#endif
+-#define IEXTEN 0x00000400
+-
+-/* Values for the ACTION argument to `tcflow'. */
+-#define TCOOFF 0
+-#define TCOON 1
+-#define TCIOFF 2
+-#define TCION 3
+-
+-/* Values for the QUEUE_SELECTOR argument to `tcflush'. */
+-#define TCIFLUSH 0
+-#define TCOFLUSH 1
+-#define TCIOFLUSH 2
+-
+-/* Values for the OPTIONAL_ACTIONS argument to `tcsetattr'. */
+-#define TCSANOW 0
+-#define TCSADRAIN 1
+-#define TCSAFLUSH 2
+-
+-#ifndef __UCLIBC_STRICT_HEADERS__
+-struct sgttyb {
+- char sg_ispeed;
+- char sg_ospeed;
+- char sg_erase;
+- char sg_kill;
+- short sg_flags;
+-};
+-#endif
+-
+-struct tchars {
+- char t_intrc;
+- char t_quitc;
+- char t_startc;
+- char t_stopc;
+- char t_eofc;
+- char t_brkc;
+-};
+-
+-struct ltchars {
+- char t_suspc;
+- char t_dsuspc;
+- char t_rprntc;
+- char t_flushc;
+- char t_werasc;
+- char t_lnextc;
+-};
+-
+-/* Used for packet mode */
+-#define TIOCPKT_DATA 0
+-#define TIOCPKT_FLUSHREAD 1
+-#define TIOCPKT_FLUSHWRITE 2
+-#define TIOCPKT_STOP 4
+-#define TIOCPKT_START 8
+-#define TIOCPKT_NOSTOP 16
+-#define TIOCPKT_DOSTOP 32
+-
+-struct winsize {
+- unsigned short ws_row;
+- unsigned short ws_col;
+- unsigned short ws_xpixel;
+- unsigned short ws_ypixel;
+-};
+-
+-#define NCC 10
+-struct termio {
+- unsigned short c_iflag; /* input mode flags */
+- unsigned short c_oflag; /* output mode flags */
+- unsigned short c_cflag; /* control mode flags */
+- unsigned short c_lflag; /* local mode flags */
+- unsigned char c_line; /* line discipline */
+- unsigned char c_cc[NCC]; /* control characters */
+-};
+-
+-/* c_cc characters */
+-#define _VINTR 0
+-#define _VQUIT 1
+-#define _VERASE 2
+-#define _VKILL 3
+-#define _VEOF 4
+-#define _VMIN 5
+-#define _VEOL 6
+-#define _VTIME 7
+-#define _VEOL2 8
+-#define _VSWTC 9
+-
+-/* modem lines */
+-#define TIOCM_LE 0x001
+-#define TIOCM_DTR 0x002
+-#define TIOCM_RTS 0x004
+-#define TIOCM_ST 0x008
+-#define TIOCM_SR 0x010
+-#define TIOCM_CTS 0x020
+-#define TIOCM_CAR 0x040
+-#define TIOCM_RNG 0x080
+-#define TIOCM_DSR 0x100
+-#define TIOCM_CD TIOCM_CAR
+-#define TIOCM_RI TIOCM_RNG
+-
+-/* ioctl (fd, TIOCSERGETLSR, &result) where result may be as below */
+-#define TIOCSER_TEMT 0x01 /* Transmitter physically empty */
+-
+-/* line disciplines */
+-#define N_TTY 0
+-#define N_SLIP 1
+-#define N_MOUSE 2
+-#define N_PPP 3
+-#define N_STRIP 4
+-#define N_AX25 5
+-#define N_X25 6 /* X.25 async */
+-#define N_6PACK 7
+-#define N_MASC 8 /* Mobitex module */
+-#define N_R3964 9 /* Simatic R3964 module */
+-#define N_PROFIBUS_FDL 10 /* Profibus */
+-#define N_IRDA 11 /* Linux IR */
+-#define N_SMSBLOCK 12 /* SMS block mode */
+-#define N_HDLC 13 /* synchronous HDLC */
+-#define N_SYNC_PPP 14 /* synchronous PPP */
+-#define N_HCI 15 /* Bluetooth HCI UART */
+--
+2.22.0
+