socsvn commit: r253376 - soc2013/dpl/head/contrib/bzip2

dpl at FreeBSD.org dpl at FreeBSD.org
Sun Jun 23 12:53:54 UTC 2013


Author: dpl
Date: Sun Jun 23 12:53:53 2013
New Revision: 253376
URL: http://svnweb.FreeBSD.org/socsvn/?view=rev&rev=253376

Log:
  Declare structs needed to pass fds only if needed.
  (Not compiliing and don't know why, investigating)
  

Modified:
  soc2013/dpl/head/contrib/bzip2/bzip2.c

Modified: soc2013/dpl/head/contrib/bzip2/bzip2.c
==============================================================================
--- soc2013/dpl/head/contrib/bzip2/bzip2.c	Sun Jun 23 10:51:26 2013	(r253375)
+++ soc2013/dpl/head/contrib/bzip2/bzip2.c	Sun Jun 23 12:53:53 2013	(r253376)
@@ -91,7 +91,7 @@
 #	ifdef __FreeBSD__
 #		include <osreldate.h>
 #		if __FreeBSD_version >= 900041
-#			define CAPSICUM
+#			define CAPSICUM 1
 #			include <sys/capability.h>
 #			include <sys/socket.h>
 #			include <sys/wait.h>
@@ -221,17 +221,28 @@
 FILE    *outputHandleJustInCase;
 Int32   workFactor;
 
-#ifdef CAPSICUM
+#if CAPSICUM
 int sv[2], len;
+char buf[1];
+char cms[CMSG_SPACE(sizeof(int))];
+struct iovec iov;
 struct cmsghdr  *cmsg;
+struct msghdr msg;
 
+buf[0] = 0;
+iov.iov_base = buf;
+iov.iov_len = 1;
+
+cmsg->cmsg_len = CMSG_LEN(sizeof (int));
 cmsg->cmsg_level = SOL_SOCKET;
 cmsg->cmsg_type = SOL_RIGHTS;
-struct msghdr   msg;
+
 msg.msg_name = NULL;
-msg.msg_namelen = 0;
-msg.msg_iov = NULL;
-msg.msg_iovlen = 0;
+msg.,msg_namelen = 0;
+msg.msg_iov = &iov;
+msg.msg_iovlen = 1;
+/* msg.msg_control = (caddr_t)cms; */
+/* msg.msg_controllen = CMSG_LEN(sizeof(int)); */
 #endif
 
 static void    panic                 ( const Char* ) NORETURN;
@@ -987,7 +998,7 @@
    FILE*     fp;
    IntNative fh;
    fh = open(name, O_WRONLY|O_CREAT|O_EXCL, S_IWUSR|S_IRUSR);
-#  ifdef CAPSICUM
+#  if CAPSICUM
    cap_rights_limit(fh, CAP_WRITE);
 #  endif
    if (fh == -1) return NULL;
@@ -1162,7 +1173,7 @@
    FILE  *inStr;
    FILE  *outStr;
    Int32 n, i;
-#  ifdef CAPSICUM
+#  if CAPSICUM
    Int32 infd;
    pid_t forkpid;
 #  endif
@@ -1254,7 +1265,7 @@
    }
 
    if ( srcMode != SM_I2O ){
-#	ifdef CAPSICUM
+#	if CAPSICUM
 		 infd = open( inName, O_RDONLY );
 		 cap_rights_limit(infd, CAP_READ);
          inStr = fdopen ( infd, "rb" );
@@ -1328,7 +1339,7 @@
       fflush ( stderr );
    }
 
-#  ifdef CAPSICUM
+#  if CAPSICUM
    /* Pass the limited file descriptors with a unix domain socket. */
    switch( forkpid = rfork(RFPROC | RFCFDG) ) {
       case ( 0 ):
@@ -1358,7 +1369,7 @@
          
            deleteOutputOnInterrupt = False;
 
-#  ifdef CAPSICUM
+#  if CAPSICUM
            break;
 
 	  case ( -1 ):
@@ -1367,7 +1378,7 @@
 
 	  default:
 		 /* Send the two FDs */
-		 sendmsg();
+		 /* sendmsg(); */
          wait(NULL);
          return;
    }
@@ -1383,7 +1394,7 @@
    FILE  *inStr;
    FILE  *outStr;
    Int32 n, i;
-#  ifdef CAPSICUM
+#  if CAPSICUM
    Int32 infd;
    pid_t forkpid;
 #  endif
@@ -1480,7 +1491,7 @@
    }
 
    if ( srcMode != SM_I2O ){
-#	ifdef CAPSICUM
+#	if CAPSICUM
 		 infd = open( inName, O_RDONLY );
 		 cap_rights_limit(infd, CAP_READ);
          inStr = fdopen ( infd, "rb" );
@@ -2035,7 +2046,7 @@
 #     endif
    }
 
-#  ifdef CAPSICUM
+#  if CAPSICUM
 
    if ( socketpair(PF_LOCAL, SOCK_STREAM, 0, sv) == -1 ){
       fprintf ( stderr, "%s: Can't create socket: %s.\n", progName, strerror(errno) );


More information about the svn-soc-all mailing list