svn commit: r357688 - head/contrib/netbsd-tests/lib/libc/c063

Kyle Evans kevans at FreeBSD.org
Sun Feb 9 04:05:33 UTC 2020


Author: kevans
Date: Sun Feb  9 04:05:30 2020
New Revision: 357688
URL: https://svnweb.freebsd.org/changeset/base/357688

Log:
  MFV r357687: Import NFS fix for O_SEARCH tests
  
  The version that ended upstream was ultimately slightly different than the
  version committed here; notably, statvfs() is used but it's redefined
  appropriately to statfs() on FreeBSD since we don't provide the fstypename
  for the former interface.

Modified:
  head/contrib/netbsd-tests/lib/libc/c063/t_o_search.c
Directory Properties:
  head/contrib/netbsd-tests/   (props changed)

Modified: head/contrib/netbsd-tests/lib/libc/c063/t_o_search.c
==============================================================================
--- head/contrib/netbsd-tests/lib/libc/c063/t_o_search.c	Sun Feb  9 04:01:46 2020	(r357687)
+++ head/contrib/netbsd-tests/lib/libc/c063/t_o_search.c	Sun Feb  9 04:05:30 2020	(r357688)
@@ -1,4 +1,4 @@
-/*	$NetBSD: t_o_search.c,v 1.9 2020/02/06 12:18:06 martin Exp $ */
+/*	$NetBSD: t_o_search.c,v 1.10 2020/02/08 19:58:36 kamil Exp $ */
 
 /*-
  * Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -29,16 +29,13 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: t_o_search.c,v 1.9 2020/02/06 12:18:06 martin Exp $");
+__RCSID("$NetBSD: t_o_search.c,v 1.10 2020/02/08 19:58:36 kamil Exp $");
 
 #include <atf-c.h>
 
 #include <sys/types.h>
-#ifdef __FreeBSD__
 #include <sys/mount.h>
-#else
 #include <sys/statvfs.h>
-#endif
 #include <sys/stat.h>
 
 #include <dirent.h>
@@ -60,6 +57,11 @@ __RCSID("$NetBSD: t_o_search.c,v 1.9 2020/02/06 12:18:
 #define USE_O_SEARCH
 #endif
 
+#ifdef __FreeBSD__
+#define	statvfs		statfs
+#define	fstatvfs	fstatfs
+#endif
+
 #define DIR "dir"
 #define FILE "dir/o_search"
 #define BASEFILE "o_search"
@@ -316,8 +318,9 @@ ATF_TC_HEAD(o_search_revokex, tc)
 }
 ATF_TC_BODY(o_search_revokex, tc)
 {
-	int dfd, fd;
+	struct statvfs vst;
 	struct stat sb;
+	int dfd, fd;
 
 	ATF_REQUIRE(mkdir(DIR, 0755) == 0);
 	ATF_REQUIRE((fd = open(FILE, O_CREAT|O_RDWR, 0644)) != -1);
@@ -327,23 +330,11 @@ ATF_TC_BODY(o_search_revokex, tc)
 
 	/* Drop permissions. The kernel must still not check the exec bit. */
 	ATF_REQUIRE(chmod(DIR, 0000) == 0);
-	{
-		const char *fstypename;
-#ifdef __FreeBSD__
-		struct statfs st;
 
-		fstatfs(dfd, &st);
-		fstypename = st.f_fstypename;
-#else
-		struct statvfs vst;
+	fstatvfs(dfd, &vst);
+	if (strcmp(vst.f_fstypename, "nfs") == 0)
+		atf_tc_expect_fail("NFS protocol cannot observe O_SEARCH semantics");
 
-		fstatvfs(dfd, &vst);
-		fstypename = vst.f_fstypename;
-#endif
-		if (strcmp(fstypename, "nfs") == 0)
-			atf_tc_expect_fail(
-			    "NFS protocol cannot observe O_SEARCH semantics");
-	}
 	ATF_REQUIRE(fstatat(dfd, BASEFILE, &sb, 0) == 0);
 
 	ATF_REQUIRE(close(dfd) == 0);


More information about the svn-src-head mailing list