~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/xtensa/include/asm/dma.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /*
  2  * include/asm-xtensa/dma.h
  3  *
  4  * This file is subject to the terms and conditions of the GNU General Public
  5  * License.  See the file "COPYING" in the main directory of this archive
  6  * for more details.
  7  *
  8  * Copyright (C) 2003 - 2005 Tensilica Inc.
  9  */
 10 
 11 #ifndef _XTENSA_DMA_H
 12 #define _XTENSA_DMA_H
 13 
 14 #include <asm/io.h>             /* need byte IO */
 15 
 16 /*
 17  * This is only to be defined if we have PC-like DMA.
 18  * By default this is not true on an Xtensa processor,
 19  * however on boards with a PCI bus, such functionality
 20  * might be emulated externally.
 21  *
 22  * NOTE:  there still exists driver code that assumes
 23  * this is defined, eg. drivers/sound/soundcard.c (as of 2.4).
 24  */
 25 #define MAX_DMA_CHANNELS        8
 26 
 27 /*
 28  * The maximum virtual address to which DMA transfers
 29  * can be performed on this platform.
 30  *
 31  * NOTE: This is board (platform) specific, not processor-specific!
 32  *
 33  * NOTE: This assumes DMA transfers can only be performed on
 34  *      the section of physical memory contiguously mapped in virtual
 35  *      space for the kernel.  For the Xtensa architecture, this
 36  *      means the maximum possible size of this DMA area is
 37  *      the size of the statically mapped kernel segment
 38  *      (XCHAL_KSEG_{CACHED,BYPASS}_SIZE), ie. 128 MB.
 39  *
 40  * NOTE: When the entire KSEG area is DMA capable, we subtract
 41  *      one from the max address so that the virt_to_phys() macro
 42  *      works correctly on the address (otherwise the address
 43  *      enters another area, and virt_to_phys() may not return
 44  *      the value desired).
 45  */
 46 
 47 #ifndef MAX_DMA_ADDRESS
 48 #define MAX_DMA_ADDRESS         (PAGE_OFFSET + XCHAL_KIO_SIZE - 1)
 49 #endif
 50 
 51 /* Reserve and release a DMA channel */
 52 extern int request_dma(unsigned int dmanr, const char * device_id);
 53 extern void free_dma(unsigned int dmanr);
 54 
 55 #endif
 56 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php