

# Designing Embedded AXI Based Direct Memory Access System

Mazin Rejab Khalil<sup>1</sup>, Rafal Taha Mahmood<sup>2</sup>

<sup>1</sup>Assistant Professor, Computer Engineering, Technical College, Mosul, Iraq <sup>2</sup>MA Student Research Stage, Computer Engineering, Technical College, Mosul, Iraq

#### **ABSTRACT**

The work aims to design a soft core processor system with Advanced eXtensible Interface (AXI) processor bus which deals with different data capacities with 32, 64, 128, and 256 bits data width. The system deals with Direct Memory Access (DMA) unit to transfer data between the system memory and external peripheral. Memory Controller Block – Dual Data Rate (MCB-DDR2) external memory is introduced to act as main memory system. Embedded design techniques were applied to construct the processor system which is to be configured on Spartan-6 (SP601) Field Programmable Gate Arrays (FPGAs) slice.

Integrated Software Environment (ISE 13.2) is used for system development and programming the hardware with suitable application program.

## 1. INTRODUCTION

Embedded design techniques tools are used now a day to design embedded processor system to be configured on FPGAs. Processor system usually consist a soft core processor (MicroBlaze) or hard processor (PowerPC), processor bus, memories and peripherals. The most commonly used buses in such a type of system are Processor Local Bus (PLB v4.6). In [1] a DMA controller is designed to act with Micro blaze processor system configured on Spartan-3A FPGAs. The system is designed to perform data transfer between the internal block RAM an external peripheral.

- In [2] a DMA system is depicted to act with multiprocessor connected via On-chip Processer Bus (OPB).
- In [3] a DMA mode is proposed to act as a universal synchronous/ a synchronous Receiver/Transmitter (USART) IP soft core in Altera kit with AVALON bus.

In the work AXI processor bus is used instead of PLB processor bus with adding a MCB-DDR2 external memory. AXI processor system must be adapted to deal with different data width due to application diversities to cope with this challenge the need for a flexible processor bus arose. Xilinx Company developed and advanced extensible bus interface (AXI) that is configurable on Spartan-6 FPGAs. Figure (1) shows the AXI interconnect core block diagram [4].



Figure 1. AXI Interconnect Core Block Diagram



# International Journal of Enhanced Research in Science, Technology & Engineering ISSN: 2319-7463, Vol. 4 Issue 8, August-2015

The AXI Interconnect core consists of the SI (AXI Interconnect Slave Interface), the MI (AXI Interconnect Master Interface) and the functional units that comprise the AXI channel pathways between them. The SI accepts Write and Read transaction requests from connected master devices. The MI issues transactions to slave devices. At the center is the crossbar that routes traffic on all the AXI channels between the various devices connected to the SI and MI. The AXI Interconnect core also comprises other functional units located between the crossbar and each of the interfaces that perform various conversion and storage functions. The crossbar effectively splits the AXI Interconnect core down the middle between the SI-related functional units (SI hemisphere) and the MI-related units (MI hemisphere). [4]

The Central Direct Memory Access (AXI CDMA) core is a soft Xilinx IP core that can be introduced to the designed soft core processor system. The AXI CDMA provides high-bandwidth direct memory access (DMA) between a memory mapped source address and a memory mapped destination address using the AXI4 protocol. Initialization, status, and control registers are accessed through an AXI4-Lite slave interface, suitable for the Xilinx MicroBlaz microprocessor. Figure (2) shows the block diagram of AXI-CDMA Intellectual Property (IP) core [5].



Figure 2. The Block Diagram of AXI-CDMA

The basic core design has an AXI4 Master interface for the main CDMA data transport function and an AXI4-Lite Slave interface for register accesses. The core's control and status registers are included in the Register Module. Access to these registers is provided through the AXI4-Lite Slave interface. The register module provides control and status for all CDMA operations. Primary high-speed CDMA data transport is provided by the AXI DataMover helper core. The AXI DataMover is used for high-throughput transfer of data from AXI4 to AXI4-Stream and from AXI4-Stream to AXI4. The DataMover provides CDMA operations with 4 kbyte address boundary protection, automatic burst partitioning, as well as providing the ability to queue multiple transfer requests. Furthermore, the AXI DataMover provides byte-level data realignment (for 32-bit and 64-bit data widths) allowing the CDMA to read from and write to any byte offset combination [5].

The AXI Centralized DMA provides the same simple transfer mode operation as the legacy PLBv4.6 Centralized DMA. A simple mode transfer is defined as that which the CPU programs the Centralized DMA register set for a single transfer and then initiates the transfer. The Centralized DMA:

- Performs the transfer
- Generates an interrupt when the transfer is complete
- Waits for the microprocessor to program and start the next transfer



# International Journal of Enhanced Research in Science, Technology & Engineering ISSN: 2319-7463, Vol. 4 Issue 8, August-2015

Also, the AXI Centralized DMA includes an optional data realignment function for 32- and 64-bit bus widths. This feature allows addressing independence between the transfer source and destination addresses [6].

The suggested procedure in the work starts by constructing the embedded processor system, introducing the AXI-CDMA controller to the system and programming the resultant hardware using C language to accommodate the system to operate in CDMA mode. The results are displayed at Hyper Terminal media and real time chip scope window.

## 2. SYSTEM DESIGN

The system under consideration is designed with in two stages:

- 1) The hardware part of the soft processor system is constructed, and then the AXI-CDMA controller core is added to the system.
- 2) In the software part the resultant hardware is programmed by C language to make the system operate in a CDMA mode.

# A. Hardware Part Development

The hardware part includes the processor (MicroBlaze), AXI bus, CDMA unit, DDR2 Interface (128 MB), External Memory Controller (EMC), BRAM, Networking, Interrupt Controller, General purpose Input/output (GPIO), Floating Point Unit (FPU) and MicroBlaze Debug Module (MDM). It is developed in the Xilinx Platform Studio (XPS) and its component is defined in Microprocessor Hardware Specification (MHS) file, figure (3) displays the block diagram of the designed hardware part [5].



Figure 3. The Block Diagram of the Designed System

The CDMA IP core is added to the system using the following steps:

- Instantiate the IP core from Pcore files to the system.
- Making bus connections for master and slave part.
- Making port connections between the IP and the AXI bus.
- Configuring the IP module parameter to cope with the system criteria.



- Generating an address to the added IP within the system address map.
- Rescan the system to sense the newly added IP.

# **B.** Software Part Development

C- Program is developed to be run on the processor to make the system act in DMA mode. Figure (4) shows the flow chart of the prepared program.



Figure 4. The flow chart of designed system programming



## 3. RESULTS

Figure (5) shown the resulting hardware part of the system, figure (5-a) shows the assembly view and figure (5-b) shows the address map of the designed system issued by the platform studio XPS.



a



b

Figure 5. The hardware part of designed soft core when adding DMA core

- a. The assembly view of the system.
- b. The address map of the system.



Figure (6) shows the data read from destination buffer and the data transferred from the source buffer displayed in hyper terminal window.



Figure 6. The data transfer from source to destination buffer

Figure (7) shows the operation of data transfer displayed on chip scope window during write data bus cycle.



Figure 7. Data transfer based on CDMA operation displayed on chip scope window



# International Journal of Enhanced Research in Science, Technology & Engineering ISSN: 2319-7463, Vol. 4 Issue 8, August-2015

#### 4. Conclusions

Adding extensible processor bus (AXI) offers the DMA based processor system high flexibility as the data width between the source and destination peripherals will not be restricted to fixed widths. The data width between destination and source can be (32/32, 32/64, 32/128, 64/32, 64/64, 64/128, 128/128, 128/64, 128/32).

AXI also provides facility to use different source/destination data flow rates. This flexibility enables the processor system to be used with various applications.

## 5. References

- [1]. Bakshi A. B., Burman A. B., & Chakraborty A. Ch., 2014, "Development of DMA controller for real time data processing in FPGA based embedded application", IOSR Journal of VLSI and Signal Processing (IOSR-JVSP). e-ISSN: 2319-4200, p-ISSN No.: 2319-4197, <a href="https://www.iosrjournals.org">www.iosrjournals.org</a>, PP 01-08.
- [2]. Tumeo A. T., Monchiero M. M., Palermo G. P., Ferrandi F. F. & Sciuto D. S., 2008, "Lightweight DMA Management Mechanisms for Multiprocessors on FPGA", 1-4244-1898-5/08/\$20.00 IEEE .
- [3]. Allam P. A., 2013, "Design And Implementation Of USART IP Soft Core Based On DMA Mode", International Journal of Computer Trends and Technology (IJCTT), ISSN:2231-2803, <a href="http://www.ijcttjourmal.org">http://www.ijcttjourmal.org</a>, page no.:3580-3584.
- [4]. XILINX, 2011, "LogiCORE IP AXI Interconnect (v1.03.a)", web site: www.xilinx.com, DS768.
- [5]. XILINX, 2011, "LogiCORE IP AXI Central Direct Memory Access (axi\_cdma) (v3.01.a)", web site: www.xilinx.com, DS792.
- [6]. XILINX, 2011, "AXI Reference Guide", web site: www.xilinx.com, UG761.