Date: Mon, 7 May 2018 08:13:08 +0000 (UTC) From: Emanuel Haupt <ehaupt@FreeBSD.org> To: ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org Subject: svn commit: r469273 - in head/net/socat: . files Message-ID: <201805070813.w478D81B097101@repo.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: ehaupt Date: Mon May 7 08:13:07 2018 New Revision: 469273 URL: https://svnweb.freebsd.org/changeset/ports/469273 Log: Reinstate a patch from r384479 that was accidentally removed in r432474. It restores support to bridge a serial port across tcp. Notified by: leres, Alexandre.Fenyo@secu-independants.fr (via mail) MFH: 2018Q2 (blanket) Added: head/net/socat/files/patch-xioopts.c (contents, props changed) Modified: head/net/socat/Makefile Modified: head/net/socat/Makefile ============================================================================== --- head/net/socat/Makefile Mon May 7 08:11:06 2018 (r469272) +++ head/net/socat/Makefile Mon May 7 08:13:07 2018 (r469273) @@ -3,7 +3,7 @@ PORTNAME= socat PORTVERSION= 1.7.3.2 -PORTREVISION= 2 +PORTREVISION= 3 CATEGORIES= net ipv6 MASTER_SITES= http://www.dest-unreach.org/socat/download/ \ LOCAL/ehaupt Added: head/net/socat/files/patch-xioopts.c ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/net/socat/files/patch-xioopts.c Mon May 7 08:13:07 2018 (r469273) @@ -0,0 +1,73 @@ +--- xioopts.c.orig 2015-01-24 10:15:22 UTC ++++ xioopts.c +@@ -2971,6 +2971,25 @@ int retropt_bind(struct opt *opts, + OFUNC_TERMIOS_FLAG, OFUNC_TERMIOS_PATTERN, and some OFUNC_SPEC */ + int applyopts(int fd, struct opt *opts, enum e_phase phase) { + struct opt *opt; ++#ifdef HAVE_TERMIOS_ISPEED ++ int ispeed_major = -1, ospeed_major = -1; ++ unsigned int ispeed_value, ospeed_value; ++ bool speed_done = false; ++ ++ opt = opts; while (opt && opt->desc != ODESC_END) { ++ if (opt->desc == ODESC_DONE || ++ (phase != PH_ALL && opt->desc->phase != phase)) { ++ ++opt; continue; } ++ if (opt->desc->optcode == OPT_ISPEED) { ++ ispeed_major = opt->desc->major; ++ ispeed_value = opt->value.u_uint; } ++ if (opt->desc->optcode == OPT_OSPEED) { ++ ospeed_major = opt->desc->major; ++ ospeed_value = opt->value.u_uint; } ++ ++opt; ++ continue; ++ } ++#endif /* HAVE_TERMIOS_ISPEED */ + + opt = opts; while (opt && opt->desc != ODESC_END) { + if (opt->desc == ODESC_DONE || +@@ -3605,21 +3624,29 @@ int applyopts(int fd, struct opt *opts, + + #ifdef HAVE_TERMIOS_ISPEED + } else if (opt->desc->func == OFUNC_TERMIOS_SPEED) { +- union { +- struct termios termarg; +- speed_t speeds[sizeof(struct termios)/sizeof(speed_t)]; +- } tdata; +- if (Tcgetattr(fd, &tdata.termarg) < 0) { +- Error3("tcgetattr(%d, %p): %s", +- fd, &tdata.termarg, strerror(errno)); +- opt->desc = ODESC_ERROR; ++opt; continue; +- } +- tdata.speeds[opt->desc->major] = opt->value.u_uint; +- if (Tcsetattr(fd, TCSADRAIN, &tdata.termarg) < 0) { +- Error3("tcsetattr(%d, TCSADRAIN, %p): %s", +- fd, &tdata.termarg, strerror(errno)); +- opt->desc = ODESC_ERROR; ++opt; continue; +- } ++ if (speed_done == false) { ++ union { ++ struct termios termarg; ++ speed_t speeds[sizeof(struct termios)/sizeof(speed_t)]; ++ } tdata; ++ if (Tcgetattr(fd, &tdata.termarg) < 0) { ++ Error3("tcgetattr(%d, %p): %s", ++ fd, &tdata.termarg, strerror(errno)); ++ opt->desc = ODESC_ERROR; ++opt; continue; ++ } ++ if (ispeed_major < 0 || ospeed_major < 0) ++ tdata.speeds[opt->desc->major] = opt->value.u_uint; ++ else{ ++ tdata.speeds[ispeed_major] = ispeed_value; ++ tdata.speeds[ospeed_major] = ospeed_value; ++ speed_done = true; ++ } ++ if (Tcsetattr(fd, TCSADRAIN, &tdata.termarg) < 0) { ++ Error3("tcsetattr(%d, TCSADRAIN, %p): %s", ++ fd, &tdata.termarg, strerror(errno)); ++ opt->desc = ODESC_ERROR; ++opt; continue; ++ } ++ } + #endif /* HAVE_TERMIOS_ISPEED */ + + } else if (opt->desc->func == OFUNC_TERMIOS_SPEC) {
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201805070813.w478D81B097101>