⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dma_export.h

📁 MPC8241:本程序是freescale的824*系列的BSP源程序
💻 H
字号:
#ifndef DMA_EXPORT_H#define DMA_EXPORT_H/*************************************************************************** *     Copyright Motorola, Inc. 1989-2001 ALL RIGHTS RESERVED * *  $ID:$ * * You are hereby granted a copyright license to use, modify, and * distribute the SOFTWARE, also know as DINK32 (Dynamic Interactive Nano  * Kernel for 32-bit processors) solely in conjunction with the development  * and marketing of your products which use and incorporate microprocessors  * which implement the PowerPC(TM) architecture manufactured by  * Motorola and provided you comply with all of the following restrictions  * i) this entire notice is retained without alteration in any * modified and/or redistributed versions, and  * ii) that such modified versions are clearly identified as such.  * No licenses are granted by implication, estoppel or * otherwise under any patents or trademarks of Motorola, Inc. *  * The SOFTWARE is provided on an "AS IS" basis and without warranty. To * the maximum extent permitted by applicable law, MOTOROLA DISCLAIMS ALL * WARRANTIES WHETHER EXPRESS OR IMPLIED, INCLUDING IMPLIED WARRANTIES OF * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE AND ANY WARRANTY  * AGAINST INFRINGEMENT WITH REGARD TO THE SOFTWARE  * (INCLUDING ANY MODIFIED VERSIONS THEREOF) AND ANY ACCOMPANYING  * WRITTEN MATERIALS. *  * To the maximum extent permitted by applicable law, IN NO EVENT SHALL * MOTOROLA BE LIABLE FOR ANY DAMAGES WHATSOEVER (INCLUDING WITHOUT  * LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS  * INTERRUPTION, LOSS OF BUSINESS INFORMATION, * OR OTHER PECUNIARY LOSS) ARISING OF THE USE OR INABILITY TO USE THE * SOFTWARE. * Motorola assumes no responsibility for the maintenance and support of * the SOFTWARE. ************************************************************************//* These are the defined return values for the DMA_* functions. * Any non-zero value indicates failure.  Failure modes can be added for  * more detailed error reporting. */typedef enum _dma_status{ DMA_SUCCESS     = 0, DMA_ERROR,} DMA_Status;/* These are the defined channel transfer types.  */typedef enum _dma_transfer_types{	DMA_M2M =  0,	/* local memory to local memory */	DMA_M2P =  1,	/* local memory to PCI */	DMA_P2M =  2,	/* PCI to local memory */	DMA_P2P =  3,	/* PCI to PCI */} DMA_TRANSFER_TYPE;typedef enum _dma_interrupt_steer{	DMA_INT_STEER_LOCAL =  0, /* steer DMA int to local processor */	DMA_INT_STEER_PCI = 1,    /* steer DMA int to PCI bus through INTA_ */} DMA_INTERRUPT_STEER;typedef enum _dma_channel{	DMA_CHN_0 =  0, /* kahlua has two dma channels: 0 and 1 */	DMA_CHN_1 =  1,} DMA_CHANNEL;typedef enum _dma_snoop_mode{	DMA_SNOOP_DISABLE =  0,	DMA_SNOOP_ENABLE = 1,} DMA_SNOOP_MODE;/******************** App. API ******************** * The application API is for user level application  * to use the functionality provided by DMA driver. * This is a "generic" DMA interface, it should contain * nothing specific to the Kahlua implementation. * Only the generic functions are exported by the library. *  * Note: Its App.s responsibility to swap the data *       byte. In our API, we currently transfer whatever *       we are given - Big/Little Endian.  This could *       become part of the DMA config, though. **************************************************//*  Initialize DMA unit with the following: *  optional pointer to application layer print function * *  These parameters may be added: *  ??? *  Interrupt enables, modes, etc. are set for each transfer. * *  This function must be called before DMA unit can be used. */extern DMA_Status DMA_Initialize(         /*int (*app_print_function)(char *,...)*/void); /* pointer to optional "printf"                                                 * provided by application                                                 *//* Perform the DMA transfer, only direct mode is currently implemented. * At this point, I think it would be better to define a different * function for chaining mode. * Also, I'm not sure if it is appropriate to have the "generic" API * accept snoop and int_steer parameters.  The DINK user interface allows * them, so for now I'll leave them. *  * int_steer controls DMA interrupt steering to PCI or local processor * type is the type of transfer: M2M, M2P, P2M, P2P * source is the source address of the data * dest is the destination address of the data * len is the length of data to transfer * channel is the DMA channel to use for the transfer * snoop is the snoop enable control */extern DMA_Status DMA_direct_transfer( DMA_INTERRUPT_STEER int_steer,                                       DMA_TRANSFER_TYPE type,                                       unsigned int source,                                       unsigned int dest,                                       unsigned int len,                                       DMA_CHANNEL channel,                                       DMA_SNOOP_MODE snoop);                                                                              /* function for chaining mode. * Also, I'm not sure if it is appropriate to have the "generic" API * accept snoop and int_steer parameters.  The DINK user interface allows * them, so for now I'll leave them. *  * int_steer controls DMA interrupt steering to PCI or local processor * type is the type of transfer: M2M, M2P, P2M, P2P * source is the source address of the data * dest is the destination address of the data * len is the length of data to transfer * channel is the DMA channel to use for the transfer * snoop is the snoop enable control */extern DMA_Status DMA_chaining_transfer( DMA_INTERRUPT_STEER int_steer,                                       DMA_TRANSFER_TYPE type,                                       unsigned int *chainsrc,                                       unsigned int *chaindes,                                       unsigned int *chainbcn,                                       unsigned int paranum,                                       DMA_CHANNEL channel,                                       DMA_SNOOP_MODE snoop);#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -