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