dvma.h revision 1.12.44.1 1 1.12.44.1 yamt /* $NetBSD: dvma.h,v 1.12.44.1 2008/05/16 02:23:21 yamt Exp $ */
2 1.1 gwr
3 1.4 gwr /*-
4 1.4 gwr * Copyright (c) 1996 The NetBSD Foundation, Inc.
5 1.1 gwr * All rights reserved.
6 1.1 gwr *
7 1.4 gwr * This code is derived from software contributed to The NetBSD Foundation
8 1.4 gwr * by Gordon W. Ross.
9 1.4 gwr *
10 1.1 gwr * Redistribution and use in source and binary forms, with or without
11 1.1 gwr * modification, are permitted provided that the following conditions
12 1.1 gwr * are met:
13 1.1 gwr * 1. Redistributions of source code must retain the above copyright
14 1.1 gwr * notice, this list of conditions and the following disclaimer.
15 1.1 gwr * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 gwr * notice, this list of conditions and the following disclaimer in the
17 1.1 gwr * documentation and/or other materials provided with the distribution.
18 1.1 gwr *
19 1.4 gwr * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.4 gwr * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.4 gwr * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.6 gwr * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.6 gwr * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.4 gwr * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.4 gwr * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.4 gwr * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.4 gwr * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.4 gwr * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.4 gwr * POSSIBILITY OF SUCH DAMAGE.
30 1.1 gwr */
31 1.1 gwr
32 1.1 gwr /*
33 1.9 gwr * DVMA (Direct Virtual Memory Access)
34 1.1 gwr *
35 1.9 gwr * For the unfamiliar, this is just DMA where the device doing DMA
36 1.9 gwr * operates in a virtual address space. The virtual to physical
37 1.9 gwr * translations are controlled by some sort of I/O MMU, which may
38 1.9 gwr * be the same used by the CPU (sun3) or not (sun3x). Usually, the
39 1.9 gwr * virtual space accessed by DVMA devices is a small sub-range of
40 1.9 gwr * the CPU virtual space, and that range is known as DVMA space.
41 1.1 gwr */
42 1.1 gwr
43 1.9 gwr #ifdef _SUN3_
44 1.9 gwr #include <machine/dvma3.h>
45 1.9 gwr #endif /* SUN3 */
46 1.9 gwr #ifdef _SUN3X_
47 1.9 gwr #include <machine/dvma3x.h>
48 1.9 gwr #endif /* SUN3X */
49 1.1 gwr
50 1.10 chs void dvma_init(void);
51 1.5 gwr
52 1.3 gwr /* Allocate/free actual pages of DVMA space. */
53 1.12 christos void *dvma_malloc(size_t);
54 1.10 chs void dvma_free(void *, size_t);
55 1.1 gwr
56 1.3 gwr /* Remap/unmap kernel memory in DVMA space. */
57 1.12 christos void *dvma_mapin(void *, int, int);
58 1.10 chs void dvma_mapout(void *, int);
59 1.1 gwr
60 1.3 gwr /* Convert a kernel DVMA pointer to a slave address. */
61 1.10 chs u_long dvma_kvtopa(void *, int);
62 1.1 gwr
63