1170477Salc/*-
2170477Salc * Copyright (c) 2002-2006 Rice University
3172317Salc * Copyright (c) 2007 Alan L. Cox <alc@cs.rice.edu>
4170477Salc * All rights reserved.
5170477Salc *
6170477Salc * This software was developed for the FreeBSD Project by Alan L. Cox,
7170477Salc * Olivier Crameri, Peter Druschel, Sitaram Iyer, and Juan Navarro.
8170477Salc *
9170477Salc * Redistribution and use in source and binary forms, with or without
10170477Salc * modification, are permitted provided that the following conditions
11170477Salc * are met:
12170477Salc * 1. Redistributions of source code must retain the above copyright
13170477Salc *    notice, this list of conditions and the following disclaimer.
14170477Salc * 2. Redistributions in binary form must reproduce the above copyright
15170477Salc *    notice, this list of conditions and the following disclaimer in the
16170477Salc *    documentation and/or other materials provided with the distribution.
17170477Salc *
18170477Salc * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19170477Salc * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20170477Salc * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21170477Salc * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT
22170477Salc * HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
23170477Salc * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
24170477Salc * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
25170477Salc * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
26170477Salc * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27170477Salc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
28170477Salc * WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29170477Salc * POSSIBILITY OF SUCH DAMAGE.
30170477Salc *
31170477Salc * $FreeBSD$
32170477Salc */
33170477Salc
34170477Salc/*
35170477Salc *	Physical memory system definitions
36170477Salc */
37170477Salc
38170477Salc#ifndef	_VM_PHYS_H_
39170477Salc#define	_VM_PHYS_H_
40170477Salc
41174821Salc#ifdef _KERNEL
42174821Salc
43210550Sjhb/* Domains must be dense (non-sparse) and zero-based. */
44210550Sjhbstruct mem_affinity {
45210550Sjhb	vm_paddr_t start;
46210550Sjhb	vm_paddr_t end;
47210550Sjhb	int domain;
48210550Sjhb};
49210550Sjhb
50254065Skibstruct vm_freelist {
51254065Skib	struct pglist pl;
52254065Skib	int lcnt;
53254065Skib};
54254065Skib
55254065Skibstruct vm_phys_seg {
56254065Skib	vm_paddr_t	start;
57254065Skib	vm_paddr_t	end;
58254065Skib	vm_page_t	first_page;
59254065Skib	int		domain;
60254065Skib	struct vm_freelist (*free_queues)[VM_NFREEPOOL][VM_NFREEORDER];
61254065Skib};
62254065Skib
63210550Sjhbextern struct mem_affinity *mem_affinity;
64250601Sattilioextern int vm_ndomains;
65254065Skibextern struct vm_phys_seg vm_phys_segs[];
66254065Skibextern int vm_phys_nsegs;
67210550Sjhb
68227568Salc/*
69227568Salc * The following functions are only to be used by the virtual memory system.
70227568Salc */
71170477Salcvoid vm_phys_add_page(vm_paddr_t pa);
72226928Salcvm_page_t vm_phys_alloc_contig(u_long npages, vm_paddr_t low, vm_paddr_t high,
73226928Salc    u_long alignment, vm_paddr_t boundary);
74210327Sjchandravm_page_t vm_phys_alloc_freelist_pages(int flind, int pool, int order);
75170477Salcvm_page_t vm_phys_alloc_pages(int pool, int order);
76254065Skibboolean_t vm_phys_domain_intersects(long mask, vm_paddr_t low, vm_paddr_t high);
77235372Skibint vm_phys_fictitious_reg_range(vm_paddr_t start, vm_paddr_t end,
78235372Skib    vm_memattr_t memattr);
79235372Skibvoid vm_phys_fictitious_unreg_range(vm_paddr_t start, vm_paddr_t end);
80235372Skibvm_page_t vm_phys_fictitious_to_vm_page(vm_paddr_t pa);
81226928Salcvoid vm_phys_free_contig(vm_page_t m, u_long npages);
82170477Salcvoid vm_phys_free_pages(vm_page_t m, int order);
83170477Salcvoid vm_phys_init(void);
84243132Skibvm_page_t vm_phys_paddr_to_vm_page(vm_paddr_t pa);
85172317Salcvoid vm_phys_set_pool(int pool, vm_page_t m, int order);
86174821Salcboolean_t vm_phys_unfree_page(vm_page_t m);
87170477Salcboolean_t vm_phys_zero_pages_idle(void);
88170477Salc
89254065Skib/*
90254065Skib *	vm_phys_domain:
91254065Skib *
92254065Skib * 	Return the memory domain the page belongs to.
93254065Skib */
94254065Skibstatic inline struct vm_domain *
95254065Skibvm_phys_domain(vm_page_t m)
96254065Skib{
97254065Skib#if MAXMEMDOM > 1
98254065Skib	int domn, segind;
99254065Skib
100254065Skib	/* XXXKIB try to assert that the page is managed */
101254065Skib	segind = m->segind;
102254065Skib	KASSERT(segind < vm_phys_nsegs, ("segind %d m %p", segind, m));
103254065Skib	domn = vm_phys_segs[segind].domain;
104254065Skib	KASSERT(domn < vm_ndomains, ("domain %d m %p", domn, m));
105254065Skib	return (&vm_dom[domn]);
106254065Skib#else
107254065Skib	return (&vm_dom[0]);
108254065Skib#endif
109254065Skib}
110254065Skib
111254065Skibstatic inline void
112254065Skibvm_phys_freecnt_adj(vm_page_t m, int adj)
113254065Skib{
114254065Skib
115254065Skib	mtx_assert(&vm_page_queue_free_mtx, MA_OWNED);
116254065Skib	cnt.v_free_count += adj;
117254065Skib	vm_phys_domain(m)->vmd_free_count += adj;
118254065Skib}
119254065Skib
120174821Salc#endif	/* _KERNEL */
121170477Salc#endif	/* !_VM_PHYS_H_ */
122