|  | /****************************************************************************** | 
|  | * | 
|  | *     Author: Xilinx, Inc. | 
|  | * | 
|  | * | 
|  | *     This program is free software; you can redistribute it and/or modify it | 
|  | *     under the terms of the GNU General Public License as published by the | 
|  | *     Free Software Foundation; either version 2 of the License, or (at your | 
|  | *     option) any later version. | 
|  | * | 
|  | * | 
|  | *     XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS" AS A | 
|  | *     COURTESY TO YOU. BY PROVIDING THIS DESIGN, CODE, OR INFORMATION AS | 
|  | *     ONE POSSIBLE IMPLEMENTATION OF THIS FEATURE, APPLICATION OR STANDARD, | 
|  | *     XILINX IS MAKING NO REPRESENTATION THAT THIS IMPLEMENTATION IS FREE | 
|  | *     FROM ANY CLAIMS OF INFRINGEMENT, AND YOU ARE RESPONSIBLE FOR OBTAINING | 
|  | *     ANY THIRD PARTY RIGHTS YOU MAY REQUIRE FOR YOUR IMPLEMENTATION. | 
|  | *     XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO | 
|  | *     THE ADEQUACY OF THE IMPLEMENTATION, INCLUDING BUT NOT LIMITED TO ANY | 
|  | *     WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM | 
|  | *     CLAIMS OF INFRINGEMENT, IMPLIED WARRANTIES OF MERCHANTABILITY AND | 
|  | *     FITNESS FOR A PARTICULAR PURPOSE. | 
|  | * | 
|  | * | 
|  | *     Xilinx hardware products are not intended for use in life support | 
|  | *     appliances, devices, or systems. Use in such applications is | 
|  | *     expressly prohibited. | 
|  | * | 
|  | * | 
|  | *     (c) Copyright 2002-2004 Xilinx Inc. | 
|  | *     All rights reserved. | 
|  | * | 
|  | * | 
|  | *     You should have received a copy of the GNU General Public License along | 
|  | *     with this program; if not, write to the Free Software Foundation, Inc., | 
|  | *     675 Mass Ave, Cambridge, MA 02139, USA. | 
|  | * | 
|  | * FILENAME: | 
|  | * | 
|  | * xbuf_descriptor.h | 
|  | * | 
|  | * DESCRIPTION: | 
|  | * | 
|  | * This file contains the interface for the XBufDescriptor component. | 
|  | * The XBufDescriptor component is a passive component that only maps over | 
|  | * a buffer descriptor data structure shared by the scatter gather DMA hardware | 
|  | * and software. The component's primary purpose is to provide encapsulation of | 
|  | * the buffer descriptor processing.  See the source file xbuf_descriptor.c for | 
|  | * details. | 
|  | * | 
|  | * NOTES: | 
|  | * | 
|  | * Most of the functions of this component are implemented as macros in order | 
|  | * to optimize the processing.  The names are not all uppercase such that they | 
|  | * can be switched between macros and functions easily. | 
|  | * | 
|  | ******************************************************************************/ | 
|  |  | 
|  | #ifndef XBUF_DESCRIPTOR_H	/* prevent circular inclusions */ | 
|  | #define XBUF_DESCRIPTOR_H	/* by using protection macros */ | 
|  |  | 
|  | /***************************** Include Files *********************************/ | 
|  |  | 
|  | #include "xbasic_types.h" | 
|  | #include "xdma_channel_i.h" | 
|  |  | 
|  | /************************** Constant Definitions *****************************/ | 
|  |  | 
|  | /* The following constants allow access to all fields of a buffer descriptor | 
|  | * and are necessary at this level of visibility to allow macros to access | 
|  | * and modify the fields of a buffer descriptor.  It is not expected that the | 
|  | * user of a buffer descriptor would need to use these constants. | 
|  | */ | 
|  |  | 
|  | #define XBD_DEVICE_STATUS_OFFSET    0 | 
|  | #define XBD_CONTROL_OFFSET	    1 | 
|  | #define XBD_SOURCE_OFFSET	    2 | 
|  | #define XBD_DESTINATION_OFFSET	    3 | 
|  | #define XBD_LENGTH_OFFSET	    4 | 
|  | #define XBD_STATUS_OFFSET	    5 | 
|  | #define XBD_NEXT_PTR_OFFSET	    6 | 
|  | #define XBD_ID_OFFSET		    7 | 
|  | #define XBD_FLAGS_OFFSET	    8 | 
|  | #define XBD_RQSTED_LENGTH_OFFSET    9 | 
|  |  | 
|  | #define XBD_SIZE_IN_WORDS	    10 | 
|  |  | 
|  | /* | 
|  | * The following constants define the bits of the flags field of a buffer | 
|  | * descriptor | 
|  | */ | 
|  |  | 
|  | #define XBD_FLAGS_LOCKED_MASK	    1UL | 
|  |  | 
|  | /**************************** Type Definitions *******************************/ | 
|  |  | 
|  | typedef u32 XBufDescriptor[XBD_SIZE_IN_WORDS]; | 
|  |  | 
|  | /***************** Macros (Inline Functions) Definitions *********************/ | 
|  |  | 
|  | /* each of the following macros are named the same as functions rather than all | 
|  | * upper case in order to allow either the macros or the functions to be | 
|  | * used, see the source file xbuf_descriptor.c for documentation | 
|  | */ | 
|  |  | 
|  | #define XBufDescriptor_Initialize(InstancePtr)			\ | 
|  | {								\ | 
|  | (*((u32 *)InstancePtr + XBD_CONTROL_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_SOURCE_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_DESTINATION_OFFSET) = 0);   \ | 
|  | (*((u32 *)InstancePtr + XBD_LENGTH_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_STATUS_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_DEVICE_STATUS_OFFSET) = 0); \ | 
|  | (*((u32 *)InstancePtr + XBD_NEXT_PTR_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_ID_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_FLAGS_OFFSET) = 0);	    \ | 
|  | (*((u32 *)InstancePtr + XBD_RQSTED_LENGTH_OFFSET) = 0); \ | 
|  | } | 
|  |  | 
|  | #define XBufDescriptor_GetControl(InstancePtr)	 \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_CONTROL_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetControl(InstancePtr, Control)	 \ | 
|  | (*((u32 *)InstancePtr + XBD_CONTROL_OFFSET) = (u32)Control) | 
|  |  | 
|  | #define XBufDescriptor_IsLastControl(InstancePtr) \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_CONTROL_OFFSET) & \ | 
|  | XDC_CONTROL_LAST_BD_MASK) | 
|  |  | 
|  | #define XBufDescriptor_SetLast(InstancePtr) \ | 
|  | (*((u32 *)InstancePtr + XBD_CONTROL_OFFSET) |= XDC_CONTROL_LAST_BD_MASK) | 
|  |  | 
|  | #define XBufDescriptor_GetSrcAddress(InstancePtr) \ | 
|  | ((u32 *)(*((u32 *)InstancePtr + XBD_SOURCE_OFFSET))) | 
|  |  | 
|  | #define XBufDescriptor_SetSrcAddress(InstancePtr, Source) \ | 
|  | (*((u32 *)InstancePtr + XBD_SOURCE_OFFSET) = (u32)Source) | 
|  |  | 
|  | #define XBufDescriptor_GetDestAddress(InstancePtr) \ | 
|  | ((u32 *)(*((u32 *)InstancePtr + XBD_DESTINATION_OFFSET))) | 
|  |  | 
|  | #define XBufDescriptor_SetDestAddress(InstancePtr, Destination) \ | 
|  | (*((u32 *)InstancePtr + XBD_DESTINATION_OFFSET) = (u32)Destination) | 
|  |  | 
|  | #define XBufDescriptor_GetLength(InstancePtr)				\ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_RQSTED_LENGTH_OFFSET) -	\ | 
|  | *((u32 *)InstancePtr + XBD_LENGTH_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetLength(InstancePtr, Length)			    \ | 
|  | {									    \ | 
|  | (*((u32 *)InstancePtr + XBD_LENGTH_OFFSET) = (u32)(Length));    \ | 
|  | (*((u32 *)InstancePtr + XBD_RQSTED_LENGTH_OFFSET) = (u32)(Length));\ | 
|  | } | 
|  |  | 
|  | #define XBufDescriptor_GetStatus(InstancePtr)	 \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_STATUS_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetStatus(InstancePtr, Status)	 \ | 
|  | (*((u32 *)InstancePtr + XBD_STATUS_OFFSET) = (u32)Status) | 
|  |  | 
|  | #define XBufDescriptor_IsLastStatus(InstancePtr) \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_STATUS_OFFSET) & \ | 
|  | XDC_STATUS_LAST_BD_MASK) | 
|  |  | 
|  | #define XBufDescriptor_GetDeviceStatus(InstancePtr) \ | 
|  | ((u32)(*((u32 *)InstancePtr + XBD_DEVICE_STATUS_OFFSET))) | 
|  |  | 
|  | #define XBufDescriptor_SetDeviceStatus(InstancePtr, Status) \ | 
|  | (*((u32 *)InstancePtr + XBD_DEVICE_STATUS_OFFSET) = (u32)Status) | 
|  |  | 
|  | #define XBufDescriptor_GetNextPtr(InstancePtr) \ | 
|  | (XBufDescriptor *)(*((u32 *)InstancePtr + XBD_NEXT_PTR_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetNextPtr(InstancePtr, NextPtr) \ | 
|  | (*((u32 *)InstancePtr + XBD_NEXT_PTR_OFFSET) = (u32)NextPtr) | 
|  |  | 
|  | #define XBufDescriptor_GetId(InstancePtr) \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_ID_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetId(InstancePtr, Id) \ | 
|  | (*((u32 *)InstancePtr + XBD_ID_OFFSET) = (u32)Id) | 
|  |  | 
|  | #define XBufDescriptor_GetFlags(InstancePtr) \ | 
|  | (u32)(*((u32 *)InstancePtr + XBD_FLAGS_OFFSET)) | 
|  |  | 
|  | #define XBufDescriptor_SetFlags(InstancePtr, Flags) \ | 
|  | (*((u32 *)InstancePtr + XBD_FLAGS_OFFSET) = (u32)Flags) | 
|  |  | 
|  | #define XBufDescriptor_Lock(InstancePtr) \ | 
|  | (*((u32 *)InstancePtr + XBD_FLAGS_OFFSET) |= XBD_FLAGS_LOCKED_MASK) | 
|  |  | 
|  | #define XBufDescriptor_Unlock(InstancePtr) \ | 
|  | (*((u32 *)InstancePtr + XBD_FLAGS_OFFSET) &= ~XBD_FLAGS_LOCKED_MASK) | 
|  |  | 
|  | #define XBufDescriptor_IsLocked(InstancePtr) \ | 
|  | (*((u32 *)InstancePtr + XBD_FLAGS_OFFSET) & XBD_FLAGS_LOCKED_MASK) | 
|  |  | 
|  | /************************** Function Prototypes ******************************/ | 
|  |  | 
|  | /* The following prototypes are provided to allow each of the functions to | 
|  | * be implemented as a function rather than a macro, and to provide the | 
|  | * syntax to allow users to understand how to call the macros, they are | 
|  | * commented out to prevent linker errors | 
|  | * | 
|  |  | 
|  | u32 XBufDescriptor_Initialize(XBufDescriptor* InstancePtr); | 
|  |  | 
|  | u32 XBufDescriptor_GetControl(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetControl(XBufDescriptor* InstancePtr, u32 Control); | 
|  |  | 
|  | u32 XBufDescriptor_IsLastControl(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetLast(XBufDescriptor* InstancePtr); | 
|  |  | 
|  | u32 XBufDescriptor_GetLength(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetLength(XBufDescriptor* InstancePtr, u32 Length); | 
|  |  | 
|  | u32 XBufDescriptor_GetStatus(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetStatus(XBufDescriptor* InstancePtr, u32 Status); | 
|  | u32 XBufDescriptor_IsLastStatus(XBufDescriptor* InstancePtr); | 
|  |  | 
|  | u32 XBufDescriptor_GetDeviceStatus(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetDeviceStatus(XBufDescriptor* InstancePtr, | 
|  | u32 Status); | 
|  |  | 
|  | u32 XBufDescriptor_GetSrcAddress(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetSrcAddress(XBufDescriptor* InstancePtr, | 
|  | u32 SourceAddress); | 
|  |  | 
|  | u32 XBufDescriptor_GetDestAddress(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetDestAddress(XBufDescriptor* InstancePtr, | 
|  | u32 DestinationAddress); | 
|  |  | 
|  | XBufDescriptor* XBufDescriptor_GetNextPtr(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetNextPtr(XBufDescriptor* InstancePtr, | 
|  | XBufDescriptor* NextPtr); | 
|  |  | 
|  | u32 XBufDescriptor_GetId(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetId(XBufDescriptor* InstancePtr, u32 Id); | 
|  |  | 
|  | u32 XBufDescriptor_GetFlags(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_SetFlags(XBufDescriptor* InstancePtr, u32 Flags); | 
|  |  | 
|  | void XBufDescriptor_Lock(XBufDescriptor* InstancePtr); | 
|  | void XBufDescriptor_Unlock(XBufDescriptor* InstancePtr); | 
|  | u32 XBufDescriptor_IsLocked(XBufDescriptor* InstancePtr); | 
|  |  | 
|  | void XBufDescriptor_Copy(XBufDescriptor* InstancePtr, | 
|  | XBufDescriptor* DestinationPtr); | 
|  |  | 
|  | */ | 
|  |  | 
|  | #endif				/* end of protection macro */ |