Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 27 Feb 2012 17:41:23 +0000 (UTC)
From:      Sergey Kandaurov <pluknet@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-9@freebsd.org
Subject:   svn commit: r232234 - stable/9/usr.bin/fstat
Message-ID:  <201202271741.q1RHfNDL029651@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: pluknet
Date: Mon Feb 27 17:41:23 2012
New Revision: 232234
URL: http://svn.freebsd.org/changeset/base/232234

Log:
  Backout r230934 (MFCed as r231859) which didn't work with unix sockets and
  several filesystem layers mounted at the specified path.
  
  Pointy hat to:	pluknet
  Reported by:	flo via broken tinderbox

Modified:
  stable/9/usr.bin/fstat/fstat.c
Directory Properties:
  stable/9/usr.bin/fstat/   (props changed)

Modified: stable/9/usr.bin/fstat/fstat.c
==============================================================================
--- stable/9/usr.bin/fstat/fstat.c	Mon Feb 27 17:39:34 2012	(r232233)
+++ stable/9/usr.bin/fstat/fstat.c	Mon Feb 27 17:41:23 2012	(r232234)
@@ -38,7 +38,6 @@ __FBSDID("$FreeBSD$");
 #include <sys/socketvar.h>
 #include <sys/sysctl.h>
 #include <sys/queue.h>
-#include <sys/un.h>
 
 #include <netinet/in.h>
 
@@ -225,53 +224,28 @@ static void
 print_file_info(struct procstat *procstat, struct filestat *fst,
     const char *uname, const char *cmd, int pid)
 {
-	struct sockstat sock;
 	struct vnstat vn;
 	DEVS *d;
 	const char *filename;
 	int error, fsmatch = 0;
 	char errbuf[_POSIX2_LINE_MAX];
 
-	error = 0;
 	filename = NULL;
 	if (checkfile != 0) {
-		switch (fst->fs_type) {
-		case PS_FST_TYPE_VNODE:
-		case PS_FST_TYPE_FIFO:
-			error = procstat_get_vnode_info(procstat, fst, &vn, errbuf);
-			break;
-		case PS_FST_TYPE_SOCKET:
-			error = procstat_get_socket_info(procstat, fst, &sock, errbuf);
-			break;
-		default:
+		if (fst->fs_type != PS_FST_TYPE_VNODE &&
+		    fst->fs_type != PS_FST_TYPE_FIFO)
 			return;
-		}
+		error = procstat_get_vnode_info(procstat, fst, &vn, errbuf);
 		if (error != 0)
 			return;
 
 		for (d = devs; d != NULL; d = d->next)
-			switch (fst->fs_type) {
-			case PS_FST_TYPE_VNODE:
-			case PS_FST_TYPE_FIFO:			
-				if (d->fsid == vn.vn_fsid) {
-					fsmatch = 1;
-					if ((unsigned)d->ino == vn.vn_fileid) {
-						filename = d->name;
-						break;
-					}
-				}
-				break;
-			case PS_FST_TYPE_SOCKET:
-				if (sock.dom_family == AF_UNIX) {
-					fsmatch = 1;
-					if (strcmp(((struct sockaddr_un *)
-					    (&sock.sa_local))->sun_path,
-					    d->name) == 0) {
-						filename = d->name;
-						break;
-					}
+			if (d->fsid == vn.vn_fsid) {
+				fsmatch = 1;
+				if ((unsigned)d->ino == vn.vn_fileid) {
+					filename = d->name;
+					break;
 				}
-				break;
 			}
 		if (fsmatch == 0 || (filename == NULL && fsflg == 0))
 			return;



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201202271741.q1RHfNDL029651>