# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## **Xilinx Device Drivers Documentation**

Generated on 30 Sep 2003 for Xilinx Device Drivers

## **Device Driver Summary**

A summary of each device driver is provided below. This includes links to the driver's layer 1, high-level header file and its layer 0, low-level header file. A description of the device driver layers can be found in the Device Driver Programmer Guide. In addition, <u>building block</u> components are described, followed by a list of layer 2 drivers/adapters available for the <u>VxWorks</u> Real-Time Operating System (RTOS).

### **ATM Controller**

The Asynchronous Transfer Mode (ATM) Controller driver resides in the *atmc* subdirectory. Details of the layer 1 high level driver can be found in the <u>xatmc.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xatmc\_l.h</u> header file.

### Ethernet 10/100 MAC

The Ethernet 10/100 MAC driver resides in the *emac* subdirectory. Details of the layer 1 high level driver can be found in the <u>xemac.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xemac l.h</u> header file.

### Ethernet 10/100 MAC Lite

The Ethernet 10/100 MAC Lite driver resides in the *emaclite* subdirectory. Details of the layer 0 low level driver can be found in the <u>xemaclite\_l.h</u> header file.

### **External Memory Controller**

The External Memory Controller driver resides in the *emc* subdirectory. Details of the layer 1 high level driver can be found in the <u>xemc.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xemc l.h</u> header file.

### **General Purpose I/O**

The General Purpose I/O driver resides in the gpio subdirectory. Details of the layer 1 high level driver can be found in the <u>xgpio.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xgpio\_l.h</u> header file.

### **Gigabit Ethernet MAC**

The 1 Gigabit Ethernet MAC driver resides in the *gemac* subdirectory. Details of the layer 1 high level driver can be found in the <u>xgemac.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xgemac\_l.h</u> header file.

### **HDLC**

The HDLC driver resides in the *hdlc* subdirectory. Details of the layer 1 high level driver can be found in the <u>xhdlc.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xhdlc l.h</u> header file.

### Intel StrataFlash

The Intel StrataFlash driver resides in the *flash* subdirectory. Details of the layer 1 high level driver can be found in the <u>xflash.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xflash\_intel\_l.h</u> header file.

### Inter-Integrated Circuit (IIC)

The IIC driver resides in the *iic* subdirectory. Details of the layer 1 high level driver can be found in the <u>xiic.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xiic\_l.h</u> header file.

### **Interrupt Controller**

The Interrupt Controller driver resides in the *intc* subdirectory. Details of the layer 1 high level driver can be found in the <u>xintc.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xintc\_l.h</u> header file.

### **OPB Arbiter**

The OPB Arbiter driver resides in the *opbarb* subdirectory. Details of the layer 1 high level driver can be found in the <u>xopbarb.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xopbarb\_l.h</u> header file.

### **OPB to PLB Bridge**

The OPB to PLB bridge driver resides in the *opb2plb* subdirectory. Details of the layer 1 high level driver can be found in the <u>xopb2plb.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xopb2plb l.h</u> header file.

### **PCI** Bridge

The PCI bridge driver resides in the *pci* subdirectory. Details of the layer 1 high level driver can be found in the <u>xpci.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xpci\_l.h</u> header file.

### **PLB Arbiter**

The PLB arbiter driver resides in the *plbarb* subdirectory. Details of the layer 1 high level driver can be found in the <u>xplbarb.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xplbarb\_l.h</u> header file.

### **PLB to OPB Bridge**

The PLB to OPB bridge driver resides in the *plb2opb* subdirectory. Details of the layer 1 high level driver can be found in the <u>xplb2opb.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xplb2opb</u> l.h header file.

### Rapid I/O

The Rapid I/O driver resides in the *rapidio* subdirectory. Details of the layer 0 low level driver can be found in the <u>xrapidio\_1.h</u> header file.

### **Serial Peripheral Interface (SPI)**

The SPI driver resides in the *spi* subdirectory. Details of the layer 1 high level driver can be found in the <u>xspi.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xspi\_l.h</u> header file.

### **System ACE**

The System ACE driver resides in the *sysace* subdirectory. Details of the layer 1 high level driver can be found in the <u>xsysace.h</u> header file. Details of the layer 0 low level

driver can be found in the xsysace\_1.h header file.

### Timer/Counter

The Timer/Counter driver resides in the *tmrctr* subdirectory. Details of the layer 1 high level driver can be found in the <u>xtmrctr.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xtmrctr\_l.h</u> header file.

### **UART Lite**

The UART Lite driver resides in the *uartlite* subdirectory. Details of the layer 1 high level driver can be found in the <u>xuartlite.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xuartlite 1.h</u> header file.

### **UART 16450/16550**

The UART 16450/16550 driver resides in the *uartns550* subdirectory. Details of the layer 1 high level driver can be found in the <u>xuartns550.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xuartns550\_l.h</u> header file.

### **Watchdog Timer/Timebase**

The Watchdog Timer/Timebase driver resides in the *wdttb* subdirectory. Details of the layer 1 high level driver can be found in the <u>xwdttb.h</u> header file. Details of the layer 0 low level driver can be found in the <u>xwdttb</u> l.h header file.

## **Building Block Components**

### Common

Common components reside in the *common* subdirectory and comprise a collection of header files and ".c" files that are commonly used by all device drivers and application code. Included in this collection are: <a href="mailto:xstatus.h">xstatus.h</a>, which contains the identifiers for Xilinx status codes; <a href="mailto:xparameters.h">xparameters.h</a>, which contains the identifiers for the driver configurations and memory map; and <a href="mailto:xbasic\_types.h">xbasic\_types.h</a>, which contains identifiers for primitive data types and commonly used constants.

### CPU/CPU\_PPC405

CPU components reside in the *cpu*[\_*ppc405*] sudirectory and comprise I/O functions specific to a processor. These I/O functions are defined in xio.h. These functions are used by drivers and are not intended for external use.

### **IPIF**

IPIF components reside in the *ipif* subdirectory and comprise functions related to the IP Interface (IPIF) interrupt control logic. Since most devices are built with IPIF, drivers utilize this common source code to prevent duplication of code within the drivers. These functions are used by drivers and are not intended for external use.

### **DMA**

DMA components reside in the *dma* subdirectory and comprise functions used for Direct Memory Access (DMA). Both simple DMA and scatter-gather DMA are supported.

### **Packet FIFO**

Packet FIFO components reside in the *packet\_fifo* subdirectory and comprise functions used for packet FIFO control. Packet FIFOs are typically used by devices that process and potentially retransmit packets, such as Ethernet and ATM. These functions are used by drivers and are not intended for external use.

## VxWorks Support

VxWorks RTOS adapters (also known as layer 2 device drivers) are provided for the following devices:

- 10/100 Ethernet MAC (Enhanced Network Driver Interface)
- Gigabit Ethernet MAC (Enhanced Network Driver Interface)
- UART 16550/16450 (Serial IO Interface)
- UART Lite (Serial IO Interface)
- System ACE (Block Device Interface)

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

## atmc/v1\_00\_c/src/xatmc.h File Reference

### **Detailed Description**

The implementation of the **XAtmc** component, which is the driver for the Xilinx ATM controller.

The Xilinx ATM controller supports the following features:

- Simple and scatter-gather DMA operations, as well as simple memory mapped direct I/O interface (FIFOs).
- Independent internal transmit and receive FIFOs
- Internal loopback
- Header error check (HEC) generation and checking
- Cell buffering with or without header/User Defined
- Parity generation and checking
- Header generation for transmit cell payloads
- Physical interface (PHY) data path of 16 bits
- Basic statistics gathering such as long cells, short cells, parity errors, and HEC errors

The driver does not support all of the features listed above. Features not currently supported by the driver are:

- Simple DMA (in polled or interrupt mode)
- Direct I/O (FIFO) operations in interrupt mode (polled mode does use the FIFO directly)

It is the responsibility of the application get the interrupt handler of the ATM controller and connect it to the interrupt source.

The driver services interrupts and passes ATM cells to the upper layer software through callback functions. The upper layer software must register its callback functions during initialization. The driver requires callback functions for received cells, for confirmation of transmitted cells, and for asynchronous errors. The frequency of interrupts can be controlled with the packet threshold and packet wait bound features of the scatter-gather DMA engine.

The callback function which performs processing for scatter-gather DMA is executed in an interrupt context and is designed to allow the processing of the scatter-gather list to be passed to a thread context. The scatter-gather processing can require more processing than desired in an interrupt context. Functions are provided to be called from the callback function or thread context to get cells from the send and receive scatter-gather list.

Some errors that can occur in the device require a device reset. These errors are listed in the SetErrorHandler function header. The upper layer's error handler is responsible for resetting the device and re-configuring it based on its needs (the driver does not save the current configuration).

#### **DMA Support**

The Xilinx ATMC device is available for both the IBM On-Chip Peripheral Bus (OPB) and Processor Local Bus (PLB). This driver works for both. However, a current limitation of the ATMC device on the PLB is that it does not support DMA. For this reason, the DMA scatter-gather functions (e.g., **XAtmc\_SgSend()**) of this driver will not function for the PLB version of the ATMC device.

#### Note:

Xilinx drivers are typically composed of two components, one is the driver and the other is the adapter. The driver is independent of OS and processor and is intended to be highly portable. The adapter is OS-specific and facilitates communication between the driver and the OS.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XAtmc struct XAtmc_Config struct XAtmc_Stats
```

### **Configuration options**

These options are used in **XAtmc\_SetOptions**() to configure the device.

```
#define XAT_LOOPBACK_OPTION
#define XAT_POLLED_OPTION
#define XAT_DISCARD_SHORT_OPTION
#define XAT_DISCARD_PARITY_OPTION
```

```
#define XAT_DISCARD_LONG_OPTION
#define XAT_DISCARD_HEC_OPTION
#define XAT_DISCARD_VXI_OPTION
#define XAT_PAYLOAD_ONLY_OPTION
#define XAT_NO_SEND_PARITY_OPTION
```

### **Cell status**

These constants define the status values for a received cell. The status is available when polling to receive a cell or in the buffer descriptor after a cell is received using DMA scatter-gather.

```
#define XAT_CELL_STATUS_LONG
#define XAT_CELL_STATUS_SHORT
#define XAT_CELL_STATUS_BAD_PARITY
#define XAT_CELL_STATUS_BAD_HEC
#define XAT_CELL_STATUS_VXI_MISMATCH
#define XAT_CELL_STATUS_NO_ERROR
```

### Typedefs for callbacks

Callback functions.

```
typedef void(* XAtmc_SgHandler )(void *CallBackRef, Xuint32 CellCount) typedef void(* XAtmc_ErrorHandler )(void *CallBackRef, XStatus ErrorCode)
```

### **Functions**

```
XStatus XAtmc_Initialize (XAtmc *InstancePtr, Xuint16 DeviceId)
        XStatus XAtmc_Start (XAtmc *InstancePtr)
        XStatus XAtmc_Stop (XAtmc *InstancePtr)
           void XAtmc_Reset (XAtmc *InstancePtr)
        XStatus XAtmc_SelfTest (XAtmc *InstancePtr)
XAtmc_Config * XAtmc_LookupConfig (Xuint16 DeviceId)
        XStatus XAtmc_SgSend (XAtmc *InstancePtr, XBufDescriptor *BdPtr)
        XStatus XAtmc_SgRecv (XAtmc *InstancePtr, XBufDescriptor *BdPtr)
        XStatus XAtmc SgGetSendCell (XAtmc *InstancePtr, XBufDescriptor **PtrToBdPtr, int
                *BdCountPtr)
        XStatus XAtmc_SgGetRecvCell (XAtmc *InstancePtr, XBufDescriptor **PtrToBdPtr, int
                *BdCountPtr)
        XStatus XAtmc_PollSend (XAtmc *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
        XStatus XAtmc PollRecv (XAtmc *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr, Xuint32
                *CellStatusPtr)
        XStatus XAtmc_SetOptions (XAtmc *InstancePtr, Xuint32 Options)
```

```
Xuint32 XAtmc_GetOptions (XAtmc *InstancePtr)
XStatus XAtmc_SetPhyAddress (XAtmc *InstancePtr, Xuint8 Address)
Xuint8 XAtmc_GetPhyAddress (XAtmc *InstancePtr)
XStatus XAtmc_SetHeader (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 Header)
Xuint32 XAtmc_GetHeader (XAtmc *InstancePtr, Xuint32 Direction)
XStatus XAtmc_SetUserDefined (XAtmc *InstancePtr, Xuint8 UserDefined)
Xuint8 XAtmc GetUserDefined (XAtmc *InstancePtr)
XStatus XAtmc SetPktThreshold (XAtmc *InstancePtr, Xuint32 Direction, Xuint8 Threshold)
XStatus XAtmc_GetPktThreshold (XAtmc *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)
XStatus XAtmc_SetPktWaitBound (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 TimerValue)
XStatus XAtmc_GetPktWaitBound (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)
   void XAtmc_GetStats (XAtmc *InstancePtr, XAtmc_Stats *StatsPtr)
   void XAtmc ClearStats (XAtmc *InstancePtr)
XStatus XAtmc_SetSgRecvSpace (XAtmc *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
XStatus XAtmc_SetSgSendSpace (XAtmc *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
   void XAtmc_InterruptHandler (void *InstancePtr)
   void XAtmc SetSgRecvHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc SgHandler
       FuncPtr)
   void XAtmc_SetSgSendHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc_SgHandler
       FuncPtr)
   void XAtmc_SetErrorHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc_ErrorHandler
       FuncPtr)
```

### **Define Documentation**

#### #define XAT\_CELL\_STATUS\_BAD\_HEC

```
XAT_CELL_STATUS_LONG

XAT_CELL_STATUS_SHORT

Cell was too short

XAT_CELL_STATUS_BAD_PARITY

Cell parity was not correct

XAT_CELL_STATUS_BAD_HEC

Cell HEC was not correct

XAT_CELL_STATUS_VXI_MISMATCH

Cell VPI/VCI fields didn't match the expected header values

XAT_CELL_STATUS_NO_ERROR

Cell received without errors
```

#### #define XAT\_CELL\_STATUS\_BAD\_PARITY

XAT\_CELL\_STATUS\_LONG Cell was too long
XAT\_CELL\_STATUS\_SHORT Cell was too short
XAT\_CELL\_STATUS\_BAD\_PARITY Cell parity was not correct
XAT\_CELL\_STATUS\_BAD\_HEC Cell HEC was not correct
XAT\_CELL\_STATUS\_VXI\_MISMATCH Cell VPI/VCI fields didn't match the expected header values
XAT\_CELL\_STATUS\_NO\_ERROR Cell received without errors

#### #define XAT\_CELL\_STATUS\_LONG

XAT\_CELL\_STATUS\_LONG

XAT\_CELL\_STATUS\_SHORT

Cell was too short

XAT\_CELL\_STATUS\_BAD\_PARITY

Cell parity was not correct

XAT\_CELL\_STATUS\_BAD\_HEC

Cell HEC was not correct

XAT\_CELL\_STATUS\_VXI\_MISMATCH

Cell VPI/VCI fields didn't match the expected header values

XAT\_CELL\_STATUS\_NO\_ERROR

Cell received without errors

#### #define XAT\_CELL\_STATUS\_NO\_ERROR

XAT\_CELL\_STATUS\_LONG

XAT\_CELL\_STATUS\_SHORT

Cell was too short

XAT\_CELL\_STATUS\_BAD\_PARITY

Cell parity was not correct

XAT\_CELL\_STATUS\_BAD\_HEC

Cell HEC was not correct

XAT\_CELL\_STATUS\_VXI\_MISMATCH

Cell VPI/VCI fields didn't match the expected header values

XAT\_CELL\_STATUS\_NO\_ERROR

Cell received without errors

#### #define XAT\_CELL\_STATUS\_SHORT

XAT\_CELL\_STATUS\_LONG

XAT\_CELL\_STATUS\_SHORT

Cell was too short

XAT\_CELL\_STATUS\_BAD\_PARITY

Cell parity was not correct

XAT\_CELL\_STATUS\_BAD\_HEC

Cell HEC was not correct

XAT\_CELL\_STATUS\_VXI\_MISMATCH

Cell VPI/VCI fields didn't match the expected header values

XAT\_CELL\_STATUS\_NO\_ERROR

Cell received without errors

#### #define XAT\_CELL\_STATUS\_VXI\_MISMATCH

XAT\_CELL\_STATUS\_LONG Cell was too long XAT\_CELL\_STATUS\_SHORT Cell was too short

XAT\_CELL\_STATUS\_BAD\_PARITY Cell parity was not correct XAT\_CELL\_STATUS\_BAD\_HEC Cell HEC was not correct

XAT\_CELL\_STATUS\_VXI\_MISMATCH Cell VPI/VCI fields didn't match the expected

header values

XAT\_CELL\_STATUS\_NO\_ERROR Cell received without errors

#### #define XAT DISCARD HEC OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT DISCARD LONG OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT DISCARD PARITY OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT\_DISCARD\_PARITY\_OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT\_DISCARD\_SHORT\_OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT DISCARD PARITY OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT DISCARD VXI OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT LOOPBACK OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT\_NO\_SEND\_PARITY\_OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT\_PAYLOAD\_ONLY\_OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT\_DISCARD\_VXI\_OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

#### #define XAT\_POLLED\_OPTION

XAT\_DISCARD\_SHORT\_OPTION Discard runt/short cells

XAT\_DISCARD\_PARITY\_OPTION Discard cells with parity errors

XAT\_DISCARD\_LONG\_OPTION Discard long cells

XAT\_DISCARD\_HEC\_OPTION Discard cells with HEC errors

XAT DISCARD VXI OPTION Discard cells which don't match in the

VCI/VPI fields

XAT\_PAYLOAD\_ONLY\_OPTION Buffer payload only

XAT\_NO\_SEND\_PARITY\_OPTION Disable parity for sent cells

### **Typedef Documentation**

#### typedef void(\* XAtmc\_ErrorHandler)(void \*CallBackRef, XStatus ErrorCode)

Callback when data is sent or received with scatter-gather DMA.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions,

and passed back to the upper layer when the callback is invoked.

*ErrorCode* indicates the error that occurred.

#### typedef void(\* XAtmc\_SgHandler)(void \*CallBackRef, Xuint32 CellCount)

Callback when data is sent or received with scatter-gather DMA.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked.

CellCount is the number of cells sent or received.

### **Function Documentation**

void XAtmc\_ClearStats( XAtmc \* InstancePtr)



header which is being compared against received cells. An invalid specified direction will cause this function to return a value of 0.

#### **Note:**

None.

Xuint32 XAtmc\_GetOptions( XAtmc \* InstancePtr)

Gets Atmc driver/device options. The value returned is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The 32-bit value of the Atmc options. The value is a bit-mask representing all options that are currently enabled. See **xatmc.h** for a detailed description of the options.

#### Note:

None.

#### Xuint8 XAtmc\_GetPhyAddress( XAtmc \* InstancePtr)

Gets the PHY address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The 5-bit PHY address (0 - 31) currently being used by the ATM controller.

#### **Note:**

None.

Gets the value of the packet threshold register for this driver/device. The packet threshold is used for interrupt coalescing when the ATM controller is configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be

copied. An output parameter. A value of 0 indicates the use of packet threshold by the

hardware is disabled.

#### Returns:

- o XST SUCCESS if the packet threshold was retrieved successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST INVALID PARAM if an invalid direction was specified

Note:

None.

Gets the packet wait bound register for this driver/device. The packet wait bound is used for interrupt coalescing when the ATM controller is configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

WaitPtr is a pointer to the byte into which the current value of the packet wait bound register will be

copied. An output parameter. Units are in milliseconds in the range 0 - 1023. A value of 0

indicates the packet wait bound timer is disabled.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

None.

Gets a copy of the **XAtmc\_Stats** structure, which contains the current statistics for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

#### **Returns:**

None. Although the output parameter will contain a copy of the statistics upon return from this function.

#### Note:

Gets the 2nd byte of the User Defined data in the ATM controller for the channel which is sending data. The ATM controller will attach the header to all cells which are being sent and do not have a header. The header of a 16 bit Utopia interface contains the User Defined data which is two bytes. The first byte contains the HEC field and the second byte is available for user data. This function only allows the second byte to be retrieved.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The second byte of the User Defined data.

#### **Note:**

None.

Initializes a specific ATM controller instance/driver. The initialization entails:

- Initialize fields of the **XAtmc** structure
- Clear the ATM statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- Configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists will be passed to the driver.
- Reset the ATM controller

The only driver function that should be called before this Initialize function is called is GetInstance.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

DeviceId

is the unique id of the device controlled by this **XAtmc** instance. Passing in a device id associates the generic **XAtmc** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started

#### Note:

Interrupt handler for the ATM controller driver. It performs the following processing:

- Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: the ATM controller, the send packet FIFO, the receive packet FIFO, the send DMA channel, or the receive DMA channel. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the ATM controller.
- Call the appropriate handler based on the source of the interrupt.

#### **Parameters:**

*InstancePtr* contains a pointer to the ATMC controller instance for the interrupt.

#### **Returns:**

None.

#### **Note:**

None.

#### 

Looks up the device configuration based on the unique device ID. The table AtmcConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId contains the unique device ID that for the device. This ID is used to lookup the configuration.

#### **Returns:**

A pointer to the configuration for the specified device, or XNULL if the device could not be found.

#### Note:

Receives an ATM cell in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the cell directly from the ATM controller packet FIFO. This is a non-blocking receive, in that if there is no cell ready to be received at the device, the function returns with an error. The buffer into which the cell will be received must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer into which the received Atmc cell will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to the size of the buffer on entry

into the function and the size the received cell on return from the function.

CellStatusPtr is both an input and an output parameter. It is a pointer to the status of the cell which is

received. It is only valid if the return value indicates success. The status is necessary when cells with errors are not being discarded. This status is a bit mask which may

contain one or more of the following values with the exception of

XAT\_CELL\_STATUS\_NO\_ERROR which is mutually exclusive. The status values are:

- XAT\_CELL\_STATUS\_NO\_ERROR indicates the cell was received without any errors
- XAT\_CELL\_STATUS\_BAD\_PARITY indicates the cell parity was not correct
- XAT CELL STATUS BAD HEC indicates the cell HEC was not correct
- XAT\_CELL\_STATUS\_SHORT indicates the cell was not the correct length
- XAT\_CELL\_STATUS\_VXI\_MISMATCH indicates the cell VPI/VCI fields did not match the expected header values

#### **Returns:**

- o XST\_SUCCESS if the cell was sent successfully
- o XST DEVICE IS STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST NO DATA if tThere is no cell to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the cell is too small for the cell waiting in the FIFO.

#### **Note:**

The input buffer must be big enough to hold the largest ATM cell. The buffer must also be 32-bit aligned.

Sends an ATM cell in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the cell directly to the ATM controller packet FIFO, then enters a loop checking the device status for completion or error. The buffer to be sent must be word-aligned.

It is assumed that the upper layer software supplies a correctly formatted ATM cell based upon the configuration of the ATM controller (attaching header or not).

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the ATM cell to be sent.

ByteCount is the size of the ATM cell. An ATM cell for a 16 bit Utopia interface is 54 bytes with a 6

byte header and 48 bytes of payload. This function may be used to send short cells with or

without headers depending on the configuration of the ATM controller.

#### **Returns:**

- o XST\_SUCCESS if the cell was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST\_PFIFO\_NO\_ROOM if there is no room in the FIFO for this cell
- o XST\_FIFO\_ERROR if the FIFO was overrun or underrun

#### Note:

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread.

The input buffer must be big enough to hold the largest ATM cell. The buffer must also be 32-bit aligned.

#### void XAtmc Reset( XAtmc \* InstancePtr)

Resets the ATM controller. It resets the the DMA channels, the FIFOs, and the ATM controller. The reset does not remove any of the buffer descriptors from the scatter-gather list for DMA. Reset must only be called after the driver has been initialized.

The configuration after this reset is as follows:

- Disabled transmitter and receiver
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation
- PHY address of 0

The upper layer software is responsible for re-configuring (if necessary) and restarting the ATM controller after the reset.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

None.

#### Note:

The reset is accomplished by setting the IPIF reset register. This takes care of resetting all hardware blocks, including the ATM controller.

#### XStatus XAtmc\_SelfTest( XAtmc \* InstancePtr)

Performs a self-test on the ATM controller device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the ATM controller device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if self-test was successful
- o XST\_PFIFO\_BAD\_REG\_VALUE if the FIFO failed register self-test
- o XST\_DMA\_TRANSFER\_ERROR if DMA failed data transfer self-test
- XST\_DMA\_RESET\_REGISTER\_ERROR if DMA control register value was incorrect after a reset
- o XST\_REGISTER\_ERROR if the ATM controller failed register reset test
- o XST\_LOOPBACK\_ERROR if the ATM controller internal loopback failed
- o XST\_IPIF\_REG\_WIDTH\_ERROR if an invalid register width was passed into the function
- o XST\_IPIF\_RESET\_REGISTER\_ERROR if the value of a register at reset was invalid
- XST\_IPIF\_DEVICE\_STATUS\_ERROR if a write to the device status register did not read back correctly
- o XST\_IPIF\_DEVICE\_ACK\_ERROR if a bit in the device status register did not reset when acked
- o XST\_IPIF\_DEVICE\_ENABLE\_ERROR if the device interrupt enable register was not updated correctly by the hardware when other registers were written to
- XST\_IPIF\_IP\_STATUS\_ERROR if a write to the IP interrupt status register did not read back correctly
- o XST\_IPIF\_IP\_ACK\_ERROR if one or more bits in the IP status register did not reset when acked
- XST\_IPIF\_IP\_ENABLE\_ERROR if the IP interrupt enable register was not updated correctly when other registers were written to

#### **Note:**

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

Sets the callback function for handling errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback which should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable ATM controller error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_ATMC\_ERROR\_COUNT\_MAX indicates the counters of the ATM controller have reached the maximum value and that the statistics of the ATM controller should be cleared.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Sets the send or receive ATM header in the ATM controller. If cells with only payloads are given to the controller to be sent, it will attach the header to the cells. If the ATM controller is configured appropriately, it will compare the header of received cells against the receive header and discard cells which don't match in the VCI and VPI fields of the header.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the direction, send(transmit) or receive, for the header to set.

Header contains the ATM header to be attached to each transmitted cell for cells with only

payloads or the expected header for cells which are received.

#### **Returns:**

- o XST\_SUCCESS if the PHY address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

None.

Set Atmc driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option. A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off. See **xatmc.h** for a detailed description of the available options.

#### **Parameters:**

InstancePtr is a pointer to the XAtmc instance to be worked on.OptionsFlag is a bit-mask representing the Atmc options to turn on or off

#### **Returns:**

- XST\_SUCCESS if options were set successfully
- o XST DEVICE IS STARTED if the device has not yet been stopped

#### **Note:**

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Sets the PHY address for this driver/device. The address is a 5-bit value. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on. *Address* contains the 5-bit PHY address (0 - 31).

#### **Returns:**

- o XST\_SUCCESS if the PHY address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### **Note:**

None.

Sets the packet count threshold register for this driver/device. The device must be stopped before setting the threshold. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

Threshold is the value of the packet threshold count used during interrupt coalescing. A value of 0 disables the use of packet threshold by the hardware.

#### **Returns:**

- XST\_SUCCESS if the threshold was successfully set
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_DMA\_SG\_COUNT\_EXCEEDED if the threshold must be equal to or less than the number of descriptors in the list
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

Sets the packet wait bound register for this driver/device. The device must be stopped before setting the timer value. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold.

The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound used during interrupt coalescing. It is in milliseconds in the range 0 - 1023. A value of 0 disables the packet wait bound timer.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was set successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST DEVICE IS STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if an invalid direction was specified

#### **Note:**

None.

```
void XAtmc_SetSgRecvHandler( XAtmc * InstancePtr,
void * CallBackRef,
XAtmc_SgHandler FuncPtr
)
```

Sets the callback function for handling received cells in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of cells, determined by the DMA scatter-gather packet threshold, are received. The number of received cells is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each received cell from the list and should attach a new buffer to each descriptor. It is important that the specified number of cells passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are other potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Atmc driver. The memory space must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on. *MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the XAtmc\_Initialize function because the DMA channel components must be initialized before the memory space is set.

Sets the callback function for handling confirmation of transmitted cells in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of cells, determined by the DMA scatter-gather packet threshold, are sent. The number of sent cells is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each sent cell from the list and should also free the buffers attached to the descriptors if necessary. It is important that the specified number of cells passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### Parameters:

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Atmc driver. The memory space must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the XAtmc\_Initialize function because the DMA channel components must be initialized before the memory space is set.

Sets the 2nd byte of the User Defined data in the ATM controller for the channel which is sending data. The ATM controller will attach the header to all cells which are being sent and do not have a header. The header of a 16 bit Utopia interface contains the User Defined data which is two bytes. The first byte contains the HEC field and the second byte is available for user data. This function only allows the second byte to be set.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on. *UserDefined* contains the second byte of the User Defined data.

#### **Returns:**

- o XST\_SUCCESS if the user-defined data was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

None.

Gets the first buffer descriptor of the oldest cell which was received by the scatter-gather DMA channel of the ATM controller. This function is provided to be called from a callback function such that the buffer descriptors for received cells can be processed. The function should be called by the application repetitively for the number of cells indicated as an argument in the callback function. This function may also be used when only payloads are being sent and received by the ATM controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*PtrToBdPtr* is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the cell. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the cell. This input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the cell pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST NOT SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there
  are no buffer descriptors to be processed in the list.

#### Note:

```
XStatus XAtmc_SgGetSendCell( XAtmc * InstancePtr, XBufDescriptor ** PtrToBdPtr, int * BdCountPtr
```

Gets the first buffer descriptor of the oldest cell which was sent by the scatter-gather DMA channel of the ATM controller. This function is provided to be called from a callback function such that the buffer descriptors for sent cells can be processed. The function should be called by the application repetitively for the number of cells indicated as an argument in the callback function. This function may also be used when only payloads are being sent and received by the ATM controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*PtrToBdPtr* is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the cell. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the cell. this input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the cell pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST DMA SG NO LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there
  are no buffer descriptors to be processed in the list.

#### Note:

None.

Adds this descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be word-aligned. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of cells to replace filled buffers with empty buffers. The contents of the specified buffer descriptor are copied into the scatter-gather transmit list. This function can be called when the device is started or stopped.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

#### **Returns:**

- o XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST NOT SGDMA if the device is not in scatter-gather DMA mode

- o XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

#### Note:

None.

Sends an ATM cell using scatter-gather DMA. The caller attaches the cell to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire ATM cell may or may not be contained within one descriptor. The contents of the buffer descriptor are copied into the scatter-gather transmit list. The caller is responsible for providing mutual exclusion to guarantee that a cell is contiguous in the transmit list. The buffer attached to the descriptor must be word-aligned.

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the cell, the inserts are committed, which means the descriptors for this cell are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted ATM cell based upon the configuration of the ATM controller (attaching header or not). The ATM controller must be started before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

#### **Returns:**

- XST\_SUCCESS if the buffer was successfully sent
- XST DEVICE IS STOPPED if the ATM controller has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

#### **XStatus XAtmc\_Start( XAtmc \*** *InstancePtr*)

Starts the ATM controller as follows:

- If not in polled mode enable interrupts
- Enable the transmitter
- Enable the receiver
- Start the DMA channels if the descriptor lists are not empty

It is necessary for the caller to connect the interrupt servive routine of the ATM controller to the interrupt source, typically an interrupt controller, and enable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the device was started successfully
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- o XST\_DMA\_SG\_LIST\_EMPTY iff configured for scatter-gather DMA and no buffer descriptors have been put into the list for the receive channel.

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

#### **XStatus XAtmc\_Stop( XAtmc \*** *InstancePtr*)

Stops the ATM controller as follows:

- Stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode

It is the callers responsibility to disconnect the interrupt handler of the ATM controller from the interrupt source, typically an interrupt controller, and disable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions

| functions. So | o if one task n | night be setting | device options  | while anot | ther is trying t | to stop the | device, th | ıe |
|---------------|-----------------|------------------|-----------------|------------|------------------|-------------|------------|----|
| user is requi | red to provide  | protection of t  | his shared data | (typically | using a semap    | ohore).     |            |    |

Generated on 30 Sep 2003 for Xilinx Device Drivers

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 2003 Xilinx Inc. All rights reserved.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## **Xilinx Device Drivers Data Structures**

Here are the data structures with brief descriptions:

| XAtmc            |
|------------------|
| XAtmc_Config     |
| XAtmc_Stats      |
| XEmac            |
| XEmac_Config     |
| XEmac_Stats      |
| XEmc             |
| XEmc_Config      |
| XENV_TIME_STAMP  |
| XFlash_Config    |
| XFlashGeometry   |
| XFlashPartID     |
| XFlashProgCap    |
| XFlashProperties |
| XFlashTag        |
| XFlashTiming     |
| XGemac           |
| XGemac_Config    |
| XGemac_HardStats |
| XGemac_SoftStats |
| XGpio            |
| XHdlc            |
| XHdlc_Config     |
| XHdlc_Stats      |
| 1111010_Dtuto    |

| XIic                 |
|----------------------|
| XIic_Config          |
| XIicStats            |
| XIntc                |
| XIntc_Config         |
| XOpb2Plb             |
| XOpb2Plb_Config      |
| XOpbArb              |
| XOpbArb_Config       |
| XPci                 |
| XPciError            |
| XPlb2Opb             |
| XPlb2Opb_Config      |
| XPlbArb              |
| XPlbArb_Config       |
| XSpi                 |
| XSpi_Config          |
| XSpi_Stats           |
| XSysAce              |
| XSysAce_CFParameters |
| XSysAce_Config       |
| XTmrCtr              |
| XTmrCtr_Config       |
| XTmrCtrStats         |
| XUartLite            |
| XUartLite_Buffer     |
| XUartLite_Config     |
| XUartLite_Stats      |
| XUartNs550           |
| XUartNs550_Config    |
| XUartNs550Format     |

XUartNs550Stats
XWdtTb
XWdtTb\_Config

Generated on 30 Sep 2003 for Xilinx Device Drivers

# **Xilinx Device Drivers File List**

Here is a list of all documented files with brief descriptions:

| Tiere is a fist of all documented files with offer de |
|-------------------------------------------------------|
| atmc/v1_00_c/src/xatmc.c                              |
| atmc/v1_00_c/src/xatmc.h                              |
| atmc/v1_00_c/src/xatmc_cfg.c                          |
| atmc/v1_00_c/src/xatmc_g.c                            |
| atmc/v1_00_c/src/xatmc_i.h                            |
| atmc/v1_00_c/src/xatmc_l.c                            |
| atmc/v1_00_c/src/xatmc_l.h                            |
| common/v1_00_a/src/xbasic_types.c                     |
| common/v1_00_a/src/xbasic_types.h                     |
| common/v1_00_a/src/xenv.h                             |
| common/v1_00_a/src/xenv_linux.h                       |
| common/v1_00_a/src/xenv_none.h                        |
| common/v1_00_a/src/xenv_vxworks.h                     |
| common/v1_00_a/src/xparameters.h                      |
| common/v1_00_a/src/xstatus.h                          |
| common/v1_00_a/src/xutil.h                            |
| common/v1_00_a/src/xutil_memtest.c                    |
| cpu/v1_00_a/src/xio.c                                 |
| cpu/v1_00_a/src/xio.h                                 |
| cpu_ppc405/v1_00_a/src/xio.c                          |
| cpu_ppc405/v1_00_a/src/xio.h                          |
| cpu_ppc405/v1_00_a/src/xio_dcr.c                      |
| cpu_ppc405/v1_00_a/src/xio_dcr.h                      |
| emac/v1_00_d/src/xemac.c                              |
|                                                       |

```
emac/v1 00 d/src/xemac.h
emac/v1_00_d/src/xemac_g.c
emac/v1_00_d/src/xemac_i.h
emac/v1_00_d/src/xemac_intr.c
emac/v1 00 d/src/xemac intr dma.c
emac/v1 00 d/src/xemac intr fifo.c
emac/v1_00_d/src/xemac_l.c
emac/v1 00 d/src/xemac l.h
emac/v1 00 d/src/xemac multicast.c
emac/v1_00_d/src/xemac_options.c
emac/v1_00_d/src/xemac_phy.c
emac/v1 00 d/src/xemac polled.c
emac/v1 00 d/src/xemac selftest.c
emac/v1_00_d/src/xemac_stats.c
emaclite/v1_00_a/src/xemaclite_l.c
emaclite/v1 00 a/src/xemaclite l.h
emc/v1_00_a/src/xemc.c
emc/v1 00 a/src/xemc.h
emc/v1_00_a/src/xemc_g.c
emc/v1_00_a/src/xemc_i.h
emc/v1 00 a/src/xemc l.h
emc/v1_00_a/src/xemc_selftest.c
flash/v1 00 a/src/xflash.c
flash/v1_00_a/src/xflash.h
flash/v1_00_a/src/xflash_cfi.c
flash/v1 00 a/src/xflash cfi.h
flash/v1 00 a/src/xflash g.c
flash/v1 00 a/src/xflash geometry.c
flash/v1_00_a/src/xflash_geometry.h
flash/v1_00_a/src/xflash_intel.c
flash/v1 00 a/src/xflash intel.h
```

```
flash/v1 00 a/src/xflash intel l.c
flash/v1 00 a/src/xflash intel l.h
flash/v1_00_a/src/xflash_properties.h
gemac/v1_00_d/src/xgemac.c
gemac/v1_00_d/src/xgemac.h
gemac/v1_00_d/src/xgemac_control.c
gemac/v1_00_d/src/xgemac_g.c
gemac/v1_00_d/src/xgemac_i.h
gemac/v1_00_d/src/xgemac_intr.c
gemac/v1 00 d/src/xgemac intr dma.c
gemac/v1_00_d/src/xgemac_intr_fifo.c
gemac/v1_00_d/src/xgemac_l.h
gemac/v1 00 d/src/xgemac multicast.c
gemac/v1_00_d/src/xgemac_options.c
gemac/v1_00_d/src/xgemac_polled.c
gemac/v1_00_d/src/xgemac_selftest.c
gemac/v1_00_d/src/xgemac_stats.c
gpio/v1 00 a/src/xgpio.c
gpio/v1_00_a/src/xgpio.h
gpio/v1_00_a/src/xgpio_extra.c
gpio/v1_00_a/src/xgpio_g.c
gpio/v1_00_a/src/xgpio_i.h
gpio/v1_00_a/src/xgpio_l.h
gpio/v1_00_a/src/xgpio_selftest.c
hdlc/v1_00_a/src/xhdlc.c
hdlc/v1 00 a/src/xhdlc.h
hdlc/v1_00_a/src/xhdlc_dmasg.c
hdlc/v1_00_a/src/xhdlc_g.c
hdlc/v1_00_a/src/xhdlc_i.h
hdlc/v1 00 a/src/xhdlc l.c
hdlc/v1_00_a/src/xhdlc_l.h
```

| hdlc/v1_00_a/src/xhdlc_options.c    |
|-------------------------------------|
| hdlc/v1_00_a/src/xhdlc_selftest.c   |
| hdlc/v1_00_a/src/xhdlc_stats.c      |
| iic/v1_01_c/src/xiic.c              |
| iic/v1_01_c/src/xiic.h              |
| iic/v1_01_c/src/xiic_g.c            |
| iic/v1_01_c/src/xiic_i.h            |
| iic/v1_01_c/src/xiic_intr.c         |
| iic/v1_01_c/src/xiic_l.c            |
| iic/v1_01_c/src/xiic_l.h            |
| iic/v1_01_c/src/xiic_master.c       |
| iic/v1_01_c/src/xiic_multi_master.c |
| iic/v1_01_c/src/xiic_options.c      |
| iic/v1_01_c/src/xiic_selftest.c     |
| iic/v1_01_c/src/xiic_slave.c        |
| iic/v1_01_c/src/xiic_stats.c        |
| intc/v1_00_b/src/xintc.c            |
| intc/v1_00_b/src/xintc.h            |
| intc/v1_00_b/src/xintc_g.c          |
| intc/v1_00_b/src/xintc_i.h          |
| intc/v1_00_b/src/xintc_intr.c       |
| intc/v1_00_b/src/xintc_l.c          |
| intc/v1_00_b/src/xintc_l.h          |
| intc/v1_00_b/src/xintc_lg.c         |
| intc/v1_00_b/src/xintc_options.c    |
| intc/v1_00_b/src/xintc_selftest.c   |
| opb2plb/v1_00_a/src/xopb2plb.c      |
| opb2plb/v1_00_a/src/xopb2plb.h      |
| opb2plb/v1_00_a/src/xopb2plb_g.c    |
| opb2plb/v1_00_a/src/xopb2plb_i.h    |
| opb2plb/v1_00_a/src/xopb2plb_l.h    |

```
opb2plb/v1_00_a/src/xopb2plb_selftest.c
opbarb/v1_02_a/src/xopbarb.c
opbarb/v1_02_a/src/xopbarb.h
opbarb/v1_02_a/src/xopbarb_g.c
opbarb/v1_02_a/src/xopbarb_l.h
pci/v1_00_a/src/xpci.h
pci/v1_00_a/src/xpci_config.c
pci/v1_00_a/src/xpci_g.c
pci/v1_00_a/src/xpci_intr.c
pci/v1_00_a/src/xpci_l.h
pci/v1_00_a/src/xpci_selftest.c
pci/v1_00_a/src/xpci_v3.c
plb2opb/v1_00_a/src/xplb2opb.c
plb2opb/v1_00_a/src/xplb2opb.h
plb2opb/v1_00_a/src/xplb2opb_g.c
plb2opb/v1_00_a/src/xplb2opb_i.h
plb2opb/v1_00_a/src/xplb2opb_l.h
plb2opb/v1 00 a/src/xplb2opb selftest.c
plbarb/v1_01_a/src/xplbarb.c
plbarb/v1_01_a/src/xplbarb.h
plbarb/v1_01_a/src/xplbarb_g.c
plbarb/v1 01 a/src/xplbarb i.h
plbarb/v1_01_a/src/xplbarb_l.h
plbarb/v1_01_a/src/xplbarb_selftest.c
rapidio/v1_00_a/src/xrapidio_l.c
rapidio/v1 00 a/src/xrapidio l.h
spi/v1_00_b/src/xspi.c
spi/v1_00_b/src/xspi.h
spi/v1_00_b/src/xspi_g.c
spi/v1_00_b/src/xspi_i.h
spi/v1_00_b/src/xspi_l.h
```

```
spi/v1_00_b/src/xspi_options.c
spi/v1_00_b/src/xspi_selftest.c
spi/v1_00_b/src/xspi_stats.c
sysace/v1_00_a/src/xsysace.c
sysace/v1_00_a/src/xsysace.h
sysace/v1 00 a/src/xsysace compactflash.c
sysace/v1_00_a/src/xsysace_g.c
sysace/v1_00_a/src/xsysace_intr.c
sysace/v1_00_a/src/xsysace_jtagcfg.c
sysace/v1_00_a/src/xsysace_l.c
sysace/v1_00_a/src/xsysace_l.h
sysace/v1_00_a/src/xsysace_selftest.c
tmrctr/v1 00 b/src/xtmrctr.c
tmrctr/v1_00_b/src/xtmrctr.h
tmrctr/v1_00_b/src/xtmrctr_g.c
tmrctr/v1 00 b/src/xtmrctr i.h
tmrctr/v1_00_b/src/xtmrctr_intr.c
tmrctr/v1 00 b/src/xtmrctr l.c
tmrctr/v1 00 b/src/xtmrctr l.h
tmrctr/v1_00_b/src/xtmrctr_options.c
tmrctr/v1 00 b/src/xtmrctr selftest.c
tmrctr/v1_00_b/src/xtmrctr_stats.c
uartlite/v1 00 b/src/xuartlite.c
uartlite/v1_00_b/src/xuartlite.h
uartlite/v1_00_b/src/xuartlite_g.c
uartlite/v1 00 b/src/xuartlite i.h
uartlite/v1_00_b/src/xuartlite_intr.c
uartlite/v1 00 b/src/xuartlite l.c
uartlite/v1 00 b/src/xuartlite l.h
uartlite/v1_00_b/src/xuartlite_selftest.c
uartlite/v1 00 b/src/xuartlite stats.c
```

```
uartns550/v1_00_b/src/xuartns550.c
uartns550/v1_00_b/src/xuartns550.h
uartns550/v1_00_b/src/xuartns550_format.c
uartns550/v1_00_b/src/xuartns550_g.c
uartns550/v1 00 b/src/xuartns550 i.h
uartns550/v1 00 b/src/xuartns550 intr.c
uartns550/v1_00_b/src/xuartns550_l.c
uartns550/v1_00_b/src/xuartns550_l.h
uartns550/v1_00_b/src/xuartns550_options.c
uartns550/v1_00_b/src/xuartns550_selftest.c
uartns550/v1_00_b/src/xuartns550_stats.c
wdttb/v1_00_b/src/xwdttb.c
wdttb/v1 00 b/src/xwdttb.h
wdttb/v1_00_b/src/xwdttb_g.c
wdttb/v1_00_b/src/xwdttb_i.h
wdttb/v1_00_b/src/xwdttb_l.h
wdttb/v1_00_b/src/xwdttb_selftest.c
```

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# Xilinx Device Drivers Data Fields

# $\underline{a} | \underline{b} | \underline{c} | \underline{d} | \underline{e} | \underline{f} | \underline{h} | \underline{i} | \underline{1} | \underline{m} | \underline{n} | \underline{p} | \underline{r} | \underline{s} | \underline{t} | \underline{u} | \underline{v} | \underline{w} | \underline{x}$

Here is a list of all documented struct and union fields with links to the structures/unions they belong to:

#### - a -

• AbsoluteBlock : XFlashGeometry

AbsoluteOffset : XFlashGeometry

AckBeforeService : XIntc\_Config

• ArbitrationLost : XIicStats

• AtmcInterrupts : **XAtmc\_Stats** 

## - b -

- BaseAddr : XWdtTb\_Config, XFlash\_Config
- BaseAddress: XUartNs550\_Config, XTmrCtr\_Config, XSysAce\_Config, XSpi\_Config, XPlbArb\_Config, XPlb2Opb\_Config, XOpbArb\_Config, XOpb2Plb\_Config, XIntc\_Config, XIic\_Config, XHdlc\_Config, XGemac\_Config, XFlashGeometry, XEmac\_Config, XAtmc\_Config
- BaudRate: XUartNs550Format, XUartLite\_Config
- BufferSize : XSysAce\_CFParameters
- BufferType : XSysAce\_CFParameters
- BusBusy: XIicStats
- BytesTransferred : XSpi\_Stats

#### - C -

- Capabilities : XSysAce\_CFParameters
- CharactersReceived : XUartNs550Stats, XUartLite\_Stats

- CharactersTransmitted: XUartNs550Stats, XUartLite\_Stats
- CommandSet: XFlashPartID
- CurNumCylinders : XSysAce\_CFParameters
- CurNumHeads : XSysAce\_CFParameters
- CurSectorsPerCard : XSysAce\_CFParameters
- CurSectorsPerTrack : XSysAce\_CFParameters

## - d -

- DataBits : XUartNs550Format, XUartLite\_Config
- DblWord : XSysAce\_CFParameters
- DeviceID : XFlashPartID
- DeviceId: XWdtTb\_Config, XUartNs550\_Config, XUartLite\_Config, XTmrCtr\_Config, XSysAce\_Config, XSpi\_Config, XPlbArb\_Config, XPlb2Opb\_Config, XOpbArb\_Config, XOpb2Plb\_Config, XIntc\_Config, XIic\_Config, XHdlc\_Config, XGemac\_Config, XFlash\_Config, XEmc\_Config, XEmac\_Config, XAtmc\_Config
- DeviceSize : **XFlashGeometry**
- DmaErrors : XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats, XAtmc\_Stats
- DmaMode : XSysAce\_CFParameters
- DmaRegBaseAddr : XPci
- DmaType : **XPci**

#### - e -

- EmacInterrupts : **XGemac\_SoftStats**, **XEmac\_Stats**
- EraseBlock\_Ms: XFlashTiming
- EraseChip\_Ms: XFlashTiming
- EraseQueueSize : XFlashProgCap

# - f -

- FifoErrors: XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats, XAtmc\_Stats
- FwVersion : XSysAce\_CFParameters

• Has10BitAddr : **XIic\_Config** 

• HasCounters : XGemac\_Config, XEmac\_Config

• HasFifos : **XSpi\_Config** 

• HasGmii : XGemac\_Config

• HasMii : **XEmac\_Config** 

• HdlcInterrupts : XHdlc\_Stats

## - i -

• IicInterrupts : XIicStats

• InputClockHz: XUartNs550\_Config

• Interrupts : **XTmrCtrStats** 

• IpIfDmaConfig: XHdlc\_Config, XGemac\_Config, XEmac\_Config, XAtmc\_Config

• IsError : **XPciError** 

• IsReady : XPci

# - | -

• LbaSectors : XSysAce\_CFParameters

• LocalBusReadAddr : **XPciError** 

• LocalBusReason : **XPciError** 

• LocalBusWriteAddr: XPciError

#### - m -

• ManufacturerID : XFlashPartID

• MaxSectors : XSysAce\_CFParameters

• MemoryLayout : **XFlashGeometry** 

• ModeFaults : **XSpi\_Stats** 

 $\bullet \quad Model No: {\bf XSysAce\_CFParameters}$ 

• ModemInterrupts : XUartNs550Stats

• MultipleSectors : XSysAce\_CFParameters

#### - n -

• NumBanks : **XEmc\_Config** 

• Number : **XFlashGeometry** 

- NumBlocks : **XFlashGeometry**
- NumBytesPerSector : XSysAce\_CFParameters
- NumBytesPerTrack : XSysAce\_CFParameters
- NumCylinders : XSysAce\_CFParameters
- NumEccBytes : XSysAce\_CFParameters
- NumEraseRegions : XFlashGeometry
- NumHeads : XSysAce\_CFParameters
- NumInterrupts : **XSpi\_Stats**
- NumMasters: XPlbArb\_Config, XPlb2Opb\_Config, XOpbArb\_Config
- NumParts : **XFlash\_Config**
- NumSectorsPerCard : XSysAce\_CFParameters
- NumSectorsPerTrack : XSysAce\_CFParameters
- NumSlaveBits : **XSpi\_Config**

# - p -

- Parity: XUartNs550Format
- ParityOdd: XUartLite\_Config
- PartID : XFlashProperties
- PartMode : XFlash\_Config
- PartWidth : **XFlash\_Config**
- PciReadAddr : XPciError
- PciReason : **XPciError**
- PciSerrReadAddr : **XPciError**
- PciSerrReason : XPciError
- PciSerrWriteAddr: XPciError
- PciWriteAddr : XPciError
- PioMode : XSysAce\_CFParameters
- PowerDesc : XSysAce\_CFParameters
- ProgCap : XFlashProperties

#### - r -

- ReceiveBreakDetected : XUartNs550Stats
- ReceiveFifoSize : XHdlc\_Config
- ReceiveFramingErrors : XUartNs550Stats, XUartLite\_Stats
- ReceiveInterrupts : XUartNs550Stats, XUartLite\_Stats
- ReceiveOverrunErrors : XUartNs550Stats, XUartLite\_Stats

- ReceiveParityErrors : XUartNs550Stats, XUartLite\_Stats
- Recv1024\_MaxByte : **XGemac\_HardStats**
- Recv128\_255Byte : **XGemac\_HardStats**
- Recv256\_511Byte : **XGemac\_HardStats**
- Recv512\_1023Byte : **XGemac\_HardStats**
- Recv64Byte : **XGemac\_HardStats**
- Recv65\_127Byte : **XGemac\_HardStats**
- RecvAbortedFrames : XHdlc Stats
- RecvAlignmentErrors : **XHdlc\_Stats**, **XEmac\_Stats**
- RecvBadOpcode : **XGemac\_HardStats**
- RecvBroadcast : XGemac HardStats
- RecvBytes: XIicStats, XHdlc\_Stats, XGemac\_HardStats, XEmac\_Stats
- RecvCells : **XAtmc\_Stats**
- RecvCollisionErrors : XEmac Stats
- RecvControl: XGemac HardStats
- RecvFcs : XGemac\_HardStats
- RecvFcsErrors: XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats
- RecvFragment : XGemac\_HardStats
- RecvFrames: XHdlc\_Stats, XGemac\_HardStats, XEmac\_Stats
- RecvHecErrors : **XAtmc\_Stats**
- RecvInterrupts: XIicStats, XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats,
   XAtmc\_Stats
- RecvLengthFieldErrors : XGemac\_SoftStats, XEmac\_Stats
- RecvLengthRange : **XGemac\_HardStats**
- RecvLong : XGemac\_HardStats
- RecvLongCells : **XAtmc\_Stats**
- RecvLongErrors : **XGemac\_SoftStats**, **XEmac\_Stats**
- RecvMissedFrameErrors : XEmac\_Stats
- RecvMulticast : **XGemac\_HardStats**
- RecvOverrunErrors : XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats
- RecvOverruns : XSpi\_Stats
- RecvParityErrors : **XAtmc\_Stats**
- RecvPause : XGemac\_HardStats
- RecvShort : XGemac\_HardStats
- RecvShortCells : XAtmc\_Stats
- RecvShortErrors : XEmac\_Stats
- RecvSlotLengthErrors : XGemac\_SoftStats
- RecvUnderrunErrors : XGemac\_SoftStats, XEmac\_Stats

- RecvUnexpectedHeaders : **XAtmc\_Stats**
- RecvVlan : XGemac\_HardStats
- RegBaseAddr : XUartLite\_Config, XPci, XEmc\_Config
- RepeatedStarts : XIicStats

#### **- S -**

- SecurityStatus : XSysAce\_CFParameters
- SendBytes : XIicStats
- SendInterrupts : XIicStats
- SerialNo : XSysAce\_CFParameters
- Signature : XSysAce\_CFParameters
- Size: XFlashGeometry
- SlaveModeFaults : XSpi\_Stats
- SlaveOnly : XSpi\_Config
- StatusInterrupts : **XUartNs550Stats**
- StopBits: XUartNs550Format

## - t -

- TimeMax : XFlashProperties
- TimeTypical : XFlashProperties
- TotalInterrupts : **XGemac\_SoftStats**
- TotalIntrs : **XEmac\_Stats**
- TranslationValid : XSysAce\_CFParameters
- TransmitFifoSize : XHdlc\_Config
- TransmitInterrupts : XUartNs550Stats, XUartLite\_Stats
- TxErrors : XIicStats

#### - u -

• UseParity : **XUartLite\_Config** 

#### - V -

- VendorUnique : XSysAce\_CFParameters
- VendorUniqueBytes : XSysAce\_CFParameters

- WriteBuffer\_Us: XFlashTiming
- WriteBufferAlignmentMask : XFlashProgCap
- WriteBufferSize : XFlashProgCap
- WriteSingle\_Us: XFlashTiming

#### - X -

- Xmit1024\_MaxByte : **XGemac\_HardStats**
- Xmit128\_255Byte : **XGemac\_HardStats**
- Xmit1stCollision : XGemac\_HardStats
- Xmit256\_511Byte : **XGemac\_HardStats**
- Xmit512\_1023Byte : **XGemac\_HardStats**
- Xmit64Byte : XGemac\_HardStats
- Xmit65\_127Byte : **XGemac\_HardStats**
- XmitBroadcast : XGemac HardStats
- XmitBytes: XHdlc Stats, XGemac HardStats, XEmac Stats
- XmitCarrierSense : XGemac HardStats
- XmitCells : XAtmc\_Stats
- XmitControl : XGemac\_HardStats
- XmitDeferred : XGemac\_HardStats
- XmitExcessCollision : XGemac\_HardStats
- XmitExcessDeferral : XEmac\_Stats
- XmitExcessDeferralErrors : XGemac\_SoftStats
- XmitExcessDeferred : XGemac\_HardStats
- XmitFrames: XHdlc\_Stats, XGemac\_HardStats, XEmac\_Stats
- XmitInterrupts : XHdlc\_Stats, XGemac\_SoftStats, XEmac\_Stats, XAtmc\_Stats
- XmitLateColision : **XGemac\_HardStats**
- XmitLateCollErrors : **XGemac\_SoftStats**
- XmitLateCollisionErrors : XEmac\_Stats
- XmitLong : XGemac\_HardStats
- XmitMulticast : XGemac\_HardStats
- XmitMultiCollision : XGemac\_HardStats
- XmitOverrunErrors : **XGemac\_SoftStats**, **XEmac\_Stats**
- XmitPause : XGemac\_HardStats
- XmitPFifoUnderrunErrors : XGemac\_SoftStats

• XmitUnderrun : **XGemac\_HardStats** 

• XmitUnderrunErrors : **XGemac\_SoftStats**, **XEmac\_Stats** 

• XmitUnderruns : **XSpi\_Stats** 

• XmitVlan : **XGemac\_HardStats** 

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# Xilinx Device Drivers Globals

### $\underline{1} \mid \underline{\mathbf{x}}$

Here is a list of all documented functions, variables, defines, enums, and typedefs with links to the documentation:

- | -

• LOOPBACK\_BYTE\_COUNT : xhdlc\_selftest.c

#### - X -

- XAssert(): xbasic\_types.h, xbasic\_types.c
- XASSERT\_NONVOID : xbasic\_types.h
- XASSERT\_NONVOID\_ALWAYS : xbasic\_types.h
- XASSERT\_VOID : xbasic\_types.h
- XASSERT\_VOID\_ALWAYS : xbasic\_types.h
- XAssertCallback : xbasic\_types.h
- XAssertSetCallback(): xbasic\_types.h, xbasic\_types.c
- XAssertStatus : xbasic\_types.h, xbasic\_types.c
- XAT\_CELL\_STATUS\_BAD\_HEC: xatmc.h
- XAT\_CELL\_STATUS\_BAD\_PARITY : xatmc.h
- XAT\_CELL\_STATUS\_LONG: xatmc.h
- XAT\_CELL\_STATUS\_NO\_ERROR: xatmc.h
- XAT\_CELL\_STATUS\_SHORT : xatmc.h
- XAT\_CELL\_STATUS\_VXI\_MISMATCH: xatmc.h
- XAT\_DISCARD\_HEC\_OPTION: xatmc.h
- XAT\_DISCARD\_LONG\_OPTION: xatmc.h
- XAT DISCARD PARITY OPTION: xatmc.h
- XAT\_DISCARD\_SHORT\_OPTION : xatmc.h
- XAT\_DISCARD\_VXI\_OPTION : xatmc.h

- XAT\_LOOPBACK\_OPTION : xatmc.h
- XAT\_NO\_SEND\_PARITY\_OPTION: xatmc.h
- XAT\_PAYLOAD\_ONLY\_OPTION : xatmc.h
- XAT\_POLLED\_OPTION : xatmc.h
- XAtmc\_ClearStats(): xatmc\_cfg.c, xatmc.h
- XAtmc\_ConfigTable : xatmc\_i.h, xatmc\_g.c
- XAtmc\_ErrorHandler : xatmc.h
- XAtmc\_GetHeader(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetOptions(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetPhyAddress(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetPktThreshold(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetPktWaitBound(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetStats(): xatmc\_cfg.c, xatmc.h
- XAtmc\_GetUserDefined(): xatmc\_cfg.c, xatmc.h
- XAtmc\_Initialize(): xatmc\_cfg.c, xatmc.h
- XAtmc\_InterruptHandler(): xatmc.h, xatmc.c
- XAtmc\_LookupConfig(): xatmc\_cfg.c, xatmc.h
- XAtmc\_mDisable : xatmc\_l.h
- XAtmc\_mEnable : xatmc\_l.h
- XAtmc\_mIsRxEmpty : xatmc\_l.h
- XAtmc\_mIsSgDma : xatmc\_i.h
- XAtmc\_mIsTxDone : xatmc\_l.h
- XAtmc\_mReadReg : xatmc\_l.h
- XAtmc\_mWriteReg : xatmc\_l.h
- XAtmc\_PollRecv(): xatmc.h, xatmc.c
- XAtmc\_PollSend(): xatmc.h, xatmc.c
- XAtmc\_RecvCell(): xatmc\_l.h, xatmc\_l.c
- XAtmc\_Reset(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SelfTest(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SendCell(): xatmc\_l.h, xatmc\_l.c
- XAtmc\_SetErrorHandler(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetHeader(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetOptions(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetPhyAddress(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetPktThreshold(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetPktWaitBound(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetSgRecvHandler(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetSgRecvSpace(): xatmc\_cfg.c, xatmc.h

- XAtmc\_SetSgSendHandler(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetSgSendSpace(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SetUserDefined(): xatmc\_cfg.c, xatmc.h
- XAtmc\_SgGetRecvCell(): xatmc.h, xatmc.c
- XAtmc\_SgGetSendCell(): xatmc.h, xatmc.c
- XAtmc\_SgHandler: xatmc.h
- XAtmc\_SgRecv(): xatmc.h, xatmc.c
- XAtmc\_SgSend(): xatmc.h, xatmc.c
- XAtmc\_Start(): xatmc\_cfg.c, xatmc.h
- XAtmc\_Stop(): xatmc\_cfg.c, xatmc.h
- Xboolean: xbasic\_types.h
- XEM\_BROADCAST\_OPTION : xemac.h
- XEM\_FDUPLEX\_OPTION : xemac.h
- XEM\_FLOW\_CONTROL\_OPTION: xemac.h
- XEM\_INSERT\_ADDR\_OPTION : xemac.h
- XEM INSERT FCS OPTION: xemac.h
- XEM\_INSERT\_PAD\_OPTION: xemac.h
- XEM LOOPBACK OPTION: xemac.h
- XEM\_MULTICAST\_OPTION : xemac.h
- XEM\_OVWRT\_ADDR\_OPTION : xemac.h
- XEM\_POLLED\_OPTION : xemac.h
- XEM\_PROMISC\_OPTION : xemac.h
- XEM\_STRIP\_PAD\_FCS\_OPTION : xemac.h
- XEM\_UNICAST\_OPTION : xemac.h
- XEmac\_ClearStats(): xemac\_stats.c, xemac.h
- XEmac\_ConfigTable : **xemac\_i.h**, **xemac\_g.c**
- XEmac\_ErrorHandler : xemac.h
- XEmac\_FifoHandler : xemac.h
- XEmac\_FifoRecv(): xemac\_intr\_fifo.c, xemac.h
- XEmac\_FifoSend(): xemac\_intr\_fifo.c, xemac.h
- XEmac\_GetInterframeGap(): xemac\_options.c, xemac.h
- XEmac\_GetMacAddress(): xemac.h, xemac.c
- XEmac\_GetOptions(): xemac\_options.c, xemac.h
- XEmac\_GetPktThreshold(): xemac\_intr\_dma.c, xemac.h
- XEmac\_GetPktWaitBound(): xemac\_intr\_dma.c, xemac.h
- XEmac\_GetStats(): xemac\_stats.c, xemac.h
- XEmac\_Initialize(): xemac.h, xemac.c
- XEmac\_IntrHandlerDma(): xemac\_intr\_dma.c, xemac.h

- XEmac\_IntrHandlerFifo(): xemac\_intr\_fifo.c, xemac.h
- XEmac\_LookupConfig(): xemac.h, xemac.c
- XEmac\_mDisable : xemac\_l.h
- XEmac\_mEnable : xemac\_l.h
- XEmac\_mIsDma: xemac.h
- XEmac mIsRxEmpty: xemac l.h
- XEmac\_mIsSgDma : xemac.h
- XEmac\_mIsSimpleDma : xemac.h
- XEmac\_mIsTxDone : xemac\_l.h
- XEmac\_mPhyReset : xemac\_l.h
- XEmac\_mReadReg : xemac\_l.h
- XEmac\_mSetControlReg : xemac\_l.h
- XEmac\_mSetMacAddress : xemac\_l.h
- XEmac\_MulticastAdd(): xemac\_multicast.c, xemac.h
- XEmac\_MulticastClear(): xemac\_multicast.c, xemac.h
- XEmac\_mWriteReg : xemac\_l.h
- XEmac\_PhyRead(): xemac\_phy.c, xemac.h
- XEmac\_PhyWrite(): xemac\_phy.c, xemac.h
- XEmac\_PollRecv(): xemac\_polled.c, xemac.h
- XEmac\_PollSend(): xemac\_polled.c, xemac.h
- XEmac\_RecvFrame(): xemac\_l.h, xemac\_l.c
- XEmac\_Reset(): xemac.h, xemac.c
- XEmac\_SelfTest(): xemac\_selftest.c, xemac.h
- XEmac\_SendFrame(): xemac\_l.h, xemac\_l.c
- XEmac\_SetErrorHandler(): xemac\_intr.c, xemac.h
- XEmac\_SetFifoRecvHandler(): xemac\_intr\_fifo.c, xemac.h
- XEmac\_SetFifoSendHandler(): xemac\_intr\_fifo.c, xemac.h
- XEmac\_SetInterframeGap(): xemac\_options.c, xemac.h
- XEmac\_SetMacAddress(): xemac.h, xemac.c
- XEmac\_SetOptions(): xemac\_options.c, xemac.h
- XEmac\_SetPktThreshold(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SetPktWaitBound(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SetSgRecvHandler(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SetSgRecvSpace(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SetSgSendHandler(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SetSgSendSpace(): xemac\_intr\_dma.c, xemac.h
- XEmac\_SgHandler : xemac.h
- XEmac\_SgRecv(): xemac\_intr\_dma.c, xemac.h

- XEmac\_SgSend(): xemac\_intr\_dma.c, xemac.h
- XEmac\_Start(): xemac.h, xemac.c
- XEmac\_Stop(): xemac.h, xemac.c
- XEmacLite\_mIsRxEmpty : xemaclite\_l.h
- XEmacLite\_mIsTxDone : xemaclite\_l.h
- XEmacLite\_RecvFrame(): xemaclite\_l.h, xemaclite\_l.c
- XEmacLite\_SendFrame(): xemaclite\_l.h, xemaclite\_l.c
- XEmacLite\_SetMacAddress(): xemaclite\_l.h, xemaclite\_l.c
- XEmc\_GetAccessSpeed(): xemc.h, xemc.c
- XEmc\_GetPageMode(): xemc.h, xemc.c
- XEmc\_Initialize(): xemc.h, xemc.c
- XEmc\_LookupConfig(): xemc.h, xemc.c
- XEmc\_mDisableFastAccess : xemc\_l.h
- XEmc\_mDisablePageMode : xemc\_l.h
- XEmc\_mEnableFastAccess : xemc\_l.h
- XEmc\_mEnablePageMode : xemc\_l.h
- XEmc\_mGetControlReg : xemc\_l.h
- XEmc mGetOffset: xemc l.h
- XEmc\_mSetControlReg : xemc\_l.h
- XEmc\_SelfTest(): xemc\_selftest.c, xemc.h
- XEmc\_SetAccessSpeed(): xemc.h, xemc.c
- XEmc\_SetPageMode(): xemc.h, xemc.c
- XENV\_MEM\_COPY: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XENV\_MEM\_FILL: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XENV\_TIME\_STAMP : xenv\_none.h, xenv\_linux.h
- XENV\_TIME\_STAMP\_DELTA\_MS: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XENV\_TIME\_STAMP\_DELTA\_US: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XENV\_TIME\_STAMP\_GET: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XENV\_USLEEP: xenv\_vxworks.h, xenv\_none.h, xenv\_linux.h
- XFALSE : xbasic\_types.h
- XFL\_CFI\_ADVANCE\_PTR16 : xflash\_cfi.h
- XFL\_CFI\_ADVANCE\_PTR8 : xflash\_cfi.h
- XFL\_CFI\_POSITION\_PTR : **xflash\_cfi.h**
- XFL\_CFI\_READ16: xflash\_cfi.h
- XFL\_CFI\_READ8 : **xflash\_cfi.h**
- XFL\_GEOMETRY\_BLOCK\_DIFF: xflash\_geometry.h
- XFL\_GEOMETRY\_BLOCKS\_LEFT: xflash\_geometry.h
- XFL\_GEOMETRY\_INCREMENT : xflash\_geometry.h

- XFL\_GEOMETRY\_IS\_ABSOLUTE\_VALID: xflash\_geometry.h
- XFL\_GEOMETRY\_IS\_BLOCK\_VALID: xflash\_geometry.h
- XFL\_MANUFACTURER\_ID\_INTEL: xflash.h
- XFL\_MAX\_ERASE\_REGIONS : xflash\_geometry.h
- XFL\_NON\_BLOCKING\_ERASE\_OPTION: xflash.h
- XFL\_NON\_BLOCKING\_WRITE\_OPTION: xflash.h
- XFlash: xflash.h
- XFlash\_ConfigTable : **xflash\_g.c**
- XFlash\_DeviceControl(): xflash.h, xflash.c
- XFlash\_Erase(): xflash.h, xflash.c
- XFlash\_EraseBlock(): xflash.h, xflash.c
- XFlash\_EraseBlockResume(): xflash.h, xflash.c
- XFlash\_EraseBlockSuspend(): xflash.h, xflash.c
- XFlash\_EraseChip(): xflash.h, xflash.c
- XFlash\_EraseResume(): xflash.h, xflash.c
- XFlash\_EraseSuspend(): xflash.h, xflash.c
- XFlash\_GetBlockStatus(): xflash.h, xflash.c
- XFlash\_GetGeometry(): xflash.h, xflash.c
- XFlash\_GetOptions(): xflash.h, xflash.c
- XFlash\_GetProperties(): xflash.h, xflash.c
- XFlash\_GetStatus(): xflash.h, xflash.c
- XFlash\_Initialize(): xflash.h, xflash.c
- XFlash\_IsReady(): **xflash.c**
- XFlash\_Lock(): xflash.h, xflash.c
- XFlash\_LockBlock(): xflash.h, xflash.c
- XFlash\_LookupConfig(): xflash.h, xflash.c
- XFlash\_Read(): xflash.h, xflash.c
- XFlash\_ReadBlock(): xflash.h, xflash.c
- XFlash\_Reset(): xflash.h, xflash.c
- XFlash\_SelfTest(): xflash.h, xflash.c
- XFlash\_SetOptions(): xflash.h, xflash.c
- XFlash\_Unlock(): xflash.h, xflash.c
- XFlash\_UnlockBlock(): xflash.h, xflash.c
- XFlash\_Write(): xflash.h, xflash.c
- XFlash\_WriteBlock(): xflash.h, xflash.c
- XFlash\_WriteBlockResume(): xflash.h, xflash.c
- XFlash\_WriteBlockSuspend(): xflash.h, xflash.c
- XFlash\_WriteResume(): xflash.h, xflash.c

- XFlash\_WriteSuspend(): xflash.h, xflash.c
- XFlashCFI\_ReadCommon(): xflash\_cfi.h, xflash\_cfi.c
- XFlashGeometry\_ConvertLayout(): xflash\_geometry.h, xflash\_geometry.c
- XFlashGeometry\_ToAbsolute(): xflash\_geometry.h, xflash\_geometry.c
- XFlashGeometry\_ToBlock(): xflash\_geometry.h, xflash\_geometry.c
- XFlashIntel DeviceControl(): xflash intel.h, xflash intel.c
- XFlashIntel\_Erase(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel EraseAddr(): xflash intel l.h, xflash intel l.c
- XFlashIntel\_EraseBlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_EraseBlockResume(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_EraseBlockSuspend(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_EraseChip(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_EraseResume(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_EraseSuspend(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_GetBlockStatus(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_GetGeometry(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_GetOptions(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_GetProperties(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_GetStatus(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_Initialize(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_Lock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_LockAddr(): xflash\_intel\_l.h, xflash\_intel\_l.c
- XFlashIntel\_LockBlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_mSendCmd : xflash\_intel\_l.h
- XFlashIntel\_Read(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_ReadAddr(): xflash\_intel\_l.h, xflash\_intel\_l.c
- XFlashIntel\_ReadBlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_Reset(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_SelfTest(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_SetOptions(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_Unlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_UnlockAddr(): xflash\_intel\_l.h, xflash\_intel\_l.c
- XFlashIntel\_UnlockBlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_WaitReady(): xflash\_intel\_l.h, xflash\_intel\_l.c
- XFlashIntel\_Write(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_WriteAddr(): xflash\_intel\_l.h, xflash\_intel\_l.c
- XFlashIntel\_WriteBlock(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_WriteBlockResume(): xflash\_intel.h, xflash\_intel.c

- XFlashIntel\_WriteBlockSuspend(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_WriteResume(): xflash\_intel.h, xflash\_intel.c
- XFlashIntel\_WriteSuspend(): xflash\_intel.h, xflash\_intel.c
- Xfloat32 : xbasic\_types.h
- Xfloat64 : xbasic\_types.h
- XGE\_AUTO\_NEGOTIATE\_OPTION : xgemac.h
- XGE\_BROADCAST\_OPTION : xgemac.h
- XGE\_CEAH\_OFFSET: xgemac\_l.h
- XGE\_CEAL\_OFFSET : xgemac\_l.h
- XGE\_DMA\_OFFSET : xgemac\_l.h
- XGE\_DMA\_RECV\_OFFSET : xgemac\_l.h
- XGE\_DMA\_SEND\_OFFSET : xgemac\_l.h
- XGE\_ECR\_OFFSET : xgemac\_l.h
- XGE\_EMIR\_OFFSET : xgemac\_l.h
- XGE\_FDUPLEX\_OPTION : xgemac.h
- XGE\_FLOW\_CONTROL\_OPTION: xgemac.h
- XGE\_IFGP\_OFFSET : xgemac\_l.h
- XGE\_INSERT\_ADDR\_OPTION : xgemac.h
- XGE\_INSERT\_FCS\_OPTION : xgemac.h
- XGE\_INSERT\_PAD\_OPTION : xgemac.h
- XGE\_ISR\_OFFSET : xgemac\_l.h
- XGE\_JUMBO\_OPTION : xgemac.h
- XGE\_LOOPBACK\_OPTION : xgemac.h
- XGE\_MGTCR\_OFFSET : xgemac\_l.h
- XGE\_MGTDR\_OFFSET : xgemac\_l.h
- XGE\_MULTICAST\_OPTION : xgemac.h
- XGE\_OVWRT\_ADDR\_OPTION : xgemac.h
- XGE\_PFIFO\_OFFSET: xgemac\_l.h
- XGE\_PFIFO\_RXDATA\_OFFSET : xgemac\_l.h
- XGE\_PFIFO\_RXREG\_OFFSET : xgemac\_l.h
- XGE\_PFIFO\_TXDATA\_OFFSET : xgemac\_l.h
- XGE\_PFIFO\_TXREG\_OFFSET : xgemac\_l.h
- XGE\_POLLED\_OPTION : **xgemac.h**
- XGE\_PROMISC\_OPTION : xgemac.h
- XGE\_RPLR\_OFFSET: xgemac l.h
- XGE\_RSR\_OFFSET : xgemac\_l.h
- XGE\_SAH\_OFFSET : xgemac\_l.h
- XGE\_SAL\_OFFSET : xgemac\_l.h

- XGE\_STAT\_1023RXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_1023TXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_127RXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_127TXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_255RXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_255TXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_511RXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_511TXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_64RXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_64TXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_BFRXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_BFTXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_CARRIERERR\_OFFSET : xgemac\_l.h
- XGE\_STAT\_CFRXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_CFTXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_CFUNSUP\_OFFSET : xgemac\_l.h
- XGE\_STAT\_DEFERRED\_OFFSET : xgemac\_l.h
- XGE\_STAT\_EXCESSDEF\_OFFSET : xgemac\_l.h
- XGE\_STAT\_FCSERR\_OFFSET : xgemac\_l.h
- XGE\_STAT\_FRAGRX\_OFFSET : xgemac\_l.h
- XGE\_STAT\_LATECOLL\_OFFSET : xgemac\_l.h
- XGE\_STAT\_LTERROR\_OFFSET : xgemac\_l.h
- XGE\_STAT\_MAXRXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_MAXTXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_MCOLL\_OFFSET : xgemac\_l.h
- XGE\_STAT\_MCRXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_MFTXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_OFRXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_OFTXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_PFRXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_PFTXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_REG\_OFFSET : **xgemac\_l.h**
- XGE\_STAT\_RXBYTES\_OFFSET: xgemac\_l.h
- XGE\_STAT\_RXOK\_OFFSET: xgemac\_l.h
- XGE\_STAT\_SCOLL\_OFFSET : xgemac\_l.h
- XGE\_STAT\_TXABORTED\_OFFSET : xgemac\_l.h
- XGE\_STAT\_TXBYTES\_OFFSET : xgemac\_l.h
- XGE\_STAT\_TXOK\_OFFSET : xgemac\_l.h

- XGE\_STAT\_TXURUNERR\_OFFSET : xgemac\_l.h
- XGE\_STAT\_UFRX\_OFFSET: xgemac\_l.h
- XGE\_STAT\_VLANRXOK\_OFFSET : xgemac\_l.h
- XGE\_STAT\_VLANTXOK\_OFFSET : xgemac\_l.h
- XGE\_STRIP\_PAD\_FCS\_OPTION : xgemac.h
- XGE\_TPLR\_OFFSET: xgemac\_l.h
- XGE\_TPPR\_OFFSET : xgemac\_l.h
- XGE\_TSR\_OFFSET : xgemac\_l.h
- XGE\_UNICAST\_OPTION : xgemac.h
- XGE\_VLAN\_OPTION : xgemac.h
- XGemac\_ClearSoftStats(): xgemac\_stats.c, xgemac.h
- XGemac\_ConfigTable : xgemac\_i.h, xgemac\_g.c
- XGemac\_ErrorHandler : xgemac.h
- XGemac\_FifoHandler : xgemac.h
- XGemac\_FifoRecv(): xgemac\_intr\_fifo.c, xgemac.h
- XGemac\_FifoSend(): xgemac\_intr\_fifo.c, xgemac.h
- XGemac\_GetHardStats(): xgemac\_stats.c, xgemac.h
- XGemac\_GetInterframeGap(): xgemac\_control.c, xgemac.h
- XGemac\_GetMacAddress(): xgemac.h, xgemac.c
- XGemac\_GetOptions(): xgemac\_options.c, xgemac.h
- XGemac\_GetPktThreshold(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_GetPktWaitBound(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_GetSoftStats(): xgemac\_stats.c, xgemac.h
- XGemac\_Initialize(): xgemac.h, xgemac.c
- XGemac\_IntrHandlerDma(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_IntrHandlerFifo(): xgemac\_intr\_fifo.c, xgemac.h
- XGemac\_LookupConfig(): xgemac.h, xgemac.c
- XGemac\_mDisable : xgemac\_l.h
- XGemac\_mEnable : xgemac\_l.h
- XGemac\_MgtRead(): xgemac\_control.c, xgemac.h
- XGemac\_MgtWrite(): xgemac\_control.c, xgemac.h
- XGemac\_mIsDma : xgemac.h
- XGemac\_mIsRxEmpty : **xgemac\_l.h**
- XGemac\_mIsSgDma : **xgemac.h**
- XGemac\_mIsSimpleDma : xgemac.h
- XGemac\_mIsTxDone : xgemac\_l.h
- XGemac\_mPhyReset : xgemac\_l.h
- XGemac\_mReadReg : xgemac\_l.h

- XGemac\_mSetControlReg : xgemac\_l.h
- XGemac\_mSetMacAddress: xgemac\_l.h
- XGemac\_MulticastAdd(): xgemac\_multicast.c, xgemac.h
- XGemac\_MulticastClear(): xgemac\_multicast.c, xgemac.h
- XGemac\_mWriteReg : xgemac\_l.h
- XGemac\_PollRecv(): xgemac\_polled.c, xgemac.h
- XGemac\_PollSend(): xgemac\_polled.c, xgemac.h
- XGemac\_Reset(): xgemac.h, xgemac.c
- XGemac\_SelfTest(): xgemac\_selftest.c, xgemac.h
- XGemac\_SendPause(): xgemac\_control.c, xgemac.h
- XGemac\_SetErrorHandler(): xgemac\_intr.c, xgemac.h
- XGemac\_SetFifoRecvHandler(): xgemac\_intr\_fifo.c, xgemac.h
- XGemac\_SetFifoSendHandler(): xgemac\_intr\_fifo.c, xgemac.h
- XGemac\_SetInterframeGap(): xgemac\_control.c, xgemac.h
- XGemac\_SetMacAddress(): xgemac.h, xgemac.c
- XGemac\_SetOptions(): xgemac\_options.c, xgemac.h
- XGemac\_SetPktThreshold(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SetPktWaitBound(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SetSgRecvHandler(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SetSgRecvSpace(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SetSgSendHandler(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SetSgSendSpace(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SgHandler : xgemac.h
- XGemac\_SgRecv(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_SgSend(): xgemac\_intr\_dma.c, xgemac.h
- XGemac\_Start(): xgemac.h, xgemac.c
- XGemac\_Stop(): xgemac.h, xgemac.c
- XGpio\_ConfigTable : xgpio\_i.h, xgpio\_g.c
- XGPIO\_DATA\_OFFSET: xgpio\_l.h
- XGpio\_DiscreteClear(): xgpio\_extra.c, xgpio.h
- XGpio\_DiscreteRead(): xgpio.h, xgpio.c
- XGpio\_DiscreteSet(): xgpio\_extra.c, xgpio.h
- XGpio\_DiscreteWrite(): xgpio.h, xgpio.c
- XGpio\_Initialize(): xgpio.h, xgpio.c
- XGpio\_LookupConfig(): xgpio.h, xgpio.c
- XGpio\_mGetDataReg : xgpio\_l.h
- XGpio\_mReadReg : xgpio\_l.h
- XGpio\_mSetDataReg : xgpio\_l.h

- XGpio\_mWriteReg : xgpio\_l.h
- XGpio\_SelfTest(): xgpio\_selftest.c, xgpio.h
- XGpio\_SetDataDirection(): xgpio.h, xgpio.c
- XGPIO\_TRI\_OFFSET : xgpio\_l.h
- XHD\_OPTION\_CRC\_32 : xhdlc.h
- XHD\_OPTION\_CRC\_DISABLE : xhdlc.h
- XHD\_OPTION\_LOOPBACK : xhdlc.h
- XHD\_OPTION\_POLLED : xhdlc.h
- XHD\_OPTION\_RX\_16\_ADDR : xhdlc.h
- XHD\_OPTION\_RX\_BROADCAST : xhdlc.h
- XHD\_OPTION\_RX\_FILTER\_ADDR : xhdlc.h
- XHD\_OPTION\_RX\_REMOVE\_ADDR : xhdlc.h
- XHdlc\_ClearStats(): xhdlc\_stats.c, xhdlc.h
- XHdlc\_ConfigTable : xhdlc\_i.h, xhdlc\_g.c
- XHdlc\_ErrorHandler: xhdlc.h
- XHdlc\_GetAddress(): xhdlc\_options.c, xhdlc.h
- XHdlc\_GetOptions(): xhdlc\_options.c, xhdlc.h
- XHdlc\_GetStats(): xhdlc\_stats.c, xhdlc.h
- XHdlc\_Initialize(): xhdlc.h, xhdlc.c
- XHdlc\_InterruptHandler(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_LookupConfig(): xhdlc.h, xhdlc.c
- XHdlc\_mDisable : xhdlc\_l.h
- XHdlc\_mEnable : xhdlc\_l.h
- XHdlc\_mReadReg : xhdlc\_l.h
- XHdlc\_mSetAddressReg : xhdlc\_l.h
- XHdlc\_mSetRxControlReg : xhdlc\_l.h
- XHdlc\_mSetTxControlReg : xhdlc\_l.h
- XHdlc\_mWriteReg: xhdlc\_l.h
- XHdlc\_Recv(): xhdlc.h, xhdlc.c
- XHdlc\_RecvFrame(): xhdlc\_l.h, xhdlc\_l.c
- XHdlc\_Reset() : **xhdlc.h**, **xhdlc.c**
- XHdlc\_SelfTest(): xhdlc\_selftest.c, xhdlc.h
- XHdlc\_Send(): xhdlc.h, xhdlc.c
- XHdlc\_SendFrame(): xhdlc\_l.h, xhdlc\_l.c
- XHdlc\_SetAddress(): xhdlc\_options.c, xhdlc.h
- XHdlc\_SetErrorHandler(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SetOptions(): xhdlc\_options.c, xhdlc.h
- XHdlc\_SetSgRecvHandler(): xhdlc\_dmasg.c, xhdlc.h

- XHdlc\_SetSgRecvSpace(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SetSgSendHandler(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SetSgSendSpace(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SgGetRecvFrame(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SgGetSendFrame(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SgHandler: xhdlc.h
- XHdlc\_SgRecv(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_SgSend(): xhdlc\_dmasg.c, xhdlc.h
- XHdlc\_Start(): xhdlc.h, xhdlc.c
- XHdlc\_Stop(): xhdlc.h, xhdlc.c
- XII\_ADDR\_TO\_RESPOND\_TYPE : xiic.h
- XII\_ADDR\_TO\_SEND\_TYPE : xiic.h
- XII\_ARB\_LOST\_EVENT : xiic.h
- XII\_BUS\_NOT\_BUSY\_EVENT : xiic.h
- XII\_GENERAL\_CALL\_EVENT : xiic.h
- XII\_GENERAL\_CALL\_OPTION: xiic.h
- XII\_MASTER\_READ\_EVENT : xiic.h
- XII\_MASTER\_WRITE\_EVENT: xiic.h
- XII\_REPEATED\_START\_OPTION : xiic.h
- XII SEND\_10 BIT OPTION: xiic.h
- XII\_SLAVE\_NO\_ACK\_EVENT : xiic.h
- XIic\_ClearStats(): xiic\_stats.c, xiic.h
- XIic\_ConfigTable : xiic\_i.h, xiic\_g.c
- XIic\_GetAddress(): xiic.h, xiic.c
- XIic\_GetOptions(): xiic\_options.c, xiic.h
- XIic\_GetStats(): xiic\_stats.c, xiic.h
- XIic\_Handler : xiic.h
- XIic\_Initialize(): xiic.h, xiic.c
- XIic\_InterruptHandler(): xiic\_intr.c, xiic.h
- XIic\_IsSlave(): xiic.c
- XIic\_LookupConfig(): xiic.h, xiic.c
- XIic\_MasterRecv(): xiic\_master.c, xiic.h
- XIic\_MasterSend(): xiic\_master.c, xiic.h
- XIic\_MultiMasterInclude(): xiic\_multi\_master.c, xiic.h
- XIic\_Recv(): xiic\_l.h, xiic\_l.c
- XIic\_Reset(): xiic.h, xiic.c
- XIic\_SelfTest(): xiic\_selftest.c, xiic.h
- XIic\_Send(): xiic\_l.h, xiic\_l.c

- XIic\_SetAddress(): xiic.h, xiic.c
- XIic\_SetOptions(): xiic\_options.c, xiic.h
- XIic\_SetRecvHandler(): xiic.h, xiic.c
- XIic\_SetSendHandler(): xiic.h, xiic.c
- XIic\_SetStatusHandler(): xiic.h, xiic.c
- XIic\_Start(): xiic.h, xiic.c
- XIic\_StatusHandler : xiic.h
- XIic\_Stop(): xiic.h, xiic.c
- XIN\_REAL\_MODE : xintc.h
- XIN\_SIMULATION\_MODE : xintc.h
- XIN\_SVC\_ALL\_ISRS\_OPTION : xintc.h
- XIN\_SVC\_SGL\_ISR\_OPTION : xintc.h
- Xint16: xbasic\_types.h
- Xint32 : xbasic\_types.h
- Xint8 : xbasic\_types.h
- XIntc\_Acknowledge(): xintc.h, xintc.c
- XIntc\_ConfigTable : xintc\_i.h, xintc\_g.c
- XIntc\_Connect(): xintc.h, xintc.c
- XIntc\_DefaultHandler(): xintc\_l.h, xintc\_l.c
- XIntc\_Disable(): xintc.h, xintc.c
- XIntc\_Disconnect(): xintc.h, xintc.c
- XIntc\_Enable(): xintc.h, xintc.c
- XIntc\_GetOptions(): xintc\_options.c, xintc.h
- XIntc\_Initialize(): xintc.h, xintc.c
- XIntc\_InterruptHandler(): xintc\_intr.c, xintc.h
- XIntc\_LookupConfig(): xintc.h, xintc.c
- XIntc\_LowLevelInterruptHandler(): xintc\_l.h, xintc\_l.c
- XIntc\_mAckIntr : xintc\_l.h
- XIntc\_mDisableIntr : xintc\_l.h
- XIntc\_mEnableIntr : xintc\_l.h
- XIntc\_mGetIntrStatus : xintc\_l.h
- XIntc\_mMasterDisable : xintc\_l.h
- XIntc\_mMasterEnable : xintc\_l.h
- XIntc\_SelfTest(): xintc\_selftest.c, xintc.h
- XIntc\_SetOptions(): xintc\_options.c, xintc.h
- XIntc\_SimulateIntr(): xintc\_selftest.c, xintc.h
- XIntc\_Start(): xintc.h, xintc.c
- XIntc\_Stop(): xintc.h, xintc.c

- XIntc\_VoidInterruptHandler(): xintc\_intr.c, xintc.h
- XInterruptHandler: xbasic\_types.h
- XIo\_Address : xio.h
- XIo\_DcrIn(): xio\_dcr.h, xio\_dcr.c
- XIo\_DcrOut(): xio\_dcr.h, xio\_dcr.c
- XIo\_EndianSwap16(): xio.h, xio.c
- XIo\_EndianSwap16OLD(): xio.c
- XIo\_EndianSwap32(): xio.h, xio.c
- XIo\_EndianSwap32OLD(): xio.c
- XIo\_In16: xio.h, xio.c, xio.h
- XIo\_In32 : **xio.h**, **xio.c**, **xio.h**
- XIo\_In8: xio.h, xio.c, xio.h
- XIo\_InSwap16(): xio.h, xio.c
- XIo\_InSwap32(): xio.h, xio.c
- XIo\_Out16: xio.h, xio.c, xio.h
- XIo\_Out32 : xio.h, xio.c, xio.h
- XIo\_Out8 : xio.h, xio.c, xio.h
- XIo\_OutSwap16(): xio.h, xio.c
- XIo\_OutSwap32(): xio.h, xio.c
- XNULL: xbasic\_types.h
- XO2P\_NO\_ERROR : xopb2plb.h
- XO2P\_READ\_ERROR : xopb2plb.h
- XO2P\_WRITE\_ERROR : xopb2plb.h
- XOA\_DYNAMIC\_PRIORITY\_OPTION : xopbarb.h
- XOA\_PARK\_BY\_ID\_OPTION : xopbarb.h
- XOA\_PARK\_ENABLE\_OPTION : xopbarb.h
- XOpb2Plb\_ClearErrors(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_ConfigTable : xopb2plb\_i.h, xopb2plb\_g.c
- XOpb2Plb\_DisableInterrupt(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_DisableLock(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_EnableInterrupt(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_EnableLock(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_GetErrorAddress(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_GetErrorStatus(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_Initialize(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_IsError(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_LookupConfig(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_mGetBearReg : xopb2plb\_l.h

- XOpb2Plb\_mGetBesrReg : xopb2plb\_l.h
- XOpb2Plb\_mGetControlReg: xopb2plb\_l.h
- XOpb2Plb\_mSetControlReg : xopb2plb\_l.h
- XOpb2Plb\_Reset(): xopb2plb.h, xopb2plb.c
- XOpb2Plb\_SelfTest(): xopb2plb\_selftest.c, xopb2plb.h
- XOpbArb\_ConfigTable : xopbarb\_g.c
- XOpbArb\_GetOptions(): xopbarb.h, xopbarb.c
- XOpbArb\_GetParkId(): xopbarb.h, xopbarb.c
- XOpbArb\_GetPriorityLevel(): xopbarb.h, xopbarb.c
- XOpbArb\_Initialize(): xopbarb.h, xopbarb.c
- XOpbArb\_LookupConfig(): xopbarb.h, xopbarb.c
- XOpbArb\_mClearParkMasterNot : xopbarb\_l.h
- XOpbArb\_mClearPriorityRegsValid: xopbarb\_l.h
- XOpbArb\_mDisableDynamic: xopbarb\_l.h
- XOpbArb\_mDisableParking: xopbarb\_l.h
- XOpbArb\_mEnableDynamic : xopbarb\_l.h
- XOpbArb\_mEnableParking : xopbarb\_l.h
- XOpbArb\_mGetControlReg : xopbarb\_l.h
- XOpbArb\_mGetPriorityReg : xopbarb\_l.h
- XOpbArb\_mSetControlReg : xopbarb\_l.h
- XOpbArb\_mSetParkedMasterId : xopbarb\_l.h
- XOpbArb\_mSetParkMasterNot : xopbarb\_l.h
- XOpbArb\_mSetPriorityReg : xopbarb\_l.h
- XOpbArb\_mSetPriorityRegsValid : xopbarb\_l.h
- XOpbArb\_ResumePriorityLevels(): xopbarb.h, xopbarb.c
- XOpbArb\_SelfTest(): xopbarb.h, xopbarb.c
- XOpbArb\_SetOptions(): xopbarb.h, xopbarb.c
- XOpbArb\_SetParkId(): xopbarb.h, xopbarb.c
- XOpbArb\_SetPriorityLevel(): xopbarb.h, xopbarb.c
- XOpbArb\_SuspendPriorityLevels(): xopbarb.h, xopbarb.c
- XP2O\_DRIVING\_BEAR\_MASK : xplb2opb.h
- XP2O\_ERROR\_READ\_MASK : xplb2opb.h
- XP2O\_ERROR\_TYPE\_MASK : xplb2opb.h
- XP2O\_LOCK\_ERR\_MASK : xplb2opb.h
- XPci\_AckRead(): xpci\_intr.c, xpci.h
- XPci\_AckSend(): xpci\_intr.c, xpci.h
- XPCI\_BUSNO\_BUS\_MASK : xpci\_l.h
- XPCI\_BUSNO\_OFFSET : xpci\_l.h

- XPCI\_BUSNO\_SUBBUS\_MASK : xpci\_l.h
- XPCI\_CAR\_OFFSET : xpci\_l.h
- XPCI\_CDR\_OFFSET : xpci\_l.h
- XPci\_ConfigIn(): xpci.h
- XPci\_ConfigIn16(): xpci\_config.c, xpci.h
- XPci\_ConfigIn32(): xpci\_config.c, xpci.h
- XPci\_ConfigIn8(): xpci\_config.c, xpci.h
- XPci\_ConfigOut(): xpci.h
- XPci\_ConfigOut16(): xpci\_config.c, xpci.h
- XPci\_ConfigOut32(): xpci\_config.c, xpci.h
- XPci\_ConfigOut8(): xpci\_config.c, xpci.h
- XPci\_ConfigPack(): xpci.h
- XPCI\_DMA\_TYPE\_NONE : xpci\_l.h
- XPCI\_DMA\_TYPE\_SG: xpci\_l.h
- XPCI\_DMA\_TYPE\_SIMPLE : xpci\_l.h
- XPci\_ErrorClear(): xpci.h
- XPci\_ErrorGet(): xpci.h
- XPci\_GetBusNumber(): xpci.h
- XPci\_GetDmaImplementation(): xpci.h
- XPCI\_HDR\_BAR0 : xpci\_l.h
- XPCI\_HDR\_BAR1 : xpci\_l.h
- XPCI\_HDR\_BAR2 : xpci\_l.h
- XPCI\_HDR\_BAR3 : xpci\_l.h
- XPCI\_HDR\_BAR4 : xpci\_l.h
- XPCI\_HDR\_BAR5 : xpci\_l.h
- XPCI\_HDR\_BAR\_ADDR\_MASK: xpci\_l.h
- XPCI\_HDR\_BAR\_PREFETCH\_NO: xpci\_l.h
- XPCI\_HDR\_BAR\_PREFETCH\_YES: xpci\_l.h
- XPCI\_HDR\_BAR\_SPACE\_IO: xpci\_l.h
- XPCI\_HDR\_BAR\_SPACE\_MEMORY : **xpci\_l.h**
- XPCI\_HDR\_BAR\_TYPE\_ABOVE\_4GB : xpci\_l.h
- XPCI\_HDR\_BAR\_TYPE\_BELOW\_1MB : xpci\_l.h
- XPCI\_HDR\_BAR\_TYPE\_BELOW\_4GB: xpci\_l.h
- XPCI\_HDR\_BAR\_TYPE\_MASK: xpci\_l.h
- XPCI\_HDR\_BAR\_TYPE\_RESERVED : xpci\_l.h
- XPCI\_HDR\_BIST : xpci\_l.h
- XPCI\_HDR\_CACHE\_LINE\_SZ: xpci\_l.h
- XPCI\_HDR\_CAP\_PTR : xpci\_l.h

- XPCI\_HDR\_CARDBUS\_PTR : xpci\_l.h
- XPCI\_HDR\_CLASSCODE : xpci\_l.h
- XPCI\_HDR\_COMMAND : xpci\_l.h
- XPCI\_HDR\_DEVICE : xpci\_l.h
- XPCI\_HDR\_INT\_LINE : xpci\_l.h
- XPCI\_HDR\_INT\_PIN: xpci\_l.h
- XPCI\_HDR\_LATENCY: xpci\_l.h
- XPCI\_HDR\_MAX\_LAT: xpci\_l.h
- XPCI\_HDR\_MIN\_GNT: xpci\_l.h
- XPCI\_HDR\_NUM\_BAR : xpci\_l.h
- XPCI\_HDR\_REVID : xpci\_l.h
- XPCI\_HDR\_ROM\_BASE : xpci\_l.h
- XPCI\_HDR\_STATUS : xpci\_l.h
- XPCI\_HDR\_SUB\_DEVICE : xpci\_l.h
- XPCI\_HDR\_SUB\_VENDOR : xpci\_l.h
- XPCI\_HDR\_TYPE: xpci\_l.h
- XPCI\_HDR\_VENDOR : xpci\_l.h
- XPCI\_IAR\_OFFSET : xpci\_l.h
- XPCI\_INHIBIT\_LOCAL\_BUS\_R : xpci\_l.h
- XPCI\_INHIBIT\_LOCAL\_BUS\_W : xpci\_l.h
- XPCI\_INHIBIT\_MASK : xpci\_l.h
- XPCI\_INHIBIT\_OFFSET : xpci\_l.h
- XPCI\_INHIBIT\_PCI\_R : xpci\_l.h
- XPCI\_INHIBIT\_PCI\_W: xpci\_l.h
- XPci\_InhibitAfterError(): xpci.h
- XPci\_Initialize(): xpci.h
- XPci\_InterruptClear(): xpci\_intr.c, xpci.h
- XPci\_InterruptDisable(): xpci\_intr.c, xpci.h
- XPci\_InterruptEnable(): xpci\_intr.c, xpci.h
- XPci\_InterruptGetEnabled(): xpci\_intr.c, xpci.h
- XPci\_InterruptGetHighestPending(): xpci\_intr.c, xpci.h
- XPci\_InterruptGetPending(): xpci\_intr.c, xpci.h
- XPci\_InterruptGetStatus(): xpci\_intr.c, xpci.h
- XPci\_InterruptGlobalDisable(): xpci\_intr.c, xpci.h
- XPci\_InterruptGlobalEnable(): xpci\_intr.c, xpci.h
- XPci\_InterruptPciClear(): xpci\_intr.c, xpci.h
- XPci\_InterruptPciDisable(): xpci\_intr.c, xpci.h
- XPci\_InterruptPciEnable(): xpci\_intr.c, xpci.h

- XPci\_InterruptPciGetEnabled(): xpci\_intr.c, xpci.h
- XPci\_InterruptPciGetStatus(): xpci\_intr.c, xpci.h
- XPCI\_IR\_LM\_BR\_W: xpci\_l.h
- XPCI\_IR\_LM\_BRANGE\_W: xpci\_l.h
- XPCI\_IR\_LM\_BRD\_W: xpci\_l.h
- XPCI\_IR\_LM\_BRT\_W: xpci\_l.h
- XPCI\_IR\_LM\_MA\_W : xpci\_l.h
- XPCI\_IR\_LM\_PERR\_R: xpci\_l.h
- XPCI\_IR\_LM\_PERR\_W: xpci\_l.h
- XPCI\_IR\_LM\_SERR\_R : xpci\_l.h
- XPCI\_IR\_LM\_SERR\_W: xpci\_l.h
- XPCI\_IR\_LM\_TA\_R : xpci\_l.h
- XPCI\_IR\_LM\_TA\_W : xpci\_l.h
- XPCI\_IR\_MASK: xpci\_l.h
- XPCI\_IR\_PI\_SERR\_R : xpci\_l.h
- XPCI\_IR\_PI\_SERR\_W: xpci\_l.h
- XPCI\_LMA\_R\_OFFSET : xpci\_l.h
- XPCI\_LMA\_W\_OFFSET: xpci\_l.h
- XPCI\_LMADDR\_BR\_W: xpci\_l.h
- XPCI\_LMADDR\_BRANGE\_W : xpci\_l.h
- XPCI\_LMADDR\_BRD\_W : xpci\_l.h
- XPCI\_LMADDR\_BRT\_W : xpci\_l.h
- XPCI\_LMADDR\_MA\_W : xpci\_l.h
- XPCI\_LMADDR\_MASK : xpci\_l.h
- XPCI\_LMADDR\_OFFSET : xpci\_l.h
- XPCI\_LMADDR\_PERR\_R : xpci\_l.h
- XPCI\_LMADDR\_PERR\_W: xpci\_l.h
- XPCI\_LMADDR\_SERR\_R: xpci\_l.h
- XPCI\_LMADDR\_SERR\_W: xpci\_l.h
- XPCI\_LMADDR\_TA\_R : xpci\_l.h
- XPCI\_LMADDR\_TA\_W : **xpci\_l.h**
- XPci\_LookupConfig(): xpci.h
- XPci\_mAckRead : xpci\_l.h
- XPci\_mAckSend : xpci\_l.h
- XPci\_mConfigIn: xpci\_l.h
- XPci\_mConfigOut : **xpci\_l.h**
- XPci\_mIntrClear : xpci\_l.h
- XPci\_mIntrDisable : xpci\_l.h

- XPci\_mIntrEnable : xpci\_l.h
- XPci\_mIntrGlobalDisable : xpci\_l.h
- XPci\_mIntrGlobalEnable : xpci\_l.h
- XPci\_mIntrPciClear: xpci\_l.h
- XPci\_mIntrPciDisable : xpci\_l.h
- XPci\_mIntrPciEnable : xpci\_l.h
- XPci\_mIntrPciReadIER: xpci\_l.h
- XPci\_mIntrPciReadISR : xpci\_l.h
- XPci\_mIntrPciWriteISR : xpci\_l.h
- XPci\_mIntrReadID : xpci\_l.h
- XPci\_mIntrReadIER : xpci\_l.h
- XPci\_mIntrReadIPR : xpci\_l.h
- XPci\_mIntrReadISR : xpci\_l.h
- XPci\_mIntrWriteISR : xpci\_l.h
- XPci\_mLocal2Pci : xpci\_l.h
- XPci\_mPci2Local : xpci\_l.h
- XPci\_mReadReg : xpci\_l.h
- XPci\_mReset : xpci\_l.h
- XPci\_mSpecialCycle : xpci\_l.h
- XPci\_mWriteReg : xpci\_l.h
- XPCI\_PIA\_R\_OFFSET : xpci\_l.h
- XPCI\_PIA\_W\_OFFSET : xpci\_l.h
- XPCI\_PIADDR\_ERRACK\_R : xpci\_l.h
- XPCI\_PIADDR\_ERRACK\_W: xpci\_l.h
- XPCI\_PIADDR\_MASK : xpci\_l.h
- XPCI\_PIADDR\_OFFSET : xpci\_l.h
- XPCI\_PIADDR\_RANGE\_W: xpci\_l.h
- XPCI\_PIADDR\_RETRY\_W: xpci\_l.h
- XPCI\_PIADDR\_TIMEOUT\_W: xpci\_l.h
- XPCI\_PREOVRD\_OFFSET : xpci\_l.h
- XPci\_Reset() : **xpci.h**
- XPCI\_SC\_DATA\_OFFSET : xpci\_l.h
- XPci\_SelfTest(): xpci\_selftest.c, xpci.h
- XPCI\_SERR\_R\_OFFSET : xpci\_l.h
- XPCI\_SERR\_W\_OFFSET : xpci\_l.h
- XPci\_SetBusNumber(): xpci.h
- XPci\_SpecialCycle(): xpci\_intr.c, xpci.h
- XPCI\_STATCMD\_66MHZ\_CAP: xpci\_l.h

- XPCI\_STATCMD\_BACK\_EN: xpci\_l.h
- XPCI\_STATCMD\_BUSM\_EN: xpci\_l.h
- XPCI\_STATCMD\_DEVSEL\_FAST: xpci\_l.h
- XPCI\_STATCMD\_DEVSEL\_MED: xpci\_l.h
- XPCI\_STATCMD\_DEVSEL\_MSK : xpci\_l.h
- XPCI\_STATCMD\_ERR\_MASK : xpci\_l.h
- XPCI\_STATCMD\_INT\_DISABLE : xpci\_l.h
- XPCI\_STATCMD\_INT\_STATUS : xpci\_l.h
- XPCI\_STATCMD\_IO\_EN: xpci\_l.h
- XPCI\_STATCMD\_MEM\_EN: xpci\_l.h
- XPCI\_STATCMD\_MEMWR\_INV\_EN: xpci\_l.h
- XPCI\_STATCMD\_MPERR : xpci\_l.h
- XPCI\_STATCMD\_MSTABRT\_RCV : xpci\_l.h
- XPCI\_STATCMD\_OFFSET: xpci\_l.h
- XPCI\_STATCMD\_PARITY: xpci\_l.h
- XPCI\_STATCMD\_PERR\_DET: xpci\_l.h
- XPCI\_STATCMD\_SERR\_EN: xpci\_l.h
- XPCI\_STATCMD\_SERR\_SIG: xpci\_l.h
- XPCI\_STATCMD\_SPECIALCYC: xpci\_l.h
- XPCI\_STATCMD\_STEPPING : xpci\_l.h
- XPCI\_STATCMD\_TGTABRT\_RCV : xpci\_l.h
- XPCI\_STATCMD\_TGTABRT\_SIG : xpci\_l.h
- XPCI\_STATCMD\_VGA\_SNOOP\_EN: xpci\_l.h
- XPCI\_STATV3\_DATA\_XFER : xpci\_l.h
- XPCI\_STATV3\_DISC\_WDATA : xpci\_l.h
- XPCI\_STATV3\_DISC\_WODATA : xpci\_l.h
- XPCI\_STATV3\_MASK: xpci\_l.h
- XPCI\_STATV3\_MASTER\_ABRT: xpci\_l.h
- XPCI\_STATV3\_NORM\_TERM : xpci\_l.h
- XPCI\_STATV3\_OFFSET: xpci\_l.h
- XPCI\_STATV3\_PCI\_RETRY\_R : xpci\_l.h
- XPCI\_STATV3\_PCI\_RETRY\_W : xpci\_l.h
- XPCI\_STATV3\_TGT\_ABRT: xpci\_l.h
- XPCI\_STATV3\_TGT\_TERM : xpci\_l.h
- XPCI\_STATV3\_TRANS\_END: xpci\_l.h
- XPCI\_STATV3\_WRITE\_BUSY : xpci\_l.h
- XPci\_V3StatusCommandGet(): xpci\_v3.c, xpci.h
- XPci\_V3TransactionStatusClear(): xpci\_v3.c, xpci.h

- XPci\_V3TransactionStatusGet(): xpci\_v3.c, xpci.h
- XPlb2Opb\_ClearErrors(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_ConfigTable : xplb2opb\_i.h, xplb2opb\_g.c
- XPlb2Opb\_DisableInterrupt(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_EnableInterrupt(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_GetErrorAddress(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_GetErrorByteEnables(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_GetErrorStatus(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_GetMasterDrivingError(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_GetNumMasters(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_Initialize(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_IsError(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_LookupConfig(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_mGetByteEnableReg: xplb2opb\_l.h
- XPlb2Opb\_mGetControlReg: xplb2opb\_l.h
- XPlb2Opb\_mGetErrorAddressReg: xplb2opb\_l.h
- XPlb2Opb\_mGetErrorDetectReg : xplb2opb\_l.h
- XPlb2Opb\_mGetErrorTypeReg : xplb2opb\_l.h
- XPlb2Opb\_mGetLockBitReg: xplb2opb\_l.h
- XPlb2Opb\_mGetMasterDrivingReg : xplb2opb\_l.h
- XPlb2Opb\_mGetReadWriteReg : xplb2opb\_l.h
- XPlb2Opb\_mSetControlReg : xplb2opb\_l.h
- XPlb2Opb\_mSetErrorDetectReg : xplb2opb\_l.h
- XPlb2Opb\_Reset(): xplb2opb.h, xplb2opb.c
- XPlb2Opb\_SelfTest(): xplb2opb\_selftest.c, xplb2opb.h
- XPlbArb\_ClearErrors(): xplbarb.h, xplbarb.c
- XPlbArb\_ConfigTable : **xplbarb\_i.h**, **xplbarb\_g.c**
- XPlbArb\_DisableInterrupt(): xplbarb.h, xplbarb.c
- XPlbArb\_EnableInterrupt(): xplbarb.h, xplbarb.c
- XPlbArb\_GetErrorAddress(): xplbarb.h, xplbarb.c
- XPlbArb\_GetErrorStatus(): xplbarb.h, xplbarb.c
- XPlbArb\_GetNumMasters(): xplbarb.h, xplbarb.c
- XPlbArb\_Initialize(): xplbarb.h, xplbarb.c
- XPlbArb\_IsError(): xplbarb.h, xplbarb.c
- XPlbArb\_LookupConfig(): xplbarb.h, xplbarb.c
- XPlbArb\_mDisableInterrupt : xplbarb\_l.h
- XPlbArb\_mEnableInterrupt : xplbarb\_l.h
- XPlbArb\_mGetControlReg : xplbarb\_l.h

- XPlbArb\_mGetPearAddrReg : xplbarb\_l.h
- XPlbArb\_mGetPearByteEnReg: xplbarb\_l.h
- XPlbArb\_mGetPesrLockReg: xplbarb\_l.h
- XPlbArb\_mGetPesrMDriveReg : xplbarb\_l.h
- XPlbArb\_mGetPesrMerrReg : xplbarb\_l.h
- XPlbArb\_mGetPesrRnwReg : xplbarb\_l.h
- XPlbArb\_mReset : xplbarb\_l.h
- XPlbArb\_mSetPesrMerrReg : xplbarb\_l.h
- XPlbArb\_Reset(): xplbarb.h, xplbarb.c
- XPlbArb\_SelfTest(): xplbarb\_selftest.c, xplbarb.h
- XRapidIo\_mGetLinkStatus: xrapidio\_l.h
- XRapidIo\_mReadReg: xrapidio\_l.h
- XRapidIo\_mReset: xrapidio\_l.h
- XRapidIo\_mWriteReg: xrapidio\_l.h
- XRapidIo\_RecvPkt(): xrapidio\_l.h, xrapidio\_l.c
- XRapidIo\_SendPkt(): xrapidio\_l.h, xrapidio\_l.c
- XSA\_BMR\_16BIT\_MASK : xsysace\_l.h
- XSA\_BMR\_OFFSET: xsysace\_l.h
- XSA\_CF\_SECTOR\_SIZE : xsysace\_l.h
- XSA\_CLR\_LBA\_MASK : xsysace\_l.h
- XSA\_CLR\_OFFSET : xsysace\_l.h
- XSA\_CR\_CFGADDR\_MASK : xsysace\_l.h
- XSA\_CR\_CFGADDR\_SHIFT : xsysace\_l.h
- XSA\_CR\_CFGDONEIRQ\_MASK : xsysace\_l.h
- XSA\_CR\_CFGMODE\_MASK : xsysace\_l.h
- XSA\_CR\_CFGPROG\_MASK : xsysace\_l.h
- XSA\_CR\_CFGRESET\_MASK: xsysace\_l.h
- XSA\_CR\_CFGSEL\_MASK: xsysace\_l.h
- XSA\_CR\_CFGSTART\_MASK: xsysace\_l.h
- XSA\_CR\_DATARDYIRQ\_MASK : xsysace\_l.h
- XSA\_CR\_ERRORIRQ\_MASK : xsysace\_l.h
- XSA\_CR\_FORCECFGADDR\_MASK: xsysace\_l.h
- XSA\_CR\_FORCECFGMODE\_MASK: xsysace\_l.h
- XSA\_CR\_FORCELOCK\_MASK : xsysace\_l.h
- XSA\_CR\_LOCKREQ\_MASK : xsysace\_l.h
- XSA\_CR\_OFFSET : xsysace\_l.h
- XSA\_CR\_RESETIRQ\_MASK: xsysace\_l.h
- XSA\_DATA\_BUFFER\_SIZE : xsysace\_l.h

- XSA\_DBR\_OFFSET : xsysace\_l.h
- XSA\_ER\_ABORT : xsysace\_l.h
- XSA\_ER\_BAD\_BLOCK: xsysace\_l.h
- XSA\_ER\_CARD\_READ : xsysace\_l.h
- XSA\_ER\_CARD\_READY : xsysace\_l.h
- XSA\_ER\_CARD\_RESET : xsysace\_l.h
- XSA\_ER\_CARD\_WRITE : xsysace\_l.h
- XSA\_ER\_CFG\_ADDR : xsysace\_l.h
- XSA\_ER\_CFG\_FAIL : xsysace\_l.h
- XSA\_ER\_CFG\_INIT : xsysace\_l.h
- XSA\_ER\_CFG\_INSTR : xsysace\_l.h
- XSA\_ER\_CFG\_READ : xsysace\_l.h
- XSA\_ER\_GENERAL : xsysace\_l.h
- XSA\_ER\_OFFSET: xsysace\_l.h
- XSA\_ER\_RESERVED : xsysace\_l.h
- XSA\_ER\_SECTOR\_ID: xsysace\_l.h
- XSA\_ER\_SECTOR\_READY : xsysace\_l.h
- XSA\_ER\_UNCORRECTABLE : xsysace\_l.h
- XSA\_EVENT\_CFG\_DONE : xsysace.h
- XSA\_EVENT\_DATA\_DONE : xsysace.h
- XSA\_EVENT\_ERROR : xsysace.h
- XSA\_FAT\_12\_BOOT\_REC : xsysace\_l.h
- XSA\_FAT\_12\_CALC : xsysace\_l.h
- XSA\_FAT\_12\_PART\_REC : xsysace\_l.h
- XSA\_FAT\_16\_BOOT\_REC: xsysace\_l.h
- XSA\_FAT\_16\_CALC : xsysace\_l.h
- XSA\_FAT\_16\_PART\_REC: xsysace\_l.h
- XSA\_FAT\_VALID\_BOOT\_REC: xsysace\_l.h
- XSA\_FAT\_VALID\_PART\_REC : xsysace\_l.h
- XSA\_FSR\_OFFSET : xsysace\_l.h
- XSA\_MLR\_LBA\_MASK : xsysace\_l.h
- XSA\_MLR\_OFFSET : xsysace\_l.h
- XSA\_SCCR\_ABORT\_MASK : xsysace\_l.h
- XSA\_SCCR\_CMD\_MASK : xsysace\_l.h
- XSA\_SCCR\_COUNT\_MASK : xsysace\_l.h
- XSA\_SCCR\_IDENTIFY\_MASK : xsysace\_l.h
- XSA\_SCCR\_OFFSET : xsysace\_l.h
- XSA\_SCCR\_READDATA\_MASK : xsysace\_l.h

- XSA\_SCCR\_RESET\_MASK: xsysace\_l.h
- XSA\_SCCR\_WRITEDATA\_MASK: xsysace\_l.h
- XSA\_SR\_CFBSY\_MASK : xsysace\_l.h
- XSA\_SR\_CFCERROR\_MASK : xsysace\_l.h
- XSA\_SR\_CFCORR\_MASK: xsysace\_l.h
- XSA\_SR\_CFDETECT\_MASK : xsysace\_l.h
- XSA\_SR\_CFDRQ\_MASK: xsysace\_l.h
- XSA\_SR\_CFDSC\_MASK : xsysace\_l.h
- XSA\_SR\_CFDWF\_MASK: xsysace\_l.h
- XSA\_SR\_CFERR\_MASK: xsysace\_l.h
- XSA\_SR\_CFGADDR\_MASK: xsysace\_l.h
- XSA\_SR\_CFGDONE\_MASK: xsysace\_l.h
- XSA\_SR\_CFGERROR\_MASK: xsysace\_l.h
- XSA\_SR\_CFGLOCK\_MASK: xsysace\_l.h
- XSA\_SR\_CFGMODE\_MASK: xsysace\_l.h
- XSA\_SR\_CFRDY\_MASK: xsysace\_l.h
- XSA\_SR\_DATABUFMODE\_MASK : xsysace\_l.h
- XSA\_SR\_DATABUFRDY\_MASK: xsysace\_l.h
- XSA\_SR\_MPULOCK\_MASK: xsysace\_l.h
- XSA\_SR\_OFFSET : xsysace\_l.h
- XSA\_SR\_RDYFORCMD\_MASK : xsysace\_l.h
- XSA\_VR\_OFFSET : xsysace\_l.h
- XSP\_CLK\_ACTIVE\_LOW\_OPTION : xspi.h
- XSP\_CLK\_PHASE\_1\_OPTION : xspi.h
- XSP\_LOOPBACK\_OPTION : xspi.h
- XSP\_MANUAL\_SSELECT\_OPTION: xspi.h
- XSP\_MASTER\_OPTION: xspi.h
- XSpi\_Abort(): xspi\_i.h, xspi.c
- XSpi\_ClearStats(): xspi\_stats.c, xspi.h
- XSpi\_ConfigTable : xspi\_i.h, xspi\_g.c
- XSpi\_GetOptions(): xspi\_options.c, xspi.h
- XSpi\_GetSlaveSelect(): xspi.h, xspi.c
- XSpi\_GetStats(): xspi\_stats.c, xspi.h
- XSpi\_Initialize(): xspi.h, xspi.c
- XSpi\_InterruptHandler(): xspi.h, xspi.c
- XSpi\_LookupConfig(): xspi.h, xspi.c
- XSpi\_mDisable : xspi\_l.h
- XSpi\_mEnable : xspi\_l.h

- XSpi\_mGetControlReg : xspi\_l.h
- XSpi\_mGetSlaveSelectReg : xspi\_l.h
- XSpi\_mGetStatusReg : xspi\_l.h
- XSpi\_mRecvByte : xspi\_l.h
- XSpi\_mSendByte : xspi\_l.h
- XSpi\_mSetControlReg: xspi\_l.h
- XSpi\_mSetSlaveSelectReg : xspi\_l.h
- XSpi\_Reset(): xspi.h, xspi.c
- XSpi\_SelfTest(): xspi\_selftest.c, xspi.h
- XSpi\_SetOptions(): xspi\_options.c, xspi.h
- XSpi\_SetSlaveSelect(): xspi.h, xspi.c
- XSpi\_SetStatusHandler(): xspi.h, xspi.c
- XSpi\_Start(): xspi.h, xspi.c
- XSpi\_StatusHandler: xspi.h
- XSpi\_Stop(): xspi.h, xspi.c
- XSpi\_Transfer(): xspi.h, xspi.c
- XStatus: xstatus.h
- XSysAce\_AbortCF(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_ConfigTable : xsysace\_g.c
- XSysAce\_DisableInterrupt(): xsysace\_intr.c, xsysace.h
- XSysAce\_EnableInterrupt(): xsysace\_intr.c, xsysace.h
- XSysAce\_EventHandler : xsysace.h
- XSysAce\_GetCfgSector(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_GetErrors(): xsysace.h, xsysace.c
- XSysAce\_GetFatStatus(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_GetVersion(): xsysace\_selftest.c, xsysace.h
- XSysAce\_IdentifyCF(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_Initialize(): xsysace.h, xsysace.c
- XSysAce\_InterruptHandler(): xsysace\_intr.c, xsysace.h
- XSysAce\_IsCfgDone(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_IsCFReady(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_Lock(): xsysace.h, xsysace.c
- XSysAce\_LookupConfig(): xsysace.h, xsysace.c
- XSysAce\_mAndControlReg : xsysace\_l.h
- XSysAce\_mDisableIntr : xsysace\_l.h
- XSysAce\_mEnableIntr : xsysace\_l.h
- XSysAce\_mGetControlReg : xsysace\_l.h
- XSysAce\_mGetErrorReg : xsysace\_l.h

- XSysAce\_mGetStatusReg : xsysace\_l.h
- XSysAce\_mIsCfgDone : xsysace\_l.h
- XSysAce\_mIsIntrEnabled : xsysace\_l.h
- XSysAce\_mIsMpuLocked: xsysace\_l.h
- XSysAce\_mIsReadyForCmd : xsysace\_l.h
- XSysAce\_mOrControlReg : xsysace\_l.h
- XSysAce\_mSetCfgAddr: xsysace\_l.h
- XSysAce\_mSetControlReg : xsysace\_l.h
- XSysAce\_mWaitForLock : xsysace\_l.h
- XSysAce\_ProgramChain(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_ReadDataBuffer(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_ReadSector(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_RegRead16(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_RegRead32(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_RegWrite16(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_RegWrite32(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_ResetCF(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_ResetCfg(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_SectorRead(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_SectorWrite(): xsysace\_compactflash.c, xsysace.h
- XSysAce\_SelfTest(): xsysace\_selftest.c, xsysace.h
- XSysAce\_SetCfgAddr(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_SetEventHandler(): xsysace\_intr.c, xsysace.h
- XSysAce\_SetStartMode(): xsysace\_jtagcfg.c, xsysace.h
- XSysAce\_Unlock(): xsysace.h, xsysace.c
- XSysAce\_WriteDataBuffer(): xsysace\_l.h, xsysace\_l.c
- XSysAce\_WriteSector(): xsysace\_l.h, xsysace\_l.c
- XTC\_AUTO\_RELOAD\_OPTION: xtmrctr.h
- XTC\_CAPTURE\_MODE\_OPTION: xtmrctr.h
- XTC\_DEVICE\_TIMER\_COUNT : xtmrctr\_l.h
- XTC\_DOWN\_COUNT\_OPTION : xtmrctr.h
- XTC\_ENABLE\_ALL\_OPTION : xtmrctr.h
- XTC\_EXT\_COMPARE\_OPTION : xtmrctr.h
- XTC\_INT\_MODE\_OPTION : xtmrctr.h
- XTimerCtr\_mReadReg : xtmrctr\_l.h
- XTmrCtr\_ClearStats(): xtmrctr\_stats.c, xtmrctr.h
- XTmrCtr\_ConfigTable : xtmrctr\_i.h, xtmrctr\_g.c
- XTmrCtr\_GetCaptureValue(): xtmrctr.h, xtmrctr.c

- XTmrCtr\_GetOptions(): xtmrctr\_options.c, xtmrctr.h
- XTmrCtr\_GetStats(): xtmrctr\_stats.c, xtmrctr.h
- XTmrCtr\_GetValue(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_Handler : xtmrctr.h
- XTmrCtr\_Initialize(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_InterruptHandler(): xtmrctr\_intr.c, xtmrctr.h
- XTmrCtr\_IsExpired(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_mDisable : xtmrctr\_l.h
- XTmrCtr\_mDisableIntr : xtmrctr\_l.h
- XTmrCtr\_mEnable : xtmrctr\_l.h
- XTmrCtr\_mEnableIntr: xtmrctr\_l.h
- XTmrCtr\_mGetControlStatusReg : xtmrctr\_l.h
- XTmrCtr\_mGetLoadReg : xtmrctr\_l.h
- XTmrCtr\_mGetTimerCounterReg : xtmrctr\_l.h
- XTmrCtr\_mHasEventOccurred: xtmrctr\_l.h
- XTmrCtr\_mLoadTimerCounterReg : xtmrctr\_l.h
- XTmrCtr\_mSetControlStatusReg : xtmrctr\_l.h
- XTmrCtr\_mSetLoadReg : xtmrctr\_l.h
- XTmrCtr\_mWriteReg : xtmrctr\_l.h
- XTmrCtr\_Reset(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_SelfTest(): xtmrctr\_selftest.c, xtmrctr.h
- XTmrCtr\_SetHandler(): xtmrctr\_intr.c, xtmrctr.h
- XTmrCtr\_SetOptions(): xtmrctr\_options.c, xtmrctr.h
- XTmrCtr\_SetResetValue(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_Start(): xtmrctr.h, xtmrctr.c
- XTmrCtr\_Stop(): **xtmrctr.h**, **xtmrctr.c**
- XTRUE: xbasic\_types.h
- XUartLite\_ClearStats(): xuartlite\_stats.c, xuartlite.h
- XUartLite\_ConfigTable : xuartlite\_i.h, xuartlite\_g.c
- XUartLite\_DisableInterrupt(): xuartlite\_intr.c, xuartlite.h
- XUartLite\_EnableInterrupt(): xuartlite\_intr.c, xuartlite.h
- XUartLite\_GetStats(): xuartlite\_stats.c, xuartlite.h
- XUartLite\_Handler: xuartlite.h
- XUartLite\_Initialize(): xuartlite.h, xuartlite.c
- XUartLite\_InterruptHandler(): xuartlite\_intr.c, xuartlite.h
- XUartLite\_IsSending(): xuartlite.h, xuartlite.c
- XUartLite\_mDisableIntr : xuartlite\_l.h
- XUartLite\_mEnableIntr : xuartlite\_l.h

- XUartLite\_mGetStatusReg : xuartlite\_l.h
- XUartLite\_mIsIntrEnabled: xuartlite\_l.h
- XUartLite\_mIsReceiveEmpty: xuartlite\_l.h
- XUartLite\_mIsTransmitFull : xuartlite\_l.h
- XUartLite\_mSetControlReg : xuartlite\_l.h
- XUartLite\_ReceiveBuffer(): xuartlite\_i.h, xuartlite.c
- XUartLite\_Recv(): xuartlite.h, xuartlite.c
- XUartLite\_RecvByte(): xuartlite\_l.h, xuartlite\_l.c
- XUartLite\_ResetFifos(): xuartlite.h, xuartlite.c
- XUartLite\_SelfTest(): xuartlite\_selftest.c, xuartlite.h
- XUartLite\_Send(): xuartlite.h, xuartlite.c
- XUartLite\_SendBuffer(): xuartlite\_i.h, xuartlite.c
- XUartLite\_SendByte(): xuartlite\_l.h, xuartlite\_l.c
- XUartLite\_SetRecvHandler(): xuartlite\_intr.c, xuartlite.h
- XUartLite\_SetSendHandler(): xuartlite\_intr.c, xuartlite.h
- XUartNs550\_ClearStats(): xuartns550\_stats.c, xuartns550.h
- XUartNs550 ConfigTable: xuartns550 i.h, xuartns550 g.c
- XUartNs550 GetDataFormat(): xuartns550 format.c, xuartns550.h
- XUartNs550\_GetFifoThreshold(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_GetLastErrors(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_GetModemStatus(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_GetOptions(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_GetStats(): xuartns550\_stats.c, xuartns550.h
- XUartNs550\_Handler : xuartns550.h
- XUartNs550\_Initialize(): xuartns550.h, xuartns550.c
- XUartNs550\_InterruptHandler(): xuartns550\_intr.c, xuartns550.h
- XUartNs550\_IsSending(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_LookupConfig(): xuartns550.h, xuartns550.c
- XUartNs550\_mDisableIntr: xuartns550\_l.h
- XUartNs550\_mEnableIntr: xuartns550\_l.h
- XUartNs550\_mGetLineControlReg : xuartns550\_l.h
- XUartNs550\_mGetLineStatusReg : xuartns550\_l.h
- XUartNs550\_mIsReceiveData: xuartns550\_l.h
- XUartNs550\_mIsTransmitEmpty : xuartns550\_l.h
- XUartNs550\_mReadReg : xuartns550\_l.h
- XUartNs550\_mSetLineControlReg : xuartns550\_l.h
- XUartNs550\_mWriteReg : xuartns550\_l.h
- XUartNs550\_ReceiveBuffer(): xuartns550\_i.h, xuartns550.c

- XUartNs550\_Recv(): xuartns550.h, xuartns550.c
- XUartNs550\_RecvByte(): xuartns550\_l.h, xuartns550\_l.c
- XUartNs550\_SelfTest(): xuartns550\_selftest.c, xuartns550.h
- XUartNs550\_Send(): xuartns550.h, xuartns550.c
- XUartNs550\_SendBuffer(): xuartns550\_i.h, xuartns550.c
- XUartNs550\_SendByte(): xuartns550\_l.h, xuartns550\_l.c
- XUartNs550\_SetDataFormat(): xuartns550\_format.c, xuartns550.h
- XUartNs550\_SetFifoThreshold(): xuartns550\_options.c, xuartns550.h
- XUartNs550\_SetHandler(): xuartns550\_intr.c, xuartns550.h
- XUartNs550\_SetOptions(): xuartns550\_options.c, xuartns550.h
- Xuint16 : xbasic\_types.h
- Xuint32 : xbasic\_types.h
- XUINT64\_LSW: xbasic\_types.h
- XUINT64\_MSW: xbasic\_types.h
- Xuint8 : xbasic\_types.h
- XUN\_ERROR\_BREAK\_MASK: xuartns550.h
- XUN\_ERROR\_FRAMING\_MASK : xuartns550.h
- XUN\_ERROR\_NONE : xuartns550.h
- XUN\_ERROR\_OVERRUN\_MASK: xuartns550.h
- XUN\_ERROR\_PARITY\_MASK : xuartns550.h
- XUN\_EVENT\_MODEM : xuartns550.h
- XUN\_EVENT\_RECV\_DATA : xuartns550.h
- XUN\_EVENT\_RECV\_ERROR: xuartns550.h
- XUN\_EVENT\_RECV\_TIMEOUT : xuartns550.h
- XUN\_EVENT\_SENT\_DATA: xuartns550.h
- XUN\_FORMAT\_1\_STOP\_BIT: xuartns550.h
- XUN\_FORMAT\_2\_STOP\_BIT: xuartns550.h
- XUN\_FORMAT\_5\_BITS: xuartns550.h
- XUN\_FORMAT\_6\_BITS: xuartns550.h
- XUN\_FORMAT\_7\_BITS: xuartns550.h
- XUN\_FORMAT\_8\_BITS: xuartns550.h
- XUN\_FORMAT\_EVEN\_PARITY: xuartns550.h
- XUN\_FORMAT\_NO\_PARITY : xuartns550.h
- XUN\_FORMAT\_ODD\_PARITY: xuartns550.h
- XUN\_MODEM\_CTS\_DELTA\_MASK: xuartns550.h
- XUN\_MODEM\_CTS\_MASK: xuartns550.h
- XUN\_MODEM\_DCD\_DELTA\_MASK: xuartns550.h
- XUN\_MODEM\_DCD\_MASK: xuartns550.h

- XUN\_MODEM\_DSR\_DELTA\_MASK: xuartns550.h
- XUN\_MODEM\_DSR\_MASK: xuartns550.h
- XUN\_MODEM\_RING\_STOP\_MASK: xuartns550.h
- XUN\_MODEM\_RINGING\_MASK: xuartns550.h
- XUN\_OPTION\_ASSERT\_DTR : xuartns550.h
- XUN\_OPTION\_ASSERT\_OUT1 : xuartns550.h
- XUN\_OPTION\_ASSERT\_OUT2: xuartns550.h
- XUN\_OPTION\_ASSERT\_RTS: xuartns550.h
- XUN\_OPTION\_DATA\_INTR : xuartns550.h
- XUN\_OPTION\_FIFOS\_ENABLE : xuartns550.h
- XUN\_OPTION\_LOOPBACK: xuartns550.h
- XUN\_OPTION\_MODEM\_INTR: xuartns550.h
- XUN\_OPTION\_RESET\_RX\_FIFO: xuartns550.h
- XUN\_OPTION\_RESET\_TX\_FIFO: xuartns550.h
- XUN\_OPTION\_SET\_BREAK: xuartns550.h
- XUT ALLMEMTESTS: xutil.h
- XUT\_FIXEDPATTERN : xutil.h
- XUT INCREMENT: xutil.h
- XUT\_INVERSEADDR : xutil.h
- XUT\_MAXTEST : xutil.h
- XUT\_WALKONES : xutil.h
- XUT\_WALKZEROS : xutil.h
- XUtil\_MemoryTest16(): xutil\_memtest.c, xutil.h
- XUtil\_MemoryTest32(): xutil\_memtest.c, xutil.h
- XUtil\_MemoryTest8(): xutil\_memtest.c, xutil.h
- XWaitInAssert : xbasic\_types.c
- XWdtTb\_ConfigTable : xwdttb\_i.h, xwdttb\_g.c
- XWdtTb\_GetTbValue(): xwdttb.h, xwdttb.c
- XWdtTb\_Initialize(): xwdttb.h, xwdttb.c
- XWdtTb\_IsWdtExpired(): xwdttb.h, xwdttb.c
- XWdtTb\_mDisableWdt : xwdttb\_l.h
- XWdtTb\_mEnableWdt : xwdttb\_l.h
- XWdtTb\_mGetTimebaseReg: xwdttb\_l.h
- XWdtTb\_mHasExpired: xwdttb\_l.h
- XWdtTb mHasReset: xwdttb l.h
- XWdtTb\_mRestartWdt : xwdttb\_l.h
- XWdtTb\_RestartWdt(): xwdttb.h, xwdttb.c
- XWdtTb\_SelfTest(): xwdttb\_selftest.c, xwdttb.h

XWdtTb\_Start(): xwdttb.h, xwdttb.cXWdtTb\_Stop(): xwdttb.h, xwdttb.c

Generated on 30 Sep 2003 for Xilinx Device Drivers

# hdlc/v1\_00\_a/src/xhdlc\_selftest.c File Reference

## **Detailed Description**

Self-test and diagnostic functions of the **XHdlc** driver.

MODIFICATION HISTORY:

## **Defines**

#define LOOPBACK\_BYTE\_COUNT

## **Functions**

XStatus XHdlc\_SelfTest (XHdlc \*InstancePtr)

## **Define Documentation**

#### #define LOOPBACK\_BYTE\_COUNT

Performs a loopback test on the HDLC device by sending and receiving a frame using loopback mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

XST\_SUCCESS Loopback was successful XST\_LOOPBACK\_ERROR Loopback was unsuccessful

#### Note:

None.

## **Function Documentation**

XStatus XHdlc\_SelfTest( XHdlc \* InstancePtr)

Performs a self-test on the HDLC device. The test includes:

- Run self-test on the FIFOs, and IPIF components
- Reset the HDLC device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

XST\_SUCCESS Self-test was successful
XST\_REGISTER\_ERROR HDLC failed register reset test
XST\_LOOPBACK\_ERROR Internal loopback failed

#### **Note:**

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

## XHdlc Struct Reference

#include <xhdlc.h>

## **Detailed Description**

The XHdlc driver instance data. The user is required to allocate a variable of this type for every HDLC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• hdlc/v1\_00\_a/src/xhdlc.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary</u> Copyright

Main Page Data Structures File List Data Fields Globals

## hdlc/v1\_00\_a/src/xhdlc.h File Reference

## **Detailed Description**

The Xilinx HDLC driver component which supports the Xilinx HDLC device.

#### **Driver Description**

The device driver enables higher layer software (e.g., an application) to communicate to HDLC devices. The driver handles transmission and reception of HDLC frames, as well as configuration of the devices. A single device driver can support multiple HDLC devices.

The driver is designed for a zero-copy buffer scheme. That is, the driver will not copy buffers. This avoids potential throughput bottlenecks within the driver.

Since the driver is a simple pass-through mechanism between an application and the HDLC devices, no assembly or disassembly of HDLC frames is done at the driver-level. This assumes that the application passes a correctly formatted HDLC frame to the driver for transmission, and that the driver does not validate the contents of an incoming frame.

The driver supports polled mode and interrupt mode only with DMA scatter-gather. FIFO interrupt mode without DMA scatter-gather is not yet supported. The default mode of operation is polled.

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. Configuration parameters are stored in the **xhdlc\_g.c** file. A table is defined where each entry contains configuration information for an HDLC device. This information includes such things as the base address of the memory-mapped device.

#### **HDLC Frame Description**

An HDLC frame contains a number of fields as illustrated below. The size of several fields, the Address and FCS fields, are variable depending on the the configuration of the device as set through the options.

<Opening Flag><Address><Control><Data><FCS><Closing Flag>

#### **Asserts**

Asserts are used within all Xilinx drivers to enforce constraints on argument values. Asserts can be turned off on a system-wide basis by defining, at compile time, the NDEBUG identifier. By default, asserts are turned on and it is recommended that application developers leave asserts on during development.

#### Note:

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

## **Data Structures**

```
struct XHdlc_Config
struct XHdlc_Stats
```

## Typedefs for callbacks

Callback functions.

```
typedef void(* XHdlc_SgHandler )(void *CallBackRef, unsigned FrameCount)
typedef void(* XHdlc_ErrorHandler )(void *CallBackRef, XStatus ErrorCode)
```

### **Defines**

```
#define XHD_OPTION_POLLED

#define XHD_OPTION_LOOPBACK

#define XHD_OPTION_CRC_32

#define XHD_OPTION_CRC_DISABLE

#define XHD_OPTION_RX_FILTER_ADDR

#define XHD_OPTION_RX_REMOVE_ADDR

#define XHD_OPTION_RX_BROADCAST

#define XHD_OPTION_RX_16_ADDR
```

## **Functions**

```
XStatus XHdlc_Initialize (XHdlc *InstancePtr, Xuint16 DeviceId)
       XStatus XHdlc_Start (XHdlc *InstancePtr)
       XStatus XHdlc_Stop (XHdlc *InstancePtr)
           void XHdlc_Reset (XHdlc *InstancePtr)
XHdlc_Config * XHdlc_LookupConfig (Xuint16 DeviceId)
       XStatus XHdlc_Send (XHdlc *InstancePtr, Xuint8 *FramePtr, unsigned ByteCount)
       XStatus XHdlc_Recv (XHdlc *InstancePtr, Xuint8 *FramePtr, unsigned *ByteCountPtr, Xuint8
               *FrameStatusPtr)
       XStatus XHdlc_SelfTest (XHdlc *InstancePtr)
       XStatus XHdlc_SetOptions (XHdlc *InstancePtr, Xuint8 Options)
        Xuint8 XHdlc_GetOptions (XHdlc *InstancePtr)
           void XHdlc_SetAddress (XHdlc *InstancePtr, Xuint16 Address)
       Xuint16 XHdlc GetAddress (XHdlc *InstancePtr)
           void XHdlc_GetStats (XHdlc *InstancePtr, XHdlc_Stats *StatsPtr)
           void XHdlc_ClearStats (XHdlc *InstancePtr)
       XStatus XHdlc_SgSend (XHdlc *InstancePtr, XBufDescriptor *BdPtr)
       XStatus XHdlc_SgRecv (XHdlc *InstancePtr, XBufDescriptor *BdPtr)
       XStatus XHdlc_SgGetSendFrame (XHdlc *InstancePtr, XBufDescriptor **PtrToBdPtr,
               unsigned *BdCountPtr)
       XStatus XHdlc_SgGetRecvFrame (XHdlc *InstancePtr, XBufDescriptor **PtrToBdPtr,
               unsigned *BdCountPtr)
       XStatus XHdlc_SetSgRecvSpace (XHdlc *InstancePtr, Xuint32 *MemoryPtr, unsigned
               ByteCount)
       XStatus XHdlc_SetSgSendSpace (XHdlc *InstancePtr, Xuint32 *MemoryPtr, unsigned
               ByteCount)
           void XHdlc InterruptHandler (void *InstancePtr)
```

## **Define Documentation**

#### #define XHD\_OPTION\_CRC\_32

send/receive 32 bit CRCs

#### #define XHD\_OPTION\_CRC\_DISABLE

disable sending CRCs

#### #define XHD\_OPTION\_LOOPBACK

loopback transmit to receive

#### #define XHD\_OPTION\_POLLED

polled mode, default

#### #define XHD\_OPTION\_RX\_16\_ADDR

receive 16 bit addresses, 8 bit } is the default

#### #define XHD\_OPTION\_RX\_BROADCAST

receive broadcast addresses

#### #define XHD\_OPTION\_RX\_FILTER\_ADDR

receive address filtering

#### #define XHD\_OPTION\_RX\_REMOVE\_ADDR

don't buffer receive addresses

## **Typedef Documentation**

#### typedef void(\* XHdlc\_ErrorHandler)(void \*CallBackRef, XStatus ErrorCode)

Callback when errors occur in interrupt mode.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked.

*ErrorCode* indicates the error that occurred.

#### typedef void(\* XHdlc\_SgHandler)(void \*CallBackRef, unsigned FrameCount)

Callback when data is sent or received with scatter-gather DMA.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked.

FrameCount is the number of frames sent or received.

## **Function Documentation**

#### void XHdlc\_ClearStats( XHdlc \* InstancePtr)

Clear the statistics for the specified HDLC driver instance.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

Xuint16 XHdlc\_GetAddress( XHdlc \* InstancePtr)

Get the receive address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### Returns:

The receive address of the HDLC device.

#### Note:

None.

#### Xuint8 XHdlc\_GetOptions( XHdlc \* InstancePtr)

Get HDLC driver/device options. A value is returned which is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

The value of the HDLC options. The value is a bit-mask representing all options that are currently enabled. See **xhdlc.h** for a description of the available options.

#### Note:

None.

```
void XHdlc_GetStats( XHdlc * InstancePtr, XHdlc_Stats * StatsPtr )
```

Get a copy of the statistics structure, which contains the current statistics for this driver. The statistics are only cleared at initialization or on demand using the **XHdlc\_ClearStats()** function.

The FifoErrors counts indicate that the device has been or needs to be reset. Reset of the device is the responsibility of the caller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

None.

Note:

None.

Initialize a specific **XHdlc** instance/driver. The initialization entails:

- Initialize fields of the XHdlc structure
- Clear the HDLC statistics for this device
- Configure the FIFO components and DMA channels
- Reset the HDLC device

The driver defaults to polled mode operation. Interrupt mode can be selected using the SetOptions() function and turning off polled mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XHdlc** instance. Passing in a device id associates the generic **XHdlc** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.
- o XST\_NO\_FEATURE if the device configuration information indicates a feature that is not supported by this driver (no IPIF or simple DMA).

#### Note:

None.

void XHdlc\_InterruptHandler( void \* InstancePtr)

Interrupt handler for the HDLC driver. It performs the following processing:

- Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: the HDLC device, the send packet FIFO, the receive packet FIFO, the send DMA channel, or the receive DMA channel. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the HDLC device.
- Call the appropriate handler based on the source of the interrupt.

#### **Parameters:**

*InstancePtr* contains a pointer to the HDLC device instance for the interrupt.

#### **Returns:**

None.

#### Note:

None.

#### 

Lookup the device configuration based on the unique device ID. The table XHdlc\_ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID of the device being looked up.

#### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

#### Note:

Receive an HDLC frame in polled mode. The driver receives the frame directly from the devices packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The buffer into which the frame will be received must be word-aligned.

The frames which are received by the device are stripped of the Opening Flag and Closing Flag fields such that buffers which receive data will not contain these fields. The frames do contain the FCS field. The Address field may or may not be contained in a receive buffer depending on the options set.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

FramePtr is a pointer to a 32 bit word aligned buffer into which the received HDLC

frame will be copied.

ByteCountPtr is both an input and output parameter. It is a pointer to a 32-bit word that

contains the number of bytes in the specified frame buffer on entry and the

number of bytes in the received frame on return from the function.

FrameStatusPtr is an output which is changed by the driver to contain the status of the frame. It

indicates any status that occurred for the received frame.

#### **Returns:**

- o XST\_SUCCESS if the frame was received successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST NO DATA if there is no frame to be received from the FIFO
- o XST\_BUFFER\_TOO\_SMALL if the specified receive buffer is smaller than the the received frame. The received frame is not retrieved from the receive FIFO such that a reset of the device is necessary to resynchronize the internal length and data FIFOs.
- XST\_FIFO\_ERROR if a non-recoverable FIFO error has occurred. A reset of the device is necessary to clear this error.

#### Note:

Receive buffer must also be 32-bit aligned. The user must ensure that the size of the receive buffer is large enough to hold the frames received.

void XHdlc\_Reset( XHdlc \* InstancePtr)

Reset the HDLC instance. This is a graceful reset in that the device is stopped first then it resets the FIFOs and DMA channels if present. Reset must only be called after the driver has been initialized. The reset does not remove any of the buffer descriptors from the scatter-gather list for DMA.

The configuration after this reset is as follows:

- Disabled transmitter and receiver
- Device interrupts are disabled
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation

The upper layer software is responsible for re-configuring (if necessary) and restarting the HDLC device after the reset. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

#### **Parameters:**

**Returns:** 

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

|       | None. |  |
|-------|-------|--|
| Note: | None. |  |

#### XStatus XHdlc\_SelfTest( XHdlc \* InstancePtr)

Performs a self-test on the HDLC device. The test includes:

- Run self-test on the FIFOs, and IPIF components
- Reset the HDLC device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

| XST_ | _SUCCESS   |        |
|------|------------|--------|
| XST_ | _REGISTER_ | _ERROR |
| XST  | LOOPBACK   | ERROR  |

#### Note:

None.

Send an HDLC frame in polled mode. The driver writes the frame directly to the HDLC packet FIFO. Statistics are updated if an error previously occurred. The buffer to be sent must be word-aligned. This function is a non-blocking function in that it does not wait for the frame to be sent before returning.

The hardware device adds the Opening Flag, FCS, and Closing Flag fields to the frame such that these should not be put in the buffers which are to be sent.

The hardware device uses a length FIFO to keep track of each frame that has been put into the data FIFO. When sending a lot of short frames it is possible to fill this FIFO so that another frame cannot be sent until a frame has been sent by the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

FramePtr is a pointer to a 32 bit word aligned buffer containing the HDLC frame to be sent.

ByteCount is the size of the HDLC frame as an input. This size must be smaller than the size of the transmit FIFO of the device.

#### **Returns:**

- o XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST FIFO NO ROOM if there is no room in the devices FIFOs for this frame.
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.

#### **Note:**

Set the receive address for this driver/device. The address is a 8 or 16 bit value within a HDLC frame.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

Address is the address to be set.

#### **Returns:**

None.

#### Note:

None.

Sets the callback function for handling errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback which should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable HDLC device error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_ERROR\_COUNT\_MAX indicates the counters of the HDLC device have reached the maximum value and that the statistics of the HDLC device should be cleared.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

Note:

None.

Set HDLC driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option (i.e., you can OR the options together). A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

Options is a bit-mask representing the HDLC options to turn on or off. See **xhdlc.h** for a description of the available options.

#### **Returns:**

- o XST\_SUCCESS if the options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- XST\_NO\_FEATURE if the polled option is being turned off and the device configuration information indicates DMA scatter gather is not supported. This driver does not support interrupt driven without DMA scatter-gather (FIFO only) yet.

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Sets the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of frames, determined by the DMA scatter-gather packet threshold, are received. The number of received frames is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each received frame from the list and should attach a new buffer to each descriptor. It is important that the specified number of frames passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are other potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the HDLC driver. The memory space must be word-aligned.

This function must be called prior to calling **XHdlc\_Start**().

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

- o XST SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the HDLC device is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XHdlc\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Sets the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of frames, determined by the DMA scatter-gather packet threshold, are sent. The number of sent frames is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each sent frame from the list and should also free the buffers attached to the descriptors if necessary. It is important that the specified number of frames passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Gives the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the HDLC driver. The memory space must be word-aligned.

This function must be called prior to calling **XHdlc\_Start()**.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the HDLC device is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XHdlc\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

```
XStatus XHdlc_SgGetRecvFrame( XHdlc * InstancePtr, XBufDescriptor ** PtrToBdPtr, unsigned * BdCountPtr
```

Gets the first buffer descriptor of the oldest frame which was received by the scatter-gather DMA channel of the HDLC device. This function is provided to be called from a callback function such that the buffer descriptors for received frames can be processed. The function should be called by the application repetitively for the number of frames indicated as an argument in the callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*PtrToBdPtr* is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the frame. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the frame. This input argument is also an output.

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the frame pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- o XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### Note:

None.

```
XStatus XHdlc_SgGetSendFrame( XHdlc * InstancePtr, XBufDescriptor ** PtrToBdPtr, unsigned * BdCountPtr
```

Gets the first buffer descriptor of the oldest frame which was sent by the scatter-gather DMA channel of the HDLC device. This function is provided to be called from a callback function such that the buffer descriptors for sent frames can be processed. The function should be called by the application repetitively for the number of frames indicated as an argument in the callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

PtrToBdPtr is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the frame. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the frame. this input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the frame pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- o XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### **Note:**

Adds this descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be word-aligned. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. The contents of the specified buffer descriptor are copied into the scatter-gather transmit list. This function can be called when the device is started or stopped.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

#### **Returns:**

- XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- o XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

#### Note:

None.

Sends a HDLC frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire frame may or may not be contained within one descriptor. The contents of the buffer descriptor are copied into the scatter-gather transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor must be word-aligned.

The driver updates the descriptor with the DMA control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted HDLC frame based upon the configuration of the HDLC device. The HDLC device must be started before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

#### **Returns:**

- o XST\_SUCCESS if the buffer was successfully sent
- o XST\_DEVICE\_IS\_STOPPED if the HDLC device has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

#### XStatus XHdlc\_Start( XHdlc \* InstancePtr)

Start the HDLC device and driver by enabling the transmitter and receiver. This function must be called before other functions to send or receive data. It supports either polled or DMA scatter gather interrupt driven modes of operation. It does not yet support interrupt driven with FIFOs (non-DMA) or simple DMA without scatter gather.

If the driver is configured for interrupt driven operation, the interrupts of the device are enabled. The user should have connected the interrupt handler of the driver to an interrupt source such as an interrupt controller or the processor interrupt prior to this function being called.

Prior to calling this function, the functions **XHdlc\_SetSgRecvSpace()** and **XHdlc\_SetSgSendSpace()** should be called to setup the memory buffers and descriptor lists for the DMA scatter-gather.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

- XST\_SUCCESS if the device was started successfully
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function. This is required if in interrupt mode.
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- XST\_DMA\_SG\_LIST\_EMPTY if configured for scatter-gather DMA and a descriptor list has been created for the receive channel but no buffers inserted into it.

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

## XStatus XHdlc\_Stop( XHdlc \* InstancePtr)

Stop the HDLC device as follows:

- If the device is configured with DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the HDLC frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

- o XST SUCCESS if the device was stopped successfully
- XST\_DEVICE\_IS\_STOPPED if the device is already stopped

#### Note:

None.

# hdlc/v1\_00\_a/src/xhdlc\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of HDLC devices in the system.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a jhl 04/08/02 First release

#include "xhdlc.h"
```

## **Variables**

XHdlc\_Config XHdlc\_ConfigTable [XPAR\_XHDLC\_NUM\_INSTANCES]

## **Variable Documentation**

## XHdlc\_Config XHdlc\_ConfigTable[XPAR\_XHDLC\_NUM\_INSTANCES]

This table contains configuration information for each HDLC device in the system.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XHdlc\_Config Struct Reference

#include <xhdlc.h>

## **Detailed Description**

This typedef contains configuration information for a device.

## **Data Fields**

**Xuint16 DeviceId** 

**Xuint32 BaseAddress** 

Xuint32 TransmitFifoSize

Xuint32 ReceiveFifoSize

**Xuint8 IpIfDmaConfig** 

## **Field Documentation**

Xuint32 XHdlc\_Config::BaseAddress

Device base address

Xuint16 XHdlc\_Config::DeviceId

Unique ID of device

Xuint8 XHdlc\_Config::IpIfDmaConfig

## IPIF/DMA hardware configuration

## Xuint32 XHdlc\_Config::ReceiveFifoSize

Receive FIFO size in bytes

## Xuint32 XHdlc\_Config::TransmitFifoSize

Transmit FIFO size in bytes

The documentation for this struct was generated from the following file:

• hdlc/v1\_00\_a/src/xhdlc.h

# common/v1\_00\_a/src/xbasic\_types.h File Reference

## **Detailed Description**

This file contains basic types for Xilinx software IP. These types do not follow the standard naming convention with respect to using the component name in front of each name because they are considered to be primitives.

#### Note:

This file contains items which are architecture dependent.

#### MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes        |         |        |       |             |      |      |
|-------|-----|----------|----------------|---------|--------|-------|-------------|------|------|
|       |     |          |                |         |        |       |             | _    |      |
| 1.00a | rmm | 12/14/01 | First release  |         |        |       |             |      |      |
|       | rmm | 05/09/03 | Added "xassert | always" | macros | to ri | d ourselves | of d | diab |
|       |     |          | compiler warni | .ngs    |        |       |             |      |      |

## **Data Structures**

struct Xuint64

## **Primitive types**

These primitive types are created for transportability. They are dependent upon the target architecture.

```
typedef unsigned char Xuint8
typedef char Xint8
typedef unsigned short Xuint16
typedef short Xint16
typedef unsigned long Xuint32
```

```
typedef long Xint32
typedef float Xfloat32
typedef double Xfloat64
typedef unsigned long Xboolean
```

## **Defines**

```
#define XTRUE

#define XFALSE

#define XNULL

#define XUINT64_MSW(x)

#define XUINT64_LSW(x)

#define XASSERT_VOID(expression)

#define XASSERT_NONVOID(expression)

#define XASSERT_VOID_ALWAYS()

#define XASSERT_NONVOID_ALWAYS()
```

## **Typedefs**

```
typedef void(* XInterruptHandler )(void *InstancePtr)
typedef void(* XAssertCallback )(char *FilenamePtr, int LineNumber)
```

## **Functions**

```
void XAssert (char *, int)
void XAssertSetCallback (XAssertCallback Routine)
```

## **Variables**

unsigned int XAssertStatus

## **Define Documentation**

#define XASSERT\_NONVOID( expression )

This assert macro is to be used for functions that do return a value. This in conjunction with the XWaitInAssert boolean can be used to accommodate tests so that asserts which fail allow execution to continue.

#### **Parameters:**

expression is the expression to evaluate. If it evaluates to false, the assert occurs.

#### **Returns:**

Returns 0 unless the XWaitInAssert variable is true, in which case no return is made and an infinite loop is entered.

#### Note:

None.

## #define XASSERT\_NONVOID\_ALWAYS( )

Always assert. This assert macro is to be used for functions that do return a value. Use for instances where an assert should always occur.

#### **Returns:**

Returns void unless the XWaitInAssert variable is true, in which case no return is made and an infinite loop is entered.

#### **Note:**

None.

## #define XASSERT\_VOID( expression )

This assert macro is to be used for functions that do not return anything (void). This in conjunction with the XWaitInAssert boolean can be used to accommodate tests so that asserts which fail allow execution to continue.

#### **Parameters:**

expression is the expression to evaluate. If it evaluates to false, the assert occurs.

## **Returns:**

Returns void unless the XWaitInAssert variable is true, in which case no return is made and an infinite loop is entered.

## **Note:**

## #define XASSERT\_VOID\_ALWAYS( )

Always assert. This assert macro is to be used for functions that do not return anything (void). Use for instances where an assert should always occur.

#### **Returns:**

Returns void unless the XWaitInAssert variable is true, in which case no return is made and an infinite loop is entered.

## Note:

None.

## #define XFALSE

Xboolean false

## #define XNULL

Null

## #define XTRUE

Xboolean true

## #define XUINT64\_LSW(x)

Return the least significant half of the 64 bit data type.

#### **Parameters:**

x is the 64 bit word.

#### **Returns:**

The lower 32 bits of the 64 bit word.

#### **Note:**

None.

## #define XUINT64\_MSW(x)



## typeder char mine

signed 8-bit

## typedef void(\* XInterruptHandler)(void \*InstancePtr)

This data type defines an interrupt handler for a device. The argument points to the instance of the component

## typedef unsigned short Xuint16

unsigned 16-bit

## typedef unsigned long Xuint32

unsigned 32-bit

## typedef unsigned char Xuint8

unsigned 8-bit

## **Function Documentation**

```
void XAssert( char * File, int Line
```

Implements assert. Currently, it calls a user-defined callback function if one has been set. Then, it potentially enters an infinite loop depending on the value of the XWaitInAssert variable.

#### **Parameters:**

File is the name of the filename of the source Line is the linenumber within File

#### **Returns:**

None.

## **Note:**

None.

## void XAssertSetCallback (XAssertCallback Routine)

Sets up a callback function to be invoked when an assert occurs. If there was already a callback installed, then it is replaced.

#### Parameters:

Routine is the callback to be invoked when an assert is taken

#### **Returns:**

None.

#### Note:

This function has no effect if NDEBUG is set

## **Variable Documentation**

## unsigned int XAssertStatus( )

This variable allows testing to be done easier with asserts. An assert sets this variable such that a driver can evaluate this variable to determine if an assert occurred.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# common/v1\_00\_a/src/xstatus.h File Reference

## **Detailed Description**

This file contains Xilinx software status codes. Status codes have their own data type called XStatus. These codes are used throughout the Xilinx device drivers.

#include "xbasic\_types.h"

## **Typedefs**

typedef Xuint32 XStatus

## **Typedef Documentation**

typedef Xuint32 XStatus

The status typedef.

# hdlc/v1\_00\_a/src/xhdlc\_l.h File Reference

## **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xhdlc.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 05/20/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XHdlc_mReadReg(BaseAddress, RegOffset)
#define XHdlc_mWriteReg(BaseAddress, RegOffset, Data)
#define XHdlc_mSetRxControlReg(BaseAddress, Mask)
#define XHdlc_mSetTxControlReg(BaseAddress, Mask)
#define XHdlc_mSetAddressReg(BaseAddress, Address)
#define XHdlc_mEnable(BaseAddress)
#define XHdlc_mDisable(BaseAddress)
```

## **Functions**

void XHdlc\_SendFrame (Xuint32 BaseAddress, Xuint8 \*FramePtr, unsigned ByteCount) unsigned XHdlc\_RecvFrame (Xuint32 BaseAddress, Xuint8 \*FramePtr, Xuint32 \*FrameStatusPtr)

## **Define Documentation**

## #define XHdlc\_mDisable( BaseAddress )

Disable the transmitter and receiver. Preserve the contents of the control registers.

#### **Parameters:**

BaseAddress is the base address of the device

## **Returns:**

None.

#### Note:

None.

## #define XHdlc\_mEnable( BaseAddress )

Enable the transmitter and receiver. Preserve the contents of the control registers.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

None.

#### Note:

None.

# #define XHdlc\_mReadReg( BaseAddress, RegOffset



Set the contents of the receive control register. Use the XHD\_RXCR\_\* constants defined above to create the bit-mask to be written to the register.

| Da |              | 4   | ers: |
|----|--------------|-----|------|
| Га | $\mathbf{I}$ | нес | ers. |

BaseAddress is the base address of the device

Mask is the 32 bit value to write to the control register

## **Returns:**

None.

## **Note:**

None.

# #define XHdlc\_mSetTxControlReg( BaseAddress, Mask

Set the contents of the transmit control register. Use the XHD\_TXCR\_\* constants defined above to create the bit-mask to be written to the register.

## **Parameters:**

BaseAddress is the base address of the device

Mask is the 32 bit value to write to the control register

## **Returns:**

None.

## **Note:**

```
#define XHdlc_mWriteReg( BaseAddress, RegOffset, Data )
```

Write the specified data to the specified register.

## **Parameters:**

BaseAddress is the base address of the device RegOffset is the register offset to be written

Data is the 32-bit value to write to the register

## **Returns:**

None.

**Note:** 

None.

## **Function Documentation**

```
unsigned XHdlc_RecvFrame( Xuint32 BaseAddress,

Xuint8 * FramePtr,

Xuint32 * FrameStatusPtr

)
```

Receive a frame. Wait for a frame to arrive.

## **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to a 32 bit word-aligned buffer where the frame will be

stored.

FrameStatusPtr is a pointer to a frame status that will be valid after this function returns.

## **Returns:**

The size, in bytes, of the frame received.

## Note:

```
void XHdlc_SendFrame( Xuint32 BaseAddress, Xuint8 * FramePtr, unsigned ByteCount
```

Send a HDLC frame. This size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

## **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to 32 bit word-aligned frame

ByteCount is the number of bytes in the frame

## **Returns:**

None.

## **Note:**

None.

## Xilinx Device Drivers

## Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# cpu\_ppc405/v1\_00\_a/src/xio.h File Reference

## **Detailed Description**

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).

```
#include "xbasic_types.h"
```

## **Typedefs**

typedef Xuint32 XIo\_Address

## **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)
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)

## **Typedef Documentation**

## typedef Xuint32 XIo\_Address

Typedef for an I/O address. Typically correlates to the width of the address bus.

## **Function Documentation**

## Xuint16 XIo\_In16( XIo\_Address InAddress)

Performs an input operation for a 16-bit memory location by reading from the specified address and returning the value read from that address.

## **Parameters:**

InAddress contains the address to perform the input operation at.

## **Returns:**

The value read from the specified input address.

#### **Note:**

None.

Xuint32 XIo\_In32( XIo\_Address InAddress)



## **Parameters:**

*InAddress* contains the address to perform the input operation at.

## **Returns:**

The value read from the specified input address.

## **Note:**

None.

## Xuint8 XIo\_In8( XIo\_Address InAddress)

Performs an input operation for an 8-bit memory location by reading from the specified address and returning the value read from that address.

## **Parameters:**

InAddress contains the address to perform the input operation at.

## **Returns:**

The value read from the specified input address.

## **Note:**

None.

## Xuint16 XIo\_InSwap16( XIo\_Address InAddress)

Performs an input operation for a 16-bit memory location by reading from the specified address and returning the byte-swapped value read from that address.

## **Parameters:**

*InAddress* contains the address to perform the input operation at.

## **Returns:**

The byte-swapped value read from the specified input address.

## Note:

None.

## Xuint32 XIo\_InSwap32( XIo\_Address InAddress)

Performs an input operation for a 32-bit memory location by reading from the specified address and returning the byte-swapped value read from that address.

## **Parameters:**

*InAddress* contains the address to perform the input operation at.

## **Returns:**

The byte-swapped value read from the specified input address.

## Note:

```
void XIo_Out16( XIo_Address OutAddress,
Xuint16 Value
)
```

Performs an output operation for a 16-bit memory location by writing the specified value to the specified address.

## **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

## **Returns:**

None.

## Note:

None.

```
void XIo_Out32( XIo_Address OutAddress, Xuint32 Value
```

Performs an output operation for a 32-bit memory location by writing the specified value to the specified address.

## **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

## **Returns:**

None.

## Note:

```
void XIo_Out8( XIo_Address OutAddress,
Xuint8 Value
)
```

Performs an output operation for an 8-bit memory location by writing the specified value to the specified address.

## **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

## **Returns:**

None.

## Note:

None.

```
void XIo_OutSwap16( XIo_Address OutAddress, Xuint16 Value
)
```

Performs an output operation for a 16-bit memory location by writing the specified value to the specified address. The value is byte-swapped before being written.

#### **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

## **Returns:**

None.

#### Note:

```
void XIo_OutSwap32( XIo_Address OutAddress, Xuint32 Value
)
```

| Performs an output operation for a 32-bit memory location by writing the specified value to |
|---------------------------------------------------------------------------------------------|
| the the specified address. The value is byte-swapped before being written.                  |
|                                                                                             |

| Parameters: |                                                                     |                                                           |  |  |  |  |
|-------------|---------------------------------------------------------------------|-----------------------------------------------------------|--|--|--|--|
|             | OutAddress contains the address to perform the output operation at. |                                                           |  |  |  |  |
|             | Value                                                               | contains the value to be output at the specified address. |  |  |  |  |
| Return      | <b>ns:</b><br>None.                                                 |                                                           |  |  |  |  |
|             | None.                                                               |                                                           |  |  |  |  |

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page <u>Data Structures</u> <u>File List</u> <u>Data Fields</u> <u>Globals</u>

# common/v1\_00\_a/src/xparameters.h File Reference

## **Detailed Description**

This file contains system parameters for the Xilinx device driver environment. It is a representation of the system in that it contains the number of each device in the system as well as the parameters and memory map for each device. The user can view this file to obtain a summary of the devices in their system and the device parameters.

This file may be automatically generated by a design tool such as System Generator.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XHdlc\_Stats Struct Reference

#include <xhdlc.h>

## **Detailed Description**

HDLC statistics (see XHdlc\_GetStats() and XHdlc\_ClearStats())

## **Data Fields**

**Xuint16 XmitFrames** 

**Xuint16 XmitBytes** 

**Xuint16 RecvFrames** 

**Xuint16 RecvBytes** 

**Xuint16 RecvFcsErrors** 

**Xuint16 RecvAlignmentErrors** 

**Xuint16 RecvOverrunErrors** 

**Xuint16 RecvAbortedFrames** 

**Xuint16 FifoErrors** 

**Xuint16 DmaErrors** 

**Xuint16 RecvInterrupts** 

**Xuint16 XmitInterrupts** 

**Xuint16 HdlcInterrupts** 

## **Field Documentation**

## Xuint16 XHdlc\_Stats::DmaErrors

Number of DMA errors

## Xuint16 XHdlc\_Stats::FifoErrors

Number of FIFO errors since init

## Xuint16 XHdlc\_Stats::HdlcInterrupts

Number of HDLC (device) interrupts

## Xuint16 XHdlc\_Stats::RecvAbortedFrames

Number of transmit aborted frames

## Xuint16 XHdlc\_Stats::RecvAlignmentErrors

Number of frames received with alignment errors

## Xuint16 XHdlc\_Stats::RecvBytes

Number of bytes received

## Xuint16 XHdlc\_Stats::RecvFcsErrors

Number of frames discarded due to FCS errors

## **Xuint16** XHdlc\_Stats::RecvFrames

Number of frames received

## Xuint16 XHdlc\_Stats::RecvInterrupts

Number of receive interrupts

## Xuint16 XHdlc\_Stats::RecvOverrunErrors

Number of frames discarded due to overrun errors

## Xuint16 XHdlc\_Stats::XmitBytes

Number of bytes transmitted

## Xuint16 XHdlc\_Stats::XmitFrames

Number of frames transmitted

## Xuint16 XHdlc\_Stats::XmitInterrupts

Number of transmit interrupts

The documentation for this struct was generated from the following file:

• hdlc/v1\_00\_a/src/xhdlc.h

# hdlc/v1\_00\_a/src/xhdlc\_i.h File Reference

## **Detailed Description**

This header file contains internal identifiers, which are those shared between **XHdlc** components. The identifiers in this file are not intended for use external to the driver.

```
MODIFICATION HISTORY:
```

#include "xhdlc.h"

## **Variables**

XHdlc\_Config XHdlc\_ConfigTable []

## **Variable Documentation**

XHdlc\_Config XHdlc\_ConfigTable[]( )

This table contains configuration information for each HDLC device in the system.

# common/v1\_00\_a/src/xbasic\_types.c File Reference

## **Detailed Description**

This file contains basic functions for Xilinx software IP.

```
#include "xbasic_types.h"
```

## **Functions**

```
void XAssert (char *File, int Line)
void XAssertSetCallback (XAssertCallback Routine)
```

## **Variables**

```
unsigned int XAssertStatus
Xboolean XWaitInAssert
```

## **Function Documentation**

```
void XAssert( char * File, int Line )
```

Implements assert. Currently, it calls a user-defined callback function if one has been set. Then, it potentially enters an infinite loop depending on the value of the XWaitInAssert variable.

## **Parameters:**

File is the name of the filename of the source Line is the linenumber within File

## **Returns:**

None.

#### **Note:**

None.

## void XAssertSetCallback (XAssertCallback Routine)

Sets up a callback function to be invoked when an assert occurs. If there was already a callback installed, then it is replaced.

## **Parameters:**

Routine is the callback to be invoked when an assert is taken

#### **Returns:**

None.

## Note:

This function has no effect if NDEBUG is set

## **Variable Documentation**

## unsigned int XAssertStatus

This variable allows testing to be done easier with asserts. An assert sets this variable such that a driver can evaluate this variable to determine if an assert occurred.

## **Xboolean** XWaitInAssert

This variable allows the assert functionality to be changed for testing such that it does not wait infinitely. Use the debugger to disable the waiting during testing of asserts.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## **XAtmc Struct Reference**

#include <xatmc.h>

## **Detailed Description**

The XAtmc driver instance data. The user is required to allocate a variable of this type for every ATMC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• atmc/v1\_00\_c/src/xatmc.h

## atmc/v1\_00\_c/src/xatmc.c File Reference

## **Detailed Description**

This file contains the ATM controller driver. This file contains send and receive functions as well as interrupt service routines.

There is one interrupt service routine registered with the interrupt controller. This function determines the source of the interrupt and calls an appropriate handler function.

#### Note:

None.

#### MODIFICATION HISTORY:

```
#include "xatmc.h"
#include "xatmc_i.h"
#include "xipif_v1_23_b.h"
#include "xpacket_fifo_v2_00_a.h"
#include "xio.h"
```

## **Functions**

```
XStatus XAtmc_SgSend (XAtmc *InstancePtr, XBufDescriptor *BdPtr)
XStatus XAtmc_SgRecv (XAtmc *InstancePtr, XBufDescriptor *BdPtr)
```

## **Function Documentation**

## void XAtmc\_InterruptHandler( void \* InstancePtr)

Interrupt handler for the ATM controller driver. It performs the following processing:

- Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: the ATM controller, the send packet FIFO, the receive packet FIFO, the send DMA channel, or the receive DMA channel. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the ATM controller.
- Call the appropriate handler based on the source of the interrupt.

#### **Parameters:**

*InstancePtr* contains a pointer to the ATMC controller instance for the interrupt.

#### **Returns:**

None.

#### Note:

Receives an ATM cell in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the cell directly from the ATM controller packet FIFO. This is a non-blocking receive, in that if there is no cell ready to be received at the device, the function returns with an error. The buffer into which the cell will be received must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer into which the received Atmc cell will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to the size of the buffer on entry into the function and the size the received cell on return from the function.

CellStatusPtr is both an input and an output parameter. It is a pointer to the status of the cell which is received. It is only valid if the return value indicates success. The status is necessary when cells with errors are not being discarded. This status is a bit mask which may contain one or more of the following values with the exception of XAT\_CELL\_STATUS\_NO\_ERROR which is mutually exclusive. The status values are:

- XAT\_CELL\_STATUS\_NO\_ERROR indicates the cell was received without any errors
- XAT\_CELL\_STATUS\_BAD\_PARITY indicates the cell parity was not correct
- XAT\_CELL\_STATUS\_BAD\_HEC indicates the cell HEC was not correct
- XAT CELL STATUS SHORT indicates the cell was not the correct length
- XAT\_CELL\_STATUS\_VXI\_MISMATCH indicates the cell VPI/VCI fields did not match the expected header values

#### **Returns:**

- o XST SUCCESS if the cell was sent successfully
- XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- XST\_NOT\_POLLED if the device is not in polled mode
- o XST NO DATA if tThere is no cell to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the cell is too small for the cell waiting in the FIFO.

#### Note:

The input buffer must be big enough to hold the largest ATM cell. The buffer must also be 32-bit aligned.

Sends an ATM cell in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the cell directly to the ATM controller packet FIFO, then enters a loop checking the device status for completion or error. The buffer to be sent must be word-aligned.

It is assumed that the upper layer software supplies a correctly formatted ATM cell based upon the configuration of the ATM controller (attaching header or not).

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the ATM cell to be sent.

ByteCount is the size of the ATM cell. An ATM cell for a 16 bit Utopia interface is 54 bytes

with a 6 byte header and 48 bytes of payload. This function may be used to send short cells with or without headers depending on the configuration of the ATM

controller.

#### **Returns:**

- XST\_SUCCESS if the cell was sent successfully
- XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- XST\_NOT\_POLLED if the device is not in polled mode
- XST\_PFIFO\_NO\_ROOM if there is no room in the FIFO for this cell
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun

#### Note:

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread.

The input buffer must be big enough to hold the largest ATM cell. The buffer must also be 32-bit aligned.

Gets the first buffer descriptor of the oldest cell which was received by the scatter-gather DMA channel of the ATM controller. This function is provided to be called from a callback function such that the buffer descriptors for received cells can be processed. The function should be called by the application repetitively for the number of cells indicated as an argument in the callback function. This function may also be used when only payloads are being sent and received by the ATM controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

PtrToBdPtr is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the cell. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the cell. This input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the cell pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### Note:

None.

Gets the first buffer descriptor of the oldest cell which was sent by the scatter-gather DMA channel of the ATM controller. This function is provided to be called from a callback function such that the buffer descriptors for sent cells can be processed. The function should be called by the application repetitively for the number of cells indicated as an argument in the callback function. This function may also be used when only payloads are being sent and received by the ATM controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

PtrToBdPtr is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the cell. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the cell. this input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the cell pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### Note:

None.

Adds this descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be word-aligned. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of cells to replace filled buffers with empty buffers. The contents of the specified buffer descriptor are copied into the scatter-gather transmit list. This function can be called when the device is started or stopped.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

#### **Returns:**

o XST\_SUCCESS if a descriptor was successfully returned to the driver

- XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

#### **Note:**

None.

Sends an ATM cell using scatter-gather DMA. The caller attaches the cell to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire ATM cell may or may not be contained within one descriptor. The contents of the buffer descriptor are copied into the scatter-gather transmit list. The caller is responsible for providing mutual exclusion to guarantee that a cell is contiguous in the transmit list. The buffer attached to the descriptor must be word-aligned.

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the cell, the inserts are committed, which means the descriptors for this cell are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted ATM cell based upon the configuration of the ATM controller (attaching header or not). The ATM controller must be started before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

#### **Returns:**

- XST\_SUCCESS if the buffer was successfully sent
- o XST\_DEVICE\_IS\_STOPPED if the ATM controller has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

## **Note:**

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# atmc/v1\_00\_c/src/xatmc\_i.h File Reference

# **Detailed Description**

This file contains data which is shared between files internal to the **XAtmc** component. It is intended for internal use only.

#### MODIFICATION HISTORY:

# **Defines**

#define **XAtmc\_mIsSgDma**(InstancePtr)

## **Variables**

**XAtmc\_Config XAtmc\_ConfigTable** []

# **Define Documentation**

#### #define XAtmc\_mIsSgDma( InstancePtr )

This macro determines if the device is currently configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured for scatter-gather DMA, or XFALSE if it is not.

#### Note:

Signature: Xboolean **XAtmc\_mIsSgDma**(XAtmc \*InstancePtr)

# **Variable Documentation**

**XAtmc\_Config XAtmc\_ConfigTable**[]( )

This table contains configuration information for each ATMC device in the system.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# atmc/v1\_00\_c/src/xatmc\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xatmc.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00b rpm 05/01/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

# **Defines**

```
#define XAtmc_mReadReg(BaseAddress, RegOffset)
#define XAtmc_mWriteReg(BaseAddress, RegOffset, Data)
#define XAtmc_mEnable(BaseAddress)
#define XAtmc_mDisable(BaseAddress)
#define XAtmc_mIsTxDone(BaseAddress)
#define XAtmc_mIsTxDone(BaseAddress)
```

# **Functions**

```
void XAtmc_SendCell (Xuint32 BaseAddress, Xuint8 *CellPtr, int Size)
int XAtmc_RecvCell (Xuint32 BaseAddress, Xuint8 *CellPtr, Xuint32 *CellStatusPtr)
```

# **Define Documentation**

#### #define XAtmc\_mDisable( BaseAddress )

Disable the transmitter and receiver. Preserve the contents of the control register.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

None.

#### Note:

None.

#### #define XAtmc\_mEnable( BaseAddress )

Enable the transmitter and receiver. Preserve the contents of the control register.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

None.

#### Note:

None.

### #define XAtmc\_mIsRxEmpty( BaseAddress )

| Parameters:  BaseAddress is the base address of the device                                              |
|---------------------------------------------------------------------------------------------------------|
| Returns:  XTRUE if it is empty, or XFALSE if it is not.                                                 |
| Note: None.                                                                                             |
| #define XAtmc_mIsTxDone( BaseAddress )                                                                  |
| Check to see if the transmission is complete.                                                           |
| Parameters:                                                                                             |
| BaseAddress is the base address of the device                                                           |
| Returns:  XTRUE if it is done, or XFALSE if it is not.                                                  |
| Note: None.                                                                                             |
| #define XAtmc_mReadReg( BaseAddress,  RegOffset )                                                       |
| Read the given register.                                                                                |
| Parameters:  BaseAddress is the base address of the device  RegOffset is the register offset to be read |
| Returns: The 32-bit value of the register                                                               |
| Note: None.                                                                                             |

Check to see if the receive FIFO is empty.

Write the given register.

#### **Parameters:**

BaseAddress is the base address of the device RegOffset is the register offset to be written

Data is the 32-bit value to write to the register

#### **Returns:**

None.

**Note:** 

None.

# **Function Documentation**

```
int XAtmc_RecvCell( Xuint32 BaseAddress,
Xuint8 * CellPtr,
Xuint32 * CellStatusPtr
)
```

Receive a cell. Wait for a cell to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

*CellPtr* is a pointer to a word-aligned buffer where the cell will be stored.

CellStatusPtr is a pointer to a cell status that will be valid after this function returns.

#### **Returns:**

The size, in bytes, of the cell received.

#### Note:

None.

```
void XAtmc_SendCell( Xuint32 BaseAddress, Xuint8 * CellPtr, int Size
```

Send an ATM cell. This function blocks waiting for the cell to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device
CellPtr is a pointer to word-aligned cell
Size is the size, in bytes, of the cell

#### **Returns:**

None.

#### **Note:**

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# XAtmc\_Config Struct Reference

#include <xatmc.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xuint8 IpIfDmaConfig

# **Field Documentation**

Xuint32 XAtmc\_Config::BaseAddress

Base address of device

Xuint16 XAtmc\_Config::DeviceId

Unique ID of device

Xuint8 XAtmc\_Config::IpIfDmaConfig

IPIF/DMA hardware configuration

The documentation for this struct was generated from the following file:

• atmc/v1\_00\_c/src/xatmc.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers Driver Summary Copyright Data Structures File List Data Fields Clabels

Main Page Data Structures File List Data Fields Globals

# XAtmc\_Stats Struct Reference

#include <xatmc.h>

# **Detailed Description**

ATM controller statistics

# **Data Fields**

**Xuint32 XmitCells** 

**Xuint32 RecvCells** 

**Xuint32 RecvUnexpectedHeaders** 

**Xuint32 RecvShortCells** 

**Xuint32 RecvLongCells** 

**Xuint32 RecvHecErrors** 

**Xuint32 RecvParityErrors** 

**Xuint32 DmaErrors** 

**Xuint32 FifoErrors** 

**Xuint32 RecvInterrupts** 

**Xuint32 XmitInterrupts** 

**Xuint32 AtmcInterrupts** 

# **Field Documentation**

Xuint32 XAtmc\_Stats::AtmcInterrupts

#### Number of ATMC interrupts

#### Xuint32 XAtmc\_Stats::DmaErrors

Number of DMA errors since init

#### Xuint32 XAtmc Stats::FifoErrors

Number of FIFO errors since init

#### Xuint32 XAtmc\_Stats::RecvCells

Number of cells received

#### Xuint32 XAtmc\_Stats::RecvHecErrors

Number of HEC errors

### **Xuint32 XAtmc\_Stats::RecvInterrupts**

Number of receive interrupts

## Xuint32 XAtmc\_Stats::RecvLongCells

Number of long cells

## Xuint32 XAtmc\_Stats::RecvParityErrors

Number of parity errors

### Xuint32 XAtmc\_Stats::RecvShortCells

Number of short cells

### Xuint32 XAtmc\_Stats::RecvUnexpectedHeaders

Number of cells with unexpected headers

### Xuint32 XAtmc\_Stats::XmitCells

Number of cells transmitted

# Xuint32 XAtmc\_Stats::XmitInterrupts

Number of transmit interrupts

The documentation for this struct was generated from the following file:

• atmc/v1\_00\_c/src/xatmc.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# atmc/v1\_00\_c/src/xatmc\_cfg.c File Reference

# **Detailed Description**

Functions in this file handle configuration (including initialization, reset, and self-test) of the Xilinx ATM driver component.

#### Note:

None.

#### MODIFICATION HISTORY:

# **Data Structures**

struct Mapping

## **Functions**

```
XStatus XAtmc_Initialize (XAtmc *InstancePtr, Xuint16 DeviceId)
        XStatus XAtmc_Start (XAtmc *InstancePtr)
        XStatus XAtmc_Stop (XAtmc *InstancePtr)
           void XAtmc_Reset (XAtmc *InstancePtr)
        XStatus XAtmc_SelfTest (XAtmc *InstancePtr)
        XStatus XAtmc SetOptions (XAtmc *InstancePtr, Xuint32 OptionsFlag)
       Xuint32 XAtmc_GetOptions (XAtmc *InstancePtr)
        XStatus XAtmc SetPhyAddress (XAtmc *InstancePtr, Xuint8 Address)
         Xuint8 XAtmc_GetPhyAddress (XAtmc *InstancePtr)
        XStatus XAtmc SetHeader (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 Header)
       Xuint32 XAtmc GetHeader (XAtmc *InstancePtr, Xuint32 Direction)
        XStatus XAtmc_SetUserDefined (XAtmc *InstancePtr, Xuint8 UserDefined)
         Xuint8 XAtmc GetUserDefined (XAtmc *InstancePtr)
        XStatus XAtmc_SetPktThreshold (XAtmc *InstancePtr, Xuint32 Direction, Xuint8 Threshold)
        XStatus XAtmc GetPktThreshold (XAtmc *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)
        XStatus XAtmc SetPktWaitBound (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 TimerValue)
        XStatus XAtmc_GetPktWaitBound (XAtmc *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)
           void XAtmc_GetStats (XAtmc *InstancePtr, XAtmc_Stats *StatsPtr)
           void XAtmc_ClearStats (XAtmc *InstancePtr)
        XStatus XAtmc_SetSgRecvSpace (XAtmc *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
        XStatus XAtmc_SetSgSendSpace (XAtmc *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
           void XAtmc_SetSgRecvHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc_SgHandler
                FuncPtr)
           void XAtmc_SetSgSendHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc_SgHandler
                FuncPtr)
           void XAtmc_SetErrorHandler (XAtmc *InstancePtr, void *CallBackRef, XAtmc_ErrorHandler
                FuncPtr)
XAtmc_Config * XAtmc_LookupConfig (Xuint16 DeviceId)
```

# **Function Documentation**

void XAtmc\_ClearStats( XAtmc \* InstancePtr)

Clears the **XAtmc\_Stats** structure for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

```
Xuint32 XAtmc_GetHeader( XAtmc * InstancePtr,
Xuint32 Direction
)
```

Gets the send or receive ATM header in the ATM controller. The ATM controller attachs the send header to cells which are to be sent but contain only the payload.

If the ATM controller is configured appropriately, it will compare the header of received cells against the receive header and discard cells which don't match in the VCI and VPI fields of the header.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*Direction* indicates whether we're retrieving the send header or the receive header.

#### **Returns:**

The ATM header currently being used by the ATM controller for attachment to transmitted cells or the header which is being compared against received cells. An invalid specified direction will cause this function to return a value of 0.

#### **Note:**

None.

#### Xuint32 XAtmc\_GetOptions( XAtmc \* InstancePtr)

Gets Atmc driver/device options. The value returned is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The 32-bit value of the Atmc options. The value is a bit-mask representing all options that are currently enabled. See **xatmc.h** for a detailed description of the options.

#### Note:

None.

#### Xuint8 XAtmc\_GetPhyAddress( XAtmc \* InstancePtr)

Gets the PHY address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The 5-bit PHY address (0 - 31) currently being used by the ATM controller.

#### Note:

None.

Gets the value of the packet threshold register for this driver/device. The packet threshold is used for interrupt coalescing when the ATM controller is configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be copied. An output parameter. A value of 0 indicates the use of packet threshold by the

hardware is disabled.

#### **Returns:**

- o XST\_SUCCESS if the packet threshold was retrieved successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### **Note:**

None.

Gets the packet wait bound register for this driver/device. The packet wait bound is used for interrupt coalescing when the ATM controller is configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

WaitPtr is a pointer to the byte into which the current value of the packet wait bound register will

be copied. An output parameter. Units are in milliseconds in the range 0 - 1023. A value

of 0 indicates the packet wait bound timer is disabled.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### **Note:**

None.

```
void XAtmc_GetStats( XAtmc * InstancePtr,
XAtmc_Stats * StatsPtr
)
```

Gets a copy of the **XAtmc\_Stats** structure, which contains the current statistics for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

#### **Returns:**

None. Although the output parameter will contain a copy of the statistics upon return from this function.

#### Note:

None.

Xuint8 XAtmc\_GetUserDefined( XAtmc \* InstancePtr)

Gets the 2nd byte of the User Defined data in the ATM controller for the channel which is sending data. The ATM controller will attach the header to all cells which are being sent and do not have a header. The header of a 16 bit Utopia interface contains the User Defined data which is two bytes. The first byte contains the HEC field and the second byte is available for user data. This function only allows the second byte to be retrieved.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

The second byte of the User Defined data.

#### Note:

None.

Initializes a specific ATM controller instance/driver. The initialization entails:

- Initialize fields of the **XAtmc** structure
- Clear the ATM statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- Configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists will be passed to the driver.
- Reset the ATM controller

The only driver function that should be called before this Initialize function is called is GetInstance.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XAtmc** instance. Passing in a device id associates the generic **XAtmc** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS if initialization was successful
- o XST DEVICE IS STARTED if the device has already been started

#### Note:

None.

#### 

Looks up the device configuration based on the unique device ID. The table AtmcConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceId* contains the unique device ID that for the device. This ID is used to lookup the configuration.

#### **Returns:**

A pointer to the configuration for the specified device, or XNULL if the device could not be found.

#### **Note:**

None.

#### void XAtmc\_Reset( XAtmc \* InstancePtr)

Resets the ATM controller. It resets the DMA channels, the FIFOs, and the ATM controller. The reset does not remove any of the buffer descriptors from the scatter-gather list for DMA. Reset must only be called after the driver has been initialized.

The configuration after this reset is as follows:

- Disabled transmitter and receiver
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation
- PHY address of 0

The upper layer software is responsible for re-configuring (if necessary) and restarting the ATM controller after the reset.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

None.

#### Note:

The reset is accomplished by setting the IPIF reset register. This takes care of resetting all hardware blocks, including the ATM controller.

Performs a self-test on the ATM controller device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the ATM controller device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- o XST SUCCESS if self-test was successful
- o XST PFIFO BAD REG VALUE if the FIFO failed register self-test
- o XST\_DMA\_TRANSFER\_ERROR if DMA failed data transfer self-test
- XST\_DMA\_RESET\_REGISTER\_ERROR if DMA control register value was incorrect after a reset
- o XST\_REGISTER\_ERROR if the ATM controller failed register reset test
- o XST\_LOOPBACK\_ERROR if the ATM controller internal loopback failed
- o XST\_IPIF\_REG\_WIDTH\_ERROR if an invalid register width was passed into the function
- o XST\_IPIF\_RESET\_REGISTER\_ERROR if the value of a register at reset was invalid
- XST\_IPIF\_DEVICE\_STATUS\_ERROR if a write to the device status register did not read back correctly
- XST\_IPIF\_DEVICE\_ACK\_ERROR if a bit in the device status register did not reset when acked
- XST\_IPIF\_DEVICE\_ENABLE\_ERROR if the device interrupt enable register was not updated correctly by the hardware when other registers were written to
- XST\_IPIF\_IP\_STATUS\_ERROR if a write to the IP interrupt status register did not read back correctly
- XST\_IPIF\_IP\_ACK\_ERROR if one or more bits in the IP status register did not reset when acked
- XST\_IPIF\_IP\_ENABLE\_ERROR if the IP interrupt enable register was not updated correctly when other registers were written to

#### Note:

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

Sets the callback function for handling errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback which should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable ATM controller error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_ATMC\_ERROR\_COUNT\_MAX indicates the counters of the ATM controller have reached the maximum value and that the statistics of the ATM controller should be cleared.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Sets the send or receive ATM header in the ATM controller. If cells with only payloads are given to the controller to be sent, it will attach the header to the cells. If the ATM controller is configured appropriately, it will compare the header of received cells against the receive header and discard cells which don't match in the VCI and VPI fields of the header.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*Direction* indicates the direction, send(transmit) or receive, for the header to set.

Header contains the ATM header to be attached to each transmitted cell for cells with only

payloads or the expected header for cells which are received.

#### **Returns:**

- XST\_SUCCESS if the PHY address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

None.

Set Atmc driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option. A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off. See **xatmc.h** for a detailed description of the available options.

#### **Parameters:**

InstancePtr is a pointer to the **XAtmc** instance to be worked on.

OptionsFlag is a bit-mask representing the Atmc options to turn on or off

#### **Returns:**

- o XST SUCCESS if options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Sets the PHY address for this driver/device. The address is a 5-bit value. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on. *Address* contains the 5-bit PHY address (0 - 31).

#### **Returns:**

- o XST SUCCESS if the PHY address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

None.

Sets the packet count threshold register for this driver/device. The device must be stopped before setting the threshold. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

Threshold is the value of the packet threshold count used during interrupt coalescing. A value of 0 disables the use of packet threshold by the hardware.

#### **Returns:**

- XST\_SUCCESS if the threshold was successfully set
- o XST NOT SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_DMA\_SG\_COUNT\_EXCEEDED if the threshold must be equal to or less than the number of descriptors in the list
- o XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

None.

Sets the packet wait bound register for this driver/device. The device must be stopped before setting the timer value. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold.

The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound used during interrupt coalescing. It is in milliseconds in the range 0 - 1023. A value of 0 disables the packet wait bound timer.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was set successfully
- o XST NOT SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if an invalid direction was specified

#### Note:

None.

Sets the callback function for handling received cells in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of cells, determined by the DMA scatter-gather packet threshold, are received. The number of received cells is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each received cell from the list and should attach a new buffer to each descriptor. It is important that the specified number of cells passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are other potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Atmc driver. The memory space must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- o XST SUCCESS if the space was initialized successfully
- o XST NOT SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the XAtmc\_Initialize function because the DMA channel components must be initialized before the memory space is set.

```
void XAtmc_SetSgSendHandler( XAtmc * InstancePtr, void * CallBackRef, XAtmc_SgHandler FuncPtr )
```

Sets the callback function for handling confirmation of transmitted cells in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of cells, determined by the DMA scatter-gather packet threshold, are sent. The number of sent cells is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each sent cell from the list and should also free the buffers attached to the descriptors if necessary. It is important that the specified number of cells passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the application in the callback. This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Atmc driver. The memory space must be word-aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the ATM controller is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the XAtmc\_Initialize function because the DMA channel components must be initialized before the memory space is set.

Sets the 2nd byte of the User Defined data in the ATM controller for the channel which is sending data. The ATM controller will attach the header to all cells which are being sent and do not have a header. The header of a 16 bit Utopia interface contains the User Defined data which is two bytes. The first byte contains the HEC field and the second byte is available for user data. This function only allows the second byte to be set.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on. *UserDefined* contains the second byte of the User Defined data.

#### **Returns:**

- XST\_SUCCESS if the user-defined data was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

None.

#### XStatus XAtmc Start( XAtmc \* InstancePtr)

Starts the ATM controller as follows:

- If not in polled mode enable interrupts
- Enable the transmitter
- Enable the receiver
- Start the DMA channels if the descriptor lists are not empty

It is necessary for the caller to connect the interrupt servive routine of the ATM controller to the interrupt source, typically an interrupt controller, and enable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- o XST SUCCESS if the device was started successfully
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- XST\_DMA\_SG\_LIST\_EMPTY iff configured for scatter-gather DMA and no buffer descriptors have been put into the list for the receive channel.

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

#### XStatus XAtmc\_Stop( XAtmc \* InstancePtr)

Stops the ATM controller as follows:

- Stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode

It is the callers responsibility to disconnect the interrupt handler of the ATM controller from the interrupt source, typically an interrupt controller, and disable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XAtmc** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to stop the device, the user is required to provide protection of this shared data (typically using a semaphore).

Generated on 30 Sep 2003 for Xilinx Device Drivers

# atmc/v1\_00\_c/src/xatmc\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of ATMC devices in the system. Each ATMC device should have an entry in this table.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a JHL 07/31/01 First release

1.00b rpm 05/01/02 Condensed base addresses into one

1.00c rpm 01/08/03 New release supports v2.00a of packet fifo driver an v1.23b of the IPIF driver
```

```
#include "xatmc.h"
#include "xparameters.h"
```

## **Variables**

XAtmc\_Config XAtmc\_ConfigTable [XPAR\_XATMC\_NUM\_INSTANCES]

## **Variable Documentation**

### XAtmc\_Config XAtmc\_ConfigTable[XPAR\_XATMC\_NUM\_INSTANCES]

This table contains configuration information for each ATMC device in the system.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# atmc/v1\_00\_c/src/xatmc\_l.c File Reference

## **Detailed Description**

This file contains low-level polled functions to send and receive ATM cells.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 05/01/02 First release

#include "xatmc 1.h"
```

## **Functions**

```
void XAtmc_SendCell (Xuint32 BaseAddress, Xuint8 *CellPtr, int Size)
int XAtmc_RecvCell (Xuint32 BaseAddress, Xuint8 *CellPtr, Xuint32 *CellStatusPtr)
```

## **Function Documentation**

```
int XAtmc_RecvCell( Xuint32 BaseAddress,
Xuint8 * CellPtr,
Xuint32 * CellStatusPtr
)
```

Receive a cell. Wait for a cell to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

*CellPtr* is a pointer to a word-aligned buffer where the cell will be stored.

CellStatusPtr is a pointer to a cell status that will be valid after this function returns.

#### **Returns:**

The size, in bytes, of the cell received.

#### **Note:**

None.

Send an ATM cell. This function blocks waiting for the cell to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device CellPtr is a pointer to word-aligned cell Size is the size, in bytes, of the cell

#### **Returns:**

None.

#### **Note:**

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## emac/v1\_00\_d/src/xemac.h File Reference

## **Detailed Description**

The Xilinx Ethernet driver component. This component supports the Xilinx Ethernet 10/100 MAC (EMAC).

The Xilinx Ethernet 10/100 MAC supports the following features:

- Simple and scatter-gather DMA operations, as well as simple memory mapped direct I/O interface (FIFOs).
- Media Independent Interface (MII) for connection to external 10/100 Mbps PHY transceivers.
- MII management control reads and writes with MII PHYs
- Independent internal transmit and receive FIFOs
- CSMA/CD compliant operations for half-duplex modes
- Programmable PHY reset signal
- Unicast, broadcast, and promiscuous address filtering
- Reception of all multicast addresses (no multicast filtering yet) (NOTE: EMAC core may not support this check the specification)
- Internal loopback
- Automatic source address insertion or overwrite (programmable)
- Automatic FCS insertion and stripping (programmable)
- Automatic pad insertion and stripping (programmable)
- Pause frame (flow control) detection in full-duplex mode
- Programmable interframe gap
- VLAN frame support.
- Pause frame support

The device driver supports all the features listed above.

#### **Driver Description**

The device driver enables higher layer software (e.g., an application) to communicate to the EMAC. The driver handles transmission and reception of Ethernet frames, as well as configuration of the controller. It does not handle protocol stack functionality such as Link Layer Control (LLC) or the Address Resolution Protocol (ARP). The protocol stack that makes use of the driver handles this functionality. This implies that the driver is simply a pass-through mechanism between a protocol stack and the EMAC. A single device driver can support multiple EMACs.

The driver is designed for a zero-copy buffer scheme. That is, the driver will not copy buffers. This avoids potential throughput bottlenecks within the driver.

Since the driver is a simple pass-through mechanism between a protocol stack and the EMAC, no assembly or disassembly of Ethernet frames is done at the driver-level. This assumes that the protocol stack passes a correctly formatted Ethernet frame to the driver for transmission, and that the driver does not validate the contents of an incoming frame

#### **Buffer Alignment**

It is important to note that when using direct FIFO communication (either polled or interrupt-driven), packet buffers must be 32-bit aligned. When using DMA and the OPB 10/100 Ethernet core, packet buffers must be 32-bit aligned. When using DMA and the PLB 10/100 Ethernet core, packet buffers must be 64-bit aligned. When using scatter-gather DMA, the buffer descriptors must be 32-bit aligned (for either the OPB or the PLB core). The driver may not enforce this alignment and it is up to the user to guarantee the proper alignment.

#### **PHY Communication**

The driver provides rudimentary read and write functions to allow the higher layer software to access the PHY. The EMAC provides MII registers for the driver to access. This management interface can be parameterized away in the FPGA implementation process. If this is the case, the PHY read and write functions of the driver return XST\_NO\_FEATURE.

External loopback is usually supported at the PHY. It is up to the user to turn external loopback on or off at the PHY. The driver simply provides pass- through functions for configuring the PHY. The driver does not read, write, or reset the PHY on its own. All control of the PHY must be done by the user.

#### **Asynchronous Callbacks**

The driver services interrupts and passes Ethernet frames to the higher layer software through asynchronous callback functions. When using the driver directly (i.e., not with the RTOS protocol stack), the higher layer software must register its callback functions during initialization. The driver requires callback functions for received frames, for confirmation of transmitted frames, and for asynchronous errors.

#### **Interrupts**

The driver has no dependencies on the interrupt controller. The driver provides two interrupt handlers.

XEmac\_IntrHandlerDma() handles interrupts when the EMAC is configured with scatter-gather DMA.

XEmac\_IntrHandlerFifo() handles interrupts when the EMAC is configured for direct FIFO I/O or simple DMA. Either of these routines can be connected to the system interrupt controller by the user.

#### **Interrupt Frequency**

When the EMAC is configured with scatter-gather DMA, the frequency of interrupts can be controlled with the interrupt coalescing features of the scatter-gather DMA engine. The frequency of interrupts can be adjusted using the driver API functions for setting the packet count threshold and the packet wait bound values.

The scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case.

The packet wait bound is a timer value used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold.

These values can be tuned by the user to meet their needs. If there appear to be interrupt latency problems or delays in packet arrival that are longer than might be expected, the user should verify that the packet count threshold is set low enough to receive interrupts before the wait bound timer goes off.

#### **Device Reset**

Some errors that can occur in the device require a device reset. These errors are listed in the **XEmac\_SetErrorHandler**() function header. The user's error handler is responsible for resetting the device and re-configuring it based on its needs (the driver does not save the current configuration). When integrating into an RTOS, these reset and re-configure obligations are taken care of by the Xilinx adapter software if it exists for that RTOS.

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. Configuration parameters are stored in the **xemac\_g.c** files. A table is defined where each entry contains configuration information for an EMAC device. This information includes such things as the base address of the memory-mapped device, the base addresses of IPIF, DMA, and FIFO modules within the device, and whether the device has DMA, counter registers, multicast support, MII support, and flow control.

The driver tries to use the features built into the device. So if, for example, the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels and expects that the user has set up the buffer descriptor lists already. If the user expects to use the driver in a mode different than how the hardware is configured, the user should modify the configuration table to reflect the mode to be used. Modifying the configuration table is a workaround for now until we get some experience with how users are intending to use the hardware in its different configurations. For example, if the hardware is built with scatter-gather DMA but the user is intending to use only simple DMA, the user either needs to modify the config table as a workaround or rebuild the hardware with only simple DMA. The recommendation at this point is to build the hardware with the features you intend to use. If you're inclined to modify the table, do so before the call to XEmac\_Initialize(). Here is a snippet of code that changes a device to simple DMA (the hardware needs to have DMA for this to work of course):

```
XEmac_Config *ConfigPtr;
ConfigPtr = XEmac_LookupConfig(DeviceId);
ConfigPtr->IpIfDmaConfig = XEM_CFG_SIMPLE_DMA;
```

#### **Simple DMA**

Simple DMA is supported through the FIFO functions, FifoSend and FifoRecv, of the driver (i.e., there is no separate interface for it). The driver makes use of the DMA engine for a simple DMA transfer if the device is configured with DMA, otherwise it uses the FIFOs directly. While the simple DMA interface is therefore transparent to the user, the caching of network buffers is not. If the device is configured with DMA and the FIFO interface is used, the user must ensure that the network buffers are not cached or are cache coherent, since DMA will be used to transfer to and from the Emac device. If the device is configured with DMA and the user really wants to use the FIFOs directly, the user should rebuild the hardware without DMA. If unable to do this, there is a workaround (described above in Device Configuration) to modify the configuration table of the driver to fake the driver into thinking the device has no DMA. A code snippet follows:

```
XEmac_Config *ConfigPtr;
ConfigPtr = XEmac_LookupConfig(DeviceId);
ConfigPtr->IpIfDmaConfig = XEM_CFG_NO_DMA;
```

#### **Asserts**

Asserts are used within all Xilinx drivers to enforce constraints on argument values. Asserts can be turned off on a system-wide basis by defining, at compile time, the NDEBUG identifier. By default, asserts are turned on and it is recommended that users leave asserts on during development.

#### **Building the driver**

The **XEmac** driver is composed of several source files. Why so many? This allows the user to build and link only those parts of the driver that are necessary. Since the EMAC hardware can be configured in various ways (e.g., with or without DMA), the driver too can be built with varying features. For the most part, this means that besides always linking in **xemac.c**, you link in only the driver functionality you want. Some of the choices you have are polled vs. interrupt, interrupt with FIFOs only vs. interrupt with DMA, self-test diagnostics, and driver statistics. Note that currently the DMA code must be linked in, even if

you don't have DMA in the device.

#### Note:

Xilinx drivers are typically composed of two components, one is the driver and the other is the adapter. The driver is independent of OS and processor and is intended to be highly portable. The adapter is OS-specific and facilitates communication between the driver and an OS.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xstatus.h"
#include "xparameters.h"
#include "xpacket_fifo_v2_00_a.h"
#include "xdma_channel.h"
```

### **Data Structures**

```
struct XEmac struct XEmac_Config struct XEmac_Stats
```

## **Configuration options**

Device configuration options (see the **XEmac\_SetOptions**() and **XEmac\_GetOptions**() for information on how to use these options)

```
#define XEM_UNICAST_OPTION
#define XEM_BROADCAST_OPTION
#define XEM_PROMISC_OPTION
#define XEM_FDUPLEX_OPTION
```

```
#define XEM_POLLED_OPTION

#define XEM_LOOPBACK_OPTION

#define XEM_MULTICAST_OPTION

#define XEM_FLOW_CONTROL_OPTION

#define XEM_INSERT_PAD_OPTION

#define XEM_INSERT_FCS_OPTION

#define XEM_INSERT_ADDR_OPTION

#define XEM_OVWRT_ADDR_OPTION

#define XEM_STRIP_PAD_FCS_OPTION
```

## Typedefs for callbacks

Callback functions.

```
typedef void(* XEmac_SgHandler )(void *CallBackRef, XBufDescriptor *BdPtr, Xuint32 NumBds) typedef void(* XEmac_FifoHandler )(void *CallBackRef) typedef void(* XEmac_ErrorHandler )(void *CallBackRef, XStatus ErrorCode)
```

## **Defines**

```
#define XEmac_mIsSgDma(InstancePtr)
#define XEmac_mIsSimpleDma(InstancePtr)
#define XEmac_mIsDma(InstancePtr)
```

## **Functions**

```
XStatus XEmac_Initialize (XEmac *InstancePtr, Xuint16 DeviceId)
        XStatus XEmac_Start (XEmac *InstancePtr)
        XStatus XEmac_Stop (XEmac *InstancePtr)
            void XEmac_Reset (XEmac *InstancePtr)
XEmac_Config * XEmac_LookupConfig (Xuint16 DeviceId)
        XStatus XEmac SelfTest (XEmac *InstancePtr)
        XStatus XEmac_PollSend (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
        XStatus XEmac PollRecv (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
        XStatus XEmac_SgSend (XEmac *InstancePtr, XBufDescriptor *BdPtr, int Delay)
        XStatus XEmac SgRecv (XEmac *InstancePtr, XBufDescriptor *BdPtr)
        XStatus XEmac_SetPktThreshold (XEmac *InstancePtr, Xuint32 Direction, Xuint8 Threshold)
        XStatus XEmac GetPktThreshold (XEmac *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)
        XStatus XEmac_SetPktWaitBound (XEmac *InstancePtr, Xuint32 Direction, Xuint32 TimerValue)
        XStatus XEmac GetPktWaitBound (XEmac *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)
        XStatus XEmac_SetSgRecvSpace (XEmac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
        XStatus XEmac_SetSgSendSpace (XEmac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
            void XEmac SetSgRecvHandler (XEmac *InstancePtr, void *CallBackRef, XEmac SgHandler FuncPtr)
            void XEmac_SetSgSendHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_SgHandler FuncPtr)
            void XEmac IntrHandlerDma (void *InstancePtr)
        XStatus XEmac_FifoSend (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
```

```
XStatus XEmac FifoRecv (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
   void XEmac_SetFifoRecvHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_FifoHandler FuncPtr)
   void XEmac SetFifoSendHandler (XEmac *InstancePtr, void *CallBackRef, XEmac FifoHandler FuncPtr)
   void XEmac_IntrHandlerFifo (void *InstancePtr)
   void XEmac_SetErrorHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_ErrorHandler FuncPtr)
XStatus XEmac_SetOptions (XEmac *InstancePtr, Xuint32 OptionFlag)
Xuint32 XEmac GetOptions (XEmac *InstancePtr)
XStatus XEmac_SetMacAddress (XEmac *InstancePtr, Xuint8 *AddressPtr)
   void XEmac GetMacAddress (XEmac *InstancePtr, Xuint8 *BufferPtr)
XStatus XEmac_SetInterframeGap (XEmac *InstancePtr, Xuint8 Part1, Xuint8 Part2)
   void XEmac_GetInterframeGap (XEmac *InstancePtr, Xuint8 *Part1Ptr, Xuint8 *Part2Ptr)
XStatus XEmac_MulticastAdd (XEmac *InstancePtr, Xuint8 *AddressPtr)
XStatus XEmac_MulticastClear (XEmac *InstancePtr)
XStatus XEmac_PhyRead (XEmac *InstancePtr, Xuint32 PhyAddress, Xuint32 RegisterNum, Xuint16
        *PhyDataPtr)
XStatus XEmac_PhyWrite (XEmac *InstancePtr, Xuint32 PhyAddress, Xuint32 RegisterNum, Xuint16 PhyData)
   void XEmac_GetStats (XEmac *InstancePtr, XEmac_Stats *StatsPtr)
   void XEmac ClearStats (XEmac *InstancePtr)
```

## **Define Documentation**

#### #define XEM\_BROADCAST\_OPTION

Broadcast addressing (defaults on)

#### #define XEM\_FDUPLEX\_OPTION

Full duplex mode (defaults off)

#### #define XEM\_FLOW\_CONTROL\_OPTION

Interpret pause frames in full duplex mode (defaults off)

#### #define XEM\_INSERT\_ADDR\_OPTION

Insert source address on transmit (defaults on)

#### **#define XEM INSERT FCS OPTION**

Insert FCS (CRC) on transmit (defaults on)

#### #define XEM\_INSERT\_PAD\_OPTION

Pad short frames on transmit (defaults on)

#### #define XEM\_LOOPBACK\_OPTION

Internal loopback mode (defaults off)

#### #define XEM\_MULTICAST\_OPTION

Multicast address reception (defaults off)

#### #define XEM\_OVWRT\_ADDR\_OPTION

Overwrite source address on transmit. This is only used only used if source address insertion is on (defaults on)

#### #define XEM\_POLLED\_OPTION

Polled mode (defaults off)

#### #define XEM PROMISC OPTION

Promiscuous addressing (defaults off)

#### #define XEM\_STRIP\_PAD\_FCS\_OPTION

Strip FCS and padding from received frames (defaults off)

#### #define XEM UNICAST OPTION

Unicast addressing (defaults on)

#### #define XEmac\_mIsDma( InstancePtr )

This macro determines if the device is currently configured with DMA (either simple DMA or scatter-gather DMA)

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured with DMA, or XFALSE otherwise

#### Note:

Signature: Xboolean **XEmac mIsDma**(XEmac \*InstancePtr)

#### #define XEmac\_mIsSgDma( InstancePtr )

This macro determines if the device is currently configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured for scatter-gather DMA, or XFALSE if it is not.

#### Note:

Signature: Xboolean XEmac\_mIsSgDma(XEmac \*InstancePtr)

#### #define XEmac\_mIsSimpleDma( InstancePtr )

This macro determines if the device is currently configured for simple DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured for simple DMA, or XFALSE otherwise

#### Note:

Signature: Xboolean XEmac\_mIsSimpleDma(XEmac \*InstancePtr)

## **Typedef Documentation**

#### typedef void(\* XEmac\_ErrorHandler)(void \*CallBackRef, XStatus ErrorCode)

Callback when an asynchronous error occurs.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked.

*ErrorCode* is a Xilinx error code defined in **xstatus.h**. Also see **XEmac\_SetErrorHandler**() for a description of possible errors.

#### typedef void(\* XEmac\_FifoHandler)(void \*CallBackRef)

Callback when data is sent or received with direct FIFO communication or simple DMA. The user typically defines two callacks, one for send and one for receive.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked.

#### typedef void(\* XEmac SgHandler)(void \*CallBackRef, XBufDescriptor \*BdPtr, Xuint32 NumBds)

Callback when data is sent or received with scatter-gather DMA.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed

back to the upper layer when the callback is invoked.

BdPtr is a pointer to the first buffer descriptor in a list of buffer descriptors.NumBds is the number of buffer descriptors in the list pointed to by BdPtr.

## **Function Documentation**

#### void XEmac\_ClearStats( XEmac \* InstancePtr)

Clear the XEmacStats structure for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

Receive an Ethernet frame into the buffer passed as an argument. This function is called in response to the callback function for received frames being called by the driver. The callback function is set up using SetFifoRecvHandler, and is invoked when the driver receives an interrupt indicating a received frame. The driver expects the upper layer software to call this function, FifoRecv, to receive the frame. The buffer supplied should be large enough to hold a maximum-size Ethernet frame.

The buffer into which the frame will be received must be 32-bit aligned. If using simple DMA and the PLB 10/100 Ethernet core, the buffer must be 64-bit aligned.

If the device is configured with DMA, simple DMA will be used to transfer the buffer from the Emac to memory. This means that this buffer should not be cached. See the comment section "Simple DMA" in **xemac.h** for more information.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains the size of the buffer on entry into the function and the size the received frame on return from the function.

#### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST NOT INTERRUPT if the device is not in interrupt mode
- o XST\_NO\_DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.
- o XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

The input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame using direct FIFO I/O or simple DMA with interrupts. The caller provides a contiguous-memory buffer and its length. The buffer must be 32-bit aligned. If using simple DMA and the PLB 10/100 Ethernet core, the buffer must be 64-bit aligned. The callback function set by using SetFifoSendHandler is invoked when the transmission is complete.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field.

If the device is configured with DMA, simple DMA will be used to transfer the buffer from memory to the Emac. This means that this buffer should not be cached. See the comment section "Simple DMA" in **xemac.h** for more information.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

#### **Returns:**

- o XST\_SUCCESS if the frame was successfully sent. An interrupt is generated when the EMAC transmits the frame and the driver calls the callback set with **XEmac SetFifoSendHandler**()
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST NOT INTERRUPT if the device is not in interrupt mode
- o XST\_FIFO\_NO\_ROOM if there is no room in the FIFO for this frame
- o XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

Get the interframe gap, parts 1 and 2. See the description of interframe gap above in **XEmac\_SetInterframeGap**().

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Part1Ptr is a pointer to an 8-bit buffer into which the interframe gap part 1 value will be copied.

Part2Ptr is a pointer to an 8-bit buffer into which the interframe gap part 2 value will be copied.

#### **Returns:**

None. The values of the interframe gap parts are copied into the output parameters.

Get the MAC address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufferPtr is an output parameter, and is a pointer to a buffer into which the current MAC address will be copied. The buffer must be at least 6 bytes.

#### **Returns:**

None.

#### Note:

None.

#### Xuint32 XEmac\_GetOptions( XEmac \* InstancePtr)

Get Ethernet driver/device options. The 32-bit value returned is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

The 32-bit value of the Ethernet options. The value is a bit-mask representing all options that are currently enabled. See **xemac.h** for a description of the available options.

#### Note:

None.

Get the value of the packet count threshold for this driver/device. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be copied. An output parameter. A value of 0 indicates the use of packet threshold by the hardware is disabled.

- o XST\_SUCCESS if the packet threshold was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA

XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
error.

#### Note:

None.

Get the packet wait bound timer for this driver/device. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case. The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

WaitPtr

is a pointer to the byte into which the current value of the packet wait bound register will be copied. An output parameter. Units are in milliseconds in the range 0 - 1023. A value of 0 indicates the packet wait bound timer is disabled.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

None.

Get a copy of the XEmacStats structure, which contains the current statistics for this driver. The statistics are only cleared at initialization or on demand using the **XEmac\_ClearStats()** function.

The DmaErrors and FifoErrors counts indicate that the device has been or needs to be reset. Reset of the device is the responsibility of the upper layer software.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

#### Returns:

None.

#### Note:

None.

Initialize a specific **XEmac** instance/driver. The initialization entails:

- Initialize fields of the XEmac structure
- Clear the Ethernet statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- If the device is configured with DMA, configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists may be passed to the driver.
- Reset the Ethernet MAC

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XEmac** instance. Passing in a device id associates the generic **XEmac** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

#### Note:

None.

#### void XEmac\_IntrHandlerDma( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured with scatter- gather DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, Send Packet FIFO, Recv DMA channel, or Send DMA channel. The packet FIFOs only interrupt during "deadlock" conditions.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance that just interrupted.

#### **Returns:**

None.

#### Note:

None.

#### void XEmac\_IntrHandlerFifo( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured for direct FIFO communication or simple DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, or Send Packet FIFO. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the MAC.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance that just interrupted.

#### **Returns:**

None.

#### Note:

None.

#### 

Lookup the device configuration based on the unique device ID. The table EmacConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID of the device being looked up.

#### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

#### Note:

None.

Add a multicast address to the list of multicast addresses from which the EMAC accepts frames. The EMAC uses a hash table for multicast address filtering. Obviously, the more multicast addresses that are added reduces the accuracy of the address filtering. The upper layer software that receives multicast frames should perform additional filtering when accuracy must be guaranteed. There is no way to retrieve a multicast address or the multicast address list once added. The upper layer software should maintain its own list of multicast addresses. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte multicast address.

#### **Returns:**

- o XST\_SUCCESS if the multicast address was added successfully
- o XST\_NO\_FEATURE if the device is not configured with multicast support
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

Not currently supported.

#### XStatus XEmac MulticastClear( XEmac \* InstancePtr)

Clear the hash table used by the EMAC for multicast address filtering. The entire hash table is cleared, meaning no multicast frames will be accepted after this function is called. If this function is used to delete one or more multicast addresses, the upper layer software is responsible for adding back those addresses still needed for address filtering. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- XST SUCCESS if the multicast address list was cleared
- o XST NO FEATURE if the device is not configured with multicast support
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

Not currently supported.

Read the current value of the PHY register indicated by the PhyAddress and the RegisterNum parameters. The MAC provides the driver with the ability to talk to a PHY that adheres to the Media Independent Interface (MII) as defined in the IEEE 802.3 standard.

#### **Parameters:**

```
InstancePtr is a pointer to the XEmac instance to be worked on.
```

*PhyAddress* is the address of the PHY to be read (supports multiple PHYs) *RegisterNum* is the register number, 0-31, of the specific PHY register to read

*PhyDataPtr* is an output parameter, and points to a 16-bit buffer into which the current value of the register will be copied.

#### **Returns:**

- XST\_SUCCESS if the PHY was read from successfully
- o XST NO FEATURE if the device is not configured with MII support
- o XST\_EMAC\_MII\_BUSY if there is another PHY operation in progress
- XST\_EMAC\_MII\_READ\_ERROR if a read error occurred between the MAC and the PHY

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that the read is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PhyRead thread.

Write data to the specified PHY register. The Ethernet driver does not require the device to be stopped before writing to the PHY. Although it is probably a good idea to stop the device, it is the responsibility of the application to deem this necessary. The MAC provides the driver with the ability to talk to a PHY that adheres to the Media Independent Interface (MII) as defined in the IEEE 802.3 standard.

#### **Parameters:**

InstancePtr is a pointer to the **XEmac** instance to be worked on.

PhyAddress is the address of the PHY to be written (supports multiple PHYs)

RegisterNum is the register number, 0-31, of the specific PHY register to write

PhyData is the 16-bit value that will be written to the register

#### **Returns:**

- XST\_SUCCESS if the PHY was written to successfully. Since there is no error status from the MAC on a
  write, the user should read the PHY to verify the write was successful.
- o XST\_NO\_FEATURE if the device is not configured with MII support
- o XST\_EMAC\_MII\_BUSY if there is another PHY operation in progress

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that the write is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PhyWrite thread.

Receive an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the frame directly from the MAC's packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The MAC's error status is not checked, so statistics are not updated for polled receive. The buffer into which the frame will be received must be 32-bit aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains the size of the buffer on entry into the function and the size the received frame on return from the function.

- o XST\_SUCCESS if the frame was sent successfully
- o XST DEVICE IS STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST NO DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the

Input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the frame directly to the MAC's packet FIFO, then enters a loop checking the device status for completion or error. Statistics are updated if an error occurs. The buffer to be sent must be 32-bit aligned.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

#### **Returns:**

- o XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST NOT POLLED if the device is not in polled mode
- XST\_FIFO\_NO\_ROOM if there is no room in the EMAC's length FIFO for this frame
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.
- XST\_EMAC\_COLLISION if the send failed due to excess deferral or late collision

#### Note:

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread. On a 10Mbps MAC, it takes about 1.21 msecs to transmit a maximum size Ethernet frame (1518 bytes). On a 100Mbps MAC, it takes about 121 usecs to transmit a maximum size Ethernet frame.

void XEmac\_Reset( XEmac \* InstancePtr)

Reset the Ethernet MAC. This is a graceful reset in that the device is stopped first. Resets the DMA channels, the FIFOs, the transmitter, and the receiver. The PHY is not reset. Any frames in the scatter-gather descriptor lists will remain in the lists. The side effect of doing this is that after a reset and following a restart of the device, frames that were in the list before the reset may be transmitted or received. Reset must only be called after the driver has been initialized.

The driver is also taken out of polled mode if polled mode was set. The user is responsible for re-configuring the driver into polled mode after the reset if desired.

The configuration after this reset is as follows:

- Half duplex
- Disabled transmitter and receiver
- Enabled PHY (the PHY is not reset)
- MAC transmitter does pad insertion, FCS insertion, and source address overwrite.
- MAC receiver does not strip padding or FCS
- Interframe Gap as recommended by IEEE Std. 802.3 (96 bit times)
- Unicast addressing enabled
- Broadcast addressing enabled
- Multicast addressing disabled (addresses are preserved)
- Promiscuous addressing disabled
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation
- MAC address of all zeros
- Non-polled mode

The upper layer software is responsible for re-configuring (if necessary) and restarting the MAC after the reset. Note that the PHY is not reset. PHY control is left to the upper layer software. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

#### **Parameters:**

None.

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

| Retu  |       |  |  |  |  |
|-------|-------|--|--|--|--|
|       | None. |  |  |  |  |
| Note: |       |  |  |  |  |

XStatus XEmac\_SelfTest( XEmac \* InstancePtr)

Performs a self-test on the Ethernet device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the Ethernet device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

| XST_SUCCESS  XST_PFIFO_BAD_REG_VALUE  XST_DMA_TRANSFER_ERROR  XST_DMA_RESET_REGISTER_ERROR | Self-test was successful FIFO failed register self-test DMA failed data transfer self-test DMA control register value was incorrect |
|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| XST_REGISTER_ERROR                                                                         | after a reset Ethernet failed register reset test                                                                                   |
| XST_LOOPBACK_ERROR                                                                         | Internal loopback failed                                                                                                            |
| XST_IPIF_REG_WIDTH_ERROR                                                                   | An invalid register width was passed into the function                                                                              |
| XST_IPIF_RESET_REGISTER_ERROR                                                              | The value of a register at reset was invalid                                                                                        |
| XST_IPIF_DEVICE_STATUS_ERROR                                                               | A write to the device status register did not read back correctly                                                                   |
| XST_IPIF_DEVICE_ACK_ERROR                                                                  | A bit in the device status register did not reset when acked                                                                        |
| XST_IPIF_DEVICE_ENABLE_ERROR                                                               | The device interrupt enable register was not updated correctly by the hardware when other registers were written to                 |
| XST_IPIF_IP_STATUS_ERROR                                                                   | A write to the IP interrupt status register did not read back correctly                                                             |
| XST_IPIF_IP_ACK_ERROR                                                                      | One or more bits in the IP status register did not reset when acked                                                                 |
| XST_IPIF_IP_ENABLE_ERROR                                                                   | The IP interrupt enable register was not updated correctly when other registers were written to                                     |

#### Note:

This function makes use of options-related functions, and the **XEmac\_PollSend()** and **XEmac\_PollRecv()** functions.

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

```
void XEmac_SetErrorHandler( XEmac * InstancePtr,
void * CallBackRef,
XEmac_ErrorHandler FuncPtr
)
```

Set the callback function for handling asynchronous errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable MAC error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_DMA\_SG\_NO\_LIST indicates an attempt was made to access a scatter-gather DMA list that has not yet been
  created.
- XST\_DMA\_SG\_LIST\_EMPTY indicates the driver tried to get a descriptor from the receive descriptor list, but the list was empty.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

```
void XEmac_SetFifoRecvHandler( XEmac * InstancePtr,
void * CallBackRef,
XEmac_FifoHandler FuncPtr
)
```

Set the callback function for handling confirmation of transmitted frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called by the driver once per frame sent. The callback is responsible for freeing the transmitted buffer if necessary.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

*FuncPtr* is the pointer to the callback function.

**Returns:** 

None.

Note:

None.

Set the callback function for handling received frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called once per frame received. During the callback, the upper layer software should call FifoRecv to retrieve the received frame.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

is the pointer to the callback function.

**Returns:** 

None.

FuncPtr 1

**Note:** 

None.

Set the Interframe Gap (IFG), which is the time the MAC delays between transmitting frames. There are two parts required. The total interframe gap is the total of the two parts. The values provided for the Part1 and Part2 parameters are multiplied by 4 to obtain the bit-time interval. The first part should be the first 2/3 of the total interframe gap. The MAC will reset the interframe gap timer if carrier sense becomes true during the period defined by interframe gap Part1. Part1 may be shorter than 2/3 the total and can be as small as zero. The second part should be the last 1/3 of the total interframe gap, but can be as large as the total interframe gap. The MAC will not reset the interframe gap timer if carrier sense becomes true during the period defined by interframe gap Part2.

The device must be stopped before setting the interframe gap.

#### Parameters:

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Part1 is the interframe gap part 1 (which will be multiplied by 4 to get the bit-time interval).

*Part2* is the interframe gap part 2 (which will be multiplied by 4 to get the bit-time interval).

#### **Returns:**

- o XST\_SUCCESS if the interframe gap was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped

#### **Note:**

None.

Set the MAC address for this driver/device. The address is a 48-bit value. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte MAC address.

#### **Returns:**

- o XST\_SUCCESS if the MAC address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

None.

Set Ethernet driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option (i.e., you can OR the options together). A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

OptionsFlag is a bit-mask representing the Ethernet options to turn on or off. See **xemac.h** for a description of the available options.

#### **Returns:**

- o XST SUCCESS if the options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Set the packet count threshold for this device. The device must be stopped before setting the threshold. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

Threshold is the value of the packet threshold count used during interrupt coalescing. A value of 0 disables the use of packet threshold by the hardware.

#### **Returns:**

- o XST\_SUCCESS if the threshold was successfully set
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

#### Note:

The packet threshold could be set to larger than the number of descriptors allocated to the DMA channel. In this case, the wait bound will take over and always indicate data arrival. There was a check in this function that returned an error if the treshold was larger than the number of descriptors, but that was removed because users would then have to set the threshold only after they set descriptor space, which is an order dependency that caused confustion.

Set the packet wait bound timer for this driver/device. The device must be stopped before setting the timer value. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case. The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound used during interrupt coalescing. It is in milliseconds in the range 0 - 1023. A value of 0 disables the packet wait bound timer.

- XST\_SUCCESS if the packet wait bound was set successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

None.

Set the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame received. The head of a descriptor list is passed in along with the number of descriptors in the list. Before leaving the callback, the upper layer software should attach a new buffer to each descriptor in the list.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Give the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be 32-bit aligned. An assert will occur if asserts are turned on and the memory is not aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*MemoryPtr* is a pointer to the aligned memory.

ByteCount is the length, in bytes, of the memory space.

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XEmac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

```
void XEmac_SetSgSendHandler( XEmac * InstancePtr, void * CallBackRef, XEmac_SgHandler FuncPtr
```

Set the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame sent. The head of a descriptor list is passed in along with the number of descriptors in the list. The callback is responsible for freeing buffers attached to these descriptors.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Give the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be 32-bit aligned. An assert will occur if asserts are turned on and the memory is not aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*MemoryPtr* is a pointer to the aligned memory.

ByteCount is the length, in bytes, of the memory space.

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XEmac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Add a descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be 32-bit aligned if using the OPB Ethernet core and 64-bit aligned if using the PLB Ethernet core. This function is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. This function can be called when the device is started or stopped. Note that it does start the scatter- gather DMA engine. Although this is not necessary during initialization, it is not a problem during initialization because the MAC receiver is not yet started.

The buffer attached to the descriptor must be aligned on both the front end and the back end.

Notification of received frames are done asynchronously through the receive callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

#### **Returns:**

- o XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

Send an Ethernet frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire Ethernet frame may or may not be contained within one descriptor. This function simply inserts the descriptor into the scatter- gather engine's transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor must be 32-bit aligned if using the OPB Ethernet core and 64-bit aligned if using the PLB Ethernet core.

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

This call is non-blocking. Notification of error or successful transmission is done asynchronously through the send or error callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

Delay indicates whether to start the scatter-gather DMA channel immediately, or whether to wait. This allows the user to build up a list of more than one descriptor before starting the transmission of the packets, which allows the application to keep up with DMA and have a constant stream of frames being transmitted. Use XEM\_SGDMA\_NODELAY or XEM\_SGDMA\_DELAY, defined in xemac.h, as the value of this argument. If the user chooses to delay and build a list, the user must call this function with the XEM\_SGDMA\_NODELAY option or call XEmac\_Start() to kick off the transmissions.

#### **Returns:**

- o XST\_SUCCESS if the buffer was successfull sent
- o XST\_DEVICE\_IS\_STOPPED if the Ethernet MAC has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA
  channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread
  mutual exclusion problem on transmit.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

#### XStatus XEmac\_Start( XEmac \* InstancePtr)

Start the Ethernet controller as follows:

- If not in polled mode
  - o Set the internal interrupt enable registers appropriately
  - Enable interrupts within the device itself. Note that connection of the driver's interrupt handler to the interrupt source (typically done using the interrupt controller component) is done by the higher layer software.
  - o If the device is configured with scatter-gather DMA, start the DMA channels if the descriptor lists are not empty
- Enable the transmitter
- Enable the receiver

The PHY is enabled after driver initialization. We assume the upper layer software has configured it and the EMAC appropriately before this function is called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

- o XST SUCCESS if the device was started successfully
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function.
   This is required if in interrupt mode.
- o XST DEVICE IS STARTED if the device is already started

 XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.

#### Note:

The driver tries to match the hardware configuration. So if the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels and expects that the user has set up the buffer descriptor lists already. If the user expects to use the driver in a mode different than how the hardware is configured, the user should modify the configuration table to reflect the mode to be used. Modifying the config table is a workaround for now until we get some experience with how users are intending to use the hardware in its different configurations. For example, if the hardware is built with scatter-gather DMA but the user is intending to use only simple DMA, the user either needs to modify the config table as a workaround or rebuild the hardware with only simple DMA.

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

#### XStatus XEmac\_Stop( XEmac \* InstancePtr)

Stop the Ethernet MAC as follows:

- If the device is configured with scatter-gather DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

The PHY is left enabled after a Stop is called.

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the Ethernet frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

#### **Note:**

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

## emac/v1\_00\_d/src/xemac\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of EMAC devices in the system.

MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes                                                 |
|-------|-----|----------|---------------------------------------------------------|
|       |     |          |                                                         |
| 1.00a | rpm | 07/31/01 | First release                                           |
| 1.00b | rpm | 02/20/02 | Repartitioned files and functions                       |
| 1.00c | rpm | 12/05/02 | New version includes support for simple DMA             |
| 1.00d | rpm | 09/26/03 | New version includes support PLB Ethernet and v2.00a of |
|       |     |          | the packet fifo driver.                                 |
|       |     |          |                                                         |

```
#include "xemac.h"
#include "xparameters.h"
```

## **Variables**

XEmac\_Config XEmac\_ConfigTable [XPAR\_XEMAC\_NUM\_INSTANCES]

## **Variable Documentation**

#### XEmac\_Config XEmac\_ConfigTable[XPAR\_XEMAC\_NUM\_INSTANCES]

This table contains configuration information for each EMAC device in the system.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XEmac\_Config Struct Reference

#include <xemac.h>

## **Detailed Description**

This typedef contains configuration information for a device.

## **Data Fields**

**Xuint16 DeviceId** 

**Xuint32 BaseAddress** 

**Xboolean HasCounters** 

Xuint8 IpIfDmaConfig

Xboolean HasMii

## **Field Documentation**

**Xuint32 XEmac\_Config::BaseAddress** 

Register base address

Xuint16 XEmac\_Config::DeviceId

Unique ID of device

**Xboolean XEmac\_Config::HasCounters** 

Does device have counters?

### **Xboolean XEmac\_Config::HasMii**

Does device support MII?

### Xuint8 XEmac\_Config::IpIfDmaConfig

IPIF/DMA hardware configuration

The documentation for this struct was generated from the following file:

• emac/v1\_00\_d/src/xemac.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

## emac/v1\_00\_d/src/xemac.c File Reference

## **Detailed Description**

The **XEmac** driver. Functions in this file are the minimum required functions for this driver. See **xemac.h** for a detailed description of the driver.

#### MODIFICATION HISTORY:

```
Ver Who Date
                   Changes
1.00a rpm 07/31/01 First release
1.00b rpm 02/20/02 Repartitioned files and functions
1.00b rpm 07/23/02 Removed the PHY reset from Initialize()
1.00b rmm 09/23/02 Removed commented code in Initialize(). Recycled as
                    XEmac_mPhyReset macro in xemac_1.h.
1.00c rpm 12/05/02 New version includes support for simple DMA
1.00c rpm 12/12/02 Changed location of IsStarted assignment in XEmac Start
                    to be sure the flag is set before the device and
                    interrupts are enabled.
1.00c rpm 02/03/03 SelfTest was not clearing polled mode. Take driver out
                    of polled mode in XEmac_Reset() to fix this problem.
1.00c rmm 05/13/03 Fixed diab compiler warnings relating to asserts.
1.00d rpm 09/26/03 New version includes support PLB Ethernet and v2.00a of
                    the packet fifo driver.
```

```
#include "xbasic_types.h"
#include "xemac_i.h"
#include "xio.h"
#include "xipif_v1_23_b.h"
```

## **Functions**

XStatus XEmac\_Initialize (XEmac \*InstancePtr, Xuint16 DeviceId)
XStatus XEmac Start (XEmac \*InstancePtr)

```
XStatus XEmac_Stop (XEmac *InstancePtr)
void XEmac_Reset (XEmac *InstancePtr)
XStatus XEmac_SetMacAddress (XEmac *InstancePtr, Xuint8 *AddressPtr)
void XEmac_GetMacAddress (XEmac *InstancePtr, Xuint8 *BufferPtr)
XEmac_Config * XEmac_LookupConfig (Xuint16 DeviceId)
```

## **Function Documentation**

```
void XEmac_GetMacAddress( XEmac * InstancePtr,
Xuint8 * BufferPtr
)
```

Get the MAC address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufferPtr is an output parameter, and is a pointer to a buffer into which the current MAC address will be copied. The buffer must be at least 6 bytes.

#### **Returns:**

None.

#### Note:

None.

Initialize a specific **XEmac** instance/driver. The initialization entails:

- Initialize fields of the XEmac structure
- Clear the Ethernet statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- If the device is configured with DMA, configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists may be passed to the driver.
- Reset the Ethernet MAC

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*DeviceId* 

is the unique id of the device controlled by this **XEmac** instance. Passing in a device id associates the generic **XEmac** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

#### Note:

None.

#### 

Lookup the device configuration based on the unique device ID. The table EmacConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceId* is the unique device ID of the device being looked up.

#### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

#### Note:

None.

#### void XEmac\_Reset( XEmac \* InstancePtr)

Reset the Ethernet MAC. This is a graceful reset in that the device is stopped first. Resets the DMA channels, the FIFOs, the transmitter, and the receiver. The PHY is not reset. Any frames in the scatter-gather descriptor lists will remain in the lists. The side effect of doing this is that after a reset and following a restart of the device, frames that were in the list before the reset may be transmitted or received. Reset must only be called after the driver has been initialized.

The driver is also taken out of polled mode if polled mode was set. The user is responsible for re-configuring the driver into polled mode after the reset if desired.

The configuration after this reset is as follows:

- Half duplex
- Disabled transmitter and receiver
- Enabled PHY (the PHY is not reset)
- MAC transmitter does pad insertion, FCS insertion, and source address overwrite.
- MAC receiver does not strip padding or FCS

- Interframe Gap as recommended by IEEE Std. 802.3 (96 bit times)
- Unicast addressing enabled
- Broadcast addressing enabled
- Multicast addressing disabled (addresses are preserved)
- Promiscuous addressing disabled
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation
- MAC address of all zeros
- Non-polled mode

The upper layer software is responsible for re-configuring (if necessary) and restarting the MAC after the reset. Note that the PHY is not reset. PHY control is left to the upper layer software. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

Set the MAC address for this driver/device. The address is a 48-bit value. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte MAC address.

#### **Returns:**

- XST\_SUCCESS if the MAC address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

Start the Ethernet controller as follows:

- If not in polled mode
  - o Set the internal interrupt enable registers appropriately
  - Enable interrupts within the device itself. Note that connection of the driver's interrupt handler to the interrupt source (typically done using the interrupt controller component) is done by the higher layer software.
  - o If the device is configured with scatter-gather DMA, start the DMA channels if the descriptor lists are not empty
- Enable the transmitter
- Enable the receiver

The PHY is enabled after driver initialization. We assume the upper layer software has configured it and the EMAC appropriately before this function is called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was started successfully
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function. This is required if in interrupt mode.
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- o XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.

#### Note:

The driver tries to match the hardware configuration. So if the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels and expects that the user has set up the buffer descriptor lists already. If the user expects to use the driver in a mode different than how the hardware is configured, the user should modify the configuration table to reflect the mode to be used. Modifying the config table is a workaround for now until we get some experience with how users are intending to use the hardware in its different configurations. For example, if the hardware is built with scatter-gather DMA but the user is intending to use only simple DMA, the user either needs to modify the config table as a workaround or rebuild the hardware with only simple DMA.

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

XStatus XEmac\_Stop( XEmac \* InstancePtr)

#### Stop the Ethernet MAC as follows:

- If the device is configured with scatter-gather DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

The PHY is left enabled after a Stop is called.

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the Ethernet frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# **XEmac Struct Reference**

#include <xemac.h>

# **Detailed Description**

The XEmac driver instance data. The user is required to allocate a variable of this type for every EMAC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• emac/v1\_00\_d/src/xemac.h

# emac/v1\_00\_d/src/xemac\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xemac.h**.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xio.h"
```

# **Defines**

```
#define XEmac_mReadReg(BaseAddress, RegOffset)
#define XEmac_mWriteReg(BaseAddress, RegOffset, Data)
#define XEmac_mSetControlReg(BaseAddress, Mask)
#define XEmac_mSetMacAddress(BaseAddress, AddressPtr)
#define XEmac_mEnable(BaseAddress)
#define XEmac_mDisable(BaseAddress)
#define XEmac_mIsTxDone(BaseAddress)
#define XEmac_mIsRxEmpty(BaseAddress)
#define XEmac_mIsRxEmpty(BaseAddress)
#define XEmac_mPhyReset(BaseAddress)
```

# **Functions**

```
void XEmac_SendFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, int Size)
int XEmac_RecvFrame (Xuint32 BaseAddress, Xuint8 *FramePtr)
```

| Define Documentation                                                                 |
|--------------------------------------------------------------------------------------|
| #define XEmac_mDisable( BaseAddress )                                                |
| Disable the transmitter and receiver. Preserve the contents of the control register. |
| Parameters:  BaseAddress is the base address of the device                           |
| Returns: None.                                                                       |
| Note: None.                                                                          |
| #define XEmac_mEnable( BaseAddress )                                                 |
| Enable the transmitter and receiver. Preserve the contents of the control register.  |
| Parameters:                                                                          |
| BaseAddress is the base address of the device                                        |
| Returns:                                                                             |
| None.                                                                                |
| Note:                                                                                |
| None.                                                                                |

## #define XEmac\_mIsRxEmpty( BaseAddress )

| Parameters:  BaseAddress is the base address of the device |
|------------------------------------------------------------|
| Returns:  XTRUE if it is empty, or XFALSE if it is not.    |
| Note: None.                                                |
| #define XEmac_mIsTxDone( BaseAddress )                     |
| Check to see if the transmission is complete.              |
| Parameters:  BaseAddress is the base address of the device |
| Returns:  XTRUE if it is done, or XFALSE if it is not.     |
| Note: None.                                                |
| #define XEmac_mPhyReset( BaseAddress )                     |
| Reset MII compliant PHY                                    |
| Parameters:  BaseAddress is the base address of the device |
| Returns: None.                                             |
| Note: None.                                                |
| #define XEmac_mReadReg( BaseAddress,                       |

Check to see if the receive FIFO is empty.

| Read the given register.                                                                                                                  |   |
|-------------------------------------------------------------------------------------------------------------------------------------------|---|
| Parameters:  BaseAddress is the base address of the device  RegOffset is the register offset to be read                                   |   |
| Returns: The 32-bit value of the register                                                                                                 |   |
| Note: None.                                                                                                                               |   |
| #define XEmac_mSetControlReg( BaseAddress,                                                                                                |   |
| Set the contents of the control register. Use the XEM_ECR_* constants defined above to create the bit-mask to be written to the register. | ( |
| Parameters:  BaseAddress is the base address of the device  Mask is the 16-bit value to write to the control register                     |   |
| Returns: None.                                                                                                                            |   |
| Note: None.                                                                                                                               |   |
| #define XEmac_mSetMacAddress( BaseAddress, AddressPtr )                                                                                   |   |
| Set the station address of the EMAC device.                                                                                               |   |
| Parameters:  BaseAddress is the base address of the device  AddressPtr is a pointer to a 6-byte MAC address                               |   |
| Returns: None.                                                                                                                            |   |
| Note: None.                                                                                                                               |   |

Write the given register.

#### **Parameters:**

BaseAddress is the base address of the device RegOffset is the register offset to be written

Data is the 32-bit value to write to the register

#### **Returns:**

None.

**Note:** 

None.

# **Function Documentation**

```
int XEmac_RecvFrame( Xuint32 BaseAddress, Xuint8 * FramePtr
)
```

Receive a frame. Wait for a frame to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to a 32-bit aligned buffer where the frame will be stored

#### **Returns:**

The size, in bytes, of the frame received.

Note:

```
void XEmac_SendFrame( Xuint32 BaseAddress, Xuint8 * FramePtr, int Size )
```

Send an Ethernet frame. This size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

## **Parameters:**

BaseAddress is the base address of the device
FramePtr is a pointer to a 32-bit aligned frame
Size is the size, in bytes, of the frame

## **Returns:**

None.

**Note:** 

None.

# emac/v1\_00\_d/src/xemac\_i.h File Reference

# **Detailed Description**

This header file contains internal identifiers, which are those shared between **XEmac** components. The identifiers in this file are not intended for use external to the driver.

#### MODIFICATION HISTORY:

# **Variables**

XEmac\_Config XEmac\_ConfigTable []

# **Variable Documentation**

```
XEmac_Config XEmac_ConfigTable[]( )
```

This table contains configuration information for each EMAC device in the system.

# Xilinx Device Drivers

# <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

# XEmac\_Stats Struct Reference

#include <xemac.h>

# **Detailed Description**

Ethernet statistics (see **XEmac\_GetStats**() and **XEmac\_ClearStats**())

# **Data Fields**

| <b>T</b> | •   | 400   | <b>T</b> 7 |    | 4 10 |     |     |
|----------|-----|-------|------------|----|------|-----|-----|
| - X 1    | าาท | 11 47 | <b>,</b> X | mı | TH:  | rar | nes |
|          |     |       |            |    |      |     |     |

**Xuint32 XmitBytes** 

Xuint32 XmitLateCollisionErrors

Xuint32 XmitExcessDeferral

**Xuint32 XmitOverrunErrors** 

**Xuint32 XmitUnderrunErrors** 

**Xuint32 RecvFrames** 

**Xuint32 RecvBytes** 

**Xuint32 RecvFcsErrors** 

**Xuint32 RecvAlignmentErrors** 

**Xuint32 RecvOverrunErrors** 

**Xuint32 RecvUnderrunErrors** 

Xuint32 RecvMissedFrameErrors

Xuint32 RecvCollisionErrors

**Xuint32 RecvLengthFieldErrors** 

**Xuint32 RecvShortErrors** 

**Xuint32 RecvLongErrors** 

**Xuint32 DmaErrors** 

**Xuint32 FifoErrors** 

**Xuint32 RecvInterrupts** 

**Xuint32 XmitInterrupts** 

**Xuint32 EmacInterrupts** 

**Xuint32 TotalIntrs** 

# **Field Documentation**

### Xuint32 XEmac\_Stats::DmaErrors

Number of DMA errors since init

## Xuint32 XEmac\_Stats::EmacInterrupts

Number of MAC (device) interrupts

### Xuint32 XEmac\_Stats::FifoErrors

Number of FIFO errors since init

# Xuint32 XEmac\_Stats::RecvAlignmentErrors

Number of frames received with alignment errors

## Xuint32 XEmac\_Stats::RecvBytes

Number of bytes received

## Xuint32 XEmac\_Stats::RecvCollisionErrors

Number of frames discarded due to collisions

## Xuint32 XEmac\_Stats::RecvFcsErrors

Number of frames discarded due to FCS errors

### Xuint32 XEmac Stats::RecvFrames

Number of frames received

## Xuint32 XEmac\_Stats::RecvInterrupts

Number of receive interrupts

## **Xuint32 XEmac\_Stats::RecvLengthFieldErrors**

Number of frames discarded with invalid length field

## Xuint32 XEmac\_Stats::RecvLongErrors

Number of long frames discarded

### Xuint32 XEmac Stats::RecvMissedFrameErrors

Number of frames missed by MAC

### Xuint32 XEmac\_Stats::RecvOverrunErrors

Number of frames discarded due to overrun errors

### Xuint32 XEmac Stats::RecvShortErrors

Number of short frames discarded

## Xuint32 XEmac Stats::RecvUnderrunErrors

Number of recv underrun errors

## **Xuint32 XEmac\_Stats::TotalIntrs**

Total interrupts

# Xuint32 XEmac\_Stats::XmitBytes

Number of bytes transmitted

## Xuint32 XEmac\_Stats::XmitExcessDeferral

Number of transmission failures due o excess collision deferrals

## Xuint32 XEmac Stats::XmitFrames

Number of frames transmitted

## Xuint32 XEmac\_Stats::XmitInterrupts

Number of transmit interrupts

## Xuint32 XEmac\_Stats::XmitLateCollisionErrors

Number of transmission failures due to late collisions

## Xuint32 XEmac\_Stats::XmitOverrunErrors

Number of transmit overrun errors

## Xuint32 XEmac\_Stats::XmitUnderrunErrors

Number of transmit underrun errors

The documentation for this struct was generated from the following file:

• emac/v1\_00\_d/src/xemac.h

# emac/v1\_00\_d/src/xemac\_stats.c File Reference

# **Detailed Description**

Contains functions to get and clear the **XEmac** driver statistics.

#### MODIFICATION HISTORY:

# **Functions**

#include "xemac i.h"

```
void XEmac_GetStats (XEmac *InstancePtr, XEmac_Stats *StatsPtr)
void XEmac_ClearStats (XEmac *InstancePtr)
```

# **Function Documentation**

```
void XEmac_ClearStats( XEmac * InstancePtr)
```

| Parameters:  InstancePtr is a pointer to the XEmac instance to be worked on.                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Returns: None.                                                                                                                                                                                               |
| Note: None.                                                                                                                                                                                                  |
| id XEmac_GetStats( XEmac * InstancePtr,                                                                                                                                                                      |
| Get a copy of the XEmacStats structure, which contains the current statistics for this driver. The statistics are only cleared at initialization or on demand using the <b>XEmac_ClearStats</b> () function. |
| The DmaErrors and FifoErrors counts indicate that the device has been or needs to be reset. Reset of the levice is the responsibility of the upper layer software.                                           |
| Parameters:                                                                                                                                                                                                  |
| <i>InstancePtr</i> is a pointer to the <b>XEmac</b> instance to be worked on.                                                                                                                                |
| StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.                                                                                        |
| Returns:                                                                                                                                                                                                     |
| None.                                                                                                                                                                                                        |

Clear the XEmacStats structure for this driver.

Note:

None.

# emac/v1\_00\_d/src/xemac\_intr\_fifo.c File Reference

# **Detailed Description**

Contains functions related to interrupt mode using direct FIFO I/O or simple DMA. The driver uses simple DMA if the device is configured with DMA, otherwise it uses direct FIFO access.

The interrupt handler, **XEmac\_IntrHandlerFifo**(), must be connected by the user to the interrupt controller.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xemac_i.h"
#include "xio.h"
#include "xipif_v1_23_b.h"
```

# **Functions**

```
XStatus XEmac_FifoSend (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)

XStatus XEmac_FifoRecv (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)

void XEmac_IntrHandlerFifo (void *InstancePtr)

void XEmac_SetFifoRecvHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_FifoHandler

FuncPtr)
```

# **Function Documentation**

Receive an Ethernet frame into the buffer passed as an argument. This function is called in response to the callback function for received frames being called by the driver. The callback function is set up using SetFifoRecvHandler, and is invoked when the driver receives an interrupt indicating a received frame. The driver expects the upper layer software to call this function, FifoRecv, to receive the frame. The buffer supplied should be large enough to hold a maximum-size Ethernet frame.

The buffer into which the frame will be received must be 32-bit aligned. If using simple DMA and the PLB 10/100 Ethernet core, the buffer must be 64-bit aligned.

If the device is configured with DMA, simple DMA will be used to transfer the buffer from the Emac to memory. This means that this buffer should not be cached. See the comment section "Simple DMA" in **xemac.h** for more information.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains

the size of the buffer on entry into the function and the size the received frame on return

from the function.

#### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- o XST DEVICE IS STOPPED if the device has not yet been started
- o XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST\_NO\_DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.
- o XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

The input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame using direct FIFO I/O or simple DMA with interrupts. The caller provides a contiguous-memory buffer and its length. The buffer must be 32-bit aligned. If using simple DMA and the PLB 10/100 Ethernet core, the buffer must be 64-bit aligned. The callback function set by using SetFifoSendHandler is invoked when the transmission is complete.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field.

If the device is configured with DMA, simple DMA will be used to transfer the buffer from memory to the Emac. This means that this buffer should not be cached. See the comment section "Simple DMA" in xemac.h for more information.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

#### **Returns:**

- XST\_SUCCESS if the frame was successfully sent. An interrupt is generated when the EMAC transmits the frame and the driver calls the callback set with XEmac\_SetFifoSendHandler()
- o XST DEVICE IS STOPPED if the device has not yet been started
- o XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST\_FIFO\_NO\_ROOM if there is no room in the FIFO for this frame
- XST DEVICE BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

void XEmac\_IntrHandlerFifo( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured for direct FIFO communication or simple DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, or Send Packet FIFO. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the MAC.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance that just interrupted.

#### **Returns:**

None.

#### Note:

None.

```
void XEmac_SetFifoRecvHandler( XEmac * InstancePtr,
void * CallBackRef,
XEmac_FifoHandler FuncPtr
)
```

Set the callback function for handling confirmation of transmitted frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called by the driver once per frame sent. The callback is responsible for freeing the transmitted buffer if necessary.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Set the callback function for handling received frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called once per frame received. During the callback, the upper layer software should call FifoRecv to retrieve the received frame.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the

adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

| $\mathbf{p}$ | Δ1 | fıı | m | ne | • |
|--------------|----|-----|---|----|---|
| $\mathbf{r}$ | ш  | u   | r |    | - |

None.

#### Note:

None.

# emac/v1\_00\_d/src/xemac\_options.c File Reference

# **Detailed Description**

Functions in this file handle configuration of the **XEmac** driver.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xemac_i.h"
#include "xio.h"
```

# **Data Structures**

struct OptionMap

# **Functions**

```
XStatus XEmac_SetOptions (XEmac *InstancePtr, Xuint32 OptionsFlag)

Xuint32 XEmac_GetOptions (XEmac *InstancePtr)

XStatus XEmac_SetInterframeGap (XEmac *InstancePtr, Xuint8 Part1, Xuint8 Part2)

void XEmac_GetInterframeGap (XEmac *InstancePtr, Xuint8 *Part1Ptr, Xuint8 *Part2Ptr)
```

# **Function Documentation**

Get the interframe gap, parts 1 and 2. See the description of interframe gap above in **XEmac\_SetInterframeGap**().

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Part1Ptr is a pointer to an 8-bit buffer into which the interframe gap part 1 value will be copied.

Part2Ptr is a pointer to an 8-bit buffer into which the interframe gap part 2 value will be copied.

#### **Returns:**

None. The values of the interframe gap parts are copied into the output parameters.

#### Xuint32 XEmac\_GetOptions( XEmac \* InstancePtr)

Get Ethernet driver/device options. The 32-bit value returned is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

The 32-bit value of the Ethernet options. The value is a bit-mask representing all options that are currently enabled. See **xemac.h** for a description of the available options.

#### Note:

Set the Interframe Gap (IFG), which is the time the MAC delays between transmitting frames. There are two parts required. The total interframe gap is the total of the two parts. The values provided for the Part1 and Part2 parameters are multiplied by 4 to obtain the bit-time interval. The first part should be the first 2/3 of the total interframe gap. The MAC will reset the interframe gap timer if carrier sense becomes true during the period defined by interframe gap Part1. Part1 may be shorter than 2/3 the total and can be as small as zero. The second part should be the last 1/3 of the total interframe gap, but can be as large as the total interframe gap. The MAC will not reset the interframe gap timer if carrier sense becomes true during the period defined by interframe gap Part2.

The device must be stopped before setting the interframe gap.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Part1 is the interframe gap part 1 (which will be multiplied by 4 to get the bit-time interval).

Part2 is the interframe gap part 2 (which will be multiplied by 4 to get the bit-time interval).

#### **Returns:**

- o XST\_SUCCESS if the interframe gap was set successfully
- XST\_DEVICE\_IS\_STARTED if the device has not been stopped

#### Note:

None.

Set Ethernet driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option (i.e., you can OR the options together). A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

OptionsFlag is a bit-mask representing the Ethernet options to turn on or off. See **xemac.h** for a description of the available options.

#### **Returns:**

- o XST SUCCESS if the options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

# emac/v1\_00\_d/src/xemac\_intr\_dma.c File Reference

# **Detailed Description**

Contains functions used in interrupt mode when configured with scatter-gather DMA.

The interrupt handler, **XEmac\_IntrHandlerDma**(), must be connected by the user to the interrupt controller.

#### MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes                                                                                                                                                                                                                                        |
|-------|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.00a | _   |          | First release                                                                                                                                                                                                                                  |
| 1.00b | rpm | 02/20/02 | Repartitioned files and functions                                                                                                                                                                                                              |
| 1.00c | rpm | 12/05/02 | New version includes support for simple DMA and the delay argument to SgSend                                                                                                                                                                   |
| 1.00c | rpm | 02/03/03 | The XST_DMA_SG_COUNT_EXCEEDED return code was removed from SetPktThreshold in the internal DMA driver. Also avoided compiler warnings by initializing Result in the interrupt service routines.                                                |
| 1.00c | rpm | 03/26/03 | Fixed a problem in the interrupt service routines where the interrupt status was toggled clear after a call to ErrorHandler, but if ErrorHandler reset the device the toggle actually asserted the interrupt because the reset had cleared it. |
| 1.00d | rpm | 09/26/03 | New version includes support PLB Ethernet and v2.00a of the packet fifo driver.                                                                                                                                                                |

```
#include "xbasic_types.h"
#include "xemac_i.h"
#include "xio.h"
#include "xbuf_descriptor.h"
#include "xdma_channel.h"
#include "xipif_v1_23_b.h"
```

# **Functions**

```
XStatus XEmac_SgSend (XEmac *InstancePtr, XBufDescriptor *BdPtr, int Delay)

XStatus XEmac_SgRecv (XEmac *InstancePtr, XBufDescriptor *BdPtr)

void XEmac_IntrHandlerDma (void *InstancePtr)

XStatus XEmac_SetPktThreshold (XEmac *InstancePtr, Xuint32 Direction, Xuint8 Threshold)

XStatus XEmac_GetPktThreshold (XEmac *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)

XStatus XEmac_SetPktWaitBound (XEmac *InstancePtr, Xuint32 Direction, Xuint32 TimerValue)

XStatus XEmac_GetPktWaitBound (XEmac *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)

XStatus XEmac_SetSgRecvSpace (XEmac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)

XStatus XEmac_SetSgSendSpace (XEmac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)

void XEmac_SetSgRecvHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_SgHandler FuncPtr)

void XEmac_SetSgSendHandler (XEmac *InstancePtr, void *CallBackRef, XEmac_SgHandler FuncPtr)
```

# **Function Documentation**

Get the value of the packet count threshold for this driver/device. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

Direction indicates the channel, send or receive, from which the threshold register is read.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be

copied. An output parameter. A value of 0 indicates the use of packet threshold by the

hardware is disabled.

#### **Returns:**

- o XST SUCCESS if the packet threshold was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

Get the packet wait bound timer for this driver/device. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case. The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

WaitPtr is a pointer to the byte into which the current value of the packet wait bound register will be

copied. An output parameter. Units are in milliseconds in the range 0 - 1023. A value of 0

indicates the packet wait bound timer is disabled.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST NOT SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

None.

#### void XEmac IntrHandlerDma( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured with scatter- gather DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, Send Packet FIFO, Recv DMA channel, or Send DMA channel. The packet FIFOs only interrupt during "deadlock" conditions.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance that just interrupted.

#### **Returns:**

None.

#### Note:

Set the packet count threshold for this device. The device must be stopped before setting the threshold. The packet count threshold is used for interrupt coalescing, which reduces the frequency of interrupts from the device to the processor. In this case, the scatter-gather DMA engine only interrupts when the packet count threshold is reached, instead of interrupting for each packet. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

Threshold is the value of the packet threshold count used during interrupt coalescing. A value of 0

disables the use of packet threshold by the hardware.

#### **Returns:**

- o XST\_SUCCESS if the threshold was successfully set
- o XST NOT SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

The packet threshold could be set to larger than the number of descriptors allocated to the DMA channel. In this case, the wait bound will take over and always indicate data arrival. There was a check in this function that returned an error if the treshold was larger than the number of descriptors, but that was removed because users would then have to set the threshold only after they set descriptor space, which is an order dependency that caused confustion.

Set the packet wait bound timer for this driver/device. The device must be stopped before setting the timer value. The packet wait bound is used during interrupt coalescing to trigger an interrupt when not enough packets have been received to reach the packet count threshold. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in our case. The timer is in milliseconds.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*Direction* indicates the channel, send or receive, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound used during interrupt coalescing. It is in milliseconds in the range 0 - 1023. A value of 0 disables the packet wait bound timer.

#### **Returns:**

- o XST\_SUCCESS if the packet wait bound was set successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

None.

Set the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame received. The head of a descriptor list is passed in along with the number of descriptors in the list. Before leaving the callback, the upper layer software should attach a new buffer to each descriptor in the list.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*CallBackRef* is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

None.

#### **Note:**

Give the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be 32-bit aligned. An assert will occur if asserts are turned on and the memory is not aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*MemoryPtr* is a pointer to the aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XEmac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

```
void XEmac_SetSgSendHandler( XEmac * InstancePtr,
void * CallBackRef,
XEmac_SgHandler FuncPtr
)
```

Set the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame sent. The head of a descriptor list is passed in along with the number of descriptors in the list. The callback is responsible for freeing buffers attached to these descriptors.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Give the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be 32-bit aligned. An assert will occur if asserts are turned on and the memory is not aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*MemoryPtr* is a pointer to the aligned memory.

*ByteCount* is the length, in bytes, of the memory space.

#### **Returns:**

- o XST SUCCESS if the space was initialized successfully
- XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XEmac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Add a descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be 32-bit aligned if using the OPB Ethernet core and 64-bit aligned if using the PLB Ethernet core. This function is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. This function can be called when the device is started or stopped. Note that it does start the scatter- gather DMA engine. Although this is not necessary during initialization, it is not a problem during initialization because the MAC receiver is not yet started.

The buffer attached to the descriptor must be aligned on both the front end and the back end.

Notification of received frames are done asynchronously through the receive callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

Send an Ethernet frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire Ethernet frame may or may not be contained within one descriptor. This function simply inserts the descriptor into the scatter- gather engine's transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor must be 32-bit aligned if using the OPB Ethernet core and 64-bit aligned if using the PLB Ethernet core.

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

This call is non-blocking. Notification of error or successful transmission is done asynchronously through the send or error callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

Delay indicates whether to start the scatter-gather DMA channel immediately, or whether to wait.

This allows the user to build up a list of more than one descriptor before starting the transmission of the packets, which allows the application to keep up with DMA and have a constant stream of frames being transmitted. Use XEM SGDMA NODELAY or

XEM\_SGDMA\_DELAY, defined in **xemac.h**, as the value of this argument. If the user

chooses to delay and build a list, the user must call this function with the

XEM SGDMA NODELAY option or call **XEmac Start**() to kick off the transissions.

#### **Returns:**

- XST\_SUCCESS if the buffer was successfull sent
- o XST\_DEVICE\_IS\_STOPPED if the Ethernet MAC has not been started yet

- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

#### **Note:**

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

# emac/v1\_00\_d/src/xemac\_multicast.c File Reference

# **Detailed Description**

Contains functions to configure multicast addressing in the Ethernet MAC.

MODIFICATION HISTORY:

# **Functions**

```
XStatus XEmac_MulticastAdd (XEmac *InstancePtr, Xuint8 *AddressPtr)
XStatus XEmac_MulticastClear (XEmac *InstancePtr)
```

# **Function Documentation**

Add a multicast address to the list of multicast addresses from which the EMAC accepts frames. The EMAC uses a hash table for multicast address filtering. Obviously, the more multicast addresses that are added reduces the accuracy of the address filtering. The upper layer software that receives multicast frames should perform additional filtering when accuracy must be guaranteed. There is no way to retrieve a multicast address or the multicast address list once added. The upper layer software should maintain its own list of multicast addresses. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte multicast address.

#### **Returns:**

- o XST\_SUCCESS if the multicast address was added successfully
- o XST\_NO\_FEATURE if the device is not configured with multicast support
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### **Note:**

Not currently supported.

#### XStatus XEmac\_MulticastClear( XEmac \* InstancePtr)

Clear the hash table used by the EMAC for multicast address filtering. The entire hash table is cleared, meaning no multicast frames will be accepted after this function is called. If this function is used to delete one or more multicast addresses, the upper layer software is responsible for adding back those addresses still needed for address filtering. The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the multicast address list was cleared
- o XST NO FEATURE if the device is not configured with multicast support
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

Not currently supported.

# emac/v1\_00\_d/src/xemac\_phy.c File Reference

# **Detailed Description**

Contains functions to read and write the PHY through the Ethernet MAC MII registers. These assume an MII-compliant PHY.

#### MODIFICATION HISTORY:

## **Functions**

#include "xio.h"

## **Function Documentation**

Read the current value of the PHY register indicated by the PhyAddress and the RegisterNum parameters. The MAC provides the driver with the ability to talk to a PHY that adheres to the Media Independent Interface (MII) as defined in the IEEE 802.3 standard.

#### **Parameters:**

InstancePtr is a pointer to the XEmac instance to be worked on.
 PhyAddress is the address of the PHY to be read (supports multiple PHYs)
 RegisterNum is the register number, 0-31, of the specific PHY register to read
 PhyDataPtr is an output parameter, and points to a 16-bit buffer into which the current value of the register will be copied.

#### **Returns:**

- o XST\_SUCCESS if the PHY was read from successfully
- o XST\_NO\_FEATURE if the device is not configured with MII support
- o XST\_EMAC\_MII\_BUSY if there is another PHY operation in progress
- o XST\_EMAC\_MII\_READ\_ERROR if a read error occurred between the MAC and the PHY

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that the read is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PhyRead thread.

Write data to the specified PHY register. The Ethernet driver does not require the device to be stopped before writing to the PHY. Although it is probably a good idea to stop the device, it is the responsibility of the application to deem this necessary. The MAC provides the driver with the ability to talk to a PHY that adheres to the Media Independent Interface (MII) as defined in the IEEE 802.3 standard.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

*PhyAddress* is the address of the PHY to be written (supports multiple PHYs) *RegisterNum* is the register number, 0-31, of the specific PHY register to write

*PhyData* is the 16-bit value that will be written to the register

#### **Returns:**

- XST\_SUCCESS if the PHY was written to successfully. Since there is no error status from the MAC on a write, the user should read the PHY to verify the write was successful.
- o XST\_NO\_FEATURE if the device is not configured with MII support
- o XST\_EMAC\_MII\_BUSY if there is another PHY operation in progress

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that the write is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PhyWrite thread.

# emac/v1\_00\_d/src/xemac\_polled.c File Reference

# **Detailed Description**

Contains functions used when the driver is in polled mode. Use the **XEmac\_SetOptions**() function to put the driver into polled mode.

#### MODIFICATION HISTORY:

### **Functions**

#include "xio.h"

#include "xipif\_v1\_23\_b.h"

```
XStatus XEmac_PollSend (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
XStatus XEmac_PollRecv (XEmac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
```

## **Function Documentation**

Receive an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the frame directly from the MAC's packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The MAC's error status is not checked, so statistics are not updated for polled receive. The buffer into which the frame will be received must be 32-bit aligned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains

the size of the buffer on entry into the function and the size the received frame on return

from the function.

#### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST NO DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.

#### Note:

Input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the frame directly to the MAC's packet FIFO, then enters a loop checking the device status for completion or error. Statistics are updated if an error occurs. The buffer to be sent must be 32-bit aligned.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

BufPtr is a pointer to a aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

#### **Returns:**

- o XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST\_FIFO\_NO\_ROOM if there is no room in the EMAC's length FIFO for this frame
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.
- o XST\_EMAC\_COLLISION if the send failed due to excess deferral or late collision

#### Note:

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread. On a 10Mbps MAC, it takes about 1.21 msecs to transmit a maximum size Ethernet frame (1518 bytes). On a 100Mbps MAC, it takes about 121 usecs to transmit a maximum size Ethernet frame.

# emac/v1\_00\_d/src/xemac\_l.c File Reference

# **Detailed Description**

This file contains low-level polled functions to send and receive Ethernet frames.

MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00b rpm 04/29/02 First release
1.00c rpm 12/05/02 New version includes support for simple DMA
1.00d rpm 09/26/03 New version includes support PLB Ethernet and v2.00a of the packet fifo driver.
```

# **Functions**

#include "xemac\_l.h"

```
void XEmac_SendFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, int Size)
int XEmac_RecvFrame (Xuint32 BaseAddress, Xuint8 *FramePtr)
```

## **Function Documentation**

```
int XEmac_RecvFrame( Xuint32 BaseAddress, Xuint8 * FramePtr
)
```

Receive a frame. Wait for a frame to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to a 32-bit aligned buffer where the frame will be stored

#### **Returns:**

The size, in bytes, of the frame received.

#### Note:

None.

```
void XEmac_SendFrame( Xuint32 BaseAddress, Xuint8 * FramePtr, int Size
```

Send an Ethernet frame. This size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to a 32-bit aligned frame Size is the size, in bytes, of the frame

#### **Returns:**

None.

#### **Note:**

None.

# emac/v1\_00\_d/src/xemac\_selftest.c File Reference

# **Detailed Description**

Self-test and diagnostic functions of the **XEmac** driver.

MODIFICATION HISTORY:

### **Functions**

XStatus XEmac\_SelfTest (XEmac \*InstancePtr)

## **Function Documentation**

XStatus XEmac\_SelfTest( XEmac \* InstancePtr)

Performs a self-test on the Ethernet device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the Ethernet device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

#### **Returns:**

| XST_SUCCESS  XST_PFIFO_BAD_REG_VALUE  XST_DMA_TRANSFER_ERROR  XST_DMA_RESET_REGISTER_ERROR | Self-test was successful FIFO failed register self-test DMA failed data transfer self-test DMA control register value was incorrect after a reset |
|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| XST_REGISTER_ERROR                                                                         | Ethernet failed register reset test                                                                                                               |
| XST_LOOPBACK_ERROR                                                                         | Internal loopback failed                                                                                                                          |
| XST_IPIF_REG_WIDTH_ERROR                                                                   | An invalid register width was passed into the function                                                                                            |
| XST_IPIF_RESET_REGISTER_ERROR                                                              | The value of a register at reset was invalid                                                                                                      |
| XST_IPIF_DEVICE_STATUS_ERROR                                                               | A write to the device status register did not read back correctly                                                                                 |
| XST_IPIF_DEVICE_ACK_ERROR                                                                  | A bit in the device status register did not reset when acked                                                                                      |
| XST_IPIF_DEVICE_ENABLE_ERROR                                                               | The device interrupt enable register was not updated correctly by the hardware when other registers were written to                               |
| XST_IPIF_IP_STATUS_ERROR                                                                   | A write to the IP interrupt status register did not read back correctly                                                                           |
| XST_IPIF_IP_ACK_ERROR                                                                      | One or more bits in the IP status register did not reset when acked                                                                               |
| XST_IPIF_IP_ENABLE_ERROR                                                                   | The IP interrupt enable register was not updated correctly when other registers were written to                                                   |

#### Note:

This function makes use of options-related functions, and the **XEmac\_PollSend()** and **XEmac\_PollRecv()** functions.

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

# emac/v1\_00\_d/src/xemac\_intr.c File Reference

# **Detailed Description**

This file contains general interrupt-related functions of the **XEmac** driver.

#### MODIFICATION HISTORY:

```
Ver
      Who Date
                     Changes
1.00a rpm 07/31/01 First release
1.00b rpm 02/20/02 Repartitioned files and functions
1.00c rpm 12/05/02 New version includes support for simple DMA
1.00c rpm 03/31/03 Added comment to indicate that no Receive Length FIFO
                     overrun interrupts occur in v1.00l and later of the EMAC
                    device. This avoids the need to reset the device on
                     receive overruns.
1.00d rpm 09/26/03 New version includes support PLB Ethernet and v2.00a of
                     the packet fifo driver.
#include "xbasic_types.h"
#include "xemac i.h"
#include "xio.h"
#include "xipif_v1_23_b.h"
```

### **Functions**

void XEmac\_SetErrorHandler (XEmac \*InstancePtr, void \*CallBackRef, XEmac\_ErrorHandler FuncPtr)

## **Function Documentation**

Set the callback function for handling asynchronous errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable MAC error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_DMA\_SG\_NO\_LIST indicates an attempt was made to access a scatter-gather DMA list that has not yet been created.
- XST\_DMA\_SG\_LIST\_EMPTY indicates the driver tried to get a descriptor from the receive descriptor list, but the list was empty.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmac** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the adapter in the callback. This helps the adapter correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

| Ketur | ns:   |  |  |  |  |
|-------|-------|--|--|--|--|
|       | None. |  |  |  |  |
| Note: |       |  |  |  |  |
|       | None. |  |  |  |  |
|       |       |  |  |  |  |

# emaclite/v1\_00\_a/src/xemaclite\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions and macros that can be used to access the device.

The Xilinx Ethernet Lite driver component. This component supports the Xilinx Lite Ethernet 10/100 MAC (EMAC Lite).

The Xilinx Ethernet Lite 10/100 MAC supports the following features:

- Media Independent Interface (MII) for connection to external 10/100 Mbps PHY transceivers.
- Independent internal transmit and receive buffers
- CSMA/CD compliant operations for half-duplex modes
- Unicast and broadcast
- Automatic FCS insertion
- Automatic pad insertion on transmit

The Xilinx Ethernet Lite 10/100 MAC does not support the following features:

- interrupts
- multi-frame buffering only 1 transmit frame is allowed into the transmit buffer only 1 receive frame is allowed into the receive buffer. the hardware blocks reception until buffer is emptied
- Pause frame (flow control) detection in full-duplex mode
- Programmable interframe gap
- Multicast and promiscuous address filtering
- Internal loopback
- Automatic source address insertion or overwrite (programmable)

#### **Driver Description**

The device driver enables higher layer software (e.g., an application) to communicate to the EMAC Lite. The driver handles transmission and reception of Ethernet frames, as well as configuration of the controller. It does not handle protocol stack functionality such as Link Layer Control (LLC) or the Address Resolution Protocol (ARP). The protocol stack that makes use of the driver handles this functionality. This implies that the driver is simply a pass-through mechanism between a protocol stack and the EMAC Lite.

Since the driver is a simple pass-through mechanism between a protocol stack and the EMAC Lite, no assembly or disassembly of Ethernet frames is done at the driver-level. This assumes that the protocol stack passes a correctly formatted Ethernet frame to the driver for transmission, and that the driver does not validate the contents of an incoming frame.

#### Note:

None

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a ecm 06/01/02 First release
#include "xbasic_types.h"
#include "xio.h"
```

# **Defines**

```
#define XEmacLite_mIsTxDone(BaseAddress)
#define XEmacLite mIsRxEmpty(BaseAddress)
```

## **Functions**

```
void XEmacLite_SetMacAddress (Xuint32 BaseAddress, Xuint8 *AddressPtr)
void XEmacLite_SendFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, unsigned Size)
Xuint16 XEmacLite_RecvFrame (Xuint32 BaseAddress, Xuint8 *FramePtr)
```

# **Define Documentation**

#### #define XEmacLite\_mIsRxEmpty( BaseAddress )

Check to see if the receive is empty.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

XTRUE if it is empty, or XFALSE if it is not.

#### Note:

Xboolean **XEmacLite\_mIsRxEmpty**(Xuint32 BaseAddress)

#### #define XEmacLite\_mIsTxDone( BaseAddress )

Check to see if the transmission is complete.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

XTRUE if it is done, or XFALSE if it is not.

#### Note:

Xboolean **XEmacLite\_mIsTxDone**(Xuint32 BaseAddress)

# **Function Documentation**

```
Xuint16 XEmacLite_RecvFrame( Xuint32 BaseAddress, Xuint8 * FramePtr
)
```

Receive a frame. Wait for a frame to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

*FramePtr* is a pointer to a buffer where the frame will be stored.

#### **Returns:**

The type/length field of the frame received. When the type/length field contains the type, XEL\_RPLR\_MAX\_LENGTH bytes will be copied out of the buffer and it is up to the higher layers to sort out the frame.

#### Note:

This function call is blocking in nature, i.e. it will wait until a frame arrives.

The hardware is actually a 32-bit access of which the least significant 8 bits are actually used. This forces the strange 32-bit read of the receive buffer in the buffer copy and the increment by 4 in the source address.

```
void XEmacLite_SendFrame( Xuint32 BaseAddress, Xuint8 * FramePtr, unsigned Size
```

Send an Ethernet frame. The size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to frame

*Size* is the size, in bytes, of the frame

#### **Returns:**

None.

#### Note:

This function call is blocking in nature, i.e. it will wait until the frame is transmitted.

The hardware is actually a 32-bit access of which the least significant 8 bits are actually used. This forces the strange 32-bit write of the byte array in the buffer copy and the increment by 4 in the destination address.

```
void XEmacLite_SetMacAddress( Xuint32 BaseAddress, Xuint8 * AddressPtr )
```

Set the MAC address for this device. The address is a 48-bit value.

#### **Parameters:**

BaseAddress is register base address of the XEmacLite device.

AddressPtr is a pointer to a 6-byte MAC address. the format of the MAC address is major octet to minor octet

#### **Returns:**

None.

#### **Note:**

TX must be idle and RX should be idle for deterministic results.

# emaclite/v1\_00\_a/src/xemaclite\_l.c File Reference

# **Detailed Description**

This file contains the minimal, polled functions to send and receive Ethernet frames.

```
MODIFICATION HISTORY:
```

## **Functions**

```
void XEmacLite_SendFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, unsigned Size)
Xuint16 XEmacLite_RecvFrame (Xuint32 BaseAddress, Xuint8 *FramePtr)
void XEmacLite_SetMacAddress (Xuint32 BaseAddress, Xuint8 *AddressPtr)
```

# **Function Documentation**

```
Xuint16 XEmacLite_RecvFrame( Xuint32 BaseAddress, Xuint8 * FramePtr
)
```

Receive a frame. Wait for a frame to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

*FramePtr* is a pointer to a buffer where the frame will be stored.

#### **Returns:**

The type/length field of the frame received. When the type/length field contains the type, XEL\_RPLR\_MAX\_LENGTH bytes will be copied out of the buffer and it is up to the higher layers to sort out the frame.

#### Note:

This function call is blocking in nature, i.e. it will wait until a frame arrives.

The hardware is actually a 32-bit access of which the least significant 8 bits are actually used. This forces the strange 32-bit read of the receive buffer in the buffer copy and the increment by 4 in the source address.

```
void XEmacLite_SendFrame( Xuint32 BaseAddress, Xuint8 * FramePtr, unsigned Size
```

Send an Ethernet frame. The size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to frame

*Size* is the size, in bytes, of the frame

#### **Returns:**

None.

#### Note:

This function call is blocking in nature, i.e. it will wait until the frame is transmitted.

The hardware is actually a 32-bit access of which the least significant 8 bits are actually used. This forces the strange 32-bit write of the byte array in the buffer copy and the increment by 4 in the destination address.

```
void XEmacLite_SetMacAddress( Xuint32 BaseAddress, Xuint8 * AddressPtr
)
```

Set the MAC address for this device. The address is a 48-bit value.

#### **Parameters:**

BaseAddress is register base address of the XEmacLite device.

AddressPtr is a pointer to a 6-byte MAC address. the format of the MAC address is major octet to minor octet

#### **Returns:**

None.

#### Note:

TX must be idle and RX should be idle for deterministic results.

# emc/v1\_00\_a/src/xemc.h File Reference

# **Detailed Description**

This file contains the software API definition of the Xilinx External Memory Controller (**XEmc**) component. This controller can be attached to host OPB or PLB buses to control multiple banks of supported memory devices. The type of host bus is transparent to software.

This driver allows the user to access the device's registers to support fast/slow access to the memory devices as well as enabling/disabling paged mode access.

The Xilinx OPB/PLB External memory controller is a soft IP core designed for Xilinx FPGAs and contains the following general features:

- Support for 128, 64, 32, 16, and 8 bit bus interfaces.
- Controls up to 8 banks of supported memory devices.
- Separate control register for each bank of memory.
- Selectable wait state control (fast or slow). (See note 1)
- Supports page mode accesses. Page size is 8 bytes.
- System clock frequency of up to 133 MHz.

#### **OPB** features:

- OPB V2.0 bus interface with byte-enable support.
- Memory width of connected devices is the same as or smaller than OPB bus width.

#### Note:

(1) The number of wait states inserted for fast and slow mode is determined by the HW designer and is hard-coded into the IP. Each bank has its own settings.

```
#include "xbasic_types.h"
#include "xstatus.h"
```

### **Data Structures**

```
struct XEmc
struct XEmc_Config
```

### **Functions**

```
XStatus XEmc_Initialize (XEmc *InstancePtr, Xuint16 DeviceId)

XEmc_Config * XEmc_LookupConfig (Xuint16 DeviceId)

XStatus XEmc_SetPageMode (XEmc *InstancePtr, unsigned Bank, unsigned Mode)

XStatus XEmc_SetAccessSpeed (XEmc *InstancePtr, unsigned Bank, unsigned Speed)

unsigned XEmc_GetPageMode (XEmc *InstancePtr, unsigned Bank)

unsigned XEmc_GetAccessSpeed (XEmc *InstancePtr, unsigned Bank)

XStatus XEmc_SelfTest (XEmc *InstancePtr)
```

### **Function Documentation**

Gets current access speed setting for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank

is the set of devices to retrieve the setting for. Valid range is 0 to the number of banks minus one. The number of banks is defined as a constant in **xparameters.h** 

(XPAR\_EMC\_<n>\_NUM\_BANKS) or it can be found in the NumBanks attribute of the XEmc

instance.

#### **Returns:**

Current access speed of bank. XEMC\_ACCESS\_SPEED\_FAST or XEMC\_ACCESS\_SPEED\_SLOW.

#### Note:

none

```
unsigned XEmc_GetPageMode( XEmc * InstancePtr, unsigned Bank )
```

Gets the current page mode setting for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank

is the set of devices to retrieve the setting for. Valid range is 0 to the number of banks minus one. The number of banks is defined as a constant in **xparameters.h** 

(XPAR\_EMC\_<n>\_NUM\_BANKS) or it can be found in the NumBanks attribute of the **XEmc** instance.

#### **Returns:**

Current mode of bank. XEMC\_PAGE\_MODE\_ENABLE or XEMC\_PAGE\_MODE\_DISABLE.

#### **Note:**

none

Initializes the **XEmc** instance provided by the caller based on the given DeviceID.

#### **Parameters:**

*InstancePtr* is a pointer to an **XEmc** instance. The memory the pointer references must be pre-allocated by the caller. Further calls to manipulate the component through the **XEmc** API must be made with this pointer.

*DeviceId* 

is the unique id of the device controlled by this **XEmc** component. Passing in a device id associates the generic **XEmc** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS Initialization was successful.
- XST\_DEVICE\_NOT\_FOUND Device configuration data was not found for a device with the supplied device ID.

#### Note:

The control registers for each bank are not modified because it is possible that they have been setup during bootstrap processing prior to "C" runtime support.

Looks up the device configuration based on the unique device ID. The table XEmc\_ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceID* is the device identifier to lookup.

#### **Returns:**

**XEmc** configuration structure pointer if DeviceID is found.

XNULL if DeviceID is not found.

#### XStatus XEmc\_SelfTest( XEmc \* InstancePtr)

Runs a self-test on the driver/device. This includes the following tests:

• Control register read/write access for each bank.

Memory devices controlled by this component are not changed. However access speeds are toggled which could possibly have undesirable effects.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on. This parameter must have been previously initialized with **XEmc\_Initialize**().

#### **Returns:**

```
XST_SUCCESS If test passed
```

XST\_FAILURE If test failed

#### Note:

- o Control register contents are restored to their original state when the test completes.
- o This test does not abort if an error is detected.

```
XStatus XEmc_SetAccessSpeed( XEmc * InstancePtr, unsigned Bank, unsigned Speed )
```

Sets the access speed for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank is the set of devices to change. Valid range is 0 to the number of banks minus one. The number

of banks is defined as a constant in **xparameters.h** (XPAR\_EMC\_<n>\_NUM\_BANKS) or it

can be found in the NumBanks attribute of the **XEmc** instance.

*Speed* is the new access speed. Valid speeds are XEMC\_ACCESS\_SPEED\_SLOW and

XEMC ACCESS SPEED FAST.

#### **Returns:**

- XST\_SUCCESS Access speed successfully set.
- o XST\_INVALID\_PARAM Speed parameter is invalid.

#### **Note:**

none

```
XStatus XEmc_SetPageMode( XEmc * InstancePtr, unsigned Bank, unsigned Mode )
```

Sets the page mode for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank is the set of devices to change. Valid range is 0 to the number of banks minus one. The number

of banks is defined as a constant in **xparameters.h** (XPAR\_EMC\_<n>\_NUM\_BANKS) or it

can be found in the NumBanks attribute of the **XEmc** instance.

Mode is the new mode to set. Valid modes are XEMC\_PAGE\_MODE\_ENABLE and

XEMC\_PAGE\_MODE\_DISABLE.

#### **Returns:**

- o XST\_SUCCESS Mode successfully set.
- o XST\_INVALID\_PARAM Mode parameter is invalid.

#### Note:

none

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# **XEmc Struct Reference**

#include <xemc.h>

# **Detailed Description**

The XEmc driver instance data. The user is required to allocate a variable of this type for every EMC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• emc/v1\_00\_a/src/xemc.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

# XEmc\_Config Struct Reference

#include <xemc.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 RegBaseAddr Xuint8 NumBanks

# **Field Documentation**

Xuint16 XEmc\_Config::DeviceId

Unique ID of device

**Xuint8 XEmc\_Config::NumBanks** 

Number of devices controlled by this component

Xuint32 XEmc\_Config::RegBaseAddr

Register base address

The documentation for this struct was generated from the following file:

• emc/v1\_00\_a/src/**xemc.h** 

# emc/v1\_00\_a/src/xemc.c File Reference

# **Detailed Description**

The implementation of the **XEmc** component. See **xemc.h** for more information about the component.

#### Note:

None

#### MODIFICATION HISTORY:

# **Functions**

```
XStatus XEmc_Initialize (XEmc *InstancePtr, Xuint16 DeviceId)

XEmc_Config * XEmc_LookupConfig (Xuint16 DeviceId)

XStatus XEmc_SetPageMode (XEmc *InstancePtr, unsigned Bank, unsigned Mode)

XStatus XEmc_SetAccessSpeed (XEmc *InstancePtr, unsigned Bank, unsigned Speed)

unsigned XEmc_GetPageMode (XEmc *InstancePtr, unsigned Bank)

unsigned XEmc_GetAccessSpeed (XEmc *InstancePtr, unsigned Bank)
```

# **Function Documentation**

```
unsigned XEmc_GetAccessSpeed( XEmc * InstancePtr, unsigned Bank )
```

Gets current access speed setting for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank

is the set of devices to retrieve the setting for. Valid range is 0 to the number of banks minus one. The number of banks is defined as a constant in **xparameters.h** (XPAR\_EMC\_<n>\_NUM\_BANKS) or it can be found in the NumBanks attribute of the **XEmc** instance.

#### **Returns:**

```
Current access speed of bank. XEMC_ACCESS_SPEED_FAST or XEMC_ACCESS_SPEED_SLOW.
```

#### **Note:**

none

```
unsigned XEmc_GetPageMode( XEmc * InstancePtr, unsigned Bank )
```

Gets the current page mode setting for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank

is the set of devices to retrieve the setting for. Valid range is 0 to the number of banks minus one. The number of banks is defined as a constant in **xparameters.h** (XPAR\_EMC\_<n>\_NUM\_BANKS) or it can be found in the NumBanks attribute of the **XEmc** instance.

#### **Returns:**

```
Current mode of bank. XEMC_PAGE_MODE_ENABLE or XEMC_PAGE_MODE_DISABLE.
```

#### Note:

Initializes the **XEmc** instance provided by the caller based on the given DeviceID.

#### **Parameters:**

InstancePtr is a pointer to an **XEmc** instance. The memory the pointer references must be pre-allocated by the caller. Further calls to manipulate the component through the **XEmc** API must be made with this pointer.

DeviceId is the unique id of the device controlled by this **XEmc** component. Passing in a device id associates the generic **XEmc** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS Initialization was successful.
- XST\_DEVICE\_NOT\_FOUND Device configuration data was not found for a device with the supplied device ID.

#### Note:

The control registers for each bank are not modified because it is possible that they have been setup during bootstrap processing prior to "C" runtime support.

### 

Looks up the device configuration based on the unique device ID. The table XEmc\_ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceID* is the device identifier to lookup.

#### **Returns:**

**XEmc** configuration structure pointer if DeviceID is found.

XNULL if DeviceID is not found.

```
XStatus XEmc_SetAccessSpeed( XEmc * InstancePtr, unsigned Bank, unsigned Speed )
```

Sets the access speed for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank is the set of devices to change. Valid range is 0 to the number of banks minus

one. The number of banks is defined as a constant in xparameters.h

(XPAR EMC <n> NUM BANKS) or it can be found in the NumBanks

attribute of the **XEmc** instance.

*Speed* is the new access speed. Valid speeds are XEMC\_ACCESS\_SPEED\_SLOW

and XEMC\_ACCESS\_SPEED\_FAST.

#### **Returns:**

- XST\_SUCCESS Access speed successfully set.
- XST\_INVALID\_PARAM Speed parameter is invalid.

#### Note:

none

```
XStatus XEmc_SetPageMode( XEmc * InstancePtr,
unsigned Bank,
unsigned Mode
)
```

Sets the page mode for the given bank of memory devices.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on.

Bank is the set of devices to change. Valid range is 0 to the number of banks minus

one. The number of banks is defined as a constant in **xparameters.h** 

(XPAR\_EMC\_<n>\_NUM\_BANKS) or it can be found in the NumBanks

attribute of the **XEmc** instance.

*Mode* is the new mode to set. Valid modes are XEMC\_PAGE\_MODE\_ENABLE

and XEMC\_PAGE\_MODE\_DISABLE.

#### **Returns:**

- o XST\_SUCCESS Mode successfully set.
- o XST INVALID PARAM Mode parameter is invalid.

| Note: |      |  |  |  |  |
|-------|------|--|--|--|--|
|       | none |  |  |  |  |
|       |      |  |  |  |  |
|       |      |  |  |  |  |

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# emc/v1\_00\_a/src/xemc\_i.h File Reference

# **Detailed Description**

This header file contains register offsets and bit definitions for the external memory controller (EMC). The definitions here are meant to be used for internal xemc driver purposes.

#### MODIFICATION HISTORY:

# emc/v1\_00\_a/src/xemc\_l.h File Reference

# **Detailed Description**

Contains identifiers and low-level macros that can be used to access the device directly. High-level functions are defined in **xemc.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 05/14/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XEmc_mGetOffset(Bank)

#define XEmc_mGetControlReg(Base, Bank)

#define XEmc_mSetControlReg(Base, Bank, Data)

#define XEmc_mEnablePageMode(BaseAddress, Bank)

#define XEmc_mDisablePageMode(BaseAddress, Bank)

#define XEmc_mEnableFastAccess(BaseAddress, Bank)

#define XEmc_mDisableFastAccess(BaseAddress, Bank)
```

## **Define Documentation**

| #define Xl          | Emc_mDisableFastAccess( BaseAddress,  Bank )                                          |
|---------------------|---------------------------------------------------------------------------------------|
| Disable 1           | fast access in the given memory bank.                                                 |
|                     | ters:  BaseAddress is the base address of the device  Bank is the memory bank to set. |
| Returns<br>N        | ione.                                                                                 |
| Note:               | Tone.                                                                                 |
| #define Xl          | Emc_mDisablePageMode( BaseAddress,                                                    |
| Disable p           | page mode in the given memory bank.                                                   |
|                     | SaseAddress is the base address of the device Sank is the memory bank to set.         |
| <b>Returns</b><br>N | ione.                                                                                 |
| Note:               | one.                                                                                  |
| #define Xl          | Emc_mEnableFastAccess( BaseAddress, Bank )                                            |



Reads the contents of a bank's control register.

#### **Parameters:**

*Base* is the base address of the EMC component.

Bank identifies the control register to read.

#### **Returns:**

Value of the Bank's control register

#### Note:

Macro signature: Xuint32 XEmc\_mGetControlReg(Xuint32 Base, unsigned Bank)

#### #define XEmc\_mGetOffset( Bank )

Calculate the offset of a control register based on its bank. This macro is used internally.

#### **Parameters:**

Bank is the bank number of the control register offset to calculate

#### **Returns:**

Offset to control register associated with Bank parameter.

#### Note:

- o To compute the physical address of the register add the base address of the component to the result of this macro.
- o Does not test for validity of Bank.
- Macro signature: unsigned XEmc\_mGetOffset(unsigned Bank)

#### #define XEmc\_mSetControlReg( Base,

Bank,

Data )

Writes to a bank's control register.

#### **Parameters:**

Base is the base address of the EMC component.

Bank identifies the control register to modify.

Data is the data to write to the control register.

#### **Returns:**

None.

#### Note:

 Macro signature: void XEmc\_mSetControlReg(Xuint32 Base, unsigned Bank, Xuint32 Data)

# emc/v1\_00\_a/src/xemc\_selftest.c File Reference

# **Detailed Description**

The implementation of the **XEmc** component for the self-test functions.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

1.00a rmm 02/08/02 First release

#include "xemc.h"
#include "xemc_i.h"
```

## **Functions**

**XStatus XEmc\_SelfTest** (**XEmc** \*InstancePtr)

## **Function Documentation**

XStatus XEmc\_SelfTest( XEmc \* InstancePtr)

Runs a self-test on the driver/device. This includes the following tests:

• Control register read/write access for each bank.

Memory devices controlled by this component are not changed. However access speeds are toggled which could possibly have undesirable effects.

#### **Parameters:**

*InstancePtr* is a pointer to the **XEmc** instance to be worked on. This parameter must have been previously initialized with **XEmc\_Initialize**().

#### **Returns:**

XST\_SUCCESS If test passed

XST\_FAILURE If test failed

#### Note:

- o Control register contents are restored to their original state when the test completes.
- o This test does not abort if an error is detected.

# common/v1\_00\_a/src/xenv\_vxworks.h File Reference

# **Detailed Description**

Defines common services that are typically found in a VxWorks target environment.

#### Note:

This file is not intended to be included directly by driver code. Instead, the generic **xenv.h** file is intended to be included by driver code.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

rmm 09/13/03 CR 177068: Fix compiler warning in XENV_MEM_FILL rmm 10/24/02 Added XENV_USLEEP macro

1.00a rmm 07/16/01 First release
```

```
#include "xbasic_types.h"
#include "vxWorks.h"
#include "vxLib.h"
#include <string.h>
```

## **Data Structures**

struct XENV\_TIME\_STAMP

## **Defines**

```
#define XENV_MEM_COPY(DestPtr, SrcPtr, Bytes)

#define XENV_MEM_FILL(DestPtr, Data, Bytes)

#define XENV_TIME_STAMP_GET(StampPtr)

#define XENV_TIME_STAMP_DELTA_US(Stamp1Ptr, Stamp2Ptr)

#define XENV_TIME_STAMP_DELTA_MS(Stamp1Ptr, Stamp2Ptr)

#define XENV_USLEEP(delay)
```

## **Define Documentation**

```
#define XENV_MEM_COPY( DestPtr,
SrcPtr,
Bytes )
```

Copies a non-overlapping block of memory.

#### **Parameters:**

DestPtr is the destination address to copy data to.
SrcPtr is the source address to copy data from.
Bytes is the number of bytes to copy.

#### **Returns:**

None.

#### Note:

Signature: void XENV\_MEM\_COPY(void \*DestPtr, void \*SrcPtr, unsigned Bytes)

Fills an area of memory with constant data.

#### **Parameters:**

*DestPtr* is the destination address to set.

Data contains the value to set.

*Bytes* is the number of bytes to set.

#### **Returns:**

None.

#### Note:

Signature: void XENV\_MEM\_FILL(void \*DestPtr, char Data, unsigned Bytes)

# #define XENV\_TIME\_STAMP\_DELTA\_MS( Stamp1Ptr, Stamp2Ptr )

This macro is not yet implemented and always returns 0.

#### **Parameters:**

*Stamp1Ptr* is the first sampled time stamp.

Stamp2Ptr is the second sampled time stamp.

#### **Returns:**

0

#### Note:

None.

# #define XENV\_TIME\_STAMP\_DELTA\_US( Stamp1Ptr, Stamp2Ptr )

| Parameters:  Stamp1Ptr is the first sampled time stamp.  Stamp2Ptr is the second sampled time stamp.                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Returns:                                                                                                                                               |
| Note: None.                                                                                                                                            |
| define XENV_TIME_STAMP_GET( StampPtr )                                                                                                                 |
| Time is derived from the 64 bit PPC timebase register                                                                                                  |
| Parameters:  StampPtr is the storage for the retrieved time stamp.  Returns:  None.  Note:  Signature: void XENV_TIME_STAMP_GET(XTIME_STAMP *StampPtr) |
| define XENV_USLEEP( delay )                                                                                                                            |
| XENV_USLEEP(unsigned delay)                                                                                                                            |
| Delay the specified number of microseconds.                                                                                                            |
| Parameters:  delay is the number of microseconds to delay.                                                                                             |
| Returns: None                                                                                                                                          |

This macro is not yet implemented and always returns 0.

# common/v1\_00\_a/src/xenv.h File Reference

# **Detailed Description**

Defines common services that are typically found in a host operating. environment. This include file simply includes an OS specific file based on the compile-time constant BUILD\_ENV\_\*, where \* is the name of the target environment.

All services are defined as macros.

#### MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes          |
|-------|-----|----------|------------------|
|       |     |          |                  |
| 1.00b | ch  | 10/24/02 | Added XENV_LINUX |
| 1.00a | rmm | 04/17/02 | First release    |

#include "xenv\_none.h"

# common/v1\_00\_a/src/xenv\_none.h File Reference

# **Detailed Description**

Defines common services specified by **xenv.h**. Some of these services are defined as not performing any action. The implementation of these services are left to the user.

#### Note:

This file is not intended to be included directly by driver code. Instead, the generic **xenv.h** file is intended to be included by driver code.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
---- --- --- ---- ---- ----- ----- 1.00a rmm 03/21/02 First release
```

# **Defines**

```
#define XENV_MEM_COPY(DestPtr, SrcPtr, Bytes)

#define XENV_MEM_FILL(DestPtr, Data, Bytes)

#define XENV_TIME_STAMP_GET(StampPtr)

#define XENV_TIME_STAMP_DELTA_US(Stamp1Ptr, Stamp2Ptr)

#define XENV_TIME_STAMP_DELTA_MS(Stamp1Ptr, Stamp2Ptr)

#define XENV_USLEEP(delay)
```

# **Typedefs**

typedef int XENV\_TIME\_STAMP

# **Define Documentation**

```
#define XENV_MEM_COPY( DestPtr,
SrcPtr,
Bytes )
```

Copies a non-overlapping block of memory.

#### **Parameters:**

DestPtr is the destination address to copy data to.SrcPtr is the source address to copy data from.Bytes is the number of bytes to copy.

#### **Returns:**

None.

#### Note:

Signature: void **XENV\_MEM\_COPY**(void \*DestPtr, void \*SrcPtr, unsigned Bytes)

Fills an area of memory with constant data.

#### **Parameters:**

*DestPtr* is the destination address to set.

Data contains the value to set.

Bytes is the number of bytes to set.

#### **Returns:**

None.

#### **Note:**

Signature: void **XENV\_MEM\_FILL**(void \*DestPtr, char Data, unsigned Bytes)

# #define XENV\_TIME\_STAMP\_DELTA\_MS( Stamp1Ptr, Stamp2Ptr )

This macro is not yet implemented and always returns 0.

#### **Parameters:**

Stamp1Ptr is the first sampled time stamp.
Stamp2Ptr is the second sampled time stamp.

#### **Returns:**

0

#### Note:

This macro must be implemented by the user

```
#define XENV_TIME_STAMP_DELTA_US( Stamp1Ptr, Stamp2Ptr )
```

This macro is not yet implemented and always returns 0.

#### **Parameters:**

Stamp1Ptr is the first sampled time stamp.

Stamp2Ptr is the second sampled time stamp.

#### **Returns:**

0

#### **Note:**

This macro must be implemented by the user

#### #define XENV\_TIME\_STAMP\_GET( StampPtr )

Time is derived from the 64 bit PPC timebase register

#### **Parameters:**

*StampPtr* is the storage for the retrieved time stamp.

#### **Returns:**

None.

#### Note:

Signature: void **XENV\_TIME\_STAMP\_GET**(XTIME\_STAMP \*StampPtr)

#### Note:

This macro must be implemented by the user

#### #define XENV\_USLEEP( delay )

**XENV\_USLEEP**(unsigned delay)

Delay the specified number of microseconds. Not implemented without OS support.

#### **Parameters:**

delay is the number of microseconds to delay.

#### **Returns:**

None

# **Typedef Documentation**

### $typedef\ int\ XENV\_TIME\_STAMP$

A structure that contains a time stamp used by other time stamp macros defined below. This structure is processor dependent.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# XENV\_TIME\_STAMP Struct Reference

#include <xenv\_vxworks.h>

# **Detailed Description**

A structure that contains a time stamp used by other time stamp macros defined below. This structure is processor dependent.

The documentation for this struct was generated from the following file:

• common/v1\_00\_a/src/xenv\_vxworks.h

# common/v1\_00\_a/src/xenv\_linux.h File Reference

# **Detailed Description**

Defines common services specified by **xenv.h**. Some of these services are defined as not performing any action. The implementation of these services are left to the user.

#### Note:

This file is not intended to be included directly by driver code. Instead, the generic **xenv.h** file is intended to be included by driver code.

#### MODIFICATION HISTORY:

## **Defines**

```
#define XENV_MEM_COPY(DestPtr, SrcPtr, Bytes)

#define XENV_MEM_FILL(DestPtr, Data, Bytes)

#define XENV_TIME_STAMP_GET(StampPtr)

#define XENV_TIME_STAMP_DELTA_US(Stamp1Ptr, Stamp2Ptr)

#define XENV_TIME_STAMP_DELTA_MS(Stamp1Ptr, Stamp2Ptr)

#define XENV_USLEEP(delay)
```

# **Typedefs**

typedef int XENV\_TIME\_STAMP

# **Define Documentation**

```
#define XENV_MEM_COPY( DestPtr,
SrcPtr,
Bytes )
```

Copies a non-overlapping block of memory.

#### **Parameters:**

DestPtr is the destination address to copy data to.SrcPtr is the source address to copy data from.Bytes is the number of bytes to copy.

#### **Returns:**

None.

#### Note:

Signature: void **XENV\_MEM\_COPY**(void \*DestPtr, void \*SrcPtr, unsigned Bytes)

Fills an area of memory with constant data.

#### **Parameters:**

*DestPtr* is the destination address to set.

Data contains the value to set.

Bytes is the number of bytes to set.

#### **Returns:**

None.

#### **Note:**

Signature: void **XENV\_MEM\_FILL**(void \*DestPtr, char Data, unsigned Bytes)

# #define XENV\_TIME\_STAMP\_DELTA\_MS( Stamp1Ptr, Stamp2Ptr )

This macro is not yet implemented and always returns 0.

#### **Parameters:**

Stamp1Ptr is the first sampled time stamp.
Stamp2Ptr is the second sampled time stamp.

#### **Returns:**

0

#### Note:

This macro must be implemented by the user

```
#define XENV_TIME_STAMP_DELTA_US( Stamp1Ptr, Stamp2Ptr )
```

This macro is not yet implemented and always returns 0.

#### **Parameters:**

Stamp1Ptr is the first sampled time stamp.

Stamp2Ptr is the second sampled time stamp.

#### **Returns:**

0

#### **Note:**

This macro must be implemented by the user

#### #define XENV\_TIME\_STAMP\_GET( StampPtr )

Time is derived from the 64 bit PPC timebase register

#### **Parameters:**

*StampPtr* is the storage for the retrieved time stamp.

#### **Returns:**

None.

#### Note:

Signature: void **XENV\_TIME\_STAMP\_GET**(XTIME\_STAMP \*StampPtr)

#### Note:

This macro must be implemented by the user

### #define XENV\_USLEEP( delay )

**XENV\_USLEEP**(unsigned delay)

Delay the specified number of microseconds.

#### **Parameters:**

delay is the number of microseconds to delay.

#### **Returns:**

None

# **Typedef Documentation**

### $typedefint \ XENV\_TIME\_STAMP$

A structure that contains a time stamp used by other time stamp macros defined below. This structure is processor dependent.

# flash/v1\_00\_a/src/xflash\_cfi.h File Reference

# **Detailed Description**

This is a helper component for XFlash. It contains methods used to extract and interpret Common Flash Interface (CFI) from a flash memory part that supports the CFI query command.

```
MODIFICATION HISTORY:
```

## **Defines**

```
#define XFL_CFI_POSITION_PTR(Ptr, BaseAddr, Interleave, ByteAddr)
#define XFL_CFI_READ8(Ptr, Interleave)
#define XFL_CFI_READ16(Ptr, Interleave, Data)
#define XFL_CFI_ADVANCE_PTR8(Ptr, Interleave)
#define XFL_CFI_ADVANCE_PTR16(Ptr, Interleave)
```

## **Functions**

XStatus XFlashCFI\_ReadCommon (XFlashGeometry \*GeometryPtr, XFlashProperties \*PropertiesPtr)

## **Define Documentation**

# #define XFL\_CFI\_ADVANCE\_PTR16( Ptr, Interleave )

Advances the CFI pointer to the next 16-bit quantity.

#### **Parameters:**

Ptr is the pointer to advance. Can be a pointer to any type. Interleave is the byte interleaving (based on part layout)

#### **Returns:**

Adjusted Ptr.

# #define XFL\_CFI\_ADVANCE\_PTR8( Ptr, Interleave )

Advances the CFI pointer to the next byte

#### **Parameters:**

Ptr is the pointer to advance. Can be a pointer to any type. Interleave is the byte interleaving (based on part layout)

#### **Returns:**

Adjusted Ptr.

#### #define XFL\_CFI\_POSITION\_PTR( Ptr,

BaseAddr, Interleave, ByteAddr ) Moves the CFI data pointer to a physical address that corresponds to a specific CFI byte offset.

#### **Parameters:**

*Ptr* is the pointer to modify. Can be of any type

BaseAddr is the base address of flash part

*Interleave* is the byte interleaving (based on part layout)

ByteAddr is the byte offset within CFI data to read

#### **Returns:**

The Ptr argument is set to point at the the CFI byte specified by the ByteAddr parameter.

#### #define XFL\_CFI\_READ16(Ptr,

Interleave,

**Data** 

Reads 16-bits of data from the CFI data location into a local variable.

#### **Parameters:**

*Ptr* is the pointer to read. Can be a pointer to any type.

*Interleave* is the byte interleaving (based on part layout)

Data is the 16-bit storage location for the data to be read.

#### **Returns:**

The 16-bit value at Ptr adjusted for the interleave factor.

#### #define XFL\_CFI\_READ8( Ptr,

**Interleave** )

Reads 8-bits of data from the CFI data location into a local variable.

#### **Parameters:**

Ptr is the pointer to read. Can be a pointer to any type.

*Interleave* is the byte interleaving (based on part layout)

#### **Returns:**

The byte at Ptr adjusted for the interleave factor.

# **Function Documentation**

Retrieves the standard CFI data from the part(s), interpret the data, and update the provided geometry and properties structures.

Extended CFI data is part specific and ignored here. This data must be read by the specific part component driver.

#### **Parameters:**

GeometryPtr is an input/output parameter. This function expects the BaseAddress and MemoryLayout attributes to be correctly initialized. All other attributes of this structure will be setup using translated CFI data read from the part.

*PropertiesPtr* is an output parameter. Timing, identification, and programming CFI data will be translated and written to this structure.

#### **Returns:**

- o XST\_SUCCESS if successful.
- o XST\_FLASH\_CFI\_QUERY\_ERROR if an error occurred interpreting the data.
- o XST\_FLASH\_PART\_NOT\_SUPPORTED if invalid Layout parameter

#### Note:

None.

# flash/v1\_00\_a/src/xflash.h File Reference

# **Detailed Description**

This is the base component for XFlash. It provides the public interface which upper layers use to communicate with specific flash hardware.

This driver supports "Common Flash Interface" (CFI) enabled flash hardware. CFI allows entire families of flash parts to be supported with a single driver sub-component.

This driver is designed for devices external to the FPGA. As a result interfaces such as IPIF and versioning are not incorporated into its design. A more detailed description of the driver operation can be found in **XFlash.c** 

#### Note:

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads, mutual exclusion, virtual memory, cache control, or HW write protection management must be satisfied by the layer above this driver.

All writes to flash occur in units of bus-width bytes. If more than one part exists on the data bus, then the parts are written in parallel. Reads from flash are performed in any width up to the width of the data bus. It is assumed that the flash bus controller or local bus supports these types of accesses.

#### MODIFICATION HISTORY:

### **Data Structures**

# **Configuration options**

#define XFL\_NON\_BLOCKING\_ERASE\_OPTION #define XFL\_NON\_BLOCKING\_WRITE\_OPTION

### **Defines**

#define XFL\_MANUFACTURER\_ID\_INTEL

# **Typedefs**

typedef XFlashTag XFlash

### **Functions**

```
XStatus XFlash_Initialize (XFlash *InstancePtr, Xuint16 DeviceId)
          XStatus XFlash_SelfTest (XFlash *InstancePtr)
          XStatus XFlash_Reset (XFlash *InstancePtr)
  XFlash_Config * XFlash_LookupConfig (Xuint16 DeviceId)
          XStatus XFlash SetOptions (XFlash *InstancePtr, Xuint32 OptionsFlag)
          Xuint32 XFlash_GetOptions (XFlash *InstancePtr)
XFlashProperties * XFlash GetProperties (XFlash *InstancePtr)
XFlashGeometry * XFlash_GetGeometry (XFlash *InstancePtr)
          XStatus XFlash DeviceControl (XFlash *InstancePtr, Xuint32 Command, Xuint32 Param,
                   Xuint32 *ReturnPtr)
          XStatus XFlash Read (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void *DestPtr)
          XStatus XFlash_Write (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void *SrcPtr)
          XStatus XFlash WriteSuspend (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlash_WriteResume (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlash Erase (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlash EraseSuspend (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlash_EraseResume (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlash_Lock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlash_Unlock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlash_GetStatus (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlash ReadBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32
                   Offset, Xuint32 Bytes, void *DestPtr)
```

- XStatus XFlash\_WriteBlock (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32 Offset, Xuint32 Bytes, void \*SrcPtr)
- XStatus XFlash\_WriteBlockSuspend (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32 Offset)
- XStatus XFlash\_WriteBlockResume (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32 Offset)
- XStatus XFlash\_EraseBlock (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint16 NumBlocks)
- XStatus XFlash EraseBlockSuspend (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block)
- XStatus XFlash\_EraseBlockResume (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block)
- XStatus XFlash\_LockBlock (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint16 NumBlocks)
- XStatus XFlash\_UnlockBlock (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint16 NumBlocks)
- XStatus XFlash\_GetBlockStatus (XFlash \*InstancePtr, Xuint16 Region, Xuint16 Block)
- XStatus XFlash\_EraseChip (XFlash \*InstancePtr)

## **Define Documentation**

#### #define XFL MANUFACTURER ID INTEL

Supported manufacturer IDs. Note, that not all parts from these listed vendors are supported.

#### #define XFL\_NON\_BLOCKING\_ERASE\_OPTION

| XFL_NON_BLOCKING_ERASE_OPTION | Controls whether the interface blocks on |
|-------------------------------|------------------------------------------|
|                               | device erase until the operation is      |
|                               | completed 1=noblock, 0=block             |
| XFL_NON_BLOCKING_WRITE_OPTION | Controls whether the interface blocks on |
|                               | device program until the operation is    |
|                               | completed 1=noblock, 0=block             |

#### #define XFL\_NON\_BLOCKING\_WRITE\_OPTION

| XFL_NON_BLOCKING_ERASE_OPTION | Controls whether the interface blocks on |
|-------------------------------|------------------------------------------|
|                               | device erase until the operation is      |
|                               | completed 1=noblock, 0=block             |
| XFL_NON_BLOCKING_WRITE_OPTION | Controls whether the interface blocks on |
|                               | device program until the operation is    |
|                               | completed 1=noblock, 0=block             |

# **Typedef Documentation**

#### typedef struct XFlashTag XFlash

The XFlash driver instance data. The user is required to allocate a variable of this type for every flash device in the system. A pointer to a variable of this type is then passed to the driver API functions.

## **Function Documentation**

Accesses device specific data or commands. For a list of commands, see derived component documentation.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Command is the device specific command to issue

Param is the command parameter

*ReturnPtr* is the result of command (if any)

#### **Returns:**

- XST\_SUCCESS if successful
- XST\_FLASH\_NOT\_SUPPORTED if the command is not recognized/supported by the device(s).

#### Note:

None.

Erases the specified address range.

Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

Erase the specified range of the device(s). Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_ERASE\_OPTION option has an impact on the number of bytes that can be erased in a single call to this function:

- If clear, then the number of bytes to erase can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the block size of the device at the provided offset and whether the device(s) contains a block erase queue.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin erasure.

*Bytes* is the number of bytes to erase.

#### **Returns:**

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set, then the return value is one of the following:

- XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- o XST\_FLASH\_BLOCKING\_CALL\_ERROR if the amount of data to be erased exceeds the erase queue capacity of the device(s).

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned:

XST\_FLASH\_ERROR if an erase error occurred. This error is usually device specific. Use
 XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is
 possible that the target address range was only partially erased.

#### Note:

Due to flash memory design, the range actually erased may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Erases the specified block.

Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_ERASE\_OPTION option has an impact on the number of bytes that can be erased in a single call to this function:

- If clear, then the number of bytes to erase can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the block size of the device at the provided offset and whether the device(s) contains a block erase queue.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

*NumBlocks* is the the number of blocks to erase.

#### **Returns:**

If XFL NON BLOCKING ERASE OPTION option is set, then the return value is one of the below.

- o XST SUCCESS if successfull.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned

XST\_FLASH\_ERROR if an erase error occured. This error is usually device specific. Use
 XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is
 possible that the target address range was only partially erased.

#### Note:

The arguments point to a starting Region and Block. The NumBlocks parameter may cross over Region boundaries as long as the entire range lies within the part(s) address range and the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is not set.

Resumes an erase operation that was suspended with XFlash\_EraseBlockSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being erased

#### **Returns:**

- o XST SUCCESS if successful.
- o XST FLASH NOT SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

Suspends a currently in progress erase operation and place the device(s) in read mode. When suspended, any block not being erased can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_EraseBlock**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being erased

#### **Returns:**

- o XST\_SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

#### XStatus XFlash\_EraseChip( XFlash \* InstancePtr)

Erases the entire device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

#### **Returns:**

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set, then the return value is always XST\_SUCCESS. If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned:

- o XST FLASH NOT SUPPORTED if the chip erase is not supported by the device(s).
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error during the operation.
   XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

None.

Resumes an erase operation that was suspended with XFlash\_EraseSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where erase resumption should be Resumed.

#### **Returns:**

- o XST SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Suspends a currently in progress erase operation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_Erase**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where suspension should occur.

#### **Returns:**

- o XST SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Returns the status of the device. This function is intended to be used to poll the device in the following circumstances:

- After calling XFlash WriteBlock with XFL NON BLOCKING WRITE OPTION option set.
- After calling XFlash EraseBlock with XFL NON BLOCKING ERASE OPTION option set.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the erase region the block appears in.Block is the block number within the erase region.

#### **Returns:**

- o XST\_FLASH\_READY if the device(s) have completed the previous operation without error.
- o XST\_FLASH\_BUSY if the device(s) are currently performing an erase or write operation.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error occurring during
  another operation such as write, erase, or block locking. XFlash\_DeviceControl() must be used
  to access the cause of the device specific error condition.

#### Note:

With some types of flash devices, there may be no difference between using XFlash\_GetBlockStatus or XFlash\_GetStatus. See your part data sheet for more information.

# XFlashGeometry\* XFlash\_GetGeometry( XFlash \* InstancePtr) Gets the instance's geometry data **Parameters:** *InstancePtr* is the pointer to the XFlash instance to be worked on. **Returns:** Instance's Geometry structure Note: None. Xuint32 XFlash\_GetOptions( XFlash \* InstancePtr) Gets interface options for this device instance. **Parameters:** *InstancePtr* is the pointer to the XFlash instance to be worked on. **Returns:** Current options flag **Note:** None. XFlashProperties\* XFlash\_GetProperties( XFlash \* InstancePtr) Gets the instance's property data **Parameters:** *InstancePtr* is the pointer to the XFlash instance to be worked on. **Returns:** Instance's Properties structure Note: None. XStatus XFlash\_GetStatus( XFlash \* InstancePtr, Xuint32 Offset

Returns the status of the device. This function is intended to be used to poll the device in the following circumstances:

- After calling XFlash\_Write with XFL\_NON\_BLOCKING\_WRITE\_OPTION option set.
- After calling XFlash\_Erase or XFlash\_EraseChip with XFL\_NON\_BLOCKING\_ERASE\_OPTION
  option set.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the part.

#### **Returns:**

- o XST\_FLASH\_READY if the device(s) have completed the previous operation without error.
- o XST\_FLASH\_BUSY if the device(s) are currently performing an erase or write operation.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error occurring during
  another operation such as write, erase, or block locking. XFlash\_DeviceControl() must be used
  to access the cause of the device specific error condition.

#### Note:

With some types of flash devices, there may be no difference between using XFlash\_GetBlockStatus or XFlash\_GetStatus. See your part data sheet for more information.

Initializes a specific XFlash instance. The initialization entails:

- Issuing the CFI query command
- Get and translate relevent CFI query information.
- Set default options for the instance.
- Setup the VTable.
- Call the initialize function of the instance, which does the following:
  - o Get and translate extended vendor CFI query information.
  - Some VTable functions may be replaced with more efficient ones based on data extracted from the extended CFI query. A replacement example would be a buffered XFlash\_WriteBlock replacing a non-buffered XFlash\_WriteBlock.
  - o Reset the device by clearing any status information and placing the device in read mode.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

DeviceId is the unique id of the device controlled by this component. Passing in a device id associates the generic component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

The return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is

returned. Possible error codes are:

- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.
- XST\_FLASH\_PART\_NOT\_SUPPORTED if the command set algorithm or Layout is not supported by any derived component compiled into the system.
- XST\_FLASH\_TOO\_MANY\_REGIONS if the part contains too many erase regions. This can be fixed by increasing the value of XFL\_MAX\_ERASE\_REGIONS then re- compiling the driver.
- XST\_FLASH\_CFI\_QUERY\_ERROR if the device would not enter CFI query mode. Either the
  device(s) do not support CFI, the wrong BaseAddress param was used, an unsupported part
  layout exists, or a hardware problem exists with the part.

#### Note:

None.

Locks the blocks in the specified range of the device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin block locking.

*Bytes* is the number of bytes to lock.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

Due to flash memory design, the range actually locked may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Locks the specified block. Prevents it from being erased or written.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

NumBlocks is the the number of blocks to erase. The number may extend into a different region.

#### **Returns:**

- o XST SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

None.

#### 

Looks up the device configuration based on the unique device ID.

#### **Parameters:**

DeviceId is the unique device ID to be searched for in the table

#### **Returns:**

Returns a pointer to the configuration data for the device, or XNULL if not device is found.

Copies data from the device(s) memory space to a user buffer. The source and destination addresses can be on any alignment supported by the processor.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to read.

*Bytes* is the number of bytes to copy.

*DestPtr* is the destination address to copy data to.

#### **Returns:**

- o XST\_SUCCESS if successful.
- o XST FLASH ADDRESS ERROR if the source address does not start within the addressable

areas of the device(s).

#### Note:

This function allows the transfer of data past the end of the device's address space. If this occurs, then results are undefined.

Copy data from a specific device block to a user buffer. The source and destination addresses can be on any byte alignment supported by the target processor.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

Region is the erase region the block appears in.Block is the block number within the erase region.

Offset is the starting offset in the block where reading will begin.

*Bytes* is the number of bytes to copy.

*DestPtr* is the destination address to copy data to.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if Region, Block, and Offset parameters do not point to a valid block.

#### Note:

The arguments point to a starting Region, Block, and Offset within that block. The Bytes parameter may cross over Region and Block boundaries. If Bytes extends past the end of the device's address space, then results are undefined.

XStatus XFlash Reset( XFlash \* InstancePtr)

Clears the device(s) status register(s) and place the device(s) into read mode.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_BUSY if the flash devices were in the middle of an operation and could not be reset.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error during the operation.
   XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

None.

# XStatus XFlash\_SelfTest( XFlash \* InstancePtr)

Runs a self-test on the driver/device. This is a destructive test. Tests performed include:

- Address bus test
- Data bus test

When the tests are complete, the device is reset back into read mode.

#### **Parameters:**

*InstancePtr* is a pointer to the XComponent instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_ERROR if any test fails.

#### Note:

None.

Sets interface options for this device instance.

Here are the currently available options:

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on. *OptionsFlag* is the options to set. 1=set option, 0=clear option.

#### **Returns:**

- XST\_SUCCESS if options successfully set.
- o XST\_FLASH\_NOT\_SUPPORTED if option is not supported.

#### Note:

None.

Unlocks the blocks in the specified range of the device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin block unlocking.

*Bytes* is the number of bytes to unlock.

#### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

Due to flash memory design, the range actually unlocked may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Unlocks the specified block.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

NumBlocks is the the number of blocks to erase. The number may extend into a different region.

#### **Returns:**

- o XST SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### **Note:**

None.

Programs the devices with data stored in the user buffer. The source and destination address must be aligned to the width of the flash's data bus.

Returns immediately if the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_WRITE\_OPTION option has an impact on the number of bytes that can be written:

- If clear, then the number of bytes to write can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the alignment and size of the device's write buffer. The rule is that the number of bytes being written cannot cross over an alignment boundary. Alignment information is obtained in the InstancePtr->Properties.ProgCap attribute.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset into the device(s) address space from which to begin programming. Must be

aligned to the width of the flash's data bus.

*Bytes* is the number of bytes to program.

SrcPtr is the source address containing data to be programmed. Must be aligned to the width of

the flash's data bus.

#### **Returns:**

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set, then the return value is one of the following:

- o XST SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- XST\_FLASH\_ALIGNMENT\_ERROR if the Offset or SrcPtr is not aligned to the width of the flash's data bus.
- o XST\_BLOCKING\_CALL\_ERROR if the write would cross a write buffer boundary.

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is clear, then the following additional codes can be returned:

XST\_FLASH\_ERROR if a write error occurred. This error is usually device specific. Use
 XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is
 possible that the target address range was only partially programmed.

#### Note:

None.

Programs the devices with data stored in the user buffer. The source and destination address can be on any alignment supported by the processor. This function will block until the operation completes or an error is detected.

Returns immediately if the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_WRITE\_OPTION option has an impact on the number of bytes that can be written:

- If clear, then the number of bytes to write can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the alignment and size of the device's write buffer. The rule is that the number of bytes being written cannot cross over an alignment boundary. Alignment information is obtained in the InstancePtr->Properties.ProgCap attribute.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

Region is the erase region the block appears in.Block is the block number within the erase region.

Offset is the starting offset in the block where writing will begin.

*Bytes* is the number of bytes to write.

SrcPtr is the source address containing data to be programmed

#### **Returns:**

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set, then the return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is returned. Possible error codes are:

- XST\_FLASH\_ADDRESS\_ERROR if Region, Block, and Offset parameters do not point to a valid block. Or, the Bytes parameter causes the read to go past the last addressible byte in the device(s).
- o XST\_FLASH\_ALIGNMENT\_ERROR if the Offset or SrcPtr is not aligned to the width of the flash's data bus.
- XST\_BLOCKING\_CALL\_ERROR if the write would cross a write buffer boundary.
   If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is clear, then the following additional codes can be returned:
  - XST\_FLASH\_ERROR if a write error occured. This error is usually device specific. Use
     XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is
     possible that the target address range was only partially programmed.

#### **Note:**

The arguments point to a starting Region, Block, and Offset within that block. The Bytes parameter may cross over Region and Block boundaries as long as the entire range lies within the part(s) address range and the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is not set.

Resumes a write operation that was suspended with XFlash\_WriteBlockSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing block
Block is the block that is being erased

Offset is the offset in the device where resumption should occur

#### **Returns:**

- XST\_SUCCESS if successful.
- o XST FLASH NOT SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

Suspends a currently in progress write opearation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set and a previous call to **XFlash\_WriteBlock**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being written

Offset is the offset in the device where suspension should occur

#### **Returns:**

- o XST SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored in those cases.

Resumes a write operation that was suspended with XFlash WriteSuspend.

#### **Parameters:**

InstancePtr is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where write resumption should occur.

#### **Returns:**

- o XST SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Suspends a currently in progress write operation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_Write**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

InstancePtr is the pointer to the XFlash instance to be worked on.Offset is the offset with the device where suspension should occur.

#### **Returns:**

- o XST\_SUCCESS if successful.
- o XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Generated on 30 Sep 2003 for Xilinx Device Drivers

#### Xilinx Device Drivers

## Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# flash/v1\_00\_a/src/xflash.c File Reference

# **Detailed Description**

This module implements the base component for flash memory devices that conform to the "Common Flash Interface" (CFI) standard. CFI allows a single flash driver to be used for an entire family of parts.

This is not a driver for a specific device, but for a set of command read/write/erase algorithms. CFI allows us to determine which algorithm to utilize at runtime. It is this set of command algorithms that will be implemented as the derived component.

Flash memory space is segmented into areas called blocks. The size of each block is based on a power of 2. A region is defined as a contiguous set of blocks of the same size. Some parts have several regions while others have one. The arrangement of blocks and regions is referred to by this module as the part's geometry.

The cells within the part can be programmed from a logic 1 to a logic 0 and not the other way around. To change a cell back to a logic 1, the entire block containing that cell must be erased. When a block is erased all bytes contain the value 0xFF. The number of times a block can be erased is finite. Eventually the block will wear out and will no longer be capable of erasure. As of this writing, the typical flash block can be erased 100,000 or more times.

## Features provided by this module:

- Part timing, geometry, features, and command algorithm determined by CFI query.
- Supported architectures include:
  - o 16-bit data bus: Single x16 part in word mode
  - o 32-bit data bus: Two x16 parts in word mode.
- Two read/write/erase APIs.
- Erase/write suspension.
- Self test diagnostics.
- Block locking (if supported by specific part).

- Chip erase (if supported by specific part).
- Non-blocking write & erase function calls.
- Part specific control. Supported features of individual parts are listed within the driver module for that part.

Features listed above not currently implemented include:

- Non-blocking write & erase function calls.
- Block locking.
- Support of more architectues.
- Self test diagnostics.

This component exports two differing types of read/write/erase APIs. The geometry un-aware API allows the user to ignore the geometry of the underlying flash device. The geometry aware API operates on specific blocks The former API is designed for casual use while the latter may prove useful for designers wishing to use this driver under a flash file system. Both APIs can be used interchangeably.

Write and erase function calls can be set to return immediately (non-blocking) even though the intended operation is incomplete. This is useful for systems that utilize a watchdog timer. It also facilitates the use of an interrupt driven programming algorithm. This feature is dependent upon the capabilities of the flash devices.

If the geometry un-aware API is used, then the user requires no knowledge of the underlying hardware. Usage of this API along with non-blocking write/erase should be done carefully because non-blocking write/erase assumes some knowledge of the device(s) geometry.

If part specific advanced features are required, then the XFlash\_DeviceControl function is available provided the feature has been implemented by the part driver module.

#### Note:

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads, mutual exclusion, virtual memory, cache control, or HW write protection management must be satisfied by the layer above this driver.

Use of this driver by multiple threads must be carefully thought out taking into consideration the underlying flash devices in use. This driver does not use mutual exclusion or critical region control.

#### MODIFICATION HISTORY:

Ver Who Date Changes

\_\_\_\_\_

```
#include "xflash.h"
#include "xflash_cfi.h"
#include "xparameters.h"
```

# **Functions**

```
XStatus XFlash_Initialize (XFlash *InstancePtr, Xuint16 DeviceId)
XFlash Config * XFlash LookupConfig (Xuint16 DeviceId)
        XStatus XFlash_ReadBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
                Xuint32 Offset, Xuint32 Bytes, void *DestPtr)
        XStatus XFlash_WriteBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
                Xuint32 Offset, Xuint32 Bytes, void *SrcPtr)
        XStatus XFlash_WriteBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
                Block, Xuint32 Offset)
        XStatus XFlash_WriteBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
                Block, Xuint32 Offset)
        XStatus XFlash_EraseBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
                Xuint16 NumBlocks)
        XStatus XFlash_EraseBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
                Block)
        XStatus XFlash_EraseBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
                Block)
        XStatus XFlash_LockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
                Xuint16 NumBlocks)
        XStatus XFlash_UnlockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
                Xuint16 NumBlocks)
        XStatus XFlash_GetBlockStatus (XFlash *InstancePtr, Xuint16 Region, Xuint16
                Block)
        XStatus XFlash_Read (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void
                *DestPtr)
        XStatus XFlash_Write (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void
                *SrcPtr)
        XStatus XFlash_WriteSuspend (XFlash *InstancePtr, Xuint32 Offset)
        XStatus XFlash_WriteResume (XFlash *InstancePtr, Xuint32 Offset)
```

XStatus XFlash\_Erase (XFlash \*InstancePtr, Xuint32 Offset, Xuint32 Bytes)

XStatus XFlash\_EraseSuspend (XFlash \*InstancePtr, Xuint32 Offset)

```
XStatus XFlash_EraseResume (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlash_Lock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
XStatus XFlash_Unlock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
XStatus XFlash_GetStatus (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlash_EraseChip (XFlash *InstancePtr)
XStatus XFlash_SelfTest (XFlash *InstancePtr)
XStatus XFlash_Reset (XFlash *InstancePtr)
XStatus XFlash_SetOptions (XFlash *InstancePtr, Xuint32 OptionsFlag)
Xuint32 XFlash_GetOptions (XFlash *InstancePtr)
XFlashGeometry * XFlash_GetGeometry (XFlash *InstancePtr)
XFlashProperties * XFlash_GetProperties (XFlash *InstancePtr)
XStatus XFlash_DeviceControl (XFlash *InstancePtr, Xuint32 Command, Xuint32 Param, Xuint32 *ReturnPtr)
Xboolean XFlash_IsReady (XFlash *InstancePtr)
```

# **Function Documentation**

Accesses device specific data or commands. For a list of commands, see derived component documentation.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Command is the device specific command to issue

Param is the command parameter

*ReturnPtr* is the result of command (if any)

#### **Returns:**

- XST\_SUCCESS if successful
- XST\_FLASH\_NOT\_SUPPORTED if the command is not recognized/supported by the device(s).

#### Note:

None.

Erases the specified address range.

Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

Erase the specified range of the device(s). Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_ERASE\_OPTION option has an impact on the number of bytes that can be erased in a single call to this function:

- If clear, then the number of bytes to erase can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the block size of the device at the provided offset and whether the device(s) contains a block erase queue.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin erasure.

*Bytes* is the number of bytes to erase.

#### **Returns:**

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set, then the return value is one of the following:

- o XST SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- o XST\_FLASH\_BLOCKING\_CALL\_ERROR if the amount of data to be erased exceeds the erase queue capacity of the device(s).

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned:

 XST\_FLASH\_ERROR if an erase error occurred. This error is usually device specific. Use XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is possible that the target address range was only partially erased.

#### Note:

Due to flash memory design, the range actually erased may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Erases the specified block.

Returns immediately if the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_ERASE\_OPTION option has an impact on the number of bytes that can be erased in a single call to this function:

- If clear, then the number of bytes to erase can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the block size of the device at the provided offset and whether the device(s) contains a block erase queue.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

*NumBlocks* is the the number of blocks to erase.

#### **Returns:**

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set, then the return value is one of the below.

- XST\_SUCCESS if successfull.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned

 XST\_FLASH\_ERROR if an erase error occured. This error is usually device specific. Use XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is possible that the target address range was only partially erased.

#### Note:

The arguments point to a starting Region and Block. The NumBlocks parameter may cross over Region boundaries as long as the entire range lies within the part(s) address range and the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is not set.

Resumes an erase operation that was suspended with XFlash\_EraseBlockSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being erased

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

Suspends a currently in progress erase operation and place the device(s) in read mode. When suspended, any block not being erased can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_EraseBlock**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing block
Block is the block that is being erased

#### **Returns:**

- o XST SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

## **XStatus** XFlash\_EraseChip( **XFlash** \* *InstancePtr*)

Erases the entire device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

#### **Returns:**

If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set, then the return value is always XST\_SUCCESS. If XFL\_NON\_BLOCKING\_ERASE\_OPTION option is clear, then the following additional codes can be returned:

- XST\_FLASH\_NOT\_SUPPORTED if the chip erase is not supported by the device(s).
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error during the operation. XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

None.

Resumes an erase operation that was suspended with XFlash\_EraseSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where erase resumption should be Resumed.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Suspends a currently in progress erase operation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_Erase**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where suspension should occur.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the

Offset parameter is ignored.

Returns the status of the device. This function is intended to be used to poll the device in the following circumstances:

- After calling XFlash\_WriteBlock with XFL\_NON\_BLOCKING\_WRITE\_OPTION option set.
- After calling XFlash\_EraseBlock with XFL\_NON\_BLOCKING\_ERASE\_OPTION option set.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

#### **Returns:**

- XST\_FLASH\_READY if the device(s) have completed the previous operation without error.
- XST\_FLASH\_BUSY if the device(s) are currently performing an erase or write operation.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error occuring during another operation such as write, erase, or block locking.
   XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

With some types of flash devices, there may be no difference between using XFlash\_GetBlockStatus or XFlash\_GetStatus. See your part data sheet for more information.

XFlashGeometry\* XFlash\_GetGeometry( XFlash \* InstancePtr)

| Gets the instance's geometry data                                               |
|---------------------------------------------------------------------------------|
| Parameters:  InstancePtr is the pointer to the XFlash instance to be worked on. |
| Returns: Instance's Geometry structure                                          |
| Note: None.                                                                     |
| Xuint32 XFlash_GetOptions( XFlash * InstancePtr)                                |
| Gets interface options for this device instance.                                |
| Parameters:  InstancePtr is the pointer to the XFlash instance to be worked on. |
| Returns: Current options flag                                                   |
| Note: None.                                                                     |
|                                                                                 |
| XFlashProperties* XFlash_GetProperties( XFlash * InstancePtr)                   |
| Gets the instance's property data                                               |
| Parameters:  InstancePtr is the pointer to the XFlash instance to be worked on. |
| Returns: Instance's Properties structure                                        |
| Note:                                                                           |

None.

Returns the status of the device. This function is intended to be used to poll the device in the following circumstances:

- After calling XFlash\_Write with XFL\_NON\_BLOCKING\_WRITE\_OPTION option set.
- After calling XFlash\_Erase or XFlash\_EraseChip with XFL\_NON\_BLOCKING\_ERASE\_OPTION option set.

#### **Parameters:**

InstancePtr is the pointer to the XFlash instance to be worked on.

Offset is the offset into the part.

#### **Returns:**

- XST\_FLASH\_READY if the device(s) have completed the previous operation without error.
- XST\_FLASH\_BUSY if the device(s) are currently performing an erase or write operation.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error occuring during another operation such as write, erase, or block locking.
   XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

With some types of flash devices, there may be no difference between using XFlash\_GetBlockStatus or XFlash\_GetStatus. See your part data sheet for more information.

Initializes a specific XFlash instance. The initialization entails:

- Issuing the CFI query command
- Get and translate relevent CFI query information.
- Set default options for the instance.
- Setup the VTable.
- Call the initialize function of the instance, which does the following:
  - o Get and translate extended vendor CFI query information.
  - Some VTable functions may be replaced with more efficient ones based on data extracted from the extended CFI query. A replacement example would be a buffered XFlash\_WriteBlock replacing a non-buffered XFlash\_WriteBlock.
  - Reset the device by clearing any status information and placing the device in read mode.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

*DeviceId* 

is the unique id of the device controlled by this component. Passing in a device id associates the generic component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

The return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is returned. Possible error codes are:

- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.
- XST\_FLASH\_PART\_NOT\_SUPPORTED if the command set algorithm or Layout is not supported by any derived component compiled into the system.
- XST\_FLASH\_TOO\_MANY\_REGIONS if the part contains too many erase regions. This can be fixed by increasing the value of XFL\_MAX\_ERASE\_REGIONS then re- compiling the driver.
- o XST\_FLASH\_CFI\_QUERY\_ERROR if the device would not enter CFI query mode. Either the device(s) do not support CFI, the wrong BaseAddress param was used, an unsupported part layout exists, or a hardware problem exists with the part.

#### Note:

None.

Checks the readiness of the device, which means it has been successfully initialized.

#### **Parameters:**

InstancePtr is a pointer to the XFlash instance to be worked on.

#### **Returns:**

XTRUE if the device has been initialized (but not necessarily started), and XFALSE otherwise.

#### Note:

This function only exists in the base component since it is common across all derived components. Asserts based on the IsReady flag exist only in the base component.

Locks the blocks in the specified range of the device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin block

locking.

*Bytes* is the number of bytes to lock.

#### **Returns:**

- o XST SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

Due to flash memory design, the range actually locked may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Locks the specified block. Prevents it from being erased or written.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

NumBlocks is the the number of blocks to erase. The number may extend into a different

region.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

None.

# XFlash\_Config\* XFlash\_LookupConfig( Xuint16 DeviceId)

Looks up the device configuration based on the unique device ID.

#### **Parameters:**

DeviceId is the unique device ID to be searched for in the table

#### **Returns:**

Returns a pointer to the configuration data for the device, or XNULL if not device is found.

Copies data from the device(s) memory space to a user buffer. The source and destination addresses can be on any alignment supported by the processor.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to read.

*Bytes* is the number of bytes to copy.

*DestPtr* is the destination address to copy data to.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the source address does not start within the addressable areas of the device(s).

#### Note:

This function allows the transfer of data past the end of the device's address space. If this occurs, then results are undefined.

Copy data from a specific device block to a user buffer. The source and destination addresses can be on any byte alignment supported by the target processor.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

Region is the erase region the block appears in.

Block is the block number within the erase region.

Offset is the starting offset in the block where reading will begin.

*Bytes* is the number of bytes to copy.

*DestPtr* is the destination address to copy data to.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if Region, Block, and Offset parameters do not point to a valid block.

#### Note:

The arguments point to a starting Region, Block, and Offset within that block. The Bytes parameter may cross over Region and Block boundaries. If Bytes extends past the end of the device's address space, then results are undefined.

### XStatus XFlash\_Reset( XFlash \* InstancePtr)

Clears the device(s) status register(s) and place the device(s) into read mode.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_BUSY if the flash devices were in the middle of an operation and could not be reset.
- XST\_FLASH\_ERROR if the device(s) have experienced an internal error during the operation. XFlash\_DeviceControl() must be used to access the cause of the device specific error condition.

#### Note:

None.

## XStatus XFlash\_SelfTest( XFlash \* InstancePtr)

Runs a self-test on the driver/device. This is a destructive test. Tests performed include:

- Address bus test
- Data bus test.

When the tests are complete, the device is reset back into read mode.

#### **Parameters:**

*InstancePtr* is a pointer to the XComponent instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_ERROR if any test fails.

#### Note:

None.

Sets interface options for this device instance.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on. *OptionsFlag* is the options to set. 1=set option, 0=clear option.

#### **Returns:**

- XST\_SUCCESS if options successfully set.
- o XST\_FLASH\_NOT\_SUPPORTED if option is not supported.

#### Note:

None.

Unlocks the blocks in the specified range of the device(s).

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin block

unlocking.

*Bytes* is the number of bytes to unlock.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- o XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

Due to flash memory design, the range actually unlocked may be larger than what was specified by the Offset & Bytes parameters. This will occur if the parameters do not align to block boundaries.

Unlocks the specified block.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

*NumBlocks* is the the number of blocks to erase. The number may extend into a different

region.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if region and/or block do not specify a valid block within the device.
- XST\_FLASH\_NOT\_SUPPORTED if the device(s) do not support block locking.

#### Note:

None.

Programs the devices with data stored in the user buffer. The source and destination address must be aligned to the width of the flash's data bus.

Returns immediately if the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_WRITE\_OPTION option has an impact on the number of bytes that can be written:

- If clear, then the number of bytes to write can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the alignment and size of the device's write buffer. The rule is that the number of bytes being written cannot cross over an alignment boundary. Alignment information is obtained in the InstancePtr->Properties.ProgCap attribute.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset into the device(s) address space from which to begin

programming. Must be aligned to the width of the flash's data bus.

*Bytes* is the number of bytes to program.

*SrcPtr* is the source address containing data to be programmed. Must be aligned to

the width of the flash's data bus.

#### **Returns:**

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set, then the return value is one of the following:

- o XST\_SUCCESS if successful.
- XST\_FLASH\_ADDRESS\_ERROR if the destination address range is not completely within the addressable areas of the device(s).
- XST\_FLASH\_ALIGNMENT\_ERROR if the Offset or SrcPtr is not aligned to the width of the flash's data bus.
- XST\_BLOCKING\_CALL\_ERROR if the write would cross a write buffer boundary.

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is clear, then the following additional codes can be returned:

 XST\_FLASH\_ERROR if a write error occurred. This error is usually device specific. Use XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is possible that the target address range was only partially programmed.

#### Note:

Programs the devices with data stored in the user buffer. The source and destination address can be on any alignment supported by the processor. This function will block until the operation completes or an error is detected.

Returns immediately if the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set. If clear, the device(s) are polled until an error, timeout or the operation completes successfully.

The XFL\_NON\_BLOCKING\_WRITE\_OPTION option has an impact on the number of bytes that can be written:

- If clear, then the number of bytes to write can be any number as long as it is within the bounds of the device(s).
- If set, then the number of bytes depends on the alignment and size of the device's write buffer. The rule is that the number of bytes being written cannot cross over an alignment boundary. Alignment information is obtained in the InstancePtr->Properties.ProgCap attribute.

#### **Parameters:**

*InstancePtr* is a pointer to the XFlash instance to be worked on.

*Region* is the erase region the block appears in.

*Block* is the block number within the erase region.

Offset is the starting offset in the block where writing will begin.

*Bytes* is the number of bytes to write.

SrcPtr is the source address containing data to be programmed

#### **Returns:**

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set, then the return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is returned. Possible error codes are:

 XST\_FLASH\_ADDRESS\_ERROR if Region, Block, and Offset parameters do not point to a valid block. Or, the Bytes parameter causes the read to go past the last addressible byte in the device(s).

- XST\_FLASH\_ALIGNMENT\_ERROR if the Offset or SrcPtr is not aligned to the width of the flash's data bus.
- XST\_BLOCKING\_CALL\_ERROR if the write would cross a write buffer boundary.

If XFL\_NON\_BLOCKING\_WRITE\_OPTION option is clear, then the following additional codes can be returned:

 XST\_FLASH\_ERROR if a write error occured. This error is usually device specific. Use XFlash\_DeviceControl() to retrieve specific error conditions. When this error is returned, it is possible that the target address range was only partially programmed.

#### Note:

The arguments point to a starting Region, Block, and Offset within that block. The Bytes parameter may cross over Region and Block boundaries as long as the entire range lies within the part(s) address range and the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is not set.

Resumes a write operation that was suspended with XFlash\_WriteBlockSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being erased

Offset is the offset in the device where resumption should occur

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored.

Suspends a currently in progress write opearation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_WRITE\_OPTION option is set and a previous call to **XFlash\_WriteBlock**() has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Region is the region containing blockBlock is the block that is being written

Offset is the offset in the device where suspension should occur

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore Region & Block parameters are ignored in those cases.

Resumes a write operation that was suspended with XFlash\_WriteSuspend.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where write resumption should occur.

#### **Returns:**

- XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

Suspends a currently in progress write operation and place the device(s) in read mode. When suspended, any block not being programmed can be read.

This function should be used only when the XFL\_NON\_BLOCKING\_ERASE\_OPTION option is set and a previous call to **XFlash\_Write()** has been made. Otherwise, undetermined results may occur.

#### **Parameters:**

*InstancePtr* is the pointer to the XFlash instance to be worked on.

Offset is the offset with the device where suspension should occur.

#### **Returns:**

- o XST\_SUCCESS if successful.
- XST\_FLASH\_NOT\_SUPPORTED if write suspension is not supported by the device(s)

#### Note:

Some devices such as Intel do not require a block address to suspend erasure. Therefore the Offset parameter is ignored.

## Xilinx Device Drivers

### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# flash/v1\_00\_a/src/xflash\_geometry.h File Reference

## **Detailed Description**

This is a helper component for XFlash. It contains the geometry information for an XFlash instance with utilities to translate from absolute to block coordinate systems.

### **Absolute coordinates**

This coordinate system is simply an offset into the address space of the flash instance.

### **Block coordinates**

This coordinate system is dependent on the device's block geometry. All flash devices are divisible by independent erase blocks which can be addressed with this coordinate system. The coordinates are defined as:

- BlockOffset The offset within an erase block
- Block An erase block
- Region An area containing erase blocks of the same size

The picture below shows the differences between the coordinate systems. The sample part has two regions of three blocks each.

| Absolute  | Region | Block | Offset       |  |
|-----------|--------|-------|--------------|--|
|           |        |       |              |  |
| + 0       | 0      | 0     | 0            |  |
|           | 0      | 0     | blocksizeA-1 |  |
| ++        | 0      | 1     | 0            |  |
|           | 0      | 1     | blocksizeA-1 |  |
| ++        | 0      | 2     | 0            |  |
|           | 0      | 2     | blocksizeA-1 |  |
| +=======+ | 1      | 0     | 0            |  |
|           |        |       |              |  |
|           |        |       |              |  |



### **Multiple devices**

Some systems designs have more than one physical part wired in parallel on the data bus with each part appearing to be interleaved in the address space. The geometry takes these extra parts into consideration by doubling the sizes of blocks and regions.

### MODIFICATION HISTORY:

## **Data Structures**

struct XFlashGeometry

## **Defines**

#define XFL\_MAX\_ERASE\_REGIONS

```
#define XFL_GEOMETRY_IS_BLOCK_VALID(GeometryPtr, Region, Block, BlockOffset)
#define XFL_GEOMETRY_IS_ABSOLUTE_VALID(GeometryPtr, Offset)
#define XFL_GEOMETRY_BLOCKS_LEFT(GeometryPtr, Region, Block)
#define XFL_GEOMETRY_BLOCK_DIFF(GeometryPtr, StartRegion, StartBlock, EndRegion,
EndBlock)
#define XFL_GEOMETRY_INCREMENT(GeometryPtr, Region, Block)
```

## **Functions**

```
XStatus XFlashGeometry_ToBlock (XFlashGeometry *InstancePtr, Xuint32 AbsoluteOffset, Xuint16 *Region, Xuint16 *Block, Xuint32 *BlockOffset)
```

XStatus XFlashGeometry\_ToAbsolute (XFlashGeometry \*InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32 BlockOffset, Xuint32 \*AbsoluteOffsetPtr)

Xuint32 XFlashGeometry\_ConvertLayout (Xuint8 NumParts, Xuint8 PartWidth, Xuint8 PartMode)

## **Define Documentation**

```
#define XFL_GEOMETRY_BLOCK_DIFF( GeometryPtr,
StartRegion,
StartBlock,
EndRegion,
EndBlock )
```

Calculates the number of blocks between the given start and end coordinates.

### **Parameters:**

GeometryPtr is the geometry instance that defines flash addressing

StartRegion is the starting region
StartBlock is the starting block.
EndRegion is the ending region
EndBlock is the ending block.

### **Returns:**

The number of blocks between start Region/Block and end Region/Block (inclusive)

Calculates the number of blocks between the given coordinates and the end of the device.

### **Parameters:**

GeometryPtr is the geometry instance that defines flash addressing

Region is the starting region Block is the starting block.

### **Returns:**

The number of blocks between Region/Block and the end of the device (inclusive)

### 

Increments the given Region and Block to the next block address.

### **Parameters:**

GeometryPtr is the geometry instance that defines flash addressing

Region is the starting region.

Block is the starting block.

### **Returns:**

Region parameter is incremented if the next block starts in a new region. Block parameter is set to zero if the next block starts in a new region, otherwise it is incremented by one.

## #define XFL\_GEOMETRY\_IS\_ABSOLUTE\_VALID( GeometryPtr, Offset )

Tests the given absolute Offset to verify it lies within the bounds of the address space defined by a geometry instance.

### **Parameters:**

GeometryPtr is the geometry instance that defines flash addressing

Offset is the offset to test

### **Returns:**

- o 0 if Offset do not lie within the address space described by GeometryPtr.
- o 1 if Offset are within the address space

```
#define XFL_GEOMETRY_IS_BLOCK_VALID( GeometryPtr,
Region,
Block,
BlockOffset )
```

Tests the given Region, Block, and Offset to verify they lie within the address space defined by a geometry instance.

### **Parameters:**

GeometryPtr is the geometry instance that defines flash addressing

Region is the region to test Block is the block to test

BlockOffset is the offset within block

### **Returns:**

- o 0 if Region, Block, & BlockOffset do not lie within the address space described by GeometryPtr.
- o 1 if Region, Block, & BlockOffset are within the address space

### #define XFL\_MAX\_ERASE\_REGIONS

A block region is defined as a set of consecutive erase blocks of the same size. Most flash devices only have a handful of regions. If a part has more regions than defined by this constant, then the constant must be modified to accomodate the part. The minimum value of this constant is 1 and there is no maximum value. Note that increasing this value also increases the amount of memory used by the geometry structure approximately 12 bytes per increment.

## **Function Documentation**

Converts array layout into an XFL\_LAYOUT\_Xa\_Xb\_Xc constant. This function is typically called during initialization to convert ordinal values delivered by a system generator into the XFL constants which are optimized for use by the flash driver.

### **Parameters:**

NumParts - Number of parts in the array.

PartWidth - Width of each part in bytes.

PartMode - Operation mode of each part in bytes.

### **Returns:**

- o XFL\_LAYOUT\_\* One of the supported layouts
- o XNULL if a layout cannot be found that supports the given arguments

### **Note:**

None.

Converts block coordinates to a part offset. Region, Block, & BlockOffset are converted to PartOffset

### **Parameters:**

InstancePtr is the pointer to the XFlash instance to be worked on.

Region is the erase region the physical address appears in.

Block is the block within Region the physical address appears in.

BlockOffset is the offset within Block where the physical address appears.

AbsoluteOffsetPtr is the returned offset value

### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_ADDRESS\_ERROR if the block coordinates are invalid.

### Note:

Converts part offset block coordinates. PartOffset is converted to Region, Block, & BlockOffset

### **Parameters:**

*InstancePtr* is the pointer to the **XFlashGeometry** instance to be worked on.

*AbsoluteOffset* is the offset within part to find block coordinates for.

RegionPtr is the tregion that corresponds to AbsoluteOffset. This is a return parameter.

BlockPtr is the the block within Region that corresponds to AbsoluteOffset. This is a return

parameter.

BlockOffsetPtr is the the offset within Block that corresponds to AbsoluteOffset. This is a return

parameter.

### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_ADDRESS\_ERROR if the block coordinates are invalid.

### **Note:**

None.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XFlashGeometry Struct Reference

#include <xflash\_geometry.h>

## **Detailed Description**

Flash geometry

## **Data Fields**

**Xuint32 BaseAddress** 

**Xuint32 MemoryLayout** 

**Xuint32 DeviceSize** 

**Xuint32 NumEraseRegions** 

**Xuint16 NumBlocks** 

**Xuint32 AbsoluteOffset** 

**Xuint16 AbsoluteBlock** 

**Xuint16 Number** 

**Xuint32 Size** 

## **Field Documentation**

Xuint16 XFlashGeometry::AbsoluteBlock

Block number where region begins

### Xuint32 XFlashGeometry::AbsoluteOffset

Offset within part where region begins

### Xuint32 XFlashGeometry::BaseAddress

Base address of part(s)

### Xuint32 XFlashGeometry::DeviceSize

Total device size in bytes

### Xuint32 XFlashGeometry::MemoryLayout

How multiple parts are connected on the data bus. Choices are limited to XFL\_LAYOUT\_Xa\_Xb\_Xc constants

### Xuint16 XFlashGeometry::Number

Number of blocks in this region

### Xuint16 XFlashGeometry::NumBlocks

Total number of blocks in device

### Xuint32 XFlashGeometry::NumEraseRegions

Number of erase regions

### Xuint32 XFlashGeometry::Size

Size of the block in bytes

The documentation for this struct was generated from the following file:

• flash/v1\_00\_a/src/xflash\_geometry.h

## flash/v1\_00\_a/src/xflash\_properties.h File Reference

## **Detailed Description**

This is a helper component for XFlash. It contains various datum common to flash devices most of which can be derived from the CFI query.

### Note:

There is no implementation file with this component.

### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a rmm 07/16/01 First release

#include "xbasic_types.h"
#include "xstatus.h"
```

## **Data Structures**

```
struct XFlashPartID
struct XFlashProgCap
struct XFlashProperties
struct XFlashTiming
```

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XFlashPartID Struct Reference

#include <xflash\_properties.h>

## **Detailed Description**

Flash identification

## **Data Fields**

Xuint8 ManufacturerID Xuint8 DeviceID Xuint16 CommandSet

## **Field Documentation**

### Xuint16 XFlashPartID::CommandSet

Command algorithm used by part. Choices are defined in XFL\_CMDSET constants

### Xuint8 XFlashPartID::DeviceID

Part number of manufacturer

### Xuint8 XFlashPartID::ManufacturerID

Manufacturer of parts

The documentation for this struct was generated from the following file:

• flash/v1\_00\_a/src/xflash\_properties.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XFlashProgCap Struct Reference

#include <xflash\_properties.h>

## **Detailed Description**

Programming parameters

## **Data Fields**

Xuint32 WriteBufferSize Xuint32 WriteBufferAlignmentMask Xuint32 EraseQueueSize

## **Field Documentation**

### Xuint32 XFlashProgCap::EraseQueueSize

Number of erase blocks that can be queued up at once

### Xuint32 XFlashProgCap::WriteBufferAlignmentMask

Alignment of the write buffer

### Xuint32 XFlashProgCap::WriteBufferSize

Number of bytes that can be programmed at once

The documentation for this struct was generated from the following file:

• flash/v1\_00\_a/src/xflash\_properties.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XFlashProperties Struct Reference

#include <xflash\_properties.h>

## **Detailed Description**

Consolidated parameters

## **Data Fields**

XFlashPartID PartID XFlashTiming TimeTypical XFlashTiming TimeMax

XFlashProgCap ProgCap

## **Field Documentation**

XFlashPartID XFlashProperties::PartID

Uniquely identifies the part

XFlashProgCap XFlashProperties::ProgCap

Programming capabilities

XFlashTiming XFlashProperties::TimeMax

Worst case timing data

## XFlashTiming XFlashProperties::TimeTypical

Typical timing data

The documentation for this struct was generated from the following file:

 $\bullet ~~flash/v1\_00\_a/src/\textbf{xflash\_properties.h} \\$ 

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XFlashTiming Struct Reference

#include <xflash\_properties.h>

## **Detailed Description**

Flash timing

## **Data Fields**

**Xuint16 WriteSingle\_Us** 

**Xuint16 WriteBuffer\_Us** 

Xuint16 EraseBlock\_Ms

**Xuint16 EraseChip\_Ms** 

## **Field Documentation**

Xuint16 XFlashTiming::EraseBlock\_Ms

Time to erase a single block Units are in milliseconds

Xuint16 XFlashTiming::EraseChip\_Ms

Time to perform a chip erase Units are in milliseconds

**Xuint16** XFlashTiming::WriteBuffer\_Us

Time to program the contents of the write buffer. Units are in microseconds If the part does not support write buffers, then this value should be zero

### Xuint16 XFlashTiming::WriteSingle\_Us

Time to program a single word unit Units are in microseconds

The documentation for this struct was generated from the following file:

 $\bullet \hspace{0.2cm} flash/v1\_00\_a/src/\textbf{xflash\_properties.h}$ 

## Xilinx Device Drivers Driver Summary Copyright Ell Line Date Elle Line Challenge

Main Page Data Structures File List Data Fields Globals

## XFlash\_Config Struct Reference

#include <xflash.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

**Xuint16 DeviceId** 

**Xuint32 BaseAddr** 

**Xuint8 NumParts** 

**Xuint8 PartWidth** 

**Xuint8 PartMode** 

## **Field Documentation**

Xuint32 XFlash\_Config::BaseAddr

Base address of array

Xuint16 XFlash\_Config::DeviceId

Unique ID of device

Xuint8 XFlash\_Config::NumParts

Number of parts in the array

### Xuint8 XFlash\_Config::PartMode

Operation mode of each part in bytes

### Xuint8 XFlash\_Config::PartWidth

Width of each part in bytes

The documentation for this struct was generated from the following file:

• flash/v1\_00\_a/src/xflash.h

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XFlashTag Struct Reference

#include <xflash.h>

## **Detailed Description**

The XFlash driver instance data. The user is required to allocate a variable of this type for every flash device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• flash/v1\_00\_a/src/xflash.h

# flash/v1\_00\_a/src/xflash\_g.c File Reference

## **Detailed Description**

This file contains a table that specifies the configuration of devices in the system. In addition, there is a lookup function used by the driver to access its configuration information.

### MODIFICATION HISTORY:

```
Ver Who Date Changes

----- 1.00a rmm 01/18/01 First release
1.00a rpm 05/05/02 Added include of xparameters.h

#include "xflash.h"
#include "xparameters.h"
```

## **Variables**

XFlash\_Config XFlash\_ConfigTable [XPAR\_XFLASH\_NUM\_INSTANCES]

## **Variable Documentation**

### XFlash\_Config XFlash\_ConfigTable[XPAR\_XFLASH\_NUM\_INSTANCES]

This table contains configuration information for each flash device in the system.

## flash/v1\_00\_a/src/xflash\_cfi.c File Reference

## **Detailed Description**

This module implements the helper component XFlashCFI.

The helper component is responsible for retrieval and translation of CFI data from a complient flash device. CFI contains data that defines part geometry, write/erase timing, and programming data.

Data is retrieved using macros defined in this component's header file. The macros simplify data extraction because they have been written to take into account the layout of parts on the data bus. To the driver, CFI data appears as if it were always being read from a single 8-bit part (XFL\_LAYOUT\_X8\_X8\_X1) Otherwise, the retrieval code would have to contend with all the formats illustrated below. The illustration shows how the first three bytes of the CFI query data "QRY" appear in flash memory space for various part layouts.

Where the holes between Q, R, and Y are NULL (all bits 0)

### Note:

This helper component is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads, mutual exclusion, virtual memory, or cache control management must be satisfied by the layer above this driver.

## **Functions**

XStatus XFlashCFI\_ReadCommon (XFlashGeometry \*GeometryPtr, XFlashProperties \*PropertiesPtr)

## **Function Documentation**

Retrieves the standard CFI data from the part(s), interpret the data, and update the provided geometry and properties structures.

Extended CFI data is part specific and ignored here. This data must be read by the specific part component driver.

### **Parameters:**

GeometryPtr is an input/output parameter. This function expects the BaseAddress and MemoryLayout attributes to be correctly initialized. All other attributes of this structure will be setup using translated CFI data read from the part.

*PropertiesPtr* is an output parameter. Timing, identification, and programming CFI data will be translated and written to this structure.

### **Returns:**

- XST\_SUCCESS if successful.
- o XST\_FLASH\_CFI\_QUERY\_ERROR if an error occurred interpreting the data.
- o XST\_FLASH\_PART\_NOT\_SUPPORTED if invalid Layout parameter

| Note: |       |  |  |  |
|-------|-------|--|--|--|
|       | None. |  |  |  |
|       |       |  |  |  |
|       |       |  |  |  |

## flash/v1\_00\_a/src/xflash\_geometry.c File Reference

## **Detailed Description**

This module implements the helper component **XFlashGeometry**.

The helper component is responsible for containing the geometry information for the flash part(s) and for converting from an absolute part offset to region/block/blockOffset coordinates.

**XFlashGeometry** describes the geometry of the entire instance, not the individual parts of that instance. For example, if the user's board architecture uses two 16-bit parts in parallel for a 32-bit data path, then the size of erase blocks and device sizes are multiplied by a factor of two.

### Note:

This helper component is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads, mutual exclusion, virtual memory, or cache control management must be satisfied by the layer above this driver.

### MODIFICATION HISTORY:

## **Functions**

```
XStatus XFlashGeometry_ToAbsolute (XFlashGeometry *InstancePtr, Xuint16 Region, Xuint16 Block, Xuint32 BlockOffset, Xuint32 *AbsoluteOffsetPtr)

XStatus XFlashGeometry_ToBlock (XFlashGeometry *InstancePtr, Xuint32 AbsoluteOffset, Xuint16 *RegionPtr, Xuint16 *BlockPtr, Xuint32 *BlockOffsetPtr)

Xuint32 XFlashGeometry_ConvertLayout (Xuint8 NumParts, Xuint8 PartWidth, Xuint8 PartMode)
```

## **Function Documentation**

```
Xuint32 XFlashGeometry_ConvertLayout( Xuint8 NumParts, Xuint8 PartWidth, Xuint8 PartMode
)
```

Converts array layout into an XFL\_LAYOUT\_Xa\_Xb\_Xc constant. This function is typically called during initialization to convert ordinal values delivered by a system generator into the XFL constants which are optimized for use by the flash driver.

### **Parameters:**

*NumParts* - Number of parts in the array.

PartWidth - Width of each part in bytes.

PartMode - Operation mode of each part in bytes.

### **Returns:**

- XFL\_LAYOUT\_\* One of the supported layouts
- o XNULL if a layout cannot be found that supports the given arguments

### Note:

Converts block coordinates to a part offset. Region, Block, & BlockOffset are converted to PartOffset

### **Parameters:**

InstancePtr is the pointer to the XFlash instance to be worked on.

Region is the erase region the physical address appears in.

Block is the block within Region the physical address appears in.

BlockOffset is the offset within Block where the physical address appears.

AbsoluteOffsetPtr is the returned offset value

### **Returns:**

- o XST\_SUCCESS if successful.
- o XST\_FLASH\_ADDRESS\_ERROR if the block coordinates are invalid.

### Note:

Converts part offset block coordinates. PartOffset is converted to Region, Block, & BlockOffset

### **Parameters:**

*InstancePtr* is the pointer to the **XFlashGeometry** instance to be worked on.

AbsoluteOffset is the offset within part to find block coordinates for.

*RegionPtr* is the region that corresponds to AbsoluteOffset. This is a return

parameter.

BlockPtr is the the block within Region that corresponds to AbsoluteOffset. This is

a return parameter.

BlockOffsetPtr is the the offset within Block that corresponds to AbsoluteOffset. This is a

return parameter.

### **Returns:**

o XST\_SUCCESS if successful.

o XST\_FLASH\_ADDRESS\_ERROR if the block coordinates are invalid.

### Note:

None.

# flash/v1\_00\_a/src/xflash\_intel.h File Reference

## **Detailed Description**

This is an Intel specific Flash memory component driver for CFI enabled parts.

MODIFICATION HISTORY:

```
Ver Who Date Changes
-----1.00a rmm 07/16/01 First release

#include "xbasic_types.h"
#include "xflash.h"
```

## **Functions**

```
XStatus XFlashIntel_Initialize (XFlash *InstancePtr)
XStatus XFlashIntel_Reset (XFlash *InstancePtr)
XStatus XFlashIntel_Reset (XFlash *InstancePtr)
XStatus XFlashIntel_SetOptions (XFlash *InstancePtr, Xuint32 OptionsFlag)
Xuint32 XFlashIntel_GetOptions (XFlash *InstancePtr)
XFlashProperties * XFlashIntel_GetProperties (XFlash *InstancePtr)
XFlashGeometry * XFlashIntel_GetGeometry (XFlash *InstancePtr)
XStatus XFlashIntel_DeviceControl (XFlash *InstancePtr, Xuint32 Command, Xuint32 Param, Xuint32 *ReturnPtr)
XStatus XFlashIntel_Read (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void *DestPtr)
XStatus XFlashIntel_Write (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes, void *SrcPtr)
XStatus XFlashIntel_WriteSuspend (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlashIntel_WriteResume (XFlash *InstancePtr, Xuint32 Offset)
```

```
XStatus XFlashIntel_Erase (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
XStatus XFlashIntel_EraseSuspend (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlashIntel_EraseResume (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlashIntel Lock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
XStatus XFlashIntel Unlock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
XStatus XFlashIntel GetStatus (XFlash *InstancePtr, Xuint32 Offset)
XStatus XFlashIntel_ReadBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint32 Offset, Xuint32 Bytes, void *DestPtr)
XStatus XFlashIntel WriteBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint32 Offset, Xuint32 Bytes, void *SrcPtr)
XStatus XFlashIntel_WriteBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block, Xuint32 Offset)
XStatus XFlashIntel WriteBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block, Xuint32 Offset)
XStatus XFlashIntel_EraseBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel EraseBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block)
XStatus XFlashIntel_EraseBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
XStatus XFlashIntel LockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel_UnlockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel_GetBlockStatus (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block)
XStatus XFlashIntel EraseChip (XFlash *InstancePtr)
```

## **Function Documentation**

See the base component for a description of this function, its return values, and arguments.

### **Note:**

Intel specific commands:

```
Command: XFL_INTEL_DEVCTL_SET_RYBY
```

Description:

Set the mode of the RYBY signal.

### Param:

One of XFL\_INTEL\_RYBY\_PULSE\_OFF, XFL\_INTEL\_RYBY\_PULSE\_ON\_ERASE, XFL\_INTEL\_RYBY\_PULSE\_ON\_ERASE\_PROG

### Return:

None

Command: XFL\_INTEL\_DEVCTL\_GET\_LAST\_ERROR

### Description:

Retrieve the last error condition. The data is in the form of the status register(s) read from the device(s) at the time the error was detected. The registers are formatted verbatim as they are seen on the data bus.

#### Param:

None

### Return:

The contents of the Status registers at the time the last error was detected.

See the base component for a description of this function, its return values, and arguments.

### Note:

See the base component for a description of this function, its return values, and arguments.

### Note:

None.

See the base component for a description of this function, its return values, and arguments.

### Note:

Region & Block parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

### Note:

Region & Block parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

### XStatus XFlashIntel\_EraseChip( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

### Note:

See the base component for a description of this function, its return values, and arguments.

### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

### Note:

The Region & Block parameters are not used because the device's status register appears at every addressible location.

### XFlashGeometry\* XFlashIntel\_GetGeometry( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

### Note:

### Xuint32 XFlashIntel\_GetOptions( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

### Note:

None.

### XFlashProperties\* XFlashIntel\_GetProperties( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

### Note:

None.

```
XStatus XFlashIntel_GetStatus( XFlash * InstancePtr, Xuint32 Offset
```

See the base component for a description of this function, its return values, and arguments.

### Note:

The Offset parameter is not used because the device's status register appears at every addressible location.

### XStatus XFlashIntel\_Initialize( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

### **Parameters:**

*InstancePtr* is a pointer to the flash instance to be worked on.

### **Returns:**

- o XST\_SUCCESS if successful
- o XST\_FLASH\_PART\_NOT\_SUPPORTED if the part is not supported

### Note:

Two geometry attributes MUST be defined prior to invoking this function:

- o BaseAddress
- o MemoryLayout

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

**Note:** 

#### Note:

The part is assumed to be in read-array mode.

#### **XStatus** XFlashIntel\_Reset( **XFlash** \* *InstancePtr*)

See the base component for a description of this function, its return values, and arguments.

Note:

None.

### **XStatus** XFlashIntel\_SelfTest( **XFlash** \* *InstancePtr*)

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

**Note:** 

None.

See the base component for a description of this function, its return values, and arguments.

**Note:** 

None.

See the base component for a description of this function, its return values, and arguments.

Note:

#### **Note:**

Region, Block, & Offset parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### **Note:**

Region, Block, & Offset parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

```
XStatus XFlashIntel_WriteSuspend( XFlash * InstancePtr, Xuint32 Offset
```

### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

Generated on 30 Sep 2003 for Xilinx Device Drivers

#### Xilinx Device Drivers

#### **Driver Summary** Copyright

Main Page Data Structures File List Data Fields Globals

# flash/v1\_00\_a/src/xflash\_intel.c File Reference

# **Detailed Description**

The implementation of the Intel CFI Version of the XFlash component.

This module utilizes the XFlash base component, whose attributes have been defined mostly from a CFI data query. This data is used to define the geometry of the part(s), timeout values for write & erase operations, and optional features.

#### Note:

Special consideration has to be given to varying data bus widths. To boost performance, multiple devices in parallel on the data bus are accessed in parallel. Therefore to reduce complexity and increase performance, many local primitive functions are duplicated with the only difference being the width of writes to the devices.

Even with the performance boosting optimizations, the overhead associated with this component is rather high due to the general purpose nature of its design.

Flash block erasing is a time consuming operation with nearly all latency occurring due to the devices' themselves. It takes on the order of 1 second to erase each block.

Writes by comparison are much quicker so driver overhead becomes an issue. The write algorithm has been optimized for bulk data programming and should provide relatively better performance.

- o The code/comments refers to WSM frequently. This stands for Write State Machine. WSM is the internal programming engine of the devices.
- o This driver and the underlying Intel flash memory does not allow re- programming while code is executing from the same memory.
- o If hardware is flakey or fails, then this driver could hang a thread of execution.
- o This module has some dependencies on whether it is being unit tested. These areas are noted with conditional compilation based on whether XENV\_UNITTEST is defined. This is required because unit testing occurs without real flash devices.

#### MODIFICATION HISTORY:

| Ver | Who | Date | Changes |
|-----|-----|------|---------|
|     |     |      |         |

```
1.00a rmm  07/16/01 First release
1.00a rmm  03/14/02 Added 64 bit array support
1.00a rmm  05/13/03 Fixed diab compiler warnings relating to asserts.

#include "xflash_intel.h"
#include "xflash_intel_l.h"
#include "xflash_cfi.h"
#include "xflash_geometry.h"
#include "xenv.h"
```

# **Data Structures**

```
union StatReg struct XFlashVendorData_IntelTag
```

\*DestPtr)

## **Functions**

```
XStatus XFlashIntel_Initialize (XFlash *InstancePtr)
XStatus XFlashIntel_ReadBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint32 Offset, Xuint32 Bytes, void *DestPtr)
XStatus XFlashIntel_WriteBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint32 Offset, Xuint32 Bytes, void *SrcPtr)
XStatus XFlashIntel_WriteBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block, Xuint32 Offset)
XStatus XFlashIntel_WriteBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block, Xuint32 Offset)
XStatus XFlashIntel_EraseBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel EraseBlockSuspend (XFlash *InstancePtr, Xuint16 Region, Xuint16
XStatus XFlashIntel_EraseBlockResume (XFlash *InstancePtr, Xuint16 Region, Xuint16
        Block)
XStatus XFlashIntel_LockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel_UnlockBlock (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block,
        Xuint16 NumBlocks)
XStatus XFlashIntel_GetBlockStatus (XFlash *InstancePtr, Xuint16 Region, Xuint16 Block)
```

XStatus XFlashIntel\_Read (XFlash \*InstancePtr, Xuint32 Offset, Xuint32 Bytes, void

XStatus XFlashIntel\_Write (XFlash \*InstancePtr, Xuint32 Offset, Xuint32 Bytes, void \*SrcPtr)

```
XStatus XFlashIntel WriteSuspend (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlashIntel WriteResume (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlashIntel Erase (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlashIntel EraseSuspend (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlashIntel EraseResume (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlashIntel Lock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlashIntel Unlock (XFlash *InstancePtr, Xuint32 Offset, Xuint32 Bytes)
          XStatus XFlashIntel GetStatus (XFlash *InstancePtr, Xuint32 Offset)
          XStatus XFlashIntel EraseChip (XFlash *InstancePtr)
          XStatus XFlashIntel SelfTest (XFlash *InstancePtr)
          XStatus XFlashIntel Reset (XFlash *InstancePtr)
          XStatus XFlashIntel SetOptions (XFlash *InstancePtr, Xuint32 OptionsFlag)
          Xuint32 XFlashIntel GetOptions (XFlash *InstancePtr)
XFlashGeometry * XFlashIntel_GetGeometry (XFlash *InstancePtr)
XFlashProperties * XFlashIntel GetProperties (XFlash *InstancePtr)
           XStatus XFlashIntel DeviceControl (XFlash *InstancePtr, Xuint32 Command, Xuint32 Param,
                   Xuint32 *ReturnPtr)
```

# **Function Documentation**

See the base component for a description of this function, its return values, and arguments.

#### **Note:**

Intel specific commands:

```
Command: XFL_INTEL_DEVCTL_SET_RYBY

Description:
   Set the mode of the RYBY signal.

Param:
   One of XFL_INTEL_RYBY_PULSE_OFF, XFL_INTEL_RYBY_PULSE_ON_ERASE,
   XFL_INTEL_RYBY_PULSE_ON_PROG, XFL_INTEL_RYBY_PULSE_ON_ERASE_PROG

Return:
   None

Command: XFL_INTEL_DEVCTL_GET_LAST_ERROR
   Description:
   Retrieve the last error condition. The data is in the form of the
```

status register(s) read from the device(s) at the time the error was detected. The registers are formatted verbatim as they are seen on the data bus.

#### Param:

None

#### Return:

The contents of the Status registers at the time the last error was detected.

See the base component for a description of this function, its return values, and arguments.

#### Note:

None.

See the base component for a description of this function, its return values, and arguments.

#### Note:

#### **Note:**

Region & Block parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### Note:

Region & Block parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

#### XStatus XFlashIntel\_EraseChip( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

#### Note:

None.

```
XStatus XFlashIntel_EraseResume( XFlash * InstancePtr, Xuint32 Offset )
```

See the base component for a description of this function, its return values, and arguments.

#### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

#### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### Note:

The Region & Block parameters are not used because the device's status register appears at every addressible location.

#### XFlashGeometry\* XFlashIntel\_GetGeometry( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

#### **Note:**

None.

#### Xuint32 XFlashIntel\_GetOptions( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

#### Note:

None.

#### XFlashProperties\* XFlashIntel\_GetProperties( XFlash \* InstancePtr)

#### Note:

None.

See the base component for a description of this function, its return values, and arguments.

#### Note:

The Offset parameter is not used because the device's status register appears at every addressible location.

#### **XStatus** XFlashIntel\_Initialize( **XFlash** \* *InstancePtr*)

See the base component for a description of this function, its return values, and arguments.

#### **Parameters:**

*InstancePtr* is a pointer to the flash instance to be worked on.

#### **Returns:**

- o XST SUCCESS if successful
- o XST\_FLASH\_PART\_NOT\_SUPPORTED if the part is not supported

#### Note:

Two geometry attributes MUST be defined prior to invoking this function:

- BaseAddress
- MemoryLayout

See the base component for a description of this function, its return values, and arguments.

#### Note:

**Note:** 

None.

See the base component for a description of this function, its return values, and arguments.

**Note:** 

None.

See the base component for a description of this function, its return values, and arguments.

Note:

The part is assumed to be in read-array mode.

```
XStatus XFlashIntel_Reset( XFlash * InstancePtr)
```

See the base component for a description of this function, its return values, and arguments.

Note:

#### XStatus XFlashIntel\_SelfTest( XFlash \* InstancePtr)

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

**Note:** 

Note:

None.

See the base component for a description of this function, its return values, and arguments.

Note:

None.

See the base component for a description of this function, its return values, and arguments.

#### Note:

Region, Block, & Offset parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

#### Note:

Region, Block, & Offset parameters are ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

See the base component for a description of this function, its return values, and arguments.

#### Note:

Offset parameter is ignored.

Intel flash does not differentiate RESUME between erase and write. It depends on what the flash was doing at the time the SUSPEND command was issued.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# flash/v1\_00\_a/src/xflash\_intel\_I.h File Reference

# **Detailed Description**

Contains identifiers and low-level macros/functions for the Intel 28FxxxJ3A StrataFlash driver.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 05/06/02 First release
#include "xbasic_types.h"
#include "xio.h"
```

# **Defines**

#define **XFlashIntel\_mSendCmd**(BaseAddress, Offset, Command)

# **Functions**

```
int XFlashIntel_WaitReady (Xuint32 BaseAddress, Xuint32 Offset)
int XFlashIntel_WriteAddr (Xuint32 BaseAddress, Xuint32 Offset, Xuint8 *BufferPtr,
    unsigned int Length)
int XFlashIntel_ReadAddr (Xuint32 BaseAddress, Xuint32 Offset, Xuint8 *BufferPtr,
    unsigned int Length)
int XFlashIntel_EraseAddr (Xuint32 BaseAddress, Xuint32 Offset)
```

# **Define Documentation**

```
#define XFlashIntel_mSendCmd( BaseAddress,
Offset,
Command )
```

Send the specified command to the flash device.

#### **Parameters:**

BaseAddress is the base address of the device

Offset is the offset address from the base address.

*Command* is the command to send.

#### **Returns:**

None.

#### Note:

None.

# **Function Documentation**

```
int XFlashIntel_EraseAddr( Xuint32 BaseAddress, Xuint32 Offset
)
```

Erase the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset

is the offset address from the base address to begin erasing. This offset is assumed to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

This function assumes 32-bit access to the flash array.

Lock the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset

is the offset address from the base address to lock. This offset is assumed to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

Read some number of bytes from the specified address.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to begin reading.

BufferPtr is the buffer used to store the bytes that are read.

Length is the number of bytes to read from flash.

#### **Returns:**

The number of bytes actually read.

#### Note:

This function assumes 32-bit access to the flash array.

```
int XFlashIntel_UnlockAddr( Xuint32 BaseAddress, Xuint32 Offset
)
```

Unlock the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to unlock. This offset is assumed

to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

```
int XFlashIntel_WaitReady( Xuint32 BaseAddress, Xuint32 Offset
)
```

Wait for the flash array to be in the ready state (ready for a command).

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

This function assumes 32-bit access to the flash array.

```
int XFlashIntel_WriteAddr( Xuint32 BaseAddress, Xuint32 Offset, Xuint8 * BufferPtr, unsigned int Length
```

Write the specified address with some number of bytes.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to begin writing.

BufferPtr is the buffer that will be written to flash.

Length is the number of bytes in BufferPtr that will be written to flash.

#### **Returns:**

The number of bytes actually written.

#### Note:

This function assumes 32-bit access to the flash array.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# flash/v1\_00\_a/src/xflash\_intel\_l.c File Reference

# **Detailed Description**

Contains low-level functions for the XFlashIntel driver.

```
MODIFICATION HISTORY:
```

#include "xflash intel 1.h"

```
Ver Who Date Changes
---- --- 05/06/02 First release
```

# **Functions**

```
int XFlashIntel_WriteAddr (Xuint32 BaseAddress, Xuint32 Offset, Xuint8 *BufferPtr, unsigned
    int Length)
int XFlashIntel_ReadAddr (Xuint32 BaseAddress, Xuint32 Offset, Xuint8 *BufferPtr, unsigned
    int Length)
int XFlashIntel_EraseAddr (Xuint32 BaseAddress, Xuint32 Offset)
int XFlashIntel_LockAddr (Xuint32 BaseAddress, Xuint32 Offset)
int XFlashIntel_UnlockAddr (Xuint32 BaseAddress, Xuint32 Offset)
int XFlashIntel_WaitReady (Xuint32 BaseAddress, Xuint32 Offset)
```

# **Function Documentation**

```
int XFlashIntel_EraseAddr( Xuint32 BaseAddress, Xuint32 Offset
)
```

Erase the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset

is the offset address from the base address to begin erasing. This offset is assumed to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

This function assumes 32-bit access to the flash array.

```
int XFlashIntel_LockAddr( Xuint32 BaseAddress, Xuint32 Offset
```

Lock the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset

is the offset address from the base address to lock. This offset is assumed to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

```
int XFlashIntel_ReadAddr( Xuint32 BaseAddress, Xuint32 Offset, Xuint8 * BufferPtr, unsigned int Length
```

Read some number of bytes from the specified address.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to begin reading.

BufferPtr is the buffer used to store the bytes that are read.

*Length* is the number of bytes to read from flash.

#### **Returns:**

The number of bytes actually read.

#### Note:

This function assumes 32-bit access to the flash array.

```
int XFlashIntel_UnlockAddr( Xuint32 BaseAddress, Xuint32 Offset
)
```

Unlock the block beginning at the specified address. The user is assumed to know the block boundaries and pass in an address/offset that is block aligned.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to unlock. This offset is assumed

to be a block boundary.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

```
int XFlashIntel_WaitReady( Xuint32 BaseAddress, Xuint32 Offset
```

Wait for the flash array to be in the ready state (ready for a command).

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address.

#### **Returns:**

0 if successful, or -1 if an error occurred.

#### Note:

This function assumes 32-bit access to the flash array.

```
int XFlashIntel_WriteAddr( Xuint32 BaseAddress, Xuint32 Offset, Xuint8 * BufferPtr, unsigned int Length
```

Write the specified address with some number of bytes.

#### **Parameters:**

BaseAddress is the base address of the device.

Offset is the offset address from the base address to begin writing.

BufferPtr is the buffer that will be written to flash.

Length is the number of bytes in BufferPtr that will be written to flash.

#### **Returns:**

The number of bytes actually written.

#### Note:

# gemac/v1\_00\_d/src/xgemac.h File Reference

# **Detailed Description**

The Xilinx 1 gigabit Ethernet driver component (GEMAC).

The Xilinx Ethernet 1Gbit MAC supports the following features:

- Scatter-gather & simple DMA operations, as well as simple memory mapped direct I/O interface (FIFOs)
- Gigabit Media Independent Interface (GMII) for connection to external 1Gbit Mbps PHY transceivers. Supports 125Mhz 10 bit interface (TBI) to external PHY and SerDes to external transceiver
- GMII management control reads and writes with GMII PHYs
- Independent internal transmit and receive FIFOs
- CSMA/CD compliant operations for half-duplex modes
- Internal loopback
- Automatic source address insertion or overwrite (programmable)
- Automatic FCS insertion and stripping (programmable)
- Automatic pad insertion and stripping (programmable)
- Pause frame (flow control) detection in full-duplex mode
- Programmable interframe gap
- VLAN frame support
- Jumbo frame support
- Pause frame support

#### Hardware limitations in this version

- Always in promiscuous mode
- Hardware statistic counters not implemented
- Unicast, multicast, broadcast, and promiscuous address filtering not implemented
- Half-duplex mode not implemented
- Auto source address insertion not implemented

The device driver does not support the features listed below

• Programmable PHY reset signal

Device driver limitations in this version

• Simple DMA untested

#### **Driver Description**

The device driver enables higher layer software (e.g., an application) to communicate to the GEMAC. The driver handles transmission and reception of Ethernet frames, as well as configuration of the controller. It does not handle protocol stack functionality such as Link Layer Control (LLC) or the Address Resolution Protocol (ARP). The protocol stack that makes use

of the driver handles this functionality.

Since the driver is a simple pass-through mechanism between a protocol stack and the GEMAC, no assembly of Ethernet frames is done at the driver-level. This assumes that the protocol stack passes a correctly formatted Ethernet frame to the driver for transmission, and that the driver does not validate the contents of an incoming frame

A single device driver can support multiple GEMACs.

The driver is designed for a zero-copy buffer scheme when used with DMA. Direct FIFO modes requires a buffer copy to/from data FIFOs.

#### **PHY Communication**

The driver provides rudimentary read and write functions to allow the higher layer software to access the PHY. The GEMAC provides MII registers for the driver to access. This management interface can be parameterized away in the FPGA implementation process.

#### **Asynchronous Callbacks**

The driver services interrupts and passes Ethernet frames to the higher layer software through asynchronous callback functions. When using the driver directly (i.e., not with the RTOS protocol stack), the higher layer software must register its callback functions during initialization. The driver requires callback functions for received frames, for confirmation of transmitted frames, and for asynchronous errors.

#### **Interrupts**

The driver has no dependencies on the interrupt controller. The driver provides two interrupt handlers.

XGemac\_IntrHandlerDma() handles interrupts when the GEMAC is configured with scatter-gather DMA.

XGemac\_IntrHandlerFifo() handles interrupts when the GEMAC is configured for direct FIFO I/O or simple DMA. Either of these routines can be connected to the system interrupt controller by the user.

#### **Device Reset**

Some errors that can occur in the device require a device reset. These errors are listed in the **XGemac\_SetErrorHandler**() function header. The user's error handler is responsible for resetting the device and re-configuring it based on its needs (the driver does not save the current configuration). When integrating into an RTOS, these reset and re-configure obligations are taken care of by the Xilinx adapter software.

#### **Polled Mode Operation**

We hope you didn't purchase 1GB/sec GEMAC only to use it in polled mode, but in case you did, the driver supports this mode. See **XGemac\_SetOptions**(), **XGemac\_PollSend**(), and **XGemac\_PollRecv**().

Buffer data is copied to and from the FIFOs under processor control. The calling function is blocked during this copy.

#### **Interrupt Driven FIFO Mode Operation**

Buffer data is copied to and from the FIFOs under processor control. Interrupts occur when a new frame has arrived or a frame queued to transmit has been sent. The user must register callback functions with the driver to service frame reception and transmission. See XGemac\_FifoSend(), XGemac\_FifoRecv(), XGemac\_SetFifoRecvHandler(), XGemac\_SetFifoSendHandler().

#### **Interrupt Driven DMA Mode Operation**

#### **Interrupt Driven Scatter Gather DMA Mode Operation**

This is the fastest mode of operation. Buffer data is copied to and from the FIFOs under DMA control. Multiple frames either partial or whole can be transferred with no processor intervention using the scatter gather buffer descriptor list. The user must register callback functions with the driver to service frame reception and transmission. See **XGemac\_SgSend()**, **XGemac\_SgRecv()**, **XGemac\_SetSgRecvHandler()**, **XGemac\_SetSgSendHandler()**.

The frequency of interrupts can be controlled with the interrupt coalescing features of the scatter-gather DMA engine. Instead of interrupting after each packet has been processed, the scatter-gather DMA engine will interrupt when the packet count threshold is reached OR when the packet waitbound timer has expired. A packet is a generic term used by the scatter-gather DMA engine, and is equivalent to an Ethernet frame in this implementation. See **XGemac\_SetPktThreshold()**, and **XGemac\_SetPktWaitBound()**.

The user must setup a block of memory for transmit and receive buffer descriptor storage. Prior to using scatter gather. See **XGemac\_SetSgRecvSpace()** and **XGemac\_SetSgSendSpace()**.

#### **PLB Alignment Considerations**

This device has considerable alignment restrictions the user must follow. When used in polled or interrupt driven FIFO mode, buffers must be aligned on a 4 byte boundary. When used with simple or scatter-gather DMA, buffers must be aligned on 8 byte boundaries. Scatter gather buffer descriptors must be aligned on 8 byte boundaries. Failure to follow these alignment restrictions will result in asserts from the driver or bad/corrupted data being transferred.

#### **Cache Considerations**

Do not cache buffers or scatter-gather buffer descriptor space when using DMA mode. Doing so will cause cache coherency problems resulting in bad/corrupted data being transferred.

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. Configuration parameters are stored in the **xgemac\_g.c** files. A table is defined where each entry contains configuration information for a GEMAC device. This information includes such things as the base address of the memory-mapped device, and whether the device has DMA, counter registers, or GMII support.

The driver tries to use the features built into the device. So if, for example, the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels. If circumstances exist when the hardware must be used in a mode that differs from its default configuration, the user may modify the device config table prior to invoking **XGemac\_Initialize**():

```
XGemac_Config *ConfigPtr;
ConfigPtr = XGemac_LookupConfig(DeviceId);
ConfigPtr->IpIfDmaConfig = XGE_CFG_NO_DMA;
```

The user should understand that changing the config table is not without risk. For example, if the hardware is not configured without DMA and the config table is changed to include it, then system errors will occur when the driver is initialized.

#### **Asserts**

Asserts are used within all Xilinx drivers to enforce constraints on argument values. Asserts can be turned off on a system-wide basis by defining, at compile time, the NDEBUG identifier. By default, asserts are turned on and it is recommended that application developers leave asserts on during development. Substantial performance improvements can be seen when asserts are disabled.

#### **Building the driver**

The **XGemac** driver is composed of several source files. Why so many? This allows the user to build and link only those parts of the driver that are necessary. Since the GEMAC hardware can be configured in various ways (e.g., with or without DMA), the driver too can be built with varying features. For the most part, this means that besides always linking in **xgemac.c**, you link in only the driver functionality you want. Some of the choices you have are polled vs. interrupt, interrupt with FIFOs only vs. interrupt with DMA, self-test diagnostics, and driver statistics. Note that currently the DMA code must be linked in, even if you don't have DMA in the device.

#### Note:

Xilinx drivers are typically composed of two components, one is the driver and the other is the adapter. The driver is independent of OS and processor and is intended to be highly portable. The adapter is OS-specific and facilitates communication between the driver and the OS.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 01/13/03 First release

1.00b ecm 03/25/03 Revision update

1.00c rmm 05/28/03 Dma added, interframe gap interface change, added autonegotiate option, removed phy function prototypes, added constant to default to no hw counters

1.00d rmm 06/11/03 Added Jumbo frame capabilities, removed no hw counters constant
```

```
#include "xbasic_types.h"
#include "xstatus.h"
#include "xparameters.h"
#include "xpacket_fifo_v2_00_a.h"
#include "xdma_channel.h"
```

### **Data Structures**

```
struct XGemac_Config
struct XGemac_HardStats
struct XGemac_SoftStats
```

# **Configuration options**

```
See XGemac_SetOptions())
```

```
#define XGE_UNICAST_OPTION

#define XGE_BROADCAST_OPTION

#define XGE_PROMISC_OPTION

#define XGE_FDUPLEX_OPTION

#define XGE_POLLED_OPTION

#define XGE_LOOPBACK_OPTION

#define XGE_INSERT_PAD_OPTION

#define XGE_INSERT_FCS_OPTION

#define XGE_STRIP_PAD_FCS_OPTION

#define XGE_AUTO_NEGOTIATE_OPTION

#define XGE_VLAN_OPTION

#define XGE_JUMBO_OPTION
```

# Configuration options not yet supported

These options to be supported in later versions of HW and this driver.

```
#define XGE_MULTICAST_OPTION
#define XGE_INSERT_ADDR_OPTION
#define XGE_OVWRT_ADDR_OPTION
```

### **Macro functions**

```
#define XGemac_mIsSgDma(InstancePtr)
#define XGemac_mIsSimpleDma(InstancePtr)
#define XGemac_mIsDma(InstancePtr)
```

# **Callbacks**

```
typedef void(* XGemac_SgHandler )(void *CallBackRef, XBufDescriptor *BdPtr, Xuint32 NumBds) typedef void(* XGemac_FifoHandler )(void *CallBackRef) typedef void(* XGemac_ErrorHandler )(void *CallBackRef, XStatus ErrorCode)
```

### **Functions**

```
XStatus XGemac_Initialize (XGemac *InstancePtr, Xuint16 DeviceId)
XStatus XGemac_Start (XGemac *InstancePtr)
XStatus XGemac_Stop (XGemac *InstancePtr)
```

```
void XGemac Reset (XGemac *InstancePtr)
XGemac_Config * XGemac_LookupConfig (Xuint16 DeviceId)
         XStatus XGemac_SetMacAddress (XGemac *InstancePtr, Xuint8 *AddressPtr)
             void XGemac_GetMacAddress (XGemac *InstancePtr, Xuint8 *BufferPtr)
         XStatus XGemac_SelfTest (XGemac *InstancePtr)
         XStatus XGemac_PollSend (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
         XStatus XGemac PollRecv (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
         XStatus XGemac_SgSend (XGemac *InstancePtr, XBufDescriptor *BdPtr, int Delay)
         XStatus XGemac SgRecv (XGemac *InstancePtr, XBufDescriptor *BdPtr)
         XStatus XGemac SetPktThreshold (XGemac *InstancePtr, Xuint32 Direction, Xuint8 Threshold)
         XStatus XGemac_GetPktThreshold (XGemac *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)
         XStatus XGemac_SetPktWaitBound (XGemac *InstancePtr, Xuint32 Direction, Xuint32 TimerValue)
         XStatus XGemac_GetPktWaitBound (XGemac *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)
         XStatus XGemac SetSgRecvSpace (XGemac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
         XStatus XGemac_SetSgSendSpace (XGemac *InstancePtr, Xuint32 *MemoryPtr, Xuint32 ByteCount)
             void XGemac SetSgRecvHandler (XGemac *InstancePtr, void *CallBackRef, XGemac SgHandler
                 FuncPtr)
             void XGemac SetSgSendHandler (XGemac *InstancePtr, void *CallBackRef, XGemac SgHandler
                 FuncPtr)
             void XGemac IntrHandlerDma (void *InstancePtr)
         XStatus XGemac_FifoSend (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
         XStatus XGemac_FifoRecv (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
             void XGemac_SetFifoRecvHandler (XGemac *InstancePtr, void *CallBackRef, XGemac_FifoHandler
                 FuncPtr)
             void XGemac_SetFifoSendHandler (XGemac *InstancePtr, void *CallBackRef, XGemac_FifoHandler
                 FuncPtr)
             void XGemac IntrHandlerFifo (void *InstancePtr)
             void XGemac_SetErrorHandler (XGemac *InstancePtr, void *CallBackRef, XGemac_ErrorHandler
         XStatus XGemac_SetOptions (XGemac *InstancePtr, Xuint32 OptionFlag)
         Xuint32 XGemac_GetOptions (XGemac *InstancePtr)
         XStatus XGemac MulticastAdd (XGemac *InstancePtr, Xuint8 Location, Xuint8 *AddressPtr)
         XStatus XGemac_MulticastClear (XGemac *InstancePtr, Xuint8 Location)
             void XGemac GetSoftStats (XGemac *InstancePtr, XGemac SoftStats *StatsPtr)
             void XGemac_ClearSoftStats (XGemac *InstancePtr)
         XStatus XGemac_GetHardStats (XGemac *InstancePtr, XGemac_HardStats *StatsPtr)
         XStatus XGemac_SetInterframeGap (XGemac *InstancePtr, Xuint8 Ifg)
             void XGemac GetInterframeGap (XGemac *InstancePtr, Xuint8 *IfgPtr)
         XStatus XGemac_SendPause (XGemac *InstancePtr, Xuint16 PausePeriod)
         XStatus XGemac_MgtRead (XGemac *InstancePtr, int PhyAddress, int Register, Xuint16 *DataPtr)
         XStatus XGemac MgtWrite (XGemac *InstancePtr, int PhyAddress, int Register, Xuint16 Data)
```

### **Define Documentation**

#### #define XGE\_AUTO\_NEGOTIATE\_OPTION

Turn on PHY auto-negotiation (default is on)

#### #define XGE\_FDUPLEX\_OPTION

Full duplex on or off (default is off)

#### #define XGE\_FLOW\_CONTROL\_OPTION

Interpret pause frames in full duplex mode (default is off)

#### #define XGE\_INSERT\_ADDR\_OPTION

Insert source address on transmit (default is on)

#### #define XGE\_INSERT\_FCS\_OPTION

Insert FCS (CRC) on transmit (default is on)

#### #define XGE\_INSERT\_PAD\_OPTION

Pad short frames on transmit (default is on)

#### #define XGE\_JUMBO\_OPTION

Allow reception and transmission of Jumbo frames (default is off)

#### #define XGE\_LOOPBACK\_OPTION

Internal loopback on or off (default is off)

#### #define XGE\_MULTICAST\_OPTION

Multicast addressing on or off (default is off)

#### #define XGE\_OVWRT\_ADDR\_OPTION

Overwrite source address on transmit. This is only used if source address insertion is on. (default is on)

#### #define XGE\_POLLED\_OPTION

Polled mode on or off (default is off)

#### #define XGE\_PROMISC\_OPTION

Promiscuous addressing on or off (default is off)

#### #define XGE\_STRIP\_PAD\_FCS\_OPTION

Strip padding and FCS from received frames (default is off)

#### #define XGE\_UNICAST\_OPTION

Unicast addressing on or off (default is on)

#### #define XGE\_VLAN\_OPTION

#### #define XGemac\_mIsDma( InstancePtr )

This macro determines if the device is currently configured with DMA (either simple DMA or scatter-gather DMA)

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured with DMA, or XFALSE otherwise

#### Note:

Signature: Xboolean **XGemac\_mIsDma**(XGemac \*InstancePtr)

#### #define XGemac\_mIsSgDma( InstancePtr )

This macro determines if the device is currently configured for scatter-gather DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured for scatter-gather DMA, or XFALSE if it is not.

#### Note:

Signature: Xboolean **XGemac** mIsSgDma(XGemac \*InstancePtr)

#### #define XGemac\_mIsSimpleDma( InstancePtr )

This macro determines if the device is currently configured for simple DMA.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

Boolean XTRUE if the device is configured for simple DMA, or XFALSE otherwise

#### **Note:**

Signature: Xboolean **XGemac\_mIsSimpleDma**(XGemac \*InstancePtr)

# **Typedef Documentation**

typedef void(\* XGemac\_ErrorHandler)(void \*CallBackRef, XStatus ErrorCode)

Callback when an asynchronous error occurs.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions (see

XGemac\_SetFifoRecvHandler(), XGemac\_SetFifoSendHandler(), XGemac\_SetSgRecvHandler(), and XGemac\_SetSgSendHandler().

*ErrorCode* is the Xilinx error code that was detected. (see **xstatus.h**).

#### typedef void(\* XGemac\_FifoHandler)(void \*CallBackRef)

Callback when data is sent or received with direct FIFO communication.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions (see XGemac\_SetFifoRecvHandler() and XGemac\_SetFifoSendHandler()).

#### typedef void(\* XGemac\_SgHandler)(void \*CallBackRef, XBufDescriptor \*BdPtr, Xuint32 NumBds)

Callback when an Ethernet frame is sent or received with scatter-gather DMA.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions (see XGemac\_SetSgRecvHandler() and XGemac\_SetSgSendHandler()).

*BdPtr* is a pointer to the first buffer descriptor in a list of buffer descriptors that describe a single frame.

*NumBds* is the number of buffer descriptors in the list pointed to by BdPtr.

### **Function Documentation**

#### void XGemac\_ClearSoftStats( XGemac \* InstancePtr)

Clear the **XGemac SoftStats** structure for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

None.

#### Note:

Receive an Ethernet frame into the given buffer if a frame has been received by the hardware. This function is typically called by the user in response to an interrupt invoking the receive callback function as set by **XGemac\_SetFifoRecvHandler()**.

The supplied buffer should be properly aligned (see **xgemac.h**) and large enough to contain the biggest frame for the current operating mode of the GEMAC device (approx 1518 bytes for normal frames and 9000 bytes for jumbo frames).

If the device is configured with DMA, simple DMA will be used to transfer the buffer from the GEMAC to memory. In this case, the receive buffer must not be cached (see **xgemac.h**).

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a memory buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains the size of the buffer on entry into the function and the size the received frame on return from the function.

#### Returns:

- o XST\_SUCCESS if the frame was sent successfully
- o XST DEVICE IS STOPPED if the device has not yet been started
- o XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST\_NO\_DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.
- o XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

The input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame using packet FIFO with interrupts. The caller provides a contiguous-memory buffer and its length. The buffer must be properly aligned (see **xgemac.h**).

The callback function set by using **XGemac SetFifoSendHandler()** is invoked when the transmission is complete.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field.

If the device is configured with simple DMA, simple DMA will be used to transfer the buffer from memory to the GEMAC. This means that this buffer should not be cached.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

#### **Returns:**

- XST\_SUCCESS if the frame was successfully sent. An interrupt is generated when the GEMAC transmits
  the frame and the driver calls the callback set with XGemac\_SetFifoSendHandler()
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST FIFO NO ROOM if there is no room in the FIFO for this frame
- XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

Get a snapshot of the current hardware statistics counters.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

#### Returns:

XST\_SUCCESS if counters were read and copied to user space XST\_NO\_FEATURE if counters are not part of the gemac hw

#### Note:

None.

Get the interframe gap. See the description of interframe gap above in XGemac SetInterframeGap().

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*IfgPtr* is a pointer to an 8-bit buffer into which the interframe gap value will be copied. The LSB value is 8 bit times.

#### **Returns:**

None. The values of the interframe gap parts are copied into the output parameters.

```
void XGemac_GetMacAddress( XGemac * InstancePtr,
Xuint8 * BufferPtr
)
```

Get the MAC address for this driver/device.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufferPtr is an output parameter, and is a pointer to a buffer into which the current MAC address will be copied. The buffer must be at least 6 bytes.

### **Returns:**

None.

### **Note:**

None.

### Xuint32 XGemac\_GetOptions( XGemac \* InstancePtr)

Get Ethernet driver/device options. The 32-bit value returned is a bit-mask representing the options (XGE\_\*\_OPTION). A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

The 32-bit value of the Ethernet options. The value is a bit-mask representing all options that are currently enabled. See **xgemac.h** for a description of the available options.

### Note:

None.

Get the value of the packet count threshold for the scatter-gather DMA engine. See **xgemac.h** for more discussion of interrupt coalescing features.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE SEND or XGE RECV, to get.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be copied.

### **Returns:**

- o XST\_SUCCESS if the packet threshold was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

### Note:

None

Get the packet wait bound timer for this driver/device. See **xgemac.h** for more discussion of interrupt coalescing features.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE\_SEND or XGE\_RECV, to read.

WaitPtr is a pointer to the byte into which the current value of the packet wait bound register will be copied.

Units are in milliseconds. Range is 0 - 1023. A value of 0 disables the timer.

### Returns:

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

### Note:

None.

Get a copy of the **XGemac\_SoftStats** structure, which contains the current statistics for this driver as maintained by software counters. The statistics are cleared at initialization or on demand using the **XGemac\_ClearSoftStats**() function.

The DmaErrors and FifoErrors counts indicate that the device has been or needs to be reset. Reset of the device is the responsibility of the upper layer software.

Use XGemac\_GetHardStats() to retrieve hardware maintained statistics (if so configured).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

### **Returns:**

None.

### Note:

None.

Initialize a specific **XGemac** instance/driver. The initialization entails:

- Clearing memory occupied by the **XGemac** structure
- Initialize fields of the XGemac structure
- Clear the Ethernet statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- If the device is configured with DMA, configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists are to be passed to the driver.
- Reset the Ethernet MAC

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*DeviceId* is the unique id of the device controlled by this **XGemac** instance. Passing in a device id associates the generic **XGemac** instance to a specific device, as chosen by the caller or application developer.

### **Returns:**

- o XST\_SUCCESS if initialization was successful
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

| ٠, |   |   |    |   |    |
|----|---|---|----|---|----|
|    | N | • | ٠, | 1 | ٠. |
|    |   |   |    |   |    |

None.

### void XGemac\_IntrHandlerDma( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured with scatter- gather DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, Send Packet FIFO, Recv DMA channel, or Send DMA channel. The packet FIFOs only interrupt during "deadlock" conditions.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance that just interrupted.

### **Returns:**

None.

### Note:

None.

### void XGemac\_IntrHandlerFifo( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured for direct FIFO communication (as opposed to DMA).

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, or Send Packet FIFO. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the MAC.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance that just interrupted.

### **Returns:**

None.

### Note:

None.

### 

Lookup the device configuration based on the unique device ID. The table EmacConfigTable contains the configuration info for each device in the system.

### **Parameters:**

DeviceId is the unique device ID of the device being looked up.

### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

### Note:

None.

```
XStatus XGemac_MgtRead( XGemac * InstancePtr,
int PhyAddress,
int Register,
Xuint16 * DataPtr
)
```

Read a PHY register through the GMII Management Control mechanism.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

PhyAddress is the address of the PHY to be accessed. Valid range is 0 to 31.
Register is the register in the PHY to be accessed. Valid range is 0 to 31.
DataPtr is an output parameter that will contain the contents of the register.

### **Returns:**

- XST\_SUCCESS if the PHY register was successfully read and its contents were placed in DataPtr.
- o XST\_NO\_FEATURE if GMII is not present with this GEMAC instance.
- o XST\_DEVICE\_BUSY if another GMII read/write operation is already in progresss.
- XST\_FAILURE if an GMII read error is detected

### Note:

This function blocks until the read operation has completed. If there is a HW problem then this function may not return.

Write to a PHY register through the GMII Management Control mechanism.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

PhyAddress is the address of the PHY to be accessed.Register is the register in the PHY to be accessed.Data is the what will be written to the register.

### **Returns:**

- o XST\_SUCCESS if the PHY register was successfully read and its contents are placed in DataPtr.
- o XST\_DEVICE\_BUSY if another GMII read/write operation is already in progresss.
- o XST NO FEATURE if GMII is not present with this GEMAC instance.

#### Note:

This function blocks until the write operation has completed. If there is a HW problem then this function may not return.

Set a discrete multicast address entry in the CAM lookup table. There are up to XGE\_CAM\_MAX\_ADDRESSES in this table. The GEMAC must be stopped (see **XGemac\_Stop**()) before multicast addresses can be modified.

Once set, the multicast address cannot be retrieved. It can be disabled by clearing it using **XGemac\_MulticastClear()**.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Location indicates which of the entries is to be updated. Valid range is 0 to XGE\_CAM\_MAX\_ADDRESSES-1.

AddressPtr is the multicast address to set.

### **Returns:**

- o XST SUCCESS if the multicast address table was updated successfully
- o XST\_NO\_FEATURE if this feature is not included in HW
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- XST\_INVALID\_PARAM if the Location parameter is greater than XGE\_CAM\_MAX\_ADDRESSES

### **Note:**

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Clear a discrete multicast address entry in the CAM lookup table. There are up to XGE\_CAM\_MAX\_ADDRESSES in this table. The GEMAC must be stopped (see **XGemac\_Stop**()) before multicast addresses can be cleared.

The entry is cleared by writing an address of 00:00:00:00:00:00 to its location.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Location indicates which of the entries is to be cleared. Valid range is 0 to XGE\_CAM\_MAX\_ADDRESSES-1.

### **Returns:**

- XST\_SUCCESS if the multicast address table was updated successfully
- o XST\_NO\_FEATURE if this feature is not included in HW
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- o XST\_INVALID\_PARAM if the Location parameter is greater than XGE\_CAM\_MAX\_ADDRESSES

### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Receive an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the frame directly from the MAC's packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The MAC's error status is not checked, so statistics are not updated for polled receive. The buffer into which the frame will be received must be properly aligned (see **xgemac.h**).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to an aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains the size of the buffer on entry into the function and the size the received frame on return from the function.

### **Returns:**

- o XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST\_NO\_DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.

### Note:

Input buffer must be big enough to hold the largest Ethernet frame. Buffer must also be 32-bit aligned.

Send an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the frame directly to the MAC's packet FIFO, then enters a loop checking the device status for completion or error. Statistics are updated if an error occurs. The buffer to be sent must be properly aligned (see **xgemac.h**).

It is assumed that the upper layer software supplies a correctly formatted and aligned Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the Ethernet frame to be sent.

ByteCount is the size of the Ethernet frame.

### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST FIFO NO ROOM if there is no room in the GEMAC's length FIFO for this frame
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.
- o XST\_EMAC\_COLLISION if the send failed due to excess deferral or late collision

### **Note:**

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread. On a 1 Gbit (1000Mbps) MAC, it takes about 12.1 usecs to transmit a maximum size Ethernet frame.

### void XGemac\_Reset( XGemac \* InstancePtr)

Reset the Ethernet MAC. This is a graceful reset in that the device is stopped first. Resets the DMA channels, the FIFOs, the transmitter, and the receiver. All options are placed in their default state. Any frames in the scatter- gather descriptor lists will remain in the lists. The side effect of doing this is that after a reset and following a restart of the device, frames that were in the list before the reset may be transmitted or received.

The upper layer software is responsible for re-configuring (if necessary) and restarting the MAC after the reset. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

None.

### Note:

None.

### XStatus XGemac\_SelfTest( XGemac \* InstancePtr)

Performs a self-test on the Ethernet device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the Ethernet device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

| XST_SUCCESS                   | Self-test was successful                     |
|-------------------------------|----------------------------------------------|
| XST_PFIFO_BAD_REG_VALUE       | FIFO failed register self-test               |
| XST_DMA_TRANSFER_ERROR        | DMA failed data transfer self-test           |
| XST_DMA_RESET_REGISTER_ERROR  | DMA control register value was incorrect     |
|                               | after a reset                                |
| XST_REGISTER_ERROR            | Ethernet failed register reset test          |
| XST_LOOPBACK_ERROR            | Internal loopback failed                     |
| XST_IPIF_REG_WIDTH_ERROR      | An invalid register width was passed into    |
|                               | the function                                 |
| XST_IPIF_RESET_REGISTER_ERROR | The value of a register at reset was invalid |
| XST_IPIF_DEVICE_STATUS_ERROR  | A write to the device status register did    |
|                               | not read back correctly                      |
| XST_IPIF_DEVICE_ACK_ERROR     | A bit in the device status register did not  |
|                               | reset when acked                             |
| XST_IPIF_DEVICE_ENABLE_ERROR  | The device interrupt enable register was not |
|                               | updated correctly by the hardware when other |
|                               | registers were written to                    |
| XST_IPIF_IP_STATUS_ERROR      | A write to the IP interrupt status           |
|                               | register did not read back correctly         |
| XST_IPIF_IP_ACK_ERROR         | One or more bits in the IP status            |
|                               | register did not reset when acked            |
| XST_IPIF_IP_ENABLE_ERROR      | The IP interrupt enable register             |
|                               | was not updated correctly when other         |
|                               | registers were written to                    |
|                               |                                              |

### **Note:**

This function makes use of options-related functions, and the **XGemac\_PollSend()** and **XGemac\_PollRecv()** functions.

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

Send a pause packet. When called, the GEMAC hardware will initiate transmission of an automatically formed pause packet. This action will not disrupt any frame transmission in progress but will take priority over any pending frame transmission. The pause frame will be sent even if the transmitter is in the paused state.

For this function to have any effect, the XGE\_FLOW\_CONTROL option must be set (see XGemac\_SetOptions)).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

PausePeriod is the amount of time to pause. The LSB is 512 bit times.

### **Returns:**

- o XST\_SUCCESS if the pause frame transmission mechanism was successfully started.
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped

Set the callback function for handling asynchronous errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable MAC error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_DMA\_SG\_NO\_LIST indicates an attempt was made to access a scatter-gather DMA list that has not yet been created.
- XST\_DMA\_SG\_LIST\_EMPTY indicates the driver tried to get a descriptor from the receive descriptor list, but the list was empty.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the

FuncPtr is the pointer to the callback function.

**Returns:** 

None.

Note:

None.

```
void XGemac_SetFifoRecvHandler( XGemac * InstancePtr,
void * CallBackRef,
XGemac_FifoHandler FuncPtr
)
```

Set the callback function for handling confirmation of transmitted frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called by the driver once per frame sent. The callback is responsible for freeing the transmitted buffer if necessary.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the

FuncPtr is the pointer to the callback function.

**Returns:** 

None.

**Note:** 

None.

```
void XGemac_SetFifoSendHandler( XGemac * InstancePtr,
void * CallBackRef,
XGemac_FifoHandler FuncPtr
)
```

Set the callback function for handling received frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called once per frame received. During the callback, the upper layer software should call **XGemac\_FifoRecv**() to retrieve the received frame.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the driver.

FuncPtr is the pointer to the callback function.

### **Returns:**

None.

### Note:

None.

Set the Interframe Gap (IFG), which is the time the MAC delays between transmitting frames.

The device must be stopped before setting the interframe gap.

### **Parameters:**

InstancePtr is a pointer to the **XGemac** instance to be worked on.

Ifg is the interframe gap to set, the LSB is 8 bit times.

### **Returns:**

- o XST\_SUCCESS if the interframe gap was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped

### Note:

None.

Set the MAC address for this driver/device. The address is a 48-bit value. The device must be stopped before calling this function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte MAC address.

### **Returns:**

- o XST SUCCESS if the MAC address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

### Note:

None.

Set Ethernet driver/device options. The options (XGE\_\*\_OPTION) constants can be OR'd together to set/clear multiple options. A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

The device must be stopped before calling this function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*OptionsFlag* is a bit-mask representing the Ethernet options to turn on or off. See **xgemac.h** for a description of the available options.

### **Returns:**

- o XST\_SUCCESS if the options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Set the scatter-gather DMA packet count threshold for this device. See **xgemac.h** for more discussion of interrupt coalescing features.

The device must be stopped before setting the threshold.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE SEND or XGE RECV, to set.

Threshold is the value of the packet threshold count used during interrupt coalescing. Valid range is 0 - 255. A value of 0 disables the use of packet threshold by the hardware.

### **Returns:**

- o XST\_SUCCESS if the threshold was successfully set
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_DMA\_SG\_COUNT\_EXCEEDED if the threshold must be equal to or less than the number of descriptors in the list
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

### Note:

None

Set the scatter-gather DMA packet wait bound timer for this device. See **xgemac.h** for more discussion of interrupt coalescing features.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE\_SEND or XGE\_RECV, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound timer to set. Units are in milliseconds. A value of 0 means the timer is disabled.

### **Returns:**

- o XST\_SUCCESS if the packet wait bound was set successfully
- o XST NOT SGDMA if the MAC is not configured for scatter-gather DMA
- o XST DEVICE IS STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this
  error.

### Note:

None.

Set the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame received. The head of a descriptor list is passed in along with the number of descriptors in the list. Before leaving the callback, the upper layer software should attach a new buffer to each descriptor in the list.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the

FuncPtr is the pointer to the callback function.

### **Returns:**

None.

### Note:

None.

Give the driver memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xgemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be properly aligned (see **xgemac.h**).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*MemoryPtr* is a pointer to the beginning of the memory space.

ByteCount is the length, in bytes, of the memory space.

### **Returns:**

- o XST SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XGemac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Set the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame sent. The head of a descriptor list is passed in along with the number of descriptors in the list. The callback is responsible for freeing buffers attached to these descriptors.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the

FuncPtr is the pointer to the callback function.

### **Returns:**

None.

#### Note:

None.

Give the driver memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xgemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be properly aligned (see **xgemac.h**).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*MemoryPtr* is a pointer to the beginning of the memory space.

ByteCount is the length, in bytes, of the memory space.

### **Returns:**

- o XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XGemac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Add a descriptor, with an attached empty buffer, into the receive descriptor list. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. This function can be called when the device is started or stopped. Note that it does start the scatter-gather DMA engine. Although this is not necessary during initialization, it is not a problem during initialization because the MAC receiver is not yet started.

The buffer attached to the descriptor and the descriptor itself must be properly aligned (see **xgemac.h**).

Notification of received frames are done asynchronously through the receive callback function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

### Returns:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

Send an Ethernet frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire Ethernet frame may or may not be contained within one descriptor. This function simply inserts the descriptor into the scatter- gather engine's transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor and the descriptor itself must be properly aligned (see xgemac.h).

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

The buffer attached to the descriptor must be 64-bit aligned on the front end.

This call is non-blocking. Notification of error or successful transmission is done asynchronously through the send or error callback function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

Delay indicates whether to start the scatter-gather DMA channel immediately, or whether to wait. This allows

the user to queue up a list of more than one descriptor before starting the transmission of the packets. Use XEM\_SGDMA\_NODELAY or XEM\_SGDMA\_DELAY, defined in **xgemac.h**, as the value of this argument. If the user chooses to delay and build a list, the user must call this function with the

XEM\_SGDMA\_NODELAY option or call **XGemac\_Start**() to kick off the transissions.

### **Returns:**

o XST SUCCESS if the buffer was successfull sent

- o XST\_DEVICE\_IS\_STOPPED if the Ethernet MAC has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA
  channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread
  mutual exclusion problem on transmit.

### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

### XStatus XGemac\_Start( XGemac \* InstancePtr)

Start the Ethernet controller as follows:

- If in interrupt driven mode
  - o Set the internal interrupt enable registers appropriately
  - Enable interrupts within the device itself. Note that connection of the driver's interrupt handler to the interrupt source (typically done using the interrupt controller component) is done by the higher layer software.
  - o If the device is configured with DMA, start the DMA channels if the descriptor lists are not empty
- Enable the transmitter
- Enable the receiver

The PHY is enabled after driver initialization. We assume the upper layer software has configured it and the GEMAC appropriately before this function is called.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

- o XST SUCCESS if the device was started successfully
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function.
   This is required if in interrupt mode.
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- XST\_DMA\_SG\_LIST\_EMPTY if configured for scatter-gather DMA but no receive buffer descriptors have been initialized.

### Note:

The driver tries to match the hardware configuration. So if the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels and expects that the user has previously set up the buffer descriptor lists. If the user expects to use the driver in a mode different than how the hardware is configured, the user should modify the configuration table to reflect the mode to be used.

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

### XStatus XGemac\_Stop( XGemac \* InstancePtr)

Stop the Ethernet MAC as follows:

- If the device is configured with scatter-gather DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the Ethernet frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

Device options currently in effect are not changes.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of GEMAC devices in the system.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a ecm 01/13/03 First release

#include "xgemac.h"
#include "xparameters.h"
```

## **Variables**

**XGemac\_Config XGemac\_ConfigTable** [XPAR\_XGEMAC\_NUM\_INSTANCES]

## **Variable Documentation**

XGemac\_Config XGemac\_ConfigTable[XPAR\_XGEMAC\_NUM\_INSTANCES]

This table contains configuration information for each GEMAC device in the system.

## Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XGemac\_Config Struct Reference

#include <xgemac.h>

## **Detailed Description**

This typedef contains configuration information for a device.

## **Data Fields**

**Xuint16 DeviceId** 

**Xuint32 BaseAddress** 

**Xuint8 IpIfDmaConfig** 

**Xboolean HasGmii** 

**Xboolean HasCounters** 

## **Field Documentation**

Xuint32 XGemac\_Config::BaseAddress

Register base address

Xuint16 XGemac\_Config::DeviceId

Unique ID of device

**Xboolean XGemac\_Config::HasCounters** 

Does device have HW statistic counters

### Xboolean XGemac\_Config::HasGmii

Does device support GMII?

### Xuint8 XGemac\_Config::IpIfDmaConfig

IPIF/DMA hardware configuration

The documentation for this struct was generated from the following file:

• gemac/v1\_00\_d/src/xgemac.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac.c File Reference

## **Detailed Description**

The **XGemac** driver. Functions in this file are the minimum required functions for this driver. See **xgemac.h** for a detailed description of the driver.

### MODIFICATION HISTORY:

```
Ver Who Date Changes

---- --- --- ---- -----

1.00a ecm 01/13/03 First release

1.00b ecm 03/25/03 Revision update

1.00c rmm 05/28/03 DMA mods

1.00d rmm 09/12/03 Cleanup

#include "xbasic_types.h"

#include "xgemac_i.h"

#include "xio.h"

#include "xio.h"

#include "xio.h"

#include "xenv.h"
```

## **Functions**

```
XStatus XGemac_Initialize (XGemac *InstancePtr, Xuint16 DeviceId)
XStatus XGemac_Start (XGemac *InstancePtr)
XStatus XGemac_Stop (XGemac *InstancePtr)
void XGemac_Reset (XGemac *InstancePtr)
```

## **Function Documentation**

Get the MAC address for this driver/device.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufferPtr is an output parameter, and is a pointer to a buffer into which the current MAC address will be copied. The buffer must be at least 6 bytes.

### **Returns:**

None.

### Note:

None.

Initialize a specific **XGemac** instance/driver. The initialization entails:

- Clearing memory occupied by the **XGemac** structure
- Initialize fields of the XGemac structure
- Clear the Ethernet statistics for this device
- Initialize the IPIF component with its register base address
- Configure the FIFO components with their register base addresses.
- If the device is configured with DMA, configure the DMA channel components with their register base addresses. At some later time, memory pools for the scatter-gather descriptor lists are to be passed to the driver.
- Reset the Ethernet MAC

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XGemac** instance. Passing in a device id associates the generic **XGemac** instance to a specific device, as chosen by the caller or application developer.

### **Returns:**

- o XST\_SUCCESS if initialization was successful
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

### Note:

None.

### 

Lookup the device configuration based on the unique device ID. The table EmacConfigTable contains the configuration info for each device in the system.

### **Parameters:**

DeviceId is the unique device ID of the device being looked up.

### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

### Note:

None.

void XGemac\_Reset( XGemac \* InstancePtr)

Reset the Ethernet MAC. This is a graceful reset in that the device is stopped first. Resets the DMA channels, the FIFOs, the transmitter, and the receiver. All options are placed in their default state. Any frames in the scatter- gather descriptor lists will remain in the lists. The side effect of doing this is that after a reset and following a restart of the device, frames that were in the list before the reset may be transmitted or received.

The upper layer software is responsible for re-configuring (if necessary) and restarting the MAC after the reset. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

When a reset is required due to an internal error, the driver notifies the upper layer software of this need through the ErrorHandler callback and specific status codes. The upper layer software is responsible for calling this Reset function and then re-configuring the device.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

None.

### Note:

None.

Set the MAC address for this driver/device. The address is a 48-bit value. The device must be stopped before calling this function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on. *AddressPtr* is a pointer to a 6-byte MAC address.

### **Returns:**

- XST\_SUCCESS if the MAC address was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

### Note:

None.

### XStatus XGemac\_Start( XGemac \* InstancePtr)

Start the Ethernet controller as follows:

- If in interrupt driven mode
  - Set the internal interrupt enable registers appropriately
  - Enable interrupts within the device itself. Note that connection of the driver's interrupt handler to the interrupt source (typically done using the interrupt controller component) is done by the higher layer software.
  - o If the device is configured with DMA, start the DMA channels if the descriptor lists are not empty
- Enable the transmitter
- Enable the receiver

The PHY is enabled after driver initialization. We assume the upper layer software has configured it and the GEMAC appropriately before this function is called.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

- o XST\_SUCCESS if the device was started successfully
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function. This is required if in interrupt mode.
- XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- XST\_DMA\_SG\_LIST\_EMPTY if configured for scatter-gather DMA but no receive buffer descriptors have been initialized.

### Note:

The driver tries to match the hardware configuration. So if the hardware is configured with scatter-gather DMA, the driver expects to start the scatter-gather channels and expects that the user has previously set up the buffer descriptor lists. If the user expects to use the driver in a mode different than how the hardware is configured, the user should modify the configuration table to reflect the mode to be used.

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

### XStatus XGemac\_Stop( XGemac \* InstancePtr)

Stop the Ethernet MAC as follows:

- If the device is configured with scatter-gather DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the Ethernet frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

Device options currently in effect are not changes.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

- XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## **XGemac Struct Reference**

#include <xgemac.h>

## **Detailed Description**

The XGemac driver instance data. The user is required to allocate a variable of this type for every GEMAC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• gemac/v1\_00\_d/src/xgemac.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac\_i.h File Reference

## **Detailed Description**

This header file contains internal identifiers, which are those shared between **XGemac** components. The identifiers in this file are not intended for use external to the driver.

### MODIFICATION HISTORY:

```
Ver Who Date Changes

-----

1.00a ecm 01/13/03 First release

1.00b ecm 03/25/03 Revision update

1.00c rmm 05/28/03 Revision update

1.00d rmm xx/xx/xx Removed use of XGE_EIR_RECV_DFIFO_OVER_MASK, XGE_EIR
_RECV_MISSED_FRAME_MASK, XGE_EIR_RECV_COLLISION_MASK,
XGE_EIR_RECV_SHORT_ERROR_MASK, XGE_EIR_XMIT_ERROR_MASK.
Redefined default interrupt masks.
```

```
#include "xgemac.h"
#include "xgemac_l.h"
```

## **Variables**

XGemac\_Config XGemac\_ConfigTable []

## **Variable Documentation**

```
XGemac_Config XGemac_ConfigTable[]( )
```

This table contains configuration information for each GEMAC device in the system.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## gemac/v1\_00\_d/src/xgemac\_I.h File Reference

## **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xgemac.h**.

### MODIFICATION HISTORY:

| Who | Date              | Changes                                                    |
|-----|-------------------|------------------------------------------------------------|
|     |                   |                                                            |
| ecm | 01/13/03          | First release                                              |
| ecm | 03/25/03          | Revision update                                            |
| rmm | 05/28/03          | Removed tabs characters in file, added auto negotiate      |
|     |                   | bit to ECR constants.                                      |
| rmm | 09/15/03          | Moved XGE_MAX_IFG definition here from xgemac_options.c    |
|     |                   | and changed its value to 255. Added XMIT jumbo frame       |
|     |                   | bitmask to ECR register bitmasks. Removed unused and added |
|     |                   | new XGE_EIR bitmasks. Removed XGE_TEDC_OFFSET and XGE_     |
|     |                   | SLEC_OFFSET register definitions. Added XGE_RSR_OFFSET     |
|     |                   | register definition.                                       |
|     | ecm<br>ecm<br>rmm | ecm 01/13/03<br>ecm 03/25/03<br>rmm 05/28/03               |

```
#include "xbasic_types.h"
#include "xio.h"
```

## **GEMAC Core Register Offsets**

Each register is 32 bits wide

```
#define XGE_EMIR_OFFSET

#define XGE_ECR_OFFSET

#define XGE_IFGP_OFFSET

#define XGE_SAH_OFFSET

#define XGE_SAL_OFFSET

#define XGE_MGTCR_OFFSET

#define XGE_MGTDR_OFFSET

#define XGE_RPLR_OFFSET
```

```
#define XGE_TPLR_OFFSET
#define XGE_TSR_OFFSET
#define XGE_TPPR_OFFSET
#define XGE_CEAH_OFFSET
#define XGE_CEAL_OFFSET
#define XGE_RSR_OFFSET
```

## **GEMAC IPIF Register Offsets**

Each register is 32 bits wide

```
#define XGE_ISR_OFFSET

#define XGE_DMA_OFFSET

#define XGE_DMA_SEND_OFFSET

#define XGE_DMA_RECV_OFFSET

#define XGE_PFIFO_OFFSET

#define XGE_PFIFO_TXREG_OFFSET

#define XGE_PFIFO_RXREG_OFFSET

#define XGE_PFIFO_TXDATA_OFFSET

#define XGE_PFIFO_RXDATA_OFFSET
```

## **GEMAC Counter Register Offsets**

Each register is 64 bits wide

```
#define XGE_STAT_REG_OFFSET
#define XGE_STAT_RXOK_OFFSET
#define XGE_STAT_FCSERR_OFFSET
#define XGE_STAT_BFRXOK_OFFSET
#define XGE STAT MCRXOK OFFSET
#define XGE STAT 64RXOK OFFSET
#define XGE STAT_127RXOK_OFFSET
#define XGE_STAT_255RXOK_OFFSET
#define XGE_STAT_511RXOK_OFFSET
#define XGE_STAT_1023RXOK_OFFSET
#define XGE_STAT_MAXRXOK_OFFSET
#define XGE STAT CFRXOK OFFSET
#define XGE STAT LTERROR OFFSET
#define XGE_STAT_VLANRXOK_OFFSET
#define XGE_STAT_PFRXOK_OFFSET
#define XGE_STAT_CFUNSUP_OFFSET
#define XGE_STAT_OFRXOK_OFFSET
#define XGE STAT UFRX OFFSET
#define XGE STAT FRAGRX OFFSET
```

```
#define XGE STAT RXBYTES OFFSET
#define XGE_STAT_TXBYTES_OFFSET
#define XGE STAT TXOK OFFSET
#define XGE STAT BFTXOK OFFSET
#define XGE_STAT_MFTXOK_OFFSET
#define XGE_STAT_TXURUNERR_OFFSET
#define XGE_STAT_CFTXOK_OFFSET
#define XGE_STAT_64TXOK_OFFSET
#define XGE_STAT_127TXOK_OFFSET
#define XGE STAT 255TXOK OFFSET
#define XGE_STAT_511TXOK_OFFSET
#define XGE STAT 1023TXOK OFFSET
#define XGE_STAT_MAXTXOK_OFFSET
#define XGE_STAT_VLANTXOK_OFFSET
#define XGE STAT PFTXOK OFFSET
#define XGE STAT OFTXOK OFFSET
#define XGE STAT SCOLL OFFSET
#define XGE_STAT_MCOLL_OFFSET
#define XGE STAT DEFERRED OFFSET
#define XGE_STAT_LATECOLL_OFFSET
#define XGE_STAT_TXABORTED_OFFSET
#define XGE_STAT_CARRIERERR_OFFSET
#define XGE STAT EXCESSDEF OFFSET
```

## **Macro functions**

```
#define XGemac_mReadReg(BaseAddress, RegOffset)

#define XGemac_mWriteReg(BaseAddress, RegOffset, Data)

#define XGemac_mSetControlReg(BaseAddress, Mask)

#define XGemac_mSetMacAddress(BaseAddress, AddressPtr)

#define XGemac_mEnable(BaseAddress)

#define XGemac_mDisable(BaseAddress)

#define XGemac_mIsTxDone(BaseAddress)

#define XGemac_mIsRxEmpty(BaseAddress)

#define XGemac_mIsRxEmpty(BaseAddress)
```

## **Define Documentation**

### #define XGE\_CEAH\_OFFSET

CAM Entry Address High

### #define XGE\_CEAL\_OFFSET

CAM Entry Address Low

Rx keyhole

## ${\it \#define~XGE\_PFIFO\_RXREG\_OFFSET}$

Rx registers

## #define XGE\_PFIFO\_TXDATA\_OFFSET

Tx keyhole

### #define XGE\_PFIFO\_TXREG\_OFFSET

Tx registers

### #define XGE\_RPLR\_OFFSET

Rx packet length

### #define XGE\_RSR\_OFFSET

Receive status

### #define XGE\_SAH\_OFFSET

Station addr, high

### #define XGE\_SAL\_OFFSET

Station addr, low

### #define XGE\_STAT\_1023RXOK\_OFFSET

512-1023 byte frames RX'd ok

### #define XGE\_STAT\_1023TXOK\_OFFSET

512-1023 byte frames TX'd ok

### #define XGE\_STAT\_127RXOK\_OFFSET

65-127 byte frames RX'd ok

### #define XGE\_STAT\_127TXOK\_OFFSET

65-127 byte frames TX'd ok

### #define XGE\_STAT\_255RXOK\_OFFSET

128-255 byte frames RX'd ok

### #define XGE\_STAT\_255TXOK\_OFFSET

128-255 byte frames TX'd ok

### #define XGE\_STAT\_511RXOK\_OFFSET

256-511 byte frames RX'd ok

### #define XGE\_STAT\_511TXOK\_OFFSET

256-511 byte frames TX'd ok

### #define XGE\_STAT\_64RXOK\_OFFSET

64 byte frames RX'd ok

### #define XGE\_STAT\_64TXOK\_OFFSET

64 byte frames TX'd ok

### #define XGE\_STAT\_BFRXOK\_OFFSET

Broadcast Frames RX'd ok

### #define XGE\_STAT\_BFTXOK\_OFFSET

Broadcast Frames TX'd ok

### #define XGE\_STAT\_CARRIERERR\_OFFSET

Carrier sense errors

### #define XGE\_STAT\_CFRXOK\_OFFSET

Control Frames RX'd ok

### #define XGE\_STAT\_CFTXOK\_OFFSET

Control Frames TX'd ok

### #define XGE\_STAT\_CFUNSUP\_OFFSET

Control Frames with unsupported opcode RX's

### #define XGE\_STAT\_DEFERRED\_OFFSET

Deferred Frames

### #define XGE\_STAT\_EXCESSDEF\_OFFSET

Excess Deferral error

### #define XGE\_STAT\_FCSERR\_OFFSET

RX FCS error

### #define XGE\_STAT\_FRAGRX\_OFFSET

Fragment Frames RX'd

### #define XGE\_STAT\_LATECOLL\_OFFSET

Late Collision Frames

### #define XGE\_STAT\_LTERROR\_OFFSET

length/type out of range

### #define XGE\_STAT\_MAXRXOK\_OFFSET

1024-max byte frames RX'd ok

### #define XGE\_STAT\_MAXTXOK\_OFFSET

1024-Max byte frames TX'd ok

### #define XGE\_STAT\_MCOLL\_OFFSET

Multiple Collision Frames

### #define XGE\_STAT\_MCRXOK\_OFFSET

Multicast Frames RX'd ok

### #define XGE\_STAT\_MFTXOK\_OFFSET

Multicast Frames TX'd ok

### #define XGE\_STAT\_OFRXOK\_OFFSET

Oversize Frames RX'd ok

### #define XGE\_STAT\_OFTXOK\_OFFSET

Oversize Frames TX'd ok

### #define XGE\_STAT\_PFRXOK\_OFFSET

Pause Frames RX'd ok

### #define XGE\_STAT\_PFTXOK\_OFFSET

Pause Frames TX'd ok

### #define XGE\_STAT\_REG\_OFFSET

Offset of the MAC Statistics registers from the IPIF base address

### #define XGE\_STAT\_RXBYTES\_OFFSET

**RX** Byte Count

### #define XGE\_STAT\_RXOK\_OFFSET

Frames RX'd ok

# #define XGE\_STAT\_SCOLL\_OFFSET Single Collision Frames #define XGE\_STAT\_TXABORTED\_OFFSET Frames aborted due to excess collisions #define XGE\_STAT\_TXBYTES\_OFFSET TX Byte Count #define XGE\_STAT\_TXOK\_OFFSET Frames TX'd ok #define XGE\_STAT\_TXURUNERR\_OFFSET TX Underrun error #define XGE\_STAT\_UFRX\_OFFSET Undersize Frames RX'd #define XGE\_STAT\_VLANRXOK\_OFFSET VLAN Frames RX'd ok #define XGE\_STAT\_VLANTXOK\_OFFSET VLAN Frames TX'd ok #define XGE\_TPLR\_OFFSET Tx packet length #define XGE\_TPPR\_OFFSET

Tx Pause Pkt

### #define XGE\_TSR\_OFFSET

Tx status

### #define XGemac\_mDisable( BaseAddress )

| Paran        | neters:                                                                      |
|--------------|------------------------------------------------------------------------------|
|              | BaseAddress is the base address of the device                                |
| Retur        | ns:                                                                          |
|              | None.                                                                        |
| NT-4         |                                                                              |
| Note:        | None.                                                                        |
|              |                                                                              |
|              |                                                                              |
| #define      | XGemac_mEnable( BaseAddress )                                                |
| Enable       | the transmitter and receiver. Preserve the contents of the control register. |
| Paran        | neters:                                                                      |
| 1 41 411     | BaseAddress is the base address of the device                                |
|              |                                                                              |
| Retur        | ns: None.                                                                    |
|              | None.                                                                        |
| Note:        |                                                                              |
|              | None.                                                                        |
|              |                                                                              |
| #define      | XGemac_mIsRxEmpty( BaseAddress )                                             |
|              | to see if the receive FIFO is empty.                                         |
| CHECK        | to see if the receive i if o is empty.                                       |
| Paran        |                                                                              |
|              | BaseAddress is the base address of the device                                |
| Retur        | ns:                                                                          |
| Retur        | XTRUE if it is empty, or XFALSE if it is not.                                |
| <b>3.7</b> . |                                                                              |
| Note:        | None.                                                                        |
|              |                                                                              |
|              |                                                                              |
| #define      | XGemac_mIsTxDone( BaseAddress )                                              |
|              |                                                                              |
|              |                                                                              |

Disable the transmitter and receiver. Preserve the contents of the control register.

| Parameters:  BaseAddress is the base address of the device                                              |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Returns:  XTRUE if it is done, or XFALSE if it is not.                                                  |  |  |  |  |  |
| Note: None.                                                                                             |  |  |  |  |  |
| define XGemac_mPhyReset( BaseAddress )                                                                  |  |  |  |  |  |
| Reset MII compliant PHY                                                                                 |  |  |  |  |  |
| Parameters:  BaseAddress is the base address of the device                                              |  |  |  |  |  |
| Returns: None.                                                                                          |  |  |  |  |  |
| Note: None.                                                                                             |  |  |  |  |  |
| define XGemac_mReadReg( BaseAddress,  RegOffset )                                                       |  |  |  |  |  |
| Read the given register.                                                                                |  |  |  |  |  |
| Parameters:  BaseAddress is the base address of the device  RegOffset is the register offset to be read |  |  |  |  |  |
| Returns: The 32-bit value of the register                                                               |  |  |  |  |  |
| Note: None.                                                                                             |  |  |  |  |  |
| define XGemac_mSetControlReg( BaseAddress,  Mask )                                                      |  |  |  |  |  |
|                                                                                                         |  |  |  |  |  |

Check to see if the transmission is complete.

| written         | to the register          | r.                                                                                                             |   |  |
|-----------------|--------------------------|----------------------------------------------------------------------------------------------------------------|---|--|
|                 | BaseAddress              | is the base address of the device is the 16-bit value to write to the                                          |   |  |
| Return          | ns:<br>None.             |                                                                                                                |   |  |
| Note:           | None.                    |                                                                                                                |   |  |
| define Y        | KGemac_mSe               | etMacAddress( BaseAddress,<br>AddressPtr )                                                                     |   |  |
| Set the         | station addres           | ss of the GEMAC device.                                                                                        |   |  |
|                 | BaseAddress              | is the base address of the device<br>is a pointer to a 6-byte MAC ad                                           |   |  |
| Return          | ns:<br>None.             |                                                                                                                |   |  |
| Note:           | None.                    |                                                                                                                |   |  |
| define <b>X</b> | KGemac_mW                | VriteReg( BaseAddress, RegOffset, Data )                                                                       |   |  |
| Write th        | he given regis           | eter.                                                                                                          |   |  |
|                 | BaseAddress<br>RegOffset | is the base address of the device<br>is the register offset to be writte<br>is the 32-bit value to write to th | n |  |
| Return          | <b>ns:</b><br>None.      |                                                                                                                |   |  |
| Note:           | None.                    |                                                                                                                |   |  |

Set the contents of the control register. Use the XGE\_ECR\_\* constants defined above to create the bit-mask to be

# gemac/v1\_00\_d/src/xgemac\_options.c File Reference

# **Detailed Description**

Functions in this file handle configuration of the **XGemac** driver.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 01/13/03 First release

1.00b ecm 03/25/03 Revision update

1.00c rmm 05/28/03 Changed interframe gap API, process auto negotiate option

1.00d rmm 06/04/03 Moved XGE_MAX_IFG definition to xgemac_l.h. Fixed assert on MAX_IFG value in XGemac_SetInterframeGap(). Added support for XGE_VLAN_OPTION and XGE_JUMBO_OPTION. Updated description of XGemac_SetInterframeGap().
```

```
#include "xbasic_types.h"
#include "xgemac_i.h"
#include "xio.h"
```

# **Data Structures**

struct OptionMap

# **Functions**

```
XStatus XGemac_SetOptions (XGemac *InstancePtr, Xuint32 OptionsFlag)
Xuint32 XGemac_GetOptions (XGemac *InstancePtr)
```

# **Function Documentation**

### Xuint32 XGemac\_GetOptions( XGemac \* InstancePtr)

Get Ethernet driver/device options. The 32-bit value returned is a bit-mask representing the options (XGE\_\*\_OPTION). A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

The 32-bit value of the Ethernet options. The value is a bit-mask representing all options that are currently enabled. See **xgemac.h** for a description of the available options.

### Note:

None.

Set Ethernet driver/device options. The options (XGE\_\*\_OPTION) constants can be OR'd together to set/clear multiple options. A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

The device must be stopped before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

OptionsFlag is a bit-mask representing the Ethernet options to turn on or off. See **xgemac.h** for a description of the available options.

#### **Returns:**

- XST\_SUCCESS if the options were set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

## Xilinx Device Drivers

# Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# XGemac\_HardStats Struct Reference

#include <xgemac.h>

# **Detailed Description**

Statistics maintained by HW

# **Data Fields**

Xuint64 RecvFrames

Xuint64 RecvFcs

Xuint64 RecvBroadcast

Xuint64 RecvMulticast

Xuint64 Recv64Byte

Xuint64 Recv65\_127Byte

Xuint64 Recv128\_255Byte

Xuint64 Recv256\_511Byte

Xuint64 Recv512\_1023Byte

Xuint64 Recv1024\_MaxByte

Xuint64 RecvControl

Xuint64 RecvLengthRange

Xuint64 RecvVlan

Xuint64 RecvPause

Xuint64 RecvBadOpcode

Xuint64 RecvLong

Xuint64 RecvShort

**Xuint64 RecvFragment** 

Xuint64 RecvBytes

Xuint64 XmitBytes

Xuint64 XmitFrames

Xuint64 XmitBroadcast

Xuint64 XmitMulticast

Xuint64 XmitUnderrun

Xuint64 XmitControl

Xuint64 Xmit64Byte

Xuint64 Xmit65\_127Byte

Xuint64 Xmit128\_255Byte

**Xuint64 Xmit256\_511Byte** 

Xuint64 Xmit512\_1023Byte

Xuint64 Xmit1024\_MaxByte

Xuint64 XmitVlan

Xuint64 XmitPause

Xuint64 XmitLong

Xuint64 Xmit1stCollision

Xuint64 XmitMultiCollision

Xuint64 XmitDeferred

Xuint64 XmitLateColision

Xuint64 XmitExcessCollision

Xuint64 XmitCarrierSense

Xuint64 XmitExcessDeferred

# **Field Documentation**

# Xuint64 XGemac\_HardStats::Recv1024\_MaxByte

Number of 1024 and larger byte frames received

# Xuint64 XGemac\_HardStats::Recv128\_255Byte

Number of 128-255 byte frames received

# Xuint64 XGemac\_HardStats::Recv256\_511Byte

Number of 256-511 byte frames received

## Xuint64 XGemac\_HardStats::Recv512\_1023Byte

Number of 512-1023 byte frames received

# Xuint64 XGemac\_HardStats::Recv64Byte

Number of 64 byte frames received

# Xuint64 XGemac\_HardStats::Recv65\_127Byte

Number of 65-127 byte frames received

### Xuint64 XGemac\_HardStats::RecvBadOpcode

Number of control frames received with an invalid opcode

### Xuint64 XGemac HardStats::RecvBroadcast

Number of broadcast frames received

### Xuint64 XGemac\_HardStats::RecvBytes

Number of bytes received

## Xuint64 XGemac\_HardStats::RecvControl

Number of control frames received

# Xuint64 XGemac\_HardStats::RecvFcs

Number of received frames discarded due to FCS errors

# Xuint64 XGemac\_HardStats::RecvFragment

Number of received frames less than 64 bytes discarded due to FCS errors

## Xuint64 XGemac\_HardStats::RecvFrames

Number of frames received

# Xuint64 XGemac\_HardStats::RecvLengthRange

Number of received frames with length or type that didn't match number of bytes actually received

### Xuint64 XGemac\_HardStats::RecvLong

Number of oversized frames received

### Xuint64 XGemac\_HardStats::RecvMulticast

Number of multicast frames received

### Xuint64 XGemac\_HardStats::RecvPause

Number of pause frames received

### Xuint64 XGemac\_HardStats::RecvShort

Number of undersized frames received

### Xuint64 XGemac HardStats::RecvVlan

Number of VLAN frames received

# Xuint64 XGemac\_HardStats::Xmit1024\_MaxByte

Number of 1024 and larger byte frames transmitted

# Xuint64 XGemac\_HardStats::Xmit128\_255Byte

Number of 128-255 byte frames transmitted

# Xuint64 XGemac\_HardStats::Xmit1stCollision

Number of frames involved in a single collision but sent successfully

# Xuint64 XGemac\_HardStats::Xmit256\_511Byte

Number of 256-511 byte frames transmitted

# Xuint64 XGemac\_HardStats::Xmit512\_1023Byte

Number of 512-1023 byte frames transmitted

### Xuint64 XGemac\_HardStats::Xmit64Byte

Number of 64 byte frames transmitted

## Xuint64 XGemac\_HardStats::Xmit65\_127Byte

Number of 65-127 byte frames transmitted

### Xuint64 XGemac\_HardStats::XmitBroadcast

Number of broadcast frames transmitted

### Xuint64 XGemac\_HardStats::XmitBytes

Number of bytes transmitted

### Xuint64 XGemac HardStats::XmitCarrierSense

Number of frames not sent due to the GMII\_CRS signal being negated

### Xuint64 XGemac\_HardStats::XmitControl

Number of control frames transmitted

# Xuint64 XGemac\_HardStats::XmitDeferred

Number of frames delayed because the medium was busy

# Xuint64 XGemac\_HardStats::XmitExcessCollision

Number of frames discarded due to excess collisions

# Xuint64 XGemac HardStats::XmitExcessDeferred

Number of frames not sent due to excess deferral times

### Xuint64 XGemac HardStats::XmitFrames

Number of frames transmitted

# Xuint64 XGemac\_HardStats::XmitLateColision

Number of frames involved in a late collision but sent successfully

# Xuint64 XGemac\_HardStats::XmitLong

Number of oversized frames transmitted

# Xuint64 XGemac\_HardStats::XmitMulticast

Number of multicast frames transmitted

# Xuint64 XGemac\_HardStats::XmitMultiCollision

Number of frames involved in a multiple collision but sent successfully

### Xuint64 XGemac HardStats::XmitPause

Number of pause frames transmitted

### Xuint64 XGemac\_HardStats::XmitUnderrun

Number of frames not sent due to underrun

# Xuint64 XGemac\_HardStats::XmitVlan

Number of VLAN frames transmitted

The documentation for this struct was generated from the following file:

• gemac/v1\_00\_d/src/**xgemac.h** 

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

# XGemac\_SoftStats Struct Reference

#include <xgemac.h>

# **Detailed Description**

Statistics mainained by SW

# **Data Fields**

| Xuint32 | <b>Xmit</b> C | )verrun <b>F</b> | crrors |
|---------|---------------|------------------|--------|
|---------|---------------|------------------|--------|

**Xuint32 XmitUnderrunErrors** 

Xuint32 XmitExcessDeferralErrors

Xuint32 XmitPFifoUnderrunErrors

Xuint32 XmitLateCollErrors

Xuint32 RecvSlotLengthErrors

Xuint32 RecvOverrunErrors

**Xuint32 RecvUnderrunErrors** 

**Xuint32 RecvLengthFieldErrors** 

**Xuint32 RecvLongErrors** 

**Xuint32 RecvFcsErrors** 

**Xuint32 DmaErrors** 

**Xuint32 FifoErrors** 

**Xuint32 RecvInterrupts** 

**Xuint32 XmitInterrupts** 

**Xuint32 EmacInterrupts** 

**Xuint32 TotalInterrupts** 

# **Field Documentation**

### Xuint32 XGemac SoftStats::DmaErrors

Number of DMA errors since init

### Xuint32 XGemac\_SoftStats::EmacInterrupts

Number of MAC (device) interrupts

### Xuint32 XGemac\_SoftStats::FifoErrors

Number of FIFO errors since init.

### Xuint32 XGemac\_SoftStats::RecvFcsErrors

Number of recy FCS errors

### Xuint32 XGemac\_SoftStats::RecvInterrupts

Number of receive interrupts

# Xuint32 XGemac\_SoftStats::RecvLengthFieldErrors

Number of recv frames discarded with invalid length field

# Xuint32 XGemac\_SoftStats::RecvLongErrors

Number of recv long frames discarded

# Xuint32 XGemac\_SoftStats::RecvOverrunErrors

Number of recy frames discarded due to overrun errors

# Xuint32 XGemac\_SoftStats::RecvSlotLengthErrors

Number of recv frames received with slot length errors

# Xuint32 XGemac\_SoftStats::RecvUnderrunErrors

Number of recy underrun errors

### Xuint32 XGemac\_SoftStats::TotalInterrupts

Total interrupts

# Xuint32 XGemac\_SoftStats::XmitExcessDeferralErrors

Number of transmit deferral errors

# Xuint32 XGemac\_SoftStats::XmitInterrupts

Number of transmit interrupts

### Xuint32 XGemac SoftStats::XmitLateCollErrors

Number of late collision errors

### Xuint32 XGemac SoftStats::XmitOverrunErrors

Number of transmit overrun errors

### Xuint32 XGemac SoftStats::XmitPFifoUnderrunErrors

Number of transmit packet fifo underrun errors

# Xuint32 XGemac\_SoftStats::XmitUnderrunErrors

Number of transmit underrun errors

The documentation for this struct was generated from the following file:

• gemac/v1\_00\_d/src/**xgemac.h** 

# gemac/v1\_00\_d/src/xgemac\_stats.c File Reference

# **Detailed Description**

Contains functions to get and clear the **XGemac** driver statistics.

MODIFICATION HISTORY:

# **Functions**

```
void XGemac_GetSoftStats (XGemac *InstancePtr, XGemac_SoftStats *StatsPtr)
void XGemac_ClearSoftStats (XGemac *InstancePtr)
XStatus XGemac_GetHardStats (XGemac *InstancePtr, XGemac_HardStats *StatsPtr)
```

# **Function Documentation**

### void XGemac\_ClearSoftStats( XGemac \* InstancePtr)

Clear the **XGemac\_SoftStats** structure for this driver.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

### **Returns:**

None.

### Note:

None.

Get a snapshot of the current hardware statistics counters.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

### **Returns:**

XST\_SUCCESS if counters were read and copied to user space XST\_NO\_FEATURE if counters are not part of the gemac hw

### Note:

None.

Get a copy of the **XGemac\_SoftStats** structure, which contains the current statistics for this driver as maintained by software counters. The statistics are cleared at initialization or on demand using the **XGemac\_ClearSoftStats**() function.

The DmaErrors and FifoErrors counts indicate that the device has been or needs to be reset. Reset of the device is the responsibility of the upper layer software.

Use XGemac\_GetHardStats() to retrieve hardware maintained statistics (if so configured).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

None.

### **Note:**

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac\_intr\_fifo.c File Reference

# **Detailed Description**

Contains functions related to interrupt mode using direct FIFO communication.

The interrupt handler, **XGemac\_IntrHandlerFifo**(), must be connected by the user to the interrupt controller.

#### MODIFICATION HISTORY:

# **Functions**

```
XStatus XGemac_FifoSend (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)

XStatus XGemac_FifoRecv (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)

void XGemac_IntrHandlerFifo (void *InstancePtr)
```

# **Function Documentation**

Receive an Ethernet frame into the given buffer if a frame has been received by the hardware. This function is typically called by the user in response to an interrupt invoking the receive callback function as set by **XGemac\_SetFifoRecvHandler**().

The supplied buffer should be properly aligned (see **xgemac.h**) and large enough to contain the biggest frame for the current operating mode of the GEMAC device (approx 1518 bytes for normal frames and 9000 bytes for jumbo frames).

If the device is configured with DMA, simple DMA will be used to transfer the buffer from the GEMAC to memory. In this case, the receive buffer must not be cached (see **xgemac.h**).

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a memory buffer into which the received Ethernet frame will

be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that

contains the size of the buffer on entry into the function and the size the

received frame on return from the function.

#### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST\_NO\_DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.
- XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA).
   The user should treat this as a fatal error that requires a reset of the EMAC device.

### Note:

The input buffer must be big enough to hold the largest Ethernet frame.

Send an Ethernet frame using packet FIFO with interrupts. The caller provides a contiguous-memory buffer and its length. The buffer must be properly aligned (see **xgemac.h**).

The callback function set by using **XGemac\_SetFifoSendHandler**() is invoked when the transmission is complete.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field.

If the device is configured with simple DMA, simple DMA will be used to transfer the buffer from memory to the GEMAC. This means that this buffer should not be cached.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the Ethernet frame to be sent. ByteCount is the size of the Ethernet frame.

#### **Returns:**

- XST\_SUCCESS if the frame was successfully sent. An interrupt is generated when the GEMAC transmits the frame and the driver calls the callback set with XGemac\_SetFifoSendHandler()
- XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- XST\_NOT\_INTERRUPT if the device is not in interrupt mode
- o XST\_FIFO\_NO\_ROOM if there is no room in the FIFO for this frame
- o XST\_DEVICE\_BUSY if configured for simple DMA and the DMA engine is busy
- o XST\_DMA\_ERROR if an error occurred during the DMA transfer (simple DMA). The user should treat this as a fatal error that requires a reset of the EMAC device.

### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

### void XGemac\_IntrHandlerFifo( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured for direct FIFO communication (as opposed to DMA).

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, or Send Packet FIFO. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the MAC.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance that just interrupted.

#### **Returns:**

None.

Note:

None.

```
void XGemac_SetFifoRecvHandler( XGemac * InstancePtr,
void * CallBackRef,
XGemac_FifoHandler FuncPtr
)
```

Set the callback function for handling confirmation of transmitted frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called by the driver once per frame sent. The callback is responsible for freeing the transmitted buffer if necessary.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

Note:

None.

Set the callback function for handling received frames when configured for direct memory-mapped I/O using FIFOs. The upper layer software should call this function during initialization. The callback is called once per frame received. During the callback, the upper layer software should call **XGemac FifoRecv**() to retrieve the received frame.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is

arbitrary and not used by the driver.

*FuncPtr* is the pointer to the callback function.

### **Returns:**

None.

### Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac\_control.c File Reference

# **Detailed Description**

Functions in this file handle various control functions of the XGemac driver.

```
MODIFICATION HISTORY:
```

# **Functions**

```
XStatus XGemac_SetInterframeGap (XGemac *InstancePtr, Xuint8 Ifg)
void XGemac_GetInterframeGap (XGemac *InstancePtr, Xuint8 *IfgPtr)

XStatus XGemac_SendPause (XGemac *InstancePtr, Xuint16 PausePeriod)

XStatus XGemac_MgtRead (XGemac *InstancePtr, int PhyAddress, int Register, Xuint16
*DataPtr)

XStatus XGemac_MgtWrite (XGemac *InstancePtr, int PhyAddress, int Register, Xuint16 Data)
```

# **Function Documentation**

Get the interframe gap. See the description of interframe gap above in **XGemac\_SetInterframeGap**().

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*IfgPtr* is a pointer to an 8-bit buffer into which the interframe gap value will be copied. The LSB value is 8 bit times.

#### **Returns:**

None. The values of the interframe gap parts are copied into the output parameters.

Read a PHY register through the GMII Management Control mechanism.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*PhyAddress* is the address of the PHY to be accessed. Valid range is 0 to 31.

*Register* is the register in the PHY to be accessed. Valid range is 0 to 31.

DataPtr is an output parameter that will contain the contents of the register.

### **Returns:**

- XST\_SUCCESS if the PHY register was successfully read and its contents were placed in DataPtr.
- o XST\_NO\_FEATURE if GMII is not present with this GEMAC instance.
- o XST\_DEVICE\_BUSY if another GMII read/write operation is already in progresss.
- o XST FAILURE if an GMII read error is detected

### Note:

This function blocks until the read operation has completed. If there is a HW problem then this function may not return.

Write to a PHY register through the GMII Management Control mechanism.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*PhyAddress* is the address of the PHY to be accessed.

Register is the register in the PHY to be accessed.

Data is the what will be written to the register.

### **Returns:**

- XST\_SUCCESS if the PHY register was successfully read and its contents are placed in DataPtr.
- XST\_DEVICE\_BUSY if another GMII read/write operation is already in progresss.
- o XST\_NO\_FEATURE if GMII is not present with this GEMAC instance.

### Note:

This function blocks until the write operation has completed. If there is a HW problem then this function may not return.

Send a pause packet. When called, the GEMAC hardware will initiate transmission of an automatically formed pause packet. This action will not disrupt any frame transmission in progress but will take priority over any pending frame transmission. The pause frame will be sent even if the transmitter is in the paused state.

For this function to have any effect, the XGE\_FLOW\_CONTROL option must be set (see XGemac\_SetOptions)).

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

PausePeriod is the amount of time to pause. The LSB is 512 bit times.

### **Returns:**

- XST\_SUCCESS if the pause frame transmission mechanism was successfully started.
- XST\_DEVICE\_IS\_STARTED if the device has not been stopped

Set the Interframe Gap (IFG), which is the time the MAC delays between transmitting frames.

The device must be stopped before setting the interframe gap.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*Ifg* is the interframe gap to set, the LSB is 8 bit times.

### **Returns:**

- o XST\_SUCCESS if the interframe gap was set successfully
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped

### Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# gemac/v1\_00\_d/src/xgemac\_intr\_dma.c File Reference

# **Detailed Description**

Contains functions used in interrupt mode when configured with scatter-gather DMA.

The interrupt handler, **XGemac\_IntrHandlerDma**(), must be connected by the user to the interrupt controller.

#### MODIFICATION HISTORY:

# **Functions**

```
XStatus XGemac_SgSend (XGemac *InstancePtr, XBufDescriptor *BdPtr, int Delay)

XStatus XGemac_SgRecv (XGemac *InstancePtr, XBufDescriptor *BdPtr)

void XGemac_IntrHandlerDma (void *InstancePtr)

XStatus XGemac_SetPktThreshold (XGemac *InstancePtr, Xuint32 Direction, Xuint8 Threshold)
```

```
XStatus XGemac_SetPktWaitBound (XGemac *InstancePtr, Xuint32 Direction, Xuint8 *ThreshPtr)

XStatus XGemac_SetPktWaitBound (XGemac *InstancePtr, Xuint32 Direction, Xuint32

TimerValue)

XStatus XGemac_GetPktWaitBound (XGemac *InstancePtr, Xuint32 Direction, Xuint32 *WaitPtr)

XStatus XGemac_SetSgRecvSpace (XGemac *InstancePtr, Xuint32 *MemoryPtr, Xuint32

ByteCount)

XStatus XGemac_SetSgSendSpace (XGemac *InstancePtr, Xuint32 *MemoryPtr, Xuint32

ByteCount)

void XGemac_SetSgRecvHandler (XGemac *InstancePtr, void *CallBackRef,

XGemac_SgHandler FuncPtr)

void XGemac_SetSgSendHandler (XGemac *InstancePtr, void *CallBackRef,

XGemac_SgHandler FuncPtr)
```

# **Function Documentation**

Get the value of the packet count threshold for the scatter-gather DMA engine. See **xgemac.h** for more discussion of interrupt coalescing features.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE\_SEND or XGE\_RECV, to get.

ThreshPtr is a pointer to the byte into which the current value of the packet threshold register will be copied.

### **Returns:**

- XST\_SUCCESS if the packet threshold was retrieved successfully
- XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

### Note:

None

Get the packet wait bound timer for this driver/device. See **xgemac.h** for more discussion of interrupt coalescing features.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*Direction* indicates the channel, XGE\_SEND or XGE\_RECV, to read.

WaitPtr is a pointer to the byte into which the current value of the packet wait bound

register will be copied. Units are in milliseconds. Range is 0 - 1023. A value of 0

disables the timer.

### **Returns:**

- o XST\_SUCCESS if the packet wait bound was retrieved successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

### **Note:**

None.

### void XGemac\_IntrHandlerDma( void \* InstancePtr)

The interrupt handler for the Ethernet driver when configured with scatter- gather DMA.

Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: MAC, Recv Packet FIFO, Send Packet FIFO, Recv DMA channel, or Send DMA channel. The packet FIFOs only interrupt during "deadlock" conditions.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance that just interrupted.

#### **Returns:**

None.

#### Note:

None.

Set the scatter-gather DMA packet count threshold for this device. See **xgemac.h** for more discussion of interrupt coalescing features.

The device must be stopped before setting the threshold.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Direction indicates the channel, XGE\_SEND or XGE\_RECV, to set.

Threshold is the value of the packet threshold count used during interrupt coalescing. Valid

range is 0 - 255. A value of 0 disables the use of packet threshold by the

hardware.

### **Returns:**

- XST\_SUCCESS if the threshold was successfully set
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_DMA\_SG\_COUNT\_EXCEEDED if the threshold must be equal to or less than the number of descriptors in the list
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

### **Note:**

None

Set the scatter-gather DMA packet wait bound timer for this device. See **xgemac.h** for more discussion of interrupt coalescing features.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*Direction* indicates the channel, XGE\_SEND or XGE\_RECV, from which the threshold register is read.

*TimerValue* is the value of the packet wait bound timer to set. Units are in milliseconds. A value of 0 means the timer is disabled.

#### **Returns:**

- XST\_SUCCESS if the packet wait bound was set successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DEVICE\_IS\_STARTED if the device has not been stopped
- XST\_INVALID\_PARAM if the Direction parameter is invalid. Turning on asserts would also catch this error.

#### Note:

None.

```
void XGemac_SetSgRecvHandler( XGemac * InstancePtr,
void * CallBackRef,
XGemac_SgHandler FuncPtr
)
```

Set the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame received. The head of a descriptor list is passed in along with the number of descriptors in the list. Before leaving the callback, the upper layer software should attach a new buffer to each descriptor in the list.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. Sending the received frame up the protocol stack should be done at task-level. If there are other potentially slow operations within the callback, these too should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the driver.

FuncPtr is the pointer to the callback function.

### **Returns:**

None.

Note:

None.

Give the driver memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xgemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be properly aligned (see **xgemac.h**).

### **Parameters:**

InstancePtr is a pointer to the **XGemac** instance to be worked on.

MemoryPtr is a pointer to the beginning of the memory space.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XGemac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Set the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called once per frame sent. The head of a descriptor list is passed in along with the number of descriptors in the list. The callback is responsible for freeing buffers attached to these descriptors.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the driver.

*FuncPtr* is the pointer to the callback function.

### **Returns:**

None.

### Note:

None.

Give the driver memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the Ethernet driver. The memory space must be big enough to hold some number of descriptors, depending on the needs of the system. The **xgemac.h** file defines minimum and default numbers of descriptors which can be used to allocate this memory space.

The memory space must be properly aligned (see **xgemac.h**).

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*MemoryPtr* is a pointer to the beginning of the memory space.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the MAC is not configured for scatter-gather DMA
- o XST\_DMA\_SG\_LIST\_EXISTS if this list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XGemac\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Add a descriptor, with an attached empty buffer, into the receive descriptor list. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. This function can be called when the device is started or stopped. Note that it does start the scatter-gather DMA engine. Although this is not necessary during initialization, it is not a problem during initialization because the MAC receiver is not yet started.

The buffer attached to the descriptor and the descriptor itself must be properly aligned (see **xgemac.h**).

Notification of received frames are done asynchronously through the receive callback function.

### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

### **Returns:**

- XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

Send an Ethernet frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire Ethernet frame may or may not be contained within one descriptor. This function simply inserts the descriptor into the scatter- gather engine's transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor and the descriptor itself must be properly aligned (see **xgemac.h**).

The driver updates the descriptor with the device control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

The buffer attached to the descriptor must be 64-bit aligned on the front end.

This call is non-blocking. Notification of error or successful transmission is done asynchronously through the send or error callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

Delay indicates whether to start the scatter-gather DMA channel immediately, or whether to wait. This allows the user to queue up a list of more than one descriptor before starting the transmission of the packets. Use

XEM\_SGDMA\_NODELAY or XEM\_SGDMA\_DELAY, defined in **xgemac.h**, as the value of this argument. If the user chooses to delay and build a list, the user must call this function with the XEM\_SGDMA\_NODELAY option or call **XGemac Start**() to kick off the transissions.

#### **Returns:**

- XST SUCCESS if the buffer was successfull sent
- o XST\_DEVICE\_IS\_STOPPED if the Ethernet MAC has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

#### Note:

| This function is not thread-safe. The user must provide mutually exclusive acces | s to this |
|----------------------------------------------------------------------------------|-----------|
| function if there are to be multiple threads that can call it.                   |           |

# gemac/v1\_00\_d/src/xgemac\_multicast.c File Reference

# **Detailed Description**

Functions in this file handle multicast addressing capabilities

```
MODIFICATION HISTORY:
```

## **Functions**

XStatus XGemac\_MulticastAdd (XGemac \*InstancePtr, Xuint8 Location, Xuint8 \*AddressPtr)
XStatus XGemac\_MulticastClear (XGemac \*InstancePtr, Xuint8 Location)

# **Function Documentation**

Set a discrete multicast address entry in the CAM lookup table. There are up to XGE\_CAM\_MAX\_ADDRESSES in this table. The GEMAC must be stopped (see XGemac\_Stop()) before multicast addresses can be modified.

Once set, the multicast address cannot be retrieved. It can be disabled by clearing it using **XGemac\_MulticastClear**().

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Location indicates which of the entries is to be updated. Valid range is 0 to

XGE\_CAM\_MAX\_ADDRESSES-1.

AddressPtr is the multicast address to set.

#### **Returns:**

- o XST\_SUCCESS if the multicast address table was updated successfully
- o XST NO FEATURE if this feature is not included in HW
- XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- XST\_INVALID\_PARAM if the Location parameter is greater than XGE\_CAM\_MAX\_ADDRESSES

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Clear a discrete multicast address entry in the CAM lookup table. There are up to XGE\_CAM\_MAX\_ADDRESSES in this table. The GEMAC must be stopped (see XGemac\_Stop()) before multicast addresses can be cleared.

The entry is cleared by writing an address of 00:00:00:00:00:00 to its location.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

Location indicates which of the entries is to be cleared. Valid range is 0 to XGE\_CAM\_MAX\_ADDRESSES-1.

#### **Returns:**

- XST\_SUCCESS if the multicast address table was updated successfully
- XST\_NO\_FEATURE if this feature is not included in HW
- o XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- XST\_INVALID\_PARAM if the Location parameter is greater than XGE\_CAM\_MAX\_ADDRESSES

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

# gemac/v1\_00\_d/src/xgemac\_polled.c File Reference

# **Detailed Description**

Contains functions used when the driver is in polled mode. Use the **XGemac\_SetOptions**() function to put the driver into polled mode.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xgemac_i.h"
#include "xio.h"
#include "xipif_v1_23_b.h"
```

### **Functions**

```
XStatus XGemac_PollSend (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 ByteCount)
XStatus XGemac_PollRecv (XGemac *InstancePtr, Xuint8 *BufPtr, Xuint32 *ByteCountPtr)
```

### **Function Documentation**

Receive an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver receives the frame directly from the MAC's packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The MAC's error status is not checked, so statistics are not updated for polled receive. The buffer into which the frame will be received must be properly aligned (see **xgemac.h**).

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to an aligned buffer into which the received Ethernet frame will be copied.

ByteCountPtr is both an input and an output parameter. It is a pointer to a 32-bit word that contains the

size of the buffer on entry into the function and the size the received frame on return from

the function.

#### **Returns:**

- XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST NO DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the buffer to receive the frame is too small for the frame waiting in the FIFO.

#### Note:

Input buffer must be big enough to hold the largest Ethernet frame. Buffer must also be 32-bit aligned.

Send an Ethernet frame in polled mode. The device/driver must be in polled mode before calling this function. The driver writes the frame directly to the MAC's packet FIFO, then enters a loop checking the device status for completion or error. Statistics are updated if an error occurs. The buffer to be sent must be properly aligned (see **xgemac.h**).

It is assumed that the upper layer software supplies a correctly formatted and aligned Ethernet frame, including the destination and source addresses, the type/length field, and the data field. It is also assumed that upper layer software does not append FCS at the end of the frame.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

BufPtr is a pointer to a word-aligned buffer containing the Ethernet frame to be sent.

*ByteCount* is the size of the Ethernet frame.

#### **Returns:**

- o XST\_SUCCESS if the frame was sent successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_NOT\_POLLED if the device is not in polled mode
- o XST\_FIFO\_NO\_ROOM if there is no room in the GEMAC's length FIFO for this frame
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.
- o XST\_EMAC\_COLLISION if the send failed due to excess deferral or late collision

#### **Note:**

There is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the PollSend thread. On a 1 Gbit (1000Mbps) MAC, it takes about 12.1 usecs to transmit a maximum size Ethernet frame.

# gemac/v1\_00\_d/src/xgemac\_selftest.c File Reference

# **Detailed Description**

Self-test and diagnostic functions of the **XGemac** driver.

MODIFICATION HISTORY:

#include "xipif\_v1\_23\_b.h"

### **Functions**

XStatus XGemac\_SelfTest (XGemac \*InstancePtr)

### **Function Documentation**

XStatus XGemac\_SelfTest( XGemac \* InstancePtr)

Performs a self-test on the Ethernet device. The test includes:

- Run self-test on DMA channel, FIFO, and IPIF components
- Reset the Ethernet device, check its registers for proper reset values, and run an internal loopback test on the device. The internal loopback uses the device in polled mode.

This self-test is destructive. On successful completion, the device is reset and returned to its default configuration. The caller is responsible for re-configuring the device after the self-test is run, and starting it when ready to send and receive frames.

It should be noted that data caching must be disabled when this function is called because the DMA self-test uses two local buffers (on the stack) for the transfer test.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

#### **Returns:**

| XST_SUCCESS  XST_PFIFO_BAD_REG_VALUE  XST_DMA_TRANSFER_ERROR  XST_DMA_RESET_REGISTER_ERROR | Self-test was successful FIFO failed register self-test DMA failed data transfer self-test DMA control register value was incorrect after a reset |
|--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| XST_REGISTER_ERROR                                                                         | Ethernet failed register reset test                                                                                                               |
| XST_LOOPBACK_ERROR                                                                         | Internal loopback failed                                                                                                                          |
| XST_IPIF_REG_WIDTH_ERROR                                                                   | An invalid register width was passed into the function                                                                                            |
| XST_IPIF_RESET_REGISTER_ERROR                                                              | The value of a register at reset was invalid                                                                                                      |
| XST_IPIF_DEVICE_STATUS_ERROR                                                               | A write to the device status register did not read back correctly                                                                                 |
| XST_IPIF_DEVICE_ACK_ERROR                                                                  | A bit in the device status register did not reset when acked                                                                                      |
| XST_IPIF_DEVICE_ENABLE_ERROR                                                               | The device interrupt enable register was not updated correctly by the hardware when other registers were written to                               |
| XST_IPIF_IP_STATUS_ERROR                                                                   | A write to the IP interrupt status register did not read back correctly                                                                           |
| XST_IPIF_IP_ACK_ERROR                                                                      | One or more bits in the IP status register did not reset when acked                                                                               |
| XST_IPIF_IP_ENABLE_ERROR                                                                   | The IP interrupt enable register was not updated correctly when other registers were written to                                                   |

#### Note:

This function makes use of options-related functions, and the **XGemac\_PollSend()** and **XGemac\_PollRecv()** functions.

Because this test uses the PollSend function for its loopback testing, there is the possibility that this function will not return if the hardware is broken (i.e., it never sets the status bit indicating that transmission is done). If this is of concern to the user, the user should provide protection from this problem - perhaps by using a different timer thread to monitor the self-test thread.

# gemac/v1\_00\_d/src/xgemac\_intr.c File Reference

# **Detailed Description**

This file contains general interrupt-related functions of the **XGemac** driver.

MODIFICATION HISTORY:

#include "xipif v1 23 b.h"

```
Ver Who Date Changes

1.00a ecm 01/13/03 First release

1.00b ecm 03/25/03 Revision update

1.00c rmm 05/28/03 Revision update

1.00d rmm xx/xx/xx Removed use of XGE_EIR_RECV_DFIFO_OVER_MASK, XGE_EIR __RECV_MISSED_FRAME_MASK, XGE_EIR_RECV_COLLISION_MASK, XGE_EIR_RECV_SHORT_ERROR_MASK

#include "xbasic_types.h"

#include "xgemac_i.h"

#include "xio.h"
```

### **Functions**

void **XGemac\_SetErrorHandler** (**XGemac** \*InstancePtr, void \*CallBackRef, **XGemac\_ErrorHandler** FuncPtr)

### **Function Documentation**

Set the callback function for handling asynchronous errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable MAC error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_DMA\_SG\_NO\_LIST indicates an attempt was made to access a scatter-gather DMA list that has not yet been created.
- XST\_DMA\_SG\_LIST\_EMPTY indicates the driver tried to get a descriptor from the receive descriptor list, but the list was empty.

#### **Parameters:**

*InstancePtr* is a pointer to the **XGemac** instance to be worked on.

CallBackRef is reference data to be passed back to the callback function. Its value is arbitrary and not used by the driver.

FuncPtr is the pointer to the callback function.

| Retur | ns:   |  |  |  |  |
|-------|-------|--|--|--|--|
|       | None. |  |  |  |  |
|       |       |  |  |  |  |
| Note: |       |  |  |  |  |
|       | None. |  |  |  |  |
|       |       |  |  |  |  |

# gpio/v1\_00\_a/src/xgpio\_i.h File Reference

# **Detailed Description**

This header file contains internal identifiers, which are those shared between the files of the driver. It is intended for internal use only.

**NOTES:** 

None.

```
MODIFICATION HISTORY:
```

```
#include "xgpio.h"
```

# **Variables**

XGpio\_Config XGpio\_ConfigTable []

# **Variable Documentation**

**XGpio\_Config XGpio\_ConfigTable**[]( )

This table contains configuration information for each GPIO device in the system.

# gpio/v1\_00\_a/src/xgpio.h File Reference

# **Detailed Description**

This file contains the software API definition of the Xilinx General Purpose I/O (XGpio) component.

The Xilinx GPIO controller is a soft IP core designed for Xilinx FPGAs and contains the following general features:

- Support for 8, 16, or 32 I/O discretes
- Each of the discretes can be configured for input or output.

#### Note:

This API utilizes 32 bit I/O to the GPIO registers. With 16 and 8 bit GPIO components, the unused bits from registers are read as zero and written as don't cares.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00a rmm 03/13/02 First release

#include "xbasic_types.h"
#include "xstatus.h"
#include "xgpio_1.h"
```

### **Data Structures**

```
struct XGpio Struct XGpio Config
```

## **Functions**

```
XStatus XGpio_Initialize (XGpio *InstancePtr, Xuint16 DeviceId)
void XGpio_SetDataDirection (XGpio *InstancePtr, Xuint32 DirectionMask)
Xuint32 XGpio_DiscreteRead (XGpio *InstancePtr)
void XGpio_DiscreteWrite (XGpio *InstancePtr, Xuint32 Mask)
XGpio_Config * XGpio_LookupConfig (Xuint16 DeviceId)
void XGpio_DiscreteSet (XGpio *InstancePtr, Xuint32 Mask)
void XGpio_DiscreteClear (XGpio *InstancePtr, Xuint32 Mask)
XStatus XGpio_SelfTest (XGpio *InstancePtr)
```

# **Function Documentation**

```
void XGpio_DiscreteClear( XGpio * InstancePtr,
Xuint32 Mask
)
```

Set output discrete(s) to logic 0.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

Mask

is the set of bits that will be set to 0 in the discrete data register. All other bits in the data register are unaffected.

#### Note:

None

Xuint32 XGpio\_DiscreteRead( XGpio \* InstancePtr)

Read state of discretes.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

#### **Returns:**

Current copy of the discretes register.

**Note:** 

None

Set output discrete(s) to logic 1.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

Mask

is the set of bits that will be set to 1 in the discrete data register. All other bits in the data register are unaffected.

Note:

None

```
void XGpio_DiscreteWrite( XGpio * InstancePtr,
Xuint32 Data
)
```

Write to discretes register

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

Data is the value to be written to the discretes register.

#### Note:

See also XGpio\_DiscreteSet() and XGpio\_DiscreteClear().

Initialize the **XGpio** instance provided by the caller based on the given DeviceID.

Nothing is done except to initialize the InstancePtr.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance. The memory the pointer references must be pre-allocated by the caller. Further calls to manipulate the component through the **XGpio** API must be made with this pointer.

DeviceId is the unique id of the device controlled by this **XGpio** component. Passing in a device id associates the generic **XGpio** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS Initialization was successfull.
- XST\_DEVICE\_NOT\_FOUND Device configuration data was not found for a device with the supplied device ID.

**NOTES:** 

None

#### 

Lookup the device configuration based on the unique device ID. The table ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceID* is the device identifier to lookup.

#### **Returns:**

- XGpio configuration structure pointer if DeviceID is found.
- XNULL if DeviceID is not found.

#### XStatus XGpio\_SelfTest( XGpio \* InstancePtr)

Run a self-test on the driver/device. This includes the following tests:

• Register reads.

#### **ARGUMENTS:**

#### **Parameters:**

*InstancePtr* is a pointer to the **XGpio** instance to be worked on. This parameter must have been previously initialized with **XGpio\_Initialize**().

#### **Returns:**

- XST\_SUCCESS If test passed
- o XST\_FAILURE If test failed

#### Note:

Assume that the device is in it's reset state which means that the TRI register is set to all inputs. We cannot twiddle bits in the data register since this may lead to a real disaster (i.e. whatever is hooked to those pins gets activated when you'd least expect).

Set the input/output direction of all discrete signals.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

*DirectionMask* is a bitmask specifying which discretes are input and which are output.

Bits set to 0 are output and bits set to 1 are input.

#### Note:

None

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# **XGpio Struct Reference**

#include <xgpio.h>

# **Detailed Description**

The XGpio driver instance data. The user is required to allocate a variable of this type for every GPIO device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• gpio/v1\_00\_a/src/xgpio.h

# gpio/v1\_00\_a/src/xgpio\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation. High-level driver functions are defined in **xgpio.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 04/24/02 First release
#include "xbasic_types.h"
#include "xio.h"
```

# Registers

Register offsets for this device. This device does not utilize IPIF registers.

```
#define XGPIO_DATA_OFFSET #define XGPIO_TRI_OFFSET
```

# **Defines**

#define **XGpio\_mWriteReg**(BaseAddress, RegOffset, Data)

#define XGpio\_mReadReg(BaseAddress, RegOffset)
#define XGpio\_mGetDataReg(BaseAddress)
#define XGpio\_mSetDataReg(BaseAddress, Data)

## **Define Documentation**

#### #define XGPIO\_DATA\_OFFSET

- XGPIO\_DATA\_OFFSET Data register
  - XGPIO\_TRI\_OFFSET Three state register (sets input/output direction) 0 configures pin for output and 1 for input.

#### #define XGpio\_mGetDataReg( BaseAddress )

Get the data register.

#### **Parameters:**

BaseAddress contains the base address of the GPIO device.

#### **Returns:**

The contents of the data register.

#### **Note:**

None.

# #define XGpio\_mReadReg( BaseAddress, RegOffset )

Read a value from a GPIO register. A 32 bit read is performed. If the GPIO component is implemented in a smaller width, only the least significant data is read from the register. The most significant data will be read as 0.

#### **Parameters:**

BaseAddress is the base address of the GPIO device.

*Register* is the register offset from the base to write to.

Data is the data written to the register.

#### **Returns:**

None.



#### #define XGPIO\_TRI\_OFFSET

- XGPIO\_DATA\_OFFSET Data register
  - XGPIO\_TRI\_OFFSET Three state register (sets input/output direction) 0 configures pin for output and 1 for input.

# gpio/v1\_00\_a/src/xgpio\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of GPIO devices in the system.

MODIFICATION HISTORY:

```
Ver Who Date Changes

----- 1.00a rmm 02/04/02 First release

#include "xgpio.h"

#include "xparameters.h"
```

### **Variables**

XGpio\_Config XGpio\_ConfigTable []

# **Variable Documentation**

### XGpio\_Config XGpio\_ConfigTable[]

This table contains configuration information for each GPIO device in the system.

# gpio/v1\_00\_a/src/xgpio\_extra.c File Reference

# **Detailed Description**

The implementation of the **XGpio** component's advanced discrete functions. See **xgpio.h** for more information about the component.

#### Note:

None

#include "xgpio.h"

# **Functions**

```
void XGpio_DiscreteSet (XGpio *InstancePtr, Xuint32 Mask) void XGpio_DiscreteClear (XGpio *InstancePtr, Xuint32 Mask)
```

# **Function Documentation**

Set output discrete(s) to logic 0.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

Mask

is the set of bits that will be set to 0 in the discrete data register. All other bits in the data register are unaffected.

#### **Note:**

None

Set output discrete(s) to logic 1.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

Mask

is the set of bits that will be set to 1 in the discrete data register. All other bits in the data register are unaffected.

#### Note:

None

# gpio/v1\_00\_a/src/xgpio.c File Reference

# **Detailed Description**

The implementation of the **XGpio** component's basic functionality. See **xgpio.h** for more information about the component.

#### Note:

None

```
#include "xparameters.h"
#include "xgpio.h"
#include "xgpio_i.h"
#include "xstatus.h"
```

## **Functions**

```
XStatus XGpio_Initialize (XGpio *InstancePtr, Xuint16 DeviceId)

XGpio_Config * XGpio_LookupConfig (Xuint16 DeviceId)

void XGpio_SetDataDirection (XGpio *InstancePtr, Xuint32 DirectionMask)

Xuint32 XGpio_DiscreteRead (XGpio *InstancePtr)

void XGpio_DiscreteWrite (XGpio *InstancePtr, Xuint32 Data)
```

## **Function Documentation**

#### Xuint32 XGpio\_DiscreteRead( XGpio \* InstancePtr)

Read state of discretes.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

#### **Returns:**

Current copy of the discretes register.

**Note:** 

None

Write to discretes register

#### **Parameters:**

InstancePtr is a pointer to an XGpio instance to be worked on.

Data is the value to be written to the discretes register.

#### Note:

See also XGpio\_DiscreteSet() and XGpio\_DiscreteClear().

Initialize the **XGpio** instance provided by the caller based on the given DeviceID.

Nothing is done except to initialize the InstancePtr.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance. The memory the pointer references must be pre-allocated by the caller. Further calls to manipulate the

component through the XGpio API must be made with this pointer.

*DeviceId* is the unique id of the device controlled by this **XGpio** component.

Passing in a device id associates the generic **XGpio** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS Initialization was successfull.
- XST\_DEVICE\_NOT\_FOUND Device configuration data was not found for a device with the supplied device ID.

#### **NOTES:**

None

### 

Lookup the device configuration based on the unique device ID. The table ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceID* is the device identifier to lookup.

#### **Returns:**

- XGpio configuration structure pointer if DeviceID is found.
- o XNULL if DeviceID is not found.

Set the input/output direction of all discrete signals.

#### **Parameters:**

*InstancePtr* is a pointer to an **XGpio** instance to be worked on.

DirectionMask is a bitmask specifying which discretes are input and which are

output. Bits set to 0 are output and bits set to 1 are input.

#### **Note:**

None

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# gpio/v1\_00\_a/src/xgpio\_selftest.c File Reference

# **Detailed Description**

The implementation of the **XGpio** component's self test function. See **xgpio.h** for more information about the component.

#### Note:

None

#include "xgpio.h"

# **Functions**

XStatus XGpio\_SelfTest (XGpio \*InstancePtr)

# **Function Documentation**

XStatus XGpio\_SelfTest( XGpio \* InstancePtr)

Run a self-test on the driver/device. This includes the following tests:

• Register reads.

#### ARGUMENTS:

#### **Parameters:**

*InstancePtr* is a pointer to the **XGpio** instance to be worked on. This parameter must have been previously initialized with **XGpio\_Initialize()**.

#### **Returns:**

- o XST\_SUCCESS If test passed
- o XST\_FAILURE If test failed

#### Note:

Assume that the device is in it's reset state which means that the TRI register is set to all inputs. We cannot twiddle bits in the data register since this may lead to a real disaster (i.e. whatever is hooked to those pins gets activated when you'd least expect).

# hdlc/v1\_00\_a/src/xhdlc\_stats.c File Reference

# **Detailed Description**

Contains functions to get and clear the **XHdlc** driver statistics.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a jhl 04/02/02 First release

#include "xbasic_types.h"
#include "xhdlc_i.h"
```

# **Functions**

```
void XHdlc_GetStats (XHdlc *InstancePtr, XHdlc_Stats *StatsPtr)
void XHdlc_ClearStats (XHdlc *InstancePtr)
```

# **Function Documentation**

```
void XHdlc_ClearStats( XHdlc * InstancePtr)
```

Clear the statistics for the specified HDLC driver instance.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

```
void XHdlc_GetStats( XHdlc * InstancePtr, XHdlc_Stats * StatsPtr )
```

Get a copy of the statistics structure, which contains the current statistics for this driver. The statistics are only cleared at initialization or on demand using the **XHdlc\_ClearStats()** function.

The FifoErrors counts indicate that the device has been or needs to be reset. Reset of the device is the responsibility of the caller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

StatsPtr is an output parameter, and is a pointer to a stats buffer into which the current statistics will be copied.

#### **Returns:**

None.

#### **Note:**

None.

# hdlc/v1\_00\_a/src/xhdlc\_options.c File Reference

## **Detailed Description**

Functions in this file allows options for the **XHdlc** driver.

MODIFICATION HISTORY:

## **Data Structures**

struct OptionMap

## **Functions**

```
XStatus XHdlc_SetOptions (XHdlc *InstancePtr, Xuint8 Options)
Xuint8 XHdlc_GetOptions (XHdlc *InstancePtr)
void XHdlc_SetAddress (XHdlc *InstancePtr, Xuint16 Address)
```

## **Function Documentation**

#### Xuint16 XHdlc\_GetAddress( XHdlc \* InstancePtr)

Get the receive address for this driver/device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

The receive address of the HDLC device.

#### Note:

None.

### Xuint8 XHdlc\_GetOptions( XHdlc \* InstancePtr)

Get HDLC driver/device options. A value is returned which is a bit-mask representing the options. A one (1) in the bit-mask means the option is on, and a zero (0) means the option is off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

The value of the HDLC options. The value is a bit-mask representing all options that are currently enabled. See **xhdlc.h** for a description of the available options.

#### Note:

Set the receive address for this driver/device. The address is a 8 or 16 bit value within a HDLC frame.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

Address is the address to be set.

#### **Returns:**

None.

#### **Note:**

None.

Set HDLC driver/device options. The device must be stopped before calling this function. The options are contained within a bit-mask with each bit representing an option (i.e., you can OR the options together). A one (1) in the bit-mask turns an option on, and a zero (0) turns the option off.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

Options is a bit-mask representing the HDLC options to turn on or off. See xhdlc.h for a description of the available options.

#### **Returns:**

- XST\_SUCCESS if the options were set successfully
- XST\_DEVICE\_IS\_STARTED if the device has not yet been stopped
- XST\_NO\_FEATURE if the polled option is being turned off and the device configuration information indicates DMA scatter gather is not supported. This driver does not support interrupt driven without DMA scatter-gather (FIFO only) yet.

#### Note:

This function is not thread-safe and makes use of internal resources that are shared between the Start, Stop, and SetOptions functions, so if one task might be setting device options while another is trying to start the device, protection of this shared data (typically using a semaphore) is required.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## hdlc/v1\_00\_a/src/xhdlc.c File Reference

## **Detailed Description**

Functions in this file are the minimum required functions for the HDLC driver. See **xhdlc.h** for a detailed description of the driver.

#### MODIFICATION HISTORY:

## **Functions**

```
XStatus XHdlc_Initialize (XHdlc *InstancePtr, Xuint16 DeviceId)

XStatus XHdlc_Start (XHdlc *InstancePtr)

XStatus XHdlc_Stop (XHdlc *InstancePtr)

void XHdlc_Reset (XHdlc *InstancePtr)

XStatus XHdlc_Send (XHdlc *InstancePtr, Xuint8 *FramePtr, unsigned ByteCount)

XStatus XHdlc_Recv (XHdlc *InstancePtr, Xuint8 *FramePtr, unsigned *ByteCountPtr, Xuint8

*FrameStatusPtr)

XHdlc_Config * XHdlc_LookupConfig (Xuint16 DeviceId)
```

## **Function Documentation**

Initialize a specific **XHdlc** instance/driver. The initialization entails:

- Initialize fields of the **XHdlc** structure
- Clear the HDLC statistics for this device
- Configure the FIFO components and DMA channels
- Reset the HDLC device

The driver defaults to polled mode operation. Interrupt mode can be selected using the SetOptions() function and turning off polled mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XHdlc** instance. Passing in a device id associates the generic **XHdlc** instance to a specific device, as chosen by the caller or

application developer.

#### **Returns:**

- XST SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.
- o XST\_NO\_FEATURE if the device configuration information indicates a feature that is not supported by this driver (no IPIF or simple DMA).

#### Note:

None.

#### 

Lookup the device configuration based on the unique device ID. The table XHdlc\_ConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID of the device being looked up.

#### **Returns:**

A pointer to the configuration table entry corresponding to the given device ID, or XNULL if no match is found.

#### Note:

Receive an HDLC frame in polled mode. The driver receives the frame directly from the devices packet FIFO. This is a non-blocking receive, in that if there is no frame ready to be received at the device, the function returns with an error. The buffer into which the frame will be received must be word-aligned.

The frames which are received by the device are stripped of the Opening Flag and Closing Flag fields such that buffers which receive data will not contain these fields. The frames do contain the FCS field. The Address field may or may not be contained in a receive buffer depending on the options set.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

FramePtr is a pointer to a 32 bit word aligned buffer into which the received HDLC frame will

be copied.

ByteCountPtr is both an input and output parameter. It is a pointer to a 32-bit word that contains the

number of bytes in the specified frame buffer on entry and the number of bytes in the

received frame on return from the function.

FrameStatusPtr is an output which is changed by the driver to contain the status of the frame. It

indicates any status that occurred for the received frame.

#### **Returns:**

- XST\_SUCCESS if the frame was received successfully
- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST NO DATA if there is no frame to be received from the FIFO
- XST\_BUFFER\_TOO\_SMALL if the specified receive buffer is smaller than the the received frame. The received frame is not retrieved from the receive FIFO such that a reset of the device is necessary to resynchronize the internal length and data FIFOs.
- XST\_FIFO\_ERROR if a non-recoverable FIFO error has occurred. A reset of the device is necessary to clear this error.

#### Note:

Receive buffer must also be 32-bit aligned. The user must ensure that the size of the receive buffer is large enough to hold the frames received.

void XHdlc\_Reset( XHdlc \* InstancePtr)

Reset the HDLC instance. This is a graceful reset in that the device is stopped first then it resets the FIFOs and DMA channels if present. Reset must only be called after the driver has been initialized. The reset does not remove any of the buffer descriptors from the scatter-gather list for DMA.

The configuration after this reset is as follows:

- Disabled transmitter and receiver
- Device interrupts are disabled
- Default packet threshold and packet wait bound register values for scatter-gather DMA operation

The upper layer software is responsible for re-configuring (if necessary) and restarting the HDLC device after the reset. Note also that driver statistics are not cleared on reset. It is up to the upper layer software to clear the statistics if needed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

Send an HDLC frame in polled mode. The driver writes the frame directly to the HDLC packet FIFO. Statistics are updated if an error previously occurred. The buffer to be sent must be word-aligned. This function is a non-blocking function in that it does not wait for the frame to be sent before returning.

The hardware device adds the Opening Flag, FCS, and Closing Flag fields to the frame such that these should not be put in the buffers which are to be sent.

The hardware device uses a length FIFO to keep track of each frame that has been put into the data FIFO. When sending a lot of short frames it is possible to fill this FIFO so that another frame cannot be sent until a frame has been sent by the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

FramePtr is a pointer to a 32 bit word aligned buffer containing the HDLC frame to be sent.

ByteCount is the size of the HDLC frame as an input. This size must be smaller than the size of the transmit FIFO of the device.

#### **Returns:**

o XST\_SUCCESS if the frame was sent successfully

- o XST\_DEVICE\_IS\_STOPPED if the device has not yet been started
- o XST\_FIFO\_NO\_ROOM if there is no room in the devices FIFOs for this frame.
- XST\_FIFO\_ERROR if the FIFO was overrun or underrun. This error is critical and requires the caller to reset the device.

#### Note:

None.

#### XStatus XHdlc\_Start( XHdlc \* InstancePtr)

Start the HDLC device and driver by enabling the transmitter and receiver. This function must be called before other functions to send or receive data. It supports either polled or DMA scatter gather interrupt driven modes of operation. It does not yet support interrupt driven with FIFOs (non-DMA) or simple DMA without scatter gather.

If the driver is configured for interrupt driven operation, the interrupts of the device are enabled. The user should have connected the interrupt handler of the driver to an interrupt source such as an interrupt controller or the processor interrupt prior to this function being called.

Prior to calling this function, the functions **XHdlc\_SetSgRecvSpace()** and **XHdlc\_SetSgSendSpace()** should be called to setup the memory buffers and descriptor lists for the DMA scatter-gather.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

- o XST SUCCESS if the device was started successfully
- o XST\_DEVICE\_IS\_STARTED if the device is already started
- XST\_NO\_CALLBACK if a callback function has not yet been registered using the SetxxxHandler function. This is required if in interrupt mode.
- XST\_DMA\_SG\_NO\_LIST if configured for scatter-gather DMA and a descriptor list has not yet been created for the send or receive channel.
- o XST\_DMA\_SG\_LIST\_EMPTY if configured for scatter-gather DMA and a descriptor list has been created for the receive channel but no buffers inserted into it.

#### Note:

This function makes use of internal resources that are shared between the Start, Stop, and SetOptions functions. So if one task might be setting device options while another is trying to start the device, the user is required to provide protection of this shared data (typically using a semaphore).

#### XStatus XHdlc\_Stop( XHdlc \* InstancePtr)

#### Stop the HDLC device as follows:

- If the device is configured with DMA, stop the DMA channels (wait for acknowledgment of stop)
- Disable the transmitter and receiver
- Disable interrupts if not in polled mode (the higher layer software is responsible for disabling interrupts at the interrupt controller)

If the device is configured for scatter-gather DMA, the DMA engine stops at the next buffer descriptor in its list. The remaining descriptors in the list are not removed, so anything in the list will be transmitted or received when the device is restarted. The side effect of doing this is that the last buffer descriptor processed by the DMA engine before stopping may not be the last descriptor in the HDLC frame. So when the device is restarted, a partial frame (i.e., a bad frame) may be transmitted/received. This is only a concern if a frame can span multiple buffer descriptors, which is dependent on the size of the network buffers.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the device was stopped successfully
- o XST\_DEVICE\_IS\_STOPPED if the device is already stopped

|   | - | - 4 |   |    |   |
|---|---|-----|---|----|---|
| N | • | м   | - | n  |   |
|   |   | ,   | ш | Г. | _ |

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# hdlc/v1\_00\_a/src/xhdlc\_dmasg.c File Reference

## **Detailed Description**

This file contains the HDLC DMA scatter gather processing. This file contains send and receive functions as well as interrupt service routines.

#### Note:

None.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

---- --- --- ---- ---- -----

1.00a JHL 06/03/02 First release

#include "xhdlc.h"

#include "xhdlc_i.h"

#include "xpacket_fifo_v1_00_b.h"

#include "xipif_v1_23_b.h"

#include "xio.h"
```

## **Functions**

```
XStatus XHdlc_SgSend (XHdlc *InstancePtr, XBufDescriptor *BdPtr)

XStatus XHdlc_SgRecv (XHdlc *InstancePtr, XBufDescriptor *BdPtr)

XStatus XHdlc_SgGetSendFrame (XHdlc *InstancePtr, XBufDescriptor **PtrToBdPtr, unsigned *BdCountPtr)
```

```
XStatus XHdlc_SgGetRecvFrame (XHdlc *InstancePtr, XBufDescriptor **PtrToBdPtr, unsigned *BdCountPtr)
void XHdlc_InterruptHandler (void *InstancePtr)

XStatus XHdlc_SetSgRecvSpace (XHdlc *InstancePtr, Xuint32 *MemoryPtr, unsigned ByteCount)

XStatus XHdlc_SetSgSendSpace (XHdlc *InstancePtr, Xuint32 *MemoryPtr, unsigned ByteCount)

void XHdlc_SetSgRecvHandler (XHdlc *InstancePtr, void *CallBackRef, XHdlc_SgHandler FuncPtr)

void XHdlc_SetSgSendHandler (XHdlc *InstancePtr, void *CallBackRef, XHdlc_SgHandler FuncPtr)

void XHdlc_SetErrorHandler (XHdlc *InstancePtr, void *CallBackRef, XHdlc_SgHandler FuncPtr)
```

## **Function Documentation**

### void XHdlc\_InterruptHandler( void \* InstancePtr)

Interrupt handler for the HDLC driver. It performs the following processing:

- Get the interrupt status from the IpIf to determine the source of the interrupt. The source can be: the HDLC device, the send packet FIFO, the receive packet FIFO, the send DMA channel, or the receive DMA channel. The packet FIFOs only interrupt during "deadlock" conditions. All other FIFO-related interrupts are generated by the HDLC device.
- Call the appropriate handler based on the source of the interrupt.

#### **Parameters:**

None.

*InstancePtr* contains a pointer to the HDLC device instance for the interrupt.

|          | • | 1 |
|----------|---|---|
| Returns: |   |   |
| None.    |   |   |
| Note:    |   |   |

Sets the callback function for handling errors. The upper layer software should call this function during initialization.

The error callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback which should be done at task-level.

The Xilinx errors that must be handled by the callback are:

- XST\_DMA\_ERROR indicates an unrecoverable DMA error occurred. This is typically a bus error or bus timeout. The handler must reset and re-configure the device.
- XST\_FIFO\_ERROR indicates an unrecoverable FIFO error occurred. This is a deadlock condition in the packet FIFO. The handler must reset and re-configure the device.
- XST\_RESET\_ERROR indicates an unrecoverable HDLC device error occurred, usually an overrun or underrun. The handler must reset and re-configure the device.
- XST\_ERROR\_COUNT\_MAX indicates the counters of the HDLC device have reached the maximum value and that the statistics of the HDLC device should be cleared.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback.

This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Sets the callback function for handling received frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of frames, determined by the DMA scatter-gather packet threshold, are received. The number of received frames is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each received frame from the list and should attach a new buffer to each descriptor. It is important that the specified number of frames passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are other potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback.

This helps the application correlate the callback to a particular driver.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

Gives the driver the memory space to be used for the scatter-gather DMA receive descriptor list. This function should only be called once, during initialization of the HDLC driver. The memory space must be word-aligned.

This function must be called prior to calling **XHdlc\_Start**().

#### **Parameters:**

InstancePtr is a pointer to the **XHdlc** instance to be worked on.

MemoryPtr is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the HDLC device is not configured for scatter-gather DMA
- XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XHdlc\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Sets the callback function for handling confirmation of transmitted frames in scatter-gather DMA mode. The upper layer software should call this function during initialization. The callback is called when a number of frames, determined by the DMA scatter-gather packet threshold, are sent. The number of sent frames is passed to the callback function. The callback function should communicate the data to a thread such that the scatter-gather list processing is not performed in an interrupt context.

The scatter-gather list processing of the thread context should call the function to get the buffer descriptors for each sent frame from the list and should also free the buffers attached to the descriptors if necessary. It is important that the specified number of frames passed to the callback function are handled by the scatter-gather list processing.

The callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

CallBackRef is a reference pointer to be passed back to the application in the callback.

This helps the application correlate the callback to a particular driver.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

None.

Gives the driver the memory space to be used for the scatter-gather DMA transmit descriptor list. This function should only be called once, during initialization of the HDLC driver. The memory space must be word-aligned.

This function must be called prior to calling **XHdlc\_Start**().

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*MemoryPtr* is a pointer to the word-aligned memory.

ByteCount is the length, in bytes, of the memory space.

#### **Returns:**

- XST\_SUCCESS if the space was initialized successfully
- o XST\_NOT\_SGDMA if the HDLC device is not configured for scatter-gather DMA
- XST\_DMA\_SG\_LIST\_EXISTS if the list space has already been created

#### Note:

If the device is configured for scatter-gather DMA, this function must be called AFTER the **XHdlc\_Initialize()** function because the DMA channel components must be initialized before the memory space is set.

Gets the first buffer descriptor of the oldest frame which was received by the scatter-gather DMA channel of the HDLC device. This function is provided to be called from a callback function such that the buffer descriptors for received frames can be processed. The function should be called by the application repetitively for the number of frames indicated as an argument in the callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

PtrToBdPtr is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the frame. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the frame. This input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the frame pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### Note:

```
XStatus XHdlc_SgGetSendFrame( XHdlc * InstancePtr, XBufDescriptor ** PtrToBdPtr, unsigned * BdCountPtr
```

Gets the first buffer descriptor of the oldest frame which was sent by the scatter-gather DMA channel of the HDLC device. This function is provided to be called from a callback function such that the buffer descriptors for sent frames can be processed. The function should be called by the application repetitively for the number of frames indicated as an argument in the callback function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

PtrToBdPtr is a pointer to a buffer descriptor pointer which will be modified to point to the first buffer descriptor of the frame. This input argument is also an output.

BdCountPtr is a pointer to a buffer descriptor count which will be modified to indicate the number of buffer descriptors for the frame. this input argument is also an output.

#### **Returns:**

A status is returned which contains one of values below. The pointer to a buffer descriptor pointed to by PtrToBdPtr and a count of the number of buffer descriptors for the frame pointed to by BdCountPtr are both modified if the return status indicates success. The status values are:

- o XST\_SUCCESS if a descriptor was successfully returned to the driver.
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode.
- o XST\_DMA\_SG\_NO\_LIST if the scatter gather list has not been created.
- XST\_DMA\_SG\_LIST\_EMPTY if no buffer descriptor was retrieved from the list because there are no buffer descriptors to be processed in the list.

#### Note:

Adds this descriptor, with an attached empty buffer, into the receive descriptor list. The buffer attached to the descriptor must be word-aligned. This is used by the upper layer software during initialization when first setting up the receive descriptors, and also during reception of frames to replace filled buffers with empty buffers. The contents of the specified buffer descriptor are copied into the scatter-gather transmit list. This function can be called when the device is started or stopped.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*BdPtr* is a pointer to the buffer descriptor that will be added to the descriptor list.

#### **Returns:**

- XST\_SUCCESS if a descriptor was successfully returned to the driver
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- XST\_DMA\_SG\_LIST\_FULL if the receive descriptor list is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point.
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit.

#### Note:

None.

Sends a HDLC frame using scatter-gather DMA. The caller attaches the frame to one or more buffer descriptors, then calls this function once for each descriptor. The caller is responsible for allocating and setting up the descriptor. An entire frame may or may not be contained within one descriptor. The contents of the buffer descriptor are copied into the scatter-gather transmit list. The caller is responsible for providing mutual exclusion to guarantee that a frame is contiguous in the transmit list. The buffer attached to the descriptor must be word-aligned.

The driver updates the descriptor with the DMA control register before being inserted into the transmit list. If this is the last descriptor in the frame, the inserts are committed, which means the descriptors for this frame are now available for transmission.

It is assumed that the upper layer software supplies a correctly formatted HDLC frame based upon the configuration of the HDLC device. The HDLC device must be started before calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XHdlc** instance to be worked on.

*BdPtr* is the address of a descriptor to be inserted into the transmit ring.

#### **Returns:**

- o XST\_SUCCESS if the buffer was successfully sent
- o XST\_DEVICE\_IS\_STOPPED if the HDLC device has not been started yet
- o XST\_NOT\_SGDMA if the device is not in scatter-gather DMA mode
- o XST\_DMA\_SG\_LIST\_FULL if the descriptor list for the DMA channel is full
- XST\_DMA\_SG\_BD\_LOCKED if the DMA channel cannot insert the descriptor into the list because a locked descriptor exists at the insert point
- XST\_DMA\_SG\_NOTHING\_TO\_COMMIT if even after inserting a descriptor into the list, the DMA channel believes there are no new descriptors to commit. If this is ever encountered, there is likely a thread mutual exclusion problem on transmit.

#### Note:

This function is not thread-safe. The user must provide mutually exclusive access to this function if there are to be multiple threads that can call it.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# hdlc/v1\_00\_a/src/xhdlc\_l.c File Reference

## **Detailed Description**

This file contains low-level polled functions to send and receive HDLC frames.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a jhl 05/20/02 First release
#include "xhdlc_1.h"
#include "xio.h"
```

## **Functions**

```
void XHdlc_SendFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, unsigned ByteCount) unsigned XHdlc_RecvFrame (Xuint32 BaseAddress, Xuint8 *FramePtr, Xuint32 *FrameStatusPtr)
```

## **Function Documentation**

```
unsigned XHdlc_RecvFrame( Xuint32 BaseAddress,
Xuint8 * FramePtr,
Xuint32 * FrameStatusPtr
)
```

Receive a frame. Wait for a frame to arrive.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to a 32 bit word-aligned buffer where the frame will be

stored.

FrameStatusPtr is a pointer to a frame status that will be valid after this function returns.

#### **Returns:**

The size, in bytes, of the frame received.

#### Note:

None.

```
void XHdlc_SendFrame( Xuint32 BaseAddress,
Xuint8 * FramePtr,
unsigned ByteCount
)
```

Send a HDLC frame. This size is the total frame size, including header. This function blocks waiting for the frame to be transmitted.

#### **Parameters:**

BaseAddress is the base address of the device

FramePtr is a pointer to 32 bit word-aligned frame

ByteCount is the number of bytes in the frame

#### **Returns:**

None.

#### Note:

## Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

## iic/v1\_01\_c/src/xiic.h File Reference

## **Detailed Description**

XIic is the driver for an IIC master or slave device.

In order to reduce the memory requirements of the driver it is partitioned such that there are optional parts of the driver. Slave, master, and multimaster features are optional such that these files are not required. In order to use the slave and multimaster features of the driver, the user must call functions (XIic\_SlaveInclude and XIic\_MultiMasterInclude) to dynamically include the code . These functions may be called at any time.

#### **Bus Throttling**

The IIC hardware provides bus throttling which allows either the device, as either a master or a slave, to stop the clock on the IIC bus. This feature allows the software to perform the appropriate processing for each interrupt without an unreasonable response restriction. With this design, it is important for the user to understand the implications of bus throttling.

#### **Repeated Start**

An application can send multiple messages, as a master, to a slave device and re-acquire the IIC bus each time a message is sent. The repeated start option allows the application to send multiple messages without re-acquiring the IIC bus for each message. This feature also could cause the application to lock up, or monopolize the IIC bus, should repeated start option be enabled and sequences of messages never end (periodic data collection). Also when repeated start is not disable before the last master message is sent or received, will leave the bus captive to the master, but unused.

#### Addressing

The IIC hardware is parameterized such that it can be built for 7 or 10 bit addresses. The driver provides the ability to control which address size is sent in messages as a master to a slave device. The address size which the hardware responds to as a slave is parameterized as 7 or 10 bits but fixed by the hardware build.

Addresses are represented as hex values with no adjustment for the data direction bit as the software manages address bit placement. This is especially important as the bit placement is not handled the same depending on which options are used such as repeated start and 7 vs 10 bit addressing.

#### **Data Rates**

The IIC hardware is parameterized such that it can be built to support data rates from DC to 400KBit. The frequency of the interrupts which occur is proportional to the data rate.

#### **Polled Mode Operation**

This driver does not provide a polled mode of operation primarily because polled mode which is non-blocking is difficult with the amount of interaction with the hardware that is necessary.

#### **Interrupts**

The device has many interrupts which allow IIC data transactions as well as bus status processing to occur.

The interrupts are divided into two types, data and status. Data interrupts indicate data has been received or transmitted while the status interrupts indicate the status of the IIC bus. Some of the interrupts, such as Not Addressed As Slave and Bus Not Busy, are only used when these specific events must be recognized as opposed to being enabled at all times.

Many of the interrupts are not a single event in that they are continuously present such that they must be disabled after recognition or when undesired. Some of these interrupts, which are data related, may be acknowledged by the software by reading or writing data to the appropriate register, or must be disabled. The following interrupts can be continuous rather than single events.

- Data Transmit Register Empty/Transmit FIFO Empty
- Data Receive Register Full/Receive FIFO
- Transmit FIFO Half Empty
- Bus Not Busy
- Addressed As Slave
- Not Addressed As Slave

The following interrupts are not passed directly to the application thru the status callback. These are only used internally for the driver processing and may result in the receive and send handlers being called to indicate completion of an operation. The following interrupts are data related rather than status.

- Data Transmit Register Empty/Transmit FIFO Empty
- Data Receive Register Full/Receive FIFO
- Transmit FIFO Half Empty
- Slave Transmit Complete

#### **Interrupt To Event Mapping**

The following table provides a mapping of the interrupts to the events which are passed to the status handler and the intended role (master or slave) for the event. Some interrupts can cause multiple events which are combined together into a single status event such as XII\_MASTER\_WRITE\_EVENT and XII\_GENERAL\_CALL\_EVENT

| Interrupt                  | Event(s)                | Role   |
|----------------------------|-------------------------|--------|
| Arbitration Lost Interrupt | XII_ARB_LOST_EVENT      | Master |
| Transmit Error             | XII_SLAVE_NO_ACK_EVENT  | Master |
| IIC Bus Not Busy           | XII_BUS_NOT_BUSY_EVENT  | Master |
| Addressed As Slave         | XII_MASTER_READ_EVENT,  | Slave  |
|                            | XII_MASTER_WRITE_EVENT, | Slave  |
|                            | XII_GENERAL_CALL_EVENT  | Slave  |

#### **Not Addressed As Slave Interrupt**

The Not Addressed As Slave interrupt is not passed directly to the application thru the status callback. It is used to determine the end of a message being received by a slave when there was no stop condition (repeated start). It will cause the receive handler to be called to indicate completion of the operation.

#### **RTOS Independence**

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes |
|-------|-----|----------|---------|
|       |     |          |         |
| 1.01a | rfp | 10/19/01 | release |
| 1.01c | ecm | 12/05/02 | new rev |

```
#include "xbasic_types.h"
#include "xstatus.h"
#include "xipif_v1_23_b.h"
#include "xiic_1.h"
```

### **Data Structures**

```
struct XIic struct XIic_Config struct XIicStats
```

## **Configuration options**

The following options may be specified or retrieved for the device and enable/disable additional features of the IIC bus. Each of the options are bit fields such that more than one may be specified.

```
#define XII_GENERAL_CALL_OPTION
#define XII_REPEATED_START_OPTION
#define XII_SEND_10_BIT_OPTION
```

#### Status events

The following status events occur during IIC bus processing and are passed to the status callback. Each event is only valid during the appropriate processing of the IIC bus. Each of these events are bit fields such that more than one may be specified.

```
#define XII_BUS_NOT_BUSY_EVENT
#define XII_ARB_LOST_EVENT
#define XII_SLAVE_NO_ACK_EVENT
#define XII_MASTER_READ_EVENT
#define XII_MASTER_WRITE_EVENT
#define XII_GENERAL_CALL_EVENT
```

## **Defines**

```
#define XII_ADDR_TO_SEND_TYPE
#define XII_ADDR_TO_RESPOND_TYPE
```

## **Typedefs**

```
typedef void(* XIic_Handler )(void *CallBackRef, int ByteCount)
typedef void(* XIic_StatusHandler )(void *CallBackRef, XStatus StatusEvent)
```

## **Functions**

```
XStatus XIic_Start (XIic *InstancePtr)
     XStatus XIic_Stop (XIic *InstancePtr)
         void XIic_Reset (XIic *InstancePtr)
      XStatus XIic_SetAddress (XIic *InstancePtr, int AddressType, int Address)
     Xuint16 XIic_GetAddress (XIic *InstancePtr, int AddressType)
XIic_Config * XIic_LookupConfig (Xuint16 DeviceId)
         void XIic_InterruptHandler (void *InstancePtr)
         void XIic SetRecvHandler (XIic *InstancePtr, void *CallBackRef, XIic Handler FuncPtr)
         void XIic_SetSendHandler (XIic *InstancePtr, void *CallBackRef, XIic_Handler FuncPtr)
         void XIic_SetStatusHandler (XIic *InstancePtr, void *CallBackRef, XIic_StatusHandler FuncPtr)
      XStatus XIic_MasterRecv (XIic *InstancePtr, Xuint8 *RxMsgPtr, int ByteCount)
     XStatus XIic MasterSend (XIic *InstancePtr, Xuint8 *TxMsgPtr, int ByteCount)
         void XIic_GetStats (XIic *InstancePtr, XIicStats *StatsPtr)
         void XIic_ClearStats (XIic *InstancePtr)
     XStatus XIic_SelfTest (XIic *InstancePtr)
         void XIic_SetOptions (XIic *InstancePtr, Xuint32 Options)
     Xuint32 XIic_GetOptions (XIic *InstancePtr)
         void XIic MultiMasterInclude (void)
```

## **Define Documentation**

#### #define XII\_ADDR\_TO\_RESPOND\_TYPE

this device's bus address when slave

#### #define XII\_ADDR\_TO\_SEND\_TYPE

bus address of slave device

#### #define XII\_ARB\_LOST\_EVENT

| XII_BUS_NOT_BUSY_EVENT | bus transitioned to not busy               |
|------------------------|--------------------------------------------|
| XII_ARB_LOST_EVENT     | arbitration was lost                       |
| XII_SLAVE_NO_ACK_EVENT | slave did not acknowledge data (had error) |
| XII_MASTER_READ_EVENT  | master reading from slave                  |
| XII_MASTER_WRITE_EVENT | master writing to slave                    |
| XII_GENERAL_CALL_EVENT | general call to all slaves                 |
|                        |                                            |

#### #define XII\_BUS\_NOT\_BUSY\_EVENT

| XII_BUS_NOT_BUSY_EVENT | bus transitioned to not busy               |
|------------------------|--------------------------------------------|
| XII_ARB_LOST_EVENT     | arbitration was lost                       |
| XII_SLAVE_NO_ACK_EVENT | slave did not acknowledge data (had error) |
| XII_MASTER_READ_EVENT  | master reading from slave                  |
| XII_MASTER_WRITE_EVENT | master writing to slave                    |
| XII_GENERAL_CALL_EVENT | general call to all slaves                 |

#### #define XII\_GENERAL\_CALL\_EVENT

XII\_BUS\_NOT\_BUSY\_EVENT bus transitioned to not busy

XII\_ARB\_LOST\_EVENT

XII\_SLAVE\_NO\_ACK\_EVENT

XII\_MASTER\_READ\_EVENT XII MASTER WRITE EVENT

XII\_GENERAL\_CALL\_EVENT

arbitration was lost

slave did not acknowledge data (had error)

master reading from slave master writing to slave general call to all slaves

#### #define XII\_GENERAL\_CALL\_OPTION

XII\_GENERAL\_CALL\_OPTION

The general call option allows an IIC slave to recognized the general call address. The status handler is called as usual indicating the device has been addressed as a slave with a general call. It is the application's responsibility to perform any special processing for the general call.

XII\_REPEATED\_START\_OPTION

The repeated start option allows multiple messages to be sent/received on the IIC bus without rearbitrating for the bus. The messages are sent as a series of messages such that the option must be enabled before the 1st message of the series, to prevent an stop condition from being generated on the bus, and disabled before the last message of the series, to allow the stop condition to be generated.

XII\_SEND\_10\_BIT\_OPTION

The send 10 bit option allows 10 bit addresses to be sent on the bus when the device is a master. The device can be configured to respond as to 7 bit addresses even though it may be communicating with other devices that support 10 bit addresses. When this option is not enabled, only 7 bit addresses are sent on the bus.

#### #define XII\_MASTER\_READ\_EVENT

XII BUS NOT BUSY EVENT XII\_ARB\_LOST\_EVENT

XII\_SLAVE\_NO\_ACK\_EVENT

XII\_MASTER\_READ\_EVENT XII MASTER WRITE EVENT

XII GENERAL CALL EVENT

bus transitioned to not busy

arbitration was lost

slave did not acknowledge data (had error)

master reading from slave master writing to slave general call to all slaves

#### #define XII\_MASTER\_WRITE\_EVENT

XII\_BUS\_NOT\_BUSY\_EVENT XII\_ARB\_LOST\_EVENT XII\_SLAVE\_NO\_ACK\_EVENT XII\_MASTER\_READ\_EVENT XII\_MASTER\_WRITE\_EVENT

XII GENERAL CALL EVENT

bus transitioned to not busy arbitration was lost slave did not acknowledge data (had error) master reading from slave master writing to slave general call to all slaves

#### #define XII\_REPEATED\_START\_OPTION

XII\_GENERAL\_CALL\_OPTION

The general call option allows an IIC slave to recognized the general call address. The status handler is called as usual indicating the device has been addressed as a slave with a general call. It is the application's responsibility to perform any special processing for the general call.

XII\_REPEATED\_START\_OPTION

The repeated start option allows multiple messages to be sent/received on the IIC bus without rearbitrating for the bus. The messages are sent as a series of messages such that the option must be enabled before the 1st message of the series, to prevent an stop condition from being generated on the bus, and disabled before the last message of the series, to allow the stop condition to be generated.

XII\_SEND\_10\_BIT\_OPTION

The send 10 bit option allows 10 bit addresses to be sent on the bus when the device is a master. The device can be configured to respond as to 7 bit addresses even though it may be communicating with other devices that support 10 bit addresses. When this option is not enabled, only 7 bit addresses are sent on the bus.

#### #define XII\_SEND\_10\_BIT\_OPTION

XII GENERAL CALL OPTION

The general call option allows an IIC slave to recognized the general call address. The status handler is called as usual indicating the device has been addressed as a slave with a general call. It is the application's responsibility to perform any special processing for the general call.

XII\_REPEATED\_START\_OPTION

The repeated start option allows multiple messages to be sent/received on the IIC bus without rearbitrating for the bus. The messages are sent as a series of messages such that the option must be enabled before the 1st message of the series, to prevent an stop condition from being generated on the bus, and disabled before the last message of the series, to allow the stop condition to be generated.

XII\_SEND\_10\_BIT\_OPTION

The send 10 bit option allows 10 bit addresses to be sent on the bus when the device is a master. The device can be configured to respond as to 7 bit addresses even though it may be communicating with other devices that support 10 bit addresses. When this option is not enabled, only 7 bit addresses are sent on the bus.

#### #define XII\_SLAVE\_NO\_ACK\_EVENT

XII\_BUS\_NOT\_BUSY\_EVENT bus transitioned to not busy
XII\_ARB\_LOST\_EVENT arbitration was lost
XII\_SLAVE\_NO\_ACK\_EVENT slave did not acknowledge data (had error)
XII\_MASTER\_READ\_EVENT master reading from slave
XII\_MASTER\_WRITE\_EVENT master writing to slave
XII\_GENERAL\_CALL\_EVENT general call to all slaves

## **Typedef Documentation**

#### typedef void(\* XIic\_Handler)(void \*CallBackRef, int ByteCount)

This callback function data type is defined to handle the asynchronous processing of sent and received data of the IIC driver. The application using this driver is expected to define a handler of this type to support interrupt driven mode. The handlers are called in an interrupt context such that minimal processing should be performed. The handler data type is utilized for both send and receive handlers.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked. Its type is unimportant to the driver component, so it is a void pointer.

ByteCount indicates the number of bytes remaining to be sent or received. A value of zero indicates that the requested number of bytes were sent or received.

#### typedef void(\* XIic StatusHandler)(void \*CallBackRef, XStatus StatusEvent)

This callback function data type is defined to handle the asynchronous processing of status events of the IIC driver. The application using this driver is expected to define a handler of this type to support interrupt driven mode. The handler is called in an interrupt context such that minimal processing should be performed.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked. Its type is unimportant to the driver component, so it is a void pointer.

StatusEvent indicates one or more status events that occurred. See the definition of the status events above.

## **Function Documentation**

#### void XIic\_ClearStats( XIic \* InstancePtr)

Clears the statistics for the IIC device by zeroing all counts.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

```
Xuint16 XIic_GetAddress( XIic * InstancePtr,
int AddressType
)
```

This function gets the addresses for the IIC device driver. The addresses include the device address that the device responds to as a slave, or the slave address to communicate with on the bus. The address returned has the same format whether 7 or 10 bits.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

AddressType indicates which address, the address which this responds to on the IIC bus as a slave, or the slave address to communicate with when this device is a master. One of the following values must be contained in this argument.

```
XII_ADDRESS_TO_SEND_TYPE slave being addressed as a master 
XII_ADDRESS_TO_RESPOND_TYPE slave address to respond to as a slave
```

If neither of the two valid arguments are used, the function returns the address of the slave device

#### **Returns:**

The address retrieved.

#### **Note:**

None.

#### Xuint32 XIic\_GetOptions( XIic \* InstancePtr)

This function gets the current options for the IIC device. Options control the how the device behaves on the IIC bus. See SetOptions for more information on options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIIc** instance to be worked on.

#### **Returns:**

The options of the IIC device. See xiic.h for a list of available options.

#### Note:

Options enabled will have a 1 in its appropriate bit position.

Gets a copy of the statistics for an IIC device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIIc** instance to be worked on.

StatsPtr is a pointer to a **XIicStats** structure which will get a copy of current statistics.

#### **Returns:**

None.

Note:

None.

Initializes a specific **XIic** instance. The initialization entails:

- Check the device has an entry in the configuration table.
- Initialize the driver to allow access to the device registers and initialize other subcomponents necessary for the operation of the device.
- Default options to:
  - o 7-bit slave addressing
  - Send messages as a slave device
  - Repeated start off
  - o General call recognition disabled
- Clear messageing and error statistics

The XIic\_Start() function must be called after this function before the device is ready to send and receive data on the IIC bus.

Before **XIic\_Start**() is called, the interrupt control must connect the ISR routine to the interrupt handler. This is done by the user, and not **XIic\_Start**() to allow the user to use an interrupt controller of their choice.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XIic** instance. Passing in a device id associates the generic **XIic** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS when successful
- o XST\_DEVICE\_IS\_STARTED indicates the device is started (i.e. interrupts enabled and messaging is possible). Must stop before re-initialization is allowed.

#### Note:

This function is the interrupt handler for the XIic driver. This function should be connected to the interrupt system.

Only one interrupt source is handled for each interrupt allowing higher priority system interrupts quicker response time.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

None.

#### 

Looks up the device configuration based on the unique device ID. The table IicConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID to look for

#### **Returns:**

A pointer to the configuration data of the device, or XNULL if no match is found.

#### Note:

None.

This function receives data as a master from a slave device on the IIC bus. If the bus is busy, it will indicate so and then enable an interrupt such that the status handler will be called when the bus is no longer busy. The slave address which has been set with the XIic\_SetAddress() function is the address from which data is received. Receiving data on the bus performs a read operation.

#### **Parameters:**

*InstancePtr* is a pointer to the Iic instance to be worked on.

RxMsgPtr is a pointer to the data to be transmitted ByteCount is the number of message bytes to be sent

#### **Returns:**

- o XST\_SUCCESS indicates the message reception processes has been initiated.
- XST\_IIC\_BUS\_BUSY indicates the bus was in use and that the BusNotBusy interrupt is enabled which will update
  the EventStatus when the bus is no longer busy.
- XST\_IIC\_GENERAL\_CALL\_ADDRESS indicates the slave address is set to the general call address. This is not allowed for Master receive mode.

This function sends data as a master on the IIC bus. If the bus is busy, it will indicate so and then enable an interrupt such that the status handler will be called when the bus is no longer busy. The slave address which has been set with the XIic\_SetAddress() function is the address to which the specific data is sent. Sending data on the bus performs a write operation.

#### **Parameters:**

*InstancePtr* points to the Iic instance to be worked on.

TxMsgPtr points to the data to be transmitted

ByteCount is the number of message bytes to be sent

#### **Returns:**

- o XST\_SUCCESS indicates the message transmission has been initiated.
- XST\_IIC\_BUS\_BUSY indicates the bus was in use and that the BusNotBusy interrupt is enabled which will update
  the EventStatus when the bus is no longer busy.

#### Note:

None

#### void XIic MultiMasterInclude( void )

This function includes multi-master code such that multi-master events are handled properly. Multi-master events include a loss of arbitration and the bus transitioning from busy to not busy. This function allows the multi-master processing to be optional. This function must be called prior to allowing any multi-master events to occur, such as after the driver is initialized.

#### Note:

None

#### void XIic\_Reset( XIic \* InstancePtr)

Resets the IIC device. Reset must only be called after the driver has been initialized. The configuration after this reset is as follows:

- Repeated start is disabled
- · General call is disabled

The upper layer software is responsible for initializing and re-configuring (if necessary) and restarting the IIC device after the reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

#### XStatus XIic\_SelfTest( XIic \* InstancePtr)

Runs a limited self-test on the driver/device. The self-test is destructive in that a reset of the device is performed in order to check the reset values of the registers and to get the device into a known state. There is no loopback capabilities for the device such that this test does not send or receive data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

| XST_SUCCESS                     | No errors found                                        |
|---------------------------------|--------------------------------------------------------|
| XST_IIC_STAND_REG_ERROR         | One or more IIC regular registers did                  |
|                                 | not zero on reset or read back                         |
|                                 | correctly based on what was written                    |
|                                 | to it                                                  |
| XST_IIC_TX_FIFO_REG_ERROR       | One or more IIC parametrizable TX                      |
|                                 | FIFO registers did not zero on reset                   |
|                                 | or read back correctly based on what                   |
|                                 | was written to it                                      |
| XST_IIC_RX_FIFO_REG_ERROR       | One or more IIC parametrizable RX                      |
|                                 | FIFO registers did not zero on reset                   |
|                                 | or read back correctly based on what was written to it |
| VOM TIG COMMO DEG DEGEO EDDOD   |                                                        |
| XST_IIC_STAND_REG_RESET_ERROR   | A non parameterizable reg value after reset not valid  |
| XST IIC TX FIFO REG RESET ERROR | Tx fifo, included in design, value                     |
| NOT_TIC_IN_TITO_NEO_NEOET_ENNON | after reset not valid                                  |
| XST IIC RX FIFO REG RESET ERROR | Rx fifo, included in design, value                     |
|                                 | after reset not valid                                  |
| XST_IIC_TBA_REG_RESET_ERROR     | 10 bit addr, incl in design, value                     |
|                                 | after reset not valid                                  |
| XST_IIC_CR_READBACK_ERROR       | Read of the control register didn't                    |
|                                 | return value written                                   |
| XST_IIC_DTR_READBACK_ERROR      | Read of the data Tx reg didn't return                  |
|                                 | value written                                          |
| XST_IIC_DRR_READBACK_ERROR      | Read of the data Receive reg didn't                    |
|                                 | return value written                                   |
| XST_IIC_ADR_READBACK_ERROR      | Read of the data Tx reg didn't return                  |
|                                 | value written                                          |
| XST_IIC_TBA_READBACK_ERROR      | Read of the 10 bit addr reg didn't                     |
|                                 | return written value                                   |

#### Note:

Only the registers that have be included into the hardware design are tested, such as, 10-bit vs 7-bit addressing.

```
XStatus XIic_SetAddress( XIic * InstancePtr,
int AddressType,
int Address
)
```

This function sets the bus addresses. The addresses include the device address that the device responds to as a slave, or the slave address to communicate with on the bus. The IIC device hardware is built to allow either 7 or 10 bit slave addressing only at build time rather than at run time. When this device is a master, slave addressing can be selected at run time to match addressing modes for other bus devices.

Addresses are represented as hex values with no adjustment for the data direction bit as the software manages address bit placement. Example: For a 7 address written to the device of 1010 011X where X is the transfer direction (send/recv), the address parameter for this function needs to be 01010011 or 0x53 where the correct bit alllignment will be handled for 7 as well as 10 bit devices. This is especially important as the bit placement is not handled the same depending on which options are used such as repeated start.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

AddressType indicates which address is being modified; the address which this device responds to on the IIC bus as a slave, or the slave address to communicate with when this device is a master. One of the following values must be contained in this argument.

```
XII_ADDRESS_TO_SEND Slave being addressed by a this master XII_ADDRESS_TO_RESPOND Address to respond to as a slave device
```

Address

contains the address to be set; 7 bit or 10 bit address. A ten bit address must be within the range: 0 - 1023 and a 7 bit address must be within the range 0 - 127.

#### **Returns:**

XST\_SUCCESS is returned if the address was successfully set, otherwise one of the following errors is returned.

- o XST\_IIC\_NO\_10\_BIT\_ADDRESSING indicates only 7 bit addressing supported.
- o XST\_INVALID\_PARAM indicates an invalid parameter was specified.

#### Note:

Upper bits of 10-bit address is written only when current device is built as a ten bit device.

```
void XIic_SetOptions( XIic * InstancePtr, Xuint32 NewOptions )
```

This function sets the options for the IIC device driver. The options control how the device behaves relative to the IIC bus. If an option applies to how messages are sent or received on the IIC bus, it must be set prior to calling functions which send or receive data.

To set multiple options, the values must be ORed together. To not change existing options, read/modify/write with the current options using **XIic\_GetOptions**().

#### **USAGE EXAMPLE:**

Read/modify/write to enable repeated start:

```
Xuint8 Options;
Options = XIic_GetOptions(&Iic);
XIic_SetOptions(&Iic, Options | XII_REPEATED_START_OPTION);
```

#### Disabling General Call:

```
Options = XIic_GetOptions(&Iic);
XIic_SetOptions(&Iic, Options &= ~XII_GENERAL_CALL_OPTION);
```

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

*NewOptions* are the options to be set. See xiic.h for a list of the available options.

#### **Returns:**

None.

#### Note:

Sending or receiving messages with repeated start enabled, and then disabling repeated start, will not take effect until another master transaction is completed. i.e. After using repeated start, the bus will continue to be throttled after repeated start is disabled until a master transaction occurs allowing the IIC to release the bus.

Options enabled will have a 1 in its appropriate bit position.

```
void XIic_SetRecvHandler( XIic * InstancePtr,
void * CallBackRef,
XIic_Handler FuncPtr
)
```

Sets the receive callback function, the receive handler, which the driver calls when it finishes receiving data. The number of bytes used to signal when the receive is complete is the number of bytes set in the XIic\_Recv function.

The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context.

The number of bytes received is passed to the handler as an argument.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

Sets the send callback function, the send handler, which the driver calls when it receives confirmation of sent data. The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context.

#### **Parameters:**

*InstancePtr* the pointer to the **XIIc** instance to be worked on.

CallBackRef the upper layer callback reference passed back when the callback function is invoked.

FuncPtr the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

```
void XIic_SetStatusHandler( XIic * InstancePtr,
void * CallBackRef,
XIic_StatusHandler FuncPtr
)
```

Sets the status callback function, the status handler, which the driver calls when it encounters conditions which are not data related. The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context. The status events that can be returned are described in xiic.h.

#### **Parameters:**

*InstancePtr* points to the XIIc instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

#### XStatus XIic\_Start( XIic \* InstancePtr)

This function starts the IIC device and driver by enabling the proper interrupts such that data may be sent and received on the IIC bus. This function must be called before the functions to send and receive data.

Before **XIic\_Start**() is called, the interrupt control must connect the ISR routine to the interrupt handler. This is done by the user, and not **XIic\_Start**() to allow the user to use an interrupt controller of their choice.

#### Start enables:

- IIC device
- Interrupts:
  - Addressed as slave to allow messages from another master
  - o Arbitration Lost to detect Tx arbitration errors
  - o Global IIC interrupt within the IPIF interface

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

XST\_SUCCESS always

#### Note:

The device interrupt is connected to the interrupt controller, but no "messaging" interrupts are enabled. Addressed as Slave is enabled to reception of messages when this devices address is written to the bus. The correct messaging interrupts are enabled when sending or receiving via the IicSend() and IicRecv() functions. No action is required by the user to control any IIC interrupts as the driver completely manages all 8 interrupts. Start and Stop control the ability to use the device. Stopping the device completely stops all device interrupts from the processor.

#### XStatus XIic\_Stop( XIic \* InstancePtr)

This function stops the IIC device and driver such that data is no longer sent or received on the IIC bus. This function stops the device by disabling interrupts. This function only disables interrupts within the device such that the caller is responsible for disconnecting the interrupt handler of the device from the interrupt source and disabling interrupts at other levels.

Due to bus throttling that could hold the bus between messages when using repeated start option, stop will not occur when the device is actively sending or receiving data from the IIC bus or the bus is being throttled by this device, but instead return XST\_IIC\_BUS\_BUSY.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIIc** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS indicates all IIC interrupts are disabled. No messages can be received or transmitted until XIic\_Start() is called.
- XST\_IIC\_BUS\_BUSY indicates this device is currently engaged in message traffic and cannot be stopped.

#### Note:

None.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XIic Struct Reference

#include <xiic.h>

# **Detailed Description**

The XIic driver instance data. The user is required to allocate a variable of this type for every IIC device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• iic/v1\_01\_c/src/xiic.h

# iic/v1\_01\_c/src/xiic\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xiic.h**.

#### MODIFICATION HISTORY:

```
#include "xbasic_types.h"
```

# **Functions**

```
unsigned XIic_Recv (Xuint32 BaseAddress, Xuint8 Address, Xuint8 *BufferPtr, unsigned ByteCount)
unsigned XIic_Send (Xuint32 BaseAddress, Xuint8 Address, Xuint8 *BufferPtr, unsigned ByteCount)
```

# **Function Documentation**

```
unsigned XIic_Recv( Xuint32 BaseAddress,
Xuint8 Address,
Xuint8 BufferPtr,
unsigned ByteCount
```

Receive data as a master on the IIC bus. This function receives the data using polled I/O and blocks until the data has been received. It only supports 7 bit addressing and non-repeated start modes of operation. The user is responsible for ensuring the bus is not busy if multiple masters are present on the bus.

#### **Parameters:**

BaseAddress contains the base address of the IIC device.

Address contains the 7 bit IIC address of the device to send the specified data to.

BufferPtr points to the data to be sent.

ByteCount is the number of bytes to be sent.

#### **Returns:**

The number of bytes received.

#### Note:

None

```
unsigned XIic_Send( Xuint32 BaseAddress,

Xuint8 Address,

Xuint8 BufferPtr,

unsigned ByteCount
```

Send data as a master on the IIC bus. This function sends the data using polled I/O and blocks until the data has been sent. It only supports 7 bit addressing and non-repeated start modes of operation. The user is responsible for ensuring the bus is not busy if multiple masters are present on the bus.

#### **Parameters:**

BaseAddress contains the base address of the IIC device.

Address contains the 7 bit IIC address of the device to send the specified data to.

BufferPtr points to the data to be sent.

ByteCount is the number of bytes to be sent.

#### **Returns:**

The number of bytes sent.

| Notes | None |  |  |  |
|-------|------|--|--|--|
|       |      |  |  |  |

# Xilinx Device Drivers Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# XIic\_Config Struct Reference

#include <xiic.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xboolean Has10BitAddr

# **Field Documentation**

Xuint32 XIic\_Config::BaseAddress

Device base address

Xuint16 XIic\_Config::DeviceId

Unique ID of device

Xboolean XIic\_Config::Has10BitAddr

does device have 10 bit address decoding

The documentation for this struct was generated from the following file:

• iic/v1\_01\_c/src/xiic.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# XIicStats Struct Reference

#include <xiic.h>

# **Detailed Description**

**XIic** statistics

# **Data Fields**

**Xuint8 ArbitrationLost** 

**Xuint8 RepeatedStarts** 

**Xuint8 BusBusy** 

**Xuint8 RecvBytes** 

**Xuint8 RecvInterrupts** 

**Xuint8 SendBytes** 

**Xuint8 SendInterrupts** 

**Xuint8 TxErrors** 

**Xuint8 IicInterrupts** 

# **Field Documentation**

Xuint8 XIicStats::ArbitrationLost

Number of times arbitration was lost

### **Xuint8** XIicStats::BusBusy

Number of times bus busy status returned

### **Xuint8** XIicStats::IicInterrupts

Number of IIC (device) interrupts

### **Xuint8** XIicStats::RecvBytes

Number of bytes received

### **Xuint8** XIicStats::RecvInterrupts

Number of receive interrupts

### **Xuint8 XIicStats::RepeatedStarts**

Number of repeated starts

### **Xuint8** XIicStats::SendBytes

Number of transmit bytes received

### **Xuint8** XIicStats::SendInterrupts

Number of transmit interrupts

### **Xuint8 XIicStats::TxErrors**

Number of transmit errors (no ack)

The documentation for this struct was generated from the following file:

• iic/v1\_01\_c/src/xiic.h

# iic/v1\_01\_c/src/xiic\_stats.c File Reference

# **Detailed Description**

Contains statistics functions for the XIIc component.

MODIFICATION HISTORY:

# **Functions**

```
void XIic_GetStats (XIic *InstancePtr, XIicStats *StatsPtr)
void XIic_ClearStats (XIic *InstancePtr)
```

# **Function Documentation**



Generated on 30 Sep 2003 for Xilinx Device Drivers

None.

# iic/v1\_01\_c/src/xiic\_i.h File Reference

# **Detailed Description**

This header file contains internal identifiers, which are those shared between **XIic** components. The identifiers in this file are not intended for use external to the driver.

#### MODIFICATION HISTORY:

## **Variables**

XIic\_Config XIic\_ConfigTable []

# **Variable Documentation**

```
XIic_Config XIic_ConfigTable[]()
```

The IIC configuration table, sized by the number of instances defined in **xparameters.h**.

# iic/v1\_01\_c/src/xiic\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of IIC devices in the system. Each IIC device should have an entry in this table.

#### MODIFICATION HISTORY:

# **Variables**

XIic\_Config XIic\_ConfigTable [XPAR\_XIIC\_NUM\_INSTANCES]

# **Variable Documentation**

### XIic\_Config XIic\_ConfigTable[XPAR\_XIIC\_NUM\_INSTANCES]

The IIC configuration table, sized by the number of instances defined in **xparameters.h**.

# iic/v1\_01\_c/src/xiic.c File Reference

### **Detailed Description**

Contains required functions for the XIic component. See xiic.h for more information on the driver.

MODIFICATION HISTORY:

### **Functions**

```
XStatus XIic_Initialize (XIic *InstancePtr, Xuint16 DeviceId)

XStatus XIic_Start (XIic *InstancePtr)

XStatus XIic_Stop (XIic *InstancePtr)

void XIic_Reset (XIic *InstancePtr)

XStatus XIic_SetAddress (XIic *InstancePtr, int AddressType, int Address)

Xuint16 XIic_GetAddress (XIic *InstancePtr, int AddressType)

Xboolean XIic_IsSlave (XIic *InstancePtr)

void XIic_SetRecvHandler (XIic *InstancePtr, void *CallBackRef, XIic_Handler FuncPtr)

void XIic_SetSendHandler (XIic *InstancePtr, void *CallBackRef, XIic_Handler FuncPtr)

void XIic_SetStatusHandler (XIic *InstancePtr, void *CallBackRef, XIic_StatusHandler FuncPtr)

XIic_Config * XIic_LookupConfig (Xuint16 DeviceId)
```

### **Function Documentation**

```
Xuint16 XIic_GetAddress( XIic * InstancePtr, int AddressType )
```

This function gets the addresses for the IIC device driver. The addresses include the device address that the device responds to as a slave, or the slave address to communicate with on the bus. The address returned has the same format whether 7 or 10 bits.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

AddressType indicates which address, the address which this responds to on the IIC bus as a slave, or the slave address to communicate with when this device is a master. One of the following values must be contained in this argument.

```
XII_ADDRESS_TO_SEND_TYPE slave being addressed as a master
XII_ADDRESS_TO_RESPOND_TYPE slave address to respond to as a slave
```

If neither of the two valid arguments are used, the function returns the address of the slave device

#### **Returns:**

The address retrieved.

Note:

None.

Initializes a specific **XIic** instance. The initialization entails:

- Check the device has an entry in the configuration table.
- Initialize the driver to allow access to the device registers and initialize other subcomponents necessary for the operation of the device.
- Default options to:
  - o 7-bit slave addressing
  - o Send messages as a slave device
  - o Repeated start off
  - o General call recognition disabled
- Clear messageing and error statistics

The XIic\_Start() function must be called after this function before the device is ready to send and receive data on the IIC bus.

Before **XIic\_Start**() is called, the interrupt control must connect the ISR routine to the interrupt handler. This is done by the user, and not **XIic\_Start**() to allow the user to use an interrupt controller of their choice.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

DeviceId is the unique id of the device controlled by this XIic instance. Passing in a device id associates the generic XIic instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST SUCCESS when successful
- XST\_DEVICE\_IS\_STARTED indicates the device is started (i.e. interrupts enabled and messaging is possible). Must stop before re-initialization is allowed.

#### Note:

None.

#### Xboolean XIic\_IsSlave( XIic \* InstancePtr)

A function to determine if the device is currently addressed as a slave

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

XTRUE if the device is addressed as slave, and XFALSE otherwise.

Note:

None.

#### 

Looks up the device configuration based on the unique device ID. The table IicConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID to look for

#### **Returns:**

A pointer to the configuration data of the device, or XNULL if no match is found.

Note:

None.

#### void XIic\_Reset( XIic \* InstancePtr)

Resets the IIC device. Reset must only be called after the driver has been initialized. The configuration after this reset is as follows:

- Repeated start is disabled
- General call is disabled

The upper layer software is responsible for initializing and re-configuring (if necessary) and restarting the IIC device after the reset.

#### **Parameters:**

*InstancePtr* is a pointer to the XIIc instance to be worked on.

#### **Returns:**

None.

Note:

None.

This function sets the bus addresses. The addresses include the device address that the device responds to as a slave, or the slave address to communicate with on the bus. The IIC device hardware is built to allow either 7 or 10 bit slave addressing only at build time rather than at run time. When this device is a master, slave addressing can be selected at run time to match addressing modes for other bus devices.

Addresses are represented as hex values with no adjustment for the data direction bit as the software manages address bit placement. Example: For a 7 address written to the device of 1010 011X where X is the transfer direction (send/recv), the address parameter for this function needs to be 01010011 or 0x53 where the correct bit alllignment will be handled for 7 as well as 10 bit devices. This is especially important as the bit placement is not handled the same depending on which options are used such as repeated start.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

AddressType indicates which address is being modified; the address which this device responds to on the IIC bus as a slave, or the slave address to communicate with when this device is a master. One of the following values must be contained in this argument.

Address

contains the address to be set; 7 bit or 10 bit address. A ten bit address must be within the range: 0 - 1023 and a 7 bit address must be within the range 0 - 127.

#### **Returns:**

XST\_SUCCESS is returned if the address was successfully set, otherwise one of the following errors is returned.

- o XST\_IIC\_NO\_10\_BIT\_ADDRESSING indicates only 7 bit addressing supported.
- o XST\_INVALID\_PARAM indicates an invalid parameter was specified.

#### Note:

Upper bits of 10-bit address is written only when current device is built as a ten bit device.

Sets the receive callback function, the receive handler, which the driver calls when it finishes receiving data. The number of bytes used to signal when the receive is complete is the number of bytes set in the XIic\_Recv function.

The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context.

The number of bytes received is passed to the handler as an argument.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

Sets the send callback function, the send handler, which the driver calls when it receives confirmation of sent data. The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context.

#### **Parameters:**

*InstancePtr* the pointer to the **XIic** instance to be worked on.

CallBackRef the upper layer callback reference passed back when the callback function is invoked.

FuncPtr the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

```
void XIic_SetStatusHandler( XIic * InstancePtr, void * CallBackRef, XIic_StatusHandler FuncPtr
)
```

Sets the status callback function, the status handler, which the driver calls when it encounters conditions which are not data related. The handler executes in an interrupt context such that it must minimize the amount of processing performed such as transferring data to a thread context. The status events that can be returned are described in xiic.h.

#### **Parameters:**

*InstancePtr* points to the XIIc instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context ...

#### XStatus XIic\_Start( XIic \* InstancePtr)

This function starts the IIC device and driver by enabling the proper interrupts such that data may be sent and received on the IIC bus. This function must be called before the functions to send and receive data.

Before **XIic\_Start**() is called, the interrupt control must connect the ISR routine to the interrupt handler. This is done by the user, and not **XIic\_Start**() to allow the user to use an interrupt controller of their choice.

#### Start enables:

- IIC device
- Interrupts:
  - o Addressed as slave to allow messages from another master
  - Arbitration Lost to detect Tx arbitration errors

o Global IIC interrupt within the IPIF interface

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

XST\_SUCCESS always

#### Note:

The device interrupt is connected to the interrupt controller, but no "messaging" interrupts are enabled. Addressed as Slave is enabled to reception of messages when this devices address is written to the bus. The correct messaging interrupts are enabled when sending or receiving via the IicSend() and IicRecv() functions. No action is required by the user to control any IIC interrupts as the driver completely manages all 8 interrupts. Start and Stop control the ability to use the device. Stopping the device completely stops all device interrupts from the processor.

#### XStatus XIic\_Stop( XIic \* InstancePtr)

This function stops the IIC device and driver such that data is no longer sent or received on the IIC bus. This function stops the device by disabling interrupts. This function only disables interrupts within the device such that the caller is responsible for disconnecting the interrupt handler of the device from the interrupt source and disabling interrupts at other levels.

Due to bus throttling that could hold the bus between messages when using repeated start option, stop will not occur when the device is actively sending or receiving data from the IIC bus or the bus is being throttled by this device, but instead return XST\_IIC\_BUS\_BUSY.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS indicates all IIC interrupts are disabled. No messages can be received or transmitted until XIic\_Start() is called.
- XST IIC BUS BUSY indicates this device is currently engaged in message traffic and cannot be stopped.

#### Note:

None.

# iic/v1\_01\_c/src/xiic\_options.c File Reference

# **Detailed Description**

Contains options functions for the **XIic** component. This file is not required unless the functions in this file are called.

#### MODIFICATION HISTORY:

# **Functions**

```
void XIic_SetOptions (XIic *InstancePtr, Xuint32 NewOptions)
Xuint32 XIic_GetOptions (XIic *InstancePtr)
```

# **Function Documentation**

### Xuint32 XIic\_GetOptions( XIic \* InstancePtr)

This function gets the current options for the IIC device. Options control the how the device behaves on the IIC bus. See SetOptions for more information on options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIIc** instance to be worked on.

#### **Returns:**

The options of the IIC device. See xiic.h for a list of available options.

#### Note:

Options enabled will have a 1 in its appropriate bit position.

This function sets the options for the IIC device driver. The options control how the device behaves relative to the IIC bus. If an option applies to how messages are sent or received on the IIC bus, it must be set prior to calling functions which send or receive data.

To set multiple options, the values must be ORed together. To not change existing options, read/modify/write with the current options using **XIic\_GetOptions**().

#### **USAGE EXAMPLE:**

Read/modify/write to enable repeated start:

```
Xuint8 Options;
Options = XIic_GetOptions(&Iic);
XIic_SetOptions(&Iic, Options | XII_REPEATED_START_OPTION);
```

### Disabling General Call:

```
Options = XIic_GetOptions(&Iic);
XIic_SetOptions(&Iic, Options &= ~XII_GENERAL_CALL_OPTION);
```

#### **Parameters:**

InstancePtr is a pointer to the XIic instance to be worked on.NewOptions are the options to be set. See xiic.h for a list of the available options.

#### **Returns:**

None.

### **Note:**

Sending or receiving messages with repeated start enabled, and then disabling repeated start, will not take effect until another master transaction is completed. i.e. After using repeated start, the bus will continue to be throttled after repeated start is disabled until a master transaction occurs allowing the IIC to release the bus.

Options enabled will have a 1 in its appropriate bit position.

# iic/v1\_01\_c/src/xiic\_intr.c File Reference

# **Detailed Description**

Contains interrupt functions of the **XIic** driver. This file is required for the driver.

MODIFICATION HISTORY:

```
Ver Who Date Changes
---- --- --- ---- -----
1.01a rfp 10/19/01 release
1.01c ecm 12/05/02 new rev
1.01c rmm 05/14/03 Fixed diab compiler warnings relating to asserts.
#include "xiic.h"
#include "xiic_i.h"
#include "xiio.h"
```

## **Functions**

void XIic\_InterruptHandler (void \*InstancePtr)

# **Function Documentation**

void XIic\_InterruptHandler( void \* InstancePtr)

This function is the interrupt handler for the **XIic** driver. This function should be connected to the interrupt system.

Only one interrupt source is handled for each interrupt allowing higher priority system interrupts quicker response time.

### **Parameters:**

*InstancePtr* is a pointer to the **XIic** instance to be worked on.

### **Returns:**

None.

# iic/v1\_01\_c/src/xiic\_master.c File Reference

# **Detailed Description**

Contains master functions for the **XIic** component. This file is necessary to send or receive as a master on the IIC bus.

```
MODIFICATION HISTORY:
```

# **Functions**

```
XStatus XIic_MasterSend (XIic *InstancePtr, Xuint8 *TxMsgPtr, int ByteCount)
XStatus XIic_MasterRecv (XIic *InstancePtr, Xuint8 *RxMsgPtr, int ByteCount)
```

# **Function Documentation**

This function receives data as a master from a slave device on the IIC bus. If the bus is busy, it will indicate so and then enable an interrupt such that the status handler will be called when the bus is no longer busy. The slave address which has been set with the **XIic\_SetAddress**() function is the address from which data is received. Receiving data on the bus performs a read operation.

#### **Parameters:**

*InstancePtr* is a pointer to the Iic instance to be worked on. *RxMsgPtr* is a pointer to the data to be transmitted

ByteCount is the number of message bytes to be sent

#### **Returns:**

- o XST\_SUCCESS indicates the message reception processes has been initiated.
- XST\_IIC\_BUS\_BUSY indicates the bus was in use and that the BusNotBusy interrupt is enabled which will update the EventStatus when the bus is no longer busy.
- o XST\_IIC\_GENERAL\_CALL\_ADDRESS indicates the slave address is set to the the general call address. This is not allowed for Master receive mode.

This function sends data as a master on the IIC bus. If the bus is busy, it will indicate so and then enable an interrupt such that the status handler will be called when the bus is no longer busy. The slave address which has been set with the **XIic\_SetAddress**() function is the address to which the specific data is sent. Sending data on the bus performs a write operation.

#### **Parameters:**

InstancePtr points to the Iic instance to be worked on. TxMsgPtr points to the data to be transmitted

ByteCount is the number of message bytes to be sent

#### **Returns:**

o XST\_SUCCESS indicates the message transmission has been initiated.

| Note: |      |  |  |  |  |
|-------|------|--|--|--|--|
|       | None |  |  |  |  |
|       |      |  |  |  |  |
|       |      |  |  |  |  |

busy.

o XST\_IIC\_BUS\_BUSY indicates the bus was in use and that the BusNotBusy

interrupt is enabled which will update the EventStatus when the bus is no longer

# iic/v1\_01\_c/src/xiic\_multi\_master.c File Reference

# **Detailed Description**

Contains multi-master functions for the **XIic** component. This file is necessary if multiple masters are on the IIC bus such that arbitration can be lost or the bus can be busy.

```
MODIFICATION HISTORY:
```

# **Functions**

void XIic\_MultiMasterInclude ()

# **Function Documentation**

void XIic\_MultiMasterInclude( void )

| This function includes multi-master code such that multi-master events are handled properly.        |
|-----------------------------------------------------------------------------------------------------|
| Multi-master events include a loss of arbitration and the bus transitioning from busy to not        |
| busy. This function allows the multi-master processing to be optional. This function must be        |
| called prior to allowing any multi-master events to occur, such as after the driver is initialized. |

| T A |    | 4  |   |
|-----|----|----|---|
|     | n  | tΔ |   |
| Τ.  | ₩, | u  | • |

None

# iic/v1\_01\_c/src/xiic\_l.c File Reference

# **Detailed Description**

This file contains low-level driver functions that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation.

#### MODIFICATION HISTORY:

```
Ver
       Who Date
                     Changes
 1.01b jhl 5/13/02 First release
 1.01b jhl 10/14/02 Corrected bug in the receive function, the setup of the
                                                  interrupt status mask was not being
done in the loop such
                                                  that a read would sometimes fail on
the last byte because
                                                  the transmit error which should have
been ignored was
                                                 being used. This would leave an
extra byte in the FIFO
                                                  and the bus throttled such that the
next operation would
                                                  also fail. Also updated the receive
function to not
                                                 disable the device after the last
byte until after the
                                                 bus transitions to not busy which is
more consistent
                                                 with the expected behavior.
 1.01c ecm 12/05/02 new rev
#include "xbasic_types.h"
#include "xio.h"
#include "xipif_v1_23_b.h"
```

### **Functions**

#include "xiic\_l.h"

unsigned XIic\_Recv (Xuint32 BaseAddress, Xuint8 Address, Xuint8 \*BufferPtr, unsigned ByteCount) unsigned XIic\_Send (Xuint32 BaseAddress, Xuint8 Address, Xuint8 \*BufferPtr, unsigned ByteCount)

### **Function Documentation**

```
unsigned XIic_Recv( Xuint32 BaseAddress,
Xuint8 Address,
Xuint8 * BufferPtr,
unsigned ByteCount
)
```

Receive data as a master on the IIC bus. This function receives the data using polled I/O and blocks until the data has been received. It only supports 7 bit addressing and non-repeated start modes of operation. The user is responsible for ensuring the bus is not busy if multiple masters are present on the bus.

#### **Parameters:**

BaseAddress contains the base address of the IIC device.

Address contains the 7 bit IIC address of the device to send the specified data to.

BufferPtr points to the data to be sent.ByteCount is the number of bytes to be sent.

#### **Returns:**

The number of bytes received.

#### **Note:**

None

```
unsigned XIic_Send( Xuint32 BaseAddress, Xuint8 Address, Xuint8 * BufferPtr, unsigned ByteCount )
```

Send data as a master on the IIC bus. This function sends the data using polled I/O and blocks until the data has been sent. It only supports 7 bit addressing and non-repeated start modes of operation. The user is responsible for ensuring the bus is not busy if multiple masters are present on the bus.

#### **Parameters:**

BaseAddress contains the base address of the IIC device.

Address contains the 7 bit IIC address of the device to send the specified data to.

BufferPtr points to the data to be sent.ByteCount is the number of bytes to be sent.

#### **Returns:**

The number of bytes sent.

#### Note:

None

# iic/v1\_01\_c/src/xiic\_selftest.c File Reference

# **Detailed Description**

Contains selftest functions for the XIic component.

MODIFICATION HISTORY:

```
Ver Who Date Changes

1.01b jhl 3/26/02 repartioned the driver

1.01c ecm 12/05/02 new rev

#include "xiic.h"

#include "xiic_i.h"

#include "xiio.h"
```

### **Functions**

XStatus XIic SelfTest (XIic \*InstancePtr)

### **Function Documentation**

```
XStatus XIic SelfTest( XIic * InstancePtr)
```

Runs a limited self-test on the driver/device. The self-test is destructive in that a reset of the device is performed in order to check the reset values of the registers and to get the device into a known state. There is no loopback capabilities for the device such that this test does not send or receive data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XIIc** instance to be worked on.

#### **Returns:**

```
XST_SUCCESS
XST_IIC_STAND_REG_ERROR
```

No errors found One or more IIC regular registers did not zero on reset or read back correctly based on what was written to it

| XST_IIC_TX_FIFO_REG_ERROR       | One or more IIC parametrizable TX FIFO registers did not zero on reset or read back correctly based on what was written to it |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| XST_IIC_RX_FIFO_REG_ERROR       | One or more IIC parametrizable RX FIFO registers did not zero on reset or read back correctly based on what was written to it |
| XST_IIC_STAND_REG_RESET_ERROR   | A non parameterizable reg value after reset not valid                                                                         |
| XST_IIC_TX_FIFO_REG_RESET_ERROR | Tx fifo, included in design, value after reset not valid                                                                      |
| XST_IIC_RX_FIFO_REG_RESET_ERROR | Rx fifo, included in design, value after reset not valid                                                                      |
| XST_IIC_TBA_REG_RESET_ERROR     | 10 bit addr, incl in design, value after reset not valid                                                                      |
| XST_IIC_CR_READBACK_ERROR       | Read of the control register didn't return value written                                                                      |
| XST_IIC_DTR_READBACK_ERROR      | Read of the data Tx reg didn't return value written                                                                           |
| XST_IIC_DRR_READBACK_ERROR      | Read of the data Receive reg didn't return value written                                                                      |
| XST_IIC_ADR_READBACK_ERROR      | Read of the data Tx reg didn't return value written                                                                           |
| XST_IIC_TBA_READBACK_ERROR      | Read of the 10 bit addr reg didn't return written value                                                                       |

### Note:

Only the registers that have be included into the hardware design are tested, such as, 10-bit vs 7-bit addressing.

# intc/v1\_00\_b/src/xintc.h File Reference

# **Detailed Description**

The Xilinx interrupt controller driver component. This component supports the Xilinx interrupt controller. A more detailed description of the API for the component can be found in the **xintc.c** file.

The interrupt controller driver uses the idea of priority for the various handlers. Priority is an integer within the range of 0 and 31 inclusive with 0 being the highest priority interrupt source.

The Xilinx interrupt controller supports the following features:

- specific individual interrupt enabling/disabling
- specific individual interrupt acknowledging
- attaching specific callback function to handle interrupt source
- master enable/disable
- single callback per interrupt or all pending interrupts handled for each interrupt of the processor

The acknowledgement of the interrupt within the interrupt controller is selectable, either prior to the device's handler being called or after the handler is called. This is necessary to support interrupt signal inputs which are either edge or level signals. Edge driven interrupt signals require that the interrupt is acknowledged prior to the interrupt being serviced in order to prevent the loss of interrupts which are occurring extremely close together. A level driven interrupt input signal requires the interrupt to acknowledged after servicing the interrupt to ensure that the interrupt only generates a single interrupt condition.

Details about connecting the interrupt handler of the driver are contained in the source file specific to interrupt processing, **xintc\_intr.c**.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

| Ver   | Who | Date     | Changes                                                          |
|-------|-----|----------|------------------------------------------------------------------|
|       |     |          |                                                                  |
| 1.00a | ecm | 08/16/01 | First release                                                    |
| 1.00a | rpm | 01/09/02 | Removed the AckLocation argument from ${\tt XIntc\_Connect}()$ . |
|       |     |          | This information is now internal in <pre>xintc_g.c.</pre>        |
| 1.00b | jhl | 02/13/02 | Repartitioned the driver for smaller files                       |

1.00b jhl 04/24/02 Made LookupConfig function global and relocated config data type

```
#include "xbasic_types.h"
#include "xparameters.h"
#include "xstatus.h"
#include "xintc_l.h"
```

### **Data Structures**

```
struct XIntc struct XIntc_Config
```

# **Configuration options**

These options are used in **XIntc\_SetOptions**() to configure the device.

```
#define XIN_SVC_SGL_ISR_OPTION
#define XIN_SVC_ALL_ISRS_OPTION
```

### Start modes

One of these values is passed to **XIntc\_Start()** to start the device.

```
#define XIN_SIMULATION_MODE #define XIN_REAL_MODE
```

### **Functions**

```
XStatus XIntc_Initialize (XIntc *InstancePtr, Xuint16 DeviceId)

XStatus XIntc_Start (XIntc *InstancePtr, Xuint8 Mode)

void XIntc_Stop (XIntc *InstancePtr)

XStatus XIntc_Connect (XIntc *InstancePtr, Xuint8 Id, XInterruptHandler Handler, void

*CallBackRef)

void XIntc_Disconnect (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Enable (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Disable (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Acknowledge (XIntc *InstancePtr, Xuint8 Id)

XIntc_Config * XIntc_LookupConfig (Xuint16 DeviceId)
```

```
void XIntc_VoidInterruptHandler ()
void XIntc_InterruptHandler (XIntc *InstancePtr)
XStatus XIntc_SetOptions (XIntc *InstancePtr, Xuint32 Options)
Xuint32 XIntc_GetOptions (XIntc *InstancePtr)
XStatus XIntc_SelfTest (XIntc *InstancePtr)
XStatus XIntc_SimulateIntr (XIntc *InstancePtr, Xuint8 Id)
```

# **Define Documentation**

# #define XIN\_REAL\_MODE

Real mode, no simulation allowed, hardware interrupts recognized

# #define XIN\_SIMULATION\_MODE

Simulation only mode, no hardware interrupts recognized

# #define XIN\_SVC\_ALL\_ISRS\_OPTION

| XIN_SVC_SGL_ISR_OPTION  | Service the highest priority pending interrupt |
|-------------------------|------------------------------------------------|
|                         | and then return.                               |
| XIN_SVC_ALL_ISRS_OPTION | Service all of the pending interrupts and then |
|                         | return.                                        |

# #define XIN\_SVC\_SGL\_ISR\_OPTION

| XIN_SVC_SGL_ISR_OPTION  | Service the highest priority pending interrupt |
|-------------------------|------------------------------------------------|
|                         | and then return.                               |
| XIN_SVC_ALL_ISRS_OPTION | Service all of the pending interrupts and then |
|                         | return.                                        |

# **Function Documentation**

```
void XIntc_Acknowledge( XIntc * InstancePtr, Xuint8 Id
```

Acknowledges the interrupt source provided as the argument Id. When the interrupt is acknowledged, it causes the interrupt controller to clear its interrupt condition.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id contains the ID of the interrupt source and should be in the range of 0 to

XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

## **Returns:**

None.

#### Note:

None.

Makes the connection between the Id of the interrupt source and the associated handler that is to run when the interrupt is recognized. The argument provided in this call as the Callbackref is used as the argument for the handler when it is called.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

*Id* contains the ID of the interrupt source and should be in the range of 0 to

XPAR INTC MAX NUM INTR INPUTS - 1 with 0 being the highest priority interrupt.

*Handler* to the handler for that interrupt.

CallBackRef is the callback reference, usually the instance pointer of the connecting driver.

# **Returns:**

- o XST\_SUCCESS if the handler was connected correctly.
- o XST\_INTC\_CONNECT\_ERROR if the handler is already in use. Must disconnect existing handler assignment prior to calling connect again.

### Note:

```
void XIntc_Disable( XIntc * InstancePtr, Xuint8 Id
```

Disables the interrupt source provided as the argument Id such that the interrupt controller will not cause interrupts for the specified Id. The interrupt controller will continue to hold an interrupt condition for the Id, but will not cause an interrupt.

## **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id

contains the ID of the interrupt source and should be in the range of 0 to XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

# **Returns:**

None.

# Note:

None.

```
void XIntc_Disconnect( XIntc * InstancePtr, Xuint8 Id
```

Updates the interrupt table with the Null Handler and XNULL arguments at the location pointed at by the Id. This effectively disconnects that interrupt source from any handler. The interrupt is disabled also.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id

contains the ID of the interrupt source and should be in the range of 0 to XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

## **Returns:**

None.

# **Note:**

```
void XIntc_Enable( XIntc * InstancePtr, Xuint8 Id )
```

Enables the interrupt source provided as the argument Id. Any pending interrupt condition for the specified Id will occur after this function is called.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id

contains the ID of the interrupt source and should be in the range of 0 to

XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

#### **Returns:**

None.

# **Note:**

None.

# Xuint32 XIntc\_GetOptions( XIntc \* InstancePtr)

Return the currently set options.

## **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

### **Returns:**

The currently set options. The options are described in **xintc.h**.

## **Note:**

None.

```
XStatus XIntc_Initialize( XIntc * InstancePtr, Xuint16 DeviceId )
```

Initialize a specific interrupt controller instance/driver. The initialization entails:

- Initialize fields of the **XIntc** structure
- Initial vector table with stub function calls
- All interrupt sources are disabled
- Interrupt output is disabled

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

DeviceId

is the unique id of the device controlled by this **XIntc** instance. Passing in a device id associates the generic **XIntc** instance to a specific device, as chosen by the caller or application developer.

## **Returns:**

XST\_SUCCESS if initialization was successful
 XST\_DEVICE\_IS\_STARTED if the device has already been started
 XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

# void XIntc\_InterruptHandler( XIntc \* InstancePtr)

The interrupt handler for the driver. This function determines the pending interrupts and calls the appropriate handlers in the priority based order.

This specific function allows multiple interrupt controller instances to be handled. The user must connect this function to the interrupt system such that it is called whenever the devices which are connected to it cause an interrupt.

## **Parameters:**

Note:

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

# Returns: None.

**Note:** 

None.

# XIntc\_Config\* XIntc\_LookupConfig( Xuint16 DeviceId)

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

### **Parameters:**

DeviceId is the unique identifier for a device.

### **Returns:**

A pointer to the **XIntc** configuration structure for the specified device, or XNULL if the device was not found.

## Note:

None.

## XStatus XIntc SelfTest( XIntc \* InstancePtr)

Run a self-test on the driver/device. This is a destructive test.

This involves forcing interrupts into the controller and verifying that they are recognized and can be acknowledged. This test will not succeed if the interrupt controller has been started in real mode such that interrupts cannot be forced.

## **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

### **Returns:**

- o XST\_SUCCESS if self-test is successful.
- o XST\_INTC\_FAIL\_SELFTEST if the Interrupt controller fails the self-test. It will fail the self test if the device has previously been started in real mode.

## **Note:**

None.

Set the options for the interrupt controller driver.

### **Parameters:**

InstancePtr is a pointer to the **XIntc** instance to be worked on.

Options to be set. The available options are described in **xintc.h**.

## **Returns:**

- o XST\_SUCCESS if the options were set successfully
- o XST\_INVALID\_PARAM if the specified option was not valid

# Note:

Allows software to simulate an interrupt in the interrupt controller. This function will only be successful when the interrupt controller has been started in simulation mode. Once it has been started in real mode, interrupts cannot be simulated. A simulated interrupt allows the interrupt controller to be tested without any device to drive an interrupt input signal into it.

## **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

*Id* is the interrupt ID for which to simulate an interrupt.

## **Returns:**

XST\_SUCCESS if successful, or XST\_FAILURE if the interrupt could not be simulated because the interrupt controller is or has previously been in real mode.

## Note:

None.

```
XStatus XIntc_Start( XIntc * InstancePtr,
Xuint8 Mode
)
```

Starts the interrupt controller by enabling the output from the controller to the processor. Interrupts may be generated by the interrupt controller after this function is called.

It is necessary for the caller to connect the interrupt handler of this component to the proper interrupt source.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Mode

determines if software is allowed to simulate interrupts or real interrupts are allowed to occur. Note that these modes are mutually exclusive. The interrupt controller hardware resets in a mode that allows software to simulate interrupts until this mode is exited. It cannot be reentered once it has been exited. One of the following values should be used for the mode.

- XIN\_SIMULATION\_MODE enables simulation of interrupts only
- XIN\_REAL\_MODE enables hardware interrupts only

### **Returns:**

- XST\_SUCCESS if the device was started successfully
- XST\_FAILURE if simulation mode was specified and it could not be set because real mode has already been entered.

### Note:

Must be called after **XIntc** initialization is completed.

| Stops the interrupt controller by disabling the output from the controller so that no interrupts will be caused by the interrupt controller.                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters:                                                                                                                                                                                                                                          |
| <i>InstancePtr</i> is a pointer to the <b>XIntc</b> instance to be worked on.                                                                                                                                                                        |
| Returns:                                                                                                                                                                                                                                             |
| None.                                                                                                                                                                                                                                                |
| Note:                                                                                                                                                                                                                                                |
| None.                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                      |
| void XIntc_VoidInterruptHandler( )                                                                                                                                                                                                                   |
| Interrupt handler for the driver. This function determines the pending interrupts and calls the appropriate handlers in the priority based order.                                                                                                    |
| This specific function does not support multiple interrupt controller instances to be handled. The user must connect this function to the interrupt system such that it is called whenever the devices which are connected to it cause an interrupt. |
| Returns:                                                                                                                                                                                                                                             |
| None.                                                                                                                                                                                                                                                |
| Note:                                                                                                                                                                                                                                                |
| None.                                                                                                                                                                                                                                                |
| Generated on 30 Sep 2003 for Xilinx Device Drivers                                                                                                                                                                                                   |

void XIntc\_Stop( XIntc \* InstancePtr)

# intc/v1\_00\_b/src/xintc.c File Reference

# **Detailed Description**

Contains required functions for the **XIntc** driver for the Xilinx Interrupt Controller. See **xintc.h** for a detailed description of the driver.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 08/16/01 First release
1.00b jhl 02/21/02 Repartitioned the driver for smaller files
1.00b jhl 04/24/02 Made LookupConfig global and compressed ack before table in the configuration into a bit mask
```

```
#include "xbasic_types.h"
#include "xintc.h"
#include "xintc_l.h"
#include "xintc_i.h"
```

# **Functions**

```
XStatus XIntc_Initialize (XIntc *InstancePtr, Xuint16 DeviceId)

XStatus XIntc_Start (XIntc *InstancePtr, Xuint8 Mode)

void XIntc_Stop (XIntc *InstancePtr)

XStatus XIntc_Connect (XIntc *InstancePtr, Xuint8 Id, XInterruptHandler Handler, void

*CallBackRef)

void XIntc_Disconnect (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Enable (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Disable (XIntc *InstancePtr, Xuint8 Id)

void XIntc_Acknowledge (XIntc *InstancePtr, Xuint8 Id)

XIntc_Config * XIntc_LookupConfig (Xuint16 DeviceId)
```

# **Function Documentation**

```
void XIntc_Acknowledge( XIntc * InstancePtr, Xuint8 Id
```

Acknowledges the interrupt source provided as the argument Id. When the interrupt is acknowledged, it causes the interrupt controller to clear its interrupt condition.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

*Id* contains the ID of the interrupt source and should be in the range of 0 to

XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

## **Returns:**

None.

#### Note:

None.

Makes the connection between the Id of the interrupt source and the associated handler that is to run when the interrupt is recognized. The argument provided in this call as the Callbackref is used as the argument for the handler when it is called.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

*Id* contains the ID of the interrupt source and should be in the range of 0 to

XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority

interrupt.

Handler to the handler for that interrupt.

CallBackRef is the callback reference, usually the instance pointer of the connecting driver.

## **Returns:**

- o XST SUCCESS if the handler was connected correctly.
- o XST\_INTC\_CONNECT\_ERROR if the handler is already in use. Must disconnect existing handler assignment prior to calling connect again.

### Note:

```
void XIntc_Disable( XIntc * InstancePtr, Xuint8 Id
```

Disables the interrupt source provided as the argument Id such that the interrupt controller will not cause interrupts for the specified Id. The interrupt controller will continue to hold an interrupt condition for the Id, but will not cause an interrupt.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id contains the ID of the interrupt source and should be in the range of 0 to XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

### **Returns:**

None.

# **Note:**

None.

```
void XIntc_Disconnect( XIntc * InstancePtr, Xuint8 Id
```

Updates the interrupt table with the Null Handler and XNULL arguments at the location pointed at by the Id. This effectively disconnects that interrupt source from any handler. The interrupt is disabled also.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id contains the ID of the interrupt source and should be in the range of 0 to XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

### **Returns:**

None.

# **Note:**

```
void XIntc_Enable( XIntc * InstancePtr, Xuint8 Id
```

Enables the interrupt source provided as the argument Id. Any pending interrupt condition for the specified Id will occur after this function is called.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Id contains the ID of the interrupt source and should be in the range of 0 to XPAR\_INTC\_MAX\_NUM\_INTR\_INPUTS - 1 with 0 being the highest priority interrupt.

#### **Returns:**

None.

### Note:

None.

```
XStatus XIntc_Initialize( XIntc * InstancePtr, Xuint16 DeviceId )
```

Initialize a specific interrupt controller instance/driver. The initialization entails:

- Initialize fields of the **XIntc** structure
- Initial vector table with stub function calls
- All interrupt sources are disabled
- Interrupt output is disabled

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XIntc** instance. Passing in a device id associates the generic **XIntc** instance to a specific device, as chosen by the caller or application developer.

## **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if device configuration information was not found for a device with the supplied device ID.

# **Note:**

None.

# 

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

## **Parameters:**

DeviceId is the unique identifier for a device.

#### **Returns:**

A pointer to the **XIntc** configuration structure for the specified device, or XNULL if the device was not found.

### Note:

None.

Starts the interrupt controller by enabling the output from the controller to the processor. Interrupts may be generated by the interrupt controller after this function is called.

It is necessary for the caller to connect the interrupt handler of this component to the proper interrupt source.

## **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

Mode

determines if software is allowed to simulate interrupts or real interrupts are allowed to occur. Note that these modes are mutually exclusive. The interrupt controller hardware resets in a mode that allows software to simulate interrupts until this mode is exited. It cannot be reentered once it has been exited. One of the following values should be used for the mode.

- XIN\_SIMULATION\_MODE enables simulation of interrupts only
- XIN\_REAL\_MODE enables hardware interrupts only

### **Returns:**

- o XST SUCCESS if the device was started successfully
- XST\_FAILURE if simulation mode was specified and it could not be set because real mode has already been entered.

#### Note:

Must be called after **XIntc** initialization is completed.

| Parameters:                                                        |               |
|--------------------------------------------------------------------|---------------|
| <i>InstancePtr</i> is a pointer to the <b>XIntc</b> instance to be | be worked on. |
|                                                                    |               |
| Returns:                                                           |               |
| None.                                                              |               |
|                                                                    |               |
| Note:                                                              |               |
| None.                                                              |               |
|                                                                    |               |
|                                                                    |               |

Stops the interrupt controller by disabling the output from the controller so that no interrupts will be caused by

the interrupt controller.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XIntc Struct Reference

#include <xintc.h>

# **Detailed Description**

The XIntc driver instance data. The user is required to allocate a variable of this type for every intc device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• intc/v1\_00\_b/src/xintc.h

# intc/v1\_00\_b/src/xintc\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation. High-level driver functions are defined in **xintc.h**.

```
MODIFICATION HISTORY:
```

# **Data Structures**

struct XIntc\_VectorTableEntry

# **Defines**

```
#define XIntc_mMasterEnable(BaseAddress)
#define XIntc_mMasterDisable(BaseAddress)
#define XIntc_mEnableIntr(BaseAddress, EnableMask)
```

```
#define XIntc_mDisableIntr(BaseAddress, DisableMask)
#define XIntc_mAckIntr(BaseAddress, AckMask)
#define XIntc_mGetIntrStatus(BaseAddress)
```

# **Functions**

```
void XIntc_DefaultHandler (void *Input)
void XIntc_LowLevelInterruptHandler (void)
```

# **Define Documentation**

```
#define XIntc_mAckIntr( BaseAddress, AckMask
```

Acknowledge specific interrupt(s) in the interrupt controller.

# **Parameters:**

BaseAddress is the base address of the device

**AckMask** 

is the 32-bit value to write to the acknowledge register. Each bit of the mask corresponds to an interrupt input signal that is connected to the interrupt controller (INT0 = LSB). Only the bits which are set in the mask will acknowledge interrupts.

# **Returns:**

```
#define XIntc_mDisableIntr( BaseAddress, DisableMask )
```

Disable specific interrupt(s) in the interrupt controller.

## **Parameters:**

BaseAddress is the base address of the device

DisableMask is the 32-bit value to write to the enable register. Each bit of the mask corresponds to an interrupt input signal that is connected to the interrupt controller (INT0 = LSB). Only the bits which are set in the mask will disable interrupts.

# **Returns:**

None.

# #define XIntc\_mEnableIntr( BaseAddress, EnableMask )

Enable specific interrupt(s) in the interrupt controller.

# **Parameters:**

BaseAddress is the base address of the device

EnableMask is the 32-bit value to write to the enable register. Each bit of the mask corresponds to an interrupt input signal that is connected to the interrupt controller (INT0 = LSB). Only the bits which are set in the mask will enable interrupts.

## **Returns:**

None.

# #define XIntc\_mGetIntrStatus( BaseAddress )

Get the interrupt status from the interrupt controller which indicates which interrupts are active and enabled.

# **Parameters:**

BaseAddress is the base address of the device

## **Returns:**

The 32-bit contents of the interrupt status register. Each bit corresponds to an interrupt input signal that is connected to the interrupt controller (INT0 = LSB). Bits which are set indicate an active interrupt which is also enabled.

# #define XIntc mMasterDisable( BaseAddress )

Disable all interrupts in the Master Enable register of the interrupt controller.

# **Parameters:**

BaseAddress is the base address of the device.

## **Returns:**

None.

# #define XIntc mMasterEnable( BaseAddress )

Enable all interrupts in the Master Enable register of the interrupt controller. The interrupt controller defaults to all interrupts disabled from reset such that this macro must be used to enable interrupts.

## **Parameters:**

BaseAddress is the base address of the device.

## **Returns:**

None.

# **Function Documentation**

# void XIntc\_DefaultHandler( void \* UnusedInput)

This function is an default interrupt handler for the low level driver of the interrupt controller. It allows the interrupt vector table to be initialized to this function so that unexpected interrupts don't result in a system crash.

### **Parameters:**

*UnusedInput* is an unused input that is necessary for this function to have the signature of an input handler.

# **Returns:**

None.

# Note:

# void XIntc\_LowLevelInterruptHandler( void )

This function is an interrupt handler for the low level driver of the interrupt controller. It must be connected to the interrupt source such that is called when an interrupt of the interrupt controller is active. It will resolve which interrupts are active and enabled and call the appropriate interrupt handler. It acknowledges the interrupt after it has been serviced by the interrupt handler.

This function assumes that an interrupt vector table has been previously initialized by the user. It does not verify that entries in the table are valid before calling an interrupt handler.

## **Returns:**

None.

# Note:

The constants XPAR\_INTC\_SINGLE\_BASEADDR & XPAR\_INTC\_MAX\_ID must be setup for this to compile. Interrupt IDs range from 0 - 31 and correspond to the interrupt input signals for the interrupt controller. XPAR\_INTC\_MAX\_ID specifies the highest numbered interrupt input signal that is used.

# intc/v1\_00\_b/src/xintc\_i.h File Reference

# **Detailed Description**

This file contains data which is shared between files and internal to the **XIntc** component. It is intended for internal use only.

## MODIFICATION HISTORY:

# **Variables**

**XIntc\_Config XIntc\_ConfigTable** []

# **Variable Documentation**

XIntc\_Config XIntc\_ConfigTable[]( )

This table contains configuration information for each into device in the system. The **XIntc** driver must know when to acknowledge the interrupt. The entry which specifies this is a bit mask where each bit corresponds to a specific interrupt. A bit set indicates to ack it before servicing it. Generally, acknowledge before service is used when the interrupt signal is edge-sensitive, and after when the signal is level-sensitive.

# Xilinx Device Drivers Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# XIntc\_Config Struct Reference

#include <xintc.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xuint32 AckBeforeService

# **Field Documentation**

Xuint32 XIntc\_Config::AckBeforeService

Ack location per interrupt

Xuint32 XIntc\_Config::BaseAddress

Register base address

Xuint16 XIntc\_Config::DeviceId

Unique ID of device

The documentation for this struct was generated from the following file:

• intc/v1\_00\_b/src/xintc.h

# intc/v1\_00\_b/src/xintc\_intr.c File Reference

# **Detailed Description**

This file contains the interrupt processing for the **XIntc** component which is the driver for the Xilinx Interrupt Controller. The interrupt processing is partitioned seperately such that users are not required to use the provided interrupt processing. This file requires other files of the driver to be linked in also.

Two different interrupt handlers are provided for this driver such that the user must select the appropriate handler for the application. The first interrupt handler, XIntc\_VoidInterruptHandler, is provided for systems which use only a single interrupt controller or for systems that cannot otherwise provide an argument to the **XIntc** interrupt handler (e.g., the RTOS interrupt vector handler may not provide such a facility). The second interrupt handler, XIntc\_InterruptHandler, uses an input argument which is an instance pointer to an interrupt controller driver such that multiple interrupt controllers can be supported. This handler requires the calling function to pass it the appropriate argument, so another level of indirection may be required.

The interrupt processing may be used by connecting one of the interrupt handlers to the interrupt system. These handlers do not save and restore the processor context but only handle the processing of the Interrupt Controller. The two handlers are provided as working examples. The user is encouraged to supply their own interrupt handler when performance tuning is deemed necessary.

# MODIFICATION HISTORY:

```
#include "xbasic_types.h"
#include "xintc_i.h"
#include "xintc.h"
```

# **Functions**

void XIntc\_VoidInterruptHandler ()
void XIntc\_InterruptHandler (XIntc \*InstancePtr)

# **Function Documentation**

# void XIntc\_InterruptHandler( XIntc \* InstancePtr)

The interrupt handler for the driver. This function determines the pending interrupts and calls the appropriate handlers in the priority based order.

This specific function allows multiple interrupt controller instances to be handled. The user must connect this function to the interrupt system such that it is called whenever the devices which are connected to it cause an interrupt.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

# **Returns:**

None.

## Note:

None.

void XIntc\_VoidInterruptHandler( )

| Interrupt handler for the driver. T | his function determines | s the pending interrupts | and calls the |
|-------------------------------------|-------------------------|--------------------------|---------------|
| appropriate handlers in the priori  | ty based order.         |                          |               |

This specific function does not support multiple interrupt controller instances to be handled. The user must connect this function to the interrupt system such that it is called whenever the devices which are connected to it cause an interrupt.

| Returi | ns:   |  |  |  |
|--------|-------|--|--|--|
|        | None. |  |  |  |
| Note:  | None. |  |  |  |

# intc/v1\_00\_b/src/xintc\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of interrupt controller devices in the system.

# MODIFICATION HISTORY:

# **Variables**

XIntc\_Config XIntc\_ConfigTable [XPAR\_XINTC\_NUM\_INSTANCES]

# **Variable Documentation**

XIntc\_Config XIntc\_ConfigTable[XPAR\_XINTC\_NUM\_INSTANCES]

This table contains configuration information for each into device in the system. The **XIntc** driver must know when to acknowledge the interrupt. The entry which specifies this is a bit mask where each bit corresponds to a specific interrupt. A bit set indicates to ack it before servicing it. Generally, acknowledge before service is used when the interrupt signal is edge-sensitive, and after when the signal is level-sensitive.

# intc/v1\_00\_b/src/xintc\_l.c File Reference

# **Detailed Description**

This file contains low-level driver functions that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation.

```
MODIFICATION HISTORY:
```

# **Functions**

```
void XIntc_DefaultHandler (void *UnusedInput)
void XIntc_LowLevelInterruptHandler (void)
```

# **Function Documentation**

void XIntc\_DefaultHandler( void \* UnusedInput)

This function is an default interrupt handler for the low level driver of the interrupt controller. It allows the interrupt vector table to be initialized to this function so that unexpected interrupts don't result in a system crash.

# **Parameters:**

*UnusedInput* is an unused input that is necessary for this function to have the signature of an input handler.

## **Returns:**

None.

# Note:

None.

# void XIntc\_LowLevelInterruptHandler( void )

This function is an interrupt handler for the low level driver of the interrupt controller. It must be connected to the interrupt source such that is called when an interrupt of the interrupt controller is active. It will resolve which interrupts are active and enabled and call the appropriate interrupt handler. It acknowledges the interrupt after it has been serviced by the interrupt handler.

This function assumes that an interrupt vector table has been previously initialized by the user. It does not verify that entries in the table are valid before calling an interrupt handler.

# **Returns:**

None.

# Note:

The constants XPAR\_INTC\_SINGLE\_BASEADDR & XPAR\_INTC\_MAX\_ID must be setup for this to compile. Interrupt IDs range from 0 - 31 and correspond to the interrupt input signals for the interrupt controller. XPAR\_INTC\_MAX\_ID specifies the highest numbered interrupt input signal that is used.

# intc/v1\_00\_b/src/xintc\_options.c File Reference

# **Detailed Description**

Contains option functions for the **XIntc** driver. These functions allow the user to configure an instance of the **XIntc** driver. This file requires other files of the component to be linked in also.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 02/21/02 First release

#include "xbasic_types.h"
#include "xintc.h"
```

# **Functions**

```
XStatus XIntc_SetOptions (XIntc *InstancePtr, Xuint32 Options)
Xuint32 XIntc_GetOptions (XIntc *InstancePtr)
```

# **Function Documentation**

Xuint32 XIntc\_GetOptions( XIntc \* InstancePtr)

Return the currently set options.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

# **Returns:**

The currently set options. The options are described in **xintc.h**.

# Note:

None.

```
XStatus XIntc_SetOptions( XIntc * InstancePtr, Xuint32 Options )
```

Set the options for the interrupt controller driver.

# **Parameters:**

*InstancePtr* is a pointer to the XIntc instance to be worked on.*Options* to be set. The available options are described in xintc.h.

## **Returns:**

- o XST\_SUCCESS if the options were set successfully
- o XST\_INVALID\_PARAM if the specified option was not valid

# Note:

None.

# intc/v1\_00\_b/src/xintc\_selftest.c File Reference

# **Detailed Description**

Contains diagnostic self-test functions for the **XIntc** component. This file requires other files of the component to be linked in also.

```
MODIFICATION HISTORY:
```

# **Functions**

```
XStatus XIntc_SelfTest (XIntc *InstancePtr)
XStatus XIntc SimulateIntr (XIntc *InstancePtr, Xuint8 Id)
```

# **Function Documentation**

```
XStatus XIntc_SelfTest( XIntc * InstancePtr)
```

Run a self-test on the driver/device. This is a destructive test.

This involves forcing interrupts into the controller and verifying that they are recognized and can be acknowledged. This test will not succeed if the interrupt controller has been started in real mode such that interrupts cannot be forced.

# **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

## **Returns:**

- o XST\_SUCCESS if self-test is successful.
- o XST\_INTC\_FAIL\_SELFTEST if the Interrupt controller fails the self-test. It will fail the self test if the device has previously been started in real mode.

## Note:

None.

Allows software to simulate an interrupt in the interrupt controller. This function will only be successful when the interrupt controller has been started in simulation mode. Once it has been started in real mode, interrupts cannot be simulated. A simulated interrupt allows the interrupt controller to be tested without any device to drive an interrupt input signal into it.

### **Parameters:**

*InstancePtr* is a pointer to the **XIntc** instance to be worked on.

*Id* is the interrupt ID for which to simulate an interrupt.

## **Returns:**

XST\_SUCCESS if successful, or XST\_FAILURE if the interrupt could not be simulated because the interrupt controller is or has previously been in real mode.

# Note:

# cpu\_ppc405/v1\_00\_a/src/xio\_dcr.h File Reference

# **Detailed Description**

The DCR I/O access functions.

## Note:

These access functions are specific to the PPC405 CPU. Changes might be necessary for other members of the IBM PPC Family.

## MODIFICATION HISTORY:

#include "xbasic\_types.h"

# **Functions**

```
void XIo_DcrOut (Xuint32 DcrRegister, Xuint32 Data)
Xuint32 XIo_DcrIn (Xuint32 DcrRegister)
```

# **Function Documentation**

Xuint32 XIo\_DcrIn( Xuint32 DcrRegister)

| Parameters:                                                                                                                       |
|-----------------------------------------------------------------------------------------------------------------------------------|
| DcrRegister is the intended source DCR register                                                                                   |
| Returns:  Contents of the specified DCR register.                                                                                 |
| Note: None.                                                                                                                       |
| void XIo_DcrOut( Xuint32 DcrRegister, Xuint32 Data )                                                                              |
| Outputs value provided to specified register defined in the header file.                                                          |
| Parameters:  DcrRegister is the intended destination DCR register  Data is the value to be placed into the specified DCR register |
| Returns: None.                                                                                                                    |
| Note:<br>None.                                                                                                                    |
| Congreted on 30 San 2003 for Viliar Davige Drivers                                                                                |

Reads value from specified register.

# cpu\_ppc405/v1\_00\_a/src/xio\_dcr.c File Reference

## **Detailed Description**

The implementation of the XDcrIo interface. See xio\_dcr.h for more information about the component.

#### MODIFICATION HISTORY:

```
#include "xstatus.h"
#include "xbasic_types.h"
#include "xio.h"
#include "xio_dcr.h"
```

#### **Data Structures**

struct DcrFunctionTableEntryTag

### **Functions**

void XIo\_DcrOut (Xuint32 DcrRegister, Xuint32 Data)
Xuint32 XIo\_DcrIn (Xuint32 DcrRegister)

## **Function Documentation**

```
Xuint32 XIo_DcrIn( Xuint32 DcrRegister)
```

Reads value from specified register.

#### **Parameters:**

DcrRegister is the intended source DCR register

#### **Returns:**

Contents of the specified DCR register.

#### Note:

None.

```
void XIo_DcrOut( Xuint32 DcrRegister, Xuint32 Data
```

Outputs value provided to specified register defined in the header file.

#### **Parameters:**

DcrRegister is the intended destination DCR register

Data is the value to be placed into the specified DCR register

#### **Returns:**

None.

#### Note:

## cpu/v1\_00\_a/src/xio.h File Reference

## **Detailed Description**

This file contains the interface for the XIo component, which encapsulates the Input/Output functions for processors that do not require any special I/O handling.

#### Note:

This file may contain architecture-dependent items (memory-mapped or non-memory-mapped I/O).

```
#include "xbasic_types.h"
```

## **Defines**

```
#define XIo_In8(InputPtr)

#define XIo_In16(InputPtr)

#define XIo_In32(InputPtr)

#define XIo_Out8(OutputPtr, Value)

#define XIo_Out16(OutputPtr, Value)

#define XIo_Out32(OutputPtr, Value)
```

## **Typedefs**

typedef Xuint32 XIo\_Address

## **Functions**

```
void XIo_EndianSwap16 (Xuint16 Source, Xuint16 *DestPtr)
void XIo_EndianSwap32 (Xuint32 Source, Xuint32 *DestPtr)
```

## **Define Documentation**

#### #define XIo\_In16( InputPtr )

Performs an input operation for a 16-bit memory location by reading from the specified address and returning the value read from that address.

#### **Parameters:**

*InputPtr* contains the address to perform the input operation at.

#### **Returns:**

The value read from the specified input address.

#### #define XIo\_In32( InputPtr )

Performs an input operation for a 32-bit memory location by reading from the specified address and returning the value read from that address.

#### **Parameters:**

*InputPtr* contains the address to perform the input operation at.

#### **Returns:**

The value read from the specified input address.

#### #define XIo\_In8( InputPtr )

Performs an input operation for an 8-bit memory location by reading from the specified address and returning the value read from that address.

#### **Parameters:**

*InputPtr* contains the address to perform the input operation at.

#### **Returns:**

The value read from the specified input address.

## #define XIo\_Out16( OutputPtr, Value )

Performs an output operation for a 16-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutputPtr contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

## #define XIo\_Out32( OutputPtr, Value

Performs an output operation for a 32-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutputPtr contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

```
#define XIo_Out8( OutputPtr,
Value )
```

Performs an output operation for an 8-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutputPtr contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

## **Typedef Documentation**

```
typedef Xuint32 XIo_Address
```

Typedef for an I/O address. Typically correlates to the width of the address bus.

## **Function Documentation**

Performs a 16-bit endian converion.

#### **Parameters:**

*Source* contains the value to be converted.

*DestPtr* contains a pointer to the location to put the converted value.

#### **Returns:**

None.

#### **Note:**

```
void XIo_EndianSwap32( Xuint32 Source,
Xuint32 * DestPtr
)
```

Performs a 32-bit endian converion.

#### **Parameters:**

Source contains the value to be converted.

DestPtr contains a pointer to the location to put the converted value.

#### **Returns:**

None.

#### Note:

None.

## cpu/v1\_00\_a/src/xio.c File Reference

## **Detailed Description**

Contains I/O functions for memory-mapped or non-memory-mapped I/O architectures. These functions encapsulate generic CPU I/O requirements.

#### **Note:**

This file may contain architecture-dependent code.

```
#include "xio.h"
#include "xbasic_types.h"
```

## **Functions**

```
void XIo_EndianSwap16 (Xuint16 Source, Xuint16 *DestPtr)
void XIo_EndianSwap32 (Xuint32 Source, Xuint32 *DestPtr)
```

## **Function Documentation**

| Performs a 16-bit endian converion.                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------|
| Parameters:  Source contains the value to be converted.  DestPtr contains a pointer to the location to put the converted value. |
| Returns: None.                                                                                                                  |
| Note: None.                                                                                                                     |
| oid XIo_EndianSwap32( Xuint32 Source,                                                                                           |
| Performs a 32-bit endian converion.                                                                                             |
| Parameters:  Source contains the value to be converted.  DestPtr contains a pointer to the location to put the converted value. |

Generated on 30 Sep 2003 for Xilinx Device Drivers

**Returns:** 

Note:

None.

#### Xilinx Device Drivers

### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# cpu\_ppc405/v1\_00\_a/src/xio.c File Reference

## **Detailed Description**

Contains I/O functions for memory-mapped or non-memory-mapped I/O architectures. These functions encapsulate PowerPC architecture-specific I/O requirements.

#### Note:

This file contains architecture-dependent code.

The order of the SYNCHRONIZE\_IO and the read or write operation is important. For the Read operation, all I/O needs to complete prior to the desired read to insure valid data from the address. The PPC is a weakly ordered I/O model and reads can and will occur prior to writes and the SYNCHRONIZE\_IO ensures that any writes occur prior to the read. For the Write operation the SYNCHRONIZE\_IO occurs after the desired write to ensure that the address is updated with the new value prior to any subsequent read.

```
#include "xio.h"
#include "xbasic types.h"
```

## **Functions**

```
Xuint8 XIo_In8 (XIo_Address InAddress)
Xuint16 XIo In16 (XIo Address InAddress)
```

Xuint32 XIo\_In32 (XIo\_Address InAddress)

Xuint16 XIo\_InSwap16 (XIo\_Address InAddress)

Xuint32 XIo\_InSwap32 (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)
void XIo_EndianSwap16OLD (Xuint16 Source, Xuint16 *DestPtr)
void XIo_EndianSwap32OLD (Xuint32 Source, Xuint32 *DestPtr)
void XIo_OutSwap16 (XIo_Address OutAddress, Xuint16 Value)
void XIo_OutSwap32 (XIo_Address OutAddress, Xuint32 Value)
```

## **Function Documentation**

```
void XIo_EndianSwap16OLD( Xuint16 Source,
Xuint16 * DestPtr
)
```

Performs a 16-bit endian converion.

#### **Parameters:**

*Source* contains the value to be converted.

*DestPtr* contains a pointer to the location to put the converted value.

#### **Returns:**

None.

#### Note:

```
void XIo_EndianSwap32OLD( Xuint32 Source,
Xuint32 * DestPtr
)
```

Performs a 32-bit endian converion. **Parameters:** Source contains the value to be converted. DestPtr contains a pointer to the location to put the converted value. **Returns:** None. Note: None. Xuint16 XIo\_In16( XIo\_Address InAddress) Performs an input operation for a 16-bit memory location by reading from the specified address and returning the value read from that address. **Parameters:** *InAddress* contains the address to perform the input operation at. **Returns:** The value read from the specified input address. **Note:** 

Xuint32 XIo\_In32( XIo\_Address InAddress)



#### **Parameters:**

*InAddress* contains the address to perform the input operation at.

#### **Returns:**

The value read from the specified input address.

#### **Note:**

None.

#### Xuint8 XIo\_In8( XIo\_Address InAddress)

Performs an input operation for an 8-bit memory location by reading from the specified address and returning the value read from that address.

#### **Parameters:**

InAddress contains the address to perform the input operation at.

#### **Returns:**

The value read from the specified input address.

#### **Note:**

None.

#### Xuint16 XIo\_InSwap16( XIo\_Address InAddress)

Performs an input operation for a 16-bit memory location by reading from the specified address and returning the byte-swapped value read from that address.

#### **Parameters:**

*InAddress* contains the address to perform the input operation at.

#### **Returns:**

The byte-swapped value read from the specified input address.

#### Note:

None.

#### Xuint32 XIo\_InSwap32( XIo\_Address InAddress)

Performs an input operation for a 32-bit memory location by reading from the specified address and returning the byte-swapped value read from that address.

#### **Parameters:**

*InAddress* contains the address to perform the input operation at.

#### **Returns:**

The byte-swapped value read from the specified input address.

#### **Note:**

```
void XIo_Out16( XIo_Address OutAddress,
Xuint16 Value
)
```

Performs an output operation for a 16-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

#### Note:

None.

```
void XIo_Out32( XIo_Address OutAddress, Xuint32 Value
```

Performs an output operation for a 32-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

#### Note:

```
void XIo_Out8( XIo_Address OutAddress,
Xuint8 Value
)
```

Performs an output operation for an 8-bit memory location by writing the specified value to the specified address.

#### **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

#### Note:

None.

```
void XIo_OutSwap16( XIo_Address OutAddress, Xuint16 Value
)
```

Performs an output operation for a 16-bit memory location by writing the specified value to the specified address. The value is byte-swapped before being written.

#### **Parameters:**

OutAddress contains the address to perform the output operation at.

Value contains the value to be output at the specified address.

#### **Returns:**

None.

#### Note:

```
void XIo_OutSwap32( XIo_Address OutAddress, Xuint32 Value
)
```

| Performs an output operation for a 32-bit memory location by writing the specified value to |
|---------------------------------------------------------------------------------------------|
| the the specified address. The value is byte-swapped before being written.                  |
|                                                                                             |

| Parameters: |                     |                                                           |  |
|-------------|---------------------|-----------------------------------------------------------|--|
|             | OutAddress          | contains the address to perform the output operation at.  |  |
|             | Value               | contains the value to be output at the specified address. |  |
| Return      | <b>ns:</b><br>None. |                                                           |  |
|             | None.               |                                                           |  |

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# opb2plb/v1\_00\_a/src/xopb2plb.h File Reference

## **Detailed Description**

This component contains the implementation of the **XOpb2Plb** component. It is the driver for the OPB to PLB Bridge. The bridge converts OPB bus transactions to PLB bus transactions. The hardware acts as a slave on the OPB side and as a master on the PLB side. This interface is necessary for the peripherals to access PLB based memory.

This driver allows the user to access the Bridge registers to support the handling of bus errors and other access errors and determine an appropriate solution if possible.

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

The Xilinx OPB to PLB Bridge is a soft IP core designed for Xilinx FPGAs and contains the following features:

- 64-bit PLB Master interface.
- Communicates with 32- or 64-bit PLB slaves.
- Non-burst transfers of 1-8 bytes.
- Burst transfers, including word and double-word bursts of fixed lengths, up to the depth of the burst buffer. Buffer depth configurable via a design parameter.
- Cacheline transactions of 4, 8, and 16 words.
- Programmable address boundaries that encompass the inverse of the PLB to OPB Bridge address space.
- Translates OPB data bursts to either cacheline or fixed length PLB burst transfers.
- Performing only CPU subset transactions (cachelines) can reduce system logic utilization and improve timing through the simplification of PLB slave IP.
- Using PLB burst transfers yields better bus cycle efficiency but may increase logic utilization and degrade timing in the system OPB Slave interface.

- 32-bit OPB Slave interface with byte enable transfers. *Note*: Does not support dynamic bus sizing or non-byte enable transactions. PLB and OPB clocks can have an asynchronous relationship (OPB clock frequency must be less than or equal to the PLB clock frequency).
- Bus Error Status Register (BESR) and Bus Error Address Register (BEAR) to report errors.
- DCR Slave interface provides access to BESR and BEAR.

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. The current configuration data is contained in the **xopb2plb\_g.c**. A table is defined where each entry contains configuration information for a device. This information includes such things as the base address of the DCR mapped device.

#### **Register Access**

The bridge registers reside on the DCR address bus which is a parameter that can be selected in the hardware. If the DCR is not used, the registers reside in the OPB address space. A restriction of this driver is that if more than one bridge exists in the system, all must be configured the same way. That is, all must use DCR or all must use OPB.

#### Note:

This driver is not thread-safe. Thread safety must be guaranteed by the layer above this driver if there is a need to access the device from multiple threads.

#### MODIFICATION HISTORY:

### **Data Structures**

struct XOpb2Plb struct XOpb2Plb\_Config

## **OPB-PLB** bridge error status values

#define XO2P\_READ\_ERROR
#define XO2P\_WRITE\_ERROR
#define XO2P\_NO\_ERROR

## **Functions**

```
XStatus XOpb2Plb_Initialize (XOpb2Plb *InstancePtr, Xuint16 DeviceId)
void XOpb2Plb_Reset (XOpb2Plb *InstancePtr)

XOpb2Plb_Config * XOpb2Plb_LookupConfig (Xuint16 DeviceId)
Xboolean XOpb2Plb_IsError (XOpb2Plb *InstancePtr)
void XOpb2Plb_ClearErrors (XOpb2Plb *InstancePtr)
Xuint32 XOpb2Plb_GetErrorStatus (XOpb2Plb *InstancePtr)
Xuint32 XOpb2Plb_GetErrorAddress (XOpb2Plb *InstancePtr)
void XOpb2Plb_EnableInterrupt (XOpb2Plb *InstancePtr)
void XOpb2Plb_DisableInterrupt (XOpb2Plb *InstancePtr)
void XOpb2Plb_EnableLock (XOpb2Plb *InstancePtr)
void XOpb2Plb_EnableLock (XOpb2Plb *InstancePtr)
XStatus XOpb2Plb_DisableLock (XOpb2Plb *InstancePtr, Xuint32 TestAddress)
```

## **Define Documentation**

#### #define XO2P\_NO\_ERROR

XO2P\_READ\_ERROR A read error occurred
XO2P\_WRITE\_ERROR A write error occurred
XO2P\_NO\_ERROR There is no error

#### #define XO2P\_READ\_ERROR

| XO2P_ | _READ_ERROR  |
|-------|--------------|
| XO2P_ | _WRITE_ERROR |
| XO2P  | NO_ERROR     |

A read error occurred A write error occurred There is no error

#### #define XO2P\_WRITE\_ERROR

| XO2P_ | _READ_E | ERROR  |
|-------|---------|--------|
| XO2P_ | _WRITE_ | _ERROR |
| XO2P_ | NO_ERF  | ROR    |

A read error occurred A write error occurred There is no error

## **Function Documentation**

void XOpb2Plb\_ClearErrors( XOpb2Plb \* InstancePtr)

Clears the errors. If the lock bit is set, this allows subsequent errors to be recognized.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

void XOpb2Plb\_DisableInterrupt( XOpb2Plb \* InstancePtr)

| Disables the interrupt output from the bridge                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters:  InstancePtr is a pointer to the XOpb2Plb instance to be worked on.                                                                                                                                                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                             |
| Note:  The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation. |
| void XOpb2Plb_DisableLock( XOpb2Plb * InstancePtr)                                                                                                                                                                                                                                                                                                                         |
| Disables the locking of the status on error for the bridge. This 'unlocks' the status and address registers allowing subsequent errors to overwrite the current values when an error occurs.                                                                                                                                                                               |
| Parameters:  InstancePtr is a pointer to the XOpb2Plb instance to be worked on.                                                                                                                                                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                             |
| Note: None.                                                                                                                                                                                                                                                                                                                                                                |

void XOpb2Plb\_EnableInterrupt( XOpb2Plb \* InstancePtr)

| Enables the interrupt output from the bridge                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters:  InstancePtr is a pointer to the XOpb2Plb instance to be worked on.                                                                                                                                                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                             |
| Note:  The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation. |
| oid XOpb2Plb_EnableLock( XOpb2Plb * InstancePtr)                                                                                                                                                                                                                                                                                                                           |
| Enables the locking of the status on error for the bridge. This 'locks' the status and address register values when an error occurs, preventing subsequent errors from overwriting the values. Clearing the error allows the status and address registers to update with the next error that occurs                                                                        |
| Parameters:  InstancePtr is a pointer to the XOpb2Plb instance to be worked on.                                                                                                                                                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                             |

Xuint32 XOpb2Plb\_GetErrorAddress( XOpb2Plb \* InstancePtr)

**Note:** 

Returns the PLB Address where the most recent error occured. If there isn't an outstanding error, the last address in error is returned. 0x00000000 is the initial value coming out of reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

Address where error causing access occurred

#### Note:

Calling **XOpb2Plb\_IsError**() is recommended to confirm that an error has occurred prior to calling **XOpb2Plb\_GetErrorAddress**() to ensure that the data in the error address register is relevant.

#### Xuint32 XOpb2Plb\_GetErrorStatus( XOpb2Plb \* InstancePtr)

Returns the error status indicating the type of error that has occurred.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

The current error status for the OPB to PLB bridge. The possible return values are described in **xopb2plb.h**.

#### Note:

Initializes a specific **XOpb2Plb** instance. Looks up the configuration data for the given device ID and then initializes instance data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XOpb2Plb** component. Passing in a device id associates the generic **XOpb2Plb** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST\_DEVICE\_NOT\_FOUND if the requested device is not found

#### **Note:**

None.

#### **Xboolean XOpb2Plb\_IsError( XOpb2Plb \* InstancePtr)**

Returns XTRUE is there is an error outstanding

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

Boolean XTRUE if there is an error, XFALSE if there is no current error.

#### Note:

None.

#### 

Looks up the device configuration based on the unique device ID. The table OpbPlbConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID of the device to look for.

#### **Returns:**

A pointer to the configuration data of the given device, or XNULL if no match is found.

#### **Note:**

None.

#### void XOpb2Plb\_Reset( XOpb2Plb \* InstancePtr)

Forces a software-induced reset to occur in the bridge and disables interrupts and the locking functionality in the process.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

Disables interrupts and the locking functionality in the process.

Runs a self-test on the driver/device.

This tests reads the provided TestAddress which is intended to cause an error Then the **XOpb2Plb\_IsError**() routine is called and if there is an error, the address is checked against the provided location and if they match XST\_SUCCESS is returned and all errors are then cleared.

If the **XOpb2Plb\_IsError**() is called and no error is indicated, XST\_FAILURE is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

TestAddress is a location that should cause an error on read.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_FAILURE if the driver fails the self-test.

#### Note:

This test assumes that the bus error interrupts to the processor are not enabled.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## **XOpb2Plb Struct Reference**

#include <xopb2plb.h>

## **Detailed Description**

The XOpb2Plb driver instance data. The user is required to allocate a variable of this type for every OPB-to-PLB bridge device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• opb2plb/v1\_00\_a/src/xopb2plb.h

# opb2plb/v1\_00\_a/src/xopb2plb\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of OPB-to-PLB bridge devices in the system. Each bridge device should have an entry in this table.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 01/22/02 First release
1.00a rpm 05/14/02 Made configuration table/data public

#include "xopb2plb.h"
#include "xparameters.h"
```

## **Variables**

XOpb2Plb\_Config XOpb2Plb\_ConfigTable [XPAR\_XOPB2PLB\_NUM\_INSTANCES]

## **Variable Documentation**

#### XOpb2Plb\_Config XOpb2Plb\_ConfigTable[XPAR\_XOPB2PLB\_NUM\_INSTANCES]

The OPB-to-PLB bridge configuration table, sized by the number of instances defined in **xparameters.h**.

# Xilinx Device Drivers Driver Summary Copyright

### Main Page Data Structures File List Data Fields Globals

## XOpb2Plb\_Config Struct Reference

#include <xopb2plb.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress

## **Field Documentation**

Xuint32 XOpb2Plb\_Config::BaseAddress

Register base address

Xuint16 XOpb2Plb\_Config::DeviceId

Unique ID of device

The documentation for this struct was generated from the following file:

opb2plb/v1\_00\_a/src/xopb2plb.h

# opb2plb/v1\_00\_a/src/xopb2plb\_l.h File Reference

## **Detailed Description**

This file contains identifiers and low-level macros that can be used to access the device directly.

```
MODIFICATION HISTORY:
```

## **Defines**

```
#define XOpb2Plb_mGetBesrReg(BaseAddress)

#define XOpb2Plb_mGetBearReg(BaseAddress)

#define XOpb2Plb_mSetControlReg(BaseAddress, Mask)

#define XOpb2Plb_mGetControlReg(BaseAddress)
```

## **Define Documentation**

| #define XOpb2Plb_mGetBearReg( BaseAddress )     |
|-------------------------------------------------|
| Get the bus error address register (BEAR).      |
| Parameters:                                     |
| BaseAddress is the base address of the device   |
| Returns:                                        |
| The 32-bit value of the error address register. |
| Note:                                           |
| None.                                           |
|                                                 |
|                                                 |
| #define XOpb2Plb_mGetBesrReg( BaseAddress )     |
| Get the bus error status register (BESR).       |
|                                                 |
| Parameters:                                     |
| BaseAddress is the base address of the device   |
| Returns:                                        |
| The 32-bit value of the error status register.  |
|                                                 |
| Note:                                           |
| None.                                           |
|                                                 |
| #I C VO LADIL CLAC 4 ID (D A II )               |
| #define XOpb2Plb_mGetControlReg( BaseAddress )  |
| Get the contents of the control register.       |
| Parameters:                                     |
| BaseAddress is the base address of the device   |
|                                                 |
| Returns:                                        |
| The 32-bit value of the control register.       |
|                                                 |
| Note:                                           |
| None.                                           |
|                                                 |

| Mask )                                              |
|-----------------------------------------------------|
| Set the control register to the given value.        |
| Parameters:                                         |
| BaseAddress is the base address of the device       |
| Mask is the value to write to the control register. |
| Returns:                                            |
| None.                                               |
| Note:                                               |
| None.                                               |
|                                                     |

 ${\it \#define~XOpb2Plb\_mSetControlReg(~BaseAddress,}$ 

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# opbarb/v1\_02\_a/src/xopbarb.h File Reference

# **Detailed Description**

This component contains the implementation of the **XOpbArb** component. It is the driver for the Onchip Peripheral Bus (OPB) Arbiter. The arbiter performs bus arbitration for devices on the OPB

#### **Priority Arbitration**

By default, the arbiter prioritizes masters on the bus based on their master IDs. A master's ID corresponds to the signals with which it connects to the arbiter. Master 0 is the highest priority, master 1 the next highest, and so on. The device driver allows an application to modify this default behavior.

There are two modes of priority arbitration, dynamic and fixed. The device can be parameterized in either of these modes. Fixed priority arbitration makes use of priority levels that can be configured by software. There is one level for each master on the bus. Priority level 0 is assigned the master ID of the highest priority master, priority level 1 is assigned the master ID of the next highest priority master, and so on.

Dynamic priority arbitration utilizes a Least Recently Used(LRU) algorithm to determine the priorities of masters on the bus. Once a master is granted the bus, it falls to the lowest priority master. A master that is not granted the bus moves up in priority until it becomes the highest priority master based on the fact that it has been the least recently used master. The arbiter uses the currently assigned priority levels as its starting configuration for the LRU algorithm. Software can modify this starting configuration by assigning master IDs to the priority levels.

When configuring priority levels (i.e., assigning master IDs to priority levels), the application must suspend use of the priority levels by the device. Every master must be represented by one and only one priority level. The device driver enforces this by making the application suspend use of the priority levels by the device during the time it takes to correctly configure the levels. Once the levels are configured, the application must explicitly resume use of the priority levels by the device. During

the time priority levels are suspended, the device reverts to its default behavior of assigning priorities based on master IDs.

#### **Bus Parking**

By default, bus parking is disabled. The device driver allows an application to enable bus parking, which forces the arbiter to always assert the grant signal for a specific master when no other masters are requesting the bus. The master chosen for parking is either the master that was last granted the bus, or the master configured by the SetParkId function. When bus parking is enabled but no park ID has been set, bus parking defaults to the master that was last granted the bus.

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. Configuration parameters are stored in **xopbarb\_g.c**. A table is defined where each entry contains configuration information for a device. This information includes such things as the base address of the memory-mapped device, the number of masters on the bus, and the priority arbitration scheme.

When the device is parameterized with only 1 master, or if the device is parameterized without a slave interface, there are no registers accessible to software and no configuration entry is available. In these configurations it is likely that the driver will not be loaded or used by the application. But in the off-chance that it is, it is assumed that no configuration information for the arbiter is entered in the **xopbarb\_g.c** table. If config information were entered for the device, there will be nothing to prevent the driver's use, and any use of the driver under these circumstances will result in undefined behavior.

#### Note:

This driver is not thread-safe. Thread safety must be guaranteed by the layer above this driver if there is a need to access the device from multiple threads.

#### MODIFICATION HISTORY:

### **Data Structures**

struct **XOpbArb**struct **XOpbArb\_Config** 

# **Configuration options**

```
#define XOA_DYNAMIC_PRIORITY_OPTION
#define XOA_PARK_ENABLE_OPTION
#define XOA_PARK_BY_ID_OPTION
```

## **Functions**

```
XStatus XOpbArb_Initialize (XOpbArb *InstancePtr, Xuint16 DeviceId)

XOpbArb_Config * XOpbArb_LookupConfig (Xuint16 DeviceId)

XStatus XOpbArb_SelfTest (XOpbArb *InstancePtr)

XStatus XOpbArb_SetOptions (XOpbArb *InstancePtr, Xuint32 Options)

Xuint32 XOpbArb_GetOptions (XOpbArb *InstancePtr)

XStatus XOpbArb_SetPriorityLevel (XOpbArb *InstancePtr, Xuint8 Level, Xuint8 MasterId)

Xuint8 XOpbArb_GetPriorityLevel (XOpbArb *InstancePtr, Xuint8 Level)

void XOpbArb_SuspendPriorityLevels (XOpbArb *InstancePtr)

XStatus XOpbArb_ResumePriorityLevels (XOpbArb *InstancePtr)

XStatus XOpbArb_SetParkId (XOpbArb *InstancePtr, Xuint8 MasterId)

XStatus XOpbArb_GetParkId (XOpbArb *InstancePtr, Xuint8 *MasterIdPtr)
```

## **Define Documentation**

#define XOA\_DYNAMIC\_PRIORITY\_OPTION

The options enable or disable additional features of the OPB Arbiter. Each of the options are bit fields such that more than one may be specified.

#### XOA\_DYNAMIC\_PRIORITY\_OPTION

The Dynamic Priority option configures the device for dynamic priority arbitration, which uses a Least Recently Used (LRU) algorithm to determine the priorities of OPB masters. This option is not applicable if the device is parameterized for fixed priority arbitration. When the device is parameterized for dynamic priority arbitration, it can still use a fixed priority arbitration by turning this option off. Fixed priority arbitration uses the priority levels as written by software to determine the priorities of OPB masters. The default is fixed priority arbitration.

#### XOA\_PARK\_ENABLE\_OPTION

The Park Enable option enables bus parking, which forces the arbiter to always assert the grant signal for a specific master when no other masters are requesting the bus. The master chosen for parking is either the master that was last granted the bus, or the master configured by the SetParkId function.

#### XOA\_PARK\_BY\_ID\_OPTION

The Park By ID option enables bus parking based on the specific master ID. The master ID defaults to master 0, and can be changed using **XOpbArb\_SetParkId()**. When this option is disabled, bus parking defaults to the master that was last granted the bus. The park enable option must be set for this option to take effect.

#### #define XOA\_PARK\_BY\_ID\_OPTION

The options enable or disable additional features of the OPB Arbiter. Each of the options are bit fields such that more than one may be specified.

#### XOA\_DYNAMIC\_PRIORITY\_OPTION

The Dynamic Priority option configures the device for dynamic priority arbitration, which uses a Least Recently Used (LRU) algorithm to determine the priorities of OPB masters. This option is not applicable if the device is parameterized for fixed priority arbitration. When the device is parameterized for dynamic priority arbitration, it can still use a fixed priority arbitration by turning this option off. Fixed priority arbitration uses the priority levels as written by software to determine the priorities of OPB masters. The default is fixed priority arbitration.

#### • XOA PARK ENABLE OPTION

The Park Enable option enables bus parking, which forces the arbiter to always assert the grant signal for a specific master when no other masters are requesting the bus. The master chosen for parking is either the master that was last granted the bus, or the master configured by the SetParkId function.

#### XOA PARK BY ID OPTION

The Park By ID option enables bus parking based on the specific master ID. The master ID defaults to master 0, and can be changed using **XOpbArb\_SetParkId**(). When this option is disabled, bus parking defaults to the master that was last granted the bus. The park enable option must be set for this option to take effect.

#### #define XOA\_PARK\_ENABLE\_OPTION

The options enable or disable additional features of the OPB Arbiter. Each of the options are bit fields such that more than one may be specified.

#### XOA\_DYNAMIC\_PRIORITY\_OPTION

The Dynamic Priority option configures the device for dynamic priority arbitration, which uses a Least Recently Used (LRU) algorithm to determine the priorities of OPB masters. This option is not applicable if the device is parameterized for fixed priority arbitration. When the device is parameterized for dynamic priority arbitration, it can still use a fixed priority arbitration by turning this option off. Fixed priority arbitration uses the priority levels as written by software to determine the priorities of OPB masters. The default is fixed priority arbitration.

#### XOA\_PARK\_ENABLE\_OPTION

The Park Enable option enables bus parking, which forces the arbiter to always assert the grant signal for a specific master when no other masters are requesting the bus. The master chosen for parking is either the master that was last granted the bus, or the master configured by the SetParkId function.

#### XOA\_PARK\_BY\_ID\_OPTION

The Park By ID option enables bus parking based on the specific master ID. The master ID defaults to master 0, and can be changed using **XOpbArb\_SetParkId**(). When this option is disabled, bus parking defaults to the master that was last granted the bus. The park enable option must be set for this option to take effect.

# **Function Documentation**

Xuint32 XOpbArb\_GetOptions( XOpbArb \* InstancePtr)

Gets the options for the arbiter. The options control how the device grants the bus to requesting masters.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

The options of the device. This is a bit mask where a 1 means the option is on, and a 0 means the option is off. See **xopbarb.h** for a description of the options.

#### Note:

None.

Gets the master ID currently used for bus parking.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

MasterIdPtr is a pointer to a byte that will hold the master ID currently used for bus parking. This is an output parameter. The ID can range from 0 to N, where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

XST\_SUCCESS if the park ID is successfully retrieved, or XST\_NO\_FEATURE if bus parking is not supported by the device.

#### Note:

Get the master ID at the given priority level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

Level

is the priority level being retrieved. The level can range from 0 (highest) to N (lowest), where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

The master ID assigned to the given priority level. The ID can range from 0 to N, where N is the number of masters minus one.

#### Note:

If the arbiter is operating in dynamic priority mode, the value returned from this function may not be predictable because the arbiter changes the values on the fly.

Initializes a specific **XOpbArb** instance. The driver is initialized to allow access to the device registers. In addition, the configuration information is retrieved for the device. Currently, configuration information is stored in **xopbarb\_g.c**.

The state of the device after initialization is:

- Fixed or dynamic priority arbitration based on hardware parameter
- Bus parking is disabled

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XOpbArb** component. Passing in a device id associates the generic **XOpbArb** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

The return value is XST\_SUCCESS if successful or XST\_DEVICE\_NOT\_FOUND if no configuration data was found for this device.

#### Note:

#### 

Looks up the device configuration based on the unique device ID. The table OpbArbConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceId* is the unique device ID to match on.

#### **Returns:**

A pointer to the configuration information for the matching device instance, or XNULL if no match is found.

#### Note:

None.

#### XStatus XOpbArb\_ResumePriorityLevels( XOpbArb \* InstancePtr)

Resumes use of the priority levels by the device. This function is typically called sometime after a call to SuspendPriorityLevels. The application must resume use of priority levels by the device when all modifications are done. If no call is made to this function after use of the priority levels has been suspended, the device will remain in its default priority arbitration mode of assigning priorities based on master IDs. A call to this function has no effect if no prior call was made to suspend the use of priority levels.

Every master must be represented by one and only one fixed priority level before the use of priority levels can be resumed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the slave is selected successfully.
- XST\_OPBARB\_INVALID\_PRIORITY if there is either a master that is not assigned a priority level, or a master that is assigned two mor more priority levels.

#### XStatus XOpbArb\_SelfTest( XOpbArb \* InstancePtr)

Runs a self-test on the driver/device. The self-test simply verifies that the arbiter's registers can be read and written. This is an intrusive test in that the arbiter will not be using the priority registers while the test is being performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_REGISTER\_ERROR if a register did not read or write correctly

#### Note:

The priority level registers are restored after testing them in order to prevent problems with the registers being the same value after the test.

If the arbiter is in dynamic priority mode, this test changes the mode to fixed to ensure that the priority registers aren't changed by the arbiter during this test. The mode is restored to it's entry value on exit.

```
XStatus XOpbArb_SetOptions( XOpbArb * InstancePtr,
Xuint32 Options
)
```

Sets the options for the OPB arbiter. The options control how the device grants the bus to requesting masters.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

Options contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. See **xopbarb.h** for a description of the options.

#### **Returns:**

- o XST\_SUCCESS if options are successfully set.
- o XST\_NO\_FEATURE if an attempt was made to enable dynamic priority arbitration when the device is configured only for fixed priority arbitration, or an attempt was made to enable parking when bus parking is not supported by the device.
- XST\_OPBARB\_PARK\_NOT\_ENABLED if bus parking by park ID was enabled but bus parking itself was not enabled.

```
Note:
```

None.

Sets the master ID used for bus parking. Bus parking must be enabled and the option to use bus parking by park ID must be set for this park ID to take effect (see the SetOptions function). If the option to use bus parking by park ID is set but this function is not called, bus parking defaults to master 0.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

MasterId

is the ID of the master that will be parked if bus parking is enabled. This master's grant signal remains asserted as long as no other master requests the bus. The ID can range from 0 to N, where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

XST\_SUCCESS if the park ID is successfully set, or XST\_NO\_FEATURE if bus parking is not supported by the device.

#### Note:

Assigns a master ID to the given priority level. The use of priority levels by the device must be suspended before calling this function. Every master ID must be assigned to one and only one priority level. The driver enforces this before allowing use of priority levels by the device to be resumed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

Level is the priority level being set. The level can range from 0 (highest) to N

(lowest), where N is the number of masters minus one. The device currently

supports up to 16 masters.

*MasterId* is the ID of the master being assigned to the priority level. The ID can range

from 0 to N, where N is the number of masters minus one. The device

currently supports up to 16 masters.

#### **Returns:**

- XST\_SUCCESS if the slave is selected successfully.
- XST\_OPBARB\_NOT\_SUSPENDED if priority levels have not been suspended.
   Before modifying the priority levels, use of priority levels by the device must be suspended.
- o XST\_OPBARB\_NOT\_FIXED\_PRIORITY if the arbiter is in dynamic mode. It must be in fixed mode to modify the priority levels.

#### Note:

None.

#### void XOpbArb\_SuspendPriorityLevels( XOpbArb \* InstancePtr)

Suspends use of the priority levels by the device. Before modifying priority levels, the application must first suspend use of the levels by the device. This is to prevent possible OPB problems if no master is assigned a priority during the modification of priority levels. The application must resume use of priority levels by the device when all modifications are done. During the time priority levels are suspended, the device reverts to its default behavior of assigning priorities based on master IDs.

This function can be used when the device is configured for either fixed priority arbitration or dynamic priority arbitration. When used during dynamic priority arbitration, the application can configure the priority levels as a starting point for the LRU algorithm.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

| ľ     | None. |  |
|-------|-------|--|
| Note: | None. |  |

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XOpbArb Struct Reference

#include <xopbarb.h>

# **Detailed Description**

The XOpbArb driver instance data. The user is required to allocate a variable of this type for every OPB arbiter device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• opbarb/v1\_02\_a/src/xopbarb.h

# opbarb/v1\_02\_a/src/xopbarb\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of OPB arbiter devices in the system.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.02a rpm 08/13/01 First release

#include "xopbarb.h"
#include "xparameters.h"
```

### **Variables**

XOpbArb\_Config XOpbArb\_ConfigTable [XPAR\_XOPBARB\_NUM\_INSTANCES]

# **Variable Documentation**

XOpbArb\_Config XOpbArb\_ConfigTable[XPAR\_XOPBARB\_NUM\_INSTANCES]

The OPB arbiter configuration table, sized by the number of instances defined in **xparameters.h**.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

### Main Page Data Structures File List Data Fields Globals

# XOpbArb\_Config Struct Reference

#include <xopbarb.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xuint8 NumMasters

# **Field Documentation**

Xuint32 XOpbArb\_Config::BaseAddress

Register base address

Xuint16 XOpbArb\_Config::DeviceId

Unique ID of device

Xuint8 XOpbArb\_Config::NumMasters

Number of masters on the bus

The documentation for this struct was generated from the following file:

• opbarb/v1\_02\_a/src/xopbarb.h

# opbarb/v1\_02\_a/src/xopbarb\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation. High-level driver functions are defined in **xopbarb.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 04/24/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XOpbArb_mSetControlReg(BaseAddress, RegisterValue)
#define XOpbArb_mGetControlReg(BaseAddress)
#define XOpbArb_mEnableDynamic(BaseAddress)
#define XOpbArb_mDisableDynamic(BaseAddress)
#define XOpbArb_mEnableParking(BaseAddress)
#define XOpbArb_mDisableParking(BaseAddress)
#define XOpbArb_mSetParkMasterNot(BaseAddress)
#define XOpbArb_mClearParkMasterNot(BaseAddress)
#define XOpbArb_mClearParkMasterNot(BaseAddress)
#define XOpbArb_mSetPriorityRegsValid(BaseAddress)
```

| $\# define \  \  \  \  \  \  \  \  \  \  \  \  \ $                               |  |  |
|----------------------------------------------------------------------------------|--|--|
| #define XOpbArb_mSetParkedMasterId(BaseAddress, ParkedMasterId)                  |  |  |
| #define XOpbArb_mSetPriorityReg(BaseAddress, Level, MasterId)                    |  |  |
| #define XOpbArb_mGetPriorityReg(BaseAddress, Level)                              |  |  |
|                                                                                  |  |  |
| <b>Define Documentation</b>                                                      |  |  |
| #define XOpbArb_mClearParkMasterNot( BaseAddress )                               |  |  |
| Clear park on master not last (park on a specific master ID) in the OPB Arbiter. |  |  |
| Parameters:                                                                      |  |  |
| BaseAddress contains the base address of the device.                             |  |  |
| Returns:                                                                         |  |  |
| None.                                                                            |  |  |
| Note:                                                                            |  |  |
| None.                                                                            |  |  |
|                                                                                  |  |  |
| #define XOpbArb_mClearPriorityRegsValid( BaseAddress )                           |  |  |
| Clear the priority registers valid in the Control Register of the OPB Arbiter.   |  |  |
| Parameters:                                                                      |  |  |
| BaseAddress contains the base address of the device.                             |  |  |
| Returns:                                                                         |  |  |
| None.                                                                            |  |  |
| Note:                                                                            |  |  |
| None.                                                                            |  |  |
|                                                                                  |  |  |

 ${\it \#define~XOpbArb\_mDisableDynamic(~BaseAddress~)}$ 

| Parameters:  BaseAddress contains the base address of the device.  |                 |
|--------------------------------------------------------------------|-----------------|
| Returns: None.                                                     |                 |
| Note: None.                                                        |                 |
| #define XOpbArb_mDisableParking( BaseAddress )                     |                 |
| Disable parking in the Control Register in the OPB Arbiter.        |                 |
| Parameters:  BaseAddress contains the base address of the device.  |                 |
| Returns: None.                                                     |                 |
| Note: None.                                                        |                 |
| #define XOpbArb_mEnableDynamic( BaseAddress )                      |                 |
| Enable dynamic priority arbitration in the Control Register in the | he OPB Arbiter. |
| Parameters:  BaseAddress contains the base address of the device.  |                 |
| Returns: None.                                                     |                 |
| Note: None.                                                        |                 |

#define XOpbArb\_mEnableParking( BaseAddress )

Disable dynamic priority arbitration in the Control Register in the OPB Arbiter.

| Enable parking in the Control Register in the OPB Arbiter.        |  |
|-------------------------------------------------------------------|--|
| Parameters:                                                       |  |
| BaseAddress contains the base address of the device.              |  |
| Returns:                                                          |  |
| None.                                                             |  |
| Note:                                                             |  |
| None.                                                             |  |
|                                                                   |  |
| #define XOpbArb_mGetControlReg( BaseAddress )                     |  |
| Get the Control Register of the OPB Arbiter.                      |  |
| Parameters:                                                       |  |
| BaseAddress contains the base address of the device.              |  |
| Returns:                                                          |  |
| The value read from the register.                                 |  |
| Note:                                                             |  |
| None.                                                             |  |
|                                                                   |  |
| #define XOpbArb_mGetPriorityReg( BaseAddress,                     |  |
| Level )                                                           |  |
| Get the priority register in the OPB Arbiter.                     |  |
| Parameters:                                                       |  |
| BaseAddress contains the base address of the device.              |  |
| Level contain the priority level of the register to get (0 - 15). |  |

The contents of the specified priority register, a master ID (0 - 15).

**Returns:** 

**Note:** 

# #define XOpbArb\_mSetControlReg( BaseAddress, RegisterValue )

Set the Control Register of the OPB Arbiter.

#### **Parameters:**

BaseAddress contains the base address of the device.

RegisterValue contains the value to be written to the register.

#### **Returns:**

None.

#### Note:

None.

# #define XOpbArb\_mSetParkedMasterId( BaseAddress, ParkedMasterId )

Set the parked master ID in the Control Register in the OPB Arbiter.

#### **Parameters:**

BaseAddress contains the base address of the device.

ParkedMasterId contains the ID of the master to park on (0 - 15).

#### **Returns:**

None.

#### Note:

None.

#### #define XOpbArb\_mSetParkMasterNot( BaseAddress )



| Parameters:  BaseAddress contains the base address of the device. |
|-------------------------------------------------------------------|
| Returns: None.                                                    |
| Note: None.                                                       |

Set the priority registers valid in the OPB Arbiter.

# opb2plb/v1\_00\_a/src/xopb2plb.c File Reference

# **Detailed Description**

Contains required functions for the **XOpb2Plb** component. See **xopb2plb.h** for more information about the component.

## **Functions**

```
XStatus XOpb2Plb_Initialize (XOpb2Plb *InstancePtr, Xuint16 DeviceId)
void XOpb2Plb_Reset (XOpb2Plb *InstancePtr)
Xboolean XOpb2Plb_IsError (XOpb2Plb *InstancePtr)
void XOpb2Plb_ClearErrors (XOpb2Plb *InstancePtr)
Xuint32 XOpb2Plb_GetErrorStatus (XOpb2Plb *InstancePtr)
Xuint32 XOpb2Plb_GetErrorAddress (XOpb2Plb *InstancePtr)
void XOpb2Plb_EnableInterrupt (XOpb2Plb *InstancePtr)
void XOpb2Plb_DisableInterrupt (XOpb2Plb *InstancePtr)
```

## **Function Documentation**

| void XOpb2Plb_ClearErrors( XOpb2Plb * InstancePtr)                                         |  |  |
|--------------------------------------------------------------------------------------------|--|--|
| Clears the errors. If the lock bit is set, this allows subsequent errors to be recognized. |  |  |
| Parameters:                                                                                |  |  |
| <i>InstancePtr</i> is a pointer to the <b>XOpb2Plb</b> instance to be worked on.           |  |  |
| Returns:                                                                                   |  |  |

#### Note:

None.

None.

#### void XOpb2Plb\_DisableInterrupt( XOpb2Plb \* InstancePtr)

Disables the interrupt output from the bridge

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

void XOpb2Plb\_DisableLock( XOpb2Plb \* InstancePtr)

Disables the locking of the status on error for the bridge. This 'unlocks' the status and address registers allowing subsequent errors to overwrite the current values when an error occurs.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

#### void XOpb2Plb\_EnableInterrupt( XOpb2Plb \* InstancePtr)

Enables the interrupt output from the bridge

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

void XOpb2Plb\_EnableLock( XOpb2Plb \* InstancePtr)

Enables the locking of the status on error for the bridge. This 'locks' the status and address register values when an error occurs, preventing subsequent errors from overwriting the values. Clearing the error allows the status and address registers to update with the next error that occurs

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

#### Xuint32 XOpb2Plb\_GetErrorAddress( XOpb2Plb \* InstancePtr)

Returns the PLB Address where the most recent error occured. If there isn't an outstanding error, the last address in error is returned. 0x00000000 is the initial value coming out of reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

Address where error causing access occurred

#### Note:

Calling **XOpb2Plb\_IsError**() is recommended to confirm that an error has occurred prior to calling **XOpb2Plb\_GetErrorAddress**() to ensure that the data in the error address register is relevant.

#### Xuint32 XOpb2Plb\_GetErrorStatus( XOpb2Plb \* InstancePtr)

Returns the error status indicating the type of error that has occurred.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

The current error status for the OPB to PLB bridge. The possible return values are described in **xopb2plb.h**.

#### Note:

None.

Initializes a specific **XOpb2Plb** instance. Looks up the configuration data for the given device ID and then initializes instance data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XOpb2Plb** component. Passing in a device id associates the generic **XOpb2Plb** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if everything starts up as expected.
- XST\_DEVICE\_NOT\_FOUND if the requested device is not found

#### **Note:**

None.

**Xboolean XOpb2Plb\_IsError**(**XOpb2Plb**\* *InstancePtr*)

Returns XTRUE is there is an error outstanding

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

Boolean XTRUE if there is an error, XFALSE if there is no current error.

#### **Note:**

None.

#### XOpb2Plb\_Config\* XOpb2Plb\_LookupConfig( Xuint16 DeviceId)

Looks up the device configuration based on the unique device ID. The table OpbPlbConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceId* is the unique device ID of the device to look for.

#### **Returns:**

A pointer to the configuration data of the given device, or XNULL if no match is found.

#### **Note:**

None.

#### void XOpb2Plb\_Reset( XOpb2Plb \* InstancePtr)

Forces a software-induced reset to occur in the bridge and disables interrupts and the locking functionality in the process.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

#### **Returns:**

None.

#### Note:

Disables interrupts and the locking functionality in the process.

# opb2plb/v1\_00\_a/src/xopb2plb\_i.h File Reference

# **Detailed Description**

This file contains data which is shared between files and internal to the **XOpb2Plb** component. It is intended for internal use only.

#### MODIFICATION HISTORY:

## **Variables**

XOpb2Plb\_Config XOpb2Plb\_ConfigTable []

# **Variable Documentation**

### XOpb2Plb\_Config XOpb2Plb\_ConfigTable[]( )

The OPB-to-PLB bridge configuration table, sized by the number of instances defined in **xparameters.h**.

# opb2plb/v1\_00\_a/src/xopb2plb\_selftest.c File Reference

# **Detailed Description**

Contains diagnostic self-test functions for the **XOpb2Plb** component. See **xopb2plb.h** for more information about the component.

This functionality assumes that the initialize function has been called prior to calling the self-test function.

```
MODIFICATION HISTORY:
```

## **Functions**

XStatus XOpb2Plb\_SelfTest (XOpb2Plb \*InstancePtr, Xuint32 TestAddress)

## **Function Documentation**

Runs a self-test on the driver/device.

This tests reads the provided TestAddress which is intended to cause an error Then the **XOpb2Plb\_IsError**() routine is called and if there is an error, the address is checked against the provided location and if they match XST\_SUCCESS is returned and all errors are then cleared.

If the **XOpb2Plb\_IsError**() is called and no error is indicated, XST\_FAILURE is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpb2Plb** instance to be worked on.

TestAddress is a location that should cause an error on read.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_FAILURE if the driver fails the self-test.

#### **Note:**

This test assumes that the bus error interrupts to the processor are not enabled.

# opbarb/v1\_02\_a/src/xopbarb.c File Reference

# **Detailed Description**

This component contains the implementation of the **XOpbArb** driver component.

MODIFICATION HISTORY:

## **Data Structures**

struct OptionsMap

# **Functions**

```
XStatus XOpbArb_Initialize (XOpbArb *InstancePtr, Xuint16 DeviceId)
XStatus XOpbArb_SelfTest (XOpbArb *InstancePtr)
XStatus XOpbArb_SetOptions (XOpbArb *InstancePtr, Xuint32 Options)
Xuint32 XOpbArb_GetOptions (XOpbArb *InstancePtr)
```

```
XStatus XOpbArb_SetPriorityLevel (XOpbArb *InstancePtr, Xuint8 Level, Xuint8 MasterId)

Xuint8 XOpbArb_GetPriorityLevel (XOpbArb *InstancePtr, Xuint8 Level)

void XOpbArb_SuspendPriorityLevels (XOpbArb *InstancePtr)

XStatus XOpbArb_ResumePriorityLevels (XOpbArb *InstancePtr)

XStatus XOpbArb_SetParkId (XOpbArb *InstancePtr, Xuint8 MasterId)

XStatus XOpbArb_GetParkId (XOpbArb *InstancePtr, Xuint8 *MasterIdPtr)

XOpbArb_Config * XOpbArb_LookupConfig (Xuint16 DeviceId)
```

# **Function Documentation**

#### Xuint32 XOpbArb\_GetOptions( XOpbArb \* InstancePtr)

Gets the options for the arbiter. The options control how the device grants the bus to requesting masters.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

The options of the device. This is a bit mask where a 1 means the option is on, and a 0 means the option is off. See **xopbarb.h** for a description of the options.

#### Note:

Gets the master ID currently used for bus parking.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

MasterIdPtr is a pointer to a byte that will hold the master ID currently used for bus parking. This is an output parameter. The ID can range from 0 to N, where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

XST\_SUCCESS if the park ID is successfully retrieved, or XST\_NO\_FEATURE if bus parking is not supported by the device.

#### Note:

None.

```
Xuint8 XOpbArb_GetPriorityLevel( XOpbArb * InstancePtr,
Xuint8 Level
)
```

Get the master ID at the given priority level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

Level

is the priority level being retrieved. The level can range from 0 (highest) to N (lowest), where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

The master ID assigned to the given priority level. The ID can range from 0 to N, where N is the number of masters minus one.

#### Note:

If the arbiter is operating in dynamic priority mode, the value returned from this function may not be predictable because the arbiter changes the values on the fly.

Initializes a specific **XOpbArb** instance. The driver is initialized to allow access to the device registers. In addition, the configuration information is retrieved for the device. Currently, configuration information is stored in **xopbarb\_g.c**.

The state of the device after initialization is:

- Fixed or dynamic priority arbitration based on hardware parameter
- Bus parking is disabled

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XOpbArb** component.

Passing in a device id associates the generic **XOpbArb** component to a

specific device, as chosen by the caller or application developer.

#### **Returns:**

The return value is XST\_SUCCESS if successful or XST\_DEVICE\_NOT\_FOUND if no configuration data was found for this device.

#### Note:

None.

#### 

Looks up the device configuration based on the unique device ID. The table OpbArbConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

*DeviceId* is the unique device ID to match on.

#### **Returns:**

A pointer to the configuration information for the matching device instance, or XNULL if no match is found.

#### **Note:**

None.

#### **XStatus XOpbArb\_ResumePriorityLevels( XOpbArb** \* *InstancePtr*)

Resumes use of the priority levels by the device. This function is typically called sometime after a call to SuspendPriorityLevels. The application must resume use of priority levels by the device when all modifications are done. If no call is made to this function after use of the priority levels has been suspended, the device will remain in its default priority arbitration mode of assigning priorities based on master IDs. A call to this function has no effect if no prior call was made to suspend the use of priority levels.

Every master must be represented by one and only one fixed priority level before the use of priority levels can be resumed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the slave is selected successfully.
- o XST\_OPBARB\_INVALID\_PRIORITY if there is either a master that is not assigned a priority level, or a master that is assigned two mor more priority levels.

#### Note:

None.

#### XStatus XOpbArb\_SelfTest( XOpbArb \* InstancePtr)

Runs a self-test on the driver/device. The self-test simply verifies that the arbiter's registers can be read and written. This is an intrusive test in that the arbiter will not be using the priority registers while the test is being performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_REGISTER\_ERROR if a register did not read or write correctly

#### Note:

The priority level registers are restored after testing them in order to prevent problems with the registers being the same value after the test.

If the arbiter is in dynamic priority mode, this test changes the mode to fixed to ensure that the priority registers aren't changed by the arbiter during this test. The mode is restored to it's entry value on exit.

Sets the options for the OPB arbiter. The options control how the device grants the bus to requesting masters.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

**Options** 

contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. See **xopbarb.h** for a description of the options.

#### **Returns:**

- o XST\_SUCCESS if options are successfully set.
- XST\_NO\_FEATURE if an attempt was made to enable dynamic priority arbitration when the device is configured only for fixed priority arbitration, or an attempt was made to enable parking when bus parking is not supported by the device.
- XST\_OPBARB\_PARK\_NOT\_ENABLED if bus parking by park ID was enabled but bus parking itself was not enabled.

#### Note:

None.

Sets the master ID used for bus parking. Bus parking must be enabled and the option to use bus parking by park ID must be set for this park ID to take effect (see the SetOptions function). If the option to use bus parking by park ID is set but this function is not called, bus parking defaults to master 0.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

*MasterId* i

is the ID of the master that will be parked if bus parking is enabled. This master's grant signal remains asserted as long as no other master requests the bus. The ID can range from 0 to N, where N is the number of masters minus one. The device currently supports up to 16 masters.

#### **Returns:**

XST\_SUCCESS if the park ID is successfully set, or XST\_NO\_FEATURE if bus parking is not supported by the device.

#### Note:

None.

Assigns a master ID to the given priority level. The use of priority levels by the device must be suspended before calling this function. Every master ID must be assigned to one and only one priority level. The driver enforces this before allowing use of priority levels by the device to be resumed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

Level is the priority level being set. The level can range from 0 (highest) to N

(lowest), where N is the number of masters minus one. The device currently

supports up to 16 masters.

MasterId is the ID of the master being assigned to the priority level. The ID can range

from 0 to N, where N is the number of masters minus one. The device

currently supports up to 16 masters.

#### **Returns:**

- o XST SUCCESS if the slave is selected successfully.
- XST\_OPBARB\_NOT\_SUSPENDED if priority levels have not been suspended.
   Before modifying the priority levels, use of priority levels by the device must be suspended.
- XST\_OPBARB\_NOT\_FIXED\_PRIORITY if the arbiter is in dynamic mode. It must be in fixed mode to modify the priority levels.

#### Note:

None.

Suspends use of the priority levels by the device. Before modifying priority levels, the application must first suspend use of the levels by the device. This is to prevent possible OPB problems if no master is assigned a priority during the modification of priority levels. The application must resume use of priority levels by the device when all modifications are done. During the time priority levels are suspended, the device reverts to its default behavior of assigning priorities based on master IDs.

This function can be used when the device is configured for either fixed priority arbitration or dynamic priority arbitration. When used during dynamic priority arbitration, the application can configure the priority levels as a starting point for the LRU algorithm.

| 1 | _ |   |   |   |     |   |   |   |    |    |   |
|---|---|---|---|---|-----|---|---|---|----|----|---|
| 1 | v | വ | r | വ | n   | n | Δ | 1 | ום | rs | • |
| ы | L | а |   | а | . u | ш |   | и | ◡. |    | ٠ |

*InstancePtr* is a pointer to the **XOpbArb** instance to be worked on.

| Retur | ns:<br>None. |  |  |  |  |
|-------|--------------|--|--|--|--|
| Note: | None.        |  |  |  |  |

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> <u>Main Page</u> <u>Data Structures</u> <u>File List</u> <u>Data Fields</u> <u>Globals</u>

# plb2opb/v1\_00\_a/src/xplb2opb.h File Reference

# **Detailed Description**

This component contains the implementation of the **XPlb2Opb** component. It is the driver for the PLB to OPB Bridge. The bridge converts PLB bus transactions to OPB bus transactions. The hardware acts as a slave on the PLB side and as a master on the OPB side. This interface is necessary for the processor to access OPB based peripherals.

This driver allows the user to access the Bridge registers to support the handling of bus errors and other access errors and determine an appropriate solution if possible.

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

The Xilinx PLB to OPB Bridge is a soft IP core designed for Xilinx FPGAs and contains the following features:

- PLB Slave interface
- 32-bit or 64-bit PLB Slave (configurable via a design parameter)
- Communicates with 32- or 64-bit PLB masters
- Non-burst transfers of 1-8 bytes
- Burst transfers, including word and double-word bursts of fixed or variable lengths, up to depth of burst buffer. Buffer depth configurable via a design parameter
- Limited support for byte, half-word, quad-word and octal-word bursts to maintain PLB compliance
- Cacheline transactions of 4, 8, and 16 words
- Support for transactions not utilized by the PPC405 Core can be eliminated via a design parameter
- PPC405 Core only utilizes single beat, 4, 8, or 16 word line transfers support for burst transactions can be eliminated via a design parameter
- Supports up to 8 PLB masters (number of PLB masters configurable via a design parameter)
- Programmable lower and upper address boundaries
- OPB Master interface with byte enable transfers *Note*: Does not support dynamic bus sizing without additional glue logic
- Data width configurable via a design parameter
- PLB and OPB clocks can have a 1:1, 1:2, 1:4 synchronous relationship
- Bus Error Address Registers (BEAR) and Bus Error Status Registers (BESR) to report errors
- DCR Slave interface provides access to BEAR/BESR
- BEAR, BESR, and DCR interface can be removed from the design via a design parameter
- Posted write buffer. Buffer depth configurable via a design parameter

#### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. The current configuration data contained in **xplb2opb\_g.c**. A table is defined where each entry contains configuration information for device. This information includes such things as the base address of the DCR mapped device, and the number of masters on the bus.

#### Note:

This driver is not thread-safe. Thread safety must be guaranteed by the layer above this driver if there is a need to access the device from multiple threads.

The Bridge registers reside on the DCR address bus.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XPlb2Opb
struct XPlb2Opb_Config
```

# PLB-OPB bridge error status masks

```
#define XP2O_DRIVING_BEAR_MASK
#define XP2O_ERROR_READ_MASK
#define XP2O_ERROR_TYPE_MASK
#define XP2O_LOCK_ERR_MASK
```

#### **Functions**

```
XStatus XPlb2Opb_Initialize (XPlb2Opb *InstancePtr, Xuint16 DeviceId)
void XPlb2Opb_Reset (XPlb2Opb *InstancePtr)
XPlb2Opb_Config * XPlb2Opb_LookupConfig (Xuint16 DeviceId)
Xboolean XPlb2Opb_IsError (XPlb2Opb *InstancePtr)
```

```
void XPlb2Opb_ClearErrors (XPlb2Opb *InstancePtr, Xuint8 Master)
Xuint32 XPlb2Opb_GetErrorStatus (XPlb2Opb *InstancePtr, Xuint8 Master)
Xuint32 XPlb2Opb_GetErrorAddress (XPlb2Opb *InstancePtr)
Xuint32 XPlb2Opb_GetErrorByteEnables (XPlb2Opb *InstancePtr)
Xuint8 XPlb2Opb_GetMasterDrivingError (XPlb2Opb *InstancePtr)
Xuint8 XPlb2Opb_GetNumMasters (XPlb2Opb *InstancePtr)
void XPlb2Opb_EnableInterrupt (XPlb2Opb *InstancePtr)
void XPlb2Opb_DisableInterrupt (XPlb2Opb *InstancePtr)
XStatus XPlb2Opb_SelfTest (XPlb2Opb *InstancePtr, Xuint32 TestAddress)
```

## **Define Documentation**

| #define XP2O_DRIV | ING_BEAR_MASK |
|-------------------|---------------|
|-------------------|---------------|

| XP2O_DRIVING_BEAR_MASK | Indicates this master is driving the       |
|------------------------|--------------------------------------------|
|                        | outstanding error                          |
| XP2O_ERROR_READ_MASK   | Indicates the error is a read error. It is |
|                        | a write error otherwise.                   |
| XP2O_ERROR_TYPE_MASK   | If set, the error was a timeout. Otherwise |
|                        | the error was an error acknowledge         |
| XP2O_LOCK_ERR_MASK     | Indicates the error is locked and cannot   |
|                        | be overwritten.                            |

#### #define XP2O\_ERROR\_READ\_MASK

| XP2O_DRIVING_BEAR_MASK | Indicates this master is driving the outstanding error              |
|------------------------|---------------------------------------------------------------------|
| XP2O_ERROR_READ_MASK   | Indicates the error is a read error. It is a write error otherwise. |
| XP2O_ERROR_TYPE_MASK   | If set, the error was a timeout. Otherwise                          |
|                        | the error was an error acknowledge                                  |
| XP2O_LOCK_ERR_MASK     | Indicates the error is locked and cannot                            |
|                        | be overwritten.                                                     |

#### #define XP2O\_ERROR\_TYPE\_MASK

| XP2O_DRIVING_BEAR_MASK | Indicates this master is driving the       |
|------------------------|--------------------------------------------|
|                        | outstanding error                          |
| XP2O_ERROR_READ_MASK   | Indicates the error is a read error. It is |
|                        | a write error otherwise.                   |
| XP2O_ERROR_TYPE_MASK   | If set, the error was a timeout. Otherwise |
|                        | the error was an error acknowledge         |
| XP2O_LOCK_ERR_MASK     | Indicates the error is locked and cannot   |
|                        | be overwritten.                            |

#### #define XP2O\_LOCK\_ERR\_MASK

|                              | es this master is driving the       |
|------------------------------|-------------------------------------|
| outstan                      | ding error                          |
| XP20_ERROR_READ_MASK Indicat | es the error is a read error. It is |
| a write                      | error otherwise.                    |
| XP2O_ERROR_TYPE_MASK If set, | the error was a timeout. Otherwise  |
| the err                      | or was an error acknowledge         |
| XP2O_LOCK_ERR_MASK Indicat   | es the error is locked and cannot   |
| be over                      | written.                            |

# **Function Documentation**

Clears any outstanding errors for the given master.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

Master of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

#### **Returns:**

None.

#### Note:

None.

Disables the interrupt output from the bridge

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

#### void XPlb2Opb\_EnableInterrupt( XPlb2Opb \* InstancePtr)

Enables the interrupt output from the bridge

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

#### Xuint32 XPlb2Opb\_GetErrorAddress( XPlb2Opb \* InstancePtr)

Returns the OPB Address where the most recent error occurred If there isn't an outstanding error, the last address in error is returned. 0x000000000 is the initial value coming out of reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

Address where error causing access occurred

#### Note:

Calling **XPlb2Opb\_IsError**() is recommended to confirm that an error has occurred prior to calling **XPlb2Opb\_GetErrorAddress**() to ensure that the data in the error address register is relevant.

#### Xuint32 XPlb2Opb\_GetErrorByteEnables( XPlb2Opb \* InstancePtr)

Returns the byte-enables asserted during the access causing the error. The enables are parameters in the hardware making the return value dynamic. An example of a 32-bit bus with all 4 byte enables available, XPlb2Opb GetErrorByteEnables will have the value 0xF0000000 returned from a 32-bit access error.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

The byte-enables asserted during the error causing access.

#### **Note:**

None.

Returns the error status for the specified master.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

*Master* of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

#### **Returns:**

The current error status for the requested master on the PLB. The status is a bit-mask and the values are described in **xplb2opb.h**.

#### Note:

None.

#### Xuint8 XPlb2Opb\_GetMasterDrivingError( XPlb2Opb \* InstancePtr)

Returns the ID of the master which is driving the error condition

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

The ID of the master that is driving the error

#### Note:

None.

#### Xuint8 XPlb2Opb\_GetNumMasters( XPlb2Opb \* InstancePtr)

Returns the number of masters associated with the provided instance

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

The number of masters. This is a number from 1 to the maximum of 32.

#### Note:

The value returned from this call needs to be adjusted if it is to be used as the argument for other calls since the masters are numbered from 0 and this function returns values starting at 1.

Initializes a specific **XPlb2Opb** instance. Looks for configuration data for the specified device, then initializes instance data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

**DeviceId** 

is the unique id of the device controlled by this **XPlb2Opb** component. Passing in a device id associates the generic **XPlb2Opb** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST\_DEVICE\_NOT\_FOUND if the requested device is not found

#### **Note:**

None.

Xboolean XPlb2Opb\_IsError( XPlb2Opb \* InstancePtr)



*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

Boolean XTRUE if there is an error, XFALSE if there is no current error.

Note:

None.

#### 

Looks up the device configuration based on the unique device ID. The table PlbOpbConfigTable contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId is the unique device ID to look for

#### **Returns:**

A pointer to the configuration data for the given device, or XNULL if no match is found.

#### Note:

None.

#### void XPlb2Opb\_Reset( XPlb2Opb \* InstancePtr)

Forces a software-induced reset to occur in the bridge. Disables interrupts in the process.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

Disables interrupts in the process.

Runs a self-test on the driver/device.

This tests reads the BCR to verify that the proper value is there.

XST\_SUCCESS is returned if expected value is there, XST\_PLB2OPB\_FAIL\_SELFTEST is returned otherwise.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

*TestAddress* is a location that could cause an error on read, not used - user definable for hw specific implementations.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_PLB2OPB\_FAIL\_SELFTEST if the driver fails self-test.

#### Note:

This test assumes that the bus error interrupts are not enabled.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# XPIb2Opb Struct Reference

#include <xplb2opb.h>

# **Detailed Description**

The XPlb2Opb driver instance data. The user is required to allocate a variable of this type for every PLB-to\_OPB bridge device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• plb2opb/v1\_00\_a/src/xplb2opb.h

# plb2opb/v1\_00\_a/src/xplb2opb\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of PLB-to-OPB bridge devices in the system. Each bridge device should have an entry in this table.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 11/16/01 First release
1.00a rpm 05/14/02 Made configuration typedef/lookup public

#include "xplb2opb.h"

#include "xparameters.h"
```

## **Variables**

XPlb2Opb\_Config XPlb2Opb\_ConfigTable [XPAR\_XPLB2OPB\_NUM\_INSTANCES]

## **Variable Documentation**

#### XPlb2Opb\_Config XPlb2Opb\_ConfigTable[XPAR\_XPLB2OPB\_NUM\_INSTANCES]

The PLB-to-OPB bridge configuration table, sized by the number of instances defined in **xparameters.h**.

## Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# XPIb2Opb\_Config Struct Reference

#include <xplb2opb.h>

# **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xuint8 NumMasters

# **Field Documentation**

Xuint32 XPlb2Opb\_Config::BaseAddress

Base address of device

Xuint16 XPlb2Opb\_Config::DeviceId

Unique ID of device

Xuint8 XPlb2Opb\_Config::NumMasters

Number of masters on the bus

The documentation for this struct was generated from the following file:

• plb2opb/v1\_00\_a/src/xplb2opb.h

# plb2opb/v1\_00\_a/src/xplb2opb\_l.h File Reference

# **Detailed Description**

This file contains identifiers and low-level macros that can be used to access the device directly. See **xplb2opb.h** for the high-level driver.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 05/10/02 First release

#include "xbasic_types.h"
#include "xio.h"
#include "xio.dcr.h"
```

### **Defines**

```
#define XPlb2Opb_mSetErrorDetectReg(BaseAddress)
#define XPlb2Opb_mSetErrorDetectReg(BaseAddress, Mask)
#define XPlb2Opb_mGetMasterDrivingReg(BaseAddress)
#define XPlb2Opb_mGetReadWriteReg(BaseAddress)
#define XPlb2Opb_mGetErrorTypeReg(BaseAddress)
#define XPlb2Opb_mGetLockBitReg(BaseAddress)
#define XPlb2Opb_mGetErrorAddressReg(BaseAddress)
#define XPlb2Opb_mGetByteEnableReg(BaseAddress)
#define XPlb2Opb_mGetByteEnableReg(BaseAddress)
#define XPlb2Opb_mSetControlReg(BaseAddress, Mask)
```

# **Define Documentation**

#### #define XPlb2Opb\_mGetByteEnableReg( BaseAddress )

Get the erorr address byte enable register.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

The 32-bit error address byte enable register contents.

#### Note:

None.

#### #define XPlb2Opb\_mGetControlReg( BaseAddress )

Get the contents of the control register.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

The 32-bit value of the control register.

#### Note:

None.

#### $\#define \ XPlb2Opb\_mGetErrorAddressReg(\ BaseAddress\ )$

 ${\it \#define~XPlb2Opb\_mGetLockBitReg(~BaseAddress~)}$ 



# ${\it \#define~XPlb2Opb\_mSetControlReg(~BaseAddress,}$ Mask Set the control register to the given value. **Parameters:** BaseAddress is the base address of the device is the value to write to the control register. Mask **Returns:** None. Note: None. #define XPlb2Opb\_mSetErrorDetectReg( BaseAddress, Mask Set the error detect register. **Parameters:** BaseAddress is the base address of the device is the 32-bit value to write to the error detect register. Mask Note: None.

# pci/v1\_00\_a/src/xpci\_intr.c File Reference

# **Detailed Description**

Implements PCI interrupt processing functions for the **XPci** component. See **xpci.h** for more information about the component.

```
MODIFICATION HISTORY:
```

```
        Ver
        Who
        Date
        Changes

        -----
        -----
        ------

        1.00a
        rmm
        03/25/02
        Original code
```

```
#include "xpci.h"
```

## **Functions**

```
void XPci_InterruptGlobalEnable (XPci *InstancePtr)
void XPci_InterruptEnable (XPci *InstancePtr, Xuint32 Mask)
void XPci_InterruptEnable (XPci *InstancePtr, Xuint32 Mask)
void XPci_InterruptDisable (XPci *InstancePtr, Xuint32 Mask)
void XPci_InterruptClear (XPci *InstancePtr, Xuint32 Mask)
Xuint32 XPci_InterruptGetEnabled (XPci *InstancePtr)
Xuint32 XPci_InterruptGetStatus (XPci *InstancePtr)
Xuint32 XPci_InterruptGetPending (XPci *InstancePtr)
Xuint32 XPci_InterruptGetHighestPending (XPci *InstancePtr)
void XPci_InterruptCiEnable (XPci *InstancePtr, Xuint32 Mask)
void XPci_InterruptPciDisable (XPci *InstancePtr, Xuint32 Mask)
```

```
void XPci_InterruptPciClear (XPci *InstancePtr, Xuint32 Mask)
Xuint32 XPci_InterruptPciGetEnabled (XPci *InstancePtr)
Xuint32 XPci_InterruptPciGetStatus (XPci *InstancePtr)
void XPci_AckSend (XPci *InstancePtr, Xuint32 Vector)
Xuint32 XPci_AckRead (XPci *InstancePtr)
void XPci_SpecialCycle (XPci *InstancePtr, Xuint32 Data)
```

# **Function Documentation**

```
Xuint32 XPci_AckRead( XPci * InstancePtr)
```

Read the contents of the PCI interrupt acknowledge vector register.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

System dependent interrupt vector.

#### Note:

None

```
void XPci_AckSend( XPci * InstancePtr, Xuint32 Vector
)
```

Generate a PCI interrupt acknowledge bus cycle with the given vector.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

*Vector* is a system dependent interrupt vector to place on the bus.

#### Note:

```
void XPci_InterruptClear( XPci * InstancePtr,
Xuint32 Mask
)
```

Clear device level pending interrupts with the provided mask.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask is the mask to clear pending interrupts for. Bit positions of 1 are cleared. This

mask is formed by OR'ing bits from XPCI\_IPIF\_INT\_MASK

#### Note:

None

```
void XPci_InterruptDisable( XPci * InstancePtr, Xuint32 Mask
)
```

Disable device interrupts. Any component interrupts enabled through **XPci\_InterruptPciEnable()** and/or the DMA driver will no longer have any effect. The component interrupt settings will be retained however.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask is the mask to disable. Bits set to 1 are disabled. The mask is formed by

OR'ing bits from XPCI\_IPIF\_INT\_MASK

#### Note:

Enable device interrupts. Device interrupts must be enabled by this function before component interrupts enabled by **XPci\_InterruptPciEnable()** and/or the DMA driver have any effect.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

*Mask* is the

is the mask to enable. Bit positions of 1 are enabled. The mask is formed by OR'ing bits from XPCI\_IPIF\_INT\_MASK.

Note:

None

#### Xuint32 XPci\_InterruptGetEnabled( XPci \* InstancePtr)

Returns the device level interrupt enable mask as set by **XPci\_InterruptEnable**().

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK.

**Note:** 

None

#### Xuint32 XPci\_InterruptGetHighestPending( XPci \* InstancePtr)

Returns the highest priority pending device interrupt that has been enabled by **XPci\_InterruptEnable()**.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask is one set bit made from XPCI\_IPIF\_INT\_MASK or zero if no interrupts are pending.

#### Note:

#### Xuint32 XPci\_InterruptGetPending( XPci \* InstancePtr)

Returns the pending status of device level interrupt signals that have been enabled by **XPci\_InterruptEnable**(). Any bit in the mask set to 1 indicates that an interrupt is pending from the given component

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK or zero if no interrupts are pending.

#### Note:

None

#### Xuint32 XPci\_InterruptGetStatus( XPci \* InstancePtr)

Returns the status of device level interrupt signals. Any bit in the mask set to 1 indicates that the given component has asserted an interrupt condition.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK.

#### **Note:**

The interrupt status indicates the status of the device irregardless if the interrupts from the devices have been enabled or not through **XPci\_InterruptEnable()**.

#### void XPci\_InterruptGlobalDisable( XPci \* InstancePtr)

Disable the core's interrupt output signal. Interrupts enabled through **XPci\_InterruptEnable()** and **XPci\_InterruptPciEnable()** will no longer be passed through until the IPIF global enable bit is set by **XPci\_InterruptGlobalEnable()**.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Note:

None

#### void XPci\_InterruptGlobalEnable( XPci \* InstancePtr)

Enable the core's interrupt output signal. Interrupts enabled through **XPci\_InterruptEnable()** and **XPci\_InterruptPciEnable()** will not be passed through until the IPIF global enable bit is set by this function.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Note:

None

```
void XPci_InterruptPciClear( XPci *
                                     InstancePtr,
                            Xuint32 Mask
                           )
```

Clear PCI bridge specific interrupt status bits with the provided mask.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

is the mask to clear pending interrupts for. Bit positions of 1 are cleared. This Mask

mask is formed by OR'ing bits from XPCI\_IR\_MASK

Note:

Disable PCI bridge specific interrupts.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask is

is the mask to disable. Bits set to 1 are disabled. The mask is formed by

OR'ing bits from XPCI\_IR\_MASK

#### Note:

None

```
void XPci_InterruptPciEnable( XPci * InstancePtr, Xuint32 Mask
)
```

Enable PCI bridge specific interrupts. Before this function has any effect in generating interrupts, the function **XPci\_InterruptEnable()** must be invoked with the XPCI\_IPIF\_INT\_PCI bit set.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to enable. Bit positions of 1 are enabled. The mask is formed by OR'ing bits from XPCI\_IR\_MASK.

#### Note:

None

Xuint32 XPci\_InterruptPciGetEnabled( XPci \* InstancePtr)

Get the PCI bridge specific interrupts enabled through **XPci\_InterruptPciEnable**(). Bits set to 1 mean that interrupt source is enabled.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of enabled bits made from XPCI\_IR\_MASK.

#### **Note:**

None

#### Xuint32 XPci\_InterruptPciGetStatus( XPci \* InstancePtr)

Get the status of PCI bridge specific interrupts that have been asserted Bits set to 1 are in an asserted state. Bits may be set to 1 irregardless of whether they have been enabled or not though **XPci\_InterruptPciEnable()**. To get the pending interrupts, AND the results of this function with **XPci\_InterruptPciGetEnabled()**.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of enabled bits made from XPCI\_IR\_MASK.

#### Note:

Broadcasts a message to all listening PCI targets.

#### **Parameters:**

InstancePtr is the PCI component to operate on.

Data is the data to broadcast.

**Note:** 

None

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

# **XPci Struct Reference**

#include <xpci.h>

# **Detailed Description**

The XPci driver instance data. The user is required to allocate a variable of this type for every PCI device in the system that will be using this API. A pointer to a variable of this type is passed to the driver API functions defined here.

# **Data Fields**

Xuint32 RegBaseAddr Xuint32 DmaRegBaseAddr Xuint32 IsReady

**Xuint8 DmaType** 

# **Field Documentation**

Xuint32 XPci::DmaRegBaseAddr

Base address of DMA (if included)

#### Xuint8 XPci::DmaType

Type of DMA (if enabled), see XPCI\_DMA\_TYPE constants in xpci\_l.h

# Xuint32 XPci::IsReady

Device is initialized and ready

### Xuint32 XPci::RegBaseAddr

Base address of registers

The documentation for this struct was generated from the following file:

• pci/v1\_00\_a/src/xpci.h

# pci/v1\_00\_a/src/xpci\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined and more PCI documentation is in **xpci.h**.

PCI configuration read/write macro functions can be changed so that data is swapped before being written to the configuration addess/data registers. As delivered in this file, these macros do not swap. Change the definitions of **XIo\_InPci**() and **XIo\_OutPci**() in this file to suit system needs.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00a rmm 05/19/02 First release

#include "xbasic_types.h"
#include "xio.h"
#include "xio.h"
```

# Registers

Register offsets for this device. Note that the following IPIF registers are implemented. Macros are defined to specifically access these registers without knowing which version of IPIF being used.

```
#define XPCI_PREOVRD_OFFSET
#define XPCI_IAR_OFFSET
#define XPCI_SC_DATA_OFFSET
#define XPCI_CAR_OFFSET
```

```
#define XPCI_CDR_OFFSET

#define XPCI_BUSNO_OFFSET

#define XPCI_STATCMD_OFFSET

#define XPCI_STATV3_OFFSET

#define XPCI_INHIBIT_OFFSET

#define XPCI_LMADDR_OFFSET

#define XPCI_LMA_R_OFFSET

#define XPCI_LMA_W_OFFSET

#define XPCI_SERR_R_OFFSET

#define XPCI_SERR_W_OFFSET

#define XPCI_PIADDR_OFFSET

#define XPCI_PIA_R_OFFSET

#define XPCI_PIA_R_OFFSET
```

# Interrupt Status and Enable Register bitmaps and masks

Bit definitions for the interrupt status register and interrupt enable registers.

```
#define XPCI_IR_MASK

#define XPCI_IR_LM_SERR_R

#define XPCI_IR_LM_PERR_R

#define XPCI_IR_LM_TA_R

#define XPCI_IR_LM_SERR_W

#define XPCI_IR_LM_PERR_W

#define XPCI_IR_LM_TA_W

#define XPCI_IR_LM_MA_W

#define XPCI_IR_LM_BR_W

#define XPCI_IR_LM_BRD_W

#define XPCI_IR_LM_BRT_W

#define XPCI_IR_LM_BRT_W

#define XPCI_IR_LM_BRANGE_W

#define XPCI_IR_PI_SERR_R

#define XPCI_IR_PI_SERR_W
```

# Inhibit transfers on errors register bitmaps and masks.

These bits contol whether subsequent PCI transactions are allowed after an error occurs. Bits set to 1 inhibit further transactions, while bits set to 0 allow further transactions after an error.

```
#define XPCI_INHIBIT_MASK

#define XPCI_INHIBIT_LOCAL_BUS_R

#define XPCI_INHIBIT_LOCAL_BUS_W

#define XPCI_INHIBIT_PCI_R

#define XPCI_INHIBIT_PCI_W
```

# PCI configuration status & command register bitmaps and masks.

Bit definitions for the PCI configuration status & command register. The definition of this register is standard for PCI devices.

```
#define XPCI_STATCMD_IO_EN
#define XPCI_STATCMD_MEM_EN
#define XPCI_STATCMD_BUSM_EN
#define XPCI STATCMD SPECIALCYC
#define XPCI_STATCMD_MEMWR_INV_EN
#define XPCI_STATCMD_VGA_SNOOP_EN
#define XPCI_STATCMD_PARITY
#define XPCI_STATCMD_STEPPING
#define XPCI STATCMD SERR EN
#define XPCI STATCMD BACK EN
#define XPCI_STATCMD_INT_DISABLE
#define XPCI_STATCMD_INT_STATUS
#define XPCI_STATCMD_66MHZ_CAP
#define XPCI_STATCMD_MPERR
#define XPCI_STATCMD_DEVSEL_MSK
#define XPCI STATCMD DEVSEL FAST
#define XPCI STATCMD DEVSEL MED
#define XPCI STATCMD TGTABRT SIG
#define XPCI_STATCMD_TGTABRT_RCV
#define XPCI STATCMD MSTABRT RCV
#define XPCI_STATCMD_SERR_SIG
#define XPCI_STATCMD_PERR_DET
#define XPCI_STATCMD_ERR_MASK
```

# V3 core transaction status register bitmaps and masks.

Bit definitions for the V3 core transaction status register. This register consists of status information on V3 core transactions.

```
#define XPCI_STATV3_MASK

#define XPCI_STATV3_DATA_XFER

#define XPCI_STATV3_TRANS_END

#define XPCI_STATV3_NORM_TERM

#define XPCI_STATV3_TGT_TERM

#define XPCI_STATV3_DISC_WODATA

#define XPCI_STATV3_DISC_WDATA

#define XPCI_STATV3_TGT_ABRT

#define XPCI_STATV3_MASTER_ABRT

#define XPCI_STATV3_PCI_RETRY_R

#define XPCI_STATV3_PCI_RETRY_W

#define XPCI_STATV3_WRITE_BUSY
```

# Bus number and subordinate bus number register bitmaps and masks

```
#define XPCI_BUSNO_BUS_MASK #define XPCI_BUSNO_SUBBUS_MASK
```

# Local bus master address register bitmaps and masks

Bit definitions for the local bus master address definition register. This register defines the meaning of the address stored in the local bus master read (XPCI\_LMA\_R\_OFFSET) and master write error (XPCI\_LMA\_W\_OFFSET) registers.

```
#define XPCI_LMADDR_MASK #define XPCI_LMADDR_SERR_R
```

```
#define XPCI_LMADDR_PERR_R
#define XPCI_LMADDR_TA_R
#define XPCI_LMADDR_SERR_W
#define XPCI_LMADDR_PERR_W
#define XPCI_LMADDR_TA_W
#define XPCI_LMADDR_MA_W
#define XPCI_LMADDR_BR_W
#define XPCI_LMADDR_BRD_W
#define XPCI_LMADDR_BRT_W
#define XPCI_LMADDR_BRT_W
#define XPCI_LMADDR_BRANGE_W
```

# PCI error address definition bitmaps and masks

Bit definitions for the PCI address definition register. This register defines the meaning of the address stored in the PCI read error address (XPCI\_PIA\_R\_OFFSET) and PCI write error address (XPCI\_PIA\_W\_OFFSET) registers.

```
#define XPCI_PIADDR_MASK
#define XPCI_PIADDR_ERRACK_R
#define XPCI_PIADDR_ERRACK_W
#define XPCI_PIADDR_RETRY_W
#define XPCI_PIADDR_TIMEOUT_W
#define XPCI_PIADDR_RANGE_W
```

# PCI configuration header offsets

Defines the offsets in the standard PCI configuration header

```
#define XPCI_HDR_VENDOR

#define XPCI_HDR_DEVICE

#define XPCI_HDR_COMMAND

#define XPCI_HDR_STATUS

#define XPCI_HDR_REVID

#define XPCI_HDR_CLASSCODE

#define XPCI_HDR_CACHE_LINE_SZ

#define XPCI_HDR_LATENCY

#define XPCI_HDR_TYPE

#define XPCI_HDR_BIST
```

```
#define XPCI_HDR_BAR1

#define XPCI_HDR_BAR1

#define XPCI_HDR_BAR2

#define XPCI_HDR_BAR3

#define XPCI_HDR_BAR4

#define XPCI_HDR_BAR5

#define XPCI_HDR_CARDBUS_PTR

#define XPCI_HDR_SUB_VENDOR

#define XPCI_HDR_SUB_DEVICE

#define XPCI_HDR_ROM_BASE

#define XPCI_HDR_CAP_PTR

#define XPCI_HDR_INT_LINE

#define XPCI_HDR_INT_LINE

#define XPCI_HDR_MIN_GNT

#define XPCI_HDR_MIN_GNT
```

# **PCI BAR register definitions**

Defines the masks and bits for the PCI XPAR\_HDR\_BARn registers The bridge supports the first three BARs in the PCI configuration header

```
#define XPCI_HDR_NUM_BAR

#define XPCI_HDR_BAR_ADDR_MASK

#define XPCI_HDR_BAR_PREFETCH_YES

#define XPCI_HDR_BAR_PREFETCH_NO

#define XPCI_HDR_BAR_TYPE_MASK

#define XPCI_HDR_BAR_TYPE_BELOW_4GB

#define XPCI_HDR_BAR_TYPE_BELOW_1MB

#define XPCI_HDR_BAR_TYPE_ABOVE_4GB

#define XPCI_HDR_BAR_TYPE_RESERVED

#define XPCI_HDR_BAR_SPACE_IO

#define XPCI_HDR_BAR_SPACE_MEMORY
```

# **DMA** type constants

Defines the types of DMA engines

#define XPCI\_DMA\_TYPE\_NONE

# **Defines**

```
#define XPci mReset(BaseAddress)
#define XPci mIntrGlobalEnable(BaseAddress)
#define XPci_mIntrGlobalDisable(BaseAddress)
#define XPci_mIntrEnable(BaseAddress, Mask)
#define XPci_mIntrDisable(BaseAddress, Mask)
#define XPci_mIntrClear(BaseAddress, Mask)
#define XPci_mIntrReadIER(BaseAddress)
#define XPci_mIntrReadISR(BaseAddress)
#define XPci mIntrWriteISR(BaseAddress, Mask)
#define XPci_mIntrReadIPR(BaseAddress)
#define XPci_mIntrReadID(BaseAddress)
#define XPci_mIntrPciEnable(BaseAddress, Mask)
#define XPci_mIntrPciDisable(BaseAddress, Mask)
#define XPci mIntrPciClear(BaseAddress, Mask)
#define XPci_mIntrPciReadIER(BaseAddress)
#define XPci_mIntrPciReadISR(BaseAddress)
#define XPci_mIntrPciWriteISR(BaseAddress, Mask)
#define XPci_mReadReg(BaseAddress, RegOffset)
#define XPci_mWriteReg(BaseAddress, RegOffset, Data)
#define XPci_mConfigIn(BaseAddress, ConfigAddress, ConfigData)
#define XPci mConfigOut(BaseAddress, ConfigAddress, ConfigData)
#define XPci mAckSend(BaseAddress, Vector)
#define XPci mAckRead(BaseAddress)
#define XPci_mSpecialCycle(BaseAddress, Data)
#define XPci_mLocal2Pci(LocalAddr, TO)
#define XPci_mPci2Local(PciAddr, TO)
```

# **Define Documentation**

# #define XPCI\_BUSNO\_BUS\_MASK

Mask for bus number

#### #define XPCI\_BUSNO\_OFFSET

bus/subordinate bus numbers

# #define XPCI\_BUSNO\_SUBBUS\_MASK

Mask for subordinate bus no

#### #define XPCI\_CAR\_OFFSET

Config addr reg (port)

# #define XPCI\_CDR\_OFFSET

Config command data

#### #define XPCI\_DMA\_TYPE\_NONE

No DMA

# #define XPCI\_DMA\_TYPE\_SG

Scatter-gather DMA

#### #define XPCI\_DMA\_TYPE\_SIMPLE

Simple DMA

# #define XPCI\_HDR\_BAR0

Base address 0

#### #define XPCI\_HDR\_BAR1

Base address 1

# #define XPCI\_HDR\_BAR2

Base address 2

# #define XPCI\_HDR\_BAR3

Base address 3

# #define XPCI\_HDR\_BAR4

### #define XPCI\_HDR\_BAR5

Base address 5

# #define XPCI\_HDR\_BAR\_ADDR\_MASK

Base address mask

#### #define XPCI\_HDR\_BAR\_PREFETCH\_NO

Range is not prefetchable

#### #define XPCI\_HDR\_BAR\_PREFETCH\_YES

Range is prefetchable

#### #define XPCI\_HDR\_BAR\_SPACE\_IO

IO space indicator

#### #define XPCI\_HDR\_BAR\_SPACE\_MEMORY

Memory space indicator

#### #define XPCI\_HDR\_BAR\_TYPE\_ABOVE\_4GB

Locate anywhere above 4GB

#### #define XPCI\_HDR\_BAR\_TYPE\_BELOW\_1MB

Reserved in PCI 2.2

#### #define XPCI\_HDR\_BAR\_TYPE\_BELOW\_4GB

Locate anywhere below 4GB

#### #define XPCI\_HDR\_BAR\_TYPE\_MASK

Memory type mask

#### #define XPCI\_HDR\_BAR\_TYPE\_RESERVED

Reserved

## #define XPCI\_HDR\_BIST

Built in self test

# #define XPCI\_HDR\_CACHE\_LINE\_SZ

Cache line size

# #define XPCI\_HDR\_CAP\_PTR

Capabilities pointer

# #define XPCI\_HDR\_CARDBUS\_PTR

Cardbus CIS pointer

# #define XPCI\_HDR\_CLASSCODE

Class code

#### #define XPCI\_HDR\_COMMAND

Command register

# #define XPCI\_HDR\_DEVICE

Device ID

# #define XPCI\_HDR\_INT\_LINE

Interrupt line

# #define XPCI\_HDR\_INT\_PIN

Interrupt pin

#### #define XPCI\_HDR\_LATENCY

Latency timer

# #define XPCI\_HDR\_MAX\_LAT

Priority level request

## #define XPCI\_HDR\_MIN\_GNT

Timeslice request

# #define XPCI\_HDR\_NUM\_BAR

Number of BARs in the PCI header

# #define XPCI\_HDR\_REVID

**Revision ID** 

#### #define XPCI\_HDR\_ROM\_BASE

Expansion ROM base address

#### #define XPCI\_HDR\_STATUS

Status register

# #define XPCI\_HDR\_SUB\_DEVICE

Subsystem ID

#### #define XPCI\_HDR\_SUB\_VENDOR

Subsystem Vendor ID

#### #define XPCI\_HDR\_TYPE

Header type

#### #define XPCI\_HDR\_VENDOR

Vendor ID

#### #define XPCI\_IAR\_OFFSET

PCI interrupt ack

# #define XPCI\_INHIBIT\_LOCAL\_BUS\_R

Local bus master reads

# #define XPCI\_INHIBIT\_LOCAL\_BUS\_W

# #define XPCI\_INHIBIT\_MASK

Mask for all bits defined below

# #define XPCI\_INHIBIT\_OFFSET

Inhibit transfers on errors

# #define XPCI\_INHIBIT\_PCI\_R

PCI initiator reads

# #define XPCI\_INHIBIT\_PCI\_W

PCI initiator writes

#### #define XPCI\_IR\_LM\_BR\_W

Local bus master burst write retry

## #define XPCI\_IR\_LM\_BRANGE\_W

Local bus master burst write range

#### #define XPCI\_IR\_LM\_BRD\_W

Local bus master burst write retry disconnect

# #define XPCI\_IR\_LM\_BRT\_W

Local bus master burst write retry timeout

## #define XPCI\_IR\_LM\_MA\_W

Local bus master abort write

#### #define XPCI\_IR\_LM\_PERR\_R

Local bus master read PERR

#### #define XPCI\_IR\_LM\_PERR\_W

Local bus master write PERR

# #define XPCI\_IR\_LM\_SERR\_R

Local bus master read SERR

# #define XPCI\_IR\_LM\_SERR\_W

Local bus master write SERR

# #define XPCI\_IR\_LM\_TA\_R

Local bus master read target abort

# #define XPCI\_IR\_LM\_TA\_W

Local bus master write target abort

# #define XPCI\_IR\_MASK

Mask of all bits

# #define XPCI\_IR\_PI\_SERR\_R

PCI initiator read SERR

# #define XPCI\_IR\_PI\_SERR\_W

PCI initiator write SERR

#### #define XPCI\_LMA\_R\_OFFSET

Local bus master read error address

# #define XPCI\_LMA\_W\_OFFSET

Local bus master write error address

#### #define XPCI\_LMADDR\_BR\_W

Master burst write retry

# #define XPCI\_LMADDR\_BRANGE\_W

Master burst write range

## #define XPCI\_LMADDR\_BRD\_W

Master burst write retry disconnect

#### #define XPCI\_LMADDR\_BRT\_W

Master burst write retry timeout

#### #define XPCI\_LMADDR\_MA\_W

Master abort write

#### #define XPCI\_LMADDR\_MASK

Mask of all bits

#### #define XPCI\_LMADDR\_OFFSET

Local bus master address definition

#### #define XPCI\_LMADDR\_PERR\_R

Master read PERR

## #define XPCI\_LMADDR\_PERR\_W

Master write PERR

#### #define XPCI\_LMADDR\_SERR\_R

Master read SERR

#### #define XPCI\_LMADDR\_SERR\_W

Master write SERR

#### #define XPCI\_LMADDR\_TA\_R

Master read target abort

#### #define XPCI\_LMADDR\_TA\_W

Master write target abort

#### #define XPci\_mAckRead( BaseAddress )



Low level PCI configuration read

C-style signature: void XPci\_mConfigIn(Xuint32 BaseAddress, Xuint32 ConfigAddress, Xuint32 ConfigData)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

ConfigAddress is the PCI configuration space address in a packed format.

ConfigData is the data read from the ConfigAddress

#### **Returns:**

Data from configuration address

Note:

None

# #define XPci\_mConfigOut( BaseAddress,

ConfigAddress, ConfigData

Low level PCI configuration write

C-style signature: void XPci\_mConfigOut(Xuint32 BaseAddress, Xuint32 ConfigAddress, Xuint32 ConfigData)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

ConfigAddress is the PCI configuration space address in a packed format.

ConfigData is the data to write at the ConfigAddress

#### **Returns:**

None

Note:

None

# #define XPci\_mIntrClear( BaseAddress, Mask

Clear pending interrupts in the device interrupt status register (DISR) This is a toggle on write register.

C-style signature: void **XPci\_mIntrClear**(Xuint32 BaseAddress, Xuint32 Mask)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

Mask

is the group of interrupts to clear. Use a logical OR of constants in XPCI\_IPIF\_INT\_MASK. Bits set to 1 are cleared, bits set to 0 are not

affected.

#### **Returns:**

None

Note:

None

# #define XPci\_mIntrDisable( BaseAddress, Mask )

Disable interrupts in the device interrupt enable register (DIER)

C-style signature: void **XPci\_mIntrDisable**(Xuint32 BaseAddress, Mask)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

Mask

is the group of interrupts to disable. Use a logical OR of constants in

XPCI\_IPIF\_INT\_MASK. Bits set to 1 are disabled, bits set to 0 are not

affected.

#### **Returns:**

None

Note:

None

```
#define XPci_mIntrEnable( BaseAddress, Mask
```

Enable interrupts in the device interrupt enable register (DIER) C-style signature: void **XPci\_mIntrEnable**(Xuint32 BaseAddress, Mask) **Parameters:** BaseAddress is the base address of the PCI component. Mask is the group of interrupts to enable. Use a logical OR of constants in XPCI\_IPIF\_INT\_MASK. Bits set to 1 are enabled, bits set to 0 are not affected. **Returns:** None Note: None #define XPci\_mIntrGlobalDisable( BaseAddress )

Global interrupt disable. Disable all interrupts from this core. Any interrupts enabled by **XPci\_mIntrEnable()** or **XPci\_mIntrPciEnable()** are disabled, however their settings remain unchanged.

C-style signature: void **XPci\_mIntrGlobalDisable**(Xuint32 BaseAddress)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

#### **Returns:**

None

#### Note:

None

#### #define XPci\_mIntrGlobalEnable( BaseAddress )

| XPci_mIntrPciEnable() have any effect.                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C-style signature: void <b>XPci_mIntrGlobalEnable</b> (Xuint32 BaseAddress)                                                                                                                                                       |
| Parameters:  BaseAddress is the base address of the PCI component.                                                                                                                                                                |
| Returns: None                                                                                                                                                                                                                     |
| Note: None                                                                                                                                                                                                                        |
| #define XPci_mIntrPciClear( BaseAddress,                                                                                                                                                                                          |
| Clear PCI specific interrupts in the interrupt status register (IISR). This is a toggle on write register.                                                                                                                        |
| C-style signature: void <b>XPci_mIntrPciClear</b> (Xuint32 BaseAddress, Xuint32 Mask)                                                                                                                                             |
| Parameters:  BaseAddress is the base address of the PCI component.  Mask is the group of interrupts to clear. Use a logical OR of constants in XPCI_IR_MASK. Bits set to 1 are cleared, bits set to 0 are not affected.  Returns: |
| None                                                                                                                                                                                                                              |
| Note: None                                                                                                                                                                                                                        |
| #define XPci_mIntrPciDisable( BaseAddress, Mask )                                                                                                                                                                                 |
|                                                                                                                                                                                                                                   |

Global interrupt enable. Must be called before any interupts enabled by **XPci\_mIntrEnable()** or

Disable PCI specific interrupt sources in the PCI interrupt enable register (IIER) C-style signature: void **XPci\_mIntrPciDisable**(Xuint32 BaseAddress, Xuint32 Mask) **Parameters:** BaseAddress is the base address of the PCI component. Mask is the group of interrupts to disable. Bits set to 1 are disabled, bits set to 0 are not affected. The mask is made up by OR'ing bits from XPCI\_IR\_MASK. **Returns:** 

None

Note:

None

#define XPci\_mIntrPciEnable( BaseAddress, Mask

Enable PCI specific interrupt sources in the PCI interrupt enable register (IIER)

C-style signature: void **XPci\_mIntrPciEnable**(Xuint32 BaseAddress, Xuint32 Mask)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

Mask

is the group of interrupts to enable. Bits set to 1 are enabled, bits set to 0 are not affected. The mask is made up by OR'ing bits from XPCI\_IR\_MASK.

**Returns:** 

None

Note:

None

#define XPci\_mIntrPciReadIER( BaseAddress )

| Pand the contents of the PCI specific interrupt anable register (IIEP)                                     |
|------------------------------------------------------------------------------------------------------------|
| Read the contents of the PCI specific interrupt enable register (IIER)                                     |
| C-style signature: Xuint32 XPci_mIntrPciReadIER(Xuint32 BaseAddress)                                       |
| Parameters:  BaseAddress is the base address of the PCI component.                                         |
| Returns:  Contents of the pending interrupt register. The mask is made up of bits defined in XPCI_IR_MASK. |
| Note: None                                                                                                 |
| define XPci_mIntrPciReadISR( BaseAddress )                                                                 |
| Read the contents of the PCI specific interrupt status register (IISR)                                     |
| C-style signature: Xuint32 XPci_mIntrPciReadISR(Xuint32 BaseAddress)                                       |
| Parameters:                                                                                                |
| BaseAddress is the base address of the PCI component.                                                      |
| Returns:  Contents of the pending interrupt register. The mask is made up of bits defined in XPCI_IR_MASK. |
| Note: None                                                                                                 |

#define XPci\_mIntrPciWriteISR( BaseAddress, Mask

Write to the PCI interrupt status register (IISR)

C-style signature: void **XPci\_mIntrPciWriteISR**(Xuint32 BaseAddress, Xuint32 Mask)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

Mask

is the value to write to the register and is assumed to be bits or'd together

from the XPCI\_IR\_MASK.

#### **Returns:**

None

Note:

None

#### #define XPci\_mIntrReadID( BaseAddress )

Read the contents of the device interrupt ID register (DIIR).

C-style signature: Xuint32 **XPci\_mIntrReadID**(Xuint32 BaseAddress)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

#### **Returns:**

Value of the register.

Note:

None

#### #define XPci\_mIntrReadIER( BaseAddress )

| Read the contents of the device interrupt enable register (DIER)                                     |
|------------------------------------------------------------------------------------------------------|
| C-style signature: Xuint32 XPci_mIntrReadIER(Xuint32 BaseAddress)                                    |
| Parameters:  BaseAddress is the base address of the PCI component.                                   |
| Returns: Value of the register.                                                                      |
| Note: None                                                                                           |
| #define XPci_mIntrReadIPR( BaseAddress )                                                             |
| Read the contents of the device interrupt pending register (DIPR).                                   |
| C-style signature: Xuint32 XPci_mIntrReadIPR(Xuint32 BaseAddress)                                    |
| Parameters:  BaseAddress is the base address of the PCI component.  Returns:  Value of the register. |
| Note: None                                                                                           |
| #define XPci_mIntrReadISR( BaseAddress )                                                             |
|                                                                                                      |



Convert local bus address to a PCI address

C-style signature: Xuint32 XPci\_mLocal2Pci(Xuint32 LocalAddress, Xuint32 TranslationOffset)

#### **Parameters:**

LocalAddress is the local address to find the equivalent PCI address for.

*TO* is the translation offset to apply

#### **Returns:**

Address in PCI space

#### Note:

IPIFBAR\_n, IPIFHIGHADDR\_n, and IPIFBAR2PCI\_n, defined in **xparameters.h**, are defined for each BAR. To make a proper conversion, LocalAddress must fall within range of a IPIFBAR\_n and IPIFHIGHADDR\_n pair and TO specified must be the matching IPIFBAR2PCI\_n. Example: pciAddr = XPci\_mLocal2Pci(XPAR\_PCI\_IPIFBAR\_0, XPAR\_PCI\_IPIFBAR2PCI\_0) finds the PCI equivalent address for the local address named by XPAR\_PCI\_IPIFBAR\_0.

# #define XPci\_mPci2Local( PciAddr, TO

Convert PCI address to a local bus address

C-style signature: Xuint32 XPci\_mPci2Local(Xuint32 PciAddress, Xuint32 TranslationOffset)

#### **Parameters:**

*PciAddress* is the PCI address to find the equivalent local address for.

*TO* is the translation offset to apply

#### **Returns:**

Address in local space

#### Note:

PCIBAR\_n, PCIBAR\_LEN\_n, and PCIBAR2IPIF\_n, defined in **xparameters.h**, are defined for each BAR. To make a proper conversion, PciAddress must fall within range of a PCIBAR\_n and PCIBAR\_LEN\_n pair and TO specified must be the matching PCIBAR2IPIF\_n. Example: localAddr = XPci\_mPci2Local( XPAR\_PCI\_PCIBAR\_0, XPAR\_PCI\_PCIBAR2IPIF\_0) finds the local address that corresponds to XPAR\_PCI\_PCIBAR\_0 on the PCI bus. Note that PCIBAR\_LEN is expressed as a power of 2.

# #define XPci\_mReadReg( BaseAddress, RegOffset )

Low level register read function.

C-style signature: Xuint32 XPci\_mReadReg(Xuint32 BaseAddress, Xuint32 RegOffset)

#### **Parameters:**

*BaseAddress* is the base address of the PCI component.

*RegOffset* is the register offset.

#### **Returns:**

Value of the register.

#### Note:

None

# #define XPci\_mReset( BaseAddress )

IPIF Low level PCI reset function. Reset the V3 core.

C-style signature: void **XPci\_mReset**(Xuint32 BaseAddress)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

#### **Returns:**

None

#### Note:

The IPIF RESETR register is located at (base + 0x80) instead of (base + 0x40) where the IPIF component driver expects it. This macro adjusts for this difference.

# #define XPci\_mSpecialCycle( BaseAddress, Data

Broadcasts a message to all listening PCI targets.

C-style signature: Xuint32 XPci\_mSpecialCycle(Xuint32 BaseAddress, Xuint32 Data)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

Data is the data to broadcast.

#### **Returns:**

None

Note:

None

# ${\it \#define~XPci\_mWriteReg(~BaseAddress,}$

RegOffset,

Data )

Low level register write function.

C-style signature: void **XPci\_mWriteReg**(Xuint32 BaseAddress, Xuint32 RegOffset, Xuint32 Data)

#### **Parameters:**

BaseAddress is the base address of the PCI component.

RegOffset is the register offset.

Data is the data to write.

#### **Returns:**

None

Note:

None

# #define XPCI\_PIA\_R\_OFFSET

PCI read error address

#### #define XPCI\_PIA\_W\_OFFSET

# #define XPCI\_PIADDR\_ERRACK\_R

PCI initiator read ErrAck

# #define XPCI\_PIADDR\_ERRACK\_W

PCI initiator write ErrAck

## #define XPCI\_PIADDR\_MASK

Mask of all bits

# #define XPCI\_PIADDR\_OFFSET

PCI address definition

## #define XPCI\_PIADDR\_RANGE\_W

PCI initiator write range

## #define XPCI\_PIADDR\_RETRY\_W

PCI initiator write retries

#### #define XPCI\_PIADDR\_TIMEOUT\_W

PCI initiator write timeout

# #define XPCI\_PREOVRD\_OFFSET

Prefetch override

# #define XPCI\_SC\_DATA\_OFFSET

Special cycle data

#### #define XPCI\_SERR\_R\_OFFSET

PCI initiater read SERR address

#### #define XPCI\_SERR\_W\_OFFSET

PCI initiater write SERR address

# #define XPCI\_STATCMD\_66MHZ\_CAP

66MHz capable

# #define XPCI\_STATCMD\_BACK\_EN

Fast back-to-back enable

# #define XPCI\_STATCMD\_BUSM\_EN

Bus master enable

# #define XPCI\_STATCMD\_DEVSEL\_FAST

Device select timing fast

# #define XPCI\_STATCMD\_DEVSEL\_MED

Device select timing medium

# #define XPCI\_STATCMD\_DEVSEL\_MSK

Device select timing mask

# #define XPCI\_STATCMD\_ERR\_MASK

Error bits or'd together

# #define XPCI\_STATCMD\_INT\_DISABLE

Interrupt disable (PCI v2.3)

# #define XPCI\_STATCMD\_INT\_STATUS

Interrupt status (PCI v2.3)

#### #define XPCI\_STATCMD\_IO\_EN

I/O access enable

# #define XPCI\_STATCMD\_MEM\_EN

Memory access enable

## #define XPCI\_STATCMD\_MEMWR\_INV\_EN

Memory write & invalidate

#### #define XPCI\_STATCMD\_MPERR

Master data PERR detected

#### #define XPCI\_STATCMD\_MSTABRT\_RCV

Received master abort

#### #define XPCI\_STATCMD\_OFFSET

PCI config status/command

#### #define XPCI\_STATCMD\_PARITY

Report parity errors

#### #define XPCI\_STATCMD\_PERR\_DET

Detected PERR

#### #define XPCI\_STATCMD\_SERR\_EN

SERR report enable

#### #define XPCI\_STATCMD\_SERR\_SIG

Signaled SERR

#### #define XPCI\_STATCMD\_SPECIALCYC

Special cycles

#### #define XPCI\_STATCMD\_STEPPING

Stepping control

#### #define XPCI\_STATCMD\_TGTABRT\_RCV

Received target abort

#### #define XPCI\_STATCMD\_TGTABRT\_SIG

### #define XPCI\_STATCMD\_VGA\_SNOOP\_EN

VGA palette snoop enable

#### #define XPCI\_STATV3\_DATA\_XFER

Data transfer. Read only

#### #define XPCI\_STATV3\_DISC\_WDATA

Disconnect with data. Read only

#### #define XPCI\_STATV3\_DISC\_WODATA

Disconnect without data. Read only

#### #define XPCI\_STATV3\_MASK

Mask of all bits

# #define XPCI\_STATV3\_MASTER\_ABRT

Master abort. Read only

# #define XPCI\_STATV3\_NORM\_TERM

Normal termination. Read only

#### #define XPCI\_STATV3\_OFFSET

V3 core transaction status

# #define XPCI\_STATV3\_PCI\_RETRY\_R

PCI retry on read. Read/write

#### #define XPCI\_STATV3\_PCI\_RETRY\_W

PCI retry on write. Read/write

# #define XPCI\_STATV3\_TGT\_ABRT

Target abort. Read only

# ${\it \#define~XPCI\_STATV3\_TGT\_TERM}$

Target termination. Read only

# ${\it \#define~XPCI\_STATV3\_TRANS\_END}$

Transaction end. Read only

# ${\it \#define~XPCI\_STATV3\_WRITE\_BUSY}$

Write busy. Read only

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# pci/v1\_00\_a/src/xpci.h File Reference

# **Detailed Description**

This file contains the software API definition of the Xilinx PCI bridge (**XPci**) component. This component bridges between local bus IPIF and the Xilinx LogiCORE PCI64 Interface v3.0 core. It provides full bridge functionality between the local bus a 32 bit V2.2 compliant PCI bus.

#### **Features**

This driver allows the user to access the device's registers to perform PCI configuration read and write access, error detection and processing, and interrupt management.

The Xilinx PCI bridge controller is a soft IP core designed for Xilinx FPGAs and contains the following features:

- Supports 32 bit OPB local bus
- PCI V2.2 Complient
- Robust error reporting and diagnostics
- DMA capable

#### **Interrupt Management**

The **XPci** component driver provides interrupt management functions. Implementation of callback handlers is left to the user. Refer to the provided PCI code fragments in the examples directory.

The PCI bridge IP core uses the IPIF to manage interrupts from devices within it. Devices in this core include the PCI bridge itself and an optional DMA engine. To manage interrupts from these devices, a three layer approach is utilized and is modeled on the IPIF.

Device specific interrupt control is at the lowest layer. This is where individual sources are managed. For example, PCI Master Abort or DMA complete interrupts are enabled/disabled/cleared here. The **XPci** function API that manages this layer is identified as XPci\_InterruptPci<operation>(). DMA interrupts at this layer are managed by the XDma\_Channel software component.

The middle layer is utilized to manage interrupts at a device level. For example, enabling PCI interrupts at this layer allows any PCI device specific interrupt enabled at the lowest layer to be passed up to the highest layer. The XPCI function API that manages this layer is identified as XPci\_Interrupt<operation>().

The middle layer serves little purpose when there is no DMA engine and can largely be ignored. During initialization, use XPci\_InterruptEnable(..., XPCI\_IPIF\_INT\_PCI) to allow all PCI interrupts enabled at the lowest layer to pass through. After this operation, the middle layer can be forgotten.

The highest layer is simply a global interrupt enable/disable switch that allows all or none of the enabled interrupts to be passed on to an interrupt controller. The **XPci** function API that manages this level is identified as XPci\_InterruptGlobal<operation>().

#### **DMA**

The PCI bridge can include a DMA engine in HW. The **XPci** software driver can be used to query which type of DMA engine has been implemented and manage interrupts. The application is required to initialize an XDma\_Channel component driver and provide an interrupt service routine to service DMA exceptions. Example DMA management code is provided in the examples directory.

#### Note:

This driver is intended to be used to bridge across multiple types of buses (PLB or OPB). While the register set will remain the same for all buses, their bit definitions may change slightly from bus to bus. The differences that arise out of this are clearly documented in this file.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00a rmm 04/15/03 First release

#include "xbasic_types.h"
#include "xstatus.h"
#include "xpci_l.h"
```

# **Data Structures**

```
struct XPci
struct XPci_Config
struct XPciError
```

# **Functions**

```
XStatus XPci_Initialize (XPci *InstancePtr, Xuint16 DeviceId, int BusNo, int SubBusNo)
    void XPci_Reset (XPci *InstancePtr)
Xuint32 XPci_ConfigPack (unsigned Bus, unsigned Device, unsigned Function)
Xuint32 XPci_ConfigIn (XPci *InstancePtr, Xuint32 ConfigAddress, Xuint8 Offset)
```

```
void XPci_ConfigOut (XPci *InstancePtr, Xuint32 ConfigAddress, Xuint8 Offset, Xuint32
              ConfigData)
         void XPci_ErrorGet (XPci *InstancePtr, XPciError *ErrorDataPtr)
         void XPci_ErrorClear (XPci *InstancePtr, XPciError *ErrorDataPtr)
         void XPci InhibitAfterError (XPci *InstancePtr, Xuint32 Mask)
         void XPci SetBusNumber (XPci *InstancePtr, int BusNo, int SubBusNo)
         void XPci GetBusNumber (XPci *InstancePtr, int *BusNoPtr, int *SubBusNoPtr)
         void XPci_GetDmaImplementation (XPci *InstancePtr, Xuint32 *BaseAddr, Xuint8 *DmaType)
XPci Config * XPci LookupConfig (Xuint16 DeviceId)
      XStatus XPci_ConfigIn8 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned
              Offset, Xuint8 *Data)
      XStatus XPci ConfigIn16 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func,
              unsigned Offset, Xuint16 *Data)
      XStatus XPci_ConfigIn32 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func,
              unsigned Offset, Xuint32 *Data)
      XStatus XPci ConfigOut8 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func,
              unsigned Offset, Xuint8 Data)
      XStatus XPci ConfigOut16 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func,
              unsigned Offset, Xuint16 Data)
      XStatus XPci ConfigOut32 (XPci *InstancePtr, unsigned Bus, unsigned Device, unsigned Func,
              unsigned Offset, Xuint32 Data)
         void XPci InterruptGlobalEnable (XPci *InstancePtr)
         void XPci_InterruptGlobalDisable (XPci *InstancePtr)
         void XPci_InterruptEnable (XPci *InstancePtr, Xuint32 Mask)
         void XPci_InterruptDisable (XPci *InstancePtr, Xuint32 Mask)
         void XPci InterruptClear (XPci *InstancePtr, Xuint32 Mask)
     Xuint32 XPci InterruptGetEnabled (XPci *InstancePtr)
     Xuint32 XPci_InterruptGetStatus (XPci *InstancePtr)
     Xuint32 XPci_InterruptGetPending (XPci *InstancePtr)
     Xuint32 XPci_InterruptGetHighestPending (XPci *InstancePtr)
         void XPci_InterruptPciEnable (XPci *InstancePtr, Xuint32 Mask)
         void XPci InterruptPciDisable (XPci *InstancePtr, Xuint32 Mask)
         void XPci_InterruptPciClear (XPci *InstancePtr, Xuint32 Mask)
     Xuint32 XPci_InterruptPciGetEnabled (XPci *InstancePtr)
     Xuint32 XPci_InterruptPciGetStatus (XPci *InstancePtr)
         void XPci AckSend (XPci *InstancePtr, Xuint32 Vector)
     Xuint32 XPci AckRead (XPci *InstancePtr)
         void XPci_SpecialCycle (XPci *InstancePtr, Xuint32 Data)
     Xuint32 XPci_V3StatusCommandGet (XPci *InstancePtr)
     Xuint32 XPci_V3TransactionStatusGet (XPci *InstancePtr)
         void XPci V3TransactionStatusClear (XPci *InstancePtr, Xuint32 Data)
      XStatus XPci SelfTest (XPci *InstancePtr)
```

# **Function Documentation**

#### Xuint32 XPci\_AckRead( XPci \* InstancePtr)

Read the contents of the PCI interrupt acknowledge vector register.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

System dependent interrupt vector.

Note:

None

Generate a PCI interrupt acknowledge bus cycle with the given vector.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

*Vector* is a system dependent interrupt vector to place on the bus.

Note:

None

Perform a 32 bit configuration read transaction.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

ConfigAddress contains the address of the PCI device to access. It should be properly formatted for

writing to the PCI configuration access port. (see **XPci\_ConfigPack**())

Offset is the register offset within the PCI device being accessed.

#### **Returns:**

32 bit data word from addressed device

## Note:

This function performs the same type of operation that XPci\_ConfigIn32, does except the user must format the ConfigAddress

```
XStatus XPci_ConfigIn16( XPci * InstancePtr,

unsigned Bus,

unsigned Device,

unsigned Func,

unsigned Offset,

Xuint16 * Data
```

Perform a 16 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.Device is the target device number.

Func is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

### **Returns:**

- o XST\_SUCCESS Operation was successfull.
- o XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

# Note:

```
XStatus XPci_ConfigIn32( XPci * InstancePtr,

unsigned Bus,

unsigned Device,

unsigned Func,

unsigned Offset,

Xuint32 * Data

)
```

Perform a 32 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

### **Returns:**

- o XST\_SUCCESS Operation was successfull.
- o XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

# Note:

None

```
XStatus XPci_ConfigIn8( XPci * InstancePtr,

unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint8 * Data

)
```

Perform a 8 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

Func is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

# **Returns:**

- XST\_SUCCESS Operation was successfull.
- XST\_PCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

### Note:

Perform a 32 bit configuration write transaction.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

ConfigAddress contains the address of the PCI device to access. It should be properly formatted for

writing to the PCI configuration access port. (see **XPci\_ConfigPack**())

Offset is the register offset within the PCI device being accessed.

ConfigData is the data to write to the addressed device.

#### Note:

This function performs the same type of operation that XPci\_ConfigOutWord, does except the user must format the Car.

```
XStatus XPci_ConfigOut16( XPci * InstancePtr,

unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint16 Data
)
```

Perform a 16 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

## **Returns:**

- o XST SUCCESS Operation was successfull.
- o XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

# Note:

```
XStatus XPci_ConfigOut32( XPci * InstancePtr,
unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint32 Data
)
```

Perform a 32 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

#### **Returns:**

- o XST\_SUCCESS Operation was successfull.
- o XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

### Note:

None

Perform a 8 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

#### **Returns:**

- XST\_SUCCESS Operation was successfull.
- o XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

Note:

None

```
Xuint32 XPci_ConfigPack( unsigned Bus, unsigned Device, unsigned Function
```

Pack configuration address data.

### **Parameters:**

Bus is the PCI bus number. Valid range 0..255.

Device is the PCI device number. Valid range 0..31.

Function is the PCI function number. Valid range 0..7.

### **Returns:**

Encoded Bus, Device & Function formatted to be written to PCI configuration address register.

### Note:

None

Clear errors associated with the PCI bridge. Which errors are cleared depend on the Reason attributes of the ErrorData parameter. For every bit set, that corresponding error is cleared.

**XPci\_ErrorGet()** and **XPci\_ErrorClear()** are designed to be used in tandem. Use ErrorGet to retrieve the errors, then ErrorClear to clear the error state.

XPci\_ErrorGet(ThisInstance, &Errors) if (Errors->IsError) { // Handle error XPci\_ErrorClear(ThisInstance, &Errors); }

If it is desired to clear some but not all errors, or a specific set of errors, then prepare ErrorData Bitmap attributes appropriately. If it is desired to clear all errors indiscriminately, then use XPCI\_CLEAR\_ALL\_ERRORS. This has the advantage of not requiring the caller to explicitly setup an XPciError structure.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

ErrorDataPtr is used to determine which error conditions to clear. Only the Bitmap attributes are used. Addr attributes of this structure are ignored. If this parameter is set to XPCI\_CLEAR\_ALL\_ERRORS then all errors are cleared.

### Note:

If PciSerrReason attribute is set or XPCI\_CLEAR\_ALL\_ERRORS is passed, then the IPIF interrupt status register bits associated with SERR are cleared. This has the same effect as acknowledging an interrupt. If you don't intend on doing this, then clear PciSerrReason before calling XPci\_ErrorClear.

Get a snapshot of the PCI bridge's error state, summarize and place results in an **XPciError** structure. Several bridge registers are read and their contents placed into the structure as follows. Register definitions and their bitmaps are located in **xpci\_l.h**:

| Attribute         | Source Register    |
|-------------------|--------------------|
|                   |                    |
| LocalBusReason    | XPCI_LMADDR_OFFSET |
| PciReason         | XPCI_PIADDR_OFFSET |
| PciSerrReason     | IPIF IISR          |
| LocalBusReadAddr  | XPCI_LMA_R_OFFSET  |
| LocalBusWriteAddr | XPCI_LMA_W_OFFSET  |
| PciSerrReadAddr   | XPCI_SERR_R_OFFSET |
| PciSerrWriteAddr  | XPCI_SERR_W_OFFSET |
| PciReadAddr       | XPCI_PIA_R_OFFSET  |
| PciWriteAddr      | XPCI_PIA_W_OFFSET  |

LocalBusReadAddr, LocalBusWriteAddr, PciSerrReadAddr, PciSerrWriteAddr, PCIReadAddr, and PciWriteAddr are all error addresses whose contents are latched at the time of the error.

LocalBusReason and PciReason are present to allow the caller to precicely determine the source of the error. The summary below indicates which bits cause the associated error address to become valid and which interrupt bits from interrupt status register are the cause if the error was reported via an interrupt.

### LocalBusReason:

| Bit                  | Error addr is valid | Associated Interrupt bit |
|----------------------|---------------------|--------------------------|
|                      |                     |                          |
| XPCI_LMADDR_SERR_R   | LocalBusReadAddr    | XPCI_IR_LM_SERR_R        |
| XPCI_LMADDR_PERR_R   | LocalBusReadAddr    | XPCI_IR_LM_PERR_R        |
| XPCI_LMADDR_TA_R     | LocalBusReadAddr    | XPCI_IR_LM_TA_R          |
| XPCI_LMADDR_SERR_W   | LocalBusWriteAddr   | XPCI_IR_LM_SERR_W        |
| XPCI_LMADDR_PERR_W   | LocalBusWriteAddr   | XPCI_IR_LM_PERR_W        |
| XPCI_LMADDR_TA_W     | LocalBusWriteAddr   | XPCI_IR_LM_TA_W          |
| XPCI_LMADDR_MA_W     | LocalBusWriteAddr   | XPCI_IR_LM_MA_W          |
| XPCI_LMADDR_BR_W     | LocalBusWriteAddr   | XPCI_IR_LM_BR_W          |
| XPCI_LMADDR_BRD_W    | LocalBusWriteAddr   | XPCI_IR_LM_BRD_W         |
| XPCI_LMADDR_BRT_W    | LocalBusWriteAddr   | XPCI_IR_LM_BRT_W         |
| XPCI_LMADDR_BRANGE_W | LocalBusWriteAddr   | XPCI_IR_LM_BRANGE_W      |
|                      |                     |                          |

## PciReason:

| Bit                   | Error addr is valid | Associated Interrupt bit |
|-----------------------|---------------------|--------------------------|
|                       |                     |                          |
| XPCI_PIADDR_ERRACK_R  | PciReadAddr         | N/A                      |
| XPCI_PIADDR_ERRACK_W  | PciWriteAddr        | N/A                      |
| XPCI_PIADDR_RETRY_W   | PciWriteAddr        | N/A                      |
| XPCI_PIADDR_TIMEOUT_W | PciWriteAddr        | N/A                      |
| XPCI_PIADDR_RANGE_W   | PciWriteAddr        | N/A                      |
| PciReasonSerr:        |                     |                          |
| Bit                   | Error addr is valid | Associated Interrupt bit |
|                       |                     |                          |
| XPCI_IR_PI_SERR_R     | PciSerrReadAddr     | XPCI_IR_PI_SERR_R        |
| XPCI_IR_PI_SERR_W     | PciSerrWriteAddr    | XPCI_IR_PI_SERR_W        |

If any of the above mentioned error reason bits are set, then attribute IsError is set to XTRUE. If no errors are detected, then it is set to XFALSE.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

ErrorData is the error snapshot data returned from the PCI bridge.

# Note:

None

Get the bus number and subordinate bus number of the pci bridge.

## **Parameters:**

InstancePtr is the PCI component to operate onBusNoPtr is storage to place the bus number

SubBusNoPtr is storage to place the subordinate bus number

# Note:

Get the DMA engine implementation information for this instance.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

BaseAddr is a return value indicating the base address of the DMA registers.

*DmaType* is a return value indicating the type of DMA implemented. The possible types are

XPCI DMA TYPE NONE for no DMA, XPCI DMA TYPE SIMPLE for simple

DMA, and XPCI\_DMA\_TYPE\_SG for scatter-gather DMA.

### Note:

None

Change how the bridge handles subsequent PCI transactions after errors occur. Transactions can be prohibited once an error occurs then allowed again once the error is cleared. Or transactions are be allowed to continue despite an error condition.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

defines the type of transactions affected. OR together bits from XPCI\_INHIBIT\_\* to form the mask. Bits set to 1 will cause transactions to be inhibited when an error exists. Bits set to 0 will allow transactions to proceed.

## Note:

Initialize the **XPci** instance provided by the caller based on the given DeviceID.

Initialization includes setting up the bar registers in the bridge's PCI header to match the IPIF settings. Not performing this step will cause the the IPIF to not respond to PCI bus hits.

# **Parameters:**

*InstancePtr* is a pointer to an XPci instance. The memory the pointer references must be pre-

allocated by the caller. Further calls to manipulate the component through the XPci API

must be made with this pointer.

is the unique id of the device controlled by this **XPci** component. Passing in a device id *DeviceId* 

associates the generic **XPci** instance to a specific device, as chosen by the caller or

application developer.

is the initial PCI bus number to assign to the host bridge. This value can be changed BusNo

later with a call to **XPci\_SetBusNumber**()

SubBusNo is the initial PCI sub-bus number to assign to the host bridge This value can be changed

later with a call to **XPci\_SetBusNumber**()

### **Returns:**

- XST\_SUCCESS Initialization was successfull.
- o XST DEVICE NOT FOUND Device configuration data was not found for a device with the supplied device ID.

### Note:

None

```
void XPci_InterruptClear( XPci *
                                 InstancePtr,
                        Xuint32 Mask
                       )
```

Clear device level pending interrupts with the provided mask.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask is the mask to clear pending interrupts for. Bit positions of 1 are cleared. This mask is

formed by OR'ing bits from XPCI\_IPIF\_INT\_MASK

### Note:

```
void XPci InterruptDisable( XPci *
                                   InstancePtr,
                          Xuint32 Mask
```

Disable device interrupts. Any component interrupts enabled through **XPci\_InterruptPciEnable()** and/or the DMA driver will no longer have any effect. The component interrupt settings will be retained however.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to disable. Bits set to 1 are disabled. The mask is formed by OR'ing bits from XPCI\_IPIF\_INT\_MASK

Note:

None

```
void XPci_InterruptEnable( XPci * InstancePtr, Xuint32 Mask
)
```

Enable device interrupts. Device interrupts must be enabled by this function before component interrupts enabled by **XPci\_InterruptPciEnable()** and/or the DMA driver have any effect.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to enable. Bit positions of 1 are enabled. The mask is formed by OR'ing bits from XPCI IPIF INT MASK.

**Note:** 

None

# Xuint32 XPci\_InterruptGetEnabled( XPci \* InstancePtr)

Returns the device level interrupt enable mask as set by **XPci\_InterruptEnable()**.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

## **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK.

Note:

None

# Xuint32 XPci\_InterruptGetHighestPending( XPci \* InstancePtr)

Returns the highest priority pending device interrupt that has been enabled by **XPci\_InterruptEnable()**.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask is one set bit made from XPCI\_IPIF\_INT\_MASK or zero if no interrupts are pending.

## Note:

None

# Xuint32 XPci\_InterruptGetPending( XPci \* InstancePtr)

Returns the pending status of device level interrupt signals that have been enabled by **XPci\_InterruptEnable**(). Any bit in the mask set to 1 indicates that an interrupt is pending from the given component

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

#### **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK or zero if no interrupts are pending.

## **Note:**

None

# Xuint32 XPci\_InterruptGetStatus( XPci \* InstancePtr)

Returns the status of device level interrupt signals. Any bit in the mask set to 1 indicates that the given component has asserted an interrupt condition.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

### **Returns:**

Mask of bits made from XPCI\_IPIF\_INT\_MASK.

### Note:

The interrupt status indicates the status of the device irregardless if the interrupts from the devices have been enabled or not through **XPci\_InterruptEnable**().

Disable the core's interrupt output signal. Interrupts enabled through **XPci\_InterruptEnable()** and **XPci\_InterruptPciEnable()** will no longer be passed through until the IPIF global enable bit is set by **XPci\_InterruptGlobalEnable()**.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Note:

None

# void XPci\_InterruptGlobalEnable( XPci \* InstancePtr)

Enable the core's interrupt output signal. Interrupts enabled through **XPci\_InterruptEnable()** and **XPci\_InterruptPciEnable()** will not be passed through until the IPIF global enable bit is set by this function.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Note:

None

Clear PCI bridge specific interrupt status bits with the provided mask.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to clear pending interrupts for. Bit positions of 1 are cleared. This mask is formed by OR'ing bits from XPCI\_IR\_MASK

**Note:** 

```
void XPci_InterruptPciDisable( XPci * InstancePtr, Xuint32 Mask )
```

Disable PCI bridge specific interrupts.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to disable. Bits set to 1 are disabled. The mask is formed by OR'ing bits from XPCI\_IR\_MASK

Note:

None

Enable PCI bridge specific interrupts. Before this function has any effect in generating interrupts, the function **XPci\_InterruptEnable()** must be invoked with the XPCI\_IPIF\_INT\_PCI bit set.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Mask

is the mask to enable. Bit positions of 1 are enabled. The mask is formed by OR'ing bits from XPCI IR MASK.

Note:

None

# Xuint32 XPci\_InterruptPciGetEnabled( XPci \* InstancePtr)

Get the PCI bridge specific interrupts enabled through **XPci\_InterruptPciEnable**(). Bits set to 1 mean that interrupt source is enabled.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

### **Returns:**

Mask of enabled bits made from XPCI\_IR\_MASK.

**Note:** 

None

# Xuint32 XPci\_InterruptPciGetStatus( XPci \* InstancePtr)

Get the status of PCI bridge specific interrupts that have been asserted Bits set to 1 are in an asserted state. Bits may be set to 1 irregardless of whether they have been enabled or not though **XPci\_InterruptPciEnable()**. To get the pending interrupts, AND the results of this function with **XPci\_InterruptPciGetEnabled()**.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

## **Returns:**

Mask of enabled bits made from XPCI IR MASK.

# Note:

None

# 

Lookup the device configuration based on the unique device ID. The table ConfigTable contains the configuration info for each device in the system.

# **Parameters:**

*DeviceID* is the device identifier to lookup.

## **Returns:**

- XEmc configuration structure pointer if DeviceID is found.
- o XNULL if DeviceID is not found.

# void XPci\_Reset( XPci \* InstancePtr)

Reset the PCI IP core. This is a destructive operation that could cause loss of data, local bus errors, or PCI bus errors if reset occurs while a transaction is pending.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

### **Note:**

None

# XStatus XPci\_SelfTest( XPci \* InstancePtr)

Run a self-test on the driver/device. This includes the following tests:

• Configuration read of the bridge device and vendor ID.

## **Parameters:**

*InstancePtr* is a pointer to the **XPci** instance to be worked on. This parameter must have been previously initialized with **XPci** Initialize().

# **Returns:**

- XST\_SUCCESS If test passed
- o XST\_FAILURE If test failed

### Note:

None

```
void XPci_SetBusNumber( XPci * InstancePtr,
int BusNo,
int SubBusNo
)
```

Set the bus number and subordinate bus number of the pci bridge. This function has effect only if the PCI bridge is configured as a PCI host bridge.

## **Parameters:**

```
InstancePtr is the PCI component to operate on.
```

BusNo is the bus number to set

SubBusNo is the subordinate bus number to set

# **Note:**

None

```
void XPci_SpecialCycle( XPci * InstancePtr, Xuint32 Data
)
```

Broadcasts a message to all listening PCI targets.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Data is the data to broadcast.

## Note:

# Xuint32 XPci\_V3StatusCommandGet( XPci \* InstancePtr)

Read the contents of the V3 bridge's status & command register. This same register can be retrieved by a PCI configuration access. The register can be written only with a PCI configuration access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

# **Returns:**

Contents of the V3 bridge's status and command register

### Note:

None

```
void XPci_V3TransactionStatusClear( XPci * InstancePtr, Xuint32 Data
```

Clear status bits in the V3 bridge's transaction status register. The contents of this register can be decoded using XPCI\_STATV3\_\* constants defined in xpci\_l.h.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Data

is the contents to write to the register. Or XPCI\_STATV3\_\* constants for those bits to be cleared. Bits in the register that are read-only are not affected.

#### Note:

None

# Xuint32 XPci\_V3TransactionStatusGet( XPci \* InstancePtr)

Read the contents of the V3 bridge's transaction status register. The contents of this register can be decoded using XPCI\_STATV3\_\* constants defined in **xpci\_l.h**.

#### **Parameters:**

*InstancePtr* is the PCI component to operate on.

# **Returns:**

Contents of the V3 bridge's transaction status register.

# Note:

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# **XPciError Struct Reference**

#include <xpci.h>

# **Detailed Description**

XPciError is used to retrieve a snapshot of the bridge's error state. Most of the attributes of this structure are copies of various bridge registers. See **XPci\_ErrorGet()** and **XPci\_ErrorClear()**.

# **Data Fields**

**Xboolean IsError** 

**Xuint32 LocalBusReason** 

**Xuint32 PciReason** 

Xuint32 PciSerrReason

Xuint32 LocalBusReadAddr

Xuint32 LocalBusWriteAddr

Xuint32 PciReadAddr

Xuint32 PciWriteAddr

Xuint32 PciSerrReadAddr

Xuint32 PciSerrWriteAddr

# **Field Documentation**

Xboolean XPciError::IsError

Global error indicator

# Xuint32 XPciError::LocalBusReadAddr

Local bus master read error address

# Xuint32 XPciError::LocalBusReason

Local bus master address definition

# Xuint32 XPciError::LocalBusWriteAddr

Local bus master write error address

# Xuint32 XPciError::PciReadAddr

PCI read error address

# Xuint32 XPciError::PciReason

PCI address definition

# Xuint32 XPciError::PciSerrReadAddr

PCI initiater read SERR address

# Xuint32 XPciError::PciSerrReason

PCI System error definiton

# Xuint32 XPciError::PciSerrWriteAddr

PCI initiater write SERR address

# Xuint32 XPciError::PciWriteAddr

PCI write error address

The documentation for this struct was generated from the following file:

• pci/v1\_00\_a/src/xpci.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# pci/v1\_00\_a/src/xpci\_config.c File Reference

# **Detailed Description**

Implements advanced PCI configuration functions for the **XPci** component. See **xpci.h** for more information about the component.

# MODIFICATION HISTORY:

```
        Ver
        Who
        Date
        Changes

        ----
        ----
        -----

        1.00a
        rmm
        03/25/02
        Original code
```

#include "xpci.h"

# **Functions**

- XStatus XPci\_ConfigIn8 (XPci \*InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned Offset, Xuint8 \*Data)
- XStatus XPci\_ConfigIn16 (XPci \*InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned Offset, Xuint16 \*Data)
- XStatus XPci\_ConfigIn32 (XPci \*InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned Offset, Xuint32 \*Data)
- XStatus XPci\_ConfigOut8 (XPci \*InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned Offset, Xuint8 Data)
- XStatus XPci\_ConfigOut16 (XPci \*InstancePtr, unsigned Bus, unsigned Device, unsigned Func, unsigned Offset, Xuint16 Data)

# **Function Documentation**

```
XStatus XPci_ConfigIn16( XPci * InstancePtr,

unsigned Bus,

unsigned Device,

unsigned Func,

unsigned Offset,

Xuint16 * Data
```

Perform a 16 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

Func is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

## **Returns:**

- XST\_SUCCESS Operation was successfull.
- XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

# Note:

```
XStatus XPci_ConfigIn32( XPci * InstancePtr,
unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint32 * Data
)
```

Perform a 32 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

## **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

## **Returns:**

- o XST\_SUCCESS Operation was successfull.
- XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

## Note:

None

```
XStatus XPci_ConfigIn8( XPci * InstancePtr,

unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint8 * Data

)
```

Perform a 8 bit read transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

Func is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

Data is the data read from the target.

#### **Returns:**

- XST\_SUCCESS Operation was successfull.
- o XST\_PCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an

invalid address.

# Note:

None

```
XStatus XPci_ConfigOut16( XPci * InstancePtr,

unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint16 Data

)
```

Perform a 16 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

# **Returns:**

- XST\_SUCCESS Operation was successfull.
- XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

## Note:

```
XStatus XPci_ConfigOut32( XPci * InstancePtr,

unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint32 Data
```

Perform a 32 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

### **Returns:**

- XST\_SUCCESS Operation was successfull.
- XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

## Note:

None

```
XStatus XPci_ConfigOut8( XPci * InstancePtr,
unsigned Bus,
unsigned Device,
unsigned Func,
unsigned Offset,
Xuint8 Data
)
```

Perform a 8 bit write transaction in PCI configuration space. Together, the Bus, Device, Func, & Offset form the address of the PCI target to access.

### **Parameters:**

*InstancePtr* is the PCI component to operate on.

Bus is the target PCI Bus #.

Device is the target device number.

*Func* is the target device's function number.

Offset is the target device's configuration space I/O offset to address.

# **Returns:**

- o XST\_SUCCESS Operation was successfull.
- XPCI\_INVALID\_ADDRESS One of Bus, Device, Func, or Offset form an invalid address.

| Note: |      |
|-------|------|
|       | None |

Generated on 30 Sep 2003 for Xilinx Device Drivers

# pci/v1\_00\_a/src/xpci\_selftest.c File Reference

# **Detailed Description**

Implements self test for the **XPci** component. See **xpci.h** for more information about the component.

MODIFICATION HISTORY:

```
        Ver
        Who
        Date
        Changes

        ----
        ----
        -----

        1.00a
        rmm
        03/25/02
        Original code
```

# **Functions**

#include "xpci.h"

XStatus XPci\_SelfTest (XPci \*InstancePtr)

# **Function Documentation**

XStatus XPci\_SelfTest( XPci \* InstancePtr)

Run a self-test on the driver/device. This includes the following tests:

• Configuration read of the bridge device and vendor ID.

# **Parameters:**

*InstancePtr* is a pointer to the **XPci** instance to be worked on. This parameter must have been previously initialized with **XPci\_Initialize**().

# **Returns:**

- XST\_SUCCESS If test passed
- o XST\_FAILURE If test failed

# **Note:**

None

Generated on 30 Sep 2003 for Xilinx Device Drivers

# pci/v1\_00\_a/src/xpci\_v3.c File Reference

# **Detailed Description**

Implements V3 core processing functions for the **XPci** component. See **xpci.h** for more information about the component.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

---- --- ---- ---- ----- 1.00a rmm 03/25/02 Original code

#include "xpci.h"
```

# **Functions**

```
Xuint32 XPci_V3StatusCommandGet (XPci *InstancePtr)
Xuint32 XPci_V3TransactionStatusGet (XPci *InstancePtr)
void XPci_V3TransactionStatusClear (XPci *InstancePtr, Xuint32 Data)
```

# **Function Documentation**

Xuint32 XPci\_V3StatusCommandGet( XPci \* InstancePtr)

Read the contents of the V3 bridge's status & command register. This same register can be retrieved by a PCI configuration access. The register can be written only with a PCI configuration access.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

# **Returns:**

Contents of the V3 bridge's status and command register

Note:

None

```
void XPci_V3TransactionStatusClear( XPci * InstancePtr, Xuint32 Data
```

Clear status bits in the V3 bridge's transaction status register. The contents of this register can be decoded using XPCI\_STATV3\_\* constants defined in **xpci\_l.h**.

# **Parameters:**

*InstancePtr* is the PCI component to operate on.

Data

is the contents to write to the register. Or XPCI\_STATV3\_\* constants for those bits to be cleared. Bits in the register that are read-only are not affected.

**Note:** 

None

Xuint32 XPci\_V3TransactionStatusGet( XPci \* InstancePtr)

| Read the contents of the V3 bridge's transaction status register. The contents of this register can be | e |
|--------------------------------------------------------------------------------------------------------|---|
| decoded using XPCI_STATV3_* constants defined in xpci_l.h.                                             |   |

# **Parameters:**

InstancePtr is the PCI component to operate on.

# **Returns:**

Contents of the V3 bridge's transaction status register.

**Note:** 

None

Generated on 30 Sep 2003 for Xilinx Device Drivers

# plb2opb/v1\_00\_a/src/xplb2opb.c File Reference

# **Detailed Description**

Contains required functions for the **XPlb2Opb** component. See **xplb2opb.h** for more information about the component.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

---- --- --- ---- ---- ------

1.00a ecm 12/7/01 First release

1.00a rpm 05/14/02 Made configuration typedef/lookup public

#include "xstatus.h"

#include "xparameters.h"

#include "xplb2opb.h"

#include "xplb2opb_i.h"

#include "xio.h"

#include "xio.h"
```

# **Functions**

```
XStatus XPlb2Opb_Initialize (XPlb2Opb *InstancePtr, Xuint16 DeviceId)

Xboolean XPlb2Opb_IsError (XPlb2Opb *InstancePtr)

void XPlb2Opb_ClearErrors (XPlb2Opb *InstancePtr, Xuint8 Master)

Xuint32 XPlb2Opb_GetErrorStatus (XPlb2Opb *InstancePtr, Xuint8 Master)

Xuint32 XPlb2Opb_GetErrorAddress (XPlb2Opb *InstancePtr)
```

```
Xuint32 XPlb2Opb_GetErrorByteEnables (XPlb2Opb *InstancePtr)
Xuint8 XPlb2Opb_GetMasterDrivingError (XPlb2Opb *InstancePtr)
Xuint8 XPlb2Opb_GetNumMasters (XPlb2Opb *InstancePtr)
void XPlb2Opb_EnableInterrupt (XPlb2Opb *InstancePtr)
void XPlb2Opb_DisableInterrupt (XPlb2Opb *InstancePtr)
void XPlb2Opb_Reset (XPlb2Opb *InstancePtr)
XPlb2Opb_Config * XPlb2Opb_LookupConfig (Xuint16 DeviceId)
```

# **Function Documentation**

Clears any outstanding errors for the given master.

# **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

Master of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

# **Returns:**

None.

### Note:

None.

void XPlb2Opb\_DisableInterrupt( XPlb2Opb \* InstancePtr)



## **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

# **Returns:**

None.

# **Note:**

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

# void XPlb2Opb\_EnableInterrupt( XPlb2Opb \* InstancePtr)

Enables the interrupt output from the bridge

## **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

# **Returns:**

None.

# Note:

The bridge hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

Xuint32 XPlb2Opb\_GetErrorAddress( XPlb2Opb \* InstancePtr)

Returns the OPB Address where the most recent error occurred If there isn't an outstanding error, the last address in error is returned. 0x000000000 is the initial value coming out of reset.

## **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

# **Returns:**

Address where error causing access occurred

# Note:

Calling **XPlb2Opb\_IsError**() is recommended to confirm that an error has occurred prior to calling **XPlb2Opb\_GetErrorAddress**() to ensure that the data in the error address register is relevant.

# Xuint32 XPlb2Opb\_GetErrorByteEnables( XPlb2Opb \* InstancePtr)

Returns the byte-enables asserted during the access causing the error. The enables are parameters in the hardware making the return value dynamic. An example of a 32-bit bus with all 4 byte enables available, XPlb2Opb\_GetErrorByteEnables will have the value 0xF0000000 returned from a 32-bit access error.

# **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

# **Returns:**

The byte-enables asserted during the error causing access.

# Note:

None.

```
Xuint32 XPlb2Opb_GetErrorStatus( XPlb2Opb * InstancePtr,
Xuint8 Master
)
```

Returns the error status for the specified master.

# **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

*Master* of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

# **Returns:**

The current error status for the requested master on the PLB. The status is a bit-mask and the values are described in **xplb2opb.h**.

# **Note:**

None.

# Xuint8 XPlb2Opb\_GetMasterDrivingError( XPlb2Opb \* InstancePtr)

Returns the ID of the master which is driving the error condition

# **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

## **Returns:**

The ID of the master that is driving the error

# Note:

None.

# Xuint8 XPlb2Opb\_GetNumMasters( XPlb2Opb \* InstancePtr)

Returns the number of masters associated with the provided instance

### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

### **Returns:**

The number of masters. This is a number from 1 to the maximum of 32.

### **Note:**

The value returned from this call needs to be adjusted if it is to be used as the argument for other calls since the masters are numbered from 0 and this function returns values starting at 1.

Initializes a specific **XPlb2Opb** instance. Looks for configuration data for the specified device, then initializes instance data.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XPlb2Opb** component. Passing in a device id associates the generic **XPlb2Opb** component to a specific device, as chosen by the caller or application developer.

### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST\_DEVICE\_NOT\_FOUND if the requested device is not found

### Note:

None.

Xboolean XPlb2Opb\_IsError( XPlb2Opb \* InstancePtr)



# plb2opb/v1\_00\_a/src/xplb2opb\_i.h File Reference

### **Detailed Description**

This file contains data which is shared between files and internal to the **XPlb2Opb** component. It is intended for internal use only.

### MODIFICATION HISTORY:

### **Variables**

XPlb2Opb\_Config XPlb2Opb\_ConfigTable []

### **Variable Documentation**

### XPlb2Opb\_Config XPlb2Opb\_ConfigTable[]( )

The PLB-to-OPB bridge configuration table, sized by the number of instances defined in **xparameters.h**.

# plb2opb/v1\_00\_a/src/xplb2opb\_selftest.c File Reference

### **Detailed Description**

Contains diagnostic self-test functions for the **XPlb2Opb** component. See **xplb2opb.h** for more information about the component.

```
MODIFICATION HISTORY:
```

### **Functions**

XStatus XPlb2Opb\_SelfTest (XPlb2Opb \*InstancePtr, Xuint32 TestAddress)

### **Function Documentation**

```
XStatus XPlb2Opb_SelfTest( XPlb2Opb * InstancePtr, Xuint32 TestAddress
```

Runs a self-test on the driver/device.

This tests reads the BCR to verify that the proper value is there.

XST\_SUCCESS is returned if expected value is there, XST\_PLB2OPB\_FAIL\_SELFTEST is returned otherwise.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlb2Opb** instance to be worked on.

*TestAddress* is a location that could cause an error on read, not used - user definable for hw specific implementations.

### **Returns:**

XST\_SUCCESS if successful, or XST\_PLB2OPB\_FAIL\_SELFTEST if the driver fails self-test.

### Note:

This test assumes that the bus error interrupts are not enabled.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# plbarb/v1\_01\_a/src/xplbarb.h File Reference

### **Detailed Description**

This component contains the implementation of the **XPlbArb** component. It is the driver for the PLB (Processor Local Bus) Arbiter. The arbiter performs bus arbitration on the PLB transactions.

This driver allows the user to access the PLB Arbiter registers to support the handling of bus errors and other access errors and determine an appropriate solution if possible.

The Arbiter Hardware generates an interrupt in error conditions which is not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

#### **Hardware Features**

The Xilinx PLB Arbiter is a soft IP core designed for Xilinx FPGAs and contains the following features:

- PLB address and data steering support for up to eight masters. Number of PLB masters is configurable via a design parameter
- 64-bit and/or 32-bit support for masters and slaves
- PLB address pipelining
- PLB arbitration support for up to eight masters. Number of PLB masters is configurable via a design parameter
- Three cycle arbitration
- Four levels of dynamic master request priority
- PLB watchdog timer
- PLB architecture compliant

### **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. The configuration data for each device is contained in **xplbarb\_g.c**. A table is defined where each entry contains configuration information for a device. This information includes such things as the base address of the DCR mapped device, and the number of masters on the bus.

### Note:

This driver is not thread-safe. Thread safety must be guaranteed by the layer above this driver if there is a need to access the device from multiple threads.

The Arbiter registers reside on the DCR address bus.

Any and all outstanding errors are cleared in the initialization function.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XPlbArb
struct XPlbArb_Config
```

### **Functions**

```
XStatus XPlbArb_Initialize (XPlbArb *InstancePtr, Xuint16 DeviceId)
void XPlbArb_Reset (XPlbArb *InstancePtr)

XPlbArb_Config * XPlbArb_LookupConfig (Xuint16 DeviceId)
Xboolean XPlbArb_IsError (XPlbArb *InstancePtr)
void XPlbArb_ClearErrors (XPlbArb *InstancePtr, Xuint8 Master)

Xuint32 XPlbArb_GetErrorStatus (XPlbArb *InstancePtr, Xuint8 Master)
Xuint32 XPlbArb_GetErrorAddress (XPlbArb *InstancePtr)
Xuint8 XPlbArb_GetNumMasters (XPlbArb *InstancePtr)
void XPlbArb_EnableInterrupt (XPlbArb *InstancePtr)
void XPlbArb_DisableInterrupt (XPlbArb *InstancePtr)
XStatus XPlbArb_SelfTest (XPlbArb *InstancePtr, Xuint32 TestAddress)
```

### **Function Documentation**

```
void XPlbArb_ClearErrors( XPlbArb * InstancePtr,
Xuint8 Master
)
```

Clears the Errors for the specified master

| -  |    |   |            |   |     |  |
|----|----|---|------------|---|-----|--|
| Pя | ra | m | <b>Δ</b> 1 | • | rc• |  |

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*Master* of which the indicated error is to be cleared, valid range is 0 - the number of masters - 1 on the bus

#### **Returns:**

None.

#### **Note:**

None.

### void XPlbArb\_DisableInterrupt( XPlbArb \* InstancePtr)

Disables the interrupt output from the arbiter

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

None

#### Note:

The Arbiter hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt source with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

### void XPlbArb\_EnableInterrupt( XPlbArb \* InstancePtr)

Enables the interrupt output from the arbiter

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

None.

### Note:

The Arbiter hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt source with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

### Xuint32 XPlbArb\_GetErrorAddress( XPlbArb \* InstancePtr)

Returns the PLB Address where the most recent error occured. If there isn't an outstanding error, the last address in error is returned. 0x00000000 is the initial value coming out of reset.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

### **Returns:**

Address where error causing access occurred

### Note:

Calling **XPlbArb\_IsError**() is recommended to confirm that an error has occurred prior to calling this function to ensure that the data in the error address register is relevant.

```
Xuint32 XPlbArb_GetErrorStatus( XPlbArb * InstancePtr,
Xuint8 Master
)
```

Returns the Error status for the specified master. These are bit masks.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

Master of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

### **Returns:**

The current error status for the requested master on the PLB. The status is a bit-mask that can contain the following bit values:

| Indicates that an error has occurred and |
|------------------------------------------|
| this master is driving the error address |
| Indicates the error was a read error (it |
| is a write error otherwise).             |
| Indicates the error status and address   |
| are locked and cannot be overwritten.    |
| Size of access that caused error         |
| Type of access that caused error         |
|                                          |

### Note:

None.

### Xuint8 XPlbArb\_GetNumMasters( XPlbArb \* InstancePtr)

Returns the number of masters associated with the arbiter.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

### **Returns:**

The number of masters. This is a number from 1 to the maximum of 32.

#### Note:

The value returned from this call needs to be adjusted if it is to be used as the argument for other calls since the masters are numbered from 0 and this function returns values starting at 1.

Initializes a specific **XPlbArb** instance. Looks up the configuration for the given device instance and initialize the instance structure.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*DeviceId* is the unique id of the device controlled by this **XPlbArb** component.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST DEVICE NOT FOUND if the requested device is not found

### Note:

None.

### **Xboolean XPlbArb\_IsError**(**XPlbArb** \* *InstancePtr*)

Returns XTRUE is there is an error outstanding

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

Boolean XTRUE if there is an error, XFALSE if there is no current error.

### Note:

None.

### 



This tests reads the PACR to verify that the proper value is there.

XST\_SUCCESS is returned if expected value is there, XST\_PLBARB\_FAIL\_SELFTEST is returned otherwise.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*TestAddress* is a location that could cause an error on read, not used - user definable for hw specific implementations.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_PLBARB\_FAIL\_SELFTEST if the driver fails the self test.

### Note:

None.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XPIbArb Struct Reference

#include <xplbarb.h>

# **Detailed Description**

The XPlbArb driver instance data. The user is required to allocate a variable of this type for every PLB arbiter device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• plbarb/v1\_01\_a/src/xplbarb.h

# plbarb/v1\_01\_a/src/xplbarb\_g.c File Reference

### **Detailed Description**

This file contains a configuration table that specifies the configuration of PLB Arbiter devices in the system. Each arbiter device should have an entry in this table.

### MODIFICATION HISTORY:

### **Variables**

XPlbArb\_Config XPlbArb\_ConfigTable [XPAR\_XPLBARB\_NUM\_INSTANCES]

### **Variable Documentation**

### XPlbArb\_Config XPlbArb\_ConfigTable[XPAR\_XPLBARB\_NUM\_INSTANCES]

The PLB Arbiter configuration table, sized by the number of instances defined in **xparameters.h**.

## Xilinx Device Drivers

#### **Driver Summary** Copyright

Main Page Data Structures File List Data Fields Globals

# XPIbArb\_Config Struct Reference

#include <xplbarb.h>

## **Detailed Description**

This typedef contains configuration information for the device. This information would typically be extracted from Configuration ROM (CROM).

### **Data Fields**

**Xuint16 DeviceId Xuint32 BaseAddress Xuint8 NumMasters** 

### **Field Documentation**

Xuint32 XPlbArb\_Config::BaseAddress

Register base address

Xuint16 XPlbArb\_Config::DeviceId

Unique ID of device

**Xuint8** XPlbArb\_Config::NumMasters

Number of masters on the bus

The documentation for this struct was generated from the following file:

• plbarb/v1\_01\_a/src/**xplbarb.h** 

# plbarb/v1\_01\_a/src/xplbarb.c File Reference

### **Detailed Description**

Contains required functions for the **XPlbArb** component. See **xplbarb.h** for more information.

MODIFICATION HISTORY:

### **Functions**

```
XStatus XPlbArb_Initialize (XPlbArb *InstancePtr, Xuint16 DeviceId)
Xboolean XPlbArb_IsError (XPlbArb *InstancePtr)
void XPlbArb_ClearErrors (XPlbArb *InstancePtr, Xuint8 Master)
Xuint32 XPlbArb_GetErrorStatus (XPlbArb *InstancePtr, Xuint8 Master)
Xuint32 XPlbArb_GetErrorAddress (XPlbArb *InstancePtr)
Xuint8 XPlbArb_GetNumMasters (XPlbArb *InstancePtr)
void XPlbArb_EnableInterrupt (XPlbArb *InstancePtr)
void XPlbArb_DisableInterrupt (XPlbArb *InstancePtr)
void XPlbArb_DisableInterrupt (XPlbArb *InstancePtr)

void XPlbArb_Reset (XPlbArb *InstancePtr)
XPlbArb_Config * XPlbArb_LookupConfig (Xuint16 DeviceId)
```

### **Function Documentation**

# void XPlbArb\_ClearErrors( XPlbArb \* InstancePtr, Xuint8 Master )

Clears the Errors for the specified master

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*Master* of which the indicated error is to be cleared, valid range is 0 - the number of masters - 1 on the bus

#### **Returns:**

None.

### Note:

None.

### void XPlbArb\_DisableInterrupt( XPlbArb \* InstancePtr)

Disables the interrupt output from the arbiter

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

None

#### Note:

The Arbiter hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt source with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

### void XPlbArb\_EnableInterrupt( XPlbArb \* InstancePtr)

Enables the interrupt output from the arbiter

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

None.

### Note:

The Arbiter hardware generates interrupts in error conditions. These interrupts are not handled by the driver directly. It is the application's responsibility to attach to the appropriate interrupt source with a handler which then calls functions provided by this driver to determine the cause of the error and take the necessary actions to correct the situation.

### Xuint32 XPlbArb\_GetErrorAddress( XPlbArb \* InstancePtr)

Returns the PLB Address where the most recent error occured. If there isn't an outstanding error, the last address in error is returned. 0x00000000 is the initial value coming out of reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

### **Returns:**

Address where error causing access occurred

#### Note:

Calling **XPlbArb\_IsError**() is recommended to confirm that an error has occurred prior to calling this function to ensure that the data in the error address register is relevant.

```
Xuint32 XPlbArb_GetErrorStatus( XPlbArb * InstancePtr,
Xuint8 Master
)
```

Returns the Error status for the specified master. These are bit masks.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*Master* of which the indicated error is to be cleared, valid range is 0 - the number of masters on the bus

### **Returns:**

The current error status for the requested master on the PLB. The status is a bit-mask that can contain the following bit values:

| XPA_DRIVING_BEAR_MASK      | Indicates that an error has occurred and |
|----------------------------|------------------------------------------|
|                            | this master is driving the error address |
| XPA_ERROR_READ_MASK        | Indicates the error was a read error (it |
|                            | is a write error otherwise).             |
| XPA_ERROR_STATUS_LOCK_MASK | Indicates the error status and address   |
|                            | are locked and cannot be overwritten.    |
| XPA_PEAR_SIZE_MASK         | Size of access that caused error         |
| XPA_PEAR_TYPE_MASK         | Type of access that caused error         |

### **Note:**

None.

### Xuint8 XPlbArb\_GetNumMasters( XPlbArb \* InstancePtr)

Returns the number of masters associated with the arbiter.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

### **Returns:**

The number of masters. This is a number from 1 to the maximum of 32.

#### Note:

The value returned from this call needs to be adjusted if it is to be used as the argument for other calls since the masters are numbered from 0 and this function returns values starting at 1.

Initializes a specific **XPlbArb** instance. Looks up the configuration for the given device instance and initialize the instance structure.

#### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*DeviceId* is the unique id of the device controlled by this **XPlbArb** component.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST DEVICE NOT FOUND if the requested device is not found

#### Note:

None.

### **Xboolean XPlbArb\_IsError**(**XPlbArb** \* *InstancePtr*)

Returns XTRUE is there is an error outstanding

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

#### **Returns:**

Boolean XTRUE if there is an error, XFALSE if there is no current error.

#### Note:

None.

### 

| DeviceId is the unique device ID to look for.                                                      |  |
|----------------------------------------------------------------------------------------------------|--|
| <b>Returns:</b> A pointer to the configuration data for the device, or XNULL if no match is found. |  |
| Note: None.                                                                                        |  |
| void XPlbArb_Reset( XPlbArb * InstancePtr)                                                         |  |
| Forces a software reset to occur in the arbiter. Disables interrupts in the process.               |  |
| Parameters:  InstancePtr is a pointer to the XPlbArb instance to be worked on.                     |  |
| Returns: None.                                                                                     |  |
| Note: Disables interrupts in the process.                                                          |  |
| Generated on 30 Sep 2003 for Xilinx Device Drivers                                                 |  |
|                                                                                                    |  |

Looks up the device configuration based on the unique device ID. The table XPlbArb\_ConfigTable contains the

configuration info for each device in the system.

**Parameters:** 

# plbarb/v1\_01\_a/src/xplbarb\_i.h File Reference

### **Detailed Description**

This file contains data which is shared between files and internal to the **XPlbArb** component. It is intended for internal use only.

### MODIFICATION HISTORY:

```
Ver Who Date Changes

---- --- --- ---- -----

1.00a ecm 02/28/02 First release

1.01a rpm 05/13/02 Updated to match hw version, moved identifiers to xplbarb_l.h
```

```
#include "xplbarb_l.h"
```

### **Variables**

XPlbArb\_Config XPlbArb\_ConfigTable []

### **Variable Documentation**

```
XPlbArb_Config XPlbArb_ConfigTable[]( )
```

The PLB Arbiter configuration table, sized by the number of instances defined in **xparameters.h**.

# plbarb/v1\_01\_a/src/xplbarb\_l.h File Reference

### **Detailed Description**

This file contains internal identifiers and low-level macros that can be used to access the device directly. See **xplbarb.h** for a description of the high-level driver.

```
MODIFICATION HISTORY:
```

### **Defines**

```
#define XPlbArb_mSetPesrMerrReg(BaseAddress)
#define XPlbArb_mSetPesrMerrReg(BaseAddress, Mask)
#define XPlbArb_mGetPesrMDriveReg(BaseAddress)
#define XPlbArb_mGetPesrRnwReg(BaseAddress)
#define XPlbArb_mGetPesrLockReg(BaseAddress)
#define XPlbArb_mGetPearAddrReg(BaseAddress)
#define XPlbArb_mGetPearByteEnReg(BaseAddress)
#define XPlbArb_mGetControlReg(BaseAddress)
#define XPlbArb_mGetControlReg(BaseAddress)
#define XPlbArb_mEnableInterrupt(BaseAddress)
```

# **Define Documentation**

| #define XPlbArb_mDisableInterrupt( BaseAddress )                              |
|-------------------------------------------------------------------------------|
| Disable interrupts in the bridge. Preserve the contents of the ctrl register. |
| Parameters:                                                                   |
| BaseAddress is the base address of the device                                 |
| Returns:                                                                      |
| None.                                                                         |
| Note:                                                                         |
| None.                                                                         |
|                                                                               |
| #dofino VDIh Arb mEnobla Interment ( Rose Address )                           |
| #define XPlbArb_mEnableInterrupt( BaseAddress )                               |
| Enable interrupts in the bridge. Preserve the contents of the ctrl register.  |
| Parameters:                                                                   |
| BaseAddress is the base address of the device                                 |
| Returns:                                                                      |
| None.                                                                         |
| Note:                                                                         |
| None.                                                                         |

 ${\it \#define~XPlbArb\_mGetControlReg(~BaseAddress~)}$ 

| Get the contents of the control register.                                         |
|-----------------------------------------------------------------------------------|
| Parameters:                                                                       |
| BaseAddress is the base address of the device                                     |
| Returns: The 32-bit control register contents.                                    |
| Note: None.                                                                       |
| rone.                                                                             |
| #define XPlbArb_mGetPearAddrReg( BaseAddress )                                    |
| -                                                                                 |
| Get the erorr address (or PEAR), which is the address that just caused the error. |
| Parameters:                                                                       |
| BaseAddress is the base address of the device                                     |
| Returns:                                                                          |
| The 32-bit error address.                                                         |
| Note:                                                                             |
| None.                                                                             |
|                                                                                   |
| #define XPlbArb_mGetPearByteEnReg( BaseAddress )                                  |
| Get the erorr address byte enable register.                                       |
| Parameters:                                                                       |
| BaseAddress is the base address of the device                                     |
| Returns:                                                                          |
| The 32-bit error address byte enable register contents.                           |
| Note:                                                                             |
| None.                                                                             |
|                                                                                   |
| #define XPlbArb_mGetPesrLockReg( BaseAddress )                                    |



| write error.                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------|
| Parameters:  BaseAddress is the base address of the device                                                                  |
| Returns: The 32-bit value of the PESR RNW error register.                                                                   |
| Note: None.                                                                                                                 |
| define XPlbArb_mReset( BaseAddress )                                                                                        |
| Reset the bridge. Preserve the contents of the control register.                                                            |
| Parameters:  BaseAddress is the base address of the device                                                                  |
| Returns: None.                                                                                                              |
| Note: None.                                                                                                                 |
| define XPlbArb_mSetPesrMerrReg( BaseAddress,  Mask )                                                                        |
| Set the error status register.                                                                                              |
| Parameters:  BaseAddress is the base address of the device  Mask is the 32-bit value to write to the error status register. |
| Note: None.                                                                                                                 |

Get the value of the Read-Not-Write register, which indicates whether the error is a read error or

# plbarb/v1\_01\_a/src/xplbarb\_selftest.c File Reference

### **Detailed Description**

Contains diagnostic self-test functions for the **XPlbArb** component. See **xplbarb.h** for more information about the component.

### MODIFICATION HISTORY:

### **Functions**

XStatus XPlbArb\_SelfTest (XPlbArb \*InstancePtr, Xuint32 TestAddress)

### **Function Documentation**

Runs a self-test on the driver/device.

This tests reads the PACR to verify that the proper value is there.

XST\_SUCCESS is returned if expected value is there, XST\_PLBARB\_FAIL\_SELFTEST is returned otherwise.

### **Parameters:**

*InstancePtr* is a pointer to the **XPlbArb** instance to be worked on.

*TestAddress* is a location that could cause an error on read, not used - user definable for hw specific implementations.

### **Returns:**

XST\_SUCCESS if successful, or XST\_PLBARB\_FAIL\_SELFTEST if the driver fails the self test.

### Note:

None.

# rapidio/v1\_00\_a/src/xrapidio\_l.h File Reference

### **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 12/13/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

### **Defines**

```
#define XRapidIo_mReadReg(BaseAddress, RegOffset)
#define XRapidIo_mWriteReg(BaseAddress, RegOffset, Data)
#define XRapidIo_mReset(BaseAddress)
#define XRapidIo_mGetLinkStatus(BaseAddress)
```

### **Functions**

unsigned **XRapidIo\_SendPkt** (**Xuint32** BaseAddress, **Xuint8** \*PktPtr, unsigned ByteCount)

# **Define Documentation**

| #define XRapidIo_mGetLinkStatus( BaseAddress )  |
|-------------------------------------------------|
| Get the status of the PHY link.                 |
|                                                 |
| Parameters:                                     |
| BaseAddress is the base address of the device   |
| Returns:                                        |
| None.                                           |
| Note:                                           |
| None.                                           |
| Tyone.                                          |
|                                                 |
| #define XRapidIo_mReadReg( BaseAddress,         |
| RegOffset )                                     |
| Read a 32-bit value from a register.            |
|                                                 |
| Parameters:                                     |
| BaseAddress is the base address of the device   |
| RegOffset is the offset of the register to read |
| Returns:                                        |
| The 32-bit register value                       |

### ${\it \#define~XRapidIo\_mReset(~BaseAddress~)}$

**Note:** 

None.

Reset the device using the IPIF reset register. Also reset the static bin counters. **Parameters:** BaseAddress is the base address of the device **Returns:** None. Note: None. #define XRapidIo\_mWriteReg( BaseAddress, RegOffset, Data Write a 32-bit value to a register. **Parameters:** BaseAddress is the base address of the device is the offset of the register to write RegOffset is the value to write Data **Returns:** 

## **Function Documentation**

None.

None.

Note:

```
unsigned XRapidIo_RecvPkt( Xuint32 BaseAddress,
Xuint8 * PktPtr
)
```

Receive a packet. Wait for a packet to arrive.

### **Parameters:**

BaseAddress is the base address of the device

*PktPtr* is a pointer to a 64-bit word-aligned buffer where the packet will be stored.

### **Returns:**

The size, in bytes, of the packet received, or 0 if the incoming buffer is not 64-bit address aligned.

### Note:

TODO: enforce 64-bit address alignment?

```
unsigned XRapidIo_SendPkt( Xuint32 BaseAddress,
Xuint8 * PktPtr,
unsigned ByteCount
)
```

Send a RapidIO packet. The byte count is the total packet size, including header. This function blocks waiting for the packet to be transmitted.

### **Parameters:**

BaseAddress is the base address of the device

*PktPtr* is a pointer to 64-bit word-aligned packet

ByteCount is the number of bytes in the packet

### **Returns:**

The number of bytes sent. If an error occurs, such as the data is not 64-bit word aligned, a value of 0 is returned.

### Note:

The data is written to the packet buffer in 32-bit chunks.

# rapidio/v1\_00\_a/src/xrapidio\_l.c File Reference

# **Detailed Description**

This file contains low-level polled functions to send and receive RapidIO frames.

```
MODIFICATION HISTORY:
```

# **Functions**

```
unsigned XRapidIo_SendPkt (Xuint32 BaseAddress, Xuint8 *PktPtr, unsigned ByteCount) unsigned XRapidIo_RecvPkt (Xuint32 BaseAddress, Xuint8 *PktPtr)
```

# **Function Documentation**

```
unsigned XRapidIo_RecvPkt( Xuint32 BaseAddress,
Xuint8 * PktPtr
)
```

Receive a packet. Wait for a packet to arrive.

### **Parameters:**

BaseAddress is the base address of the device

*PktPtr* is a pointer to a 64-bit word-aligned buffer where the packet will be stored.

### **Returns:**

The size, in bytes, of the packet received, or 0 if the incoming buffer is not 64-bit address aligned.

### Note:

TODO: enforce 64-bit address alignment?

```
unsigned XRapidIo_SendPkt( Xuint32 BaseAddress,
Xuint8 * PktPtr,
unsigned ByteCount
)
```

Send a RapidIO packet. The byte count is the total packet size, including header. This function blocks waiting for the packet to be transmitted.

### **Parameters:**

BaseAddress is the base address of the device

*PktPtr* is a pointer to 64-bit word-aligned packet

ByteCount is the number of bytes in the packet

### **Returns:**

The number of bytes sent. If an error occurs, such as the data is not 64-bit word aligned, a value of 0 is returned.

### Note:

The data is written to the packet buffer in 32-bit chunks.

# sysace/v1\_00\_a/src/xsysace\_l.h File Reference

# **Detailed Description**

Defines identifiers and low-level macros/functions for the **XSysAce** driver. These identifiers include register offsets and bit masks. A high-level driver interface is defined in **xsysace.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 06/14/02 work in progress

#include "xbasic_types.h"
#include "xio.h"
```

# **Register Offsets**

System ACE register offsets

```
#define XSA_BMR_OFFSET
#define XSA_SR_OFFSET
#define XSA_ER_OFFSET
#define XSA_CLR_OFFSET
#define XSA_MLR_OFFSET
#define XSA_SCCR_OFFSET
#define XSA_VR_OFFSET
#define XSA_CR_OFFSET
```

# **Status Values**

Status Register masks

```
#define XSA SR CFGLOCK MASK
#define XSA SR_MPULOCK_MASK
#define XSA_SR_CFGERROR_MASK
#define XSA_SR_CFCERROR_MASK
#define XSA_SR_CFDETECT_MASK
#define XSA_SR_DATABUFRDY_MASK
#define XSA_SR_DATABUFMODE_MASK
#define XSA_SR_CFGDONE_MASK
#define XSA SR RDYFORCMD MASK
#define XSA_SR_CFGMODE_MASK
#define XSA_SR_CFGADDR_MASK
#define XSA_SR_CFBSY_MASK
#define XSA_SR_CFRDY_MASK
#define XSA_SR_CFDWF_MASK
#define XSA SR CFDSC MASK
#define XSA SR CFDRO MASK
#define XSA_SR_CFCORR_MASK
#define XSA_SR_CFERR_MASK
```

# **Error Values**

Error Register masks.

```
#define XSA_ER_CARD_RESET

#define XSA_ER_CARD_READY

#define XSA_ER_CARD_READ

#define XSA_ER_CARD_WRITE

#define XSA_ER_SECTOR_READY

#define XSA_ER_CFG_ADDR

#define XSA_ER_CFG_FAIL

#define XSA_ER_CFG_READ
```

```
#define XSA_ER_CFG_INSTR
#define XSA_ER_CFG_INIT
#define XSA_ER_RESERVED
#define XSA_ER_BAD_BLOCK
#define XSA_ER_UNCORRECTABLE
#define XSA_ER_SECTOR_ID
#define XSA_ER_ABORT
#define XSA_ER_GENERAL
```

# **Sector Cound/Command Values**

Sector Count Command Register masks

```
#define XSA_SCCR_COUNT_MASK

#define XSA_SCCR_RESET_MASK

#define XSA_SCCR_IDENTIFY_MASK

#define XSA_SCCR_READDATA_MASK

#define XSA_SCCR_WRITEDATA_MASK

#define XSA_SCCR_ABORT_MASK

#define XSA_SCCR_CMD_MASK
```

# **Control Values**

# Control Register masks

```
#define XSA_CR_FORCELOCK_MASK
#define XSA_CR_LOCKREQ_MASK
#define XSA_CR_FORCECFGADDR_MASK
#define XSA_CR_FORCECFGMODE_MASK
#define XSA_CR_CFGMODE_MASK
#define XSA_CR_CFGSTART_MASK
#define XSA_CR_CFGSEL_MASK
#define XSA_CR_CFGSEL_MASK
#define XSA_CR_CFGRESET_MASK
#define XSA_CR_DATARDYIRQ_MASK
#define XSA_CR_ERRORIRQ_MASK
#define XSA_CR_CFGDONEIRQ_MASK
#define XSA_CR_CFGDONEIRQ_MASK
#define XSA_CR_RESETIRQ_MASK
#define XSA_CR_CFGPROG_MASK
```

```
#define XSA_CR_CFGADDR_MASK #define XSA_CR_CFGADDR_SHIFT
```

# **FAT Status**

FAT filesystem status masks. The first valid partition of the CF is a FAT partition.

```
#define XSA_FAT_VALID_BOOT_REC

#define XSA_FAT_VALID_PART_REC

#define XSA_FAT_12_BOOT_REC

#define XSA_FAT_16_BOOT_REC

#define XSA_FAT_16_BOOT_REC

#define XSA_FAT_16_PART_REC

#define XSA_FAT_16_CALC
```

# **Defines**

```
#define XSA_BMR_16BIT_MASK
#define XSA_CLR_LBA_MASK
#define XSA MLR LBA MASK
#define XSA_DATA_BUFFER_SIZE
#define XSA CF SECTOR SIZE
#define XSysAce_mGetControlReg(BaseAddress)
#define XSysAce_mSetControlReg(BaseAddress, Data)
#define XSysAce_mOrControlReg(BaseAddress, Data)
#define XSysAce_mAndControlReg(BaseAddress, Data)
#define XSysAce_mGetErrorReg(BaseAddress)
#define XSvsAce mGetStatusReg(BaseAddress)
#define XSvsAce mSetCfgAddr(BaseAddress, Address)
#define XSvsAce mWaitForLock(BaseAddress)
#define XSysAce_mEnableIntr(BaseAddress, Mask)
#define XSysAce_mDisableIntr(BaseAddress, Mask)
#define XSysAce_mIsReadyForCmd(BaseAddress)
#define XSysAce_mIsMpuLocked(BaseAddress)
#define XSysAce_mIsCfgDone(BaseAddress)
#define XSysAce mIsIntrEnabled(BaseAddress)
```

# **Functions**

```
int XSysAce_ReadSector (Xuint32 BaseAddress, Xuint32 SectorId, Xuint8 *BufferPtr)
int XSysAce_WriteSector (Xuint32 BaseAddress, Xuint32 SectorId, Xuint8 *BufferPtr)
Xuint32 XSysAce_RegRead32 (Xuint32 Address)
Xuint16 XSysAce_RegRead16 (Xuint32 Address)
void XSysAce_RegWrite32 (Xuint32 Address, Xuint32 Data)
void XSysAce_RegWrite16 (Xuint32 Address, Xuint16 Data)
int XSysAce_ReadDataBuffer (Xuint32 BaseAddress, Xuint8 *BufferPtr, int NumBytes)
int XSysAce_WriteDataBuffer (Xuint32 BaseAddress, Xuint8 *BufferPtr, int NumBytes)
```

# **Define Documentation**

### #define XSA\_BMR\_16BIT\_MASK

16-bit access to ACE controller

### #define XSA\_BMR\_OFFSET

Bus mode (BUSMODEREG)

### #define XSA\_CF\_SECTOR\_SIZE

Number of bytes in a CF sector

### #define XSA\_CLR\_LBA\_MASK

Config LBA Register - address mask

### #define XSA\_CLR\_OFFSET

Config LBA (CFGLBAREG)

### #define XSA\_CR\_CFGADDR\_MASK

Config address mask

### #define XSA\_CR\_CFGADDR\_SHIFT

Config address shift

### #define XSA\_CR\_CFGDONEIRQ\_MASK

Enable CFG done IRQ

### #define XSA\_CR\_CFGMODE\_MASK

CFG mode

### #define XSA\_CR\_CFGPROG\_MASK

Inverted CFGPROG pin

### #define XSA\_CR\_CFGRESET\_MASK

CFG reset

### #define XSA\_CR\_CFGSEL\_MASK

CFG select

### #define XSA\_CR\_CFGSTART\_MASK

CFG start

# #define XSA\_CR\_DATARDYIRQ\_MASK

Enable data ready IRQ

# #define XSA\_CR\_ERRORIRQ\_MASK

Enable error IRQ

### #define XSA\_CR\_FORCECFGADDR\_MASK

Force CFG address

### #define XSA\_CR\_FORCECFGMODE\_MASK

Force CFG mode

### #define XSA\_CR\_FORCELOCK\_MASK

Force lock request

# ${\it \#define~XSA\_CR\_LOCKREQ\_MASK}$

MPU lock request

# #define XSA\_CR\_OFFSET

Control (CONTROLREG)

### #define XSA\_CR\_RESETIRQ\_MASK

Reset IRQ line

### #define XSA\_DATA\_BUFFER\_SIZE

Size of System ACE data buffer

# #define XSA\_DBR\_OFFSET

Data buffer (DATABUFREG)

### #define XSA\_ER\_ABORT

CF command aborted

# #define XSA\_ER\_BAD\_BLOCK

CF bad block detected

### #define XSA\_ER\_CARD\_READ

CF read command failed

# #define XSA\_ER\_CARD\_READY

CF card failed to ready

### #define XSA\_ER\_CARD\_RESET

CF card failed to reset

# #define XSA\_ER\_CARD\_WRITE

CF write command failed

### #define XSA\_ER\_CFG\_ADDR

### #define XSA\_ER\_CFG\_FAIL

Failed to configure a device

# #define XSA\_ER\_CFG\_INIT

CFGINIT pin error - did not go high within 500ms of start

### #define XSA\_ER\_CFG\_INSTR

Invalid instruction during cfg

# #define XSA\_ER\_CFG\_READ

Cfg read of CF failed

### #define XSA\_ER\_GENERAL

CF general error

# #define XSA\_ER\_OFFSET

Error (ERRORREG)

### #define XSA\_ER\_RESERVED

reserved

# #define XSA\_ER\_SECTOR\_ID

CF sector ID not found

### #define XSA\_ER\_SECTOR\_READY

CF sector failed to ready

# #define XSA\_ER\_UNCORRECTABLE

CF uncorrectable error

### #define XSA\_FAT\_12\_BOOT\_REC

FAT12 in master boot rec

# #define XSA\_FAT\_12\_CALC

Calculated FAT12 from clusters

# #define XSA\_FAT\_12\_PART\_REC

FAT12 in parition boot rec

### #define XSA\_FAT\_16\_BOOT\_REC

FAT16 in master boot rec

### #define XSA\_FAT\_16\_CALC

Calculated FAT16 from clusters

### #define XSA\_FAT\_16\_PART\_REC

FAT16 in partition boot rec

# #define XSA\_FAT\_VALID\_BOOT\_REC

Valid master boot record

### #define XSA\_FAT\_VALID\_PART\_REC

Valid partition boot record

### #define XSA\_FSR\_OFFSET

FAT status (FATSTATREG)

### #define XSA\_MLR\_LBA\_MASK

MPU LBA Register - address mask

### #define XSA\_MLR\_OFFSET

MPU LBA (MPULBAREG)

### #define XSA\_SCCR\_ABORT\_MASK

Abort CF command

# ${\it \#define~XSA\_SCCR\_CMD\_MASK}$

Command mask

### #define XSA\_SCCR\_COUNT\_MASK

Sector count mask

### #define XSA\_SCCR\_IDENTIFY\_MASK

Identify CF card command

### #define XSA\_SCCR\_OFFSET

Sector cnt (SECCNTCMDREG)

### #define XSA\_SCCR\_READDATA\_MASK

Read CF card command

### #define XSA\_SCCR\_RESET\_MASK

Reset CF card command

### #define XSA\_SCCR\_WRITEDATA\_MASK

Write CF card command

### #define XSA\_SR\_CFBSY\_MASK

CF busy (BSY bit)

### #define XSA SR CFCERROR MASK

CF error status

### #define XSA\_SR\_CFCORR\_MASK

CF correctable error (CORR bit)

### #define XSA SR CFDETECT MASK

CF detect flag

### #define XSA\_SR\_CFDRQ\_MASK

CF data request (DRQ)

### #define XSA\_SR\_CFDSC\_MASK

CF ready (DSC bit)

# #define XSA\_SR\_CFDWF\_MASK

CF data write fault (DWF bit)

### #define XSA\_SR\_CFERR\_MASK

CF error (ERR bit)

### #define XSA\_SR\_CFGADDR\_MASK

Configuration address

### #define XSA\_SR\_CFGDONE\_MASK

Configuration done status

### #define XSA\_SR\_CFGERROR\_MASK

Config port error status

### #define XSA\_SR\_CFGLOCK\_MASK

Config port lock status

# #define XSA\_SR\_CFGMODE\_MASK

Configuration mode status

### #define XSA\_SR\_CFRDY\_MASK

CF ready (RDY bit)

### #define XSA\_SR\_DATABUFMODE\_MASK

Data buffer mode status

### #define XSA\_SR\_DATABUFRDY\_MASK

Data buffer ready status

| MPU port lock status                                                                                            |
|-----------------------------------------------------------------------------------------------------------------|
| #define XSA_SR_OFFSET                                                                                           |
| Status (STATUSREG)                                                                                              |
| #define XSA_SR_RDYFORCMD_MASK                                                                                   |
| Ready for CF command                                                                                            |
| #define XSA_VR_OFFSET                                                                                           |
| Version (VERSIONREG)                                                                                            |
| #define XSysAce_mAndControlReg( BaseAddress,                                                                    |
| Set the contents of the control register to the value specified AND'ed with its current contents.               |
| Parameters:  BaseAddress is the base address of the device.  Data is the 32-bit value to AND with the register. |
| Data is the 32-bit value to AND with the register.                                                              |
| Returns: None.                                                                                                  |
| Note: None.                                                                                                     |
| #define XSysAce_mDisableIntr( BaseAddress, Mask )                                                               |
|                                                                                                                 |

#define XSA\_SR\_MPULOCK\_MASK

| Disable ACE controller interrupts.                                           |
|------------------------------------------------------------------------------|
| Parameters:  BaseAddress is the base address of the device.                  |
| Returns: None.                                                               |
| Note: None.                                                                  |
| #define XSysAce_mEnableIntr( BaseAddress,                                    |
| Enable ACE controller interrupts.                                            |
| Parameters:  BaseAddress is the base address of the device.  Returns:  None. |
| Note: None.                                                                  |
| define XSysAce_mGetControlReg( BaseAddress )                                 |
| Get the contents of the control register.                                    |
| Parameters:  BaseAddress is the base address of the device.                  |
| Returns: The 32-bit value of the control register.                           |
| Note: None.                                                                  |

#define XSysAce\_mGetErrorReg( BaseAddress )

| Get the contents of the error register.                                                                                      |  |
|------------------------------------------------------------------------------------------------------------------------------|--|
| Parameters:  BaseAddress is the base address of the device.                                                                  |  |
| Returns: The 32-bit value of the register.                                                                                   |  |
| Note: None.                                                                                                                  |  |
| #define XSysAce_mGetStatusReg( BaseAddress )                                                                                 |  |
| Get the contents of the status register.                                                                                     |  |
| Parameters:  BaseAddress is the base address of the device.  Returns:  The 32-bit value of the register.                     |  |
| Note: None.                                                                                                                  |  |
| #define XSysAce_mIsCfgDone( BaseAddress )                                                                                    |  |
| Is the CompactFlash configuration of the target FPGA chain complete?                                                         |  |
| Parameters:  BaseAddress is the base address of the device.  Returns:  XTRUE if it is ready, XFALSE otherwise.  Note:  None. |  |
| #define XSysAce_mIsIntrEnabled( BaseAddress )                                                                                |  |



### **Parameters:**

BaseAddress is the base address of the device.

### **Returns:**

XTRUE if it is ready, XFALSE otherwise.

### Note:

None.

| #define X | XSysAce_mO     | OrControlReg( BaseAddress, Data )                                                                         |
|-----------|----------------|-----------------------------------------------------------------------------------------------------------|
| Set the   | contents of th | ne control register to the value specified OR'ed with its current contents.                               |
| Param     | eters:         |                                                                                                           |
|           | BaseAddress    | is the base address of the device.                                                                        |
|           | Data           | is the 32-bit value to OR with the register.                                                              |
| Return    | ns:            |                                                                                                           |
| -         | None.          |                                                                                                           |
| Note:     |                |                                                                                                           |
|           | None.          |                                                                                                           |
|           |                |                                                                                                           |
| #define X | XSysAce_mS     | etCfgAddr( BaseAddress,                                                                                   |
|           |                | Address )                                                                                                 |
|           | _              | address, or file, of the CompactFlash. This address indicates which .ace on figure the target FPGA chain. |
| Param     | eters:         |                                                                                                           |
|           | BaseAddress    | is the base address of the device.                                                                        |
|           | Address        | ranges from 0 to 7 and represents the eight possible .ace bitstreams that can reside on the CompactFlash. |
| Return    | ns:            |                                                                                                           |
|           | None.          |                                                                                                           |
| Note:     |                |                                                                                                           |
|           | Used cryptic   | var names to avoid conflict with caller's var names.                                                      |
| #define X | KSysAce_mS     | etControlReg( BaseAddress,                                                                                |

Set the contents of the control register.

### **Parameters:**

BaseAddress is the base address of the device.

Data is the 32-bit value to write to the register.

### **Returns:**

None.

Note:

None.

# #define XSysAce\_mWaitForLock( BaseAddress )

Request then wait for the MPU lock. This is not a forced lock, so we must contend with the configuration controller.

### **Parameters:**

BaseAddress is the base address of the device.

### **Returns:**

None.

Note:

None.

# **Function Documentation**

```
int XSysAce_ReadDataBuffer( Xuint32 BaseAddress, Xuint8 * BufferPtr, int Size
```

Read the specified number of bytes from the data buffer of the ACE controller. The data buffer, which is 32 bytes, can only be read two bytes at a time. Once the data buffer is read, we wait for it to be filled again before reading the next buffer's worth of data.

### **Parameters:**

BaseAddress is the base address of the device

BufferPtr is a pointer to a buffer in which to store data.

Size is the number of bytes to read

### **Returns:**

The total number of bytes read, or 0 if an error occurred.

### **Note:**

If Size is not aligned with the size of the data buffer (32 bytes), this function will read the entire data buffer, dropping the extra bytes on the floor since the user did not request them. This is necessary to get the data buffer to be ready again.

```
int XSysAce_ReadSector( Xuint32 BaseAddress, Xuint32 SectorId, Xuint8 * BufferPtr
```

Read a CompactFlash sector. This is a blocking, low-level function which does not return until the specified sector is read.

### **Parameters:**

BaseAddress is the base address of the device

SectorId is the id of the sector to read

BufferPtr is a pointer to a buffer where the data will be stored.

### **Returns:**

The number of bytes read. If this number is not equal to the sector size, 512 bytes, then an error occurred.

#### Note:

None.

Read a 16-bit value from the given address. Based on a compile-time constant, do the read in one 16-bit read or two 8-bit reads.

### **Parameters:**

*Address* is the address to read from.

#### **Returns:**

The 16-bit value of the address.

### Note:

No need for endian conversion in 8-bit mode since this function gets the bytes into their proper lanes in the 16-bit word.

### Xuint32 XSysAce\_RegRead32( Xuint32 Address)

Read a 32-bit value from the given address. Based on a compile-time constant, do the read in two 16-bit reads or four 8-bit reads.

### **Parameters:**

Address is the address to read from.

#### **Returns:**

The 32-bit value of the address.

### Note:

No need for endian conversion in 8-bit mode since this function gets the bytes into their proper lanes in the 32-bit word.

```
void XSysAce_RegWrite16( Xuint32 Address,
Xuint16 Data
)
```

Write a 16-bit value to the given address. Based on a compile-time constant, do the write in one 16-bit write or two 8-bit writes.

#### **Parameters:**

Address is the address to write to.

Data is the value to write

### **Returns:**

None.

### Note:

No need for endian conversion in 8-bit mode since this function writes the bytes into their proper lanes based on address.

```
void XSysAce_RegWrite32( Xuint32 Address,
Xuint32 Data
)
```

Write a 32-bit value to the given address. Based on a compile-time constant, do the write in two 16-bit writes or four 8-bit writes.

### **Parameters:**

Address is the address to write to.

Data is the value to write

### **Returns:**

None.

### Note:

No need for endian conversion in 8-bit mode since this function writes the bytes into their proper lanes based on address.

```
int XSysAce_WriteDataBuffer( Xuint32 BaseAddress, Xuint8 * BufferPtr, int Size
```

Write the specified number of bytes to the data buffer of the ACE controller. The data buffer, which is 32 bytes, can only be written two bytes at a time. Once the data buffer is written, we wait for it to be empty again before writing the next buffer's worth of data. If the size of the incoming buffer is not aligned with the System ACE data buffer size (32 bytes), then this routine pads out the data buffer with zeros so the entire data buffer is written. This is necessary for the ACE controller to process the data buffer.

### **Parameters:**

BaseAddress is the base address of the device

BufferPtr is a pointer to a buffer used to write to the controller.

*Size* is the number of bytes to write

#### **Returns:**

The total number of bytes written (not including pad bytes), or 0 if an error occurs.

### Note:

None.

```
int XSysAce_WriteSector( Xuint32 BaseAddress,
Xuint32 SectorId,
Xuint8 * BufferPtr
)
```

Write a CompactFlash sector. This is a blocking, low-level function which does not return until the specified sector is written in its entirety.

### **Parameters:**

BaseAddress is the base address of the device

SectorId is the id of the sector to write

BufferPtr is a pointer to a buffer used to write the sector.

#### **Returns:**

The number of bytes written. If this number is not equal to the sector size, 512 bytes, then an error occurred.

#### Note:

None.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XSysAce Struct Reference

#include <xsysace.h>

# **Detailed Description**

The XSysAce driver instance data. The user is required to allocate a variable of this type for every System ACE device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• sysace/v1\_00\_a/src/xsysace.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

### Xilinx Device Drivers

# Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# sysace/v1\_00\_a/src/xsysace.h File Reference

# **Detailed Description**

The Xilinx System ACE driver. This driver supports the Xilinx System Advanced Configuration Environment (ACE) controller. It currently supports only the CompactFlash solution. The driver makes use of the Microprocessor (MPU) interface to communicate with the device.

The driver provides a user the ability to access the CompactFlash through the System ACE device. The user can read and write CompactFlash sectors, identify the flash device, and reset the flash device. Also, the driver provides a user the ability to configure FPGA devices by selecting a configuration file (.ace file) resident on the CompactFlash, or directly configuring the FPGA devices via the MPU port and the configuration JTAG port of the controller.

### **Bus Mode**

The System ACE device supports both 8-bit and 16-bit access to its registers. The driver defaults to 8-bit access, but can be changed to use 16-bit access at compile-time. The compile-time constant XPAR\_XSYSACE\_MEM\_WIDTH must be defined equal to 16 to make the driver use 16-bit access. This constant is typically defined in **xparameters.h**.

### **Endianness**

The System ACE device is little-endian. If being accessed by a big-endian processor, the endian conversion will be done by the device driver. The endian conversion is encapsulated inside the XSysAce\_RegRead/Write functions so that it can be removed if the endian conversion is moved to hardware.

### **Hardware Access**

The device driver expects the System ACE controller to be a memory-mapped device. Access to the System ACE controller is typically achieved through the External Memory Controller (EMC) IP core.

The EMC is simply a pass-through device that allows access to the off-chip System ACE device. There is no software-based setup or configuration necessary for the EMC.

The System ACE registers are expected to be byte-addressable. If for some reason this is not possible, the register offsets defined in **xsysace\_l.h** must be changed accordingly.

### Reading or Writing CompactFlash

The smallest unit that can be read from or written to CompactFlash is one sector. A sector is 512 bytes. The functions provided by this driver allow the user to specify a starting sector ID and the number of sectors to be read or written. At most 256 sectors can be read or written in one operation. The user must ensure that the buffer passed to the functions is big enough to hold (512 \* NumSectors), where NumSectors is the number of sectors specified.

### **Interrupt Mode**

By default, the device and driver are in polled mode. The user is required to enable interrupts using **XSysAce\_EnableInterrupt**(). In order to use interrupts, it is necessary for the user to connect the driver's interrupt handler, **XSysAce\_InterruptHandler**(), to the interrupt system of the application. This function does not save and restore the processor context. An event handler must also be set by the user, using **XSysAce\_SetEventHandler**(), for the driver such that the handler is called when interrupt events occur. The handler is called from interrupt context and allows application-specific processing to be performed.

In interrupt mode, the only available interrupt is data buffer ready, so the size of a data transfer between interrupts is 32 bytes (the size of the data buffer).

### **Polled Mode**

The sector read and write functions are blocking when in polled mode. This choice was made over non-blocking since sector transfer rates are high (>20Mbps) and the user can limit the number of sectors transferred in a single operation to 1 when in polled mode, plus the API for non-blocking polled functions was a bit awkward. Below is some more information on the sector transfer rates given the current state of technology (year 2002). Although the seek times for CompactFlash cards is high, this average hit needs to be taken every time a new read/write operation is invoked by the user. So the additional few microseconds to transfer an entire sector along with seeking is miniscule.

- Microdrives are slower than CompactFlash cards by a significant factor, especially if the MD is asleep.
  - Microdrive:
    - Power-up/wake-up time is approx. 150 to 1000 ms.
    - Average seek time is approx. 15 to 20 ms.
  - o CompactFlash:

- Power-up/reset time is approx. 50 to 400 ms and wake-up time is approx. 3 ms.
- "Seek time" here means how long it takes the internal controller to process the command until the sector data is ready for transfer by the ACE controller. This time is approx. 2 ms per sector.
- Once the sector data is ready in the CF device buffer (i.e., "seek time" is over) the ACE controller can read 2 bytes from the MD/CF device every 11 clock cycles, assuming no wait cycles happen. For instance, if the clock is 33 MHz, then then the max. rate that the ACE controller can transfer is 6 MB/sec. However, due to other overhead (e.g., time for data buffer transfers over MPU port, etc.), a better estimate is 3-5 MB/sec.

### **Mutual Exclusion**

This driver is not thread-safe. The System ACE device has a single data buffer and therefore only one operation can be active at a time. The device driver does not prevent the user from starting an operation while a previous operation is still in progress. It is up to the user to provide this mutual exclusion.

### **Errors**

Error causes are defined in **xsysace\_l.h** using the prefix XSA\_ER\_\*. The user can use **XSysAce\_GetErrors**() to retrieve all outstanding errors.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00a rpm 06/17/02 work in progress

#include "xbasic_types.h"
#include "xstatus.h"
#include "xsysace_1.h"
```

# **Data Structures**

```
struct XSysAce_CFParameters
struct XSysAce_Config
```

# **Asynchronous Events**

Asynchronous events passed to the event handler when in interrupt mode.

Note that when an error event occurs, the only way to clear this condition is to reset the CompactFlash or the System ACE configuration controller, depending on where the error occurred. The driver does not reset either and leaves this task to the user.

```
#define XSA_EVENT_CFG_DONE
#define XSA_EVENT_DATA_DONE
#define XSA_EVENT_ERROR
```

# **Typedefs**

```
typedef void(* XSysAce_EventHandler )(void *CallBackRef, int Event)
```

# **Functions**

```
XStatus XSysAce Initialize (XSysAce *InstancePtr, Xuint16 DeviceId)
         XStatus XSvsAce Lock (XSvsAce *InstancePtr, Xboolean Force)
             void XSysAce_Unlock (XSysAce *InstancePtr)
         Xuint32 XSysAce_GetErrors (XSysAce *InstancePtr)
XSysAce_Config * XSysAce_LookupConfig (Xuint16 DeviceId)
         XStatus XSysAce_ResetCF (XSysAce *InstancePtr)
         XStatus XSysAce_AbortCF (XSysAce *InstancePtr)
         XStatus XSysAce_IdentifyCF (XSysAce *InstancePtr, XSysAce_CFParameters
                  *ParamPtr)
        Xboolean XSysAce_IsCFReady (XSysAce *InstancePtr)
         XStatus XSysAce_SectorRead (XSysAce *InstancePtr, Xuint32 StartSector, int
                  NumSectors, Xuint8 *BufferPtr)
         XStatus XSysAce_SectorWrite (XSysAce *InstancePtr, Xuint32 StartSector, int
                  NumSectors, Xuint8 *BufferPtr)
         Xuint16 XSysAce_GetFatStatus (XSysAce *InstancePtr)
             void XSysAce_ResetCfg (XSysAce *InstancePtr)
             void XSysAce_SetCfgAddr (XSysAce *InstancePtr, unsigned int Address)
```

# **Define Documentation**

### #define XSA\_EVENT\_CFG\_DONE

Configuration of JTAG chain is done

### #define XSA\_EVENT\_DATA\_DONE

Data transfer to/from CompactFlash is done

### #define XSA\_EVENT\_ERROR

An error occurred. Use **XSysAce\_GetErrors**() to determine the cause of the error(s).

# **Typedef Documentation**

typedef void(\* XSysAce\_EventHandler)(void \*CallBackRef, int Event)

Callback when an asynchronous event occurs during interrupt mode.

### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback

functions, and passed back to the upper layer when the callback is invoked.

Event is the event that occurred. See xsysace.h and the event identifiers prefixed

with XSA\_EVENT\_\* for a description of possible events.

# **Function Documentation**

XStatus XSysAce\_AbortCF( XSysAce \* InstancePtr)

Abort the CompactFlash operation currently in progress.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the abort was done successfully
- XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

### Note:

According to the ASIC designer, the abort command has not been well tested.

void XSysAce\_DisableInterrupt( XSysAce \* InstancePtr)

| Disable all System ACE interrupts and hold the interrupt request line of the device in reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters:  InstancePtr is a pointer to the XSysAce instance that just interrupted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Note: None.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| oid XSysAce_EnableInterrupt( XSysAce * InstancePtr)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Enable System ACE interrupts. There are three interrupts that can be enabled. The error interrupt enable serves as the driver's means to determine whether interrupts have been enabled or not. The configuration-done interrupt is not enabled here, instead it is enabled during a reset - which can cause a configuration process to start. The data-buffer-ready interrupt is not enabled here either. It is enabled when a read or write operation is started. The reason for not enabling the latter two interrupts are because the status bits may be set as a leftover of an earlier occurrence of the interrupt. |
| Parameters:  InstancePtr is a pointer to the XSysAce instance to work on.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Returns: None.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Xuint32 XSysAce\_GetCfgSector( XSysAce \* InstancePtr)

None.

Get the sector ID of the CompactFlash sector being used for configuration of the target FPGA chain. This sector ID (or logical block address) only affects transfers between the ACE configuration logic and the CompactFlash card. This function is typically used for debug purposes to determine which sector was being accessed when an error occurred.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

The sector ID (logical block address) being used for data transfers between the ACE configuration logic and the CompactFlash. Sector IDs range from 0 to 0x10000000.

### Note:

None.

# Xuint32 XSysAce\_GetErrors( XSysAce \* InstancePtr)

Get all outstanding errors. Errors include the inability to read or write CompactFlash and the inability to successfully configure FPGA devices along the target FPGA chain.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

A 32-bit mask of error values. See **xsysace\_l.h** for a description of possible values. The error identifiers are prefixed with XSA\_ER\_\*.

### Note:

None.

Xuint16 XSysAce\_GetFatStatus( XSysAce \* InstancePtr)

Get the status of the FAT filesystem on the first valid partition of the CompactFlash device such as the boot record and FAT types found.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

A 16-bit mask of status values. These values are defined in **xsysace\_l.h** with the prefix XSA\_FAT\_\*.

### Note:

None.

# Xuint16 XSysAce\_GetVersion( XSysAce \* InstancePtr)

Retrieve the version of the System ACE device.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

A 16-bit version where the 4 most significant bits are the major version number, the next four bits are the minor version number, and the least significant 8 bits are the revision or build number.

### Note:

None.

Identify the CompactFlash device. Retrieves the parameters for the CompactFlash storage device. Note that this is a polled read of one sector of data. The data is read from the CompactFlash into a byte buffer, which is then copied into the **XSysAce\_CFParameters** structure passed in by the user. The copy is necessary since we don't know how the compiler packs the **XSysAce\_CFParameters** structure.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

ParamPtr is a pointer to a XSysAce\_CFParameters structure where the information for the CompactFlash device will be stored. See xsysace.h for details on the XSysAce\_CFParameters structure.

#### **Returns:**

- o XST\_SUCCESS if the identify was done successfully
- o XST\_FAILURE if an error occurs. Use **XSysAce\_GetErrors**() to determine cause.
- XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

### Note:

None.

Initialize a specific **XSysAce** instance. The configuration information for the given device ID is found and the driver instance data is initialized appropriately.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

DeviceId is the unique id of the device controlled by this XSysAce instance.

#### **Returns:**

XST\_SUCCESS if successful, or XST\_DEVICE\_NOT\_FOUND if the device was not found in the configuration table in **xsysace\_g.c**.

### Note:

We do not want to reset the configuration controller here since this could cause a reconfiguration of the JTAG target chain, depending on how the CFGMODEPIN of the device is wired.

### void XSysAce\_InterruptHandler( void \* InstancePtr)

The interrupt handler for the System ACE driver. This handler must be connected by the user to an interrupt controller or source. This function does not save or restore context.

This function continues reading or writing to the compact flash if such an operation is in progress, and notifies the upper layer software through the event handler once the operation is complete or an error occurs. On an error, any command currently in progress is aborted.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance that just interrupted.

# **Returns:** None.

Note:

None.

# **Xboolean** XSysAce\_IsCfgDone( XSysAce \* InstancePtr)

Check to see if the configuration of the target FPGA chain is complete. This function is typically only used in polled mode. In interrupt mode, an event (XSA\_EVENT\_CFG\_DONE) is returned to the user in the asynchronous event handler.

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

XTRUE if the configuration is complete. XFALSE otherwise.

### Note:

None.

# Xboolean XSysAce\_IsCFReady( XSysAce \* InstancePtr)

Check to see if the CompactFlash is ready for a command. The CompactFlash may delay after one operation before it is ready for the next. This function helps the user determine when it is ready before invoking a CompactFlash operation such as **XSysAce\_SectorRead()** or **XSysAce\_SectorWrite()**;

### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

### **Returns:**

XTRUE if the CompactFlash is ready for a command, and XFALSE otherwise.

### Note:

None.

Attempt to lock access to the CompactFlash. The CompactFlash may be accessed by the MPU port as well as the JTAG configuration port within the System ACE device. This function requests exclusive access to the CompactFlash for the MPU port. This is a non-blocking request. If access cannot be locked (because the configuration controller has the lock), an appropriate status is returned. In this case, the user should call this function again until successful.

If the user requests a forced lock, the JTAG configuration controller will be put into a reset state in case it currently has a lock on the CompactFlash. This effectively aborts any operation the configuration controller had in progress and makes the configuration controller restart its process the next time it is able to get a lock.

A lock must be granted to the user before attempting to read or write the CompactFlash device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

*Force* 

is a boolean value that, when set to XTRUE, will force the MPU lock to occur in the System ACE. When set to XFALSE, the lock is requested and the device arbitrates between the MPU request and JTAG requests. Forcing the MPU lock resets the configuration controller, thus aborting any configuration operations in progress.

### **Returns:**

XST\_SUCCESS if the lock was granted, or XST\_DEVICE\_BUSY if the lock was not

granted because the configuration controller currently has access to the CompactFlash.

## Note:

If the lock is not granted to the MPU immediately, this function removes its request for a lock so that a lock is not later granted at a time when the application is (a) not ready for the lock, or (b) cannot be informed asynchronously about the granted lock since there is no such interrupt event.

## 

Looks up the device configuration based on the unique device ID. The table XSysAce\_ConfigTable contains the configuration info for each device in the system.

## **Parameters:**

DeviceId is the unique device ID to look for.

## **Returns:**

A pointer to the configuration data for the device, or XNULL if no match is found.

## Note:

None.

Program the target FPGA chain through the configuration JTAG port. This allows the user to program the devices on the target FPGA chain from the MPU port instead of from CompactFlash. The user specifies a buffer and the number of bytes to write. The buffer should be equivalent to an ACE (.ace) file.

Note that when loading the ACE file via the MPU port, the first sector of the ACE file is discarded. The CF filesystem controller in the System ACE device knows to skip the first sector when the ACE file comes from the CF, but the CF filesystem controller is bypassed when the ACE file comes from the MPU port. For this reason, this function skips the first sector of the buffer passed in.

In polled mode, the write is blocking. In interrupt mode, the write is non-blocking and an event, XSA\_EVENT\_CFG\_DONE, is returned to the user in the asynchronous event handler when the configuration is complete.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

BufferPtr is a pointer to a buffer that will be used to program the configuration JTAG

devices.

*NumBytes* is the number of bytes in the buffer. We assume that there is at least one

sector of data in the .ace file, which is the information sector.

## **Returns:**

- XST\_SUCCESS if the write was successful. In interrupt mode, this does not mean
  the write is complete, only that it has begun. An event is returned to the user when
  the write is complete.
- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- XST\_FAILURE if an error occurred during the write. The user should call XSysAce\_GetErrors() to determine the cause of the error.

## Note:

None.

## XStatus XSysAce\_ResetCF( XSysAce \* InstancePtr)

Reset the CompactFlash device. This function does not reset the System ACE controller. An ATA soft-reset of the CompactFlash is performed.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the reset was done successfully
- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

#### Note:

## void XSysAce\_ResetCfg( XSysAce \* InstancePtr)

Reset the JTAG configuration controller. This comprises a reset of the JTAG configuration controller and the CompactFlash controller (if it is currently being accessed by the configuration controller). Note that the MPU controller is not reset, meaning the MPU registers remain unchanged. The configuration controller is reset then released from reset in this function.

The CFGDONE status (and therefore interrupt) is cleared when the configuration controller is reset. If interrupts have been enabled, we go ahead and enable the CFGDONE interrupt here. This means that if and when a configuration process starts as a result of this reset, an interrupt will be received when it is complete.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

None.

## Note:

This function is not thread-safe.

Read at least one sector of data from the CompactFlash. The user specifies the starting sector ID and the number of sectors to be read. The minimum unit that can be read from the CompactFlash is a sector, which is 512 bytes.

In polled mode, this read is blocking. If there are other tasks in the system that must run, it is best to keep the number of sectors to be read to a minimum (e.g., 1). In interrupt mode, this read is non-blocking and an event, XSA\_EVENT\_DATA\_DONE, is returned to the user in the asynchronous event handler when the read is complete. The user must call **XSysAce\_EnableInterrupt**() to put the driver/device into interrupt mode.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

## **Parameters:**

*InstancePtr* is a pointer to the **XSvsAce** instance to be worked on.

StartSector is the starting sector ID from where data will be read. Sector IDs range from 0 (first sector) to 0x10000000.

*NumSectors* is the number of sectors to read. The range can be from 1 to 256.

BufferPtr is a pointer to a buffer where the data will be stored. The user must ensure it is big enough to hold (512 \* NumSectors) bytes.

#### **Returns:**

- XST\_SUCCESS if the read was successful. In interrupt mode, this does not mean
  the read is complete, only that it has begun. An event is returned to the user when
  the read is complete.
- XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the ACE controller is not ready for a command
- XST\_FAILURE if an error occurred during the read. The user should call XSysAce\_GetErrors() to determine the cause of the error.

## Note:

None.

Write data to the CompactFlash. The user specifies the starting sector ID and the number of sectors to be written. The minimum unit that can be written to the CompactFlash is a sector, which is 512 bytes.

In polled mode, this write is blocking. If there are other tasks in the system that must run, it is best to keep the number of sectors to be written to a minimum (e.g., 1). In interrupt mode, this write is non-blocking and an event, XSA\_EVENT\_DATA\_DONE, is returned to the user in the asynchronous event handler when the write is complete. The user must call **XSysAce\_EnableInterrupt**() to put the driver/device into interrupt mode.

An MPU lock, obtained using **XSysAce\_Lock()**, must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

StartSector is the starting sector ID from where data will be written. Sector IDs range from 0 (first sector) to 0x10000000.

*NumSectors* is the number of sectors to write. The range can be from 1 to 256.

BufferPtr is a pointer to the data buffer to be written. This buffer must have at least (512 \* NumSectors) bytes.

#### **Returns:**

- XST\_SUCCESS if the write was successful. In interrupt mode, this does not mean
  the write is complete, only that it has begun. An event is returned to the user when
  the write is complete.
- XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the ACE controller is not ready for a command
- XST\_FAILURE if an error occurred during the write. The user should call XSysAce\_GetErrors() to determine the cause of the error.

| <b>TA</b> 1 |    |     |
|-------------|----|-----|
|             | O1 | -Δ• |
| Τ.4         | v  |     |

None.

## XStatus XSysAce\_SelfTest( XSysAce \* InstancePtr)

A self-test that simply proves communication to the ACE controller from the device driver by obtaining an MPU lock, verifying it, then releasing it.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

## **Returns:**

XST\_SUCCESS if self-test passes, or XST\_FAILURE if an error occurs.

## Note:

```
void XSysAce_SetCfgAddr( XSysAce * InstancePtr,
unsigned int Address
)
```

Select the configuration address (or file) from the CompactFlash to be used for configuration of the target FPGA chain.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

Address

is the address or file number to be used as the bitstream to configure the target FPGA devices. There are 8 possible files, so the value of this parameter can range from 0 to 7.

## **Returns:**

None.

## Note:

None.

Set the callback function for handling events. The upper layer software should call this function during initialization. The events are passed asynchronously to the upper layer software. The events are described in **xsysace.h** and are named XSA\_EVENT\_\*.

Note that the callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

*FuncPtr* is the pointer to the callback function.

CallBackRef is a reference pointer to be passed back to the upper layer.

## **Returns:**

None.

## Note:

Set the start mode for configuration of the target FPGA chain from CompactFlash. The configuration process only starts after a reset. The user can indicate that the configuration should start immediately after a reset, or the configuration process can be delayed until the user commands it to start (using this function). The configuration controller can be reset using **XSysAce\_ResetCfg()**.

The user can select which configuration file on the CompactFlash to use using the **XSysAce\_SetCfgAddr**() function. If the user intends to configure the target FPGA chain directly from the MPU port, this function is not needed. Instead, the user would simply call **XSysAce\_ProgramChain**().

The user can use **XSysAce\_IsCfgDone**() when in polled mode to determine if the configuration is complete. If in interrupt mode, the event XSA\_EVENT\_CFG\_DONE will be returned asynchronously to the user when the configuration is complete. The user must call **XSysAce\_EnableInterrupt**() to put the device/driver into interrupt mode.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

ImmedOnReset can be set to XTRUE to indicate the configuration process will start

immediately after a reset of the ACE configuration controller, or it can be set to XFALSE to indicate the configuration process is delayed after a

reset until the user starts it (using this function).

StartCfg is a boolean indicating whether to start the configuration process or not.

When ImmedOnReset is set to XTRUE, this value is ignored. When ImmedOnReset is set to XFALSE, then this value controls when the configuration process is started. When set to XTRUE the configuration process starts (assuming a reset of the device has occurred), and when set

to XFALSE the configuration process does not start.

| T |    | •   |   |    |  |
|---|----|-----|---|----|--|
| ĸ | Δ1 | LI. | m | ns |  |
|   |    |     |   |    |  |

None.

## Note:

| Parameters:                                                                     |
|---------------------------------------------------------------------------------|
| <i>InstancePtr</i> is a pointer to the <b>XSysAce</b> instance to be worked on. |
| Returns: None.                                                                  |
| Note: None.                                                                     |

Release the MPU lock to the CompactFlash. If a lock is not currently granted to the MPU port,

this function has no effect.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# sysace/v1\_00\_a/src/xsysace.c File Reference

## **Detailed Description**

The Xilinx System ACE driver component. This driver supports the Xilinx System Advanced Configuration Environment (ACE) controller. It currently supports only the CompactFlash solution. See **xsysace.h** for a detailed description of the driver.

## MODIFICATION HISTORY:

## **Functions**

```
XStatus XSysAce_Initialize (XSysAce *InstancePtr, Xuint16 DeviceId)
XStatus XSysAce_Lock (XSysAce *InstancePtr, Xboolean Force)
void XSysAce_Unlock (XSysAce *InstancePtr)
Xuint32 XSysAce_GetErrors (XSysAce *InstancePtr)
XSysAce_Config * XSysAce_LookupConfig (Xuint16 DeviceId)
```

## **Function Documentation**

## Xuint32 XSysAce\_GetErrors( XSysAce \* InstancePtr)

Get all outstanding errors. Errors include the inability to read or write CompactFlash and the inability to successfully configure FPGA devices along the target FPGA chain.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

A 32-bit mask of error values. See **xsysace\_l.h** for a description of possible values. The error identifiers are prefixed with XSA\_ER\_\*.

## **Note:**

None.

Initialize a specific **XSysAce** instance. The configuration information for the given device ID is found and the driver instance data is initialized appropriately.

## **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

DeviceId is the unique id of the device controlled by this XSysAce instance.

## **Returns:**

XST\_SUCCESS if successful, or XST\_DEVICE\_NOT\_FOUND if the device was not found in the configuration table in **xsysace\_g.c**.

#### Note:

We do not want to reset the configuration controller here since this could cause a reconfiguration of the JTAG target chain, depending on how the CFGMODEPIN of the device is wired.

Attempt to lock access to the CompactFlash. The CompactFlash may be accessed by the MPU port as well as the JTAG configuration port within the System ACE device. This function requests exclusive access to the CompactFlash for the MPU port. This is a non-blocking request. If access cannot be locked (because the configuration controller has the lock), an appropriate status is returned. In this case, the user should call this function again until successful.

If the user requests a forced lock, the JTAG configuration controller will be put into a reset state in case it currently has a lock on the CompactFlash. This effectively aborts any operation the configuration controller had in progress and makes the configuration controller restart its process the next time it is able to get a lock.

A lock must be granted to the user before attempting to read or write the CompactFlash device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

Force

is a boolean value that, when set to XTRUE, will force the MPU lock to occur in the System ACE. When set to XFALSE, the lock is requested and the device arbitrates between the MPU request and JTAG requests. Forcing the MPU lock resets the configuration controller, thus aborting any configuration operations in progress.

## **Returns:**

XST\_SUCCESS if the lock was granted, or XST\_DEVICE\_BUSY if the lock was not granted because the configuration controller currently has access to the CompactFlash.

## Note:

If the lock is not granted to the MPU immediately, this function removes its request for a lock so that a lock is not later granted at a time when the application is (a) not ready for the lock, or (b) cannot be informed asynchronously about the granted lock since there is no such interrupt event.

| Parameters:                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------|
| DeviceId is the unique device ID to look for.                                                                              |
| Returns:                                                                                                                   |
| A pointer to the configuration data for the device, or XNULL if no match is found.                                         |
| Note: None.                                                                                                                |
| void XSysAce_Unlock( XSysAce * InstancePtr)                                                                                |
| Release the MPU lock to the CompactFlash. If a lock is not currently granted to the MPU port, this function has no effect. |
| Parameters:  InstancePtr is a pointer to the XSysAce instance to be worked on.                                             |
| Returns: None.                                                                                                             |
| Note: None.                                                                                                                |
| Generated on 30 Sep 2003 for Xilinx Device Drivers                                                                         |

Looks up the device configuration based on the unique device ID. The table XSysAce\_ConfigTable

contains the configuration info for each device in the system.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XSysAce\_Config Struct Reference

#include <xsysace.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress

## **Field Documentation**

Xuint32 XSysAce\_Config::BaseAddress

Register base address

Xuint16 XSysAce\_Config::DeviceId

Unique ID of device

The documentation for this struct was generated from the following file:

• sysace/v1\_00\_a/src/xsysace.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# sysace/v1\_00\_a/src/xsysace\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of System ACE devices in the system.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 06/17/02 work in progress

#include "xsysace.h"
#include "xparameters.h"
```

## **Variables**

XSysAce\_Config XSysAce\_ConfigTable [XPAR\_XSYSACE\_NUM\_INSTANCES]

## **Variable Documentation**

## XSysAce\_Config XSysAce\_ConfigTable[XPAR\_XSYSACE\_NUM\_INSTANCES]

The configuration table for System ACE devices in the system. Each device should have an entry in this table.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

## XSysAce\_CFParameters Struct Reference

#include <xsysace.h>

## **Detailed Description**

Typedef for CompactFlash identify drive parameters. Use **XSysAce\_IdentifyCF**() to retrieve this information from the CompactFlash storage device.

## **Data Fields**

**Xuint16 Signature** 

**Xuint16 NumCylinders** 

**Xuint16 NumHeads** 

**Xuint16 NumBytesPerTrack** 

**Xuint16 NumBytesPerSector** 

**Xuint16 NumSectorsPerTrack** 

Xuint32 NumSectorsPerCard

**Xuint16 VendorUnique** 

Xuint8 SerialNo [20]

**Xuint16 BufferType** 

**Xuint16 BufferSize** 

**Xuint16 NumEccBytes** 

**Xuint8 FwVersion** [8]

Xuint8 ModelNo [40]

**Xuint16 MaxSectors** 

Xuint16 DblWord

**Xuint16 Capabilities** 

**Xuint16 PioMode** 

**Xuint16 DmaMode** 

**Xuint16 TranslationValid** 

**Xuint16 CurNumCylinders** 

**Xuint16 CurNumHeads** 

**Xuint16 CurSectorsPerTrack** 

Xuint32 CurSectorsPerCard

**Xuint16 MultipleSectors** 

**Xuint32 LbaSectors** 

**Xuint16 SecurityStatus** 

**Xuint8 VendorUniqueBytes** [62]

**Xuint16 PowerDesc** 

## **Field Documentation**

## Xuint16 XSysAce\_CFParameters::BufferSize

Buffer size in 512-byte increments

## Xuint16 XSysAce\_CFParameters::BufferType

Buffer type

## Xuint16 XSysAce\_CFParameters::Capabilities

Device capabilities

## Xuint16 XSysAce\_CFParameters::CurNumCylinders

Current number of cylinders

## Xuint16 XSysAce\_CFParameters::CurNumHeads

Current number of heads

## Xuint32 XSysAce\_CFParameters::CurSectorsPerCard

## Current capacity in sectors

## Xuint16 XSysAce\_CFParameters::CurSectorsPerTrack

Current number of sectors per track

## Xuint16 XSysAce\_CFParameters::DblWord

Double Word not supported

## Xuint16 XSysAce\_CFParameters::DmaMode

DMA data transfer cycle timing mode

## Xuint8 XSysAce\_CFParameters::FwVersion[8]

**ASCII** firmware version

## Xuint32 XSysAce\_CFParameters::LbaSectors

Number of addressable sectors in LBA mode

## Xuint16 XSysAce\_CFParameters::MaxSectors

Max sectors on R/W Multiple cmds

## Xuint8 XSysAce\_CFParameters::ModelNo[40]

ASCII model number

## **Xuint16** XSysAce\_CFParameters::MultipleSectors

Multiple sector setting

## Xuint16 XSysAce\_CFParameters::NumBytesPerSector

Number of unformatted bytes per sector

## Xuint16 XSysAce\_CFParameters::NumBytesPerTrack

Number of unformatted bytes per track

## Xuint16 XSysAce\_CFParameters::NumCylinders

Default number of cylinders

## Xuint16 XSysAce\_CFParameters::NumEccBytes

Number of ECC bytes on R/W Long cmds

## Xuint16 XSysAce\_CFParameters::NumHeads

Default number of heads

## Xuint32 XSysAce\_CFParameters::NumSectorsPerCard

Default number of sectors per card

## Xuint16 XSysAce\_CFParameters::NumSectorsPerTrack

Default number of sectors per track

## Xuint16 XSysAce\_CFParameters::PioMode

PIO data transfer cycle timing mode

## Xuint16 XSysAce\_CFParameters::PowerDesc

Power requirement description

## Xuint16 XSysAce\_CFParameters::SecurityStatus

Security status

## Xuint8 XSysAce\_CFParameters::SerialNo[20]

ASCII serial number

## Xuint16 XSysAce\_CFParameters::Signature

CompactFlash signature is 0x848a

## Xuint16 XSysAce\_CFParameters::TranslationValid

Translation parameters are valid

## Xuint16 XSysAce\_CFParameters::VendorUnique

Vendor unique

## Xuint8 XSysAce\_CFParameters::VendorUniqueBytes[62]

Vendor unique bytes

The documentation for this struct was generated from the following file:

• sysace/v1\_00\_a/src/xsysace.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## spi/v1\_00\_b/src/xspi.h File Reference

## **Detailed Description**

This component contains the implementation of the **XSpi** component. It is the driver for an SPI master or slave device. User documentation for the driver functions is contained in this file in the form of comment blocks at the front of each function.

SPI is a 4-wire serial interface. It is a full-duplex, synchronous bus that facilitates communication between one master and one slave. The device is always full-duplex, which means that for every byte sent, one is received, and vice-versa. The master controls the clock, so it can regulate when it wants to send or receive data. The slave is under control of the master, it must respond quickly since it has no control of the clock and must send/receive data as fast or as slow as the master does.

The application software between master and slave must implement a higher layer protocol so that slaves know what to transmit to the master and when.

## **Multiple Masters**

More than one master can exist, but arbitration is the responsibility of the higher layer software. The device driver does not perform any type of arbitration.

## **Multiple Slaves**

Multiple slaves are supported by adding additional slave select (SS) signals to each device, one for each slave on the bus. The driver ensures that only one slave can be selected at any one time.

#### **FIFOs**

The SPI hardware is parameterized such that it can be built with or without FIFOs. When using FIFOs, both send and receive must have FIFOs. The driver will not function correctly if one direction has a FIFO but the other direction does not. The frequency of the interrupts which occur is proportional to the data rate such that high data rates without the FIFOs could cause the software to consume large amounts of processing time. The driver is designed to work with or without the FIFOs.

## **Interrupts**

The user must connect the interrupt handler of the driver, XSpi\_InterruptHandler to an interrupt system such that it will be called when an interrupt occurs. This function does not save and restore the processor context such that the user must provide this processing.

The driver handles the following interrupts:

- Data Transmit Register/FIFO Empty
- Data Transmit Register/FIFO Underrun
- Data Receive Register/FIFO Overrun
- Mode Fault Error
- Slave Mode Fault Error

The Data Transmit Register/FIFO Empty interrupt indicates that the SPI device has transmitted all the data available to transmit, and now its data register (or FIFO) is empty. The driver uses this interrupt to indicate progress while sending data. The driver may have more data to send, in which case the data transmit register (or FIFO) is filled for subsequent transmission. When this interrupt arrives and all the data has been sent, the driver invokes the status callback with a value of XST\_SPI\_TRANSFER\_DONE to inform the upper layer software that all data has been sent.

The Data Transmit Register/FIFO Underrun interrupt indicates that, as slave, the SPI device was required to transmit but there was no data available to transmit in the transmit register (or FIFO). This may not be an error if the master is not expecting data, but in the case where the master is expecting data this serves as a notification of such a condition. The driver reports this condition to the upper layer software through the status handler.

The Data Receive Register/FIFO Overrun interrupt indicates that the SPI device received data and subsequently dropped the data because the data receive register (or FIFO) was full. The interrupt applies to both master and slave operation. The driver reports this condition to the upper layer software through the status handler. This likely indicates a problem with the higher layer protocol, or a problem with the slave performance.

The Mode Fault Error interrupt indicates that while configured as a master, the device was selected as a slave by another master. This can be used by the application for arbitration in a multimaster environment or to indicate a problem with arbitration. When this interrupt occurs, the driver invokes the status callback with a status value of XST\_SPI\_MODE\_FAULT. It is up to the application to resolve the conflict.

The Slave Mode Fault Error interrupt indicates that a slave device was selected as a slave by a master, but the slave device was disabled. This can be used during system debugging or by the slave application to learn when the slave application has not prepared for a master operation in a timely fashion. This likely indicates a problem with the higher layer protocol, or a problem with the slave performance.

Note that during the FPGA implementation process, the interrupt registers of the IPIF can be parameterized away. This driver is currently dependent on those interrupt registers and will not function without them.

## **Polled Operation**

Currently there is no support for polled operation.

## **Device Busy**

Some operations are disallowed when the device is busy. The driver tracks whether a device is busy. The device is considered busy when a data transfer request is outstanding, and is considered not busy only when that transfer completes (or is aborted with a mode fault error). This applies to both master and slave devices.

## **Device Configuration**

The device can be configured in various ways during the FPGA implementation process. Configuration parameters are stored in the **xspi\_g.c** file. A table is defined where each entry contains configuration information for an SPI device. This information includes such things as the base address of the memory-mapped device, the base address of the IPIF module within the device, the number of slave select bits in the device, and whether the device has FIFOs and is configured as

slave-only.

## **RTOS Independence**

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

## **Data Structures**

```
struct XSpi
struct XSpi_Config
struct XSpi_Stats
```

## **Configuration options**

The following options may be specified or retrieved for the device and enable/disable additional features of the SPI. Each of the options are bit fields, so more than one may be specified.

```
#define XSP_MASTER_OPTION

#define XSP_CLK_ACTIVE_LOW_OPTION

#define XSP_CLK_PHASE_1_OPTION

#define XSP_LOOPBACK_OPTION

#define XSP_MANUAL_SSELECT_OPTION
```

## **Typedefs**

typedef void(\* XSpi\_StatusHandler )(void \*CallBackRef, Xuint32 StatusEvent, unsigned int ByteCount)

## **Functions**

XStatus XSpi\_Initialize (XSpi \*InstancePtr, Xuint16 DeviceId)

```
XStatus XSpi_Stop (XSpi *InstancePtr)

XStatus XSpi_Reset (XSpi *InstancePtr)

void XSpi_Reset (XSpi *InstancePtr)

XStatus XSpi_SetSlaveSelect (XSpi *InstancePtr, Xuint32 SlaveMask)

Xuint32 XSpi_GetSlaveSelect (XSpi *InstancePtr)

XStatus XSpi_Transfer (XSpi *InstancePtr, Xuint8 *SendBufPtr, Xuint8 *RecvBufPtr, unsigned int ByteCount)

void XSpi_SetStatusHandler (XSpi *InstancePtr, void *CallBackRef, XSpi_StatusHandler FuncPtr)

void XSpi_InterruptHandler (void *InstancePtr)

XSpi_Config * XSpi_LookupConfig (Xuint16 DeviceId)

XStatus XSpi_SelfTest (XSpi *InstancePtr)

void XSpi_GetStats (XSpi *InstancePtr, XSpi_Stats *StatsPtr)

void XSpi_ClearStats (XSpi *InstancePtr, Xuint32 Options)

XXtatus XSpi_SetOptions (XSpi *InstancePtr, Xuint32 Options)

Xuint32 XSpi_GetOptions (XSpi *InstancePtr)
```

## **Define Documentation**

## #define XSP\_CLK\_ACTIVE\_LOW\_OPTION

The Master option configures the SPI device as a master. By default, the device is a slave.

The Active Low Clock option configures the device's clock polarity. Setting this option means the clock is active low and the SCK signal idles high. By default, the clock is active high and SCK idles low.

The Clock Phase option configures the SPI device for one of two transfer formats. A clock phase of 0, the default, means data if valid on the first SCK edge (rising or falling) after the slave select (SS) signal has been asserted. A clock phase of 1 means data is valid on the second SCK edge (rising or falling) after SS has been asserted.

The Loopback option configures the SPI device for loopback mode. Data is looped back from the transmitter to the receiver.

The Manual Slave Select option, which is default, causes the device not to automatically drive the slave select. The driver selects the device at the start of a transfer and deselects it at the end of a transfer. If this option is off, then the device automatically toggles the slave select signal between bytes in a transfer.

## #define XSP\_CLK\_PHASE\_1\_OPTION

The Master option configures the SPI device as a master. By default, the device is a slave.

The Active Low Clock option configures the device's clock polarity. Setting this option means the clock is active low and the SCK signal idles high. By default, the clock is active high and SCK idles low.

The Clock Phase option configures the SPI device for one of two transfer formats. A clock phase of 0, the default, means data if valid on the first SCK edge (rising or falling) after the slave select (SS) signal has been asserted. A clock phase of 1 means data is valid on the second SCK edge (rising or falling) after SS has been asserted.

The Loopback option configures the SPI device for loopback mode. Data is looped back from the transmitter to the receiver.

The Manual Slave Select option, which is default, causes the device not to automatically drive the slave select. The driver selects the device at the start of a transfer and deselects it at the end of a transfer. If this option is off, then the device automatically toggles the slave select signal between bytes in a transfer.

## #define XSP\_LOOPBACK\_OPTION

The Master option configures the SPI device as a master. By default, the device is a slave.

The Active Low Clock option configures the device's clock polarity. Setting this option means the clock is active low and the SCK signal idles high. By default, the clock is active high and SCK idles low.

The Clock Phase option configures the SPI device for one of two transfer formats. A clock phase of 0, the default, means data if valid on the first SCK edge (rising or falling) after the slave select (SS) signal has been asserted. A clock phase of 1 means data is valid on the second SCK edge (rising or falling) after SS has been asserted.

The Loopback option configures the SPI device for loopback mode. Data is looped back from the transmitter to the receiver.

The Manual Slave Select option, which is default, causes the device not to automatically drive the slave select. The driver selects the device at the start of a transfer and deselects it at the end of a transfer. If this option is off, then the device automatically toggles the slave select signal between bytes in a transfer.

## #define XSP\_MANUAL\_SSELECT\_OPTION

The Master option configures the SPI device as a master. By default, the device is a slave.

The Active Low Clock option configures the device's clock polarity. Setting this option means the clock is active low and the SCK signal idles high. By default, the clock is active high and SCK idles low.

The Clock Phase option configures the SPI device for one of two transfer formats. A clock phase of 0, the default, means data if valid on the first SCK edge (rising or falling) after the slave select (SS) signal has been asserted. A clock phase of 1 means data is valid on the second SCK edge (rising or falling) after SS has been asserted.

The Loopback option configures the SPI device for loopback mode. Data is looped back from the transmitter to the receiver.

The Manual Slave Select option, which is default, causes the device not to automatically drive the slave select. The driver selects the device at the start of a transfer and deselects it at the end of a transfer. If this option is off, then the device automatically toggles the slave select signal between bytes in a transfer.

## #define XSP\_MASTER\_OPTION

The Master option configures the SPI device as a master. By default, the device is a slave.

The Active Low Clock option configures the device's clock polarity. Setting this option means the clock is active low and the SCK signal idles high. By default, the clock is active high and SCK idles low.

The Clock Phase option configures the SPI device for one of two transfer formats. A clock phase of 0, the default, means data if valid on the first SCK edge (rising or falling) after the slave select (SS) signal has been asserted. A clock phase of 1 means data is valid on the second SCK edge (rising or falling) after SS has been asserted.

The Loopback option configures the SPI device for loopback mode. Data is looped back from the transmitter to the receiver.

The Manual Slave Select option, which is default, causes the device not to automatically drive the slave select. The driver selects the device at the start of a transfer and deselects it at the end of a transfer. If this option is off, then the device automatically toggles the slave select signal between bytes in a transfer.

## **Typedef Documentation**

## typedef void(\* XSpi\_StatusHandler)(void \*CallBackRef, Xuint32 StatusEvent, unsigned int ByteCount)

The handler data type allows the user to define a callback function to handle the asynchronous processing of the SPI driver. The application using this driver is expected to define a handler of this type to support interrupt driven mode. The handler executes in an interrupt context such that minimal processing should be performed.

#### **Parameters:**

CallBackRef A callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked. Its type is unimportant to the driver component, so it is a void pointer.

StatusEvent Indicates one or more status events that occurred. See the XSpi\_SetStatusHandler() for details on the status events that can be passed in the callback.

ByteCount Indicates how many bytes of data were successfully transferred. This may be less than the

number of bytes requested if the status event indicates an error.

## **Function Documentation**

## void XSpi\_ClearStats( XSpi \* InstancePtr)

Clears the statistics for the SPI device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

**Returns:** 

None.

**Note:** 

None.

## Xuint32 XSpi GetOptions( XSpi \* InstancePtr)

This function gets the options for the SPI device. The options control how the device behaves relative to the SPI bus.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

Options contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. One or more bit values may be contained in the mask. See the bit definitions named XSP\_\*\_OPTIONS in the file **xspi.h**.

Note:

## Xuint32 XSpi\_GetSlaveSelect( XSpi \* InstancePtr)

Gets the current slave select bit mask for the SPI device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### Returns:

The value returned is a 32-bit mask with a 1 in the bit position of the slave currently selected. The value may be zero if no slaves are selected.

#### **Note:**

None.

Gets a copy of the statistics for an SPI device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

StatsPtr is a pointer to a XSpi\_Stats structure which will get a copy of current statistics.

#### **Returns:**

None.

#### Note:

None.

Initializes a specific **XSpi** instance such that the driver is ready to use.

The state of the device after initialization is:

- Device is disabled
- Slave mode
- Active high clock polarity
- Clock phase 0

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XSpi** instance. Passing in a device id associates the generic **XSpi** instance to a specific device, as chosen by the caller or application developer.

#### Returns:

The return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is returned. Possible error codes are:

- o XST\_DEVICE\_IS\_STARTED if the device is started. It must be stopped to re-initialize.
- XST\_DEVICE\_NOT\_FOUND if the device was not found in the configuration such that initialization could not be accomplished.

#### Note:

None.

## void XSpi\_InterruptHandler( void \* InstancePtr)

The interrupt handler for SPI interrupts. This function must be connected by the user to an interrupt source. This function does not save and restore the processor context such that the user must provide this processing.

The interrupts that are handled are:

- Mode Fault Error. This interrupt is generated if this device is selected as a slave when it is configured as a master. The driver aborts any data transfer that is in progress by resetting FIFOs (if present) and resetting its buffer pointers. The upper layer software is informed of the error.
- Data Transmit Register (FIFO) Empty. This interrupt is generated when the transmit register or FIFO is empty. The driver uses this interrupt during a transmission to continually send/receive data until there is no more data to send/receive.
- Data Transmit Register (FIFO) Underrun. This interrupt is generated when the SPI device, when configured as a slave, attempts to read an empty DTR/FIFO. An empty DTR/FIFO usually means that software is not giving the device data in a timely manner. No action is taken by the driver other than to inform the upper layer software of the error.
- Data Receive Register (FIFO) Overrun. This interrupt is generated when the SPI device attempts to write a received byte to an already full DRR/FIFO. A full DRR/FIFO usually means software is not emptying the data in a timely manner. No action is taken by the driver other than to inform the upper layer software of the error.
- Slave Mode Fault Error. This interrupt is generated if a slave device is selected as a slave while it is disabled. No action is taken by the driver other than to inform the upper layer software of the error.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

## Note:

The slave select register is being set to deselect the slave when a transfer is complete. This is being done regardless of whether it is a slave or a master since the hardware does not drive the slave select as a slave.

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId contains the ID of the device to look up the configuration for.

#### **Returns:**

A pointer to the configuration found or XNULL if the specified device ID was not found. See **xspi.h** for the definition of **XSpi\_Config**.

## **Note:**

None.

## void XSpi\_Reset( XSpi \* InstancePtr)

Resets the SPI device. Reset must only be called after the driver has been initialized. The configuration of the device after reset is the same as its configuration after initialization. Refer to the XSpi\_Initialize function for more details. This is a hard reset of the device. Any data transfer that is in progress is aborted.

The upper layer software is responsible for re-configuring (if necessary) and restarting the SPI device after the reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

## XStatus XSpi\_SelfTest( XSpi \* InstancePtr)

Runs a self-test on the driver/device. The self-test is destructive in that a reset of the device is performed in order to check the reset values of the registers and to get the device into a known state. A simple loopback test is also performed to verify that transmit and receive are working properly. The device is changed to master mode for the loopback test, since only a master can initiate a data transfer.

Upon successful return from the self-test, the device is reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

## **Returns:**

XST\_SUCCESS if successful, or one of the following error codes otherwise.

- o XST\_REGISTER\_ERROR indicates a register did not read or write correctly
- o XST\_LOOPBACK\_ERROR if a loopback error occurred.

#### Note:

None.

This function sets the options for the SPI device driver. The options control how the device behaves relative to the SPI bus. The device must be idle rather than busy transferring data before setting these device options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

**Options** 

contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. One or more bit values may be contained in the mask. See the bit definitions named XSP\_\*\_OPTIONS in the file xspi.h.

#### **Returns:**

XST\_SUCCESS if options are successfully set. Otherwise, returns:

- XST\_DEVICE\_BUSY if the device is currently transferring data. The transfer must complete or be aborted before setting options.
- o XST\_SPI\_SLAVE\_ONLY if the caller attempted to configure a slave-only device as a master.

#### Note:

This function makes use of internal resources that are shared between the **XSpi\_Stop**() and **XSpi\_SetOptions**() functions. So if one task might be setting device options options while another is trying to stop the device, the user is required to provide protection of this shared data (typically using a semaphore).

Selects or deselect the slave with which the master communicates. Each slave that can be selected is represented in the slave select register by a bit. The argument passed to this function is the bit mask with a 1 in the bit position of the slave being selected. Only one slave can be selected.

The user is not allowed to deselect the slave while a transfer is in progress. If no transfer is in progress, the user can select a new slave, which implicitly deselects the current slave. In order to explicitly deselect the current slave, a zero can be passed in as the argument to the function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

*SlaveMask* is a 32-bit mask with a 1 in the bit position of the slave being selected. Only one slave can be selected. The SlaveMask can be zero if the slave is being deselected.

## **Returns:**

XST\_SUCCESS if the slave is selected or deselected successfully. Otherwise, returns:

- XST\_DEVICE\_BUSY if a transfer is in progress, slave cannot be changed
- o XST SPI TOO MANY SLAVES if more than one slave is being selected.

#### Note:

This function only sets the slave which will be selected when a transfer occurs. The slave is not selected when the SPI is idle. The slave select has no affect when the device is configured as a slave.

Sets the status callback function, the status handler, which the driver calls when it encounters conditions that should be reported to the higher layer software. The handler executes in an interrupt context, so it must minimize the amount of processing performed such as transferring data to a thread context. One of the following status events is passed to the status handler.

| XST_SPI_MODE_FAULT        | A mode fault error occurred, meaning another master tried to select this device as a slave when this device was configured to be a master. Any transfer in progress is aborted.                                                                                                 |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XST_SPI_TRANSFER_DONE     | The requested data transfer is done                                                                                                                                                                                                                                             |
| XST_SPI_TRANSMIT_UNDERRUN | As a slave device, the master clocked data but there were none available in the transmit register/FIFO. This typically means the slave application did not issue a transfer request fast enough, or the processor/driver could not fill the transmit register/FIFO fast enough. |
| XST_SPI_RECEIVE_OVERRUN   | The SPI device lost data. Data was received but the receive data register/FIFO was full. This indicates that the device is receiving data                                                                                                                                       |
| XST_SPI_SLAVE_MODE_FAULT  | faster than the processor/driver can consume it. A slave SPI device was selected as a slave while it was disabled. This indicates the master is already transferring data (which is being dropped until the slave application issues a transfer).                               |

## **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

 ${\it CallBackRef}$  is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

## **Returns:**

None.

## Note:

The handler is called within interrupt context, so it should do its work quickly and queue potentially time-consuming work to a task-level thread.

## XStatus XSpi\_Start( XSpi \* InstancePtr)

This function enables interrupts for the SPI device. It is up to the user to connect the SPI interrupt handler to the interrupt controller before this Start function is called. The GetIntrHandler function is used for that purpose. If the device is configured with FIFOs, the FIFOs are reset at this time.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if the device is successfully started, or XST\_DEVICE\_IS\_STARTED if the device was already started.

#### Note:

None.

## XStatus XSpi\_Stop( XSpi \* InstancePtr)

This function stops the SPI device by disabling interrupts and disabling the device itself. Interrupts are disabled only within the device itself. If desired, the caller is responsible for disabling interrupts in the interrupt controller and disconnecting the interrupt handler from the interrupt controller.

If the device is in progress of transferring data on the SPI bus, this function returns a status indicating the device is busy. The user will be notified via the status handler when the transfer is complete, and at that time can again try to stop the device. As a master, we do not allow the device to be stopped while a transfer is in progress because the slave may be left in a bad state. As a slave, we do not allow the device to be stopped while a transfer is in progress because the master is not done with its transfer yet.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if the device is successfully started, or XST\_DEVICE\_BUSY if a transfer is in progress and cannot be stopped.

#### Note:

This function makes use of internal resources that are shared between the **XSpi\_Stop()** and **XSpi\_SetOptions()** functions. So if one task might be setting device options options while another is trying to stop the device, the user is required to provide protection of this shared data (typically using a semaphore).

Transfers the specified data on the SPI bus. If the SPI device is configured to be a master, this function initiates bus communication and sends/receives the data to/from the selected SPI slave. If the SPI device is configured to be a slave, this function prepares the data to be sent/received when selected by a master. For every byte sent, a byte is received.

The caller has the option of providing two different buffers for send and receive, or one buffer for both send and receive, or no buffer for receive. The receive buffer must be at least as big as the send buffer to prevent unwanted memory writes. This implies that the byte count passed in as an argument must be the smaller of the two buffers if they differ in size. Here are some sample usages:

- XSpi\_Transfer(InstancePtr, SendBuf, RecvBuf, ByteCount)
   The caller wishes to send and receive, and provides two different
   buffers for send and receive.
- XSpi\_Transfer(InstancePtr, SendBuf, NULL, ByteCount)
   The caller wishes only to send and does not care about the received
   data. The driver ignores the received data in this case.
- XSpi\_Transfer(InstancePtr, SendBuf, SendBuf, ByteCount)
   The caller wishes to send and receive, but provides the same buffer
   for doing both. The driver sends the data and overwrites the send
   buffer with received data as it transfers the data.
- XSpi\_Transfer(InstancePtr, RecvBuf, RecvBuf, ByteCount)

  The caller wishes to only receive and does not care about sending data. In this case, the caller must still provide a send buffer, but it can be the same as the receive buffer if the caller does not care what it sends. The device must send N bytes of data if it wishes to receive N bytes of data.

Although this function takes a buffer as an argument, the driver can only transfer a limited number of bytes at time. It transfers only one byte at a time if there are no FIFOs, or it can transfer the number of bytes up to the size of the FIFO. A call to this function only starts the transfer, then subsequent transfer of the data is performed by the interrupt service routine until the entire buffer has been transferred. The status callback function is called when the entire buffer has been sent/received.

This function is non-blocking. As a master, the SetSlaveSelect function must be called prior to this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

SendBufPtr is a pointer to a buffer of data which is to be sent. This buffer must not be NULL.

*RecvBufPtr* is a pointer to a buffer which will be filled with received data. This argument can be NULL if the caller does not wish to receive data.

ByteCount contains the number of bytes to send/receive. The number of bytes received always equals the number of bytes sent.

#### **Returns:**

XST SUCCESS if the buffers are successfully handed off to the driver for transfer. Otherwise, returns:

- o XST\_DEVICE\_IS\_STOPPED if the device must be started before transferring data.
- XST\_DEVICE\_BUSY indicates that a data transfer is already in progress. This is determined by the driver.



## **Note:**

This function is not thread-safe. he higher layer software must ensure that no two threads are transferring data on the SPI bus at the same time.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XSpi Struct Reference

#include <xspi.h>

## **Detailed Description**

The XSpi driver instance data. The user is required to allocate a variable of this type for every SPI device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• spi/v1\_00\_b/src/xspi.h

# spi/v1\_00\_b/src/xspi\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of SPI devices in the system.

MODIFICATION HISTORY:

## **Variables**

XSpi\_Config XSpi\_ConfigTable [XPAR\_XSPI\_NUM\_INSTANCES]

## **Variable Documentation**

### XSpi\_Config XSpi\_ConfigTable[XPAR\_XSPI\_NUM\_INSTANCES]

This table contains configuration information for each SPI device in the system.

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# XSpi\_Config Struct Reference

#include <xspi.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

**Xuint16 DeviceId** 

**Xuint32 BaseAddress** 

**Xboolean HasFifos** 

**Xboolean SlaveOnly** 

**Xuint8 NumSlaveBits** 

## **Field Documentation**

Xuint32 XSpi\_Config::BaseAddress

Base address of the device

Xuint16 XSpi\_Config::DeviceId

Unique ID of device

Xboolean XSpi\_Config::HasFifos

Does device have FIFOs?

## Xuint8 XSpi\_Config::NumSlaveBits

Number of slave select bits on the device

### Xboolean XSpi\_Config::SlaveOnly

Is the device slave only?

The documentation for this struct was generated from the following file:

•  $spi/v1_00_b/src/xspi.h$ 

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# XSpi\_Stats Struct Reference

#include <xspi.h>

## **Detailed Description**

**XSpi** statistics

## **Data Fields**

**Xuint32 ModeFaults** 

**Xuint32 XmitUnderruns** 

**Xuint32 RecvOverruns** 

**Xuint32 SlaveModeFaults** 

**Xuint32 BytesTransferred** 

**Xuint32 NumInterrupts** 

## **Field Documentation**

Xuint32 XSpi\_Stats::BytesTransferred

Number of bytes transferred

Xuint32 XSpi\_Stats::ModeFaults

Number of mode fault errors

### Xuint32 XSpi\_Stats::NumInterrupts

Number of transmit/receive interrupts

## Xuint32 XSpi\_Stats::RecvOverruns

Number of receive overruns

### Xuint32 XSpi\_Stats::SlaveModeFaults

Number of selects as a slave while disabled

## Xuint32 XSpi\_Stats::XmitUnderruns

Number of transmit underruns

The documentation for this struct was generated from the following file:

• spi/v1\_00\_b/src/xspi.h

# spi/v1\_00\_b/src/xspi\_i.h File Reference

## **Detailed Description**

This header file contains internal identifiers. It is intended for internal use only.

MODIFICATION HISTORY:

## **Functions**

void XSpi\_Abort (XSpi \*InstancePtr)

## **Variables**

XSpi\_Config XSpi\_ConfigTable []

## **Function Documentation**

#### void XSpi\_Abort( XSpi \* InstancePtr)

Aborts a transfer in progress by setting the stop bit in the control register, then resetting the FIFOs if present. The byte counts are cleared and the busy flag is set to false.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

#### Note:

This function does a read/modify/write of the control register. The user of this function needs to take care of critical sections.

## **Variable Documentation**

### XSpi\_Config XSpi\_ConfigTable[]( )

This table contains configuration information for each SPI device in the system.

# spi/v1\_00\_b/src/xspi\_l.h File Reference

## **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xspi.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b rpm 04/24/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XSpi_mSetControlReg(BaseAddress, Mask)

#define XSpi_mGetControlReg(BaseAddress)

#define XSpi_mGetStatusReg(BaseAddress)

#define XSpi_mSetSlaveSelectReg(BaseAddress, Mask)

#define XSpi_mGetSlaveSelectReg(BaseAddress)

#define XSpi_mEnable(BaseAddress)

#define XSpi_mDisable(BaseAddress)

#define XSpi_mSendByte(BaseAddress, Data)

#define XSpi_mRecvByte(BaseAddress)
```

# **Define Documentation**

| #define XSpi_mDisable( BaseAddress )                                                                         |
|--------------------------------------------------------------------------------------------------------------|
| Disable the device. Preserves the current contents of the control register.                                  |
| Parameters:                                                                                                  |
| BaseAddress is the base address of the device                                                                |
| Returns:                                                                                                     |
| None.                                                                                                        |
| Note:                                                                                                        |
| None.                                                                                                        |
| #define XSpi_mEnable( BaseAddress )                                                                          |
| Enable the device and uninhibit master transactions. Preserves the current contents of the control register. |
| Parameters:                                                                                                  |
| BaseAddress is the base address of the device                                                                |
| Returns:                                                                                                     |
| None.                                                                                                        |
| Note:                                                                                                        |

## ${\it \#define~XSpi\_mGetControlReg(~BaseAddress~)}$

None.



#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

A 16-bit value representing the contents of the control register.

#### **Note:**

None.

#### #define XSpi\_mGetSlaveSelectReg( BaseAddress )

Get the contents of the slave select register. Each bit in the mask corresponds to a slave select line. Only one slave should be selected at any one time.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

The 32-bit value in the slave select register

#### Note:

None.

### #define XSpi\_mGetStatusReg( BaseAddress )

Get the contents of the status register. Use the XSP\_SR\_\* constants defined above to interpret the bit-mask returned.

#### **Parameters:**

BaseAddress is the base address of the device

#### **Returns:**

An 8-bit value representing the contents of the status register.

#### Note:

None.

| #define XSpi_mRecvByte( BaseAddress )                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------|
| Receive one byte from the device's receive FIFO/register. It is assumed that the byte is already available.                    |
| Parameters:                                                                                                                    |
| BaseAddress is the base address of the device                                                                                  |
| Returns:                                                                                                                       |
| The byte retrieved from the receive FIFO/register.                                                                             |
| Note: None.                                                                                                                    |
| Trone.                                                                                                                         |
| #define XSpi_mSendByte( BaseAddress,                                                                                           |
| Data )                                                                                                                         |
| Send one byte to the currently selected slave. The byte that is received from the slave is saved in the receive FIFO/register. |
| Parameters:                                                                                                                    |
| BaseAddress is the base address of the device                                                                                  |
| Returns: None.                                                                                                                 |

Note:

None.

#define XSpi\_mSetControlReg( BaseAddress, Mask )

|              | ontents of the control register. Use the XSP_CR_* constants defined above to create the to be written to the register.                     |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Parame       | ters:                                                                                                                                      |
| 1            | BaseAddress is the base address of the device                                                                                              |
| Λ            | Mask is the 16-bit value to write to the control register                                                                                  |
| Returns      | <b>:</b>                                                                                                                                   |
| N            | Ione.                                                                                                                                      |
| Note:        |                                                                                                                                            |
| N            | fone.                                                                                                                                      |
|              |                                                                                                                                            |
| #define X    | Spi_mSetSlaveSelectReg( BaseAddress, Mask )                                                                                                |
|              | ontents of the slave select register. Each bit in the mask corresponds to a slave select line. e slave should be selected at any one time. |
| Parame       | ters:                                                                                                                                      |
| I            | BaseAddress is the base address of the device                                                                                              |
| Λ            | is the 32-bit value to write to the slave select register                                                                                  |
| Returns<br>N | ione.                                                                                                                                      |
| NI.4         |                                                                                                                                            |
| Note:        | Ione.                                                                                                                                      |
|              |                                                                                                                                            |

# spi/v1\_00\_b/src/xspi.c File Reference

## **Detailed Description**

Contains required functions of the **XSpi** driver component. See **xspi.h** for a detailed description of the device and driver.

MODIFICATION HISTORY:

## **Functions**

```
XStatus XSpi_Start (XSpi *InstancePtr)

XStatus XSpi_Stop (XSpi *InstancePtr)

void XSpi_Reset (XSpi *InstancePtr)

XStatus XSpi_Reset (XSpi *InstancePtr)

XStatus XSpi_Transfer (XSpi *InstancePtr, Xuint8 *SendBufPtr, Xuint8 *RecvBufPtr, unsigned int ByteCount)

XStatus XSpi_SetSlaveSelect (XSpi *InstancePtr, Xuint32 SlaveMask)

Xuint32 XSpi_GetSlaveSelect (XSpi *InstancePtr)

void XSpi_SetStatusHandler (XSpi *InstancePtr, void *CallBackRef, XSpi_StatusHandler FuncPtr)

void XSpi_InterruptHandler (void *InstancePtr)

void XSpi_Abort (XSpi *InstancePtr)

XSpi_Config * XSpi_LookupConfig (Xuint16 DeviceId)
```

## **Function Documentation**

#### void XSpi\_Abort( XSpi \* InstancePtr)

Aborts a transfer in progress by setting the stop bit in the control register, then resetting the FIFOs if present. The byte counts are cleared and the busy flag is set to false.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

#### Note:

This function does a read/modify/write of the control register. The user of this function needs to take care of critical sections.

#### Xuint32 XSpi\_GetSlaveSelect( XSpi \* InstancePtr)

Gets the current slave select bit mask for the SPI device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

The value returned is a 32-bit mask with a 1 in the bit position of the slave currently selected. The value may be zero if no slaves are selected.

#### Note:

None.

```
XStatus XSpi_Initialize( XSpi * InstancePtr,
Xuint16 DeviceId
```

Initializes a specific **XSpi** instance such that the driver is ready to use.

The state of the device after initialization is:

- Device is disabled
- Slave mode
- Active high clock polarity
- Clock phase 0

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XSpi** instance. Passing in a device id associates the generic **XSpi** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

The return value is XST\_SUCCESS if successful. On error, a code indicating the specific error is returned. Possible error codes are:

- XST\_DEVICE\_IS\_STARTED if the device is started. It must be stopped to re-initialize.
- XST\_DEVICE\_NOT\_FOUND if the device was not found in the configuration such that initialization could not be accomplished.

#### Note:

None.

#### void XSpi\_InterruptHandler( void \* InstancePtr)

The interrupt handler for SPI interrupts. This function must be connected by the user to an interrupt source. This function does not save and restore the processor context such that the user must provide this processing.

The interrupts that are handled are:

- Mode Fault Error. This interrupt is generated if this device is selected as a slave when it is configured as a master. The driver aborts any data transfer that is in progress by resetting FIFOs (if present) and resetting its buffer pointers. The upper layer software is informed of the error.
- Data Transmit Register (FIFO) Empty. This interrupt is generated when the transmit register or FIFO is empty. The driver uses this interrupt during a transmission to continually send/receive data until there is no more data to send/receive.
- Data Transmit Register (FIFO) Underrun. This interrupt is generated when the SPI device, when configured as a slave, attempts to read an empty DTR/FIFO. An empty DTR/FIFO usually means that software is not giving the device data in a timely manner. No action is taken by the driver other than to inform the upper layer software of the error.
- Data Receive Register (FIFO) Overrun. This interrupt is generated when the SPI device attempts to write a received byte to an already full DRR/FIFO. A full DRR/FIFO usually means software is not emptying the data in a timely manner. No action is taken by the driver other than to inform the upper layer software of the error.
- Slave Mode Fault Error. This interrupt is generated if a slave device is selected as a slave while it is disabled. No action is taken by the driver other than to inform the upper layer software of the error.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

#### Note:

The slave select register is being set to deselect the slave when a transfer is complete. This is being done regardless of whether it is a slave or a master since the hardware does not drive the slave select as a slave.

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId contains the ID of the device to look up the configuration for.

#### **Returns:**

A pointer to the configuration found or XNULL if the specified device ID was not found. See **xspi.h** for the definition of **XSpi\_Config**.

#### Note:

None.

#### void XSpi\_Reset( XSpi \* InstancePtr)

Resets the SPI device. Reset must only be called after the driver has been initialized. The configuration of the device after reset is the same as its configuration after initialization. Refer to the XSpi\_Initialize function for more details. This is a hard reset of the device. Any data transfer that is in progress is aborted.

The upper layer software is responsible for re-configuring (if necessary) and restarting the SPI device after the reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

```
XStatus XSpi_SetSlaveSelect( XSpi * InstancePtr, Xuint32 SlaveMask
```

Selects or deselect the slave with which the master communicates. Each slave that can be selected is represented in the slave select register by a bit. The argument passed to this function is the bit mask with a 1 in the bit position of the slave being selected. Only one slave can be selected.

The user is not allowed to deselect the slave while a transfer is in progress. If no transfer is in progress, the user can select a new slave, which implicitly deselects the current slave. In order to explicitly deselect the current slave, a zero can be passed in as the argument to the function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

*SlaveMask* is a 32-bit mask with a 1 in the bit position of the slave being selected. Only one slave can be selected. The SlaveMask can be zero if the slave is being deselected.

#### **Returns:**

XST SUCCESS if the slave is selected or deselected successfully. Otherwise, returns:

- o XST\_DEVICE\_BUSY if a transfer is in progress, slave cannot be changed
- o XST\_SPI\_TOO\_MANY\_SLAVES if more than one slave is being selected.

#### Note:

This function only sets the slave which will be selected when a transfer occurs. The slave is not selected when the SPI is idle. The slave select has no affect when the device is configured as a slave.

Sets the status callback function, the status handler, which the driver calls when it encounters conditions that should be reported to the higher layer software. The handler executes in an interrupt context, so it must minimize the amount of processing performed such as transferring data to a thread context. One of the following status events is passed to the status handler.

| XST_SPI_MODE_FAULT        | A mode fault error occurred, meaning another master tried to select this device as a slave when this device was configured to be a master. Any transfer in progress is aborted.                                                                                                 |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XST_SPI_TRANSFER_DONE     | The requested data transfer is done                                                                                                                                                                                                                                             |
| XST_SPI_TRANSMIT_UNDERRUN | As a slave device, the master clocked data but there were none available in the transmit register/FIFO. This typically means the slave application did not issue a transfer request fast enough, or the processor/driver could not fill the transmit register/FIFO fast enough. |
| XST_SPI_RECEIVE_OVERRUN   | The SPI device lost data. Data was received but the receive data register/FIFO was full. This indicates that the device is receiving data                                                                                                                                       |
| XST_SPI_SLAVE_MODE_FAULT  | faster than the processor/driver can consume it. A slave SPI device was selected as a slave while it was disabled. This indicates the master is already transferring data (which is being dropped until the slave application issues a transfer).                               |

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context, so it should do its work quickly and queue potentially time-consuming work to a task-level thread.

#### XStatus XSpi\_Start( XSpi \* InstancePtr)

This function enables interrupts for the SPI device. It is up to the user to connect the SPI interrupt handler to the interrupt controller before this Start function is called. The GetIntrHandler function is used for that purpose. If the device is configured with FIFOs, the FIFOs are reset at this time.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if the device is successfully started, or XST\_DEVICE\_IS\_STARTED if the device was already started.

#### Note:

None.

#### XStatus XSpi\_Stop( XSpi \* InstancePtr)

This function stops the SPI device by disabling interrupts and disabling the device itself. Interrupts are disabled only within the device itself. If desired, the caller is responsible for disabling interrupts in the interrupt controller and disconnecting the interrupt handler from the interrupt controller.

If the device is in progress of transferring data on the SPI bus, this function returns a status indicating the device is busy. The user will be notified via the status handler when the transfer is complete, and at that time can again try to stop the device. As a master, we do not allow the device to be stopped while a transfer is in progress because the slave may be left in a bad state. As a slave, we do not allow the device to be stopped while a transfer is in progress because the master is not done with its transfer yet.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if the device is successfully started, or XST\_DEVICE\_BUSY if a transfer is in progress and cannot be stopped.

#### Note:

This function makes use of internal resources that are shared between the **XSpi\_Stop**() and **XSpi\_SetOptions**() functions. So if one task might be setting device options options while another is trying to stop the device, the user is required to provide protection of this shared data (typically using a semaphore).

Transfers the specified data on the SPI bus. If the SPI device is configured to be a master, this function initiates bus communication and sends/receives the data to/from the selected SPI slave. If the SPI device is configured to be a slave, this function prepares the data to be sent/received when selected by a master. For every byte sent, a byte is received.

The caller has the option of providing two different buffers for send and receive, or one buffer for both send and receive, or no buffer for receive. The receive buffer must be at least as big as the send buffer to prevent unwanted memory writes. This implies that the byte count passed in as an argument must be the smaller of the two buffers if they differ in size. Here are some sample usages:

```
XSpi_Transfer(InstancePtr, SendBuf, RecvBuf, ByteCount)
    The caller wishes to send and receive, and provides two different
    buffers for send and receive.
```

```
XSpi_Transfer(InstancePtr, SendBuf, NULL, ByteCount)
    The caller wishes only to send and does not care about the received
    data. The driver ignores the received data in this case.
```

```
XSpi_Transfer(InstancePtr, SendBuf, SendBuf, ByteCount)
   The caller wishes to send and receive, but provides the same buffer
   for doing both. The driver sends the data and overwrites the send
   buffer with received data as it transfers the data.
```

```
XSpi_Transfer(InstancePtr, RecvBuf, RecvBuf, ByteCount)

The caller wishes to only receive and does not care about sending data. In this case, the caller must still provide a send buffer, but it can be the same as the receive buffer if the caller does not care what it sends. The device must send N bytes of data if it wishes to receive N bytes of data.
```

Although this function takes a buffer as an argument, the driver can only transfer a limited number of bytes at time. It transfers only one byte at a time if there are no FIFOs, or it can transfer the number of bytes up to the size of the FIFO. A call to this function only starts the transfer, then subsequent transfer of the data is performed by the interrupt service routine until the entire buffer has been transferred. The status callback function is called when the entire buffer has been sent/received.

This function is non-blocking. As a master, the SetSlaveSelect function must be called prior to this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

SendBufPtr is a pointer to a buffer of data which is to be sent. This buffer must not be NULL.

*RecvBufPtr* is a pointer to a buffer which will be filled with received data. This argument can be NULL if the caller does not wish to receive data.

ByteCount contains the number of bytes to send/receive. The number of bytes received always equals the number of bytes sent.

#### **Returns:**

XST\_SUCCESS if the buffers are successfully handed off to the driver for transfer. Otherwise, returns:

- o XST\_DEVICE\_IS\_STOPPED if the device must be started before transferring data.
- XST\_DEVICE\_BUSY indicates that a data transfer is already in progress. This is determined by the driver.
- XST\_SPI\_NO\_SLAVE indicates the device is configured as a master and a slave has not yet been selected.

#### **Note:**

This function is not thread-safe. he higher layer software must ensure that no two threads are transferring data on the SPI bus at the same time.

# spi/v1\_00\_b/src/xspi\_stats.c File Reference

## **Detailed Description**

This component contains the implementation of statistics functions for the **XSpi** driver component.

MODIFICATION HISTORY:

## **Functions**

```
void XSpi_GetStats (XSpi *InstancePtr, XSpi_Stats *StatsPtr) void XSpi_ClearStats (XSpi *InstancePtr)
```

## **Function Documentation**

```
void XSpi_ClearStats( XSpi * InstancePtr)
```

| <b>Parameters:</b>     |                                                                                          |
|------------------------|------------------------------------------------------------------------------------------|
| InstancePtr is         | s a pointer to the XSpi instance to be worked on.                                        |
|                        |                                                                                          |
| <b>Returns:</b>        |                                                                                          |
| None.                  |                                                                                          |
| Note:                  |                                                                                          |
| None.                  |                                                                                          |
|                        |                                                                                          |
|                        |                                                                                          |
| oid XSpi_GetStats( X   |                                                                                          |
| X                      | KSpi_Stats * StatsPtr                                                                    |
| )                      |                                                                                          |
| Gets a copy of the sta | atistics for an SPI device.                                                              |
| Parameters:            |                                                                                          |
| InstancePtr is         | s a pointer to the XSpi instance to be worked on.                                        |
|                        | s a pointer to a <b>XSpi_Stats</b> structure which will get a copy of current tatistics. |
| Returns:               |                                                                                          |
| None.                  |                                                                                          |
| None.                  |                                                                                          |
| Note:                  |                                                                                          |
| None.                  |                                                                                          |

Clears the statistics for the SPI device.

# spi/v1\_00\_b/src/xspi\_options.c File Reference

## **Detailed Description**

Contains functions for the configuration of the **XSpi** driver component.

MODIFICATION HISTORY:

## **Data Structures**

struct OptionsMap

## **Functions**

```
XStatus XSpi_SetOptions (XSpi *InstancePtr, Xuint32 Options)
Xuint32 XSpi_GetOptions (XSpi *InstancePtr)
```

## **Function Documentation**

#### Xuint32 XSpi\_GetOptions( XSpi \* InstancePtr)

This function gets the options for the SPI device. The options control how the device behaves relative to the SPI bus.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

Options contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. One or more bit values may be contained in the mask. See the bit definitions named XSP\_\*\_OPTIONS in the file xspi.h.

#### Note:

None.

This function sets the options for the SPI device driver. The options control how the device behaves relative to the SPI bus. The device must be idle rather than busy transferring data before setting these device options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

**Options** 

contains the specified options to be set. This is a bit mask where a 1 means to turn the option on, and a 0 means to turn the option off. One or more bit values may be contained in the mask. See the bit definitions named XSP\_\*\_OPTIONS in the file **xspi.h**.

#### **Returns:**

XST\_SUCCESS if options are successfully set. Otherwise, returns:

- XST\_DEVICE\_BUSY if the device is currently transferring data. The transfer must complete or be aborted before setting options.
- XST\_SPI\_SLAVE\_ONLY if the caller attempted to configure a slave-only device as a master.

#### Note:

This function makes use of internal resources that are shared between the **XSpi\_Stop()** and **XSpi\_SetOptions()** functions. So if one task might be setting device options options while another is trying to stop the device, the user is required to provide protection of this shared data (typically using a semaphore).

# spi/v1\_00\_b/src/xspi\_selftest.c File Reference

## **Detailed Description**

This component contains the implementation of selftest functions for the **XSpi** driver component.

MODIFICATION HISTORY:

```
Ver Who Date Changes
---- --- ---- ----
1.00b jhl 2/27/02 First release
1.00b rpm 04/25/02 Collapsed IPIF and reg base addresses into one
#include "xspi.h"
#include "xspi_i.h"
#include "xio.h"
#include "xio.h"
```

## **Functions**

**XStatus XSpi\_SelfTest** (**XSpi** \*InstancePtr)

## **Function Documentation**

```
XStatus XSpi_SelfTest( XSpi * InstancePtr)
```

Runs a self-test on the driver/device. The self-test is destructive in that a reset of the device is performed in order to check the reset values of the registers and to get the device into a known state. A simple loopback test is also performed to verify that transmit and receive are working properly. The device is changed to master mode for the loopback test, since only a master can initiate a data transfer.

Upon successful return from the self-test, the device is reset.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSpi** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if successful, or one of the following error codes otherwise.

- o XST\_REGISTER\_ERROR indicates a register did not read or write correctly
- o XST\_LOOPBACK\_ERROR if a loopback error occurred.

| •   |    |    |   |
|-----|----|----|---|
| N   | U. | tΔ | ٠ |
| 1 4 | "  |    | • |

None.

# sysace/v1\_00\_a/src/xsysace\_compactflash.c File Reference

## **Detailed Description**

Contains functions to reset, read, and write the CompactFlash device via the System ACE controller.

```
MODIFICATION HISTORY:

Ver Who Date Changes
-----1.00a rpm 06/17/02 work in progress

#include "xsysace.h"
#include "xsysace_l.h"
```

## **Functions**

```
XStatus XSysAce_ResetCF (XSysAce *InstancePtr)

XStatus XSysAce_AbortCF (XSysAce *InstancePtr)

XStatus XSysAce_IdentifyCF (XSysAce *InstancePtr, XSysAce_CFParameters *ParamPtr)

Xboolean XSysAce_IsCFReady (XSysAce *InstancePtr)

XStatus XSysAce_SectorRead (XSysAce *InstancePtr, Xuint32 StartSector, int NumSectors, Xuint8

*BufferPtr)

XStatus XSysAce_SectorWrite (XSysAce *InstancePtr, Xuint32 StartSector, int NumSectors, Xuint8

*BufferPtr)

Xuint16 XSysAce_GetFatStatus (XSysAce *InstancePtr)
```

## **Function Documentation**

Abort the CompactFlash operation currently in progress.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the abort was done successfully
- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

#### Note:

According to the ASIC designer, the abort command has not been well tested.

#### Xuint16 XSysAce\_GetFatStatus( XSysAce \* InstancePtr)

Get the status of the FAT filesystem on the first valid partition of the CompactFlash device such as the boot record and FAT types found.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

A 16-bit mask of status values. These values are defined in **xsysace\_l.h** with the prefix XSA\_FAT\_\*.

#### Note:

None.

Identify the CompactFlash device. Retrieves the parameters for the CompactFlash storage device. Note that this is a polled read of one sector of data. The data is read from the CompactFlash into a byte buffer, which is then copied into the **XSysAce\_CFParameters** structure passed in by the user. The copy is necessary since we don't know how the compiler packs the **XSysAce\_CFParameters** structure.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

ParamPtr is a pointer to a XSysAce\_CFParameters structure where the information for the CompactFlash device will be stored. See xsysace.h for details on the XSysAce\_CFParameters structure.

#### **Returns:**

- o XST\_SUCCESS if the identify was done successfully
- o XST\_FAILURE if an error occurs. Use **XSysAce\_GetErrors**() to determine cause.
- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

| T . T |              | 4   |  |
|-------|--------------|-----|--|
|       | $\mathbf{n}$ | tΔ' |  |
| 1.4   | "            |     |  |

None.

#### Xboolean XSysAce\_IsCFReady( XSysAce \* InstancePtr)

Check to see if the CompactFlash is ready for a command. The CompactFlash may delay after one operation before it is ready for the next. This function helps the user determine when it is ready before invoking a CompactFlash operation such as **XSysAce\_SectorRead()** or **XSysAce\_SectorWrite()**;

#### **Parameters:**

*InstancePtr* is a pointer to the **XSvsAce** instance to be worked on.

#### **Returns:**

XTRUE if the CompactFlash is ready for a command, and XFALSE otherwise.

#### Note:

None.

#### XStatus XSysAce\_ResetCF( XSysAce \* InstancePtr)

Reset the CompactFlash device. This function does not reset the System ACE controller. An ATA soft-reset of the CompactFlash is performed.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the reset was done successfully
- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the CompactFlash is not ready for a command

#### Note:

None.

Read at least one sector of data from the CompactFlash. The user specifies the starting sector ID and the number of sectors to be read. The minimum unit that can be read from the CompactFlash is a sector, which is 512 bytes.

In polled mode, this read is blocking. If there are other tasks in the system that must run, it is best to keep the number of sectors to be read to a minimum (e.g., 1). In interrupt mode, this read is non-blocking and an event, XSA\_EVENT\_DATA\_DONE, is returned to the user in the asynchronous event handler when the read is complete. The user must call XSysAce\_EnableInterrupt() to put the driver/device into interrupt mode.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

StartSector is the starting sector ID from where data will be read. Sector IDs range from 0 (first sector) to 0x10000000.

*NumSectors* is the number of sectors to read. The range can be from 1 to 256.

BufferPtr is a pointer to a buffer where the data will be stored. The user must ensure it is big enough to hold (512 \* NumSectors) bytes.

#### **Returns:**

 XST\_SUCCESS if the read was successful. In interrupt mode, this does not mean the read is complete, only that it has begun. An event is returned to the user when the read is complete.

- o XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- o XST\_DEVICE\_BUSY if the ACE controller is not ready for a command
- XST\_FAILURE if an error occurred during the read. The user should call XSysAce\_GetErrors() to determine the cause of the error.

#### Note:

None.

Write data to the CompactFlash. The user specifies the starting sector ID and the number of sectors to be written. The minimum unit that can be written to the CompactFlash is a sector, which is 512 bytes.

In polled mode, this write is blocking. If there are other tasks in the system that must run, it is best to keep the number of sectors to be written to a minimum (e.g., 1). In interrupt mode, this write is non-blocking and an event, XSA\_EVENT\_DATA\_DONE, is returned to the user in the asynchronous event handler when the write is complete. The user must call **XSysAce\_EnableInterrupt**() to put the driver/device into interrupt mode.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

StartSector is the starting sector ID from where data will be written. Sector IDs range from 0 (first sector) to 0x10000000.

NumSectors is the number of sectors to write. The range can be from 1 to 256.

BufferPtr is a pointer to the data buffer to be written. This buffer must have at least (512 \* NumSectors) bytes.

#### **Returns:**

- XST\_SUCCESS if the write was successful. In interrupt mode, this does not mean the write is complete, only that it has begun. An event is returned to the user when the write is complete.
- XST SYSACE NO LOCK if no MPU lock has yet been granted
- o XST DEVICE BUSY if the ACE controller is not ready for a command
- XST\_FAILURE if an error occurred during the write. The user should call XSysAce\_GetErrors() to determine the cause of the error.

| N  | A | tم |
|----|---|----|
| Τ. | v | u, |

None.

# sysace/v1\_00\_a/src/xsysace\_intr.c File Reference

## **Detailed Description**

Contains functions related to System ACE interrupt mode. The driver's interrupt handler, **XSysAce\_InterruptHandler**(), must be connected by the user to the interrupt controller.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

---- --- --- ---- ---- ------ 1.00a rpm 06/17/02 work in progress

#include "xsysace.h"
#include "xsysace_1.h"
```

## **Functions**

## **Function Documentation**

# void XSysAce\_DisableInterrupt( XSysAce \* InstancePtr) Disable all System ACE interrupts and hold the interrupt request line of the device in reset. **Parameters:** *InstancePtr* is a pointer to the **XSysAce** instance that just interrupted. **Returns:** None. Note: None. void XSysAce\_EnableInterrupt( XSysAce \* InstancePtr) Enable System ACE interrupts. There are three interrupts that can be enabled. The error interrupt enable serves as the driver's means to determine whether interrupts have been enabled or not. The configuration-done interrupt is not enabled here, instead it is enabled during a reset - which can cause a configuration process to start. The data-buffer-ready interrupt is not enabled here either. It is enabled when a read or write operation is started. The reason for not enabling the latter two interrupts are because the status bits may be set as a leftover of an earlier occurrence of the interrupt. **Parameters:** *InstancePtr* is a pointer to the **XSysAce** instance to work on. **Returns:**

void XSysAce\_InterruptHandler( void \* InstancePtr)

None.

None.

Note:

The interrupt handler for the System ACE driver. This handler must be connected by the user to an interrupt controller or source. This function does not save or restore context.

This function continues reading or writing to the compact flash if such an operation is in progress, and notifies the upper layer software through the event handler once the operation is complete or an error occurs. On an error, any command currently in progress is aborted.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance that just interrupted.

#### **Returns:**

None.

**Note:** 

None.

Set the callback function for handling events. The upper layer software should call this function during initialization. The events are passed asynchronously to the upper layer software. The events are described in **xsysace.h** and are named XSA\_EVENT\_\*.

Note that the callback is invoked by the driver within interrupt context, so it needs to do its job quickly. If there are potentially slow operations within the callback, these should be done at task-level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

*FuncPtr* is the pointer to the callback function.

CallBackRef is a reference pointer to be passed back to the upper layer.

#### **Returns:**

None.

Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## sysace/v1\_00\_a/src/xsysace\_jtagcfg.c File Reference

## **Detailed Description**

Contains functions to control the configuration of the target FPGA chain on the System ACE via the JTAG configuration port.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 06/17/02 work in progress

#include "xsysace.h"
#include "xsysace_l.h"
```

## **Functions**

```
void XSysAce_ResetCfg (XSysAce *InstancePtr)
void XSysAce_SetCfgAddr (XSysAce *InstancePtr, unsigned int Address)
void XSysAce_SetStartMode (XSysAce *InstancePtr, Xboolean ImmedOnReset, Xboolean
StartCfg)
XStatus XSysAce_ProgramChain (XSysAce *InstancePtr, Xuint8 *BufferPtr, int NumBytes)
Xboolean XSysAce_IsCfgDone (XSysAce *InstancePtr)
Xuint32 XSysAce_GetCfgSector (XSysAce *InstancePtr)
```

## **Function Documentation**

#### Xuint32 XSysAce\_GetCfgSector( XSysAce \* InstancePtr)

Get the sector ID of the CompactFlash sector being used for configuration of the target FPGA chain. This sector ID (or logical block address) only affects transfers between the ACE configuration logic and the CompactFlash card. This function is typically used for debug purposes to determine which sector was being accessed when an error occurred.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

The sector ID (logical block address) being used for data transfers between the ACE configuration logic and the CompactFlash. Sector IDs range from 0 to 0x10000000.

#### Note:

None.

#### **Xboolean** XSysAce\_IsCfgDone( XSysAce \* InstancePtr)

Check to see if the configuration of the target FPGA chain is complete. This function is typically only used in polled mode. In interrupt mode, an event (XSA\_EVENT\_CFG\_DONE) is returned to the user in the asynchronous event handler.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

XTRUE if the configuration is complete. XFALSE otherwise.

#### Note:

Program the target FPGA chain through the configuration JTAG port. This allows the user to program the devices on the target FPGA chain from the MPU port instead of from CompactFlash. The user specifies a buffer and the number of bytes to write. The buffer should be equivalent to an ACE (.ace) file.

Note that when loading the ACE file via the MPU port, the first sector of the ACE file is discarded. The CF filesystem controller in the System ACE device knows to skip the first sector when the ACE file comes from the CF, but the CF filesystem controller is bypassed when the ACE file comes from the MPU port. For this reason, this function skips the first sector of the buffer passed in.

In polled mode, the write is blocking. In interrupt mode, the write is non-blocking and an event, XSA\_EVENT\_CFG\_DONE, is returned to the user in the asynchronous event handler when the configuration is complete.

An MPU lock, obtained using **XSysAce\_Lock**(), must be granted before calling this function. If a lock has not been granted, no action is taken and an error is returned.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

BufferPtr is a pointer to a buffer that will be used to program the configuration JTAG

devices.

*NumBytes* is the number of bytes in the buffer. We assume that there is at least one

sector of data in the .ace file, which is the information sector.

#### **Returns:**

- XST\_SUCCESS if the write was successful. In interrupt mode, this does not mean
  the write is complete, only that it has begun. An event is returned to the user when
  the write is complete.
- XST\_SYSACE\_NO\_LOCK if no MPU lock has yet been granted
- XST\_FAILURE if an error occurred during the write. The user should call XSysAce\_GetErrors() to determine the cause of the error.

| N  | Oto. | • |
|----|------|---|
| Τ. | vic  | • |

Reset the JTAG configuration controller. This comprises a reset of the JTAG configuration controller and the CompactFlash controller (if it is currently being accessed by the configuration controller). Note that the MPU controller is not reset, meaning the MPU registers remain unchanged. The configuration controller is reset then released from reset in this function.

The CFGDONE status (and therefore interrupt) is cleared when the configuration controller is reset. If interrupts have been enabled, we go ahead and enable the CFGDONE interrupt here. This means that if and when a configuration process starts as a result of this reset, an interrupt will be received when it is complete.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

None.

#### Note:

This function is not thread-safe.

```
void XSysAce_SetCfgAddr( XSysAce * InstancePtr, unsigned int Address
)
```

Select the configuration address (or file) from the CompactFlash to be used for configuration of the target FPGA chain.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

Address is the address or file number to be used as the bitstream to configure the

target FPGA devices. There are 8 possible files, so the value of this parameter

can range from 0 to 7.

#### **Returns:**

None.

#### Note:

Set the start mode for configuration of the target FPGA chain from CompactFlash. The configuration process only starts after a reset. The user can indicate that the configuration should start immediately after a reset, or the configuration process can be delayed until the user commands it to start (using this function). The configuration controller can be reset using **XSysAce\_ResetCfg()**.

The user can select which configuration file on the CompactFlash to use using the **XSysAce\_SetCfgAddr**() function. If the user intends to configure the target FPGA chain directly from the MPU port, this function is not needed. Instead, the user would simply call **XSysAce\_ProgramChain**().

The user can use **XSysAce\_IsCfgDone**() when in polled mode to determine if the configuration is complete. If in interrupt mode, the event XSA\_EVENT\_CFG\_DONE will be returned asynchronously to the user when the configuration is complete. The user must call **XSysAce\_EnableInterrupt**() to put the device/driver into interrupt mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

ImmedOnReset can be set to XTRUE to indicate the configuration process will start

immediately after a reset of the ACE configuration controller, or it can be set to XFALSE to indicate the configuration process is delayed after a

reset until the user starts it (using this function).

StartCfg is a boolean indicating whether to start the configuration process or not.

When ImmedOnReset is set to XTRUE, this value is ignored. When ImmedOnReset is set to XFALSE, then this value controls when the configuration process is started. When set to XTRUE the configuration process starts (assuming a reset of the device has occurred), and when set

to XFALSE the configuration process does not start.

None.

Note:

## sysace/v1\_00\_a/src/xsysace\_selftest.c File Reference

## **Detailed Description**

Contains diagnostic functions for the System ACE device and driver. This includes a self-test to make sure communication to the device is possible and the ability to retrieve the ACE controller version.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00a rpm 06/17/02 work in progress

#include "xsysace.h"
#include "xsysace_l.h"
```

## **Functions**

```
XStatus XSysAce_SelfTest (XSysAce *InstancePtr)
Xuint16 XSysAce_GetVersion (XSysAce *InstancePtr)
```

## **Function Documentation**

Xuint16 XSysAce\_GetVersion( XSysAce \* InstancePtr)

Retrieve the version of the System ACE device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

A 16-bit version where the 4 most significant bits are the major version number, the next four bits are the minor version number, and the least significant 8 bits are the revision or build number.

#### Note:

None.

#### XStatus XSysAce\_SelfTest( XSysAce \* InstancePtr)

A self-test that simply proves communication to the ACE controller from the device driver by obtaining an MPU lock, verifying it, then releasing it.

#### **Parameters:**

*InstancePtr* is a pointer to the **XSysAce** instance to be worked on.

#### **Returns:**

XST\_SUCCESS if self-test passes, or XST\_FAILURE if an error occurs.

#### Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# sysace/v1\_00\_a/src/xsysace\_l.c File Reference

## **Detailed Description**

This file contains low-level functions to read and write CompactFlash sectors and ACE controller registers. These functions can be used when only the low-level functionality of the driver is desired. The user would typically use the high-level driver functions defined in **xsysace.h**.

#### MODIFICATION HISTORY:

## **Functions**

```
Xuint32 XSysAce_RegRead32 (Xuint32 Address)
Xuint16 XSysAce_RegRead16 (Xuint32 Address)
void XSysAce_RegWrite32 (Xuint32 Address, Xuint32 Data)
void XSysAce_RegWrite16 (Xuint32 Address, Xuint16 Data)
int XSysAce_ReadSector (Xuint32 BaseAddress, Xuint32 SectorId, Xuint8 *BufferPtr)
int XSysAce_WriteSector (Xuint32 BaseAddress, Xuint32 SectorId, Xuint8 *BufferPtr)
int XSysAce_ReadDataBuffer (Xuint32 BaseAddress, Xuint8 *BufferPtr, int Size)
```

## **Function Documentation**

```
int XSysAce_ReadDataBuffer( Xuint32 BaseAddress, Xuint8 * BufferPtr, int Size
```

Read the specified number of bytes from the data buffer of the ACE controller. The data buffer, which is 32 bytes, can only be read two bytes at a time. Once the data buffer is read, we wait for it to be filled again before reading the next buffer's worth of data.

#### **Parameters:**

BaseAddress is the base address of the device

BufferPtr is a pointer to a buffer in which to store data.

*Size* is the number of bytes to read

#### **Returns:**

The total number of bytes read, or 0 if an error occurred.

#### **Note:**

If Size is not aligned with the size of the data buffer (32 bytes), this function will read the entire data buffer, dropping the extra bytes on the floor since the user did not request them. This is necessary to get the data buffer to be ready again.

Read a CompactFlash sector. This is a blocking, low-level function which does not return until the specified sector is read.

#### **Parameters:**

BaseAddress is the base address of the device

SectorId is the id of the sector to read

BufferPtr is a pointer to a buffer where the data will be stored.

#### **Returns:**

The number of bytes read. If this number is not equal to the sector size, 512 bytes, then an error occurred.

#### **Note:**

None.

#### Xuint16 XSysAce\_RegRead16( Xuint32 Address)

Read a 16-bit value from the given address. Based on a compile-time constant, do the read in one 16-bit read or two 8-bit reads.

#### **Parameters:**

Address is the address to read from.

#### **Returns:**

The 16-bit value of the address.

#### Note:

No need for endian conversion in 8-bit mode since this function gets the bytes into their proper lanes in the 16-bit word.

#### Xuint32 XSysAce\_RegRead32( Xuint32 Address)

Read a 32-bit value from the given address. Based on a compile-time constant, do the read in two 16-bit reads or four 8-bit reads.

#### **Parameters:**

Address is the address to read from.

#### **Returns:**

The 32-bit value of the address.

#### Note:

No need for endian conversion in 8-bit mode since this function gets the bytes into their proper lanes in the 32-bit word.

```
void XSysAce_RegWrite16( Xuint32 Address, Xuint16 Data
)
```

Write a 16-bit value to the given address. Based on a compile-time constant, do the write in one 16-bit write or two 8-bit writes.

#### **Parameters:**

Address is the address to write to.

Data is the value to write

#### **Returns:**

None.

#### Note:

No need for endian conversion in 8-bit mode since this function writes the bytes into their proper lanes based on address.

```
void XSysAce_RegWrite32( Xuint32 Address,
Xuint32 Data
)
```

Write a 32-bit value to the given address. Based on a compile-time constant, do the write in two 16-bit writes or four 8-bit writes.

#### **Parameters:**

Address is the address to write to.

Data is the value to write

#### **Returns:**

None.

#### Note:

No need for endian conversion in 8-bit mode since this function writes the bytes into their proper lanes based on address.

```
int XSysAce_WriteDataBuffer( Xuint32 BaseAddress, Xuint8 * BufferPtr, int Size
```

Write the specified number of bytes to the data buffer of the ACE controller. The data buffer, which is 32 bytes, can only be written two bytes at a time. Once the data buffer is written, we wait for it to be empty again before writing the next buffer's worth of data. If the size of the incoming buffer is not aligned with the System ACE data buffer size (32 bytes), then this routine pads out the data buffer with zeros so the entire data buffer is written. This is necessary for the ACE controller to process the data buffer.

#### **Parameters:**

BaseAddress is the base address of the device

BufferPtr is a pointer to a buffer used to write to the controller.

Size is the number of bytes to write

#### **Returns:**

The total number of bytes written (not including pad bytes), or 0 if an error occurs.

#### Note:

```
int XSysAce_WriteSector( Xuint32 BaseAddress,
Xuint32 SectorId,
Xuint8 * BufferPtr
)
```

Write a CompactFlash sector. This is a blocking, low-level function which does not return until the specified sector is written in its entirety.

#### **Parameters:**

BaseAddress is the base address of the device SectorId is the id of the sector to write

BufferPtr is a pointer to a buffer used to write the sector.

#### **Returns:**

The number of bytes written. If this number is not equal to the sector size, 512 bytes, then an error occurred.

#### Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

## tmrctr/v1\_00\_b/src/xtmrctr.h File Reference

## **Detailed Description**

The Xilinx timer/counter component. This component supports the Xilinx timer/counter. More detailed description of the driver operation can be found in the **xtmrctr.c** file.

The Xilinx timer/counter supports the following features:

- Polled mode.
- Interrupt driven mode
- enabling and disabling specific timers
- PWM operation

The driver does not currently support the PWM operation of the device.

The timer counter operates in 2 primary modes, compare and capture. In either mode, the timer counter may count up or down, with up being the default.

Compare mode is typically used for creating a single time period or multiple repeating time periods in the auto reload mode, such as a periodic interrupt. When started, the timer counter loads an initial value, referred to as the compare value, into the timer counter and starts counting down or up. The timer counter expires when it rolls over/under depending upon the mode of counting. An external compare output signal may be configured such that a pulse is generated with this signal when it hits the compare value.

Capture mode is typically used for measuring the time period between external events. This mode uses an external capture input signal to cause the value of the timer counter to be captured. When started, the timer counter loads an initial value, referred to as the compare value,

The timer can be configured to either cause an interrupt when the count reaches the compare value in compare mode or latch the current count value in the capture register when an external input is asserted in capture mode. The external capture input can be enabled/disabled using the XTmrCtr\_SetOptions function. While in compare mode, it is also possible to drive an external output when the compare value is reached in the count register The external compare output can be enabled/disabled using the XTmrCtr\_SetOptions function.

#### **Interrupts**

It is the responsibility of the application to connect the interrupt handler of the timer/counter to the interrupt source. The interrupt handler function, XTmrCtr\_InterruptHandler, is visible such that the user can connect it to the interrupt source. Note that this interrupt handler does not provide interrupt context save and restore processing, the user must perform this processing.

The driver services interrupts and passes timeouts to the upper layer software through callback functions. The upper layer software must register its callback functions during initialization. The driver requires callback functions for timers.

#### Note:

The default settings for the timers are:

- o Interrupt generation disabled
- o Count up mode
- o Compare mode
- Hold counter (will not reload the timer)
- o External compare output disabled
- o External capture input disabled
- Pulse width modulation disabled
- o Timer disabled, waits for Start function to be called

A timer counter device may contain multiple timer counters. The symbol XTC\_DEVICE\_TIMER\_COUNT defines the number of timer counters in the device. The device currently contains 2 timer counters.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XTmrCtr_Config
struct XTmrCtrStats
```

## **Configuration options**

These options are used in **XTmrCtr\_SetOptions**() and **XTmrCtr\_GetOptions**()

```
#define XTC_ENABLE_ALL_OPTION
```

```
#define XTC_DOWN_COUNT_OPTION
#define XTC_CAPTURE_MODE_OPTION
#define XTC_INT_MODE_OPTION
#define XTC_AUTO_RELOAD_OPTION
#define XTC_EXT_COMPARE_OPTION
```

## **Typedefs**

typedef void(\* XTmrCtr\_Handler )(void \*CallBackRef, Xuint8 TmrCtrNumber)

## **Functions**

```
XStatus XTmrCtr_Initialize (XTmrCtr *InstancePtr, Xuint16 DeviceId)
void XTmrCtr_Start (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_Stop (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)

Xuint32 XTmrCtr_GetValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetResetValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber, Xuint32 ResetValue)

Xuint32 XTmrCtr_GetCaptureValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
Xboolean XTmrCtr_IsExpired (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_Reset (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetOptions (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber, Xuint32 Options)

Xuint32 XTmrCtr_GetOptions (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_GetStats (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_GetStats (XTmrCtr *InstancePtr, XTmrCtrStats *StatsPtr)
void XTmrCtr_ClearStats (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetHandler (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetHandler (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetHandler (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
```

### **Define Documentation**

#### #define XTC\_AUTO\_RELOAD\_OPTION

Used to configure the timer counter device.

| XTC_ENABLE_ALL_OPTION   | Enables all timer counters at once.               |
|-------------------------|---------------------------------------------------|
| XTC_DOWN_COUNT_OPTION   | Configures the timer counter to count down from   |
|                         | start value, the default is to count up.          |
| XTC_CAPTURE_MODE_OPTION | Configures the timer to capture the timer counter |
|                         | value when the external capture line is asserted. |
|                         | The default mode is compare mode.                 |
| XTC_INT_MODE_OPTION     | Enables the timer counter interrupt output.       |
| XTC_AUTO_RELOAD_OPTION  | In compare mode, configures the timer counter to  |
|                         | reload from the compare value. The default mode   |
|                         | causes the timer counter to hold when the compare |

value is hit.

In capture mode, configures the timer counter to not hold the previous capture value if a new event occurs. The default mode cause the timer counter to hold the capture value until recognized.

XTC EXT COMPARE OPTION

Enables the external compare output signal.

#### #define XTC CAPTURE MODE OPTION

Used to configure the timer counter device.

XTC AUTO RELOAD OPTION

XTC\_ENABLE\_ALL\_OPTION Enables all timer counters at once.

XTC\_DOWN\_COUNT\_OPTION Configures the timer counter to count down from

start value, the default is to count up.

XTC\_CAPTURE\_MODE\_OPTION Configures the timer to capture the timer counter

value when the external capture line is asserted.

The default mode is compare mode.

XTC\_INT\_MODE\_OPTION Enables the timer counter interrupt output.

In compare mode, configures the timer counter to reload from the compare value. The default mode causes the timer counter to hold when the compare

value is hit.

In capture mode, configures the timer counter to not hold the previous capture value if a new event

occurs. The default mode cause the timer counter to hold the capture value until recognized.

XTC\_EXT\_COMPARE\_OPTION Enables the external compare output signal.

#### #define XTC DOWN COUNT OPTION

XTC\_AUTO\_RELOAD\_OPTION

Used to configure the timer counter device.

XTC\_ENABLE\_ALL\_OPTION Enables all timer counters at once.

XTC\_DOWN\_COUNT\_OPTION Configures the timer counter to count down from

start value, the default is to count up.

XTC\_CAPTURE\_MODE\_OPTION Configures the timer to capture the timer counter

value when the external capture line is asserted.

The default mode is compare mode.

XTC\_INT\_MODE\_OPTION Enables the timer counter interrupt output.

In compare mode, configures the timer counter to reload from the compare value. The default mode causes the timer counter to hold when the compare

value is hit.

In capture mode, configures the timer counter to not hold the previous capture value if a new event occurs. The default mode cause the timer counter

to hold the capture value until recognized.

XTC\_EXT\_COMPARE\_OPTION Enables the external compare output signal.

#### #define XTC\_ENABLE\_ALL\_OPTION

XTC\_AUTO\_RELOAD\_OPTION

Used to configure the timer counter device.

XTC\_ENABLE\_ALL\_OPTION Enables all timer counters at once.

XTC\_DOWN\_COUNT\_OPTION Configures the timer counter to count down from

start value, the default is to count up.

XTC\_CAPTURE\_MODE\_OPTION Configures the timer to capture the timer counter

value when the external capture line is asserted.

The default mode is compare mode.

XTC\_INT\_MODE\_OPTION Enables the timer counter interrupt output.

In compare mode, configures the timer counter to reload from the compare value. The default mode causes the timer counter to hold when the compare

value is hit.

In capture mode, configures the timer counter to not hold the previous capture value if a new event occurs. The default mode cause the timer counter

to hold the capture value until recognized.

XTC\_EXT\_COMPARE\_OPTION Enables the external compare output signal.

#### #define XTC\_EXT\_COMPARE\_OPTION

Used to configure the timer counter device.

XTC ENABLE ALL OPTION Enables all timer counters at once.

XTC\_DOWN\_COUNT\_OPTION Configures the timer counter to count down from

start value, the default is to count up.

XTC\_CAPTURE\_MODE\_OPTION Configures the timer to capture the timer counter

value when the external capture line is asserted.

The default mode is compare mode.

XTC\_INT\_MODE\_OPTION Enables the timer counter interrupt output.

XTC\_AUTO\_RELOAD\_OPTION In compare mode, configures the timer counter to reload from the compare value. The default mode

causes the timer counter to hold when the compare

value is hit.

In capture mode, configures the timer counter to not hold the previous capture value if a new event occurs. The default mode cause the timer counter

to hold the capture value until recognized.

XTC\_EXT\_COMPARE\_OPTION Enables the external compare output signal.

#### #define XTC\_INT\_MODE\_OPTION

Used to configure the timer counter device.

| XTC_ENABLE_ALL_OPTION   | Enables all timer counters at once.                |
|-------------------------|----------------------------------------------------|
| XTC_DOWN_COUNT_OPTION   | Configures the timer counter to count down from    |
|                         | start value, the default is to count up.           |
| XTC_CAPTURE_MODE_OPTION | Configures the timer to capture the timer counter  |
|                         | value when the external capture line is asserted.  |
|                         | The default mode is compare mode.                  |
| XTC_INT_MODE_OPTION     | Enables the timer counter interrupt output.        |
| XTC_AUTO_RELOAD_OPTION  | In compare mode, configures the timer counter to   |
|                         | reload from the compare value. The default mode    |
|                         | causes the timer counter to hold when the compare  |
|                         | value is hit.                                      |
|                         | In capture mode, configures the timer counter to   |
|                         | not hold the previous capture value if a new event |
|                         | occurs. The default mode cause the timer counter   |
|                         | to hold the capture value until recognized.        |
| XTC_EXT_COMPARE_OPTION  | Enables the external compare output signal.        |
|                         |                                                    |

## **Typedef Documentation**

#### typedef void(\* XTmrCtr\_Handler)(void \*CallBackRef, Xuint8 TmrCtrNumber)

Signature for the callback function.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the callback functions,

and passed back to the upper layer when the callback is invoked. Its type is unimportant to

the driver, so it is a void pointer.

*TmrCtrNumber* is the number of the timer/counter within the device. The device typically contains at least

two timer/counters. The timer number is a zero based number with a range of 0 to

(XTC\_DEVICE\_TIMER\_COUNT - 1).

## **Function Documentation**

void XTmrCtr\_ClearStats( XTmrCtr \* InstancePtr)

Clear the **XTmrCtrStats** structure for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

Returns the timer counter value that was captured the last time the external capture input was asserted.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The current capture value for the indicated timer counter.

#### Note:

None.

Get the options for the specified timer counter.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The currently set options. An option which is set to a '1' is enabled and set to a '0' is disabled. The options are bit masks such that multiple options may be set or cleared. The options are described in **xtmrctr.h**.

#### Note:

None.

Get a copy of the XTmrCtrStats structure, which contains the current statistics for this driver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

StatsPtr is a pointer to a XTmrCtrStats structure which will get a copy of current statistics.

#### **Returns:**

None.

#### Note:

None.

Get the current value of the specified timer counter. The timer counter may be either incrementing or decrementing based upon the current mode of operation.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The current value for the timer counter.

#### Note:

Initializes a specific timer/counter instance/driver. Initialize fields of the **XTmrCtr** structure, then reset the timer/counter

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XTmrCtr** component. Passing in a device id associates the generic **XTmrCtr** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- o XST DEVICE NOT FOUND if the device doesn't exist

#### Note:

None.

#### void XTmrCtr\_InterruptHandler( void \* InstancePtr)

Interrupt Service Routine (ISR) for the driver. This function only performs processing for the device and does not save and restore the interrupt context.

#### **Parameters:**

*InstancePtr* contains a pointer to the timer/counter instance for the nterrupt.

#### **Returns:**

None.

#### Note:

None.

```
Xboolean XTmrCtr_IsExpired( XTmrCtr * InstancePtr, Xuint8 TmrCtrNumber
```

Checks if the specified timer counter of the device has expired. In capture mode, expired is defined as a capture occurred. In compare mode, expired is defined as the timer counter rolled over/under for up/down counting.

When interrupts are enabled, the expiration causes an interrupt. This function is typically used to poll a timer counter to determine when it has expired.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

XTRUE if the timer has expired, and XFALSE otherwise.

#### Note:

None.

Resets the specified timer counter of the device. A reset causes the timer counter to set it's value to the reset value.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of  $\boldsymbol{0}$  -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

#### Note:

None.

Runs a self-test on the driver/device. This test verifies that the specified timer counter of the device can be enabled and increments.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

XST\_SUCCESS if self-test was successful, or XST\_FAILURE if the timer is not incrementing.

#### Note:

This is a destructive test using the provided timer. The current settings of the timer are returned to the initialized values and all settings at the time this function is called are overwritten.

Sets the timer callback function, which the driver calls when the specified timer times out.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

FuncPtr is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context so the function that is called should either be short or pass the more extensive processing off to another task to allow the interrupt to return and normal processing to continue.

Enables the specified options for the specified timer counter. This function sets the options without regard to the current options of the driver. To prevent a loss of the current options, the user should call **XTmrCtr\_GetOptions**() prior to this function and modify the retrieved options to pass into this function to prevent loss of the current options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

Options contains the desired options to be set or cleared. Setting the option to '1' enables the

option, clearing the to '0' disables the option. The options are bit masks such that multiple

options may be set or cleared. The options are described in **xtmrctr.h**.

#### **Returns:**

None.

#### **Note:**

Set the reset value for the specified timer counter. This is the value that is loaded into the timer counter when it is reset. This value is also loaded when the timer counter is started.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

*ResetValue* contains the value to be used to reset the timer counter.

#### **Returns:**

None.

Note:

None.

Starts the specified timer counter of the device such that it starts running. The timer counter is reset before it is started and the reset value is loaded into the timer counter.

If interrupt mode is specified in the options, it is necessary for the caller to connect the interrupt handler of the timer/counter to the interrupt source, typically an interrupt controller, and enable the interrupt within the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

Note:

Stops the timer counter by disabling it.

It is the callers' responsibility to disconnect the interrupt handler of the timer\_counter from the interrupt source, typically an interrupt controller, and disable the interrupt within the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain multiple timer

counters. The timer number is a zero based number with a range of 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

| R | eſ | 11 | r | n | c | • |
|---|----|----|---|---|---|---|
| • |    |    |   |   | • | 0 |

None.

**Note:** 

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# tmrctr/v1\_00\_b/src/xtmrctr.c File Reference

## **Detailed Description**

Contains required functions for the **XTmrCtr** driver.

MODIFICATION HISTORY:

## **Functions**

```
XStatus XTmrCtr_Initialize (XTmrCtr *InstancePtr, Xuint16 DeviceId)
void XTmrCtr_Start (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_Stop (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)

Xuint32 XTmrCtr_GetValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
void XTmrCtr_SetResetValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber, Xuint32
ResetValue)

Xuint32 XTmrCtr_GetCaptureValue (XTmrCtr *InstancePtr, Xuint8 TmrCtrNumber)
```

## **Function Documentation**

Returns the timer counter value that was captured the last time the external capture input was asserted.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The current capture value for the indicated timer counter.

#### Note:

None.

Get the current value of the specified timer counter. The timer counter may be either incrementing or decrementing based upon the current mode of operation.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The current value for the timer counter.

Note:

None.

Initializes a specific timer/counter instance/driver. Initialize fields of the **XTmrCtr** structure, then reset the timer/counter

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XTmrCtr** component. Passing in a device id associates the generic **XTmrCtr** component to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- XST\_DEVICE\_NOT\_FOUND if the device doesn't exist

#### Note:

None.

Checks if the specified timer counter of the device has expired. In capture mode, expired is defined as a capture occurred. In compare mode, expired is defined as the timer counter rolled over/under for up/down counting.

When interrupts are enabled, the expiration causes an interrupt. This function is typically used to poll a timer counter to determine when it has expired.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

XTRUE if the timer has expired, and XFALSE otherwise.

#### Note:

None.

Resets the specified timer counter of the device. A reset causes the timer counter to set it's value to the reset value.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

#### Note:

Set the reset value for the specified timer counter. This is the value that is loaded into the timer counter when it is reset. This value is also loaded when the timer counter is started.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain

multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

*ResetValue* contains the value to be used to reset the timer counter.

#### **Returns:**

None.

Note:

None.

Starts the specified timer counter of the device such that it starts running. The timer counter is reset before it is started and the reset value is loaded into the timer counter.

If interrupt mode is specified in the options, it is necessary for the caller to connect the interrupt handler of the timer/counter to the interrupt source, typically an interrupt controller, and enable the interrupt within the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain

multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

Note:

Stops the timer counter by disabling it.

It is the callers' responsibility to disconnect the interrupt handler of the timer\_counter from the interrupt source, typically an interrupt controller, and disable the interrupt within the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

#### **Note:**

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

## Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XTmrCtr Struct Reference

#include <xtmrctr.h>

## **Detailed Description**

The XTmrCtr driver instance data. The user is required to allocate a variable of this type for every timer/counter device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• tmrctr/v1\_00\_b/src/xtmrctr.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# tmrctr/v1\_00\_b/src/xtmrctr\_i.h File Reference

## **Detailed Description**

This file contains data which is shared between files internal to the **XTmrCtr** component. It is intended for internal use only.

```
MODIFICATION HISTORY:
```

#include "xbasic\_types.h"

```
        Ver
        Who
        Date
        Changes

        -----
        -----
        -----

        1.00b
        jhl
        02/06/02
        First release
```

## **Variables**

XTmrCtr\_Config XTmrCtr\_ConfigTable []

## **Variable Documentation**

### XTmrCtr\_Config XTmrCtr\_ConfigTable[]( )

The timer/counter configuration table, sized by the number of instances defined in **xparameters.h**.

## Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XTmrCtr\_Config Struct Reference

#include <xtmrctr.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress

## **Field Documentation**

Xuint32 XTmrCtr\_Config::BaseAddress

Register base address

Xuint16 XTmrCtr\_Config::DeviceId

Unique ID of device

The documentation for this struct was generated from the following file:

• tmrctr/v1\_00\_b/src/xtmrctr.h

# tmrctr/v1\_00\_b/src/xtmrctr\_l.h File Reference

## **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation. High-level driver functions are defined in **xtmrctr.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 04/24/02 First release

#include "xbasic_types.h"
#include "xio.h"
```

### **Defines**

```
#define XTC_DEVICE_TIMER_COUNT

#define XTimerCtr_mReadReg(BaseAddress, TmrCtrNumber, RegOffset)

#define XTmrCtr_mWriteReg(BaseAddress, TmrCtrNumber, RegOffset, ValueToWrite)

#define XTmrCtr_mSetControlStatusReg(BaseAddress, TmrCtrNumber, RegisterValue)

#define XTmrCtr_mGetControlStatusReg(BaseAddress, TmrCtrNumber)

#define XTmrCtr_mGetTimerCounterReg(BaseAddress, TmrCtrNumber)

#define XTmrCtr_mSetLoadReg(BaseAddress, TmrCtrNumber, RegisterValue)

#define XTmrCtr_mGetLoadReg(BaseAddress, TmrCtrNumber)

#define XTmrCtr_mGetLoadReg(BaseAddress, TmrCtrNumber)
```

```
#define XTmrCtr_mDisable(BaseAddress, TmrCtrNumber)
#define XTmrCtr_mEnableIntr(BaseAddress, TmrCtrNumber)
#define XTmrCtr_mDisableIntr(BaseAddress, TmrCtrNumber)
#define XTmrCtr_mLoadTimerCounterReg(BaseAddress, TmrCtrNumber)
#define XTmrCtr mHasEventOccurred(BaseAddress, TmrCtrNumber)
```

## **Define Documentation**

#### #define XTC\_DEVICE\_TIMER\_COUNT

Defines the number of timer counters within a single hardware device. This number is not currently parameterized in the hardware but may be in the future.

Read one of the timer counter registers.

#### **Parameters:**

BaseAddress contains the base address of the timer counter device.

TmrCtrNumber contains the specific timer counter within the device, a zero based

 $number, 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).$ 

RegOffset contains the offset from the 1st register of the timer counter to select the

specific register of the timer counter.

#### **Returns:**

The value read from the register, a 32 bit value.

#### Note:

None.

## #define XTmrCtr\_mDisable( BaseAddress, TmrCtrNumber )

Disable a timer counter such that it stops running.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

Note:

None.

#### 

Disable the interrupt for a timer counter.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

**Note:** 

None.

#define XTmrCtr\_mEnable( BaseAddress, TmrCtrNumber )

Enable a timer counter such that it starts running.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC DEVICE TIMER COUNT - 1).

#### **Returns:**

None.

#### **Note:**

None.

## #define XTmrCtr\_mEnableIntr( BaseAddress, TmrCtrNumber )

Enable the interrupt for a timer counter.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC DEVICE TIMER COUNT - 1).

#### **Returns:**

None.

#### Note:

None.

#define XTmrCtr\_mGetControlStatusReg( BaseAddress, TmrCtrNumber )

Get the Control Status Register of a timer counter.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The value read from the register, a 32 bit value.

#### Note:

None.

#### 

Get the Load Register of a timer counter.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The value read from the register, a 32 bit value.

#### Note:

None.

## #define XTmrCtr\_mGetTimerCounterReg( BaseAddress, TmrCtrNumber )

Get the Timer Counter Register of a timer counter.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The value read from the register, a 32 bit value.

**Note:** 

None.

## #define XTmrCtr\_mHasEventOccurred( BaseAddress, TmrCtrNumber )

Determine if a timer counter event has occurred. Events are defined to be when a capture has occurred or the counter has roller over.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

Note:

None.

## #define XTmrCtr\_mLoadTimerCounterReg( BaseAddress, TmrCtrNumber )

Cause the timer counter to load it's Timer Counter Register with the value in the Load Register.



BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

None.

#### **Note:**

None.

### $\# define\ XTmrCtr\_mSetControlStatusReg (\ BaseAddress,$

TmrCtrNumber, RegisterValue )

Set the Control Status Register of a timer counter to the specified value.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

RegisterValue is the 32 bit value to be written to the register.

#### **Returns:**

None.

#### Note:

None.

### ${\it \#define~XTmrCtr\_mSetLoadReg(~BaseAddress,}$

TmrCtrNumber, RegisterValue

Set the Load Register of a timer counter to the specified value.

#### **Parameters:**

BaseAddress is the base address of the device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC\_DEVICE\_TIMER\_COUNT - 1).

RegisterValue is the 32 bit value to be written to the register.

#### **Returns:**

None.

#### Note:

None.

#### #define XTmrCtr\_mWriteReg( BaseAddress,

TmrCtrNumber, RegOffset, ValueToWrite

Write a specified value to a register of a timer counter.

#### **Parameters:**

BaseAddress is the base address of the timer counter device.

TmrCtrNumber is the specific timer counter within the device, a zero based number, 0 -

(XTC DEVICE TIMER COUNT - 1).

RegOffset contain the offset from the 1st register of the timer counter to select the

specific register of the timer counter.

*ValueToWrite* is the 32 bit value to be written to the register.

#### **Returns:**

None

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XTmrCtrStats Struct Reference

#include <xtmrctr.h>

## **Detailed Description**

Timer/Counter statistics

## **Data Fields**

**Xuint32 Interrupts** 

## **Field Documentation**

#### Xuint32 XTmrCtrStats::Interrupts

The number of interrupts that have occurred

The documentation for this struct was generated from the following file:

• tmrctr/v1\_00\_b/src/xtmrctr.h

# tmrctr/v1\_00\_b/src/xtmrctr\_stats.c File Reference

## **Detailed Description**

Contains function to get and clear statistics for the **XTmrCtr** component.

MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00b jhl 02/06/02 First release

#include "xbasic_types.h"
#include "xtmrctr.h"
```

## **Functions**

```
void XTmrCtr_GetStats (XTmrCtr *InstancePtr, XTmrCtrStats *StatsPtr)
void XTmrCtr_ClearStats (XTmrCtr *InstancePtr)
```

## **Function Documentation**

```
void XTmrCtr_ClearStats( XTmrCtr * InstancePtr)
```

| Donomotona                                                                                            |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Parameters:  InstancePtr is a pointer to the XTmrCtr instance to be worked on.                        |  |  |  |  |  |  |  |
| Returns: None.                                                                                        |  |  |  |  |  |  |  |
| Note: None.                                                                                           |  |  |  |  |  |  |  |
| void XTmrCtr_GetStats( XTmrCtr * InstancePtr,                                                         |  |  |  |  |  |  |  |
| Get a copy of the XTmrCtrStats structure, which contains the current statistics for this driver.      |  |  |  |  |  |  |  |
| Parameters:                                                                                           |  |  |  |  |  |  |  |
| <i>InstancePtr</i> is a pointer to the <b>XTmrCtr</b> instance to be worked on.                       |  |  |  |  |  |  |  |
| StatsPtr is a pointer to a <b>XTmrCtrStats</b> structure which will get a copy of current statistics. |  |  |  |  |  |  |  |
| Returns: None.                                                                                        |  |  |  |  |  |  |  |
| Notes                                                                                                 |  |  |  |  |  |  |  |

Clear the **XTmrCtrStats** structure for this driver.

None.

# tmrctr/v1\_00\_b/src/xtmrctr\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of timer/counter devices in the system. Each timer/counter device should have an entry in this table.

#### MODIFICATION HISTORY:

### **Variables**

XTmrCtr\_Config XTmrCtr\_ConfigTable [XPAR\_XTMRCTR\_NUM\_INSTANCES]

### **Variable Documentation**

#### XTmrCtr\_Config XTmrCtr\_ConfigTable[XPAR\_XTMRCTR\_NUM\_INSTANCES]

The timer/counter configuration table, sized by the number of instances defined in **xparameters.h**.

## tmrctr/v1\_00\_b/src/xtmrctr\_options.c File Reference

## **Detailed Description**

Contains configuration options functions for the **XTmrCtr** component.

MODIFICATION HISTORY:

### **Data Structures**

struct Mapping

## **Functions**

void XTmrCtr\_SetOptions (XTmrCtr \*InstancePtr, Xuint8 TmrCtrNumber, Xuint32 Options)
Xuint32 XTmrCtr\_GetOptions (XTmrCtr \*InstancePtr, Xuint8 TmrCtrNumber)

## **Function Documentation**

Get the options for the specified timer counter.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

*TmrCtrNumber* is the timer counter of the device to operate on. Each device may contain multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

The currently set options. An option which is set to a '1' is enabled and set to a '0' is disabled. The options are bit masks such that multiple options may be set or cleared. The options are described in **xtmrctr.h**.

#### Note:

None.

Enables the specified options for the specified timer counter. This function sets the options without regard to the current options of the driver. To prevent a loss of the current options, the user should call **XTmrCtr\_GetOptions**() prior to this function and modify the retrieved options to pass into this function to prevent loss of the current options.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain

multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

Options contains the desired options to be set or cleared. Setting the option to '1'

enables the option, clearing the to '0' disables the option. The options are bit masks such that multiple options may be set or cleared. The options

are described in **xtmrctr.h**.

| Retur | ns:   |  |  |  |
|-------|-------|--|--|--|
|       | None. |  |  |  |
|       |       |  |  |  |
| Note: |       |  |  |  |
|       | None. |  |  |  |
|       |       |  |  |  |
|       |       |  |  |  |

# tmrctr/v1\_00\_b/src/xtmrctr\_intr.c File Reference

## **Detailed Description**

Contains interrupt-related functions for the **XTmrCtr** component.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 02/06/02 First release

#include "xbasic_types.h"
#include "xtmrctr.h"
#include "xtmrctr.h"
```

## **Functions**

## **Function Documentation**

void XTmrCtr\_InterruptHandler( void \* InstancePtr)

Interrupt Service Routine (ISR) for the driver. This function only performs processing for the device and does not save and restore the interrupt context.

#### **Parameters:**

*InstancePtr* contains a pointer to the timer/counter instance for the nterrupt.

#### **Returns:**

None.

#### **Note:**

None.

Sets the timer callback function, which the driver calls when the specified timer times out.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

*FuncPtr* is the pointer to the callback function.

#### **Returns:**

None.

#### Note:

The handler is called within interrupt context so the function that is called should either be short or pass the more extensive processing off to another task to allow the interrupt to return and normal processing to continue.

## tmrctr/v1\_00\_b/src/xtmrctr\_selftest.c File Reference

## **Detailed Description**

Contains diagnostic/self-test functions for the **XTmrCtr** component.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes

1.00b jhl 02/06/02 First release

#include "xbasic_types.h"

#include "xio.h"

#include "xtmrctr.h"

#include "xtmrctr.i.h"
```

## **Functions**

XStatus XTmrCtr\_SelfTest (XTmrCtr \*InstancePtr, Xuint8 TmrCtrNumber)

## **Function Documentation**

Runs a self-test on the driver/device. This test verifies that the specified timer counter of the device can be enabled and increments.

#### **Parameters:**

*InstancePtr* is a pointer to the **XTmrCtr** instance to be worked on.

TmrCtrNumber is the timer counter of the device to operate on. Each device may contain

multiple timer counters. The timer number is a zero based number with a

range of 0 - (XTC\_DEVICE\_TIMER\_COUNT - 1).

#### **Returns:**

XST\_SUCCESS if self-test was successful, or XST\_FAILURE if the timer is not incrementing.

#### Note:

This is a destructive test using the provided timer. The current settings of the timer are returned to the initialized values and all settings at the time this function is called are overwritten.

# uartlite/v1\_00\_b/src/xuartlite\_stats.c File Reference

## **Detailed Description**

This file contains the statistics functions for the UART Lite component (**XUartLite**).

MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 08/31/01 First release
1.00b jhl 02/21/02 Repartitioned the driver for smaller files

#include "xbasic_types.h"
#include "xuartlite.h"
#include "xuartlite_i.h"
```

## **Functions**

```
void XUartLite_GetStats (XUartLite *InstancePtr, XUartLite_Stats *StatsPtr)
void XUartLite_ClearStats (XUartLite *InstancePtr)
```

## **Function Documentation**

void XUartLite\_ClearStats( XUartLite \* InstancePtr)

| Paran   | neters:                                                             |                                                                                      |  |  |  |  |  |  |
|---------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|--|
|         | InstancePtr                                                         | is a pointer to the <b>XUartLite</b> instance to be worked on.                       |  |  |  |  |  |  |
| Retur   | <b>ns:</b><br>None.                                                 |                                                                                      |  |  |  |  |  |  |
| Note:   | None.                                                               |                                                                                      |  |  |  |  |  |  |
| void XU | artLite_Ge                                                          | tStats( XUartLite * InstancePtr,                                                     |  |  |  |  |  |  |
| Return  | ıs a snapshot                                                       | of the current statistics in the structure specified.                                |  |  |  |  |  |  |
| Paran   | neters:                                                             |                                                                                      |  |  |  |  |  |  |
|         | InstancePtr is a pointer to the XUartLite instance to be worked on. |                                                                                      |  |  |  |  |  |  |
|         | StatsPtr                                                            | is a pointer to a XUartLiteStats structure to where the statistics are to be copied. |  |  |  |  |  |  |
| Retur   |                                                                     |                                                                                      |  |  |  |  |  |  |
|         | None.                                                               |                                                                                      |  |  |  |  |  |  |
| Note:   |                                                                     |                                                                                      |  |  |  |  |  |  |
|         | None.                                                               |                                                                                      |  |  |  |  |  |  |

This function zeros the statistics for the given instance.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XUartLite Struct Reference

#include <xuartlite.h>

## **Detailed Description**

The XUartLite driver instance data. The user is required to allocate a variable of this type for every UART Lite device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• uartlite/v1\_00\_b/src/xuartlite.h

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# uartlite/v1\_00\_b/src/xuartlite.h File Reference

## **Detailed Description**

This component contains the implementation of the **XUartLite** component which is the driver for the Xilinx UART Lite device. This UART is a minimal hardware implementation with minimal features. Most of the features, including baud rate, parity, and number of data bits are only configurable when the hardware device is built, rather than at run time by software.

The device has 16 byte transmit and receive FIFOs and supports interrupts. The device does not have any way to disable the receiver such that the receive FIFO may contain unwanted data. The FIFOs are not flushed when the driver is initialized, but a function is provided to allow the user to reset the FIFOs if desired.

The driver defaults to no interrupts at initialization such that interrupts must be enabled if desired. An interrupt is generated when the transmit FIFO transitions from having data to being empty or when any data is contained in the receive FIFO.

In order to use interrupts, it's necessary for the user to connect the driver interrupt handler, XUartLite\_InterruptHandler, to the interrupt system of the application. This function does not save and restore the processor context such that the user must provide it. Send and receive handlers may be set for the driver such that the handlers are called when transmit and receive interrupts occur. The handlers are called from interrupt context and are designed to allow application specific processing to be performed.

The functions, XUartLite\_Send and XUartLite\_Recv, are provided in the driver to allow data to be sent and received. They are designed to be used in polled or interrupt modes.

The driver provides a status for each received byte indicating any parity frame or overrun error. The driver provides statistics which allow visibility into these errors.

#### **RTOS Independence**

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### Note:

The driver is partitioned such that a minimal implementation may be used. More features require additional files to be linked in.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XUartLite
struct XUartLite_Buffer
struct XUartLite_Config
struct XUartLite Stats
```

## **Typedefs**

typedef void(\* XUartLite\_Handler )(void \*CallBackRef, unsigned int ByteCount)

## **Functions**

```
XStatus XUartLite_Initialize (XUartLite *InstancePtr, Xuint16 DeviceId)
void XUartLite_ResetFifos (XUartLite *InstancePtr)
unsigned int XUartLite_Send (XUartLite *InstancePtr, Xuint8 *DataBufferPtr, unsigned int NumBytes)
```

```
unsigned int XUartLite_Recv (XUartLite *InstancePtr, Xuint8 *DataBufferPtr, unsigned int NumBytes)

Xboolean XUartLite_IsSending (XUartLite *InstancePtr)

void XUartLite_GetStats (XUartLite *InstancePtr, XUartLite_Stats *StatsPtr)

void XUartLite_ClearStats (XUartLite *InstancePtr)

XStatus XUartLite_SelfTest (XUartLite *InstancePtr)

void XUartLite_EnableInterrupt (XUartLite *InstancePtr)

void XUartLite_DisableInterrupt (XUartLite *InstancePtr)

void XUartLite_DisableInterrupt (XUartLite *InstancePtr, XUartLite_Handler

FuncPtr, void *CallBackRef)

void XUartLite_SetSendHandler (XUartLite *InstancePtr, XUartLite_Handler

FuncPtr, void *CallBackRef)

void XUartLite_InterruptHandler (XUartLite *InstancePtr)
```

## **Typedef Documentation**

#### typedef void(\* XUartLite\_Handler)(void \*CallBackRef, unsigned int ByteCount)

Callback function. The first argument is a callback reference passed in by the upper layer when setting the callback functions, and passed back to the upper layer when the callback is invoked. The second argument is the ByteCount which is the number of bytes that actually moved from/to the buffer provided in the \_Send/\_Receive call.

## **Function Documentation**

#### void XUartLite\_ClearStats( XUartLite \* InstancePtr)

This function zeros the statistics for the given instance.

#### **Parameters:**

InstancePtr is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

None.

#### Note:

### void XUartLite\_DisableInterrupt( XUartLite \* InstancePtr)

This function disables the UART interrupt. After calling this function, data may still be received by the UART but no interrupt will be generated since the hardware device has no way to disable the receiver.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

None.

Note:

None.

#### void XUartLite\_EnableInterrupt( XUartLite \* InstancePtr)

This function enables the UART interrupt such that an interrupt will occur when data is received or data has been transmitted. The device contains 16 byte receive and transmit FIFOs such that an interrupt is generated anytime there is data in the receive FIFO and when the transmit FIFO transitions from not empty to empty.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

None.

Note:

Returns a snapshot of the current statistics in the structure specified.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

StatsPtr is a pointer to a XUartLiteStats structure to where the statistics are to be copied.

#### **Returns:**

None.

#### **Note:**

None.

Initialize a **XUartLite** instance. The receive and transmit FIFOs of the UART are not flushed, so the user may want to flush them. The hardware device does not have any way to disable the receiver such that any valid data may be present in the receive FIFO. This function disables the UART interrupt. The baudrate and format of the data are fixed in the hardware at hardware build time.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XUartLite** instance. Passing in a device id associates the generic **XUartLite** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- XST\_DEVICE\_NOT\_FOUND if the device is not found in the configuration table.

#### Note:

This function is the interrupt handler for the UART lite driver. It must be connected to an interrupt system by the user such that it is called when an interrupt for any UART lite occurs. This function does not save or restore the processor context such that the user must ensure this occurs.

#### **Parameters:**

InstancePtr contains a pointer to the instance of the UART that the interrupt is for.

#### **Returns:**

None.

Note:

None.

#### **Xboolean XUartLite\_IsSending(XUartLite\*** *InstancePtr)*

This function determines if the specified UART is sending data. If the transmitter register is not empty, it is sending data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

A value of XTRUE if the UART is sending data, otherwise XFALSE.

#### Note:

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer in the FIFO. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue receiving data until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

BufferPtr is pointer to buffer for data to be received into

NumBytes is the number of bytes to be received. A value of zero will stop a previous

receive operation that is in progress in interrupt mode.

#### **Returns:**

The number of bytes received.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

### void XUartLite\_ResetFifos( XUartLite \* InstancePtr)

This function resets the FIFOs, both transmit and receive, of the UART such that they are emptied. Since the UART does not have any way to disable it from receiving data, it may be necessary for the application to reset the FIFOs to get rid of any unwanted data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

| R | ഹ | - | <br>• | • |  |
|---|---|---|-------|---|--|
| • | - |   |       |   |  |
|   |   |   |       |   |  |

None.

#### Note:

#### XStatus XUartLite\_SelfTest( XUartLite \* InstancePtr)

Runs a self-test on the device hardware. Since there is no way to perform a loopback in the hardware, this test can only check the state of the status register to verify it is correct. This test assumes that the hardware device is still in its reset state, but has been initialized with the Initialize function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the self-test was successful.
- XST\_FAILURE if the self-test failed, the status register value was not correct

#### Note:

None.

This functions sends the specified buffer of data using the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART. If the UART is busy sending data, it will return and indicate zero bytes were sent.

In a polled mode, this function will only send as much data as the UART can buffer in the FIFO. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue sending data until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

BufferPtr is pointer to a buffer of data to be sent.

*NumBytes* contains the number of bytes to be sent. A value of zero will stop a previous

send operation that is in progress in interrupt mode. Any data that was already

put into the transmit FIFO will be sent.

#### **Returns:**

The number of bytes actually sent.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

*FuncPtr* is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

#### **Returns:**

None.

#### Note:

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

FuncPtr is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function

is invoked.

#### **Returns:**

None.

#### Note:

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

## XUartLite\_Buffer Struct Reference

#include <xuartlite.h>

## **Detailed Description**

The following data type is used to manage the buffers that are handled when sending and receiving data in the interrupt mode. It is intended for internal use only.

The documentation for this struct was generated from the following file:

• uartlite/v1\_00\_b/src/xuartlite.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

## XUartLite\_Config Struct Reference

#include <xuartlite.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

**Xuint16 DeviceId** 

Xuint32 RegBaseAddr

**Xuint32 BaudRate** 

**Xuint8 UseParity** 

**Xuint8 ParityOdd** 

**Xuint8 DataBits** 

## **Field Documentation**

Xuint32 XUartLite\_Config::BaudRate

Fixed baud rate

**Xuint8 XUartLite\_Config::DataBits** 

Fixed data bits

## Xuint16 XUartLite\_Config::DeviceId

Unique ID of device

## Xuint8 XUartLite\_Config::ParityOdd

Parity generated is odd when XTRUE, even when XFALSE

## Xuint32 XUartLite\_Config::RegBaseAddr

Register base address

## Xuint8 XUartLite\_Config::UseParity

Parity generator enabled when XTRUE

The documentation for this struct was generated from the following file:

• uartlite/v1\_00\_b/src/xuartlite.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# XUartLite\_Stats Struct Reference

#include <xuartlite.h>

# **Detailed Description**

Statistics for the **XUartLite** driver

## **Data Fields**

**Xuint32 TransmitInterrupts** 

**Xuint32 ReceiveInterrupts** 

**Xuint32 CharactersTransmitted** 

**Xuint32 CharactersReceived** 

**Xuint32 ReceiveOverrunErrors** 

**Xuint32 ReceiveParityErrors** 

**Xuint32 ReceiveFramingErrors** 

## **Field Documentation**

Xuint32 XUartLite\_Stats::CharactersReceived

Number of characters received

Xuint32 XUartLite\_Stats::CharactersTransmitted

Number of characters transmitted

## Xuint32 XUartLite\_Stats::ReceiveFramingErrors

Number of receive framing errors

## Xuint32 XUartLite\_Stats::ReceiveInterrupts

Number of receive interrupts

### Xuint32 XUartLite\_Stats::ReceiveOverrunErrors

Number of receive overruns

## Xuint32 XUartLite\_Stats::ReceiveParityErrors

Number of receive parity errors

## Xuint32 XUartLite\_Stats::TransmitInterrupts

Number of transmit interrupts

The documentation for this struct was generated from the following file:

• uartlite/v1\_00\_b/src/xuartlite.h

# uartlite/v1\_00\_b/src/xuartlite\_i.h File Reference

# **Detailed Description**

Contains data which is shared between the files of the **XUartLite** component. It is intended for internal use only.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

---- 08/31/01 First release

1.00b jhl 02/21/02 Reparitioned the driver for smaller files

1.00b rpm 04/24/02 Moved register definitions to xuartlite_1.h and updated macro naming convention
```

```
#include "xuartlite.h"
#include "xuartlite_l.h"
```

## **Functions**

```
unsigned int XUartLite_SendBuffer (XUartLite *InstancePtr) unsigned int XUartLite ReceiveBuffer (XUartLite *InstancePtr)
```

## **Variables**

## **Function Documentation**

#### unsigned int XUartLite\_ReceiveBuffer( XUartLite \* InstancePtr)

This function receives a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartLite** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if there is no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

The number of bytes received.

#### **Note:**

None.

unsigned int XUartLite\_SendBuffer( XUartLite \* InstancePtr)

This function sends a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartLite** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function sends the specified buffer of data to the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

NumBytes is the number of bytes actually sent (put into the UART transmitter and/or FIFO).

#### **Note:**

None.

# **Variable Documentation**

XUartLite\_Config XUartLite\_ConfigTable[]( )

The configuration table for UART Lite devices

# uartlite/v1\_00\_b/src/xuartlite\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xuartlite.h**.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00b rpm 04/25/02 First release
1.00b rpm 07/07/03 Removed references to XUartLite_mGetControlReg macro since the control register is write-only
#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XUartLite_mSetControlReg(BaseAddress, Mask)
#define XUartLite_mGetStatusReg(BaseAddress)
#define XUartLite_mIsReceiveEmpty(BaseAddress)
#define XUartLite_mIsTransmitFull(BaseAddress)
#define XUartLite_mIsIntrEnabled(BaseAddress)
#define XUartLite_mEnableIntr(BaseAddress)
#define XUartLite_mDisableIntr(BaseAddress)
```

## **Functions**

# **Define Documentation**

### #define XUartLite\_mDisableIntr( BaseAddress )

#define XUartLite\_mGetStatusReg( BaseAddress )

Disable the device interrupt. We cannot read the control register, so we just clear all bits. Since the only other

| ones are the FIFO reset bits, this works without side effects.                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Parameters:  BaseAddress is the base address of the device                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                        |
| Note: None.                                                                                                                                                                                                           |
| #define XUartLite_mEnableIntr( BaseAddress )                                                                                                                                                                          |
| Enable the device interrupt. We cannot read the control register, so we just write the enable interrupt bit and clear all others. Since the only other ones are the FIFO reset bits, this works without side effects. |
| Parameters:  BaseAddress is the base address of the device                                                                                                                                                            |
| Returns: None.                                                                                                                                                                                                        |
| Note: None.                                                                                                                                                                                                           |

| Get the contents of the status register. Use the XUL_SR_* constants defined above to interpret the bit-mask returned. |
|-----------------------------------------------------------------------------------------------------------------------|
| Parameters:  BaseAddress is the base address of the device                                                            |
| Returns:  A 32-bit value representing the contents of the status register.                                            |
| Note: None.                                                                                                           |
| #define XUartLite_mIsIntrEnabled( BaseAddress )                                                                       |
| Check to see if the interrupt is enabled.                                                                             |
| Parameters:  BaseAddress is the base address of the device                                                            |
| Returns:  XTRUE if the interrupt is enabled, XFALSE otherwise.                                                        |
| Note: None.                                                                                                           |
| #define XUartLite_mIsReceiveEmpty( BaseAddress )                                                                      |
| Check to see if the receiver has data.                                                                                |
| Parameters:  BaseAddress is the base address of the device                                                            |
| Returns:  XTRUE if the receiver is empty, XFALSE if there is data present.                                            |
| Note: None.                                                                                                           |
| #define XUartLite_mIsTransmitFull( BaseAddress )                                                                      |
|                                                                                                                       |

| Parameters:  BaseAddress is the base address of the device                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Returns:  XTRUE if the transmitter is full, XFALSE otherwise.                                                                                                         |
| Note: None.                                                                                                                                                           |
| #define XUartLite_mSetControlReg( BaseAddress,                                                                                                                        |
| Set the contents of the control register. Use the XUL_CR_* constants defined above to create the bit-mask to be written to the register.                              |
| Parameters:  BaseAddress is the base address of the device  Mask is the 32-bit value to write to the control register                                                 |
| Returns: None.                                                                                                                                                        |
| Note: None.                                                                                                                                                           |
| Function Documentation                                                                                                                                                |
| Xuint8 XUartLite_RecvByte( Xuint32 BaseAddress)                                                                                                                       |
| This functions receives a single byte using the UART. It is blocking in that it waits for the receiver to become non-empty before it reads from the receive register. |
| Parameters:  BaseAddress is the base address of the device                                                                                                            |
| Returns: The byte of data received.                                                                                                                                   |
| Note: None.                                                                                                                                                           |

Check to see if the transmitter is full.

```
void XUartLite_SendByte( Xuint32 BaseAddress, Xuint8 Data
)
```

This functions sends a single byte using the UART. It is blocking in that it waits for the transmitter to become non-full before it writes the byte to the transmit register.

#### **Parameters:**

BaseAddress is the base address of the device Data is the byte of data to send

**Returns:** 

None.

**Note:** 

None.

# uartlite/v1\_00\_b/src/xuartlite\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of UART Lite devices in the system. Each device in the system should have an entry in the table.

#### MODIFICATION HISTORY:

## **Variables**

XUartLite\_Config XUartLite\_ConfigTable [XPAR\_XUARTLITE\_NUM\_INSTANCES]

## **Variable Documentation**

XUartLite\_Config XUartLite\_ConfigTable[XPAR\_XUARTLITE\_NUM\_INSTANCES]

The configuration table for UART Lite devices

# uartlite/v1\_00\_b/src/xuartlite\_intr.c File Reference

# **Detailed Description**

This file contains interrupt-related functions for the UART Lite component (**XUartLite**).

MODIFICATION HISTORY:

## **Functions**

## **Function Documentation**

## void XUartLite\_DisableInterrupt( XUartLite \* InstancePtr)

This function disables the UART interrupt. After calling this function, data may still be received by the UART but no interrupt will be generated since the hardware device has no way to disable the receiver.

| n   |       |   | 4          |    |     |
|-----|-------|---|------------|----|-----|
| Pa  | ro    | m | $\Delta T$ | ΔΙ | ••• |
| 1 a | . I a | ш | CL         |    |     |

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

| Retur | <b>ns:</b> None. |  |  |  |  |
|-------|------------------|--|--|--|--|
| Note: | None.            |  |  |  |  |

## void XUartLite\_EnableInterrupt( XUartLite \* InstancePtr)

This function enables the UART interrupt such that an interrupt will occur when data is received or data has been transmitted. The device contains 16 byte receive and transmit FIFOs such that an interrupt is generated anytime there is data in the receive FIFO and when the transmit FIFO transitions from not empty to empty.

#### **Parameters:**

InstancePtr is a pointer to the XUartLite instance to be worked on.

| Retur | ns: None. |  |  |  |
|-------|-----------|--|--|--|
| Note: | None.     |  |  |  |

void XUartLite\_InterruptHandler( XUartLite \* InstancePtr)

This function is the interrupt handler for the UART lite driver. It must be connected to an interrupt system by the user such that it is called when an interrupt for any UART lite occurs. This function does not save or restore the processor context such that the user must ensure this occurs.

#### **Parameters:**

InstancePtr contains a pointer to the instance of the UART that the interrupt is for.

#### **Returns:**

None.

#### Note:

None.

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

FuncPtr is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

#### **Returns:**

None.

#### Note:

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

FuncPtr is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function

is invoked.

#### **Returns:**

None.

#### Note:

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

# uartlite/v1\_00\_b/src/xuartlite.c File Reference

# **Detailed Description**

Contains required functions for the **XUartLite** driver. See the **xuartlite.h** header file for more details on this driver.

#### MODIFICATION HISTORY:

## **Functions**

#include "xio.h"

```
XStatus XUartLite_Initialize (XUartLite *InstancePtr, Xuint16 DeviceId)
unsigned int XUartLite_Send (XUartLite *InstancePtr, Xuint8 *DataBufferPtr, unsigned int
NumBytes)
unsigned int XUartLite_Recv (XUartLite *InstancePtr, Xuint8 *DataBufferPtr, unsigned int
NumBytes)
```

```
void XUartLite_ResetFifos (XUartLite *InstancePtr)
Xboolean XUartLite_IsSending (XUartLite *InstancePtr)
unsigned int XUartLite_SendBuffer (XUartLite *InstancePtr)
unsigned int XUartLite_ReceiveBuffer (XUartLite *InstancePtr)
```

## **Function Documentation**

Initialize a **XUartLite** instance. The receive and transmit FIFOs of the UART are not flushed, so the user may want to flush them. The hardware device does not have any way to disable the receiver such that any valid data may be present in the receive FIFO. This function disables the UART interrupt. The baudrate and format of the data are fixed in the hardware at hardware build time.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XUartLite** instance. Passing in a device id associates the generic **XUartLite** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST\_SUCCESS if everything starts up as expected.
- o XST\_DEVICE\_NOT\_FOUND if the device is not found in the configuration table.

#### **Note:**

None.

**Xboolean XUartLite\_IsSending( XUartLite \* InstancePtr)** 

This function determines if the specified UART is sending data. If the transmitter register is not empty, it is sending data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

A value of XTRUE if the UART is sending data, otherwise XFALSE.

#### Note:

None.

### unsigned int XUartLite\_ReceiveBuffer( XUartLite \* InstancePtr)

This function receives a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartLite** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if there is no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

The number of bytes received.

#### Note:

None.

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer in the FIFO. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue receiving data until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

BufferPtr is pointer to buffer for data to be received into

*NumBytes* is the number of bytes to be received. A value of zero will stop a previous

receive operation that is in progress in interrupt mode.

#### **Returns:**

The number of bytes received.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

void XUartLite\_ResetFifos( XUartLite \* InstancePtr)

This function resets the FIFOs, both transmit and receive, of the UART such that they are emptied. Since the UART does not have any way to disable it from receiving data, it may be necessary for the application to reset the FIFOs to get rid of any unwanted data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

None.

#### Note:

None.

This functions sends the specified buffer of data using the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART. If the UART is busy sending data, it will return and indicate zero bytes were sent.

In a polled mode, this function will only send as much data as the UART can buffer in the FIFO. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue sending data until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

BufferPtr is pointer to a buffer of data to be sent.

*NumBytes* contains the number of bytes to be sent. A value of zero will stop a previous

send operation that is in progress in interrupt mode. Any data that was already

put into the transmit FIFO will be sent.

#### **Returns:**

The number of bytes actually sent.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

### unsigned int XUartLite\_SendBuffer( XUartLite \* InstancePtr)

This function sends a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartLite** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function sends the specified buffer of data to the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

NumBytes is the number of bytes actually sent (put into the UART transmitter and/or FIFO).

#### Note:

None.

# uartlite/v1\_00\_b/src/xuartlite\_l.c File Reference

# **Detailed Description**

This file contains low-level driver functions that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation.

```
MODIFICATION HISTORY:
```

## **Functions**

```
void XUartLite_SendByte (Xuint32 BaseAddress, Xuint8 Data)
Xuint8 XUartLite_RecvByte (Xuint32 BaseAddress)
```

## **Function Documentation**

Xuint8 XUartLite\_RecvByte( Xuint32 BaseAddress)



| Pa  | ra | m | ρţ | ers  | • |
|-----|----|---|----|------|---|
| ı a | 14 |   | CL | CI 3 | • |

BaseAddress is the base address of the device

#### **Returns:**

The byte of data received.

#### Note:

None.

```
void XUartLite_SendByte( Xuint32 BaseAddress, Xuint8 Data
)
```

This functions sends a single byte using the UART. It is blocking in that it waits for the transmitter to become non-full before it writes the byte to the transmit register.

#### **Parameters:**

BaseAddress is the base address of the device

Data is the byte of data to send

#### **Returns:**

None.

#### **Note:**

None.

# uartlite/v1\_00\_b/src/xuartlite\_selftest.c File Reference

# **Detailed Description**

This file contains the self-test functions for the UART Lite component (**XUartLite**).

MODIFICATION HISTORY:

```
Ver Who Date Changes

---- --- --- ---- ---- ------

1.00a ecm 08/31/01 First release

1.00b jhl 02/21/02 Repartitioned the driver for smaller files

#include "xbasic_types.h"

#include "xstatus.h"

#include "xuartlite.h"

#include "xuartlite_i.h"

#include "xio.h"
```

# **Functions**

XStatus XUartLite\_SelfTest (XUartLite \*InstancePtr)

## **Function Documentation**

XStatus XUartLite\_SelfTest( XUartLite \* InstancePtr)

Runs a self-test on the device hardware. Since there is no way to perform a loopback in the hardware, this test can only check the state of the status register to verify it is correct. This test assumes that the hardware device is still in its reset state, but has been initialized with the Initialize function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartLite** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the self-test was successful.
- o XST\_FAILURE if the self-test failed, the status register value was not correct

#### **Note:**

None.

# uartns550/v1\_00\_b/src/xuartns550\_stats.c File Reference

# **Detailed Description**

This file contains the statistics functions for the 16450/16550 UART driver.

MODIFICATION HISTORY:

## **Functions**

```
void XUartNs550_GetStats (XUartNs550 *InstancePtr, XUartNs550Stats *StatsPtr) void XUartNs550_ClearStats (XUartNs550 *InstancePtr)
```

## **Function Documentation**

void XUartNs550\_ClearStats( XUartNs550 \* InstancePtr)

| Paran   | neters:<br>InstancePti | r is a pointer to the <b>XUartNs550</b> instance to be worked on.                                                                                                 |
|---------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Retur   | ns:<br>None.           |                                                                                                                                                                   |
| Note:   | None.                  |                                                                                                                                                                   |
| void XU | JartNs550_(            | GetStats( XUartNs550 * InstancePtr,                                                                                                                               |
| This fu | unctions retu          | rns a snapshot of the current statistics in the area provided.                                                                                                    |
| Paran   |                        | r is a pointer to the <b>XUartNs550</b> instance to be worked on. is a pointer to a <b>XUartNs550Stats</b> structure to where the statistics are to be copied to. |
| Retur   | ns:<br>None.           |                                                                                                                                                                   |
| Note:   | None.                  |                                                                                                                                                                   |

This function zeros the statistics for the given instance.

#### Xilinx Device Drivers

### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# uartns550/v1\_00\_b/src/xuartns550.h File Reference

# **Detailed Description**

This driver supports the following features in the Xilinx 16450/16550 compatible UART.

- Dynamic data format (baud rate, data bits, stop bits, parity)
- Polled mode
- Interrupt driven mode
- Transmit and receive FIFOs (16 bytes each for the 16550)
- Access to the external modem control lines and the two discrete outputs

The only difference between the 16450 and the 16550 is the addition of transmit and receive FIFOs in the 16550.

#### **Baud Rate**

The UART has an internal baud rate generator that is clocked at a specified input clock frequency. Not all baud rates can be generated from some clock frequencies. The requested baud rate is checked using the provided clock for the system, and checked against the acceptable error range. An error may be returned from some functions indicating the baud rate was in error because it could not be generated.

#### **Interrupts**

The device does not have any way to disable the receiver such that the receive FIFO may contain unwanted data. The FIFOs are not flushed when the driver is initialized, but a function is provided to allow the user to reset the FIFOs if desired.

The driver defaults to no interrupts at initialization such that interrupts must be enabled if desired. An interrupt is generated for any of the following conditions.

- Transmit FIFO is empty
- Data in the receive FIFO equal to the receive threshold
- Data in the receiver when FIFOs are disabled

- Any receive status error or break condition detected
- Data in the receive FIFO for 4 character times without receiver activity
- A change of a modem signal

The application can control which interrupts are enabled using the SetOptions function.

In order to use interrupts, it is necessary for the user to connect the driver interrupt handler, **XUartNs550\_InterruptHandler**(), to the interrupt system of the application. This function does not save and restore the processor context such that the user must provide it. A handler must be set for the driver such that the handler is called when interrupt events occur. The handler is called from interrupt context and is designed to allow application specific processing to be performed.

The functions, **XUartNs550\_Send()** and **XUartNs550\_Recv()**, are provided in the driver to allow data to be sent and received. They are designed to be used in polled or interrupt modes.

#### Note:

The default configuration for the UART after initialization is:

- 19,200 bps or XPAR\_DEFAULT\_BAUD\_RATE if defined
- 8 data bits
- 1 stop bit
- no parity
- FIFO's are enabled with a receive threshold of 8 bytes

#### MODIFICATION HISTORY:

## **Data Structures**

```
struct XUartNs550
struct XUartNs550_Config
struct XUartNs550Buffer
struct XUartNs550Format
```

# **Configuration options**

```
#define XUN_OPTION_SET_BREAK

#define XUN_OPTION_LOOPBACK

#define XUN_OPTION_DATA_INTR

#define XUN_OPTION_MODEM_INTR

#define XUN_OPTION_FIFOS_ENABLE

#define XUN_OPTION_RESET_TX_FIFO

#define XUN_OPTION_RESET_RX_FIFO

#define XUN_OPTION_ASSERT_OUT2

#define XUN_OPTION_ASSERT_OUT1

#define XUN_OPTION_ASSERT_TS

#define XUN_OPTION_ASSERT_DTR
```

## **Data format values**

```
#define XUN_FORMAT_8_BITS
#define XUN_FORMAT_7_BITS
#define XUN_FORMAT_6_BITS
#define XUN_FORMAT_5_BITS
#define XUN_FORMAT_EVEN_PARITY
#define XUN_FORMAT_ODD_PARITY
#define XUN_FORMAT_NO_PARITY
#define XUN_FORMAT_1_STOP_BIT
#define XUN_FORMAT_1_STOP_BIT
```

## **Modem status values**

```
#define XUN_MODEM_DCD_DELTA_MASK
#define XUN_MODEM_DSR_DELTA_MASK
#define XUN_MODEM_CTS_DELTA_MASK
#define XUN_MODEM_RINGING_MASK
#define XUN_MODEM_DSR_MASK
#define XUN_MODEM_CTS_MASK
#define XUN_MODEM_CTS_MASK
```

## Callback events

```
#define XUN_EVENT_RECV_DATA
#define XUN_EVENT_RECV_TIMEOUT
#define XUN_EVENT_SENT_DATA
#define XUN_EVENT_RECV_ERROR
#define XUN_EVENT_MODEM
```

## **Error values**

```
#define XUN_ERROR_BREAK_MASK
#define XUN_ERROR_FRAMING_MASK
#define XUN_ERROR_PARITY_MASK
#define XUN_ERROR_OVERRUN_MASK
#define XUN_ERROR_NONE
```

# **Typedefs**

```
typedef void(* XUartNs550_Handler )(void *CallBackRef, Xuint32 Event, unsigned int EventData)
```

## **Functions**

```
XStatus XUartNs550_Initialize (XUartNs550 *InstancePtr, Xuint16 DeviceId)
unsigned int XUartNs550_Send (XUartNs550 *InstancePtr, Xuint8 *BufferPtr, unsigned int
NumBytes)
unsigned int XUartNs550_Recv (XUartNs550 *InstancePtr, Xuint8 *BufferPtr, unsigned int
NumBytes)
XUartNs550_Config * XUartNs550_LookupConfig (Xuint16 DeviceId)
XStatus XUartNs550_SetOptions (XUartNs550 *InstancePtr, Xuint16 Options)
Xuint16 XUartNs550_GetOptions (XUartNs550 *InstancePtr)
XStatus XUartNs550_SetFifoThreshold (XUartNs550 *InstancePtr, Xuint8
TriggerLevel)
Xuint8 XUartNs550_GetFifoThreshold (XUartNs550 *InstancePtr)
Xboolean XUartNs550_IsSending (XUartNs550 *InstancePtr)
```

## **Define Documentation**

#### #define XUN\_ERROR\_BREAK\_MASK

These constants specify the errors that may be retrieved from the driver using the XUartNs550\_GetLastErrors function. All of them are bit masks, except no error, such that multiple errors may be specified.

| XUN_ERROR_BREAK_MASK   | Break detected        |
|------------------------|-----------------------|
| XUN_ERROR_FRAMING_MASK | Receive framing error |
| XUN_ERROR_PARITY_MASK  | Receive parity error  |
| XUN_ERROR_OVERRUN_MASK | Receive overrun error |
| XUN_ERROR_NONE         | No error              |

#### #define XUN ERROR FRAMING MASK

These constants specify the errors that may be retrieved from the driver using the XUartNs550\_GetLastErrors function. All of them are bit masks, except no error, such that multiple errors may be specified.

| XUN_ERROR_BREAK_MASK   | Break detected        |
|------------------------|-----------------------|
| XUN_ERROR_FRAMING_MASK | Receive framing error |
| XUN_ERROR_PARITY_MASK  | Receive parity error  |
| XUN_ERROR_OVERRUN_MASK | Receive overrun error |
| XUN ERROR NONE         | No error              |

#### #define XUN\_ERROR\_NONE

These constants specify the errors that may be retrieved from the driver using the XUartNs550\_GetLastErrors function. All of them are bit masks, except no error, such that multiple errors may be specified.

| XUN_ERROR_BREAK_MASK   | Break detected        |
|------------------------|-----------------------|
| XUN_ERROR_FRAMING_MASK | Receive framing error |
| XUN_ERROR_PARITY_MASK  | Receive parity error  |
| XUN_ERROR_OVERRUN_MASK | Receive overrun error |
| XUN_ERROR_NONE         | No error              |

#### #define XUN\_ERROR\_OVERRUN\_MASK

These constants specify the errors that may be retrieved from the driver using the XUartNs550\_GetLastErrors function. All of them are bit masks, except no error, such that multiple errors may be specified.

| XUN_ERROR_BREAK_MASK   | Break detected        |
|------------------------|-----------------------|
| XUN_ERROR_FRAMING_MASK | Receive framing error |
| XUN_ERROR_PARITY_MASK  | Receive parity error  |
| XUN_ERROR_OVERRUN_MASK | Receive overrun error |
| XUN ERROR NONE         | No error              |

### #define XUN\_ERROR\_PARITY\_MASK

These constants specify the errors that may be retrieved from the driver using the XUartNs550\_GetLastErrors function. All of them are bit masks, except no error, such that multiple errors may be specified.

| XUN_ERROR_BREAK_MASK   | Break detected        |
|------------------------|-----------------------|
| XUN_ERROR_FRAMING_MASK | Receive framing error |
| XUN_ERROR_PARITY_MASK  | Receive parity error  |
| XUN_ERROR_OVERRUN_MASK | Receive overrun error |
| XUN_ERROR_NONE         | No error              |

#### #define XUN\_EVENT\_MODEM

These constants specify the handler events that are passed to a handler from the driver. These constants are not bit masks such that only one will be passed at a time to the handler.

| XUN_EVENT_RECV_DATA    | Data has been received       |
|------------------------|------------------------------|
| XUN_EVENT_RECV_TIMEOUT | A receive timeout occurred   |
| XUN_EVENT_SENT_DATA    | Data has been sent           |
| XUN_EVENT_RECV_ERROR   | A receive error was detected |
| XUN_EVENT_MODEM        | A change in modem status     |

### #define XUN\_EVENT\_RECV\_DATA

These constants specify the handler events that are passed to a handler from the driver. These constants are not bit masks such that only one will be passed at a time to the handler.

| XUN_EVENT_RECV_DATA    | Data has been received       |
|------------------------|------------------------------|
| XUN_EVENT_RECV_TIMEOUT | A receive timeout occurred   |
| XUN_EVENT_SENT_DATA    | Data has been sent           |
| XUN_EVENT_RECV_ERROR   | A receive error was detected |
| XUN_EVENT_MODEM        | A change in modem status     |

### #define XUN\_EVENT\_RECV\_ERROR

These constants specify the handler events that are passed to a handler from the driver. These constants are not bit masks such that only one will be passed at a time to the handler.

| XUN_EVENT_RECV_DATA    | Data has been received       |
|------------------------|------------------------------|
| XUN_EVENT_RECV_TIMEOUT | A receive timeout occurred   |
| XUN_EVENT_SENT_DATA    | Data has been sent           |
| XUN_EVENT_RECV_ERROR   | A receive error was detected |
| XUN_EVENT_MODEM        | A change in modem status     |

### #define XUN\_EVENT\_RECV\_TIMEOUT

These constants specify the handler events that are passed to a handler from the driver. These constants are not bit masks such that only one will be passed at a time to the handler.

| XUN_EVENT_RECV_DATA    | Data has been received       |
|------------------------|------------------------------|
| XUN_EVENT_RECV_TIMEOUT | A receive timeout occurred   |
| XUN_EVENT_SENT_DATA    | Data has been sent           |
| XUN_EVENT_RECV_ERROR   | A receive error was detected |
| XUN_EVENT_MODEM        | A change in modem status     |

## #define XUN\_EVENT\_SENT\_DATA

These constants specify the handler events that are passed to a handler from the driver. These constants are not bit masks such that only one will be passed at a time to the handler.

| XUN EVENT RECV DATA    | Data has been received       |
|------------------------|------------------------------|
|                        |                              |
| XUN_EVENT_RECV_TIMEOUT | A receive timeout occurred   |
| XUN_EVENT_SENT_DATA    | Data has been sent           |
| XUN_EVENT_RECV_ERROR   | A receive error was detected |
| XUN EVENT MODEM        | A change in modem status     |

## #define XUN\_FORMAT\_1\_STOP\_BIT

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

# #define XUN\_FORMAT\_2\_STOP\_BIT

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |
|                        |             |

## #define XUN\_FORMAT\_5\_BITS

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

## #define XUN\_FORMAT\_6\_BITS

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

## #define XUN\_FORMAT\_7\_BITS

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |
|                        |             |

## #define XUN\_FORMAT\_8\_BITS

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

## #define XUN\_FORMAT\_EVEN\_PARITY

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

## #define XUN\_FORMAT\_NO\_PARITY

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

## #define XUN\_FORMAT\_ODD\_PARITY

These constants specify the data format that may be set or retrieved with the driver. The data format includes the number of data bits, the number of stop bits and parity.

| XUN_FORMAT_8_BITS      | 8 data bits |
|------------------------|-------------|
| XUN_FORMAT_7_BITS      | 7 data bits |
| XUN_FORMAT_6_BITS      | 6 data bits |
| XUN_FORMAT_5_BITS      | 5 data bits |
| XUN_FORMAT_EVEN_PARITY | Even parity |
| XUN_FORMAT_ODD_PARITY  | Odd parity  |
| XUN_FORMAT_NO_PARITY   | No parity   |
| XUN_FORMAT_2_STOP_BIT  | 2 stop bits |
| XUN_FORMAT_1_STOP_BIT  | 1 stop bit  |

# #define XUN\_MODEM\_CTS\_DELTA\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

# #define XUN\_MODEM\_CTS\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

# #define XUN\_MODEM\_DCD\_DELTA\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

# #define XUN\_MODEM\_DCD\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK              | DCD signal changed state                                |
|---------------------------------------|---------------------------------------------------------|
| XUN_MODEM_DSR_DELTA_MASK              | DSR signal changed state                                |
| XUN_MODEM_CTS_DELTA_MASK              | CTS signal changed state                                |
| XUN_MODEM_RINGING_MASK                | Ring signal is active                                   |
| XUN_MODEM_DSR_MASK                    |                                                         |
| VON_MAGA_MASK                         | Current state of DSR signal                             |
| XUN_MODEM_DSR_MASK XUN_MODEM_CTS_MASK | Current state of DSR signal Current state of CTS signal |
|                                       |                                                         |

## #define XUN\_MODEM\_DSR\_DELTA\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

# #define XUN\_MODEM\_RING\_STOP\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

## #define XUN\_MODEM\_RINGING\_MASK

These constants specify the modem status that may be retrieved from the driver.

| XUN_MODEM_DCD_DELTA_MASK | DCD signal changed state    |
|--------------------------|-----------------------------|
| XUN_MODEM_DSR_DELTA_MASK | DSR signal changed state    |
| XUN_MODEM_CTS_DELTA_MASK | CTS signal changed state    |
| XUN_MODEM_RINGING_MASK   | Ring signal is active       |
| XUN_MODEM_DSR_MASK       | Current state of DSR signal |
| XUN_MODEM_CTS_MASK       | Current state of CTS signal |
| XUN_MODEM_DCD_MASK       | Current state of DCD signal |
| XUN_MODEM_RING_STOP_MASK | Ringing has stopped         |

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |
|                          |                         |

# #define XUN\_OPTION\_ASSERT\_OUT1

These constants specify the options that may be set or retrieved with the driver, each is a unique bit mask such that multiple options may be specified. These constants indicate the function of the option when in the active state.

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

# #define XUN\_OPTION\_ASSERT\_OUT2

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert out1 signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |
|                          |                         |

# #define XUN\_OPTION\_ASSERT\_RTS

These constants specify the options that may be set or retrieved with the driver, each is a unique bit mask such that multiple options may be specified. These constants indicate the function of the option when in the active state.

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

## #define XUN\_OPTION\_DATA\_INTR

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert out1 signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

## #define XUN\_OPTION\_FIFOS\_ENABLE

These constants specify the options that may be set or retrieved with the driver, each is a unique bit mask such that multiple options may be specified. These constants indicate the function of the option when in the active state.

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

# #define XUN\_OPTION\_LOOPBACK

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert out1 signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |
|                          |                         |

## #define XUN\_OPTION\_MODEM\_INTR

These constants specify the options that may be set or retrieved with the driver, each is a unique bit mask such that multiple options may be specified. These constants indicate the function of the option when in the active state.

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert out1 signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

# #define XUN\_OPTION\_RESET\_RX\_FIFO

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert out1 signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

# #define XUN\_OPTION\_RESET\_TX\_FIFO

These constants specify the options that may be set or retrieved with the driver, each is a unique bit mask such that multiple options may be specified. These constants indicate the function of the option when in the active state.

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

## #define XUN\_OPTION\_SET\_BREAK

| XUN_OPTION_SET_BREAK     | Set a break condition   |
|--------------------------|-------------------------|
| XUN_OPTION_LOOPBACK      | Enable local loopback   |
| XUN_OPTION_DATA_INTR     | Enable data interrupts  |
| XUN_OPTION_MODEM_INTR    | Enable modem interrupts |
| XUN_OPTION_FIFOS_ENABLE  | Enable FIFOs            |
| XUN_OPTION_RESET_TX_FIFO | Reset the transmit FIFO |
| XUN_OPTION_RESET_RX_FIFO | Reset the receive FIFO  |
| XUN_OPTION_ASSERT_OUT2   | Assert out2 signal      |
| XUN_OPTION_ASSERT_OUT1   | Assert outl signal      |
| XUN_OPTION_ASSERT_RTS    | Assert RTS signal       |
| XUN_OPTION_ASSERT_DTR    | Assert DTR signal       |

# **Typedef Documentation**

typedef void(\* XUartNs550\_Handler)(void \*CallBackRef, Xuint32 Event, unsigned int EventData)

This data type defines a handler which the application must define when using interrupt mode. The handler will be called from the driver in an interrupt context to handle application specific processing.

#### **Parameters:**

CallBackRef is a callback reference passed in by the upper layer when setting the handler, and

is passed back to the upper layer when the handler is called.

*Event* contains one of the event constants indicating why the handler is being called.

EventData contains the number of bytes sent or received at the time of the call for send and

receive events and contains the modem status for modem events.

# **Function Documentation**

void XUartNs550\_ClearStats( XUartNs550 \* InstancePtr)



Xuint8 XUartNs550\_GetFifoThreshold( XUartNs550 \* InstancePtr)

This function gets the receive FIFO trigger level. The receive trigger level indicates the number of bytes in the receive FIFO that cause a receive data event (interrupt) to be generated.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The current receive FIFO trigger level. Constants which define each trigger level are contained in the file **xuartns550.h** and named XUN\_FIFO\_TRIGGER\_\*.

#### Note:

None.

#### Xuint8 XUartNs550 GetLastErrors( XUartNs550 \* InstancePtr)

This function returns the last errors that have occurred in the specified UART. It also clears the errors such that they cannot be retrieved again. The errors include parity error, receive overrun error, framing error, and break detection.

The last errors is an accumulation of the errors each time an error is discovered in the driver. A status is checked for each received byte and this status is accumulated in the last errors.

If this function is called after receiving a buffer of data, it will indicate any errors that occurred for the bytes of the buffer. It does not indicate which bytes contained errors.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The last errors that occurred. The errors are bit masks that are contained in the file **xuartns550.h** and named XUN\_ERROR\_\*.

#### **Note:**

None.

#### Xuint8 XUartNs550 GetModemStatus( XUartNs550 \* InstancePtr)

This function gets the modem status from the specified UART. The modem status indicates any changes of the modem signals. This function allows the modem status to be read in a polled mode. The modem status is updated whenever it is read such that reading it twice may not yield the same results.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The modem status which are bit masks that are contained in the file **xuartns550.h** and named XUN\_MODEM\_\*.

#### Note:

The bit masks used for the modem status are the exact bits of the modem status register with no abstraction.

## Xuint16 XUartNs550\_GetOptions( XUartNs550 \* InstancePtr)

Gets the options for the specified driver instance. The options are implemented as bit masks such that multiple options may be enabled or disabled simulataneously.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The current options for the UART. The optionss are bit masks that are contained in the file **xuartns550.h** and named XUN\_OPTION\_\*.

#### **Returns:**

This functions returns a snapshot of the current statistics in the area provided.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

StatsPtr is a pointer to a **XUartNs550Stats** structure to where the statistics are to be copied to.

#### **Returns:**

None.

**Note:** 

None.

Initializes a specific **XUartNs550** instance such that it is ready to be used. The data format of the device is setup for 8 data bits, 1 stop bit, and no parity by default. The baud rate is set to a default value specified by XPAR\_DEFAULT\_BAUD\_RATE if the symbol is defined, otherwise it is set to 19.2K baud. If the device has FIFOs (16550), they are enabled and the a receive FIFO threshold is set for 8 bytes. The default operating mode of the driver is polled mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

DeviceId is the unique id of the device controlled by this XUartNs550 instance. Passing in a device id associates the generic XUartNs550 instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- o XST SUCCESS if initialization was successful
- XST\_DEVICE\_NOT\_FOUND if the device ID could not be found in the configuration table
- XST\_UART\_BAUD\_ERROR if the baud rate is not possible because the input clock frequency is not divisible with an acceptable amount of error

#### Note:

This function is the interrupt handler for the 16450/16550 UART driver. It must be connected to an interrupt system by the user such that it is called when an interrupt for any 16450/16550 UART occurs. This function does not save or restore the processor context such that the user must ensure this occurs.

#### **Parameters:**

InstancePtr contains a pointer to the instance of the UART that the interrupt is for.

#### **Returns:**

None.

#### **Note:**

None.

## **Xboolean XUartNs550\_IsSending(XUartNs550\*** InstancePtr)

This function determines if the specified UART is sending data. If the transmitter register is not empty, it is sending data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

A value of XTRUE if the UART is sending data, otherwise XFALSE.

#### Note:

None.

## XUartNs550\_Config\* XUartNs550\_LookupConfig( Xuint16 DeviceId)

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId contains the ID of the device to look up the configuration for.

#### **Returns:**

A pointer to the configuration found or XNULL if the specified device ID was not found.

#### **Note:**

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue receiving data until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

BufferPtr is pointer to buffer for data to be received into

NumBytes is the number of bytes to be received. A value of zero will stop a previous receive

operation that is in progress in interrupt mode.

#### **Returns:**

The number of bytes received.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

XStatus XUartNs550\_SelfTest( XUartNs550 \* InstancePtr)

This functions runs a self-test on the driver and hardware device. This self test performs a local loopback and verifies data can be sent and received.

The statistics are cleared at the end of the test. The time for this test to execute is proportional to the baud rate that has been set prior to calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the test was successful
- o XST\_UART\_TEST\_FAIL if the test failed looping back the data

#### Note:

This function can hang if the hardware is not functioning properly.

This functions sends the specified buffer of data using the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART. If the UART is busy sending data, it will return and indicate zero bytes were sent.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue sending data until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

BufferPtr is pointer to a buffer of data to be sent.

*NumBytes* contains the number of bytes to be sent. A value of zero will stop a previous send

operation that is in progress in interrupt mode. Any data that was already put into the transmit FIFO will be sent.

#### **Returns:**

The number of bytes actually sent.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

This function and the **XUartNs550\_SetOptions**() function modify shared data such that there may be a need for mutual exclusion in a multithreaded environment and if **XUartNs550\_SetOptions**() if called from a handler.

```
XStatus XUartNs550_SetDataFormat( XUartNs550 * InstancePtr, XUartNs550Format * FormatPtr
```

Sets the data format for the specified UART. The data format includes the baud rate, number of data bits, number of stop bits, and parity. It is the caller's responsibility to ensure that the UART is not sending or receiving data when this function is called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

FormatPtr is a pointer to a format structure containing the data format to be set.

#### **Returns:**

- o XST\_SUCCESS if the data format was successfully set.
- XST\_UART\_BAUD\_ERROR indicates the baud rate could not be set because of the amount of error with the baud rate and the input clock frequency.
- o XST\_INVALID\_PARAM if one of the parameters was not valid.

#### Note:

The data types in the format type, data bits and parity, are 32 bit fields to prevent a compiler warning that is a bug with the GNU PowerPC compiler. The asserts in this function will cause a warning if these fields are bytes.

The baud rates tested include: 1200, 2400, 4800, 9600, 19200, 38400, 57600 and 115200.

This functions sets the receive FIFO trigger level. The receive trigger level specifies the number of bytes in the receive FIFO that cause a receive data event (interrupt) to be generated. The FIFOs must be enabled to set the trigger level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

*TriggerLevel* contains the trigger level to set. Constants which define each trigger level are contained in the file **xuartns550.h** and named XUN\_FIFO\_TRIGGER\_\*.

#### **Returns:**

- o XST\_SUCCESS if the trigger level was set
- XST\_UART\_CONFIG\_ERROR if the trigger level could not be set, either the hardware does not support the FIFOs or FIFOs are not enabled

#### Note:

None.

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

FuncPtr is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

#### **Returns:**

None.

#### Note:

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

Sets the options for the specified driver instance. The options are implemented as bit masks such that multiple options may be enabled or disabled simultaneously.

The GetOptions function may be called to retrieve the currently enabled options. The result is ORed in the desired new settings to be enabled and ANDed with the inverse to clear the settings to be disabled. The resulting value is then used as the options for the SetOption function call.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

Options contains the options to be set which are bit masks contained in the file **xuartns550.h** and named XUN\_OPTION\_\*.

#### **Returns:**

- o XST\_SUCCESS if the options were set successfully.
- XST\_UART\_CONFIG\_ERROR if the options could not be set because the hardware does not support FIFOs

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# uartns550/v1\_00\_b/src/xuartns550.c File Reference

# **Detailed Description**

This file contains the required functions for the 16450/16550 UART driver. Refer to the header file **xuartns550.h** for more detailed information.

#### MODIFICATION HISTORY:

# **Functions**

```
XStatus XUartNs550_Initialize (XUartNs550 *InstancePtr, Xuint16 DeviceId)
unsigned int XUartNs550_Send (XUartNs550 *InstancePtr, Xuint8 *BufferPtr, unsigned
int NumBytes)
unsigned int XUartNs550_Recv (XUartNs550 *InstancePtr, Xuint8 *BufferPtr, unsigned
int NumBytes)
unsigned int XUartNs550_SendBuffer (XUartNs550 *InstancePtr)
```

# **Function Documentation**

Initializes a specific **XUartNs550** instance such that it is ready to be used. The data format of the device is setup for 8 data bits, 1 stop bit, and no parity by default. The baud rate is set to a default value specified by XPAR\_DEFAULT\_BAUD\_RATE if the symbol is defined, otherwise it is set to 19.2K baud. If the device has FIFOs (16550), they are enabled and the a receive FIFO threshold is set for 8 bytes. The default operating mode of the driver is polled mode.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XUartNs550** instance. Passing in a device id associates the generic **XUartNs550** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- XST\_DEVICE\_NOT\_FOUND if the device ID could not be found in the configuration table
- XST\_UART\_BAUD\_ERROR if the baud rate is not possible because the input clock frequency is not divisible with an acceptable amount of error

#### Note:

None.

Looks up the device configuration based on the unique device ID. A table contains the configuration info for each device in the system.

#### **Parameters:**

DeviceId contains the ID of the device to look up the configuration for.

#### **Returns:**

A pointer to the configuration found or XNULL if the specified device ID was not found.

#### Note:

None.

### unsigned int XUartNs550\_ReceiveBuffer( XUartNs550 \* InstancePtr)

This function receives a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartNs550** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if there is no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

InstancePtr is a pointer to the XUartNs550 instance to be worked on.

#### **Returns:**

The number of bytes received.

#### **Note:**

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue receiving data until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

BufferPtr is pointer to buffer for data to be received into

*NumBytes* is the number of bytes to be received. A value of zero will stop a previous

receive operation that is in progress in interrupt mode.

#### **Returns:**

The number of bytes received.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

This functions sends the specified buffer of data using the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART. If the UART is busy sending data, it will return and indicate zero bytes were sent.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue sending data until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

BufferPtr is pointer to a buffer of data to be sent.

*NumBytes* contains the number of bytes to be sent. A value of zero will stop a previous

send operation that is in progress in interrupt mode. Any data that was already

put into the transmit FIFO will be sent.

#### **Returns:**

The number of bytes actually sent.

#### Note:

The number of bytes is not asserted so that this function may be called with a value of zero to stop an operation that is already in progress.

This function and the **XUartNs550\_SetOptions**() function modify shared data such that there may be a need for mutual exclusion in a multithreaded environment and if **XUartNs550\_SetOptions**() if called from a handler.

unsigned int XUartNs550\_SendBuffer( XUartNs550 \* InstancePtr)

This function sends a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartNs550** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function sends the specified buffer of data to the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

NumBytes is the number of bytes actually sent (put into the UART tranmitter and/or FIFO).

#### Note:

None.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# uartns550/v1\_00\_b/src/xuartns550\_i.h File Reference

# **Detailed Description**

This header file contains internal identifiers, which are those shared between the files of the driver. It is intended for internal use only.

#### MODIFICATION HISTORY:

| Ver | Who | Date | Changes                                               |
|-----|-----|------|-------------------------------------------------------|
|     |     |      | First release Repartitioned driver for smaller files. |

#include "xuartns550.h"

# **Functions**

```
unsigned int XUartNs550_SendBuffer (XUartNs550 *InstancePtr) unsigned int XUartNs550_ReceiveBuffer (XUartNs550 *InstancePtr)
```

# **Variables**

XUartNs550\_Config XUartNs550\_ConfigTable []

# **Function Documentation**

### unsigned int XUartNs550\_ReceiveBuffer( XUartNs550 \* InstancePtr)

This function receives a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartNs550** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function will attempt to receive a specified number of bytes of data from the UART and store it into the specified buffer. This function is designed for either polled or interrupt driven modes. It is non-blocking such that it will return if there is no data has already received by the UART.

In a polled mode, this function will only receive as much data as the UART can buffer, either in the receiver or in the FIFO if present and enabled. The application may need to call it repeatedly to receive a buffer. Polled mode is the default mode of operation for the driver.

In interrupt mode, this function will start receiving and then the interrupt handler of the driver will continue until the buffer has been received. A callback function, as specified by the application, will be called to indicate the completion of receiving the buffer or when any receive errors or timeouts occur. Interrupt mode must be enabled using the SetOptions function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The number of bytes received.

#### Note:

None.

unsigned int XUartNs550\_SendBuffer( XUartNs550 \* InstancePtr)

This function sends a buffer that has been previously specified by setting up the instance variables of the instance. This function is designed to be an internal function for the **XUartNs550** component such that it may be called from a shell function that sets up the buffer or from an interrupt handler.

This function sends the specified buffer of data to the UART in either polled or interrupt driven modes. This function is non-blocking such that it will return before the data has been sent by the UART.

In a polled mode, this function will only send as much data as the UART can buffer, either in the transmitter or in the FIFO if present and enabled. The application may need to call it repeatedly to send a buffer.

In interrupt mode, this function will start sending the specified buffer and then the interrupt handler of the driver will continue until the buffer has been sent. A callback function, as specified by the application, will be called to indicate the completion of sending the buffer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

NumBytes is the number of bytes actually sent (put into the UART tranmitter and/or FIFO).

#### Note:

None.

# **Variable Documentation**

# XUartNs550\_Config XUartNs550\_ConfigTable[]( )

The configuration table for UART 16550/16450 devices in the table. Each device should have an entry in this table.

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers <u>Driver Summary Copyright</u> <u>Main Page Data Structures File List Data Fields Globals</u>

# XUartNs550 Struct Reference

#include <xuartns550.h>

# **Detailed Description**

The XUartNs550 driver instance data. The user is required to allocate a variable of this type for every UART 16550/16450 device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• uartns550/v1\_00\_b/src/xuartns550.h

Generated on 30 Sep 2003 for Xilinx Device Drivers

# Xilinx Device Drivers Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# XUartNs550\_Config Struct Reference

#include <xuartns550.h>

# **Detailed Description**

This typedef contains configuration information for the device.

# **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddress Xuint32 InputClockHz

# **Field Documentation**

Xuint32 XUartNs550\_Config::BaseAddress

Base address of device (IPIF)

Xuint16 XUartNs550\_Config::DeviceId

Unique ID of device

Xuint32 XUartNs550\_Config::InputClockHz

Input clock frequency

The documentation for this struct was generated from the following file:

• uartns550/v1\_00\_b/src/**xuartns550.h** 

Generated on 30 Sep 2003 for Xilinx Device Drivers

# uartns550/v1\_00\_b/src/xuartns550\_l.h File Reference

# **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation. High-level driver functions are defined in **xuartns550.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00b jhl 04/24/02 First release
#include "xbasic_types.h"
#include "xio.h"
```

# **Defines**

```
#define XUartNs550_mReadReg(BaseAddress, RegOffset)
#define XUartNs550_mWriteReg(BaseAddress, RegOffset, RegisterValue)
#define XUartNs550_mGetLineStatusReg(BaseAddress)
#define XUartNs550_mGetLineControlReg(BaseAddress)
#define XUartNs550_mSetLineControlReg(BaseAddress, RegisterValue)
#define XUartNs550_mEnableIntr(BaseAddress)
#define XUartNs550_mDisableIntr(BaseAddress)
#define XUartNs550_mIsReceiveData(BaseAddress)
#define XUartNs550_mIsReceiveData(BaseAddress)
#define XUartNs550_mIsTransmitEmpty(BaseAddress)
```

# **Functions**

Note:

None.

void XUartNs550\_SendByte (Xuint32 BaseAddress, Xuint8 Data)
Xuint8 XUartNs550\_RecvByte (Xuint32 BaseAddress)

# **Define Documentation** #define XUartNs550\_mDisableIntr( BaseAddress ) Disable the transmit and receive interrupts of the UART. **Parameters:** BaseAddress contains the base address of the device. **Returns:** None. Note: None. #define XUartNs550\_mEnableIntr( BaseAddress ) Enable the transmit and receive interrupts of the UART. **Parameters:** BaseAddress contains the base address of the device. **Returns:** None.

### $\# define\ XUartNs550\_mGetLineControlReg(\ BaseAddress\ )$

| Get the UART Line Status Register.                                |
|-------------------------------------------------------------------|
| Parameters:  BaseAddress contains the base address of the device. |
| Returns:  The value read from the register.                       |
| Note: None.                                                       |
| #define XUartNs550_mGetLineStatusReg( BaseAddress )               |
| Get the UART Line Status Register.                                |
| Parameters:  BaseAddress contains the base address of the device. |
| Returns:  The value read from the register.                       |
| Note: None.                                                       |
| #define XUartNs550_mIsReceiveData( BaseAddress )                  |
| Determine if there is receive data in the receiver and/or FIFO.   |
| Parameters:  BaseAddress contains the base address of the device. |
| Returns:  XTRUE if there is receive data, XFALSE otherwise.       |
| Note: None.                                                       |
|                                                                   |

#define XUartNs550\_mIsTransmitEmpty( BaseAddress )



Set the UART Line Status Register.

#### **Parameters:**

BaseAddress contains the base address of the device. RegisterValue is the value to be written to the register.

#### **Returns:**

None.

#### Note:

None.

# #define XUartNs550\_mWriteReg( BaseAddress, RegOffset, RegisterValue )

Write to a UART register.

#### **Parameters:**

BaseAddress contains the base address of the device.

RegOffset contains the offset from the 1st register of the device to select the specific register.

#### **Returns:**

The value read from the register.

#### Note:

None.

# **Function Documentation**

Xuint8 XUartNs550\_RecvByte( Xuint32 BaseAddress)



#### **Returns:**

The data byte received by the UART.

#### Note:

None.

```
void XUartNs550_SendByte( Xuint32 BaseAddress, Xuint8 Data
)
```

This function sends a data byte with the UART. This function operates in the polling mode and blocks until the data has been put into the UART transmit holding register.

#### **Parameters:**

BaseAddress contains the base address of the UART.

Data contains the data byte to be sent.

#### **Returns:**

None.

#### **Note:**

None.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# **XUartNs550Format Struct Reference**

#include <xuartns550.h>

# **Detailed Description**

This data type allows the data format of the device to be set and retrieved.

# **Data Fields**

**Xuint32 BaudRate** 

**Xuint32 DataBits** 

**Xuint32 Parity** 

**Xuint8 StopBits** 

# **Field Documentation**

Xuint32 XUartNs550Format::BaudRate

In bps, ie 1200

Xuint32 XUartNs550Format::DataBits

Number of data bits

Xuint32 XUartNs550Format::Parity

**Parity** 

## Xuint8 XUartNs550Format::StopBits

Number of stop bits

The documentation for this struct was generated from the following file:

• uartns550/v1\_00\_b/src/xuartns550.h

# Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u>

Main Page Data Structures File List Data Fields Globals

# XUartNs550Stats Struct Reference

#include <xuartns550.h>

# **Detailed Description**

**UART** statistics

# **Data Fields**

**Xuint16 TransmitInterrupts** 

**Xuint16 ReceiveInterrupts** 

**Xuint16 StatusInterrupts** 

**Xuint16 ModemInterrupts** 

**Xuint16 CharactersTransmitted** 

**Xuint16 CharactersReceived** 

**Xuint16 ReceiveOverrunErrors** 

**Xuint16 ReceiveParityErrors** 

 ${\bf Xuint 16\ Receive Framing Errors}$ 

**Xuint16 ReceiveBreakDetected** 

# **Field Documentation**

Xuint16 XUartNs550Stats::CharactersReceived

Number of characters received

# Xuint16 XUartNs550Stats::CharactersTransmitted

Number of characters transmitted

#### Xuint16 XUartNs550Stats::ModemInterrupts

Number of modem interrupts

#### Xuint16 XUartNs550Stats::ReceiveBreakDetected

Number of receive breaks

#### Xuint16 XUartNs550Stats::ReceiveFramingErrors

Number of receive framing errors

#### Xuint16 XUartNs550Stats::ReceiveInterrupts

Number of receive interrupts

#### Xuint16 XUartNs550Stats::ReceiveOverrunErrors

Number of receive overruns

### Xuint16 XUartNs550Stats::ReceiveParityErrors

Number of receive parity errors

### Xuint16 XUartNs550Stats::StatusInterrupts

Number of status interrupts

### Xuint16 XUartNs550Stats::TransmitInterrupts

Number of transmit interrupts

The documentation for this struct was generated from the following file:

• uartns550/v1\_00\_b/src/xuartns550.h

# uartns550/v1\_00\_b/src/xuartns550\_g.c File Reference

# **Detailed Description**

This file contains a configuration table that specifies the configuration of NS16550 devices in the system.

#### MODIFICATION HISTORY:

## **Variables**

XUartNs550\_Config XUartNs550\_ConfigTable []

# **Variable Documentation**

#### XUartNs550\_Config XUartNs550\_ConfigTable[]

The configuration table for UART 16550/16450 devices in the table. Each device should have an entry in this table.

# uartns550/v1\_00\_b/src/xuartns550\_format.c

# **Detailed Description**

This file contains the data format functions for the 16450/16550 UART driver. The data format functions allow the baud rate, number of data bits, number of stop bits and parity to be set and retrieved.

MODIFICATION HISTORY:

### **Functions**

XStatus XUartNs550\_SetDataFormat (XUartNs550 \*InstancePtr, XUartNs550Format \*FormatPtr) void XUartNs550\_GetDataFormat (XUartNs550 \*InstancePtr, XUartNs550Format \*FormatPtr)

### **Function Documentation**

Gets the data format for the specified UART. The data format includes the baud rate, number of data bits, number of stop bits, and parity.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

FormatPtr is a pointer to a format structure that will contain the data format after this call completes.

#### **Returns:**

None.

#### Note:

None.

```
XStatus XUartNs550_SetDataFormat( XUartNs550 * InstancePtr, XUartNs550Format * FormatPtr )
```

Sets the data format for the specified UART. The data format includes the baud rate, number of data bits, number of stop bits, and parity. It is the caller's responsibility to ensure that the UART is not sending or receiving data when this function is called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

FormatPtr is a pointer to a format structure containing the data format to be set.

#### **Returns:**

- o XST SUCCESS if the data format was successfully set.
- o XST\_UART\_BAUD\_ERROR indicates the baud rate could not be set because of the amount of error with the baud rate and the input clock frequency.
- o XST\_INVALID\_PARAM if one of the parameters was not valid.

#### Note:

The data types in the format type, data bits and parity, are 32 bit fields to prevent a compiler warning that is a bug with the GNU PowerPC compiler. The asserts in this function will cause a warning if these fields are bytes.

The baud rates tested include: 1200, 2400, 4800, 9600, 19200, 38400, 57600 and 115200.

# uartns550/v1\_00\_b/src/xuartns550\_options.c File Reference

# **Detailed Description**

The implementation of the options functions for the **XUartNs550** driver.

```
MODIFICATION HISTORY:
```

### **Data Structures**

struct Mapping

#include "xio.h"

### **Functions**

```
Xuint16 XUartNs550_GetOptions (XUartNs550 *InstancePtr)

XStatus XUartNs550_SetOptions (XUartNs550 *InstancePtr, Xuint16 Options)

Xuint8 XUartNs550_GetFifoThreshold (XUartNs550 *InstancePtr)

XStatus XUartNs550_SetFifoThreshold (XUartNs550 *InstancePtr, Xuint8 TriggerLevel)

Xuint8 XUartNs550_GetLastErrors (XUartNs550 *InstancePtr)

Xuint8 XUartNs550_GetModemStatus (XUartNs550 *InstancePtr)

Xboolean XUartNs550_IsSending (XUartNs550 *InstancePtr)
```

### **Function Documentation**

#### Xuint8 XUartNs550\_GetFifoThreshold( XUartNs550 \* InstancePtr)

This function gets the receive FIFO trigger level. The receive trigger level indicates the number of bytes in the receive FIFO that cause a receive data event (interrupt) to be generated.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The current receive FIFO trigger level. Constants which define each trigger level are contained in the file **xuartns550.h** and named XUN FIFO TRIGGER \*.

#### Note:

None.

#### Xuint8 XUartNs550\_GetLastErrors( XUartNs550 \* InstancePtr)

This function returns the last errors that have occurred in the specified UART. It also clears the errors such that they cannot be retrieved again. The errors include parity error, receive overrun error, framing error, and break detection.

The last errors is an accumulation of the errors each time an error is discovered in the driver. A status is checked for each received byte and this status is accumulated in the last errors.

If this function is called after receiving a buffer of data, it will indicate any errors that occurred for the bytes of the buffer. It does not indicate which bytes contained errors.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The last errors that occurred. The errors are bit masks that are contained in the file **xuartns550.h** and named XUN ERROR \*.

#### Note:

None.

#### Xuint8 XUartNs550\_GetModemStatus( XUartNs550 \* InstancePtr)

This function gets the modem status from the specified UART. The modem status indicates any changes of the modem signals. This function allows the modem status to be read in a polled mode. The modem status is updated whenever it is read such that reading it twice may not yield the same results.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The modem status which are bit masks that are contained in the file **xuartns550.h** and named XUN\_MODEM\_\*.

#### Note:

The bit masks used for the modem status are the exact bits of the modem status register with no abstraction.

#### Xuint16 XUartNs550\_GetOptions( XUartNs550 \* InstancePtr)

Gets the options for the specified driver instance. The options are implemented as bit masks such that multiple options may be enabled or disabled simulataneously.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

The current options for the UART. The optionss are bit masks that are contained in the file **xuartns550.h** and named XUN\_OPTION\_\*.

#### **Returns:**

None.

#### **Xboolean** XUartNs550\_IsSending( XUartNs550 \* InstancePtr)

This function determines if the specified UART is sending data. If the transmitter register is not empty, it is sending data.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

A value of XTRUE if the UART is sending data, otherwise XFALSE.

#### Note:

None.

This functions sets the receive FIFO trigger level. The receive trigger level specifies the number of bytes in the receive FIFO that cause a receive data event (interrupt) to be generated. The FIFOs must be enabled to set the trigger level.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

TriggerLevel contains the trigger level to set. Constants which define each trigger level are contained in the file xuartns550.h and named XUN FIFO TRIGGER \*.

#### **Returns:**

- o XST\_SUCCESS if the trigger level was set
- XST\_UART\_CONFIG\_ERROR if the trigger level could not be set, either the hardware does not support the FIFOs or FIFOs are not enabled

#### Note:

None.

Sets the options for the specified driver instance. The options are implemented as bit masks such that multiple options may be enabled or disabled simultaneously.

The GetOptions function may be called to retrieve the currently enabled options. The result is ORed in the desired new settings to be enabled and ANDed with the inverse to clear the settings to be disabled. The resulting value is then used as the options for the SetOption function call.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

Options contains the options to be set which are bit masks contained in the file **xuartns550.h** and named XUN\_OPTION\_\*.

#### **Returns:**

- XST\_SUCCESS if the options were set successfully.
- XST\_UART\_CONFIG\_ERROR if the options could not be set because the hardware does not support FIFOs

#### Note:

None.

# uartns550/v1\_00\_b/src/xuartns550\_intr.c File Reference

# **Detailed Description**

This file contains the functions that are related to interrupt processing for the 16450/16550 UART driver.

```
MODIFICATION HISTORY:
```

### **Functions**

```
void XUartNs550_SetHandler (XUartNs550 *InstancePtr, XUartNs550_Handler FuncPtr, void *CallBackRef)
void XUartNs550_InterruptHandler (XUartNs550 *InstancePtr)
```

# **Function Documentation**

This function is the interrupt handler for the 16450/16550 UART driver. It must be connected to an interrupt system by the user such that it is called when an interrupt for any 16450/16550 UART occurs. This function does not save or restore the processor context such that the user must ensure this occurs.

#### **Parameters:**

InstancePtr contains a pointer to the instance of the UART that the interrupt is for.

#### **Returns:**

None.

#### **Note:**

None.

This function sets the handler that will be called when an event (interrupt) occurs in the driver. The purpose of the handler is to allow application specific processing to be performed.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

FuncPtr is the pointer to the callback function.

CallBackRef is the upper layer callback reference passed back when the callback function is invoked.

#### **Returns:**

None.

#### **Note:**

There is no assert on the CallBackRef since the driver doesn't know what it is (nor should it)

# uartns550/v1\_00\_b/src/xuartns550\_l.c File Reference

# **Detailed Description**

This file contains low-level driver functions that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation.

#### MODIFICATION HISTORY:

# **Functions**

```
void XUartNs550_SendByte (Xuint32 BaseAddress, Xuint8 Data)
Xuint8 XUartNs550_RecvByte (Xuint32 BaseAddress)
```

# **Function Documentation**

Xuint8 XUartNs550\_RecvByte(Xuint32 BaseAddress)



#### **Returns:**

The data byte received by the UART.

#### Note:

None.

```
void XUartNs550_SendByte( Xuint32 BaseAddress, Xuint8 Data
)
```

This function sends a data byte with the UART. This function operates in the polling mode and blocks until the data has been put into the UART transmit holding register.

#### **Parameters:**

BaseAddress contains the base address of the UART.

Data contains the data byte to be sent.

#### **Returns:**

None.

#### **Note:**

None.

# uartns550/v1\_00\_b/src/xuartns550\_selftest.c File Reference

# **Detailed Description**

This file contains the self-test functions for the 16450/16550 UART driver.

MODIFICATION HISTORY:

### **Functions**

XStatus XUartNs550\_SelfTest (XUartNs550 \*InstancePtr)

## **Function Documentation**

XStatus XUartNs550\_SelfTest( XUartNs550 \* InstancePtr)

This functions runs a self-test on the driver and hardware device. This self test performs a local loopback and verifies data can be sent and received.

The statistics are cleared at the end of the test. The time for this test to execute is proportional to the baud rate that has been set prior to calling this function.

#### **Parameters:**

*InstancePtr* is a pointer to the **XUartNs550** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if the test was successful
- o XST\_UART\_TEST\_FAIL if the test failed looping back the data

#### **Note:**

This function can hang if the hardware is not functioning properly.

# common/v1\_00\_a/src/xutil.h File Reference

# **Detailed Description**

This file contains utility functions such as memory test functions.

#### **Memory test description**

A subset of the memory tests can be selected or all of the tests can be run in order. If there is an error detected by a subtest, the test stops and the failure code is returned. Further tests are not run even if all of the tests are selected.

#### Subtest descriptions:

```
XUT ALLMEMTESTS:
      Runs all of the following tests
XUT INCREMENT:
      Incrementing Value Test.
      This test starts at 'XUT_MEMTEST_INIT_VALUE' and uses the incrementing
      value as the test value for memory.
XUT_WALKONES:
      Walking Ones Test.
      This test uses a walking '1' as the test value for memory.
      location 1 = 0 \times 00000001
      location 2 = 0 \times 00000002
XUT_WALKZEROS:
      Walking Zero's Test.
      This test uses the inverse value of the walking ones test
      as the test value for memory.
      location 1 = 0xFFFFFFFE
      location 2 = 0xFFFFFFD
XUT INVERSEADDR:
      Inverse Address Test.
      This test uses the inverse of the address of the location under test
      as the test value for memory.
```

#### XUT FIXEDPATTERN:

```
Fixed Pattern Test.

This test uses the provided patters as the test value for memory.

If zero is provided as the pattern the test uses '0xDEADBEEF".
```

#### **WARNING**

The tests are **DESTRUCTIVE**. Run before any initialized memory spaces have been set up.

The address, Addr, provided to the memory tests is not checked for validity except for the XNULL case. It is possible to provide a code-space pointer for this test to start with and ultimately destroy executable code causing random failures.

#### Note:

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

#### MODIFICATION HISTORY:

# **Memory subtests**

```
#define XUT_ALLMEMTESTS
#define XUT_INCREMENT
#define XUT_WALKONES
#define XUT_WALKZEROS
#define XUT_INVERSEADDR
#define XUT_FIXEDPATTERN
#define XUT_MAXTEST
```

## **Functions**

# **Define Documentation**

#### #define XUT ALLMEMTESTS

See the detailed description of the subtests in the file description.

#### #define XUT\_FIXEDPATTERN

See the detailed description of the subtests in the file description.

#### #define XUT\_INCREMENT

See the detailed description of the subtests in the file description.

#### #define XUT\_INVERSEADDR

See the detailed description of the subtests in the file description.

#### #define XUT\_MAXTEST

See the detailed description of the subtests in the file description.

#### #define XUT\_WALKONES

See the detailed description of the subtests in the file description.

#### #define XUT\_WALKZEROS

See the detailed description of the subtests in the file description.

# **Function Documentation**

Performs a destructive 16-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

*Words* is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See **xutil.h** for possible values.

#### **Returns:**

- o XST MEMTEST FAILED is returned for a failure
- o XST SUCCESS is returned for a pass

#### Note:

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

Performs a destructive 32-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

*Words* is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See **xutil.h** for possible values.

#### **Returns:**

- o XST MEMTEST FAILED is returned for a failure
- o XST\_SUCCESS is returned for a pass

#### Note:

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

Performs a destructive 8-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

Words is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See xutil.h for possible values.

#### **Returns:**

- XST\_MEMTEST\_FAILED is returned for a failure
- o XST\_SUCCESS is returned for a pass

#### **Note:**

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

# common/v1\_00\_a/src/xutil\_memtest.c File Reference

# **Detailed Description**

Contains the memory test utility functions.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
-----1.00a ecm 11/01/01 First release

#include "xbasic_types.h"
#include "xstatus.h"
#include "xutil.h"
```

# **Functions**

```
XStatus XUtil_MemoryTest32 (Xuint32 *Addr, Xuint32 Words, Xuint32 Pattern, Xuint8 Subtest)
XStatus XUtil_MemoryTest16 (Xuint16 *Addr, Xuint32 Words, Xuint16 Pattern, Xuint8 Subtest)
XStatus XUtil_MemoryTest8 (Xuint8 *Addr, Xuint32 Words, Xuint8 Pattern, Xuint8 Subtest)
```

# **Function Documentation**

Performs a destructive 16-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

*Words* is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See xutil.h for possible values.

#### **Returns:**

- XST\_MEMTEST\_FAILED is returned for a failure
- o XST\_SUCCESS is returned for a pass

#### Note:

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

Performs a destructive 32-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

Words is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See **xutil.h** for possible values.

#### **Returns:**

- XST\_MEMTEST\_FAILED is returned for a failure
- XST\_SUCCESS is returned for a pass

#### Note:

Used for spaces where the address range of the region is smaller than the data width. If the memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

Performs a destructive 8-bit wide memory test.

#### **Parameters:**

Addr is a pointer to the region of memory to be tested.

Words is the length of the block.

Pattern is the constant used for the constant pattern test, if 0, 0xDEADBEEF is used.

Subtest is the test selected. See xutil.h for possible values.

#### **Returns:**

- XST\_MEMTEST\_FAILED is returned for a failure
- XST\_SUCCESS is returned for a pass

#### **Note:**

Used for spaces where the address range of the region is smaller than the data width. If the

memory range is greater than 2 \*\* width, the patterns used in XUT\_WALKONES and XUT\_WALKZEROS will repeat on a boundry of a power of two making it more difficult to detect addressing errors. The XUT\_INCREMENT and XUT\_INVERSEADDR tests suffer the same problem. Ideally, if large blocks of memory are to be tested, break them up into smaller regions of memory to allow the test patterns used not to repeat over the region tested.

# wdttb/v1\_00\_b/src/xwdttb\_i.h File Reference

# **Detailed Description**

This file contains data which is shared between files and internal to the **XWdtTb** component. It is intended for internal use only.

#### MODIFICATION HISTORY:

# **Variables**

XWdtTb\_Config XWdtTb\_ConfigTable []

# **Variable Documentation**

#### XWdtTb\_Config XWdtTb\_ConfigTable[]( )

This table contains configuration information for each watchdog timer device in the system.

# Xilinx Device Drivers <u>Driver Summary Copyright</u> Main Page Data Structures File List Data Fields Globals

# XWdtTb Struct Reference

#include <xwdttb.h>

# **Detailed Description**

The XWdtTb driver instance data. The user is required to allocate a variable of this type for every watchdog/timer device in the system. A pointer to a variable of this type is then passed to the driver API functions.

The documentation for this struct was generated from the following file:

• wdttb/v1\_00\_b/src/xwdttb.h

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# wdttb/v1\_00\_b/src/xwdttb.h File Reference

## **Detailed Description**

The Xilinx watchdog timer/timebase component supports the Xilinx watchdog timer/timebase hardware. More detailed description of the driver operation for each function can be found in the **xwdttb.c** file.

The Xilinx watchdog timer/timebase driver supports the following features:

- Polled mode
- enabling and disabling (if allowed by the hardware) the watchdog timer
- restarting the watchdog.
- reading the timebase.

It is the responsibility of the application to provide an interrupt handler for the timebase and the watchdog and connect them to the interrupt system if interrupt driven mode is desired.

The watchdog timer/timebase component ALWAYS generates an interrupt output when:

- the watchdog expires the first time
- the timebase rolls over

and ALWAYS generates a reset output when the watchdog timer expires a second time. This is not configurable in any way from the software driver's perspective.

The Timebase is reset to 0 when the Watchdog Timer is enabled.

If the hardware interrupt signal is not connected, polled mode is the only option (using IsWdtExpired) for the watchdog. Reset output will occur for the second watchdog timeout regardless. Polled mode for the timebase rollover is just reading the contents of the register and seeing if the MSB has transitioned from 1 to 0.

The IsWdtExpired function is used for polling the watchdog timer and it is also used to check if the watchdog was the cause of the last reset. In this situation, call Initialize then call WdtIsExpired. If the result is true watchdog timeout caused the last system reset. It is then acceptable to further initialize the component which will reset this bit.

This driver is intended to be RTOS and processor independent. It works with physical addresses only. Any needs for dynamic memory management, threads or thread mutual exclusion, virtual memory, or cache control must be satisfied by the layer above this driver.

#### MODIFICATION HISTORY:

### **Data Structures**

```
struct XWdtTb struct XWdtTb_Config
```

## **Functions**

```
XStatus XWdtTb_Initialize (XWdtTb *InstancePtr, Xuint16 DeviceId)
void XWdtTb_Start (XWdtTb *InstancePtr)
XStatus XWdtTb_Stop (XWdtTb *InstancePtr)
Xboolean XWdtTb_IsWdtExpired (XWdtTb *InstancePtr)
void XWdtTb_RestartWdt (XWdtTb *InstancePtr)
Xuint32 XWdtTb_GetTbValue (XWdtTb *InstancePtr)
XStatus XWdtTb_SelfTest (XWdtTb *InstancePtr)
```

## **Function Documentation**

#### Xuint32 XWdtTb\_GetTbValue( XWdtTb \* InstancePtr)

Returns the current contents of the timebase.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

The contents of the timebase.

#### Note:

None.

Initialize a specific watchdog timer/timebase instance/driver. This function must be called before other functions of the driver are called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XWdtTb** instance. Passing in a device id associates the generic **XWdtTb** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST\_DEVICE\_IS\_STARTED if the device has already been started
- o XST\_DEVICE\_NOT\_FOUND if the configuration for device ID was not found

#### Note:

None.

### **Xboolean XWdtTb\_IsWdtExpired( XWdtTb** \* *InstancePtr*)

Check if the watchdog timer has expired. This function is used for polled mode and it is also used to check if the last reset was caused by the watchdog timer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

XTRUE if the watchdog has expired, and XFALSE otherwise.

#### Note:

None.

#### void XWdtTb\_RestartWdt( XWdtTb \* InstancePtr)

Restart the watchdog timer. An application needs to call this function periodically to keep the timer from asserting the reset output.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

#### XStatus XWdtTb\_SelfTest( XWdtTb \* InstancePtr)

Run a self-test on the timebase. This test verifies that the timebase is incrementing. The watchdog timer is not tested due to the time required to wait for the watchdog timer to expire. The time consumed by this test is dependant on the system clock and the configuration of the dividers in for the input clock of the timebase.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if self-test was successful
- o XST\_WDTTB\_TIMER\_FAILED if the timebase is not incrementing

#### Note:

#### void XWdtTb\_Start( XWdtTb \* InstancePtr)

Start the watchdog timer of the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The Timebase is reset to 0 when the Watchdog Timer is started. The Timebase is always incrementing

#### XStatus XWdtTb\_Stop( XWdtTb \* InstancePtr)

Disable the watchdog timer.

It is the caller's responsibility to disconnect the interrupt handler of the watchdog timer from the interrupt source, typically an interrupt controller, and disable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the watchdog was stopped successfully
- XST\_NO\_FEATURE if the watchdog cannot be stopped

#### Note:

The hardware configuration controls this functionality. If it is not allowed by the hardware the failure will be returned and the timer will continue without interruption.

# wdttb/v1\_00\_b/src/xwdttb.c File Reference

## **Detailed Description**

Contains the required functions of the **XWdtTb** driver component. See **xwdttb.h** for a description of the driver.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes

1.00a ecm 08/16/01 First release
1.00b jhl 02/21/02 Repartitioned the driver for smaller files
1.00b rpm 04/26/02 Made LookupConfig public

#include "xbasic_types.h"
#include "xparameters.h"
#include "xio.h"
#include "xwdttb.h"
#include "xwdttb.h"
```

### **Functions**

```
XStatus XWdtTb_Initialize (XWdtTb *InstancePtr, Xuint16 DeviceId)
void XWdtTb_Start (XWdtTb *InstancePtr)
XStatus XWdtTb_Stop (XWdtTb *InstancePtr)
Xboolean XWdtTb_IsWdtExpired (XWdtTb *InstancePtr)
void XWdtTb_RestartWdt (XWdtTb *InstancePtr)
```

## **Function Documentation**

#### Xuint32 XWdtTb\_GetTbValue( XWdtTb \* InstancePtr)

Returns the current contents of the timebase.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

The contents of the timebase.

#### Note:

None.

Initialize a specific watchdog timer/timebase instance/driver. This function must be called before other functions of the driver are called.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

DeviceId is the unique id of the device controlled by this **XWdtTb** instance. Passing in a device id associates the generic **XWdtTb** instance to a specific device, as chosen by the caller or application developer.

#### **Returns:**

- XST\_SUCCESS if initialization was successful
- o XST DEVICE IS STARTED if the device has already been started
- o XST\_DEVICE\_NOT\_FOUND if the configuration for device ID was not found

#### **Note:**

None.

### **Xboolean XWdtTb\_IsWdtExpired( XWdtTb** \* *InstancePtr*)

Check if the watchdog timer has expired. This function is used for polled mode and it is also used to check if the last reset was caused by the watchdog timer.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

XTRUE if the watchdog has expired, and XFALSE otherwise.

#### Note:

None.

#### void XWdtTb\_RestartWdt( XWdtTb \* InstancePtr)

Restart the watchdog timer. An application needs to call this function periodically to keep the timer from asserting the reset output.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

None.

#### **Note:**

None.

void XWdtTb\_Start( XWdtTb \* InstancePtr)

Start the watchdog timer of the device.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

None.

#### Note:

The Timebase is reset to 0 when the Watchdog Timer is started. The Timebase is always incrementing

#### XStatus XWdtTb\_Stop( XWdtTb \* InstancePtr)

Disable the watchdog timer.

It is the caller's responsibility to disconnect the interrupt handler of the watchdog timer from the interrupt source, typically an interrupt controller, and disable the interrupt in the interrupt controller.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

- XST\_SUCCESS if the watchdog was stopped successfully
- XST\_NO\_FEATURE if the watchdog cannot be stopped

#### Note:

The hardware configuration controls this functionality. If it is not allowed by the hardware the failure will be returned and the timer will continue without interruption.

# wdttb/v1\_00\_b/src/xwdttb\_l.h File Reference

## **Detailed Description**

This header file contains identifiers and low-level driver functions (or macros) that can be used to access the device. High-level driver functions are defined in **xwdttb.h**.

```
MODIFICATION HISTORY:
```

```
Ver Who Date Changes
----- 1.00b rpm 04/26/02 First release
#include "xbasic_types.h"
#include "xio.h"
```

## **Defines**

```
#define XWdtTb_mGetTimebaseReg(BaseAddress)
#define XWdtTb_mEnableWdt(BaseAddress)
#define XWdtTb_mDisableWdt(BaseAddress)
#define XWdtTb_mRestartWdt(BaseAddress)
#define XWdtTb_mHasReset(BaseAddress)
#define XWdtTb_mHasExpired(BaseAddress)
```

### **Define Documentation**

| #define XWdtTb_mDisableWdt( BaseAddress )                                          |
|------------------------------------------------------------------------------------|
| Disable the watchdog timer.                                                        |
| Parameters:                                                                        |
| BaseAddress is the base address of the device                                      |
| Returns:                                                                           |
| None.                                                                              |
| Note:                                                                              |
| None.                                                                              |
|                                                                                    |
| #define XWdtTb_mEnableWdt( BaseAddress )                                           |
|                                                                                    |
| Enable the watchdog timer. Clear previous expirations. The timebase is reset to 0. |
| Parameters:                                                                        |
| BaseAddress is the base address of the device                                      |
|                                                                                    |
| Returns: None.                                                                     |
| None.                                                                              |
| Note:                                                                              |
| None.                                                                              |
|                                                                                    |
| #Joffing VIVIATE in CotTime has a Dog ( Dogs Address )                             |
| #define XWdtTb_mGetTimebaseReg( BaseAddress )                                      |
| Get the contents of the timebase register.                                         |
| Parameters:                                                                        |
| BaseAddress is the base address of the device                                      |
|                                                                                    |
| Returns:  A 32-bit value representing the timebase.                                |
| 11 32 oft value representing the timeouse.                                         |
| Note:                                                                              |

None.

| #define XWdtTb_mHasExpired( BaseAddress )                                   |  |
|-----------------------------------------------------------------------------|--|
| Check to see if the watchdog timer has expired.                             |  |
| Parameters:                                                                 |  |
| BaseAddress is the base address of the device                               |  |
| Returns:  XTRUE if the watchdog did expire, XFALSE otherwise.               |  |
| Note: None.                                                                 |  |
| #define XWdtTb_mHasReset( BaseAddress )                                     |  |
| Check to see if the last system reset was caused by the timer expiring.     |  |
| Parameters:  BaseAddress is the base address of the device                  |  |
| Returns:  XTRUE if the watchdog did cause the last reset, XFALSE otherwise. |  |
| Note: None.                                                                 |  |
| #define XWdtTb_mRestartWdt( BaseAddress )                                   |  |
| Restart the watchdog timer.                                                 |  |
| Parameters:  BaseAddress is the base address of the device                  |  |
| Returns: None.                                                              |  |
| Note: None.                                                                 |  |

## Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

## XWdtTb\_Config Struct Reference

#include <xwdttb.h>

## **Detailed Description**

This typedef contains configuration information for the device.

## **Data Fields**

Xuint16 DeviceId Xuint32 BaseAddr

## **Field Documentation**

Xuint32 XWdtTb\_Config::BaseAddr

Base address of the device

Xuint16 XWdtTb\_Config::DeviceId

Unique ID of device

The documentation for this struct was generated from the following file:

wdttb/v1\_00\_b/src/xwdttb.h

## wdttb/v1\_00\_b/src/xwdttb\_g.c File Reference

## **Detailed Description**

This file contains a table that specifies the configuration of all watchdog timer devices in the system. Each device should have an entry in the table.

#### MODIFICATION HISTORY:

### **Variables**

XWdtTb\_Config XWdtTb\_ConfigTable [XPAR\_XWDTTB\_NUM\_INSTANCES]

### **Variable Documentation**

#### XWdtTb\_Config XWdtTb\_ConfigTable[XPAR\_XWDTTB\_NUM\_INSTANCES]

This table contains configuration information for each watchdog timer device in the system.

## wdttb/v1\_00\_b/src/xwdttb\_selftest.c File Reference

## **Detailed Description**

Contains diagnostic self-test functions for the **XWdtTb** component.

MODIFICATION HISTORY:

### **Functions**

XStatus XWdtTb\_SelfTest (XWdtTb \*InstancePtr)

## **Function Documentation**

XStatus XWdtTb\_SelfTest( XWdtTb \* InstancePtr)

Run a self-test on the timebase. This test verifies that the timebase is incrementing. The watchdog timer is not tested due to the time required to wait for the watchdog timer to expire. The time consumed by this test is dependant on the system clock and the configuration of the dividers in for the input clock of the timebase.

#### **Parameters:**

*InstancePtr* is a pointer to the **XWdtTb** instance to be worked on.

#### **Returns:**

- o XST\_SUCCESS if self-test was successful
- o XST\_WDTTB\_TIMER\_FAILED if the timebase is not incrementing

#### **Note:**

None.

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# emc/v1\_00\_a/src/xemc\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of EMC devices in the system. In addition, there is a lookup function used by the driver to access its configuration information.

#### MODIFICATION HISTORY:

# iic/v1\_01\_c/src/xiic\_slave.c File Reference

## **Detailed Description**

Contains slave functions for the **XIic** component. This file is necessary when slave operations, sending and receiving data as a slave on the IIC bus, are desired.

#### MODIFICATION HISTORY:

#### Xilinx Device Drivers

#### **Driver Summary** Copyright

Main Page Data Structures File List Data Fields Globals

# intc/v1\_00\_b/src/xintc\_lg.c File Reference

## **Detailed Description**

This file contains the generated configuration data for the low level driver of the interrupt controller.

MODIFICATION HISTORY:

## Xilinx Device Drivers <u>Driver Summary</u> <u>Copyright</u> Main Page Data Structures File List Data Fields Globals

# pci/v1\_00\_a/src/xpci\_g.c File Reference

## **Detailed Description**

This file contains a configuration table that specifies the configuration of PCI devices in the system.

#### Note:

None.

```
#include "xpci.h"
#include "xparameters.h"
```

#### Xilinx Device Drivers

#### Driver Summary Copyright

Main Page Data Structures File List Data Fields Globals

# tmrctr/v1\_00\_b/src/xtmrctr\_l.c File Reference

## **Detailed Description**

This file contains low-level driver functions that can be used to access the device. The user should refer to the hardware device specification for more details of the device operation.

#### MODIFICATION HISTORY:

```
Ver Who Date Changes
----- 1.00b jhl 04/24/02 First release

#include "xbasic_types.h"
#include "xtmrctr_1.h"
```