1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*      Copyright (c) 1988 AT&T     */
  22 /*        All Rights Reserved   */
  23 /*
  24  * Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
  25  * Use is subject to license terms.
  26  * Copyright 2017 Joyent, Inc.
  27  */
  28 
  29 #ifndef _SYS_VM_MACHPARAM_H
  30 #define _SYS_VM_MACHPARAM_H
  31 
  32 #ifdef  __cplusplus
  33 extern "C" {
  34 #endif
  35 
  36 /*
  37  * Machine dependent constants for PC.
  38  */
  39 
  40 /*
  41  * USRTEXT is the start of the user text/data space.
  42  */
  43 #define USRTEXT         USRSTACK
  44 
  45 /*
  46  * Virtual memory related constants for UNIX resource control, all in bytes.
  47  * The default stack size (initial stack size limit) keeps the stack from
  48  * taking more than 2 page directory entries in addition to the part of
  49  * the page directory entry which also maps the initial text and data,
  50  * and makes the default slightly bigger than the 8MB on SPARC.
  51  */
  52 #ifdef __amd64
  53 /*
  54  * On amd64, the stack grows down from just below KERNELBASE (see the
  55  * definition of USERLIMIT in i86pc/sys/machparam.h). Theoretically,
  56  * it could grow down to the top of the VA hole (0xffff800000000000),
  57  * giving it a possible maximum of about 125T. For an amd64 xpv
  58  * kernel, all user VA space is below the VA hole. The theoretical
  59  * maximum for the stack is about the same, although it can't grow
  60  * to quite that size, since it would clash with the heap.
  61  *
  62  * Pick an upper limit that will work in both cases: 32T.
  63  *
  64  * For 32bit processes, the stack is below the text segment.
  65  */
  66 #define MAXSSIZ         (32ULL * 1024ULL * 1024ULL * 1024ULL * 1024ULL)
  67 #else
  68 #define MAXSSIZ         (USRSTACK - 1024*1024)
  69 #endif /* __amd64 */
  70 #define DFLSSIZ         (8*1024*1024 + ((USRSTACK) & 0x3FFFFF))
  71 
  72 /*
  73  * Size of the kernel segkmem system pte table.  This virtual
  74  * space is controlled by the resource map "kernelmap".
  75  */
  76 #define SYSPTSIZE       ((61*1024*1024) / MMU_PAGESIZE)
  77 
  78 /*
  79  * Size of the ethernet addressable kernel segkmem system pte table.
  80  * This virtual space is controlled by the resource map "ekernelmap".
  81  * The ethernet interfaces in some sun machines can address only
  82  * the upper 16 Megabytes of memory.  Since the ethernet
  83  * driver kmem_allocs its memory, we bias all kmem_allocs
  84  * to try ekernelmap first and if it fails try kernelmap.
  85  * Folks that allocate directly out of kernelmap, above,
  86  * get memory that is non-ethernet addressable.
  87  */
  88 #define E_SYSPTSIZE     (0x2000000 / MMU_PAGESIZE)
  89 
  90 /*
  91  * The virtual address space to be used by the seg_map segment
  92  * driver for fast kernel mappings.
  93  */
  94 #if defined(__i386)
  95 #define SEGMAPDEFAULT   (16 * 1024 * 1024)
  96 #define SEGMAPMAX       (128 * 1024 * 1024)
  97 #else
  98 #define SEGMAPDEFAULT   (64 * 1024 * 1024)
  99 #endif
 100 
 101 /*
 102  * The time for a process to be blocked before being very swappable.
 103  * This is a number of seconds which the system takes as being a non-trivial
 104  * amount of real time. You probably shouldn't change this;
 105  * it is used in subtle ways (fractions and multiples of it are, that is, like
 106  * half of a ``long time'', almost a long time, etc.)
 107  * It is related to human patience and other factors which don't really
 108  * change over time.
 109  */
 110 #define MAXSLP          20
 111 
 112 /*
 113  * A swapped in process is given a small amount of core without being bothered
 114  * by the page replacement algorithm. Basically this says that if you are
 115  * swapped in you deserve some resources. We protect the last SAFERSS
 116  * pages against paging and will just swap you out rather than paging you.
 117  * Note that each process has at least UPAGES pages which are not
 118  * paged anyways so this number just means a swapped in process is
 119  * given around 32k bytes.
 120  */
 121 /*
 122  * nominal ``small'' resident set size
 123  * protected against replacement
 124  */
 125 #define SAFERSS         3
 126 
 127 /*
 128  * DISKRPM is used to estimate the number of paging i/o operations
 129  * which one can expect from a single disk controller.
 130  *
 131  * XXX - The system doesn't account for multiple swap devices.
 132  */
 133 #define DISKRPM         600
 134 
 135 /*
 136  * The maximum value for handspreadpages which is the the distance
 137  * between the two clock hands in pages. This is only used when the page
 138  * scanner is first started.
 139  */
 140 #define MAXHANDSPREADPAGES      ((64 * 1024 * 1024) / PAGESIZE)
 141 
 142 /*
 143  * Paged text files that are less than PGTHRESH bytes
 144  * may be "prefaulted in" instead of demand paged.
 145  */
 146 #define PGTHRESH        (280 * 1024)
 147 
 148 #ifdef  __cplusplus
 149 }
 150 #endif
 151 
 152 #endif  /* _SYS_VM_MACHPARAM_H */