From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 2155) id B1C003857C59; Tue, 2 Feb 2021 09:43:37 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org B1C003857C59 Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Corinna Vinschen To: cygwin-cvs@sourceware.org Subject: [newlib-cygwin] fhandler_serial.cc: MARK and SPACE parity for serial port X-Act-Checkin: newlib-cygwin X-Git-Author: Marek Smetana X-Git-Refname: refs/heads/master X-Git-Oldrev: 05e2751665b19839ef35b555629d3ec1f72e5366 X-Git-Newrev: d4a756f13a3440576c866d0a0cfc3a001f86ad59 Message-Id: <20210202094337.B1C003857C59@sourceware.org> Date: Tue, 2 Feb 2021 09:43:37 +0000 (GMT) X-BeenThere: cygwin-cvs@cygwin.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Cygwin core component git logs List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 02 Feb 2021 09:43:37 -0000 https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=d4a756f13a3440576c866d0a0cfc3a001f86ad59 commit d4a756f13a3440576c866d0a0cfc3a001f86ad59 Author: Marek Smetana Date: Mon Feb 1 22:02:14 2021 +0100 fhandler_serial.cc: MARK and SPACE parity for serial port Diff: --- winsup/cygwin/fhandler_serial.cc | 11 ++++++++++- winsup/cygwin/include/sys/termios.h | 1 + 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/winsup/cygwin/fhandler_serial.cc b/winsup/cygwin/fhandler_serial.cc index fd5b45899..e0257302c 100644 --- a/winsup/cygwin/fhandler_serial.cc +++ b/winsup/cygwin/fhandler_serial.cc @@ -727,7 +727,12 @@ fhandler_serial::tcsetattr (int action, const struct termios *t) /* -------------- Set parity ------------------ */ if (t->c_cflag & PARENB) - state.Parity = (t->c_cflag & PARODD) ? ODDPARITY : EVENPARITY; + { + if(t->c_cflag & CMSPAR) + state.Parity = (t->c_cflag & PARODD) ? MARKPARITY : SPACEPARITY; + else + state.Parity = (t->c_cflag & PARODD) ? ODDPARITY : EVENPARITY; + } else state.Parity = NOPARITY; @@ -1068,6 +1073,10 @@ fhandler_serial::tcgetattr (struct termios *t) t->c_cflag |= (PARENB | PARODD); if (state.Parity == EVENPARITY) t->c_cflag |= PARENB; + if (state.Parity == MARKPARITY) + t->c_cflag |= (PARENB | PARODD | CMSPAR); + if (state.Parity == SPACEPARITY) + t->c_cflag |= (PARENB | CMSPAR); /* -------------- Parity errors ------------------ */ diff --git a/winsup/cygwin/include/sys/termios.h b/winsup/cygwin/include/sys/termios.h index 17e8d83a3..e4465fca3 100644 --- a/winsup/cygwin/include/sys/termios.h +++ b/winsup/cygwin/include/sys/termios.h @@ -206,6 +206,7 @@ POSIX commands */ #define CRTSXOFF 0x04000 #define CRTSCTS 0x08000 +#define CMSPAR 0x40000000 /* Mark or space (stick) parity. */ /* lflag bits */ #define ISIG 0x0001