The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/conf/param.c

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*      $NetBSD: param.c,v 1.45 2003/12/31 12:34:22 martin Exp $        */
    2 
    3 /*
    4  * Copyright (c) 1980, 1986, 1989 Regents of the University of California.
    5  * All rights reserved.
    6  * (c) UNIX System Laboratories, Inc.
    7  * All or some portions of this file are derived from material licensed
    8  * to the University of California by American Telephone and Telegraph
    9  * Co. or Unix System Laboratories, Inc. and are reproduced herein with
   10  * the permission of UNIX System Laboratories, Inc.
   11  *
   12  * Redistribution and use in source and binary forms, with or without
   13  * modification, are permitted provided that the following conditions
   14  * are met:
   15  * 1. Redistributions of source code must retain the above copyright
   16  *    notice, this list of conditions and the following disclaimer.
   17  * 2. Redistributions in binary form must reproduce the above copyright
   18  *    notice, this list of conditions and the following disclaimer in the
   19  *    documentation and/or other materials provided with the distribution.
   20  * 3. Neither the name of the University nor the names of its contributors
   21  *    may be used to endorse or promote products derived from this software
   22  *    without specific prior written permission.
   23  *
   24  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
   25  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   26  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   27  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
   28  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   29  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   30  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   31  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   32  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   33  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   34  * SUCH DAMAGE.
   35  *
   36  *      @(#)param.c     7.20 (Berkeley) 6/27/91
   37  */
   38 
   39 #include <sys/cdefs.h>
   40 __KERNEL_RCSID(0, "$NetBSD: param.c,v 1.45 2003/12/31 12:34:22 martin Exp $");
   41 
   42 #include "opt_rtc_offset.h"
   43 #include "opt_sysv.h"
   44 #include "opt_sysvparam.h"
   45 
   46 #include <sys/param.h>
   47 #include <sys/systm.h>
   48 #include <sys/socket.h>
   49 #include <sys/socketvar.h>
   50 #include <sys/proc.h>
   51 #include <sys/vnode.h>
   52 #include <sys/file.h>
   53 #include <sys/callout.h>
   54 #include <sys/mbuf.h>
   55 #include <ufs/ufs/quota.h>
   56 #include <sys/kernel.h>
   57 #include <sys/utsname.h>
   58 #ifdef SYSVSHM
   59 #include <machine/vmparam.h>
   60 #include <sys/shm.h>
   61 #endif
   62 #ifdef SYSVSEM
   63 #include <sys/sem.h>
   64 #endif
   65 #ifdef SYSVMSG
   66 #include <sys/msg.h>
   67 #endif
   68 
   69 #define CONFIG_FILE
   70 #include "config_file.h"
   71 
   72 /*
   73  * System parameter formulae.
   74  *
   75  * This file is copied into each directory where we compile
   76  * the kernel; it should be modified there to suit local taste
   77  * if necessary.
   78  *
   79  * Compiled with -DHZ=xx -DRTC_OFFSET=x -DMAXUSERS=xx
   80  */
   81 
   82 #ifdef TIMEZONE
   83 #error TIMEZONE is an obsolete kernel option.
   84 #endif
   85 
   86 #ifdef DST
   87 #error DST is an obsolete kernel option.
   88 #endif
   89 
   90 #ifndef RTC_OFFSET
   91 #define RTC_OFFSET 0
   92 #endif
   93 
   94 #ifndef HZ
   95 #define HZ 100
   96 #endif
   97 
   98 #ifndef MAXFILES
   99 #define MAXFILES        (3 * (NPROC + MAXUSERS) + 80)
  100 #endif
  101 
  102 int     hz = HZ;
  103 int     tick = 1000000 / HZ;
  104 int     tickadj = 240000 / (60 * HZ);           /* can adjust 240ms in 60s */
  105 int     rtc_offset = RTC_OFFSET;
  106 int     maxproc = NPROC;
  107 int     desiredvnodes = NVNODE;
  108 int     maxfiles = MAXFILES;
  109 int     ncallout = 16 + NPROC;  /* size of callwheel (rounded to ^2) */
  110 int     fscale = FSCALE;        /* kernel uses `FSCALE', user uses `fscale' */
  111 
  112 /*
  113  * Various mbuf-related parameters.  These can also be changed at run-time
  114  * with sysctl.
  115  */
  116 int     nmbclusters = NMBCLUSTERS;
  117 
  118 #ifndef MBLOWAT
  119 #define MBLOWAT         16
  120 #endif
  121 int     mblowat = MBLOWAT;
  122 
  123 #ifndef MCLLOWAT
  124 #define MCLLOWAT        8
  125 #endif
  126 int     mcllowat = MCLLOWAT;
  127 
  128 /*
  129  * Values in support of System V compatible shared memory.      XXX
  130  */
  131 #ifdef SYSVSHM
  132 #ifndef SHMMAX
  133 #define SHMMAX  SHMMAXPGS       /* shminit() performs a `*= PAGE_SIZE' */
  134 #endif
  135 #ifndef SHMMIN
  136 #define SHMMIN  1
  137 #endif
  138 #ifndef SHMMNI
  139 #define SHMMNI  128             /* <64k, see IPCID_TO_IX in ipc.h */
  140 #endif
  141 #ifndef SHMSEG
  142 #define SHMSEG  128
  143 #endif
  144 #define SHMALL  SHMMAXPGS
  145 
  146 struct  shminfo shminfo = {
  147         SHMMAX,
  148         SHMMIN,
  149         SHMMNI,
  150         SHMSEG,
  151         SHMALL
  152 };
  153 #endif
  154 
  155 /*
  156  * Values in support of System V compatible semaphores.
  157  */
  158 #ifdef SYSVSEM
  159 struct  seminfo seminfo = {
  160         SEMMAP,         /* # of entries in semaphore map */
  161         SEMMNI,         /* # of semaphore identifiers */
  162         SEMMNS,         /* # of semaphores in system */
  163         SEMMNU,         /* # of undo structures in system */
  164         SEMMSL,         /* max # of semaphores per id */
  165         SEMOPM,         /* max # of operations per semop call */
  166         SEMUME,         /* max # of undo entries per process */
  167         SEMUSZ,         /* size in bytes of undo structure */
  168         SEMVMX,         /* semaphore maximum value */
  169         SEMAEM          /* adjust on exit max value */
  170 };
  171 #endif
  172 
  173 /*
  174  * Values in support of System V compatible messages.
  175  */
  176 #ifdef SYSVMSG
  177 struct  msginfo msginfo = {
  178         MSGMAX,         /* max chars in a message */
  179         MSGMNI,         /* # of message queue identifiers */
  180         MSGMNB,         /* max chars in a queue */
  181         MSGTQL,         /* max messages in system */
  182         MSGSSZ,         /* size of a message segment */
  183                         /* (must be small power of 2 greater than 4) */
  184         MSGSEG          /* number of message segments */
  185 };
  186 #endif
  187 
  188 /*
  189  * These control when and to what priority a process gets after a certain
  190  * amount of CPU time expires.  AUTONICETIME is in seconds.
  191  * AUTONICEVAL is NOT offset by NZERO, i.e. it's between PRIO_MIN and PRIO_MAX.
  192  */
  193 #ifndef AUTONICETIME
  194 #define AUTONICETIME (60 * 10)  /* 10 minutes */
  195 #endif
  196 
  197 #ifndef AUTONICEVAL
  198 #define AUTONICEVAL 4           /* default + 4 */
  199 #endif
  200 
  201 int autonicetime = AUTONICETIME;
  202 int autoniceval = AUTONICEVAL;
  203 
  204 /*
  205  * Actual network mbuf sizes (read-only), for netstat.
  206  */
  207 const   int msize = MSIZE;
  208 const   int mclbytes = MCLBYTES;

Cache object: 5e3aa9bc6b6e45ce0a24eb4a6a8247e8


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.