Checking in KyoungSoo's changes for dynamically setting buffer sizes
authorSapan Bhatia <sapanb@cs.princeton.edu>
Thu, 2 Apr 2009 19:47:19 +0000 (19:47 +0000)
committerSapan Bhatia <sapanb@cs.princeton.edu>
Thu, 2 Apr 2009 19:47:19 +0000 (19:47 +0000)
fd_bmsocket.c

index 334b51e..6a830ed 100644 (file)
@@ -5,10 +5,28 @@
 #include <errno.h>
 #include "fdpass.h"
 
-unsigned int rcvbuf = 16*1024*1024;
+#define MAX_BUFSIZE (32*1024*1024)
 
-int main(int argc, char *argv[]) {
+/*------------------------------------------------------------------*/
+void
+receive_argument(int control_fd, int *rcvbuf, int *sndbuf)
+{
+  if (recv(control_fd, rcvbuf, sizeof(int), 0) != sizeof(int)) {
+    fprintf(stderr, "receiving the first argument failed\n");
+    exit(-1);
+  }
+  if (recv(control_fd, sndbuf, sizeof(int), 0) != sizeof(int)) {
+    fprintf(stderr, "receiving the first argument failed\n");
+    exit(-1);
+  }
+}
+/*------------------------------------------------------------------*/
+int 
+main(int argc, char *argv[]) 
+{
     int control_channel_fd, magic_socket;
+    int rcvbufsize = 0, sndbufsize = 0;
+    
     if (argc < 3) {
         printf("This script is called by vsys.\n");
         exit(1);
@@ -16,15 +34,40 @@ int main(int argc, char *argv[]) {
 
     sscanf(argv[2],"%d", &control_channel_fd);
 
-    magic_socket = socket(AF_INET, SOCK_STREAM, 0);
+    /* receive paramaters: rcvbufsize and sndbufsize */
+    receive_argument(control_channel_fd, &rcvbufsize, &sndbufsize);
+    if (rcvbufsize > MAX_BUFSIZE)
+      rcvbufsize = MAX_BUFSIZE;
+    if (sndbufsize > MAX_BUFSIZE)
+      sndbufsize = MAX_BUFSIZE;
 
+    magic_socket = socket(AF_INET, SOCK_STREAM, 0);
     if (magic_socket == -1) {
-        printf("Error creating socket: %d\n", errno);
+      fprintf(stderr, "Error creating socket: %d\n", errno);
+      exit(1);
+    }
+
+    /* buffer size <= 0 means we should ignore the parameter */
+    if (rcvbufsize > 0) {
+      if (setsockopt(magic_socket, 
+                    SOL_SOCKET, 
+                    SO_RCVBUFFORCE, 
+                    &rcvbufsize, sizeof(unsigned int))) {
+        fprintf(stderr, "Error calling setsockopt for RCVBUFFORCE: %d\n", 
+               errno);
         exit(1);
+      }
     }
-    if (setsockopt(magic_socket, SOL_SOCKET, SO_RCVBUFFORCE, &rcvbuf, sizeof(unsigned int))) {
-        printf("Error calling setsockopt: %d\n", errno);
+    if (sndbufsize > 0) {
+      if (setsockopt(magic_socket, 
+                    SOL_SOCKET, 
+                    SO_SNDBUFFORCE, 
+                    &sndbufsize, sizeof(unsigned int))) {
+        fprintf(stderr, "Error calling setsockopt for SNDBUFFORCE: %d\n", 
+               errno);
         exit(1);
+      }
     }
+
     send_fd(control_channel_fd, magic_socket);
 }