Home | History | Annotate | Line # | Download | only in include
dvma.h revision 1.10
      1  1.10  chs /*	$NetBSD: dvma.h,v 1.10 2005/01/22 15:36:10 chs 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.10  chs 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.10  chs 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