1122780Salc/*-
2141784Salc * Copyright (c) 2003, 2005 Alan L. Cox <alc@cs.rice.edu>
3122780Salc * All rights reserved.
4122780Salc *
5122780Salc * Redistribution and use in source and binary forms, with or without
6122780Salc * modification, are permitted provided that the following conditions
7122780Salc * are met:
8122780Salc * 1. Redistributions of source code must retain the above copyright
9122780Salc *    notice, this list of conditions and the following disclaimer.
10122780Salc * 2. Redistributions in binary form must reproduce the above copyright
11122780Salc *    notice, this list of conditions and the following disclaimer in the
12122780Salc *    documentation and/or other materials provided with the distribution.
13122780Salc *
14122780Salc * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15122780Salc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16122780Salc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17122780Salc * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18122780Salc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19122780Salc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20122780Salc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21122780Salc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22122780Salc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23122780Salc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24122780Salc * SUCH DAMAGE.
25122780Salc *
26122780Salc * $FreeBSD: releng/10.3/sys/i386/include/sf_buf.h 255318 2013-09-06 17:44:13Z glebius $
27122780Salc */
28122780Salc
29122780Salc#ifndef _MACHINE_SF_BUF_H_
30122780Salc#define _MACHINE_SF_BUF_H_
31122780Salc
32222813Sattilio#include <sys/_cpuset.h>
33122780Salc#include <sys/queue.h>
34122780Salc
35122780Salcstruct vm_page;
36122780Salc
37122780Salcstruct sf_buf {
38122860Salc	LIST_ENTRY(sf_buf) list_entry;	/* list of buffers */
39123266Salc	TAILQ_ENTRY(sf_buf) free_entry;	/* list of buffers */
40122780Salc	struct		vm_page *m;	/* currently mapped page */
41122780Salc	vm_offset_t	kva;		/* va of mapping */
42122860Salc	int		ref_count;	/* usage of this mapping */
43141784Salc#ifdef SMP
44222813Sattilio	cpuset_t	cpumask;	/* cpus on which mapping is valid */
45141784Salc#endif
46122780Salc};
47122780Salc
48255318Sglebiusstruct sf_buf * sf_buf_alloc(struct vm_page *m, int flags);
49255318Sglebiusvoid sf_buf_free(struct sf_buf *sf);
50255318Sglebius
51122780Salcstatic __inline vm_offset_t
52122780Salcsf_buf_kva(struct sf_buf *sf)
53122780Salc{
54122780Salc
55122780Salc	return (sf->kva);
56122780Salc}
57122780Salc
58122780Salcstatic __inline struct vm_page *
59122780Salcsf_buf_page(struct sf_buf *sf)
60122780Salc{
61122780Salc
62122780Salc	return (sf->m);
63122780Salc}
64122780Salc
65195940Skibboolean_t sf_buf_invalidate_cache(vm_page_t m);
66195940Skib
67122780Salc#endif /* !_MACHINE_SF_BUF_H_ */
68