File indexing completed on 2025-05-11 08:23:42
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037 #ifndef XQSPIPSU_CONTROL_H_
0038 #define XQSPIPSU_CONTROL_H_
0039
0040 #ifdef __cplusplus
0041 extern "C" {
0042 #endif
0043
0044
0045
0046 #include "xqspipsu.h"
0047
0048
0049
0050
0051
0052 #if defined (ARMR5) || defined (__aarch64__) || defined (__MICROBLAZE__)
0053 #define TAPDLY_BYPASS_VALVE_40MHZ 0x01U
0054 #define TAPDLY_BYPASS_VALVE_100MHZ 0x01U
0055 #define USE_DLY_LPBK 0x01U
0056 #define USE_DATA_DLY_ADJ 0x01U
0057 #define DATA_DLY_ADJ_DLY 0X02U
0058 #define LPBK_DLY_ADJ_DLY0 0X02U
0059 #define LPBK_DLY_ADJ_DLY1 0X02U
0060 #endif
0061
0062 #ifdef __MICROBLAZE__
0063 #define XPS_SYS_CTRL_BASEADDR 0xFF180000U
0064 #endif
0065
0066 void XQspiPsu_GenFifoEntryData(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg);
0067 u32 XQspiPsu_SetIOMode(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg);
0068 void XQspiPsu_IORead(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg,
0069 u32 StatusReg);
0070 void XQspiPsu_PollDataConfig(XQspiPsu *InstancePtr, XQspiPsu_Msg *FlashMsg);
0071 void XQspiPsu_TXSetup(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg);
0072 void XQspiPsu_SetupRxDma(const XQspiPsu *InstancePtr,
0073 XQspiPsu_Msg *Msg);
0074 void XQspiPsu_Setup64BRxDma(const XQspiPsu *InstancePtr,
0075 XQspiPsu_Msg *Msg);
0076 void XQspiPsu_RXSetup(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg);
0077 void XQspiPsu_TXRXSetup(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg,
0078 u32 *GenFifoEntry);
0079 void XQspiPsu_GenFifoEntryDataLen(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg,
0080 u32 *GenFifoEntry);
0081 u32 XQspiPsu_CreatePollDataConfig(const XQspiPsu *InstancePtr,
0082 const XQspiPsu_Msg *FlashMsg);
0083 void XQspiPsu_PollDataHandler(XQspiPsu *InstancePtr, u32 StatusReg);
0084 u32 XQspiPsu_SelectSpiMode(u8 SpiMode);
0085 void XQspiPsu_SetDefaultConfig(XQspiPsu *InstancePtr);
0086 void XQspiPsu_FillTxFifo(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg, u32 Size);
0087 void XQspiPsu_ReadRxFifo(XQspiPsu *InstancePtr, XQspiPsu_Msg *Msg, s32 Size);
0088
0089 #if defined (ARMR5) || defined (__aarch64__) || defined (__MICROBLAZE__)
0090 s32 XQspipsu_Set_TapDelay(const XQspiPsu *InstancePtr, u32 TapdelayBypass,
0091 u32 LPBKDelay, u32 Datadelay);
0092 s32 XQspipsu_Calculate_Tapdelay(const XQspiPsu *InstancePtr, u8 Prescaler);
0093 #endif
0094
0095 #ifdef __cplusplus
0096 }
0097 #endif
0098
0099
0100 #endif
0101
0102