Home | History | Annotate | Line # | Download | only in include
dvma.h revision 1.11.26.1
      1  1.11.26.1  rmind /*	$NetBSD: dvma.h,v 1.11.26.1 2007/03/12 05:51:09 rmind 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.4    gwr  * 3. All advertising materials mentioning features or use of this software
     19        1.1    gwr  *    must display the following acknowledgement:
     20        1.4    gwr  *        This product includes software developed by the NetBSD
     21        1.4    gwr  *        Foundation, Inc. and its contributors.
     22        1.4    gwr  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23        1.4    gwr  *    contributors may be used to endorse or promote products derived
     24        1.4    gwr  *    from this software without specific prior written permission.
     25        1.1    gwr  *
     26        1.4    gwr  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27        1.4    gwr  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28        1.4    gwr  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29        1.6    gwr  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30        1.6    gwr  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31        1.4    gwr  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32        1.4    gwr  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33        1.4    gwr  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34        1.4    gwr  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35        1.4    gwr  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36        1.4    gwr  * POSSIBILITY OF SUCH DAMAGE.
     37        1.1    gwr  */
     38        1.1    gwr 
     39        1.1    gwr /*
     40        1.9    gwr  * DVMA (Direct Virtual Memory Access)
     41        1.1    gwr  *
     42        1.9    gwr  * For the unfamiliar, this is just DMA where the device doing DMA
     43        1.9    gwr  * operates in a virtual address space.  The virtual to physical
     44        1.9    gwr  * translations are controlled by some sort of I/O MMU, which may
     45        1.9    gwr  * be the same used by the CPU (sun3) or not (sun3x).  Usually, the
     46        1.9    gwr  * virtual space accessed by DVMA devices is a small sub-range of
     47        1.9    gwr  * the CPU virtual space, and that range is known as DVMA space.
     48        1.1    gwr  */
     49        1.1    gwr 
     50        1.9    gwr #ifdef	_SUN3_
     51        1.9    gwr #include <machine/dvma3.h>
     52        1.9    gwr #endif	/* SUN3 */
     53        1.9    gwr #ifdef	_SUN3X_
     54        1.9    gwr #include <machine/dvma3x.h>
     55        1.9    gwr #endif	/* SUN3X */
     56        1.1    gwr 
     57       1.10    chs void dvma_init(void);
     58        1.5    gwr 
     59        1.3    gwr /* Allocate/free actual pages of DVMA space. */
     60  1.11.26.1  rmind void *dvma_malloc(size_t);
     61       1.10    chs void dvma_free(void *, size_t);
     62        1.1    gwr 
     63        1.3    gwr /* Remap/unmap kernel memory in DVMA space. */
     64  1.11.26.1  rmind void *dvma_mapin(void *, int, int);
     65       1.10    chs void dvma_mapout(void *, int);
     66        1.1    gwr 
     67        1.3    gwr /* Convert a kernel DVMA pointer to a slave address. */
     68       1.10    chs u_long dvma_kvtopa(void *, int);
     69        1.1    gwr 
     70