vm_machparam.h revision 7c478bd95313f5f23a4c958a745db2134aa03244
/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/* Copyright (c) 1988 AT&T */
/* All Rights Reserved */
/*
* Copyright 2004 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
#ifndef _SYS_VM_MACHPARAM_H
#define _SYS_VM_MACHPARAM_H
#pragma ident "%Z%%M% %I% %E% SMI"
#ifdef __cplusplus
extern "C" {
#endif
/*
* Machine dependent constants for PC.
*/
/*
* USRTEXT is the start of the user text/data space.
*/
#define USRTEXT USRSTACK
/*
* Virtual memory related constants for UNIX resource control, all in bytes.
* The default stack size (initial stack size limit) keeps the stack from
* taking more than 2 page directory entries in addition to the part of
* the page directory entry which also maps the initial text and data,
* and makes the default slightly bigger than the 8MB on SPARC.
*/
#ifdef __amd64
/*
* The maximum stack size on amd64 is chosen to allow the stack to consume
* all the va space between the top of the user's virtual address space and
* the top of the va hole.
*/
#define MAXSSIZ (USRSTACK - 0xFFFF800000000000)
#else
#define MAXSSIZ (USRSTACK - 1024*1024)
#endif
#define DFLSSIZ (8*1024*1024 + ((USRSTACK) & 0x3FFFFF))
/*
* The following are limits beyond which the hard or soft limits for stack
* and data cannot be increased. These may be viewed as fundamental
* characteristics of the system. Note: a bug in SVVS requires that the
* default hard limit be increasable, so the default hard limit must be
* less than these physical limits.
*/
#define DSIZE_LIMIT (USERLIMIT-USRTEXT) /* physical data limit */
#define SSIZE_LIMIT (USRSTACK) /* physical stack limit */
/*
* Size of the kernel segkmem system pte table. This virtual
* space is controlled by the resource map "kernelmap".
*/
#define SYSPTSIZE ((61*1024*1024) / MMU_PAGESIZE)
/*
* Size of the ethernet addressable kernel segkmem system pte table.
* This virtual space is controlled by the resource map "ekernelmap".
* The ethernet interfaces in some sun machines can address only
* the upper 16 Megabytes of memory. Since the ethernet
* driver kmem_allocs its memory, we bias all kmem_allocs
* to try ekernelmap first and if it fails try kernelmap.
* Folks that allocate directly out of kernelmap, above,
* get memory that is non-ethernet addressable.
*/
#define E_SYSPTSIZE (0x2000000 / MMU_PAGESIZE)
/*
* The virtual address space to be used by the seg_map segment
* driver for fast kernel mappings.
*/
#if defined(__i386)
#define SEGMAPDEFAULT (16 * 1024 * 1024)
#define SEGMAPMAX (128 * 1024 * 1024)
#else
#define SEGMAPDEFAULT (64 * 1024 * 1024)
#endif
/*
* The time for a process to be blocked before being very swappable.
* This is a number of seconds which the system takes as being a non-trivial
* amount of real time. You probably shouldn't change this;
* it is used in subtle ways (fractions and multiples of it are, that is, like
* half of a ``long time'', almost a long time, etc.)
* It is related to human patience and other factors which don't really
* change over time.
*/
#define MAXSLP 20
/*
* A swapped in process is given a small amount of core without being bothered
* by the page replacement algorithm. Basically this says that if you are
* swapped in you deserve some resources. We protect the last SAFERSS
* pages against paging and will just swap you out rather than paging you.
* Note that each process has at least UPAGES pages which are not
* paged anyways so this number just means a swapped in process is
* given around 32k bytes.
*/
/*
* nominal ``small'' resident set size
* protected against replacement
*/
#define SAFERSS 3
/*
* DISKRPM is used to estimate the number of paging i/o operations
* which one can expect from a single disk controller.
*
* XXX - The system doesn't account for multiple swap devices.
*/
#define DISKRPM 60
/*
* The maximum value for handspreadpages which is the the distance
* between the two clock hands in pages.
*/
#define MAXHANDSPREADPAGES ((64 * 1024 * 1024) / PAGESIZE)
/*
* Paged text files that are less than PGTHRESH bytes
* may be "prefaulted in" instead of demand paged.
*/
#define PGTHRESH (280 * 1024)
#ifdef __cplusplus
}
#endif
#endif /* _SYS_VM_MACHPARAM_H */