1/*-
  2 * SPDX-License-Identifier: (BSD-3-Clause AND MIT-CMU)
  3 *
  4 * Copyright (c) 1991, 1993
  5 *	The Regents of the University of California.  All rights reserved.
  6 *
  7 * Redistribution and use in source and binary forms, with or without
  8 * modification, are permitted provided that the following conditions
  9 * are met:
 10 * 1. Redistributions of source code must retain the above copyright
 11 *    notice, this list of conditions and the following disclaimer.
 12 * 2. Redistributions in binary form must reproduce the above copyright
 13 *    notice, this list of conditions and the following disclaimer in the
 14 *    documentation and/or other materials provided with the distribution.
 15 * 3. Neither the name of the University nor the names of its contributors
 16 *    may be used to endorse or promote products derived from this software
 17 *    without specific prior written permission.
 18 *
 19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 22 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 29 * SUCH DAMAGE.
 30 *
 31 *	@(#)vm.h	8.2 (Berkeley) 12/13/93
 32 *	@(#)vm_prot.h	8.1 (Berkeley) 6/11/93
 33 *	@(#)vm_inherit.h	8.1 (Berkeley) 6/11/93
 34 *
 35 * Copyright (c) 1987, 1990 Carnegie-Mellon University.
 36 * All rights reserved.
 37 *
 38 * Authors: Avadis Tevanian, Jr., Michael Wayne Young
 39 *
 40 * Permission to use, copy, modify and distribute this software and
 41 * its documentation is hereby granted, provided that both the copyright
 42 * notice and this permission notice appear in all copies of the
 43 * software, derivative works or modified versions, and any portions
 44 * thereof, and that both notices appear in supporting documentation.
 45 *
 46 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
 47 * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
 48 * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
 49 *
 50 * Carnegie Mellon requests users of this software to return to
 51 *
 52 *  Software Distribution Coordinator  or  Software.Distribution@CS.CMU.EDU
 53 *  School of Computer Science
 54 *  Carnegie Mellon University
 55 *  Pittsburgh PA 15213-3890
 56 *
 57 * any improvements or extensions that they make and grant Carnegie the
 58 * rights to redistribute these changes.
 59 */
 60
 61#ifndef VM_H
 62#define VM_H
 63
 64#include <machine/vm.h>
 65
 66typedef char vm_inherit_t;	/* inheritance codes */
 67
 68#define	VM_INHERIT_SHARE	((vm_inherit_t) 0)
 69#define	VM_INHERIT_COPY		((vm_inherit_t) 1)
 70#define	VM_INHERIT_NONE		((vm_inherit_t) 2)
 71#define	VM_INHERIT_ZERO		((vm_inherit_t) 3)
 72#define	VM_INHERIT_DEFAULT	VM_INHERIT_COPY
 73
 74typedef u_char vm_prot_t;	/* protection codes */
 75
 76#define	VM_PROT_NONE		((vm_prot_t) 0x00)
 77#define	VM_PROT_READ		((vm_prot_t) 0x01)
 78#define	VM_PROT_WRITE		((vm_prot_t) 0x02)
 79#define	VM_PROT_EXECUTE		((vm_prot_t) 0x04)
 80#define	VM_PROT_COPY		((vm_prot_t) 0x08)	/* copy-on-read */
 81#define	VM_PROT_PRIV_FLAG	((vm_prot_t) 0x10)
 82#define	VM_PROT_FAULT_LOOKUP	VM_PROT_PRIV_FLAG
 83#define	VM_PROT_QUICK_NOFAULT	VM_PROT_PRIV_FLAG	/* same to save bits */
 84
 85#define	VM_PROT_ALL		(VM_PROT_READ|VM_PROT_WRITE|VM_PROT_EXECUTE)
 86#define VM_PROT_RW		(VM_PROT_READ|VM_PROT_WRITE)
 87#define	VM_PROT_DEFAULT		VM_PROT_ALL
 88
 89enum obj_type {
 90	OBJT_RESERVED = 0,	/* was OBJT_DEFAULT */
 91	OBJT_SWAP,
 92	OBJT_DEFAULT = OBJT_SWAP,
 93	OBJT_VNODE,
 94	OBJT_DEVICE,
 95	OBJT_PHYS,
 96	OBJT_DEAD,
 97	OBJT_SG,
 98	OBJT_MGTDEVICE,
 99	OBJT_FIRST_DYN,
100};
101typedef u_char objtype_t;
102
103union vm_map_object;
104typedef union vm_map_object vm_map_object_t;
105
106struct vm_map_entry;
107typedef struct vm_map_entry *vm_map_entry_t;
108
109struct vm_map;
110typedef struct vm_map *vm_map_t;
111
112struct vm_object;
113typedef struct vm_object *vm_object_t;
114
115#ifndef _KERNEL
116/*
117 * This is defined in <sys/types.h> for the kernel so that non-vm kernel
118 * sources (mainly Mach-derived ones such as ddb) don't have to include
119 * vm stuff.  Defining it there for applications might break things.
120 * Define it here for "applications" that include vm headers (e.g.,
121 * genassym).
122 */
123#ifndef HAVE_BOOLEAN
124typedef int boolean_t;
125#endif
126
127/*
128 * The exact set of memory attributes is machine dependent.  However,
129 * every machine is required to define VM_MEMATTR_DEFAULT and
130 * VM_MEMATTR_UNCACHEABLE.
131 */
132typedef	char vm_memattr_t;	/* memory attribute codes */
133
134/*
135 * This is defined in <sys/types.h> for the kernel so that vnode_if.h
136 * doesn't have to include <vm/vm.h>.
137 */
138struct vm_page;
139typedef struct vm_page *vm_page_t;
140#endif				/* _KERNEL */
141
142struct vm_reserv;
143typedef struct vm_reserv *vm_reserv_t;
144
145/*
146 * Information passed from the machine-independent VM initialization code
147 * for use by machine-dependant code (mainly for MMU support)
148 */
149struct kva_md_info {
150	vm_offset_t	buffer_sva;
151	vm_offset_t	buffer_eva;
152	vm_offset_t	clean_sva;
153	vm_offset_t	clean_eva;
154};
155
156/* bits from overcommit */
157#define	SWAP_RESERVE_FORCE_ON		(1 << 0)
158#define	SWAP_RESERVE_RLIMIT_ON		(1 << 1)
159#define	SWAP_RESERVE_ALLOW_NONWIRED	(1 << 2)
160
161#ifdef _KERNEL
162struct ucred;
163
164void vm_ksubmap_init(struct kva_md_info *);
165bool swap_reserve(vm_ooffset_t incr);
166bool swap_reserve_by_cred(vm_ooffset_t incr, struct ucred *cred);
167void swap_reserve_force(vm_ooffset_t incr);
168void swap_release(vm_ooffset_t decr);
169void swap_release_by_cred(vm_ooffset_t decr, struct ucred *cred);
170void swapper(void);
171
172extern struct kva_md_info	kmi;
173#define VA_IS_CLEANMAP(va)					\
174	((va) >= kmi.clean_sva && (va) < kmi.clean_eva)
175
176extern int old_mlock;
177extern int vm_ndomains;
178extern int vm_overcommit;
179#endif				/* _KERNEL */
180
181#endif				/* VM_H */