📄 xio.h
字号:
/* $Id: xio.h,v 1.10 2005/09/26 19:17:53 trujillo Exp $ *//******************************************************************************** XILINX IS PROVIDING THIS DESIGN, CODE, OR INFORMATION "AS IS"* AS A COURTESY TO YOU, SOLELY FOR USE IN DEVELOPING PROGRAMS AND* SOLUTIONS FOR XILINX DEVICES. 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 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.** (c) Copyright 2002 Xilinx Inc.* All rights reserved.*******************************************************************************//*****************************************************************************//**** @file xio.h** This file contains the interface for the XIo component, which encapsulates* the Input/Output functions for the PowerPC architecture.** @note** This file contains architecture-dependent items (memory mapped or non memory* mapped I/O).*******************************************************************************/#ifndef XIO_H /* prevent circular inclusions */#define XIO_H /* by using protection macros */#ifdef __cplusplusextern "C" {#endif/***************************** Include Files *********************************/#include "xbasic_types.h"/************************** Constant Definitions *****************************//**************************** Type Definitions *******************************//** * Typedef for an I/O address. Typically correlates to the width of the * address bus. */typedef Xuint32 XIo_Address;/***************** Macros (Inline Functions) Definitions *********************//* The following macro is specific to the GNU compiler and PowerPC family. It * performs an EIEIO instruction such that I/O operations are synced correctly. * This macro is not necessarily portable across compilers since it uses * inline assembly. */#if defined __GNUC__# define SYNCHRONIZE_IO __asm__ volatile ("eieio")#elif defined __DCC__# define SYNCHRONIZE_IO __asm volatile(" eieio")#else# define SYNCHRONIZE_IO#endif/* The following macros allow the software to be transportable across * processors which use big or little endian memory models. * * Defined first are processor-specific endian conversion macros specific to * the GNU compiler and the PowerPC family, as well as a no-op endian conversion * macro. These macros are not to be used directly by software. Instead, the * XIo_To/FromLittleEndianXX and XIo_To/FromBigEndianXX macros below are to be * used to allow the endian conversion to only be performed when necessary */#define XIo_EndianNoop(Source, DestPtr) (*DestPtr = Source)#if defined __GNUC__#define XIo_EndianSwap16(Source, DestPtr) __asm__ __volatile__(\ "sthbrx %0,0,%1\n"\ : : "r" (Source), "r" (DestPtr)\ )#define XIo_EndianSwap32(Source, DestPtr) __asm__ __volatile__(\ "stwbrx %0,0,%1\n"\ : : "r" (Source), "r" (DestPtr)\ )#elif defined __DCC____asm void XIo_EndianSwap16(Xuint16 Source, Xuint16 *DestPtr){% reg Source; reg DestPtr; sthbrx Source,0,DestPtr}__asm void XIo_EndianSwap32(Xuint32 Source, Xuint32 *DestPtr){% reg Source; reg DestPtr; stwbrx Source,0,DestPtr}#else#define XIo_EndianSwap16(Source, DestPtr) \{\ Xuint16 src = (Source); \ Xuint16 *destptr = (DestPtr); \ *destptr = src >> 8; \ *destptr |= (src << 8); \}#define XIo_EndianSwap32(Source, DestPtr) \{\ Xuint32 src = (Source); \ Xuint32 *destptr = (DestPtr); \ *destptr = src >> 24; \ *destptr |= ((src >> 8) & 0x0000FF00); \ *destptr |= ((src << 8) & 0x00FF0000); \ *destptr |= ((src << 24) & 0xFF000000); \}#endif#ifdef XLITTLE_ENDIAN/* little-endian processor */#define XIo_ToLittleEndian16 XIo_EndianNoop#define XIo_ToLittleEndian32 XIo_EndianNoop#define XIo_FromLittleEndian16 XIo_EndianNoop#define XIo_FromLittleEndian32 XIo_EndianNoop#define XIo_ToBigEndian16(Source, DestPtr) XIo_EndianSwap16(Source, DestPtr)#define XIo_ToBigEndian32(Source, DestPtr) XIo_EndianSwap32(Source, DestPtr)#define XIo_FromBigEndian16 XIo_ToBigEndian16#define XIo_FromBigEndian32 XIo_ToBigEndian32#else/* big-endian processor */#define XIo_ToLittleEndian16(Source, DestPtr) XIo_EndianSwap16(Source, DestPtr)#define XIo_ToLittleEndian32(Source, DestPtr) XIo_EndianSwap32(Source, DestPtr)#define XIo_FromLittleEndian16 XIo_ToLittleEndian16#define XIo_FromLittleEndian32 XIo_ToLittleEndian32#define XIo_ToBigEndian16 XIo_EndianNoop#define XIo_ToBigEndian32 XIo_EndianNoop#define XIo_FromBigEndian16 XIo_EndianNoop#define XIo_FromBigEndian32 XIo_EndianNoop#endif/************************** Function Prototypes ******************************//* The following functions allow the software to be transportable across * processors which may use memory mapped I/O or I/O which is mapped into a * seperate address space such as X86. The functions are better suited for * debugging and are therefore the default implementation. Macros can instead * be used if USE_IO_MACROS is defined. */#ifndef USE_IO_MACROS/* Functions */Xuint8 XIo_In8(XIo_Address InAddress);Xuint16 XIo_In16(XIo_Address InAddress);Xuint32 XIo_In32(XIo_Address InAddress);void XIo_Out8(XIo_Address OutAddress, Xuint8 Value);void XIo_Out16(XIo_Address OutAddress, Xuint16 Value);void XIo_Out32(XIo_Address OutAddress, Xuint32 Value);#else/* The following macros allow optimized I/O operations for memory mapped I/O * Note that the SYNCHRONIZE_IO may be moved by the compiler during * optimization. */#define XIo_In8(InputPtr) (*(volatile Xuint8 *)(InputPtr)); SYNCHRONIZE_IO;#define XIo_In16(InputPtr) (*(volatile Xuint16 *)(InputPtr)); SYNCHRONIZE_IO;#define XIo_In32(InputPtr) (*(volatile Xuint32 *)(InputPtr)); SYNCHRONIZE_IO;#define XIo_Out8(OutputPtr, Value) \ { (*(volatile Xuint8 *)(OutputPtr) = Value); SYNCHRONIZE_IO; }#define XIo_Out16(OutputPtr, Value) \ { (*(volatile Xuint16 *)(OutputPtr) = Value); SYNCHRONIZE_IO; }#define XIo_Out32(OutputPtr, Value) \ { (*(volatile Xuint32 *)(OutputPtr) = Value); SYNCHRONIZE_IO; }#endif/* The following functions handle IO addresses where data must be swapped * They cannot be implemented as macros */Xuint16 XIo_InSwap16(XIo_Address InAddress);Xuint32 XIo_InSwap32(XIo_Address InAddress);void XIo_OutSwap16(XIo_Address OutAddress, Xuint16 Value);void XIo_OutSwap32(XIo_Address OutAddress, Xuint32 Value);#ifdef __cplusplus}#endif#endif /* end of protection macro */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -