17c478bd9Sstevel@tonic-gate /* 27c478bd9Sstevel@tonic-gate * CDDL HEADER START 37c478bd9Sstevel@tonic-gate * 47c478bd9Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5ae115bc7Smrj * Common Development and Distribution License (the "License"). 6ae115bc7Smrj * You may not use this file except in compliance with the License. 77c478bd9Sstevel@tonic-gate * 87c478bd9Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 97c478bd9Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 107c478bd9Sstevel@tonic-gate * See the License for the specific language governing permissions 117c478bd9Sstevel@tonic-gate * and limitations under the License. 127c478bd9Sstevel@tonic-gate * 137c478bd9Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 147c478bd9Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 157c478bd9Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 167c478bd9Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 177c478bd9Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 187c478bd9Sstevel@tonic-gate * 197c478bd9Sstevel@tonic-gate * CDDL HEADER END 207c478bd9Sstevel@tonic-gate */ 2189621fe1SMarcel Telka 227c478bd9Sstevel@tonic-gate /* 2389621fe1SMarcel Telka * Copyright 2014 Nexenta Systems, Inc. All rights reserved. 24cb15d5d9SPeter Rival * Copyright (c) 1998, 2010, Oracle and/or its affiliates. All rights reserved. 257c478bd9Sstevel@tonic-gate */ 267c478bd9Sstevel@tonic-gate 277c478bd9Sstevel@tonic-gate /* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */ 287c478bd9Sstevel@tonic-gate /* All Rights Reserved */ 297c478bd9Sstevel@tonic-gate 307c478bd9Sstevel@tonic-gate /* 317c478bd9Sstevel@tonic-gate * University Copyright- Copyright (c) 1982, 1986, 1988 327c478bd9Sstevel@tonic-gate * The Regents of the University of California 337c478bd9Sstevel@tonic-gate * All Rights Reserved 347c478bd9Sstevel@tonic-gate * 357c478bd9Sstevel@tonic-gate * University Acknowledgment- Portions of this document are derived from 367c478bd9Sstevel@tonic-gate * software developed by the University of California, Berkeley, and its 377c478bd9Sstevel@tonic-gate * contributors. 387c478bd9Sstevel@tonic-gate */ 397c478bd9Sstevel@tonic-gate 407c478bd9Sstevel@tonic-gate #ifndef _SYS_PARAM_H 417c478bd9Sstevel@tonic-gate #define _SYS_PARAM_H 427c478bd9Sstevel@tonic-gate 437c478bd9Sstevel@tonic-gate #ifndef _ASM /* Avoid typedef headaches for assembly files */ 447c478bd9Sstevel@tonic-gate #include <sys/types.h> 457c478bd9Sstevel@tonic-gate #include <sys/isa_defs.h> 467c478bd9Sstevel@tonic-gate #endif /* _ASM */ 477c478bd9Sstevel@tonic-gate 48*4870e0a7SRichard PALO #include <sys/null.h> 497c478bd9Sstevel@tonic-gate 507c478bd9Sstevel@tonic-gate #ifdef __cplusplus 517c478bd9Sstevel@tonic-gate extern "C" { 527c478bd9Sstevel@tonic-gate #endif 537c478bd9Sstevel@tonic-gate 547c478bd9Sstevel@tonic-gate /* 557c478bd9Sstevel@tonic-gate * Fundamental variables; don't change too often. 567c478bd9Sstevel@tonic-gate */ 577c478bd9Sstevel@tonic-gate 587c478bd9Sstevel@tonic-gate /* 597c478bd9Sstevel@tonic-gate * _POSIX_VDISABLE has historically been defined in <sys/param.h> since 607c478bd9Sstevel@tonic-gate * an early merge with AT&T source. It has also historically been defined 617c478bd9Sstevel@tonic-gate * in <sys/termios.h>. The POSIX standard, IEEE Std. 1003.1-1988 initially 627c478bd9Sstevel@tonic-gate * required the existence of _POSIX_VDISABLE in <sys/termios.h>. 637c478bd9Sstevel@tonic-gate * Subsequent versions of the IEEE Standard as well as the X/Open 647c478bd9Sstevel@tonic-gate * specifications required that _POSIX_VDISABLE be defined in <unistd.h> 657c478bd9Sstevel@tonic-gate * while still allowing for it's existence in other headers. With the 667c478bd9Sstevel@tonic-gate * introduction of XPG6, _POSIX_VDISABLE can only be defined in <unistd.h>. 677c478bd9Sstevel@tonic-gate */ 687c478bd9Sstevel@tonic-gate #if !defined(_XPG6) || defined(__EXTENSIONS__) 697c478bd9Sstevel@tonic-gate #ifndef _POSIX_VDISABLE 707c478bd9Sstevel@tonic-gate #define _POSIX_VDISABLE 0 /* Disable special character functions */ 717c478bd9Sstevel@tonic-gate #endif 727c478bd9Sstevel@tonic-gate #endif /* !defined(_XPG6) || defined(__EXTENSIONS__) */ 737c478bd9Sstevel@tonic-gate 747c478bd9Sstevel@tonic-gate #ifndef MAX_INPUT 757c478bd9Sstevel@tonic-gate #define MAX_INPUT 512 /* Maximum bytes stored in the input queue */ 767c478bd9Sstevel@tonic-gate #endif 777c478bd9Sstevel@tonic-gate 787c478bd9Sstevel@tonic-gate #ifndef MAX_CANON 797c478bd9Sstevel@tonic-gate #define MAX_CANON 256 /* Maximum bytes for canonical processing */ 807c478bd9Sstevel@tonic-gate #endif 817c478bd9Sstevel@tonic-gate 827c478bd9Sstevel@tonic-gate #define UID_NOBODY 60001 /* user ID no body */ 837c478bd9Sstevel@tonic-gate #define GID_NOBODY UID_NOBODY 84e913d9ecSLisa Week #define UID_UNKNOWN 96 85e913d9ecSLisa Week #define GID_UNKNOWN UID_UNKNOWN 86b9e076dcSyz147064 #define UID_DLADM 15 876ba597c5SAnurag S. Maskey #define UID_NETADM 16 886ba597c5SAnurag S. Maskey #define GID_NETADM 65 897c478bd9Sstevel@tonic-gate #define UID_NOACCESS 60002 /* user ID no access */ 907c478bd9Sstevel@tonic-gate 917c478bd9Sstevel@tonic-gate #ifdef _KERNEL 927c478bd9Sstevel@tonic-gate #define MAX_TASKID 999999 937c478bd9Sstevel@tonic-gate #define MAX_MAXPID 999999 94f48205beScasper #define MAXEPHUID 0xfffffffcu /* max ephemeral user id */ 9535a5a358SJonathan Adams 9635a5a358SJonathan Adams #define FAMOUS_PID_SCHED 0 9735a5a358SJonathan Adams #define FAMOUS_PID_INIT 1 9835a5a358SJonathan Adams #define FAMOUS_PID_PAGEOUT 2 9935a5a358SJonathan Adams #define FAMOUS_PID_FSFLUSH 3 10035a5a358SJonathan Adams #define FAMOUS_PIDS 4 1017c478bd9Sstevel@tonic-gate #endif 1027c478bd9Sstevel@tonic-gate 1037c478bd9Sstevel@tonic-gate #ifdef DEBUG 1047c478bd9Sstevel@tonic-gate #define DEFAULT_MAXPID 999999 1057c478bd9Sstevel@tonic-gate #define DEFAULT_JUMPPID 100000 1067c478bd9Sstevel@tonic-gate #else 1077c478bd9Sstevel@tonic-gate #define DEFAULT_MAXPID 30000 1087c478bd9Sstevel@tonic-gate #define DEFAULT_JUMPPID 0 1097c478bd9Sstevel@tonic-gate #endif 1107c478bd9Sstevel@tonic-gate 1117c478bd9Sstevel@tonic-gate #define MAXUID 2147483647 /* max user id */ 112f48205beScasper 1137c478bd9Sstevel@tonic-gate #define MAXPROJID MAXUID /* max project id */ 1147c478bd9Sstevel@tonic-gate #define MAXLINK 32767 /* max links */ 1157c478bd9Sstevel@tonic-gate 116f48205beScasper #define MINEPHUID 0x80000000u /* min ephemeral user id */ 117f48205beScasper 1187c478bd9Sstevel@tonic-gate #define NMOUNT 40 /* est. of # mountable fs for quota calc */ 1197c478bd9Sstevel@tonic-gate 1207c478bd9Sstevel@tonic-gate #define CANBSIZ 256 /* max size of typewriter line */ 1217c478bd9Sstevel@tonic-gate 1227c478bd9Sstevel@tonic-gate #define NOFILE 20 /* this define is here for */ 1237c478bd9Sstevel@tonic-gate /* compatibility purposes only */ 1247c478bd9Sstevel@tonic-gate /* and will be removed in a */ 1257c478bd9Sstevel@tonic-gate /* later release */ 1267c478bd9Sstevel@tonic-gate 1277c478bd9Sstevel@tonic-gate /* 1287c478bd9Sstevel@tonic-gate * These define the maximum and minimum allowable values of the 1297c478bd9Sstevel@tonic-gate * configurable parameter NGROUPS_MAX. 1307c478bd9Sstevel@tonic-gate */ 1317c478bd9Sstevel@tonic-gate #define NGROUPS_UMIN 0 13267dbe2beSCasper H.S. Dik #define NGROUPS_UMAX 1024 13367dbe2beSCasper H.S. Dik #define NGROUPS_OLDMAX 32 1347c478bd9Sstevel@tonic-gate 1357c478bd9Sstevel@tonic-gate /* 1367c478bd9Sstevel@tonic-gate * NGROUPS_MAX_DEFAULT: *MUST* match NGROUPS_MAX value in limits.h. 1377c478bd9Sstevel@tonic-gate */ 1387c478bd9Sstevel@tonic-gate #define NGROUPS_MAX_DEFAULT 16 1397c478bd9Sstevel@tonic-gate 1407c478bd9Sstevel@tonic-gate /* 1417c478bd9Sstevel@tonic-gate * Default process priority. Keep it in sync with limits.h. 1427c478bd9Sstevel@tonic-gate */ 1437c478bd9Sstevel@tonic-gate #define NZERO 20 1447c478bd9Sstevel@tonic-gate 1457c478bd9Sstevel@tonic-gate /* 1467c478bd9Sstevel@tonic-gate * Fundamental constants of the implementation--cannot be changed easily. 1477c478bd9Sstevel@tonic-gate */ 1487c478bd9Sstevel@tonic-gate 1497c478bd9Sstevel@tonic-gate #define NBPW sizeof (int) /* number of bytes in an integer */ 1507c478bd9Sstevel@tonic-gate 1517c478bd9Sstevel@tonic-gate #define CMASK 022 /* default mask for file creation */ 1527c478bd9Sstevel@tonic-gate #define CDLIMIT (1L<<11) /* default max write address */ 1537c478bd9Sstevel@tonic-gate #define NBPS 0x20000 /* Number of bytes per segment */ 1547c478bd9Sstevel@tonic-gate #define NBPSCTR 512 /* Bytes per disk sector. */ 1557c478bd9Sstevel@tonic-gate #define UBSIZE 512 /* unix block size. */ 1567c478bd9Sstevel@tonic-gate #define SCTRSHFT 9 /* Shift for BPSECT. */ 1577c478bd9Sstevel@tonic-gate 1587c478bd9Sstevel@tonic-gate #ifdef _LITTLE_ENDIAN 1597c478bd9Sstevel@tonic-gate #define lobyte(X) (((unsigned char *)&(X))[0]) 1607c478bd9Sstevel@tonic-gate #define hibyte(X) (((unsigned char *)&(X))[1]) 1617c478bd9Sstevel@tonic-gate #define loword(X) (((ushort_t *)&(X))[0]) 1627c478bd9Sstevel@tonic-gate #define hiword(X) (((ushort_t *)&(X))[1]) 1637c478bd9Sstevel@tonic-gate #endif 1647c478bd9Sstevel@tonic-gate #ifdef _BIG_ENDIAN 1657c478bd9Sstevel@tonic-gate #define lobyte(X) (((unsigned char *)&(X))[1]) 1667c478bd9Sstevel@tonic-gate #define hibyte(X) (((unsigned char *)&(X))[0]) 1677c478bd9Sstevel@tonic-gate #define loword(X) (((ushort_t *)&(X))[1]) 1687c478bd9Sstevel@tonic-gate #define hiword(X) (((ushort_t *)&(X))[0]) 1697c478bd9Sstevel@tonic-gate #endif 1707c478bd9Sstevel@tonic-gate 1717c478bd9Sstevel@tonic-gate /* REMOTE -- whether machine is primary, secondary, or regular */ 1727c478bd9Sstevel@tonic-gate #define SYSNAME 9 /* # chars in system name */ 1737c478bd9Sstevel@tonic-gate #define PREMOTE 39 1747c478bd9Sstevel@tonic-gate 1757c478bd9Sstevel@tonic-gate /* 1767c478bd9Sstevel@tonic-gate * MAXPATHLEN defines the longest permissible path length, 1777c478bd9Sstevel@tonic-gate * including the terminating null, after expanding symbolic links. 1787c478bd9Sstevel@tonic-gate * TYPICALMAXPATHLEN is used in a few places as an optimization 1797c478bd9Sstevel@tonic-gate * with a local buffer on the stack to avoid kmem_alloc(). 1807c478bd9Sstevel@tonic-gate * MAXSYMLINKS defines the maximum number of symbolic links 1817c478bd9Sstevel@tonic-gate * that may be expanded in a path name. It should be set high 1827c478bd9Sstevel@tonic-gate * enough to allow all legitimate uses, but halt infinite loops 1837c478bd9Sstevel@tonic-gate * reasonably quickly. 1847c478bd9Sstevel@tonic-gate * MAXNAMELEN is the length (including the terminating null) of 1857c478bd9Sstevel@tonic-gate * the longest permissible file (component) name. 1867c478bd9Sstevel@tonic-gate */ 1877c478bd9Sstevel@tonic-gate #define MAXPATHLEN 1024 1887c478bd9Sstevel@tonic-gate #define TYPICALMAXPATHLEN 64 1897c478bd9Sstevel@tonic-gate #define MAXSYMLINKS 20 1907c478bd9Sstevel@tonic-gate #define MAXNAMELEN 256 1917c478bd9Sstevel@tonic-gate 192d62bc4baSyz147064 /* 193d62bc4baSyz147064 * MAXLINKNAMELEN defines the longest possible permitted datalink name, 194d62bc4baSyz147064 * including the terminating NUL. Note that this must not be larger 195d62bc4baSyz147064 * than related networking constants such as LIFNAMSIZ. 196d62bc4baSyz147064 */ 197d62bc4baSyz147064 #define MAXLINKNAMELEN 32 198d62bc4baSyz147064 1997c478bd9Sstevel@tonic-gate #ifndef NADDR 2007c478bd9Sstevel@tonic-gate #define NADDR 13 2017c478bd9Sstevel@tonic-gate #endif 2027c478bd9Sstevel@tonic-gate 2037c478bd9Sstevel@tonic-gate /* 2047c478bd9Sstevel@tonic-gate * The following are defined to be the same as 2057c478bd9Sstevel@tonic-gate * defined in /usr/include/limits.h. They are 2067c478bd9Sstevel@tonic-gate * needed for pipe and FIFO compatibility. 2077c478bd9Sstevel@tonic-gate */ 2087c478bd9Sstevel@tonic-gate #ifndef PIPE_BUF /* max # bytes atomic in write to a pipe */ 2097c478bd9Sstevel@tonic-gate #define PIPE_BUF 5120 2107c478bd9Sstevel@tonic-gate #endif /* PIPE_BUF */ 2117c478bd9Sstevel@tonic-gate 2127c478bd9Sstevel@tonic-gate #ifndef PIPE_MAX /* max # bytes written to a pipe in a write */ 2137c478bd9Sstevel@tonic-gate #define PIPE_MAX 5120 2147c478bd9Sstevel@tonic-gate #endif /* PIPE_MAX */ 2157c478bd9Sstevel@tonic-gate 2167c478bd9Sstevel@tonic-gate #ifndef NBBY 2177c478bd9Sstevel@tonic-gate #define NBBY 8 /* number of bits per byte */ 2187c478bd9Sstevel@tonic-gate #endif 2197c478bd9Sstevel@tonic-gate 2207c478bd9Sstevel@tonic-gate /* macros replacing interleaving functions */ 2217c478bd9Sstevel@tonic-gate #define dkblock(bp) ((bp)->b_blkno) 2227c478bd9Sstevel@tonic-gate #define dkunit(bp) (minor((bp)->b_dev) >> 3) 2237c478bd9Sstevel@tonic-gate 2247c478bd9Sstevel@tonic-gate /* 2257c478bd9Sstevel@tonic-gate * File system parameters and macros. 2267c478bd9Sstevel@tonic-gate * 2277c478bd9Sstevel@tonic-gate * The file system is made out of blocks of at most MAXBSIZE units, 2287c478bd9Sstevel@tonic-gate * with smaller units (fragments) only in the last direct block. 2297c478bd9Sstevel@tonic-gate * MAXBSIZE primarily determines the size of buffers in the buffer 2307c478bd9Sstevel@tonic-gate * pool. It may be made larger without any effect on existing 2317c478bd9Sstevel@tonic-gate * file systems; however making it smaller make make some file 2327c478bd9Sstevel@tonic-gate * systems unmountable. 2337c478bd9Sstevel@tonic-gate * 2347c478bd9Sstevel@tonic-gate * Note that the blocked devices are assumed to have DEV_BSIZE 2357c478bd9Sstevel@tonic-gate * "sectors" and that fragments must be some multiple of this size. 2367c478bd9Sstevel@tonic-gate */ 2377c478bd9Sstevel@tonic-gate #define MAXBSIZE 8192 2387c478bd9Sstevel@tonic-gate #define DEV_BSIZE 512 2397c478bd9Sstevel@tonic-gate #define DEV_BSHIFT 9 /* log2(DEV_BSIZE) */ 2407c478bd9Sstevel@tonic-gate #define MAXFRAG 8 2417c478bd9Sstevel@tonic-gate #ifdef _SYSCALL32 2427c478bd9Sstevel@tonic-gate #define MAXOFF32_T 0x7fffffff 2437c478bd9Sstevel@tonic-gate #endif 2447c478bd9Sstevel@tonic-gate #ifdef _LP64 2457c478bd9Sstevel@tonic-gate #define MAXOFF_T 0x7fffffffffffffffl 2467c478bd9Sstevel@tonic-gate #define MAXOFFSET_T 0x7fffffffffffffffl 2477c478bd9Sstevel@tonic-gate #else 2487c478bd9Sstevel@tonic-gate #define MAXOFF_T 0x7fffffffl 2497c478bd9Sstevel@tonic-gate #ifdef _LONGLONG_TYPE 2507c478bd9Sstevel@tonic-gate #define MAXOFFSET_T 0x7fffffffffffffffLL 2517c478bd9Sstevel@tonic-gate #else 2527c478bd9Sstevel@tonic-gate #define MAXOFFSET_T 0x7fffffff 2537c478bd9Sstevel@tonic-gate #endif 2547c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 2557c478bd9Sstevel@tonic-gate 2567c478bd9Sstevel@tonic-gate #define btodb(bytes) /* calculates (bytes / DEV_BSIZE) */ \ 2577c478bd9Sstevel@tonic-gate ((unsigned long)(bytes) >> DEV_BSHIFT) 2587c478bd9Sstevel@tonic-gate #define dbtob(db) /* calculates (db * DEV_BSIZE) */ \ 2597c478bd9Sstevel@tonic-gate ((unsigned long)(db) << DEV_BSHIFT) 2607c478bd9Sstevel@tonic-gate 2617c478bd9Sstevel@tonic-gate /* 64 bit versions of btodb and dbtob */ 2627c478bd9Sstevel@tonic-gate #define lbtodb(bytes) /* calculates (bytes / DEV_BSIZE) */ \ 2637c478bd9Sstevel@tonic-gate ((u_offset_t)(bytes) >> DEV_BSHIFT) 2647c478bd9Sstevel@tonic-gate #define ldbtob(db) /* calculates (db * DEV_BSIZE) */ \ 2657c478bd9Sstevel@tonic-gate ((u_offset_t)(db) << DEV_BSHIFT) 2667c478bd9Sstevel@tonic-gate 2677c478bd9Sstevel@tonic-gate #ifndef _ASM /* Avoid typedef headaches for assembly files */ 2687c478bd9Sstevel@tonic-gate #ifndef NODEV 2697c478bd9Sstevel@tonic-gate #define NODEV (dev_t)(-1l) 2707c478bd9Sstevel@tonic-gate #ifdef _SYSCALL32 2717c478bd9Sstevel@tonic-gate #define NODEV32 (dev32_t)(-1) 2727c478bd9Sstevel@tonic-gate #endif /* _SYSCALL32 */ 2737c478bd9Sstevel@tonic-gate #endif /* NODEV */ 2747c478bd9Sstevel@tonic-gate #endif /* _ASM */ 2757c478bd9Sstevel@tonic-gate 2767c478bd9Sstevel@tonic-gate /* 2777c478bd9Sstevel@tonic-gate * Size of arg list passed in by user. 2787c478bd9Sstevel@tonic-gate */ 2797c478bd9Sstevel@tonic-gate #define NCARGS32 0x100000 2807c478bd9Sstevel@tonic-gate #define NCARGS64 0x200000 2817c478bd9Sstevel@tonic-gate #ifdef _LP64 2827c478bd9Sstevel@tonic-gate #define NCARGS NCARGS64 2837c478bd9Sstevel@tonic-gate #else /* _LP64 */ 2847c478bd9Sstevel@tonic-gate #define NCARGS NCARGS32 2857c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 2867c478bd9Sstevel@tonic-gate 2877c478bd9Sstevel@tonic-gate /* 2887c478bd9Sstevel@tonic-gate * Scale factor for scaled integers used to count 2897c478bd9Sstevel@tonic-gate * %cpu time and load averages. 2907c478bd9Sstevel@tonic-gate */ 2917c478bd9Sstevel@tonic-gate #define FSHIFT 8 /* bits to right of fixed binary point */ 2927c478bd9Sstevel@tonic-gate #define FSCALE (1<<FSHIFT) 2937c478bd9Sstevel@tonic-gate 2947c478bd9Sstevel@tonic-gate /* 2957c478bd9Sstevel@tonic-gate * Delay units are in microseconds. 2967c478bd9Sstevel@tonic-gate * 2977c478bd9Sstevel@tonic-gate * XXX These macros are not part of the DDI! 2987c478bd9Sstevel@tonic-gate */ 2997c478bd9Sstevel@tonic-gate #if defined(_KERNEL) && !defined(_ASM) 3007c478bd9Sstevel@tonic-gate extern void drv_usecwait(clock_t); 3017c478bd9Sstevel@tonic-gate #define DELAY(n) drv_usecwait(n) 3027c478bd9Sstevel@tonic-gate #define CDELAY(c, n) \ 3037c478bd9Sstevel@tonic-gate { \ 3047c478bd9Sstevel@tonic-gate register int N = n; \ 3057c478bd9Sstevel@tonic-gate while (--N > 0) { \ 3067c478bd9Sstevel@tonic-gate if (c) \ 3077c478bd9Sstevel@tonic-gate break; \ 3087c478bd9Sstevel@tonic-gate drv_usecwait(1); \ 3097c478bd9Sstevel@tonic-gate } \ 3107c478bd9Sstevel@tonic-gate } 3117c478bd9Sstevel@tonic-gate #endif /* defined(_KERNEL) && !defined(_ASM) */ 3127c478bd9Sstevel@tonic-gate 3137c478bd9Sstevel@tonic-gate #ifdef __cplusplus 3147c478bd9Sstevel@tonic-gate } 3157c478bd9Sstevel@tonic-gate #endif 3167c478bd9Sstevel@tonic-gate 3177c478bd9Sstevel@tonic-gate /* 3187c478bd9Sstevel@tonic-gate * The following is to free utilities from machine dependencies within 3197c478bd9Sstevel@tonic-gate * an architecture. Must be included after definition of DEV_BSIZE. 3207c478bd9Sstevel@tonic-gate */ 3217c478bd9Sstevel@tonic-gate 3227c478bd9Sstevel@tonic-gate #if (defined(_KERNEL) || defined(_KMEMUSER)) 3237c478bd9Sstevel@tonic-gate 3247c478bd9Sstevel@tonic-gate #if defined(_MACHDEP) 3257c478bd9Sstevel@tonic-gate #include <sys/machparam.h> 3267c478bd9Sstevel@tonic-gate #endif 3277c478bd9Sstevel@tonic-gate 3287c478bd9Sstevel@tonic-gate #ifdef __cplusplus 3297c478bd9Sstevel@tonic-gate extern "C" { 3307c478bd9Sstevel@tonic-gate #endif 3317c478bd9Sstevel@tonic-gate 3327c478bd9Sstevel@tonic-gate #if defined(_KERNEL) && !defined(_ASM) 3337c478bd9Sstevel@tonic-gate extern int cpu_decay_factor; 3347c478bd9Sstevel@tonic-gate extern pid_t maxpid; 3357c478bd9Sstevel@tonic-gate extern pid_t jump_pid; 3367c478bd9Sstevel@tonic-gate 3377c478bd9Sstevel@tonic-gate extern uintptr_t _kernelbase; 3387c478bd9Sstevel@tonic-gate extern uintptr_t _userlimit; 3397c478bd9Sstevel@tonic-gate extern uintptr_t _userlimit32; 3407c478bd9Sstevel@tonic-gate #endif /* defined(_KERNEL) && !defined(_ASM) */ 3417c478bd9Sstevel@tonic-gate 3428793b36bSNick Todd /* 3438793b36bSNick Todd * These three variables have been added within the #if defined(lint) 3448793b36bSNick Todd * below to ensure visibility to lint. This is a short term workaround 3458793b36bSNick Todd * to handle poor interaction between SS12 lint and these variables. 3468793b36bSNick Todd * CR 6742611 has been logged to address these issues. 3478793b36bSNick Todd */ 3488793b36bSNick Todd #if defined(lint) 3498793b36bSNick Todd extern int snooping; 3508793b36bSNick Todd extern uint_t snoop_interval; 3518793b36bSNick Todd extern const unsigned int _pageshift; 3528793b36bSNick Todd #endif /* lint */ 3537c478bd9Sstevel@tonic-gate 3547c478bd9Sstevel@tonic-gate #if !defined(_MACHDEP) 3557c478bd9Sstevel@tonic-gate 3567c478bd9Sstevel@tonic-gate /* 3577c478bd9Sstevel@tonic-gate * Implementation architecture independent sections of the kernel use 3587c478bd9Sstevel@tonic-gate * this section. 3597c478bd9Sstevel@tonic-gate */ 3607c478bd9Sstevel@tonic-gate #if defined(_KERNEL) && !defined(_ASM) 3617c478bd9Sstevel@tonic-gate extern int hz; 3627c478bd9Sstevel@tonic-gate extern int snooping; 3637c478bd9Sstevel@tonic-gate extern uint_t snoop_interval; 3647c478bd9Sstevel@tonic-gate extern const unsigned long _pagesize; 3657c478bd9Sstevel@tonic-gate extern const unsigned int _pageshift; 3667c478bd9Sstevel@tonic-gate extern const unsigned long _pageoffset; 3677c478bd9Sstevel@tonic-gate extern const unsigned long long _pagemask; 3687c478bd9Sstevel@tonic-gate extern const unsigned long _mmu_pagesize; 3697c478bd9Sstevel@tonic-gate extern const unsigned int _mmu_pageshift; 3707c478bd9Sstevel@tonic-gate extern const unsigned long _mmu_pageoffset; 3717c478bd9Sstevel@tonic-gate extern const unsigned long _mmu_pagemask; 3727c478bd9Sstevel@tonic-gate extern const uintptr_t _argsbase; 3737c478bd9Sstevel@tonic-gate extern const unsigned long _defaultstksz; 3747c478bd9Sstevel@tonic-gate extern const unsigned int _nbpg; 3757c478bd9Sstevel@tonic-gate extern const int _ncpu; 37623d9e5acSMichael Corcoran extern const int _ncpu_log2; 377cb15d5d9SPeter Rival extern const int _ncpu_p2; 3787c478bd9Sstevel@tonic-gate extern const int _clsize; 3797c478bd9Sstevel@tonic-gate #endif /* defined(_KERNEL) && !defined(_ASM) */ 3807c478bd9Sstevel@tonic-gate 38142a4b3dcSJonathan Adams /* Any additions to these #defines must be reflected in mdb_param.h+mdb_ks.c */ 3827c478bd9Sstevel@tonic-gate #define PAGESIZE _pagesize 3837c478bd9Sstevel@tonic-gate #define PAGESHIFT _pageshift 3847c478bd9Sstevel@tonic-gate #define PAGEOFFSET _pageoffset 3857c478bd9Sstevel@tonic-gate #define PAGEMASK _pagemask 3867c478bd9Sstevel@tonic-gate #define MMU_PAGESIZE _mmu_pagesize 3877c478bd9Sstevel@tonic-gate #define MMU_PAGESHIFT _mmu_pageshift 3887c478bd9Sstevel@tonic-gate #define MMU_PAGEOFFSET _mmu_pageoffset 3897c478bd9Sstevel@tonic-gate #define MMU_PAGEMASK _mmu_pagemask 3907c478bd9Sstevel@tonic-gate 3917c478bd9Sstevel@tonic-gate #define KERNELBASE _kernelbase 3927c478bd9Sstevel@tonic-gate #define USERLIMIT _userlimit 3937c478bd9Sstevel@tonic-gate #define USERLIMIT32 _userlimit32 3947c478bd9Sstevel@tonic-gate #define ARGSBASE _argsbase 3957c478bd9Sstevel@tonic-gate #define DEFAULTSTKSZ _defaultstksz 3967c478bd9Sstevel@tonic-gate #define NCPU _ncpu 39723d9e5acSMichael Corcoran #define NCPU_LOG2 _ncpu_log2 398cb15d5d9SPeter Rival #define NCPU_P2 _ncpu_p2 3997c478bd9Sstevel@tonic-gate 4007c478bd9Sstevel@tonic-gate #endif /* defined(_MACHDEP) */ 4017c478bd9Sstevel@tonic-gate 4027c478bd9Sstevel@tonic-gate /* 4037c478bd9Sstevel@tonic-gate * Some random macros for units conversion. 4047c478bd9Sstevel@tonic-gate * 4057c478bd9Sstevel@tonic-gate * These are machine independent but contain constants (*PAGESHIFT) which 4067c478bd9Sstevel@tonic-gate * are only defined in the machine dependent file. 4077c478bd9Sstevel@tonic-gate */ 4087c478bd9Sstevel@tonic-gate 4097c478bd9Sstevel@tonic-gate /* 4107c478bd9Sstevel@tonic-gate * MMU pages to bytes, and back (with and without rounding) 4117c478bd9Sstevel@tonic-gate */ 4127c478bd9Sstevel@tonic-gate #define mmu_ptob(x) ((x) << MMU_PAGESHIFT) 4137c478bd9Sstevel@tonic-gate #define mmu_btop(x) (((x)) >> MMU_PAGESHIFT) 4147c478bd9Sstevel@tonic-gate #define mmu_btopr(x) ((((x) + MMU_PAGEOFFSET) >> MMU_PAGESHIFT)) 4157c478bd9Sstevel@tonic-gate 4167c478bd9Sstevel@tonic-gate /* 4177c478bd9Sstevel@tonic-gate * 2 versions of pages to disk blocks 4187c478bd9Sstevel@tonic-gate */ 4197c478bd9Sstevel@tonic-gate #define mmu_ptod(x) ((x) << (MMU_PAGESHIFT - DEV_BSHIFT)) 4207c478bd9Sstevel@tonic-gate #define ptod(x) ((x) << (PAGESHIFT - DEV_BSHIFT)) 4217c478bd9Sstevel@tonic-gate 4227c478bd9Sstevel@tonic-gate /* 4237c478bd9Sstevel@tonic-gate * pages to bytes, and back (with and without rounding) 4247c478bd9Sstevel@tonic-gate * Large Files: The explicit cast of x to unsigned int is deliberately 4257c478bd9Sstevel@tonic-gate * removed as part of large files work. We pass longlong values to 4267c478bd9Sstevel@tonic-gate * theses macros. 4277c478bd9Sstevel@tonic-gate * 4287c478bd9Sstevel@tonic-gate * Cast the input to ptob() to be a page count. This enforces 64-bit 4297c478bd9Sstevel@tonic-gate * math on 64-bit kernels. For 32-bit kernels, callers must explicitly 4307c478bd9Sstevel@tonic-gate * cast the input to be a 64-bit type if values greater than 4GB/PAGESIZE 4317c478bd9Sstevel@tonic-gate * are possible. 4327c478bd9Sstevel@tonic-gate */ 4337c478bd9Sstevel@tonic-gate 4347c478bd9Sstevel@tonic-gate #ifdef _LP64 4357c478bd9Sstevel@tonic-gate #define ptob(x) (((pgcnt_t)(x)) << PAGESHIFT) 4367c478bd9Sstevel@tonic-gate #else 4377c478bd9Sstevel@tonic-gate #define ptob(x) ((x) << PAGESHIFT) 4387c478bd9Sstevel@tonic-gate #endif /* _LP64 */ 4397c478bd9Sstevel@tonic-gate #define btop(x) (((x) >> PAGESHIFT)) 4407c478bd9Sstevel@tonic-gate #define btopr(x) ((((x) + PAGEOFFSET) >> PAGESHIFT)) 4417c478bd9Sstevel@tonic-gate 4427c478bd9Sstevel@tonic-gate /* 4437c478bd9Sstevel@tonic-gate * disk blocks to pages, rounded and truncated 4447c478bd9Sstevel@tonic-gate */ 4457c478bd9Sstevel@tonic-gate #define NDPP (PAGESIZE/DEV_BSIZE) /* # of disk blocks per page */ 4467c478bd9Sstevel@tonic-gate #define dtop(DD) (((DD) + NDPP - 1) >> (PAGESHIFT - DEV_BSHIFT)) 4477c478bd9Sstevel@tonic-gate #define dtopt(DD) ((DD) >> (PAGESHIFT - DEV_BSHIFT)) 4487c478bd9Sstevel@tonic-gate 4497c478bd9Sstevel@tonic-gate /* 450ae115bc7Smrj * kB to pages and back 451ae115bc7Smrj */ 452ae115bc7Smrj #define kbtop(x) ((x) >> (PAGESHIFT - 10)) 453ae115bc7Smrj #define ptokb(x) ((x) << (PAGESHIFT - 10)) 454ae115bc7Smrj 455ae115bc7Smrj /* 4567c478bd9Sstevel@tonic-gate * POSIX.4 related configuration parameters 4577c478bd9Sstevel@tonic-gate */ 4587c478bd9Sstevel@tonic-gate #define _AIO_LISTIO_MAX (4096) 4597c478bd9Sstevel@tonic-gate #define _AIO_MAX (-1) 46006a502e8Scasper #define _MQ_OPEN_MAX (-1) 4617c478bd9Sstevel@tonic-gate #define _MQ_PRIO_MAX (32) 4627c478bd9Sstevel@tonic-gate #define _SEM_NSEMS_MAX INT_MAX 4637c478bd9Sstevel@tonic-gate #define _SEM_VALUE_MAX INT_MAX 4647c478bd9Sstevel@tonic-gate 4657c478bd9Sstevel@tonic-gate #ifdef __cplusplus 4667c478bd9Sstevel@tonic-gate } 4677c478bd9Sstevel@tonic-gate #endif 4687c478bd9Sstevel@tonic-gate 4697c478bd9Sstevel@tonic-gate #else /* (defined(_KERNEL) || defined(_KMEMUSER)) */ 4707c478bd9Sstevel@tonic-gate 4717c478bd9Sstevel@tonic-gate /* 4727c478bd9Sstevel@tonic-gate * The following are assorted machine dependent values which can be 4737c478bd9Sstevel@tonic-gate * obtained in a machine independent manner through sysconf(2) or 4747c478bd9Sstevel@tonic-gate * sysinfo(2). In order to guarantee that these provide the expected 4757c478bd9Sstevel@tonic-gate * value at all times, the System Private interface (leading underscore) 4767c478bd9Sstevel@tonic-gate * is used. 4777c478bd9Sstevel@tonic-gate */ 4787c478bd9Sstevel@tonic-gate 4797c478bd9Sstevel@tonic-gate #include <sys/unistd.h> 4807c478bd9Sstevel@tonic-gate 4817c478bd9Sstevel@tonic-gate #ifdef __cplusplus 4827c478bd9Sstevel@tonic-gate extern "C" { 4837c478bd9Sstevel@tonic-gate #endif 4847c478bd9Sstevel@tonic-gate 4857c478bd9Sstevel@tonic-gate #if !defined(_ASM) 4867c478bd9Sstevel@tonic-gate extern long _sysconf(int); /* System Private interface to sysconf() */ 4877c478bd9Sstevel@tonic-gate #endif /* !defined(_ASM) */ 4887c478bd9Sstevel@tonic-gate 4897c478bd9Sstevel@tonic-gate #define HZ ((clock_t)_sysconf(_SC_CLK_TCK)) 4907c478bd9Sstevel@tonic-gate #define TICK (1000000000/((clock_t)_sysconf(_SC_CLK_TCK))) 4917c478bd9Sstevel@tonic-gate #define PAGESIZE (_sysconf(_SC_PAGESIZE)) 4927c478bd9Sstevel@tonic-gate #define PAGEOFFSET (PAGESIZE - 1) 4937c478bd9Sstevel@tonic-gate #define PAGEMASK (~PAGEOFFSET) 4947c478bd9Sstevel@tonic-gate #define MAXPID ((pid_t)_sysconf(_SC_MAXPID)) 495f48205beScasper #define MAXEPHUID ((uid_t)_sysconf(_SC_EPHID_MAX)) 4967c478bd9Sstevel@tonic-gate 4977c478bd9Sstevel@tonic-gate #ifdef __cplusplus 4987c478bd9Sstevel@tonic-gate } 4997c478bd9Sstevel@tonic-gate #endif 5007c478bd9Sstevel@tonic-gate 5017c478bd9Sstevel@tonic-gate #endif /* (defined(_KERNEL) || defined(_KMEMUSER)) && defined(_MACHDEP) */ 5027c478bd9Sstevel@tonic-gate 5037c478bd9Sstevel@tonic-gate #endif /* _SYS_PARAM_H */ 504