Module Name: src
Committed By: martin
Date: Fri Aug 23 18:28:10 UTC 2024
Modified Files:
src/distrib/sets/lists/debug [netbsd-10]: mi
src/distrib/sets/lists/tests [netbsd-10]: mi
src/etc/mtree [netbsd-10]: NetBSD.dist.tests
src/external/gpl3/gcc/dist/libstdc++-v3/config/io [netbsd-10]:
basic_file_stdio.cc
Added Files:
src/tests/lib/libstdc++ [netbsd-10]: Makefile h_cin_nosync.cc
t_sync_with_stdio.sh
Log Message:
Pull up following revision(s) (requested by riastradh in ticket #801):
tests/lib/libstdc++/h_cin_nosync.cc: revision 1.1
tests/lib/libstdc++/t_sync_with_stdio.sh: revision 1.1
tests/lib/libstdc++/t_sync_with_stdio.sh: revision 1.2
etc/mtree/NetBSD.dist.tests: revision 1.204
distrib/sets/lists/tests/mi: revision 1.1313
tests/lib/libstdc++/Makefile: revision 1.1
distrib/sets/lists/debug/mi: revision 1.433
external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc:
revision 1.2
libstdc++: Add test for PR lib/58206, sync_with_stdio busted.
libstdc++: Don't try to fflush stdin.
It doesn't work. It's undefined behaviour. On NetBSD, it will fail
with EBADF, if fd 0 isn't open for write, or if fd 0 is open for
write, it will write heap garbage to fd 0.
If stream points to an output stream or an update stream in which
the most recent operation was not input, the fflush function causes
any unwritten data for that stream to be delivered to the host
environment to be written to the file; otherwise, the behavior is
undefined.
(ISO C11 and ISO C17, Sec. 7.21.5.2 `The fflush function')
PR lib/58206
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=114879
To generate a diff of this commit:
cvs rdiff -u -r1.394.2.7 -r1.394.2.8 src/distrib/sets/lists/debug/mi
cvs rdiff -u -r1.1238.2.7 -r1.1238.2.8 src/distrib/sets/lists/tests/mi
cvs rdiff -u -r1.197.2.1 -r1.197.2.2 src/etc/mtree/NetBSD.dist.tests
cvs rdiff -u -r1.1.1.12 -r1.1.1.12.6.1 \
src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc
cvs rdiff -u -r0 -r1.1.4.2 src/tests/lib/libstdc++/Makefile \
src/tests/lib/libstdc++/h_cin_nosync.cc
cvs rdiff -u -r0 -r1.2.4.2 src/tests/lib/libstdc++/t_sync_with_stdio.sh
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/distrib/sets/lists/debug/mi
diff -u src/distrib/sets/lists/debug/mi:1.394.2.7 src/distrib/sets/lists/debug/mi:1.394.2.8
--- src/distrib/sets/lists/debug/mi:1.394.2.7 Fri Aug 23 16:56:29 2024
+++ src/distrib/sets/lists/debug/mi Fri Aug 23 18:28:10 2024
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.394.2.7 2024/08/23 16:56:29 martin Exp $
+# $NetBSD: mi,v 1.394.2.8 2024/08/23 18:28:10 martin Exp $
./etc/mtree/set.debug comp-sys-root
./usr/lib comp-sys-usr compatdir
./usr/lib/i18n/libBIG5_g.a comp-c-debuglib debuglib,compatfile
@@ -2387,6 +2387,7 @@
./usr/libdata/debug/usr/tests/lib/librumphijack/h_netget.debug tests-lib-debug debug,atf,rump
./usr/libdata/debug/usr/tests/lib/libskey/t_algorithms.debug tests-lib-debug debug,atf,skey,compattestfile
./usr/libdata/debug/usr/tests/lib/libsljit/h_sljit.debug tests-lib-debug debug,atf,sljit,compattestfile
+./usr/libdata/debug/usr/tests/lib/libstdc++/h_cin_nosync.debug tests-lib-tests compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libtre/h_regex_att.debug tests-obsolete obsolete,compattestfile
./usr/libdata/debug/usr/tests/lib/libtre/t_exhaust.debug tests-lib-debug debug,atf,compattestfile
./usr/libdata/debug/usr/tests/lib/libtre/t_regex_att.debug tests-lib-debug debug,atf,compattestfile
Index: src/distrib/sets/lists/tests/mi
diff -u src/distrib/sets/lists/tests/mi:1.1238.2.7 src/distrib/sets/lists/tests/mi:1.1238.2.8
--- src/distrib/sets/lists/tests/mi:1.1238.2.7 Fri Aug 23 16:56:30 2024
+++ src/distrib/sets/lists/tests/mi Fri Aug 23 18:28:09 2024
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.1238.2.7 2024/08/23 16:56:30 martin Exp $
+# $NetBSD: mi,v 1.1238.2.8 2024/08/23 18:28:09 martin Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -149,6 +149,7 @@
./usr/libdata/debug/usr/tests/lib/librumphijack tests-lib-debug compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libskey tests-lib-debug compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libsljit tests-lib-debug compattestfile,atf
+./usr/libdata/debug/usr/tests/lib/libstdc++ tests-lib-debug compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libtre tests-lib-debug compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libusbhid tests-lib-debug compattestfile,atf
./usr/libdata/debug/usr/tests/lib/libutil tests-lib-debug compattestfile,atf
@@ -4073,6 +4074,11 @@
./usr/tests/lib/libsljit/Kyuafile tests-lib-tests compattestfile,atf,sljit,kyua
./usr/tests/lib/libsljit/h_sljit tests-lib-tests compattestfile,atf,sljit
./usr/tests/lib/libsljit/t_sljit tests-lib-tests compattestfile,atf,sljit
+./usr/tests/lib/libstdc++ tests-lib-tests compattestfile,atf
+./usr/tests/lib/libstdc++/Atffile tests-lib-tests compattestfile,atf
+./usr/tests/lib/libstdc++/Kyuafile tests-lib-tests compattestfile,atf,kyua
+./usr/tests/lib/libstdc++/h_cin_nosync tests-lib-tests compattestfile,atf
+./usr/tests/lib/libstdc++/t_sync_with_stdio tests-lib-tests compattestfile,atf
./usr/tests/lib/libtre tests-lib-tests compattestfile,atf
./usr/tests/lib/libtre/Atffile tests-lib-tests compattestfile,atf
./usr/tests/lib/libtre/Kyuafile tests-lib-tests compattestfile,atf,kyua
Index: src/etc/mtree/NetBSD.dist.tests
diff -u src/etc/mtree/NetBSD.dist.tests:1.197.2.1 src/etc/mtree/NetBSD.dist.tests:1.197.2.2
--- src/etc/mtree/NetBSD.dist.tests:1.197.2.1 Mon Sep 4 17:33:28 2023
+++ src/etc/mtree/NetBSD.dist.tests Fri Aug 23 18:28:09 2024
@@ -1,4 +1,4 @@
-# $NetBSD: NetBSD.dist.tests,v 1.197.2.1 2023/09/04 17:33:28 martin Exp $
+# $NetBSD: NetBSD.dist.tests,v 1.197.2.2 2024/08/23 18:28:09 martin Exp $
./usr/libdata/debug/usr/tests
./usr/libdata/debug/usr/tests/atf
@@ -129,6 +129,7 @@
./usr/libdata/debug/usr/tests/lib/librumphijack
./usr/libdata/debug/usr/tests/lib/libskey
./usr/libdata/debug/usr/tests/lib/libsljit
+./usr/libdata/debug/usr/tests/lib/libstdc++
./usr/libdata/debug/usr/tests/lib/libtre
./usr/libdata/debug/usr/tests/lib/libusbhid
./usr/libdata/debug/usr/tests/lib/libutil
@@ -341,6 +342,7 @@
./usr/tests/lib/librumphijack
./usr/tests/lib/libskey
./usr/tests/lib/libsljit
+./usr/tests/lib/libstdc++
./usr/tests/lib/libtre
./usr/tests/lib/libtre/data
./usr/tests/lib/libusbhid
Index: src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc
diff -u src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc:1.1.1.12 src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc:1.1.1.12.6.1
--- src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc:1.1.1.12 Sat Apr 10 22:10:12 2021
+++ src/external/gpl3/gcc/dist/libstdc++-v3/config/io/basic_file_stdio.cc Fri Aug 23 18:28:10 2024
@@ -190,7 +190,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
{ this->close(); }
__basic_file<char>*
- __basic_file<char>::sys_open(__c_file* __file, ios_base::openmode)
+ __basic_file<char>::sys_open(__c_file* __file, ios_base::openmode __mode)
{
__basic_file* __ret = NULL;
if (!this->is_open() && __file)
@@ -199,7 +199,7 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
// POSIX guarantees that fflush sets errno on error, but C doesn't.
errno = 0;
do
- __err = fflush(__file);
+ __err = (__mode == std::ios_base::in ? 0 : fflush(__file));
while (__err && errno == EINTR);
errno = __save_errno;
if (!__err)
Added files:
Index: src/tests/lib/libstdc++/Makefile
diff -u /dev/null src/tests/lib/libstdc++/Makefile:1.1.4.2
--- /dev/null Fri Aug 23 18:28:10 2024
+++ src/tests/lib/libstdc++/Makefile Fri Aug 23 18:28:09 2024
@@ -0,0 +1,12 @@
+# $NetBSD: Makefile,v 1.1.4.2 2024/08/23 18:28:09 martin Exp $
+#
+
+NOMAN= # defined
+
+TESTSDIR= ${TESTSBASE}/lib/libstdc++
+BINDIR= ${TESTSDIR}
+
+TESTS_SH+= t_sync_with_stdio
+PROG_CXX+= h_cin_nosync
+
+.include <bsd.test.mk>
Index: src/tests/lib/libstdc++/h_cin_nosync.cc
diff -u /dev/null src/tests/lib/libstdc++/h_cin_nosync.cc:1.1.4.2
--- /dev/null Fri Aug 23 18:28:10 2024
+++ src/tests/lib/libstdc++/h_cin_nosync.cc Fri Aug 23 18:28:09 2024
@@ -0,0 +1,40 @@
+/* $NetBSD: h_cin_nosync.cc,v 1.1.4.2 2024/08/23 18:28:09 martin Exp $ */
+
+/*-
+ * Copyright (c) 2024 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. 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 NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
+ */
+
+#include <iostream>
+
+int
+main(void)
+{
+ char buf[128];
+
+ std::ios::sync_with_stdio(false);
+ std::cin.read(buf, sizeof(buf));
+ std::cout << std::cin.gcount() << std::endl;
+ return 0;
+}
Index: src/tests/lib/libstdc++/t_sync_with_stdio.sh
diff -u /dev/null src/tests/lib/libstdc++/t_sync_with_stdio.sh:1.2.4.2
--- /dev/null Fri Aug 23 18:28:10 2024
+++ src/tests/lib/libstdc++/t_sync_with_stdio.sh Fri Aug 23 18:28:09 2024
@@ -0,0 +1,41 @@
+# $NetBSD: t_sync_with_stdio.sh,v 1.2.4.2 2024/08/23 18:28:09 martin Exp $
+#
+# Copyright (c) 2024 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+# 1. Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# 2. 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 NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
+#
+
+cin_nosync_head()
+{
+ atf_set descr "Check cin works after std::ios::sync_with_stdio(false)"
+}
+cin_nosync_body()
+{
+ echo hello >in
+ atf_check -o inline:'6\n' "$(atf_get_srcdir)"/h_cin_nosync <in
+}
+
+atf_init_test_cases()
+{
+ atf_add_test_case cin_nosync
+}