bug fixes for LEASES from Rick Macklem
[unix-history] / usr / src / sys / kern / uipc_domain.c
index fa67b61..5f679c3 100644 (file)
@@ -4,17 +4,19 @@
  *
  * %sccs.include.redist.c%
  *
  *
  * %sccs.include.redist.c%
  *
- *     @(#)uipc_domain.c       7.9 (Berkeley) %G%
+ *     @(#)uipc_domain.c       7.16 (Berkeley) %G%
  */
 
  */
 
-#include <sys/cdefs.h>
-#include "param.h"
-#include "socket.h"
-#include "protosw.h"
-#include "domain.h"
-#include "mbuf.h"
-#include "time.h"
-#include "kernel.h"
+#include <sys/param.h>
+#include <sys/socket.h>
+#include <sys/protosw.h>
+#include <sys/domain.h>
+#include <sys/mbuf.h>
+#include <sys/time.h>
+#include <sys/kernel.h>
+#include <sys/proc.h>
+#include <vm/vm.h>
+#include <sys/sysctl.h>
 
 #define        ADDDOMAIN(x)    { \
        extern struct domain __CONCAT(x,domain); \
 
 #define        ADDDOMAIN(x)    { \
        extern struct domain __CONCAT(x,domain); \
@@ -40,9 +42,6 @@ domaininit()
 #ifdef ISO
        ADDDOMAIN(iso);
 #endif
 #ifdef ISO
        ADDDOMAIN(iso);
 #endif
-#ifdef RMP
-       ADDDOMAIN(rmp);
-#endif
 #ifdef CCITT
        ADDDOMAIN(ccitt);
 #endif
 #ifdef CCITT
        ADDDOMAIN(ccitt);
 #endif
@@ -112,6 +111,43 @@ found:
        return (maybe);
 }
 
        return (maybe);
 }
 
+net_sysctl(name, namelen, oldp, oldlenp, newp, newlen, p)
+       int *name;
+       u_int namelen;
+       void *oldp;
+       size_t *oldlenp;
+       void *newp;
+       size_t newlen;
+       struct proc *p;
+{
+       register struct domain *dp;
+       register struct protosw *pr;
+       int family, protocol;
+
+       /*
+        * All sysctl names at this level are nonterminal;
+        * next two components are protocol family and protocol number,
+        * then at least one addition component.
+        */
+       if (namelen < 3)
+               return (EISDIR);                /* overloaded */
+       family = name[0];
+       protocol = name[1];
+
+       if (family == 0)
+               return (0);
+       for (dp = domains; dp; dp = dp->dom_next)
+               if (dp->dom_family == family)
+                       goto found;
+       return (ENOPROTOOPT);
+found:
+       for (pr = dp->dom_protosw; pr < dp->dom_protoswNPROTOSW; pr++)
+               if (pr->pr_protocol == protocol && pr->pr_sysctl)
+                       return ((*pr->pr_sysctl)(name + 2, namelen - 2,
+                           oldp, oldlenp, newp, newlen));
+       return (ENOPROTOOPT);
+}
+
 pfctlinput(cmd, sa)
        int cmd;
        struct sockaddr *sa;
 pfctlinput(cmd, sa)
        int cmd;
        struct sockaddr *sa;