123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 |
- /******************************************************************************
- * Copyright (c) 2014 - 2020 Xilinx, Inc. All rights reserved.
- * SPDX-License-Identifier: MIT
- ******************************************************************************/
- /*****************************************************************************/
- /**
- *
- * @file xil_io.h
- *
- * @addtogroup common_io_interfacing_apis Register IO interfacing APIs
- *
- * The xil_io.h file contains the interface for the general I/O component, which
- * encapsulates the Input/Output functions for the processors that do not
- * require any special I/O handling.
- *
- * @{
- * <pre>
- * MODIFICATION HISTORY:
- *
- * Ver Who Date Changes
- * ----- -------- -------- -----------------------------------------------
- * 5.00 pkp 05/29/14 First release
- * 6.00 mus 08/19/16 Remove checking of __LITTLE_ENDIAN__ flag for
- * ARM processors
- * 7.20 har 01/03/20 Added Xil_SecureOut32 for avoiding blindwrite for
- * CR-1049218
- * </pre>
- ******************************************************************************/
- #ifndef XIL_IO_H /* prevent circular inclusions */
- #define XIL_IO_H /* by using protection macros */
- #ifdef __cplusplus
- extern "C" {
- #endif
- /***************************** Include Files *********************************/
- #include "xil_types.h"
- #include "xil_printf.h"
- #include "xstatus.h"
- #if defined (__GNUC__) || defined (__ICCARM__) || defined (__MICROBLAZE__)
- #define INLINE inline
- #else
- #define INLINE __inline
- #endif
- /*****************************************************************************/
- /**
- *
- * @brief Performs an input operation for a memory location by reading
- * from the specified address and returning the 8 bit Value read from
- * that address.
- *
- * @param Addr: contains the address to perform the input operation
- *
- * @return The 8 bit Value read from the specified input address.
- *
- ******************************************************************************/
- static INLINE u8 Xil_In8(UINTPTR Addr)
- {
- return *(volatile u8 *) Addr;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an input operation for a memory location by reading from
- * the specified address and returning the 16 bit Value read from that
- * address.
- *
- * @param Addr: contains the address to perform the input operation
- *
- * @return The 16 bit Value read from the specified input address.
- *
- ******************************************************************************/
- static INLINE u16 Xil_In16(UINTPTR Addr)
- {
- return *(volatile u16 *) Addr;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an input operation for a memory location by
- * reading from the specified address and returning the 32 bit Value
- * read from that address.
- *
- * @param Addr: contains the address to perform the input operation
- *
- * @return The 32 bit Value read from the specified input address.
- *
- ******************************************************************************/
- static INLINE u32 Xil_In32(UINTPTR Addr)
- {
- return *(volatile u32 *) Addr;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an input operation for a memory location by reading the
- * 64 bit Value read from that address.
- *
- *
- * @param Addr: contains the address to perform the input operation
- *
- * @return The 64 bit Value read from the specified input address.
- *
- ******************************************************************************/
- static INLINE u64 Xil_In64(UINTPTR Addr)
- {
- return *(volatile u64 *) Addr;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an output operation for an memory location by
- * writing the 8 bit Value to the the specified address.
- *
- * @param Addr: contains the address to perform the output operation
- * @param Value: contains the 8 bit Value to be written at the specified
- * address.
- *
- * @return None.
- *
- ******************************************************************************/
- static INLINE void Xil_Out8(UINTPTR Addr, u8 Value)
- {
- volatile u8 *LocalAddr = (volatile u8 *)Addr;
- *LocalAddr = Value;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an output operation for a memory location by writing the
- * 16 bit Value to the the specified address.
- *
- * @param Addr contains the address to perform the output operation
- * @param Value contains the Value to be written at the specified address.
- *
- * @return None.
- *
- ******************************************************************************/
- static INLINE void Xil_Out16(UINTPTR Addr, u16 Value)
- {
- volatile u16 *LocalAddr = (volatile u16 *)Addr;
- *LocalAddr = Value;
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an output operation for a memory location by writing the
- * 32 bit Value to the the specified address.
- *
- * @param Addr contains the address to perform the output operation
- * @param Value contains the 32 bit Value to be written at the specified
- * address.
- *
- * @return None.
- *
- ******************************************************************************/
- static INLINE void Xil_Out32(UINTPTR Addr, u32 Value)
- {
- #ifndef ENABLE_SAFETY
- volatile u32 *LocalAddr = (volatile u32 *)Addr;
- *LocalAddr = Value;
- #else
- XStl_RegUpdate(Addr, Value);
- #endif
- }
- /*****************************************************************************/
- /**
- *
- * @brief Performs an output operation for a memory location by writing the
- * 64 bit Value to the the specified address.
- *
- * @param Addr contains the address to perform the output operation
- * @param Value contains 64 bit Value to be written at the specified address.
- *
- * @return None.
- *
- ******************************************************************************/
- static INLINE void Xil_Out64(UINTPTR Addr, u64 Value)
- {
- volatile u64 *LocalAddr = (volatile u64 *)Addr;
- *LocalAddr = Value;
- }
- #ifdef __cplusplus
- }
- #endif
- #endif /* end of protection macro */
- /**
- * @} End of "addtogroup common_io_interfacing_apis".
- */
|